gradio/js/app/lite.html
2023-07-04 14:11:22 +01:00

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>