include all og gradio into gradio js

This commit is contained in:
Ali Abid 2020-08-14 12:34:26 -07:00
parent 71aac29097
commit f9e35de8aa
9 changed files with 187 additions and 189 deletions

View File

@ -135,7 +135,6 @@ def serve_files_in_background(interface, port, directory_to_serve=None, server_n
def end_headers(self): def end_headers(self):
self.send_header('Access-Control-Allow-Origin', '*') self.send_header('Access-Control-Allow-Origin', '*')
self.send_header('Access-Control-Allow-Methods', 'GET, POST') self.send_header('Access-Control-Allow-Methods', 'GET, POST')
self.send_header('Cache-Control', 'no-store, no-cache, must-revalidate')
return super(HTTPHandler, self).end_headers() return super(HTTPHandler, self).end_headers()
def translate_path(self, path): def translate_path(self, path):

View File

@ -26,17 +26,17 @@ button, input[type="submit"], input[type="reset"], input[type="button"], select[
text-align: right; text-align: right;
font-family: monospace; font-family: monospace;
} }
#share { .share {
text-align: center; text-align: center;
margin-bottom: 10px; margin-bottom: 10px;
font-size: 14px; font-size: 14px;
} }
#share-copy { .share-copy {
background-color: whitesmoke; background-color: whitesmoke;
padding: 4px; padding: 4px;
border-radius: 2px; border-radius: 2px;
} }
#title { .title {
text-align: center; text-align: center;
} }
.container { .container {
@ -58,7 +58,7 @@ button.secondary {
color: black; color: black;
background-color: #F6F6F6; background-color: #F6F6F6;
} }
#examples table { .examples table {
border-collapse: collapse; border-collapse: collapse;
font-family: monospace; font-family: monospace;
padding: 8px; padding: 8px;
@ -67,20 +67,20 @@ button.secondary {
border-left: solid 4px whitesmoke; border-left: solid 4px whitesmoke;
border-bottom: solid 4px whitesmoke; border-bottom: solid 4px whitesmoke;
} }
#examples th { .examples th {
padding: 8px 16px; padding: 8px 16px;
text-align: left; text-align: left;
font-size: 18px; font-size: 18px;
} }
#examples td { .examples td {
padding: 8px; padding: 8px;
cursor: pointer; cursor: pointer;
} }
#examples tbody tr:nth-child(odd) { .examples tbody tr:nth-child(odd) {
background-color: white; background-color: white;
} }
#examples tbody tr:hover { .examples tbody tr:hover {
background-color: lightgray; background-color: lightgray;
} }
#credit { #credit {

View File

