mirror of
https://github.com/gradio-app/gradio.git
synced 2025-01-24 10:54:04 +08:00
111 lines
3.1 KiB
HTML
111 lines
3.1 KiB
HTML
<!DOCTYPE html>
|
|
<!-- An entrypoint for the Wasm version development -->
|
|
<html style="margin: 0; padding: 0; height: 100%;">
|
|
<head>
|
|
<meta charset="utf-8" />
|
|
<meta
|
|
name="viewport"
|
|
content="width=device-width, initial-scale=1, shrink-to-fit=no, maximum-scale=1"
|
|
/>
|
|
|
|
<link rel="preconnect" href="https://fonts.googleapis.com" />
|
|
<link
|
|
rel="preconnect"
|
|
href="https://fonts.gstatic.com"
|
|
crossorigin="anonymous"
|
|
/>
|
|
|
|
<script type="module" src="./src/lite/index.ts"></script>
|
|
</head>
|
|
|
|
<body style="margin: 0; padding: 0; height: 100%;">
|
|
<div id="gradio-app"></div>
|
|
|
|
<textarea id="code-input" cols="30" rows="10">
|
|
import gradio as gr
|
|
|
|
from greetings import greet
|
|
# def greet(name):
|
|
# return "Hello " + name + "!"
|
|
|
|
def upload_file(files):
|
|
file_paths = [file.name for file in files]
|
|
return file_paths
|
|
|
|
with gr.Blocks() as demo:
|
|
name = gr.Textbox(label="Name")
|
|
output = gr.Textbox(label="Output Box")
|
|
greet_btn = gr.Button("Greet")
|
|
greet_btn.click(fn=greet, inputs=name, outputs=output, api_name="greet")
|
|
|
|
gr.File()
|
|
|
|
file_output = gr.File()
|
|
upload_button = gr.UploadButton("Click to Upload a File", file_types=["image", "video"], file_count="multiple")
|
|
upload_button.upload(upload_file, upload_button, file_output)
|
|
|
|
demo.launch()
|
|
</textarea>
|
|
<button id="exec-button">Execute</button>
|
|
|
|
<textarea id="requirements-input"></textarea>
|
|
<button id="install-button">Install</button>
|
|
|
|
<script type="module"> // type="module" is necessary to use `createGradioApp()`, which is loaded with <script type="module" /> tag above.
|
|
const code_input = document.getElementById("code-input");
|
|
const exec_button = document.getElementById("exec-button");
|
|
const requirements_input = document.getElementById("requirements-input");
|
|
const install_button = document.getElementById("install-button");
|
|
|
|
function parse_requirements(text) {
|
|
return text
|
|
.split("\n")
|
|
.map((line) => line.trim())
|
|
.filter((line) => line.length > 0 && !line.startsWith("#"));
|
|
}
|
|
|
|
const initial_code = code_input.value;
|
|
const initial_requirements = parse_requirements(requirements_input.value);
|
|
|
|
const controller = createGradioApp({
|
|
target: document.getElementById("gradio-app"),
|
|
files: {
|
|
"greetings.py": {
|
|
data: `
|
|
def greet(name):
|
|
return "Hello " + name + "!"
|
|
`
|
|
},
|
|
"images/logo.png": {
|
|
url: "https://raw.githubusercontent.com/gradio-app/gradio/main/guides/assets/logo.png"
|
|
}
|
|
},
|
|
pyCode: initial_code,
|
|
info: true,
|
|
container: true,
|
|
isEmbed: false,
|
|
initialHeight: "300px",
|
|
eager: false,
|
|
themeMode: null,
|
|
autoScroll: false,
|
|
controlPageTitle: false,
|
|
appMode: true
|
|
});
|
|
|
|
exec_button.onclick = () => {
|
|
console.debug("exec_button.onclick");
|
|
controller.rerun(code_input.value);
|
|
console.debug("Rerun finished")
|
|
}
|
|
|
|
install_button.onclick = async () => {
|
|
console.debug("install_button.onclick");
|
|
const requirements = parse_requirements(requirements_input.value)
|
|
console.debug("requirements", requirements)
|
|
controller.install(requirements);
|
|
console.debug("Install finished")
|
|
}
|
|
</script>
|
|
</body>
|
|
</html>
|