File size: 3,014 Bytes
0bd62e5
1
{"cells": [{"cell_type": "markdown", "id": "302934307671667531413257853548643485645", "metadata": {}, "source": ["# Gradio Demo: tabs"]}, {"cell_type": "code", "execution_count": null, "id": "272996653310673477252411125948039410165", "metadata": {}, "outputs": [], "source": ["!pip install -q gradio "]}, {"cell_type": "code", "execution_count": null, "id": "288918539441861185822528903084949547379", "metadata": {}, "outputs": [], "source": ["import gradio as gr\n", "\n", "with gr.Blocks() as demo:\n", "    with gr.Tabs():\n", "        with gr.Tab(\"Set 1\"):\n", "            with gr.Tabs(selected=\"a3\") as tabs_1:\n", "                tabset_1 = []\n", "                textset_1 = []\n", "                for i in range(10):\n", "                    with gr.Tab(f\"Tab {i+1}\", id=f\"a{i+1}\") as tab:\n", "                        gr.Markdown(f\"Text {i+1}!\")\n", "                        textbox = gr.Textbox(label=f\"Input {i+1}\")\n", "                        tabset_1.append(tab)\n", "                        textset_1.append(textbox)\n", "        with gr.Tab(\"Set 2\"):\n", "            tabset_2 = []\n", "            textset_2 = []\n", "            for i in range(10):\n", "                with gr.Tab(f\"Tab {i+11}\") as tab:\n", "                    gr.Markdown(f\"Text {i+11}!\")\n", "                    textbox = gr.Textbox(label=f\"Input {i+11}\")\n", "                    tabset_2.append(tab)\n", "                    textset_2.append(textbox)\n", "\n", "        for text1, text2 in zip(textset_1, textset_2):\n", "            text1.submit(lambda x: x, text1, text2)\n", "\n", "    selected = gr.Textbox(label=\"Selected Tab\")\n", "    with gr.Row():\n", "        hide_odd_btn = gr.Button(\"Hide Odd Tabs\")\n", "        show_all_btn = gr.Button(\"Show All Tabs\")\n", "        make_even_uninteractive_btn = gr.Button(\"Make Even Tabs Uninteractive\")\n", "        make_all_interactive_btn = gr.Button(\"Make All Tabs Interactive\")\n", "\n", "    select_tab_num = gr.Number(label=\"Select Tab #\", value=1)\n", "\n", "    hide_odd_btn.click(lambda: [gr.Tab(visible=i % 2 == 1) for i, _ in enumerate(tabset_1 + tabset_2)], outputs=(tabset_1 + tabset_2))\n", "    show_all_btn.click(lambda: [gr.Tab(visible=True) for tab in tabset_1 + tabset_2], outputs=(tabset_1 + tabset_2))\n", "    make_even_uninteractive_btn.click(lambda: [gr.Tab(interactive=i % 2 == 0) for i, _ in enumerate(tabset_1 + tabset_2)], outputs=(tabset_1 + tabset_2))\n", "    make_all_interactive_btn.click(lambda: [gr.Tab(interactive=True) for tab in tabset_1 + tabset_2], outputs=(tabset_1 + tabset_2))\n", "    select_tab_num.submit(lambda x: gr.Tabs(selected=f\"a{x}\"), inputs=select_tab_num, outputs=tabs_1)\n", "\n", "    def get_selected_index(evt: gr.SelectData):\n", "        return evt.value\n", "    gr.on([tab.select for tab in tabset_1 + tabset_2], get_selected_index, outputs=selected)\n", "\n", "if __name__ == \"__main__\":\n", "    demo.launch()\n"]}], "metadata": {}, "nbformat": 4, "nbformat_minor": 5}