Spaces:
Running
Running
File size: 1,235 Bytes
585747f ae02035 0a40653 585747f fe88e4d 77b211d 585747f 0a40653 c875e8e 585747f c875e8e 73c565e efafbe1 08ceafd efafbe1 73c565e efafbe1 585747f d11c1e5 77b211d efafbe1 77b211d efafbe1 585747f |
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 |
import gradio as gr
import base64
#import execjs
# Define the Mermaid code for the flowchart
mm_html="""
<pre class="mermaid">
graph LR
A --- B
B-->C[fa:fa-ban forbidden]
B-->D(fa:fa-spinner);
</pre>"""
mermaid_code = """graph TD;
A[Start] --> B[Decision]
B -- Yes --> C[Option 1]
B -- No --> D[Option 2]
C --> E[End]
D --> E
E[End] --> F[End]
"""
# Create an ExecJS context
js_c=("""
let mermaid = require('mermaid');
mermaid.initialize({startOnLoad:true});
function renderMermaid(mermaidCode) {
mermaid.mermaidAPI.render('mermaid', mermaidCode, function(svgCode, bindFunctions) {
document.getElementById('diagram').innerHTML = svgCode;
});
}
""")
#def call_chart(mermaidCode):
def mm(graph=mermaid_code):
out_html=f'<iframe src="https://omnibus-mermaid-script.static.hf.space/?mermaid={graph}"></iframe>'
return gr.update(out_html)
"""
graph LR;
A--> B & C & D;
B--> A & E;
C--> A & E;
D--> A & E;
E--> B & C & D;
"""
with gr.Blocks() as app:
inp_text=gr.Textbox(value=mermaid_code)
btn=gr.Button()
out_html=gr.HTML()
btn.click(mm,inp_text,out_html)
app.load(mm,inp_text,out_html)
app.launch() |