todolisttest / app.py
abidlabs's picture
abidlabs HF staff
Update app.py
4bff359 verified
raw
history blame
1.54 kB
"""
This is a simple todo list app that allows you to add, remove, and mark tasks as complete.
All actions are performed on the client side.
"""
import gradio as gr
tasks = ["Get a job", "Marry rich", "", "", "", ""]
textboxes = []
with gr.Blocks() as demo:
with gr.Row():
with gr.Column(scale=3):
gr.Markdown("# A Simple Interactive Todo List")
with gr.Column(scale=2):
with gr.Row():
freeze_button = gr.Button("Freeze tasks", variant="stop")
edit_button = gr.Button("Edit tasks")
for i in range(6):
with gr.Row() as r:
t = gr.Textbox(tasks[i], placeholder="Enter a task", show_label=False, container=False, scale=7, interactive=True)
b = gr.Button("✔️", interactive=bool(tasks[i]), variant="primary" if tasks[i] else "secondary")
textboxes.append(t)
t.change(lambda : gr.Button(interactive=True, variant="primary"), None, b, js=True)
b.click(lambda : gr.Row(visible=False), None, r, js=True)
freeze_button.click(lambda : [gr.Textbox(interactive=False), gr.Textbox(interactive=False), gr.Textbox(interactive=False), gr.Textbox(interactive=False), gr.Textbox(interactive=False), gr.Textbox(interactive=False)], None, textboxes, js=True)
edit_button.click(lambda : [gr.Textbox(interactive=True), gr.Textbox(interactive=True), gr.Textbox(interactive=True), gr.Textbox(interactive=True), gr.Textbox(interactive=True), gr.Textbox(interactive=True)], None, textboxes, js=True)
demo.launch()