@ -1,6 +1,13 @@
function gradio(config, fn, target) { function gradio(config, fn, target) {
target = $(target); target = $(target);
target.html(` target.html(`
<div class="share invisible">
Live at <a class="share-link" target="_blank"></a>.
<button class="share-copy">Copy Link</button>
</div>
<div class="container">
<h1 class="title"></h1>
<p class="description"></p>
<div class="panels"> <div class="panels">
<div class="panel input_panel"> <div class="panel input_panel">
<div class="input_interfaces"> <div class="input_interfaces">
@ -12,19 +19,26 @@ function gradio(config, fn, target) {
</div> </div>
<div class="panel output_panel"> <div class="panel output_panel">
<div class="loading invisible"> <div class="loading invisible">
<img class="loading_in_progress" src="static/img/logo_loading.gif"> <img class="loading_in_progress" src="/static/img/logo_loading.gif">
<img class="loading_failed" src="static/img/logo_error.png"> <img class="loading_failed" src="/static/img/logo_error.png">
</div> </div>
<div class="output_interfaces"> <div class="output_interfaces">
</div> </div>
<div class="panel_buttons"> <div class="panel_buttons">
<input class="screenshot panel_button" type="button" value="SCREENSHOT"/> <input class="screenshot panel_button" type="button" value="SCREENSHOT"/>
<div class="screenshot_logo"> <div class="screenshot_logo">
<img src="static/img/logo_inline.png"> <img src="/static/img/logo_inline.png">
</div> </div>
<input class="flag panel_button" type="button" value="FLAG"/> <input class="flag panel_button" type="button" value="FLAG"/>
</div> </div>
</div>`); </div>
</div>
<div class="examples invisible">
<h3>Examples <small>(click to load)</small></h3>
<table>
</table>
</div>
`);
let io_master = Object.create(io_master_template); let io_master = Object.create(io_master_template);
io_master.fn = fn io_master.fn = fn
io_master.target = target; io_master.target = target;
@ -65,6 +79,22 @@ function gradio(config, fn, target) {
interface.id = id; interface.id = id;
id_to_interface_map[id] = interface; id_to_interface_map[id] = interface;
} }
if (config["title"]) {
target.find(".title").text(config["title"]);
}
if (config["description"]) {
target.find(".description").text(config["description"]);
}
if (config["share_url"]) {
let share_url = config["share_url"];
target.find(".share").removeClass("invisible");
target.find(".share-link").text(share_url).attr("href", share_url);
target.find(".share-copy").click(function() {
copyToClipboard(share_url);
target.find(".share-copy").text("Copied!");
})
};
_id = 0; _id = 0;
let input_interfaces = []; let input_interfaces = [];
@ -147,6 +177,34 @@ function gradio(config, fn, target) {
target.find(".screenshot").css("visibility", "visible"); target.find(".screenshot").css("visibility", "visible");
target.find(".flag").css("visibility", "visible") target.find(".flag").css("visibility", "visible")
} }
if (config["examples"]) {
target.find(".examples").removeClass("invisible");
let html = "<thead>"
for (let i = 0; i < config["input_interfaces"].length; i++) {
label = config["input_interfaces"][i][1]["label"];
html += "<th>" + label + "</th>";
}
html += "</thead>";
html += "<tbody>";
for (let [i, example] of config["examples"].entries()) {
html += "<tr row="+i+">";
for (let [j, col] of example.entries()) {
if (input_interfaces[j].load_example_preview) {
col = input_interfaces[j].load_example_preview(col);
}
html += "<td>" + col + "</td>";
}
html += "</tr>";
}
html += "</tbody>";
target.find(".examples table").html(html);
target.find(".examples tr").click(function() {
let example_id = parseInt($(this).attr("row"));
for (let [i, value] of config["examples"][example_id].entries()) {
input_interfaces[i].load_example(value);
}
})
};
target.find(".screenshot").click(function() { target.find(".screenshot").click(function() {
$(".screenshot").hide(); $(".screenshot").hide();

View File

@ -63,20 +63,7 @@
</head> </head>
<body id="lib"> <body id="lib">
<div id="share" class="invisible"> <div id="interface_target"></div>
Live at <a id="share-link" target="_blank"></a>.
<button id="share-copy">Copy Link</button>
</div>
<div class="container">
<h1 id="title"></h1>
<p id="description"></p>
</div>
<div id="interface_target" class="container"></div>
<div id="examples" class="container invisible">
<h3>Examples <small>(click to load)</small></h3>
<table>
</table>
</div>
<div id="credit"><a href="https://github.com/gradio-app/gradio" target="_blank"> <div id="credit"><a href="https://github.com/gradio-app/gradio" target="_blank">
<img src="static/img/logo_inline.png"> <img src="static/img/logo_inline.png">
</a></div> </a></div>
@ -132,49 +119,6 @@
<script> <script>
$.getJSON("static/config.json", function(config) { $.getJSON("static/config.json", function(config) {
io = gradio_url(config, "/api/predict/", "#interface_target"); io = gradio_url(config, "/api/predict/", "#interface_target");
if (config["title"]) {
$("#title").text(config["title"]);
}
if (config["description"]) {
$("#description").text(config["description"]);
}
if (config["share_url"]) {
let share_url = config["share_url"];
$("#share").removeClass("invisible");
$("#share-link").text(share_url).attr("href", share_url);
$("#share-copy").click(function() {
copyToClipboard(share_url);
$("#share-copy").text("Copied!");
})
};
if (config["examples"]) {
$("#examples").removeClass("invisible");
let html = "<thead>"
for (let i = 0; i < config["input_interfaces"].length; i++) {
label = config["input_interfaces"][i][1]["label"];
html += "<th>" + label + "</th>";
}
html += "</thead>";
html += "<tbody>";
for (let [i, example] of config["examples"].entries()) {
html += "<tr row="+i+">";
for (let [j, col] of example.entries()) {
if (io.input_interfaces[j].load_example_preview) {
col = io.input_interfaces[j].load_example_preview(col);
}
html += "<td>" + col + "</td>";
}
html += "</tr>";
}
html += "</tbody>";
$("#examples table").html(html);
$("#examples tr").click(function() {
let example_id = parseInt($(this).attr("row"));
for (let [i, value] of config["examples"][example_id].entries()) {
io.input_interfaces[i].load_example(value);
}
})
};
}); });
const copyToClipboard = str => { const copyToClipboard = str => {
const el = document.createElement('textarea'); const el = document.createElement('textarea');

View File

@ -1,8 +1,8 @@
import gradio as gr import gradio as gr
import numpy as np import numpy as np
def answer_question(quantity, animal, place, activity_list, morning, etc): def answer_question(quantity, animal, place, activity_list, morning):
return f"""The {quantity} {animal}s went to the {place} where they {" and ".join(activity_list)} until the {"morning" if morning else "night"}""", "OK" return f"""The {quantity} {animal}s went to the {place} where they {" and ".join(activity_list)} until the {"morning" if morning else "night"}"""
gr.Interface(answer_question, gr.Interface(answer_question,
@ -12,16 +12,12 @@ gr.Interface(answer_question,
gr.inputs.Radio(["park", "zoo", "road"]), gr.inputs.Radio(["park", "zoo", "road"]),
gr.inputs.CheckboxGroup(["ran", "swam", "ate", "slept"]), gr.inputs.CheckboxGroup(["ran", "swam", "ate", "slept"]),
gr.inputs.Checkbox(label="Is it the morning?"), gr.inputs.Checkbox(label="Is it the morning?"),
gr.inputs.Textbox(default="What else?"),
],
[
gr.outputs.Textbox(),
gr.outputs.Textbox(),
], ],
"text",
examples=[ examples=[
[2, "cat", "park", ["ran", "swam"], True, "t1"], [2, "cat", "park", ["ran", "swam"], True],
[4, "dog", "zoo", ["ate", "swam"], False, "t2"], [4, "dog", "zoo", ["ate", "swam"], False],
[10, "bird", "road", ["ran"], False, "t3"], [10, "bird", "road", ["ran"], False],
[8, "cat", "zoo", ["ate"], True, "t1"], [8, "cat", "zoo", ["ate"], True],
], ],
).launch() ).launch()

View File

@ -5,19 +5,18 @@ from tensorflow.keras.layers import *
import gradio as gr import gradio as gr
from urllib.request import urlretrieve from urllib.request import urlretrieve
urlretrieve("https://gr-models.s3-us-west-2.amazonaws.com/mnist-model.h5", "mnist-model.h5") urlretrieve("https://gr-models.s3-us-west-2.amazonaws.com/mnist-model.h5", "mnist-model.h5")
model = tf.keras.models.load_model("mnist-model.h5") model = tf.keras.models.load_model("mnist-model.h5")
def recognize_digit(image): def recognize_digit(image):
image = image.reshape(-1, 1)
prediction = model.predict(image).tolist()[0] prediction = model.predict(image).tolist()[0]
return {str(i): prediction[i] for i in range(10)} return {str(i): prediction[i] for i in range(10)}
gr.Interface( gr.Interface(
recognize_digit, recognize_digit,
gradio.inputs.Sketchpad(flatten=True), gradio.inputs.Image(shape=(28, 28), image_mode="L", source="canvas"),
gradio.outputs.Label(num_top_classes=3), gradio.outputs.Label(num_top_classes=3),
live=True, live=True,
capture_session=True, capture_session=True,

View File

@ -26,17 +26,17 @@ button, input[type="submit"], input[type="reset"], input[type="button"], select[
text-align: right; text-align: right;
font-family: monospace; font-family: monospace;
} }
#share { .share {
text-align: center; text-align: center;
margin-bottom: 10px; margin-bottom: 10px;
font-size: 14px; font-size: 14px;
} }
#share-copy { .share-copy {
background-color: whitesmoke; background-color: whitesmoke;
padding: 4px; padding: 4px;
border-radius: 2px; border-radius: 2px;
} }
#title { .title {
text-align: center; text-align: center;
} }
.container { .container {
@ -58,7 +58,7 @@ button.secondary {
color: black; color: black;
background-color: #F6F6F6; background-color: #F6F6F6;
} }
#examples table { .examples table {
border-collapse: collapse; border-collapse: collapse;
font-family: monospace; font-family: monospace;
padding: 8px; padding: 8px;
@ -67,20 +67,20 @@ button.secondary {
border-left: solid 4px whitesmoke; border-left: solid 4px whitesmoke;
border-bottom: solid 4px whitesmoke; border-bottom: solid 4px whitesmoke;
} }
#examples th { .examples th {
padding: 8px 16px; padding: 8px 16px;
text-align: left; text-align: left;
font-size: 18px; font-size: 18px;
} }
#examples td { .examples td {
padding: 8px; padding: 8px;
cursor: pointer; cursor: pointer;
} }
#examples tbody tr:nth-child(odd) { .examples tbody tr:nth-child(odd) {
background-color: white; background-color: white;
} }
#examples tbody tr:hover { .examples tbody tr:hover {
background-color: lightgray; background-color: lightgray;
} }
#credit { #credit {

