File size: 1,967 Bytes
5460b58
 
2f63946
 
447fa92
81b18bf
0fbb97c
 
 
 
2f63946
 
031410e
60fbdb7
ba5148a
0fbb97c
 
2f63946
 
 
 
 
30ba848
 
 
2f63946
30ba848
 
2f63946
30ba848
2f63946
 
30ba848
 
2f63946
447fa92
 
 
 
 
2f63946
 
 
5460b58
2f63946
 
 
 
5460b58
2f63946
 
 
 
 
 
60fbdb7
2f63946
2282ec1
08be7e7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
from pathlib import Path
import gradio as gr
from datetime import datetime
import sys
import os

import spaces # necessary to run on Zero.
from spaces.zero.client import _get_token


# create a static directory to store the static files
static_dir = Path('./static')
static_dir.mkdir(parents=True, exist_ok=True)

@spaces.GPU(duration=10)
def predict(request: gr.Request,text_input):
    token = _get_token(request)
    file_name = f"{datetime.utcnow().strftime('%s')}.html"
    file_path = static_dir / file_name
    print(file_path)
    with open(file_path, "w") as f:
        f.write(f"""
    <!DOCTYPE html>
    <html>
    <head>
        <script src="https://cdn.tailwindcss.com"></script>
    </head>
    <body class="bg-gray-200 dark:text-white dark:bg-gray-900">
        <h1 class="text-3xl font-bold">
            Hello <i>{text_input}</i> From Gradio Iframe
        </h1>
        <h3>Filename: {file_name}</h3>
    </body>
    </html>
        """)
    file_path = static_dir / file_name
    os.chmod(file_path, 0o644)
    iframe = f'<iframe src="/file={file_path}" width="100%" height="500px"></iframe>'
    link = f'<a href="/file={file_path}" target="_blank">{file_name}</a>'
    print("Serving file at:", f"/file={file_path}")
    return link, iframe

with gr.Blocks() as block:
    gr.Markdown("""
## Gradio + FastAPI + Static Server
This is a demo of how to use Gradio with FastAPI and a static server.
The Gradio app generates dynamic HTML files and stores them in a static directory. FastAPI serves the static files.
""")
    with gr.Row():
        with gr.Column():
            text_input = gr.Textbox(label="Name")
            markdown = gr.Markdown(label="Output Box")
            new_btn = gr.Button("New")
        with gr.Column():
            html = gr.HTML(label="HTML preview", show_label=True)

    new_btn.click(fn=predict, inputs=[text_input], outputs=[markdown, html])

block.launch(debug=True, share=False, ssr_mode=False)#,ssr_mode=False