mirror of
https://github.com/gradio-app/gradio.git
synced 2025-01-24 10:54:04 +08:00
include all og gradio into gradio js
This commit is contained in:
parent
71aac29097
commit
f9e35de8aa
@ -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):
|
||||||
|
@ -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 {
|
||||||
|
@ -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();
|
||||||
|
@ -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');
|
||||||
|
@ -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()
|
||||||
|
@ -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,
|
||||||
|
@ -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 {
|
||||||
|
@ -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();
|
||||||
|
@ -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');
|
||||||
|
Loading…
Reference in New Issue
Block a user