View File

@ -1,6 +1,13 @@
function gradio(config, fn, target) { function gradio(config, fn, target) {
target = $(target); target = $(target);
target.html(` target.html(`
<div class="share invisible">
Live at <a class="share-link" target="_blank"></a>.
<button class="share-copy">Copy Link</button>
</div>
<div class="container">
<h1 class="title"></h1>
<p class="description"></p>
<div class="panels"> <div class="panels">
<div class="panel input_panel"> <div class="panel input_panel">
<div class="input_interfaces"> <div class="input_interfaces">
@ -12,19 +19,26 @@ function gradio(config, fn, target) {
</div> </div>
<div class="panel output_panel"> <div class="panel output_panel">
<div class="loading invisible"> <div class="loading invisible">
<img class="loading_in_progress" src="static/img/logo_loading.gif"> <img class="loading_in_progress" src="/static/img/logo_loading.gif">
<img class="loading_failed" src="static/img/logo_error.png"> <img class="loading_failed" src="/static/img/logo_error.png">
</div> </div>
<div class="output_interfaces"> <div class="output_interfaces">
</div> </div>
<div class="panel_buttons"> <div class="panel_buttons">
<input class="screenshot panel_button" type="button" value="SCREENSHOT"/> <input class="screenshot panel_button" type="button" value="SCREENSHOT"/>
<div class="screenshot_logo"> <div class="screenshot_logo">
<img src="static/img/logo_inline.png"> <img src="/static/img/logo_inline.png">
</div> </div>
<input class="flag panel_button" type="button" value="FLAG"/> <input class="flag panel_button" type="button" value="FLAG"/>
</div> </div>
</div>`); </div>
</div>
<div class="examples invisible">
<h3>Examples <small>(click to load)</small></h3>
<table>
</table>
</div>
`);
let io_master = Object.create(io_master_template); let io_master = Object.create(io_master_template);
io_master.fn = fn io_master.fn = fn
io_master.target = target; io_master.target = target;
@ -65,6 +79,22 @@ function gradio(config, fn, target) {
interface.id = id; interface.id = id;
id_to_interface_map[id] = interface; id_to_interface_map[id] = interface;
} }
if (config["title"]) {
target.find(".title").text(config["title"]);
}
if (config["description"]) {
target.find(".description").text(config["description"]);
}
if (config["share_url"]) {
let share_url = config["share_url"];
target.find(".share").removeClass("invisible");
target.find(".share-link").text(share_url).attr("href", share_url);
target.find(".share-copy").click(function() {
copyToClipboard(share_url);
target.find(".share-copy").text("Copied!");
})
};
_id = 0; _id = 0;
let input_interfaces = []; let input_interfaces = [];
@ -147,6 +177,34 @@ function gradio(config, fn, target) {
target.find(".screenshot").css("visibility", "visible"); target.find(".screenshot").css("visibility", "visible");
target.find(".flag").css("visibility", "visible") target.find(".flag").css("visibility", "visible")
} }
if (config["examples"]) {
target.find(".examples").removeClass("invisible");
let html = "<thead>"
for (let i = 0; i < config["input_interfaces"].length; i++) {
label = config["input_interfaces"][i][1]["label"];
html += "<th>" + label + "</th>";
}
html += "</thead>";
html += "<tbody>";
for (let [i, example] of config["examples"].entries()) {
html += "<tr row="+i+">";
for (let [j, col] of example.entries()) {
if (input_interfaces[j].load_example_preview) {
col = input_interfaces[j].load_example_preview(col);
}
html += "<td>" + col + "</td>";
}
html += "</tr>";
}
html += "</tbody>";
target.find(".examples table").html(html);
target.find(".examples tr").click(function() {
let example_id = parseInt($(this).attr("row"));
for (let [i, value] of config["examples"][example_id].entries()) {
input_interfaces[i].load_example(value);
}
})
};
target.find(".screenshot").click(function() { target.find(".screenshot").click(function() {
$(".screenshot").hide(); $(".screenshot").hide();

View File

@ -63,20 +63,7 @@
</head> </head>
<body id="lib"> <body id="lib">
<div id="share" class="invisible"> <div id="interface_target"></div>
Live at <a id="share-link" target="_blank"></a>.
<button id="share-copy">Copy Link</button>
</div>
<div class="container">
<h1 id="title"></h1>
<p id="description"></p>
</div>
<div id="interface_target" class="container"></div>
<div id="examples" class="container invisible">
<h3>Examples <small>(click to load)</small></h3>
<table>
</table>
</div>
<div id="credit"><a href="https://github.com/gradio-app/gradio" target="_blank"> <div id="credit"><a href="https://github.com/gradio-app/gradio" target="_blank">
<img src="static/img/logo_inline.png"> <img src="static/img/logo_inline.png">
</a></div> </a></div>
@ -132,49 +119,6 @@
<script> <script>
$.getJSON("static/config.json", function(config) { $.getJSON("static/config.json", function(config) {
io = gradio_url(config, "/api/predict/", "#interface_target"); io = gradio_url(config, "/api/predict/", "#interface_target");
if (config["title"]) {
$("#title").text(config["title"]);
}
if (config["description"]) {
$("#description").text(config["description"]);
}
if (config["share_url"]) {
let share_url = config["share_url"];
$("#share").removeClass("invisible");
$("#share-link").text(share_url).attr("href", share_url);
$("#share-copy").click(function() {
copyToClipboard(share_url);
$("#share-copy").text("Copied!");
})
};
if (config["examples"]) {
$("#examples").removeClass("invisible");
let html = "<thead>"
for (let i = 0; i < config["input_interfaces"].length; i++) {
label = config["input_interfaces"][i][1]["label"];
html += "<th>" + label + "</th>";
}
html += "</thead>";
html += "<tbody>";
for (let [i, example] of config["examples"].entries()) {
html += "<tr row="+i+">";
for (let [j, col] of example.entries()) {
if (io.input_interfaces[j].load_example_preview) {
col = io.input_interfaces[j].load_example_preview(col);
}
html += "<td>" + col + "</td>";
}
html += "</tr>";
}
html += "</tbody>";
$("#examples table").html(html);
$("#examples tr").click(function() {
let example_id = parseInt($(this).attr("row"));
for (let [i, value] of config["examples"][example_id].entries()) {
io.input_interfaces[i].load_example(value);
}
})
};
}); });
const copyToClipboard = str => { const copyToClipboard = str => {
const el = document.createElement('textarea'); const el = document.createElement('textarea');