|
import gradio as gr |
|
from gradio_workflowbuilder import WorkflowBuilder |
|
import json |
|
|
|
|
|
def export_workflow(workflow_data): |
|
"""Export workflow as formatted JSON""" |
|
if not workflow_data: |
|
return "No workflow to export" |
|
return json.dumps(workflow_data, indent=2) |
|
|
|
|
|
|
|
with gr.Blocks( |
|
title="π¨ Visual Workflow Builder", |
|
theme=gr.themes.Soft(), |
|
css=""" |
|
.main-container { max-width: 1600px; margin: 0 auto; } |
|
.workflow-section { margin-bottom: 2rem; } |
|
.button-row { display: flex; gap: 1rem; justify-content: center; margin: 1rem 0; } |
|
|
|
.component-description { |
|
padding: 24px; |
|
background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%); |
|
border-radius: 12px; |
|
border-left: 4px solid #3b82f6; |
|
margin: 16px 0; |
|
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; |
|
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05); |
|
} |
|
|
|
.component-description p { |
|
margin: 10px 0; |
|
line-height: 1.6; |
|
color: #374151; |
|
} |
|
|
|
.base-description { |
|
font-size: 17px; |
|
font-weight: 600; |
|
color: #1e293b; |
|
} |
|
|
|
.base-description strong { |
|
color: #3b82f6; |
|
font-weight: 700; |
|
} |
|
|
|
.feature-description { |
|
font-size: 16px; |
|
color: #1e293b; |
|
font-weight: 500; |
|
} |
|
|
|
.customization-note { |
|
font-size: 15px; |
|
color: #64748b; |
|
font-style: italic; |
|
} |
|
|
|
.sample-intro { |
|
font-size: 15px; |
|
color: #1e293b; |
|
font-weight: 600; |
|
margin-top: 16px; |
|
border-top: 1px solid #e2e8f0; |
|
padding-top: 16px; |
|
} |
|
""" |
|
) as demo: |
|
|
|
with gr.Column(elem_classes=["main-container"]): |
|
gr.Markdown(""" |
|
# π¨ Visual Workflow Builder |
|
|
|
**Create sophisticated workflows with drag and drop simplicity.** |
|
""") |
|
|
|
|
|
gr.HTML(""" |
|
<div class="component-description"> |
|
<p class="base-description">Base custom component powered by <strong>svelteflow</strong>.</p> |
|
<p class="feature-description">Create custom workflows.</p> |
|
<p class="customization-note">You can customise the nodes as well as the design of the workflow.</p> |
|
<p class="sample-intro">Here is a sample:</p> |
|
</div> |
|
""") |
|
|
|
|
|
with gr.Column(elem_classes=["workflow-section"]): |
|
workflow_builder = WorkflowBuilder( |
|
label="π¨ Visual Workflow Designer", |
|
info="Drag components from the sidebar β Connect nodes by dragging from output (right) to input (left) β Click nodes to edit properties" |
|
) |
|
|
|
|
|
gr.Markdown("## πΎ Export Workflow") |
|
|
|
with gr.Row(): |
|
with gr.Column(): |
|
export_output = gr.Code( |
|
language="json", |
|
label="Workflow Configuration", |
|
lines=10 |
|
) |
|
|
|
|
|
with gr.Row(elem_classes=["button-row"]): |
|
export_btn = gr.Button("πΎ Export JSON", variant="primary", size="lg") |
|
|
|
|
|
with gr.Accordion("π How to Use", open=False): |
|
gr.Markdown(""" |
|
### π Getting Started |
|
|
|
1. **Add Components**: Drag items from the left sidebar onto the canvas |
|
2. **Connect Nodes**: Drag from the blue circle on the right of a node to the left circle of another |
|
3. **Edit Properties**: Click any node to see its editable properties on the right panel |
|
4. **Organize**: Drag nodes around to create a clean workflow layout |
|
5. **Delete**: Use the β button on nodes or click the red circle on connections |
|
|
|
### π― Component Types |
|
|
|
- **π₯ Inputs**: Text fields, file uploads, number inputs |
|
- **βοΈ Processing**: Language models, text processors, conditionals |
|
- **π€ Outputs**: Text displays, file exports, charts |
|
- **π§ Tools**: API calls, data transformers, validators |
|
|
|
### π‘ Pro Tips |
|
|
|
- **Collapsible Panels**: Use the arrow buttons to hide/show sidebars |
|
- **Live Updates**: Properties update in real-time as you edit |
|
- **Export Options**: Get JSON config for your workflow |
|
""") |
|
|
|
|
|
export_btn.click( |
|
fn=export_workflow, |
|
inputs=[workflow_builder], |
|
outputs=[export_output] |
|
) |
|
|
|
|
|
if __name__ == "__main__": |
|
demo.launch( |
|
server_name="0.0.0.0", |
|
show_error=True |
|
) |
|
|