From cad537aac57998560c9f44a37499be734de66349 Mon Sep 17 00:00:00 2001 From: pngwn Date: Thu, 19 Oct 2023 18:03:06 +0100 Subject: [PATCH 1/2] pass props to example components and to example outputs (#6014) * pass props to example components and to example outputs * add changeset * make util less egenric/ more useful * fix demo * fix demo * fix * fix test * Fix test --------- Co-authored-by: gradio-pr-bot Co-authored-by: freddyaboulton --- .changeset/green-olives-shake.md | 6 ++++++ demo/examples_component/run.ipynb | 2 +- demo/examples_component/run.py | 10 +++++---- gradio/blocks.py | 7 ++----- gradio/components/dataset.py | 22 ++++++++++++++++---- gradio/helpers.py | 11 +++++++++- gradio/utils.py | 9 ++++++++ js/dataset/Index.svelte | 3 +++ test/test_components.py | 12 ++++++----- test/test_helpers.py | 34 +++++++++++++++++++++++++++++-- 10 files changed, 94 insertions(+), 22 deletions(-) create mode 100644 .changeset/green-olives-shake.md diff --git a/.changeset/green-olives-shake.md b/.changeset/green-olives-shake.md new file mode 100644 index 0000000000000..4ca71c8a26523 --- /dev/null +++ b/.changeset/green-olives-shake.md @@ -0,0 +1,6 @@ +--- +"@gradio/dataset": minor +"gradio": minor +--- + +feat:pass props to example components and to example outputs diff --git a/demo/examples_component/run.ipynb b/demo/examples_component/run.ipynb index ec52d7767f2f9..090af8fc0feb0 100644 --- a/demo/examples_component/run.ipynb +++ b/demo/examples_component/run.ipynb @@ -1 +1 @@ -{"cells": [{"cell_type": "markdown", "id": "302934307671667531413257853548643485645", "metadata": {}, "source": ["# Gradio Demo: examples_component"]}, {"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": ["# Downloading files from the demo repo\n", "import os\n", "os.mkdir('images')\n", "!wget -q -O images/cheetah1.jpg https://github.com/gradio-app/gradio/raw/main/demo/examples_component/images/cheetah1.jpg\n", "!wget -q -O images/lion.jpg https://github.com/gradio-app/gradio/raw/main/demo/examples_component/images/lion.jpg\n", "!wget -q -O images/lion.webp https://github.com/gradio-app/gradio/raw/main/demo/examples_component/images/lion.webp\n", "!wget -q -O images/logo.png https://github.com/gradio-app/gradio/raw/main/demo/examples_component/images/logo.png"]}, {"cell_type": "code", "execution_count": null, "id": "44380577570523278879349135829904343037", "metadata": {}, "outputs": [], "source": ["import gradio as gr\n", "import os\n", "\n", "def flip(i):\n", " return i.rotate(180)\n", "\n", "with gr.Blocks() as demo:\n", " with gr.Row():\n", " with gr.Column():\n", " img_i = gr.Image(label=\"Input Image\", type=\"pil\")\n", " with gr.Column():\n", " img_o = gr.Image(label=\"Output Image\")\n", " with gr.Row():\n", " btn = gr.Button(value=\"Flip Image\")\n", " btn.click(flip, inputs=[img_i], outputs=[img_o])\n", "\n", " gr.Examples(\n", " [ \n", " os.path.join(os.path.abspath(''), \"images/cheetah1.jpg\"),\n", " os.path.join(os.path.abspath(''), \"images/lion.jpg\"),\n", " ],\n", " img_i,\n", " img_o,\n", " flip\n", " )\n", " \n", "demo.launch()"]}], "metadata": {}, "nbformat": 4, "nbformat_minor": 5} \ No newline at end of file +{"cells": [{"cell_type": "markdown", "id": "302934307671667531413257853548643485645", "metadata": {}, "source": ["# Gradio Demo: examples_component"]}, {"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": ["# Downloading files from the demo repo\n", "import os\n", "os.mkdir('images')\n", "!wget -q -O images/cheetah1.jpg https://github.com/gradio-app/gradio/raw/main/demo/examples_component/images/cheetah1.jpg\n", "!wget -q -O images/lion.jpg https://github.com/gradio-app/gradio/raw/main/demo/examples_component/images/lion.jpg\n", "!wget -q -O images/lion.webp https://github.com/gradio-app/gradio/raw/main/demo/examples_component/images/lion.webp\n", "!wget -q -O images/logo.png https://github.com/gradio-app/gradio/raw/main/demo/examples_component/images/logo.png"]}, {"cell_type": "code", "execution_count": null, "id": "44380577570523278879349135829904343037", "metadata": {}, "outputs": [], "source": ["import gradio as gr\n", "import os\n", "\n", "\n", "def flip(i):\n", " return i.rotate(180)\n", "\n", "\n", "with gr.Blocks() as demo:\n", " with gr.Row():\n", " with gr.Column():\n", " img_i = gr.Image(label=\"Input Image\", type=\"pil\")\n", " with gr.Column():\n", " img_o = gr.Image(label=\"Output Image\")\n", " with gr.Row():\n", " btn = gr.Button(value=\"Flip Image\")\n", " btn.click(flip, inputs=[img_i], outputs=[img_o])\n", "\n", " gr.Examples(\n", " [\n", " os.path.join(os.path.abspath(''), \"images/cheetah1.jpg\"),\n", " os.path.join(os.path.abspath(''), \"images/lion.jpg\"),\n", " ],\n", " img_i,\n", " img_o,\n", " flip,\n", " )\n", "\n", "demo.launch()\n"]}], "metadata": {}, "nbformat": 4, "nbformat_minor": 5} \ No newline at end of file diff --git a/demo/examples_component/run.py b/demo/examples_component/run.py index 4b05d826f4903..60f615a30e4ef 100644 --- a/demo/examples_component/run.py +++ b/demo/examples_component/run.py @@ -1,9 +1,11 @@ import gradio as gr import os + def flip(i): return i.rotate(180) + with gr.Blocks() as demo: with gr.Row(): with gr.Column(): @@ -15,13 +17,13 @@ def flip(i): btn.click(flip, inputs=[img_i], outputs=[img_o]) gr.Examples( - [ + [ os.path.join(os.path.dirname(__file__), "images/cheetah1.jpg"), os.path.join(os.path.dirname(__file__), "images/lion.jpg"), ], img_i, img_o, - flip + flip, ) - -demo.launch() \ No newline at end of file + +demo.launch() diff --git a/gradio/blocks.py b/gradio/blocks.py index 07d39a750faa8..c2b21db201353 100644 --- a/gradio/blocks.py +++ b/gradio/blocks.py @@ -588,11 +588,8 @@ def get_block_instance(id: int) -> Block: else: raise ValueError(f"Cannot find block with id {id}") cls = component_or_layout_class(block_config["type"]) - block_config["props"].pop("type", None) - block_config["props"].pop("name", None) - block_config["props"].pop("selectable", None) - block_config["props"].pop("streamable", None) - block_config["props"].pop("server_fns", None) + + block_config["props"] = utils.recover_kwargs(block_config["props"]) # If a Gradio app B is loaded into a Gradio app A, and B itself loads a # Gradio app C, then the root_urls of the components in A need to be the diff --git a/gradio/components/dataset.py b/gradio/components/dataset.py index 7fd262151d56f..8e5fd1b524f6b 100644 --- a/gradio/components/dataset.py +++ b/gradio/components/dataset.py @@ -6,6 +6,7 @@ from gradio_client.documentation import document, set_documentation_group +import gradio.utils as utils from gradio.components.base import ( Component, get_component_instance, @@ -66,6 +67,13 @@ def __init__( self.scale = scale self.min_width = min_width self._components = [get_component_instance(c) for c in components] + self.component_props = [ + utils.recover_kwargs( + component.get_config(), + ["value"], + ) + for component in self._components + ] # Narrow type to Component assert all( @@ -95,10 +103,16 @@ def skip_api(self): def get_config(self): config = super().get_config() - config["components"] = [ - component.get_block_name() for component in self._components - ] - config["component_ids"] = [component._id for component in self._components] + + config["components"] = [] + config["component_props"] = self.component_props + config["component_ids"] = [] + + for component in self._components: + config["components"].append(component.get_block_name()) + + config["component_ids"].append(component._id) + return config def preprocess(self, x: Any) -> Any: diff --git a/gradio/helpers.py b/gradio/helpers.py index 893a789260f7f..051f43d830bdc 100644 --- a/gradio/helpers.py +++ b/gradio/helpers.py @@ -259,7 +259,16 @@ def create(self) -> None: async def load_example(example_id): processed_example = self.non_none_processed_examples[example_id] - return utils.resolve_singleton(processed_example) + examples = utils.resolve_singleton(processed_example) + + return ( + update(value=examples, **self.dataset.component_props[0]) + if not isinstance(examples, list) + else [ + update(value=ex, **self.dataset.component_props[i]) + for i, ex in enumerate(examples) + ] + ) if Context.root_block: self.load_input_event = self.dataset.click( diff --git a/gradio/utils.py b/gradio/utils.py index 20494fccdd955..ef246afe4897e 100644 --- a/gradio/utils.py +++ b/gradio/utils.py @@ -950,3 +950,12 @@ def find_user_stack_level() -> int: frame = frame.f_back n += 1 return n + + +def recover_kwargs(config: dict, additional_keys_to_ignore: list[str] | None = None): + not_kwargs = ["type", "name", "selectable", "server_fns", "streamable"] + return { + k: v + for k, v in config.items() + if k not in not_kwargs and k not in (additional_keys_to_ignore or []) + } diff --git a/js/dataset/Index.svelte b/js/dataset/Index.svelte index cf3fbb2e2e48f..fd89cf0fb9eea 100644 --- a/js/dataset/Index.svelte +++ b/js/dataset/Index.svelte @@ -4,6 +4,7 @@ import type { Gradio, SelectData } from "@gradio/utils"; import { get_fetchable_url_or_file } from "@gradio/upload"; export let components: string[]; + export let component_props: Record[]; export let component_map: Map< string, Promise<{ @@ -141,6 +142,7 @@ {#if component_meta.length && component_map.get(components[0])} Date: Thu, 19 Oct 2023 13:11:00 -0400 Subject: [PATCH 2/2] Format js in v4 branch (#6016) * Format v4 branch js * add changeset * lint --------- Co-authored-by: gradio-pr-bot --- .changeset/five-islands-joke.md | 48 + .changeset/pre.json | 250 ++-- .config/basevite.config.ts | 4 +- client/js/src/client.ts | 8 +- js/_website/src/app.html | 5 +- .../src/lib/components/CopyButton.svelte | 31 +- js/_website/src/lib/components/DocsNav.svelte | 5 +- .../src/lib/components/FunctionDoc.svelte | 1 - .../lib/components/icons/DownloadIcon.svelte | 6 +- js/_website/src/routes/+layout.svelte | 18 +- .../[[version]]/docs/[doc]/+page.server.ts | 21 +- .../[[version]]/docs/[doc]/+page.svelte | 27 +- .../docs/components/+page.server.ts | 11 +- .../[[version]]/docs/components/+page.svelte | 35 +- .../[[version]]/docs/flagging/+page.server.ts | 11 +- .../[[version]]/docs/flagging/+page.svelte | 17 +- .../docs/js-client/+page.server.ts | 11 +- .../[[version]]/docs/js-client/+page.svelte | 6 +- .../docs/python-client/+page.server.ts | 5 +- .../docs/python-client/+page.svelte | 23 +- .../[[version]]/docs/themes/+page.server.ts | 13 +- .../[[version]]/docs/themes/+page.svelte | 17 +- .../guides/[guide]/+page.server.ts | 22 +- .../[[version]]/guides/[guide]/+page.svelte | 65 +- js/accordion/package.json | 2 +- js/annotatedimage/package.json | 2 +- js/app/build_plugins.ts | 2 - js/app/src/Login.stories.svelte | 4 +- js/app/src/api_docs/CodeSnippets.svelte | 9 +- js/app/src/api_docs/ResponseObject.svelte | 8 +- js/app/src/lang/ckb.json | 214 ++-- js/app/src/lang/eu.json | 32 +- js/audio/package.json | 2 +- js/box/package.json | 2 +- js/chatbot/Chatbot.stories.svelte | 28 +- js/chatbot/package.json | 2 +- js/checkbox/package.json | 2 +- js/checkbox/shared/Checkbox.svelte | 4 +- js/checkboxgroup/package.json | 2 +- js/checkboxgroup/shared/Checkboxgroup.svelte | 4 +- js/code/package.json | 2 +- js/code/shared/Code.svelte | 30 +- js/colorpicker/package.json | 2 +- js/column/package.json | 2 +- js/dataframe/package.json | 2 +- js/dataset/package.json | 2 +- js/dropdown/package.json | 2 +- js/dropdown/shared/Multiselect.svelte | 6 +- js/fallback/package.json | 2 +- js/file/package.json | 2 +- js/fileexplorer/package.json | 2 +- js/form/package.json | 2 +- js/gallery/package.json | 2 +- js/gallery/shared/Gallery.svelte | 2 +- js/group/package.json | 2 +- js/highlightedtext/package.json | 2 +- js/html/package.json | 2 +- js/image/package.json | 2 +- js/image/shared/Webcam.svelte | 4 +- js/json/package.json | 2 +- js/label/package.json | 2 +- js/markdown/package.json | 2 +- js/model3D/package.json | 2 +- js/number/package.json | 2 +- js/plot/package.json | 2 +- js/preview/package.json | 80 +- .../test/imageslider/frontend/package.json | 52 +- .../test/newtext/frontend/example/index.ts | 2 +- .../newtext/frontend/example/newtext.svelte | 10 +- .../newtext/frontend/interactive/index.ts | 2 +- .../frontend/interactive/newtext.svelte | 10 +- js/preview/test/newtext/frontend/package.json | 38 +- .../test/newtext/frontend/shared/index.ts | 2 +- .../newtext/frontend/shared/newtext.svelte | 10 +- .../test/newtext/frontend/static/index.ts | 2 +- .../newtext/frontend/static/newtext.svelte | 10 +- js/radio/package.json | 2 +- js/row/package.json | 2 +- js/slider/package.json | 2 +- js/state/package.json | 2 +- .../design-tokens/Colors.stories.svelte | 2 +- .../design-tokens/Icons.stories.svelte | 4 +- .../design-tokens/Radii.stories.svelte | 2 +- .../design-tokens/Spacing.stories.svelte | 2 +- .../design-tokens/TextSize.stories.svelte | 2 +- js/tabitem/package.json | 2 +- js/tabs/package.json | 2 +- js/textbox/package.json | 2 +- js/textbox/shared/Textbox.svelte | 6 +- js/uploadbutton/package.json | 2 +- js/video/package.json | 2 +- test/test_files/xray_config.json | 951 +++++++------- test/test_files/xray_config_diff_ids.json | 951 +++++++------- test/test_files/xray_config_wrong.json | 1098 ++++++++--------- 94 files changed, 2173 insertions(+), 2144 deletions(-) create mode 100644 .changeset/five-islands-joke.md diff --git a/.changeset/five-islands-joke.md b/.changeset/five-islands-joke.md new file mode 100644 index 0000000000000..d5a990ab289aa --- /dev/null +++ b/.changeset/five-islands-joke.md @@ -0,0 +1,48 @@ +--- +"@gradio/accordion": minor +"@gradio/annotatedimage": minor +"@gradio/app": minor +"@gradio/audio": minor +"@gradio/box": minor +"@gradio/chatbot": minor +"@gradio/checkbox": minor +"@gradio/checkboxgroup": minor +"@gradio/client": minor +"@gradio/code": minor +"@gradio/colorpicker": minor +"@gradio/column": minor +"@gradio/dataframe": minor +"@gradio/dataset": minor +"@gradio/dropdown": minor +"@gradio/fallback": minor +"@gradio/file": minor +"@gradio/fileexplorer": minor +"@gradio/form": minor +"@gradio/gallery": minor +"@gradio/group": minor +"@gradio/highlightedtext": minor +"@gradio/html": minor +"@gradio/image": minor +"@gradio/json": minor +"@gradio/label": minor +"@gradio/markdown": minor +"@gradio/model3d": minor +"@gradio/number": minor +"@gradio/plot": minor +"@gradio/preview": minor +"@gradio/radio": minor +"@gradio/row": minor +"@gradio/slider": minor +"@gradio/state": minor +"@gradio/tabitem": minor +"@gradio/tabs": minor +"@gradio/textbox": minor +"@gradio/uploadbutton": minor +"@gradio/video": minor +"gradio": minor +"imageslider": minor +"newtext": minor +"website": minor +--- + +feat:Format js in v4 branch diff --git a/.changeset/pre.json b/.changeset/pre.json index e1590e565189a..0745f399daf94 100644 --- a/.changeset/pre.json +++ b/.changeset/pre.json @@ -1,127 +1,127 @@ { - "mode": "pre", - "tag": "beta", - "initialVersions": { - "@gradio/client": "0.3.1", - "gradio_client": "0.5.0", - "gradio": "3.43.2", - "@gradio/cdn-test": "0.0.1", - "@gradio/spaces-test": "0.0.1", - "website": "0.4.0", - "@gradio/accordion": "0.0.4", - "@gradio/annotatedimage": "0.1.2", - "@gradio/app": "1.4.3", - "@gradio/atoms": "0.1.2", - "@gradio/audio": "0.3.2", - "@gradio/box": "0.0.4", - "@gradio/button": "0.1.3", - "@gradio/chatbot": "0.3.1", - "@gradio/checkbox": "0.1.3", - "@gradio/checkboxgroup": "0.1.2", - "@gradio/code": "0.1.2", - "@gradio/colorpicker": "0.1.2", - "@gradio/column": "0.0.1", - "@gradio/dataframe": "0.2.2", - "@gradio/dropdown": "0.1.3", - "@gradio/file": "0.1.2", - "@gradio/form": "0.0.5", - "@gradio/gallery": "0.3.2", - "@gradio/group": "0.0.1", - "@gradio/highlightedtext": "0.2.3", - "@gradio/html": "0.0.4", - "@gradio/icons": "0.1.0", - "@gradio/image": "0.2.2", - "@gradio/json": "0.0.5", - "@gradio/label": "0.1.2", - "@gradio/lite": "0.3.1", - "@gradio/markdown": "0.2.0", - "@gradio/model3d": "0.2.1", - "@gradio/number": "0.2.2", - "@gradio/plot": "0.1.2", - "@gradio/radio": "0.1.2", - "@gradio/row": "0.0.1", - "@gradio/slider": "0.1.2", - "@gradio/state": "0.0.1", - "@gradio/statustracker": "0.2.0", - "@gradio/tabitem": "0.0.4", - "@gradio/tabs": "0.0.5", - "@gradio/textbox": "0.2.0", - "@gradio/theme": "0.1.0", - "@gradio/tooltip": "0.0.1", - "@gradio/tootils": "0.0.2", - "@gradio/upload": "0.2.1", - "@gradio/uploadbutton": "0.0.5", - "@gradio/utils": "0.1.1", - "@gradio/video": "0.0.6", - "@gradio/wasm": "0.0.1", - "@gradio/fallback": "0.1.1", - "@gradio/preview": "0.0.2", - "@gradio/dataset": "0.0.1", - "@gradio/fileexplorer": "0.2.2", - "imageslider": "0.2.0", - "newnewtext": "0.1.2", - "newtext": "0.0.1", - "@gradio/storybook": "0.0.1" - }, - "changesets": [ - "afraid-cougars-rescue", - "bright-planes-divide", - "bright-yaks-wink", - "cold-hoops-heal", - "cold-lemons-roll", - "crazy-dancers-allow", - "cute-crabs-know", - "dark-cups-see", - "dirty-ghosts-tickle", - "dry-points-join", - "easy-mirrors-retire", - "eleven-steaks-tan", - "empty-bobcats-judge", - "flat-experts-wink", - "fresh-ears-pump", - "gentle-parks-fry", - "great-rice-grab", - "green-tips-read", - "heavy-animals-think", - "hip-drinks-bow", - "hot-icons-film", - "hungry-melons-pump", - "icy-cars-boil", - "large-banks-push", - "lazy-aliens-drive", - "lovely-news-speak", - "modern-forks-march", - "nasty-dryers-show", - "nice-actors-write", - "old-heads-give", - "plain-groups-win", - "plenty-teeth-clap", - "public-chairs-chew", - "purple-jokes-shake", - "real-spoons-pick", - "sad-ears-sink", - "sad-eels-sink", - "sad-icons-relax", - "short-clouds-see", - "silver-beers-refuse", - "slick-bats-study", - "slick-pants-stand", - "smart-groups-study", - "some-shoes-relate", - "strange-lizards-boil", - "strong-peas-tell", - "tame-chairs-tan", - "tasty-candies-type", - "three-trams-sniff", - "tough-parrots-relate", - "true-bugs-shine", - "twenty-dryers-wave", - "twenty-gifts-tickle", - "two-games-dress", - "two-mirrors-nail", - "upset-crews-learn", - "vast-terms-rhyme", - "wet-places-hunt", - "wise-beans-itch" - ] + "mode": "pre", + "tag": "beta", + "initialVersions": { + "@gradio/client": "0.3.1", + "gradio_client": "0.5.0", + "gradio": "3.43.2", + "@gradio/cdn-test": "0.0.1", + "@gradio/spaces-test": "0.0.1", + "website": "0.4.0", + "@gradio/accordion": "0.0.4", + "@gradio/annotatedimage": "0.1.2", + "@gradio/app": "1.4.3", + "@gradio/atoms": "0.1.2", + "@gradio/audio": "0.3.2", + "@gradio/box": "0.0.4", + "@gradio/button": "0.1.3", + "@gradio/chatbot": "0.3.1", + "@gradio/checkbox": "0.1.3", + "@gradio/checkboxgroup": "0.1.2", + "@gradio/code": "0.1.2", + "@gradio/colorpicker": "0.1.2", + "@gradio/column": "0.0.1", + "@gradio/dataframe": "0.2.2", + "@gradio/dropdown": "0.1.3", + "@gradio/file": "0.1.2", + "@gradio/form": "0.0.5", + "@gradio/gallery": "0.3.2", + "@gradio/group": "0.0.1", + "@gradio/highlightedtext": "0.2.3", + "@gradio/html": "0.0.4", + "@gradio/icons": "0.1.0", + "@gradio/image": "0.2.2", + "@gradio/json": "0.0.5", + "@gradio/label": "0.1.2", + "@gradio/lite": "0.3.1", + "@gradio/markdown": "0.2.0", + "@gradio/model3d": "0.2.1", + "@gradio/number": "0.2.2", + "@gradio/plot": "0.1.2", + "@gradio/radio": "0.1.2", + "@gradio/row": "0.0.1", + "@gradio/slider": "0.1.2", + "@gradio/state": "0.0.1", + "@gradio/statustracker": "0.2.0", + "@gradio/tabitem": "0.0.4", + "@gradio/tabs": "0.0.5", + "@gradio/textbox": "0.2.0", + "@gradio/theme": "0.1.0", + "@gradio/tooltip": "0.0.1", + "@gradio/tootils": "0.0.2", + "@gradio/upload": "0.2.1", + "@gradio/uploadbutton": "0.0.5", + "@gradio/utils": "0.1.1", + "@gradio/video": "0.0.6", + "@gradio/wasm": "0.0.1", + "@gradio/fallback": "0.1.1", + "@gradio/preview": "0.0.2", + "@gradio/dataset": "0.0.1", + "@gradio/fileexplorer": "0.2.2", + "imageslider": "0.2.0", + "newnewtext": "0.1.2", + "newtext": "0.0.1", + "@gradio/storybook": "0.0.1" + }, + "changesets": [ + "afraid-cougars-rescue", + "bright-planes-divide", + "bright-yaks-wink", + "cold-hoops-heal", + "cold-lemons-roll", + "crazy-dancers-allow", + "cute-crabs-know", + "dark-cups-see", + "dirty-ghosts-tickle", + "dry-points-join", + "easy-mirrors-retire", + "eleven-steaks-tan", + "empty-bobcats-judge", + "flat-experts-wink", + "fresh-ears-pump", + "gentle-parks-fry", + "great-rice-grab", + "green-tips-read", + "heavy-animals-think", + "hip-drinks-bow", + "hot-icons-film", + "hungry-melons-pump", + "icy-cars-boil", + "large-banks-push", + "lazy-aliens-drive", + "lovely-news-speak", + "modern-forks-march", + "nasty-dryers-show", + "nice-actors-write", + "old-heads-give", + "plain-groups-win", + "plenty-teeth-clap", + "public-chairs-chew", + "purple-jokes-shake", + "real-spoons-pick", + "sad-ears-sink", + "sad-eels-sink", + "sad-icons-relax", + "short-clouds-see", + "silver-beers-refuse", + "slick-bats-study", + "slick-pants-stand", + "smart-groups-study", + "some-shoes-relate", + "strange-lizards-boil", + "strong-peas-tell", + "tame-chairs-tan", + "tasty-candies-type", + "three-trams-sniff", + "tough-parrots-relate", + "true-bugs-shine", + "twenty-dryers-wave", + "twenty-gifts-tickle", + "two-games-dress", + "two-mirrors-nail", + "upset-crews-learn", + "vast-terms-rhyme", + "wet-places-hunt", + "wise-beans-itch" + ] } diff --git a/.config/basevite.config.ts b/.config/basevite.config.ts index 5e12d3264312d..378aa1bf963b8 100644 --- a/.config/basevite.config.ts +++ b/.config/basevite.config.ts @@ -21,7 +21,9 @@ const theme_token_path = join( "tokens.css" ); -const version = JSON.parse(readFileSync(version_path, { encoding: 'utf-8' })).version.trim().replace(/\./g, '-'); +const version = JSON.parse(readFileSync(version_path, { encoding: "utf-8" })) + .version.trim() + .replace(/\./g, "-"); //@ts-ignore export default defineConfig(({ mode }) => { diff --git a/client/js/src/client.ts b/client/js/src/client.ts index f3a8b8ad4e4b6..c7140909c55ae 100644 --- a/client/js/src/client.ts +++ b/client/js/src/client.ts @@ -432,11 +432,9 @@ export function api_factory( let payload: Payload; let complete: false | Record = false; const listener_map: ListenerMap = {}; - let url_params = "" - if (typeof(window) !== "undefined") { - url_params = new URLSearchParams( - window.location.search - ).toString(); + let url_params = ""; + if (typeof window !== "undefined") { + url_params = new URLSearchParams(window.location.search).toString(); } handle_blob( diff --git a/js/_website/src/app.html b/js/_website/src/app.html index 06dda00f89ee0..c8f78c33b6d87 100644 --- a/js/_website/src/app.html +++ b/js/_website/src/app.html @@ -7,7 +7,10 @@ %sveltekit.head% - +
%sveltekit.body%
diff --git a/js/_website/src/lib/components/CopyButton.svelte b/js/_website/src/lib/components/CopyButton.svelte index 3e0f6582ce6f5..17edb3ab34e6e 100644 --- a/js/_website/src/lib/components/CopyButton.svelte +++ b/js/_website/src/lib/components/CopyButton.svelte @@ -1,21 +1,20 @@ - \ No newline at end of file + diff --git a/js/_website/src/lib/components/DocsNav.svelte b/js/_website/src/lib/components/DocsNav.svelte index a46dd181c97c4..c7576636fbdea 100644 --- a/js/_website/src/lib/components/DocsNav.svelte +++ b/js/_website/src/lib/components/DocsNav.svelte @@ -121,10 +121,9 @@ TabbedInterfaceTabbedInterface - + - + diff --git a/js/_website/src/routes/+layout.svelte b/js/_website/src/routes/+layout.svelte index d43854ea41c65..7bfdf5d5e54ce 100644 --- a/js/_website/src/routes/+layout.svelte +++ b/js/_website/src/routes/+layout.svelte @@ -26,26 +26,26 @@ import version_json from "$lib/json/version.json"; let version = version_json.version; - import CopyButton from '$lib/components/CopyButton.svelte' + import CopyButton from "$lib/components/CopyButton.svelte"; import { afterNavigate } from "$app/navigation"; afterNavigate(() => { - for (const node of document.querySelectorAll('.codeblock')) { - let children = Array.from(node.querySelectorAll('pre, a')); + for (const node of document.querySelectorAll(".codeblock")) { + let children = Array.from(node.querySelectorAll("pre, a")); let textContent = node.textContent; node.innerHTML = ""; - + new CopyButton({ target: node, props: { - content: textContent ?? '', - }, - }) + content: textContent ?? "" + } + }); for (const child of children) { node.appendChild(child); } - }}) - + } + }); diff --git a/js/_website/src/routes/[[version]]/docs/[doc]/+page.server.ts b/js/_website/src/routes/[[version]]/docs/[doc]/+page.server.ts index bcfe132c9c969..78d491e52ca94 100644 --- a/js/_website/src/routes/[[version]]/docs/[doc]/+page.server.ts +++ b/js/_website/src/routes/[[version]]/docs/[doc]/+page.server.ts @@ -1,8 +1,7 @@ import Prism from "prismjs"; import "prismjs/components/prism-python"; import { make_slug_processor } from "$lib/utils"; -import { error } from '@sveltejs/kit'; - +import { error } from "@sveltejs/kit"; let language = "python"; @@ -16,7 +15,17 @@ const COLOR_SETS = [ ]; export async function load({ params, parent }) { - const { docs, components, helpers, modals, py_client, routes, on_main, wheel, pages } = await parent(); + const { + docs, + components, + helpers, + modals, + py_client, + routes, + on_main, + wheel, + pages + } = await parent(); let name = params.doc; let obj; @@ -25,7 +34,7 @@ export async function load({ params, parent }) { let method_headers = []; const get_slug = make_slug_processor(); - if (!(pages.some((p: string) => p === params.doc))) { + if (!pages.some((p: string) => p === params.doc)) { throw error(404); } @@ -49,10 +58,10 @@ export async function load({ params, parent }) { } else if (obj.name == "ChatInterface") { obj.prev_obj = "Interface"; obj.next_obj = "TabbedInterface"; - } else if (obj.name == "TabbedInterface") { + } else if (obj.name == "TabbedInterface") { obj.prev_obj = "ChatInterface"; obj.next_obj = "Blocks"; - } else if (obj.name == "Blocks") { + } else if (obj.name == "Blocks") { obj.prev_obj = "TabbedInterface"; obj.next_obj = "Row"; } diff --git a/js/_website/src/routes/[[version]]/docs/[doc]/+page.svelte b/js/_website/src/routes/[[version]]/docs/[doc]/+page.svelte index c9866a814663b..7b211db4fa179 100644 --- a/js/_website/src/routes/[[version]]/docs/[doc]/+page.svelte +++ b/js/_website/src/routes/[[version]]/docs/[doc]/+page.svelte @@ -104,19 +104,24 @@ See the Release History

- + {#if on_main} -
+

To install Gradio from main, run the following command:

-
pip install {wheel}
+
pip install {wheel}
-

- *Note: Setting share=True in launch() will not work. +

+ *Note: Setting share=True in + launch() will not work.

-
+
{/if}
@@ -164,11 +169,11 @@
- {#if obj.override_signature} + {#if obj.override_signature}
{obj.override_signature}
- {:else} + {:else}
{obj.parent}.{obj.name}(	# {python_type.type} {#if python_type.description}({python_type.description}){/if} in '{label}' {component} component{/each}{#if named}
-		api_name="/{dependency.api_name}"{:else}
-		fn_index={dependency_index}
-		{/if}
+							fn_index={dependency_index}
+						{/if}
 )
 print(result)
diff --git a/js/app/src/api_docs/ResponseObject.svelte b/js/app/src/api_docs/ResponseObject.svelte index cf048802b1ef0..3def7e7c2d813 100644 --- a/js/app/src/api_docs/ResponseObject.svelte +++ b/js/app/src/api_docs/ResponseObject.svelte @@ -24,12 +24,8 @@ > # {#if current_language === "python"}{python_type.type}{#if python_type?.description} ({python_type.description}){/if}{:else}{js_returns[ i - ].type}{#if js_returns[ - i - ].description} ({js_returns[ - i - ] - .description}){/if}{/if} + ].type}{#if js_returns[i].description} ({js_returns[i] + .description}){/if}{/if} representing output in '{label}' {component} diff --git a/js/app/src/lang/ckb.json b/js/app/src/lang/ckb.json index 12bb01ac376a6..fcbbaae925ad3 100644 --- a/js/app/src/lang/ckb.json +++ b/js/app/src/lang/ckb.json @@ -1,108 +1,108 @@ { - "3D_model": { - "3d_model": "مۆدێلی سێ ڕەهەندی" - }, - "annotated_image": { - "annotated_image": "وێنەی نیشانە کراو" - }, - "audio": { - "allow_recording_access": "تکایە ڕێگە بدە بە بەکارهێنانی مایکرۆفۆنەکە بۆ تۆمارکردن.", - "audio": "دەنگ", - "record_from_microphone": "تۆمارکردن لە مایکەوە", - "stop_recording": "تۆمارکردن بوەستێنە" - }, - "blocks": { - "connection_can_break": "لە مۆبایلدا، پەیوەندییەکە دەکرێت بپچڕێت ئەگەر ئەم تابە چالاک نەبێت یان ئامێرەکە بچێتە دۆخی پشوو، ئەمەش شوێنی خۆت لە ڕیزدا لەدەست دەدات.", - "long_requests_queue": "ڕیزێکی درێژی داواکاری هەیە. ئەم سپەیسە دووباد بکە بۆی چاوەڕوان نەبیت.", - "lost_connection": "پەیوەندی پچڕا بەهۆی جێهێشتنی پەیج. " - }, - "checkbox": { - "checkbox": "بۆکسی هەڵبژاردن", - "checkbox_group": "گروپی بۆکسی هەڵبژاردن" - }, - "code": { - "code": "کۆد" - }, - "color_picker": { - "color_picker": "ڕەنگ هەڵبژاردە" - }, - "common": { - "built_with": "دروستکراوە لەگەڵ...", - "built_with_gradio": "Gradio دروستکراوە بە", - "clear": "خاوێنکردنەوە", - "download": "دابەزاندن", - "edit": "بژارکردن", - "empty": "بەتاڵ", - "error": "هەڵە", - "hosted_on": "میوانداری کراوە لە", - "loading": "بارکردن", - "logo": "لۆگۆ", - "or": "یان", - "remove": "لابردن", - "share": "هاوبەشکردن", - "submit": "پێشکەشکردن", - "undo": "پووچکردنەوە" - }, - "dataframe": { - "incorrect_format": "فۆرماتێکی هەڵە، تەنها فایلەکانی CSV و TSV پشتگیری دەکرێن", - "new_column": "ستوونی نوێ", - "new_row": "ڕیزێکی نوێ" - }, - "dropdown": { - "dropdown": "فڕێدانە خوار" - }, - "errors": { - "build_error": "هەڵەی دروستکردن هەیە", - "config_error": "هەڵەی ڕێکخستن هەیە", - "contact_page_author": "تکایە پەیوەندی بە نووسەری پەیجەوە بکەن بۆ ئەوەی ئاگاداریان بکەنەوە.", - "no_app_file": "هیچ فایلێکی ئەپ نییە", - "runtime_error": "هەڵەیەکی runtime هەیە", - "space_not_working": "\"سپەیسەکە کارناکات چونکە\" {0}", - "space_paused": "فەزاکە وەستاوە", - "use_via_api": "لە ڕێگەی API بەکاری بهێنە" - }, - "file": { - "uploading": "بارکردن..." - }, - "highlighted_text": { - "highlighted_text": "دەقی ڕۆشن کراو" - }, - "image": { - "allow_webcam_access": "تکایە ڕێگە بدە بە بەکارهێنانی وێبکامەکە بۆ تۆمارکردن.", - "brush_color": "ڕەنگی فڵچە", - "brush_radius": "تیژڕەوی فڵچە", - "image": "وێنە", - "remove_image": "لابردنی وێنە", - "select_brush_color": "ڕەنگی فڵچە هەڵبژێرە", - "start_drawing": "دەست بکە بە وێنەکێشان", - "use_brush": "فڵچە بەکاربهێنە" - }, - "label": { - "label": "لەیبڵ" - }, - "login": { - "enable_cookies": "ئەگەر تۆ سەردانی HuggingFace Space دەکەیت لە دۆخی نادیاردا، پێویستە کووکی لایەنی سێیەم چالاک بکەیت.", - "incorrect_credentials": "بڕوانامەی هەڵە", - "login": "چونه‌ ژووره‌وه‌" - }, - "number": { - "number": "ژمارە" - }, - "plot": { - "plot": "هێڵکاری" - }, - "radio": { - "radio": "ڕادیۆ" - }, - "slider": { - "slider": "خلیسکە" - }, - "upload_text": { - "click_to_upload": "کلیک بکە بۆ بارکردن", - "drop_audio": "دەنگ لێرە دابنێ", - "drop_csv": "لێرەدا CSV دابنێ", - "drop_file": "فایل لێرە دابنێ", - "drop_image": "وێنە لێرەدا دابنێ", - "drop_video": "ڤیدیۆ لێرە دابنێ" - } - } \ No newline at end of file + "3D_model": { + "3d_model": "مۆدێلی سێ ڕەهەندی" + }, + "annotated_image": { + "annotated_image": "وێنەی نیشانە کراو" + }, + "audio": { + "allow_recording_access": "تکایە ڕێگە بدە بە بەکارهێنانی مایکرۆفۆنەکە بۆ تۆمارکردن.", + "audio": "دەنگ", + "record_from_microphone": "تۆمارکردن لە مایکەوە", + "stop_recording": "تۆمارکردن بوەستێنە" + }, + "blocks": { + "connection_can_break": "لە مۆبایلدا، پەیوەندییەکە دەکرێت بپچڕێت ئەگەر ئەم تابە چالاک نەبێت یان ئامێرەکە بچێتە دۆخی پشوو، ئەمەش شوێنی خۆت لە ڕیزدا لەدەست دەدات.", + "long_requests_queue": "ڕیزێکی درێژی داواکاری هەیە. ئەم سپەیسە دووباد بکە بۆی چاوەڕوان نەبیت.", + "lost_connection": "پەیوەندی پچڕا بەهۆی جێهێشتنی پەیج. " + }, + "checkbox": { + "checkbox": "بۆکسی هەڵبژاردن", + "checkbox_group": "گروپی بۆکسی هەڵبژاردن" + }, + "code": { + "code": "کۆد" + }, + "color_picker": { + "color_picker": "ڕەنگ هەڵبژاردە" + }, + "common": { + "built_with": "دروستکراوە لەگەڵ...", + "built_with_gradio": "Gradio دروستکراوە بە", + "clear": "خاوێنکردنەوە", + "download": "دابەزاندن", + "edit": "بژارکردن", + "empty": "بەتاڵ", + "error": "هەڵە", + "hosted_on": "میوانداری کراوە لە", + "loading": "بارکردن", + "logo": "لۆگۆ", + "or": "یان", + "remove": "لابردن", + "share": "هاوبەشکردن", + "submit": "پێشکەشکردن", + "undo": "پووچکردنەوە" + }, + "dataframe": { + "incorrect_format": "فۆرماتێکی هەڵە، تەنها فایلەکانی CSV و TSV پشتگیری دەکرێن", + "new_column": "ستوونی نوێ", + "new_row": "ڕیزێکی نوێ" + }, + "dropdown": { + "dropdown": "فڕێدانە خوار" + }, + "errors": { + "build_error": "هەڵەی دروستکردن هەیە", + "config_error": "هەڵەی ڕێکخستن هەیە", + "contact_page_author": "تکایە پەیوەندی بە نووسەری پەیجەوە بکەن بۆ ئەوەی ئاگاداریان بکەنەوە.", + "no_app_file": "هیچ فایلێکی ئەپ نییە", + "runtime_error": "هەڵەیەکی runtime هەیە", + "space_not_working": "\"سپەیسەکە کارناکات چونکە\" {0}", + "space_paused": "فەزاکە وەستاوە", + "use_via_api": "لە ڕێگەی API بەکاری بهێنە" + }, + "file": { + "uploading": "بارکردن..." + }, + "highlighted_text": { + "highlighted_text": "دەقی ڕۆشن کراو" + }, + "image": { + "allow_webcam_access": "تکایە ڕێگە بدە بە بەکارهێنانی وێبکامەکە بۆ تۆمارکردن.", + "brush_color": "ڕەنگی فڵچە", + "brush_radius": "تیژڕەوی فڵچە", + "image": "وێنە", + "remove_image": "لابردنی وێنە", + "select_brush_color": "ڕەنگی فڵچە هەڵبژێرە", + "start_drawing": "دەست بکە بە وێنەکێشان", + "use_brush": "فڵچە بەکاربهێنە" + }, + "label": { + "label": "لەیبڵ" + }, + "login": { + "enable_cookies": "ئەگەر تۆ سەردانی HuggingFace Space دەکەیت لە دۆخی نادیاردا، پێویستە کووکی لایەنی سێیەم چالاک بکەیت.", + "incorrect_credentials": "بڕوانامەی هەڵە", + "login": "چونه‌ ژووره‌وه‌" + }, + "number": { + "number": "ژمارە" + }, + "plot": { + "plot": "هێڵکاری" + }, + "radio": { + "radio": "ڕادیۆ" + }, + "slider": { + "slider": "خلیسکە" + }, + "upload_text": { + "click_to_upload": "کلیک بکە بۆ بارکردن", + "drop_audio": "دەنگ لێرە دابنێ", + "drop_csv": "لێرەدا CSV دابنێ", + "drop_file": "فایل لێرە دابنێ", + "drop_image": "وێنە لێرەدا دابنێ", + "drop_video": "ڤیدیۆ لێرە دابنێ" + } +} diff --git a/js/app/src/lang/eu.json b/js/app/src/lang/eu.json index 09a3eb0c839e0..50a124d50230e 100644 --- a/js/app/src/lang/eu.json +++ b/js/app/src/lang/eu.json @@ -1,16 +1,16 @@ -{ - "common": { - "built_with_gradio": "Gradiorekin eraikia", - "clear": "Garbitu", - "or": "edo", - "submit": "Bidali" - }, - "upload_text": { - "click_to_upload": "Klik egin kargatzeko", - "drop_audio": "Jarri hemen audioa", - "drop_csv": "Jarri hemen CSVa", - "drop_file": "Jarri hemen fitxategia", - "drop_image": "Jarri hemen irudia", - "drop_video": "Jarri hemen bideoa" - } -} \ No newline at end of file +{ + "common": { + "built_with_gradio": "Gradiorekin eraikia", + "clear": "Garbitu", + "or": "edo", + "submit": "Bidali" + }, + "upload_text": { + "click_to_upload": "Klik egin kargatzeko", + "drop_audio": "Jarri hemen audioa", + "drop_csv": "Jarri hemen CSVa", + "drop_file": "Jarri hemen fitxategia", + "drop_image": "Jarri hemen irudia", + "drop_video": "Jarri hemen bideoa" + } +} diff --git a/js/audio/package.json b/js/audio/package.json index 1ed493acafe8c..8b68d3692fb0c 100644 --- a/js/audio/package.json +++ b/js/audio/package.json @@ -24,4 +24,4 @@ "./example": "./Example.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/box/package.json b/js/box/package.json index d846cb5a3e9f5..3d7f65b6f78b4 100644 --- a/js/box/package.json +++ b/js/box/package.json @@ -14,4 +14,4 @@ "dependencies": { "@gradio/atoms": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/chatbot/Chatbot.stories.svelte b/js/chatbot/Chatbot.stories.svelte index daba5aa292fbd..8a6d750d4ce1e 100644 --- a/js/chatbot/Chatbot.stories.svelte +++ b/js/chatbot/Chatbot.stories.svelte @@ -10,20 +10,20 @@ label: { control: "text", description: "The textbox label", - name: "label", + name: "label" }, show_label: { options: [true, false], description: "Whether to show the label", control: { type: "boolean" }, - defaultValue: true, + defaultValue: true }, rtl: { options: [true, false], description: "Whether to render right-to-left", control: { type: "boolean" }, - defaultValue: false, - }, + defaultValue: false + } }} /> @@ -33,10 +33,10 @@ value={[ [ "Can you write a function in Python?", - "```py\ndef test():\n\tprint(x)\n```", + "```py\ndef test():\n\tprint(x)\n```" ], ["Can you do math?", "$$1+1=2$$"], - ["Can you say nothing?", null], + ["Can you say nothing?", null] ]} /> @@ -55,7 +55,7 @@ name="Chatbot with text rendered right-to-left" args={{ rtl: true, - latex_delimiters: [{ left: "$$", right: "$$", display: true }], + latex_delimiters: [{ left: "$$", right: "$$", display: true }] }} /> @@ -64,14 +64,14 @@ args={{ rtl: true, latex_delimiters: [{ left: "$$", right: "$$", display: true }], - show_copy_button: true, + show_copy_button: true }} /> @@ -79,7 +79,7 @@ name="Chatbot with panel layout enabled" args={{ bubble_full_width: false, - layout: "panel", + layout: "panel" }} /> @@ -89,8 +89,8 @@ layout: "panel", avatar_images: [ "https://avatars.githubusercontent.com/u/100000?v=4", - "https://avatars.githubusercontent.com/u/100000?v=4", - ], + "https://avatars.githubusercontent.com/u/100000?v=4" + ] }} /> @@ -101,7 +101,7 @@ layout: "bubble", avatar_images: [ "https://avatars.githubusercontent.com/u/100000?v=4", - "https://avatars.githubusercontent.com/u/100000?v=4", - ], + "https://avatars.githubusercontent.com/u/100000?v=4" + ] }} /> diff --git a/js/chatbot/package.json b/js/chatbot/package.json index 396aa6779512f..6e09ed323e07e 100644 --- a/js/chatbot/package.json +++ b/js/chatbot/package.json @@ -24,4 +24,4 @@ ".": "./Index.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/checkbox/package.json b/js/checkbox/package.json index ca7860d637c50..8b372a0282b5e 100644 --- a/js/checkbox/package.json +++ b/js/checkbox/package.json @@ -17,4 +17,4 @@ "@gradio/statustracker": "workspace:^", "@gradio/utils": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/checkbox/shared/Checkbox.svelte b/js/checkbox/shared/Checkbox.svelte index 5e7a0606e09ff..fb2e054742570 100644 --- a/js/checkbox/shared/Checkbox.svelte +++ b/js/checkbox/shared/Checkbox.svelte @@ -34,7 +34,7 @@ dispatch("select", { index: 0, value: label, - selected: value, + selected: value }); } }} @@ -43,7 +43,7 @@ dispatch("select", { index: 0, value: label, - selected: evt.currentTarget.checked, + selected: evt.currentTarget.checked }); }} {disabled} diff --git a/js/checkboxgroup/package.json b/js/checkboxgroup/package.json index 638cd4d952b7b..6c6ed6af8942a 100644 --- a/js/checkboxgroup/package.json +++ b/js/checkboxgroup/package.json @@ -17,4 +17,4 @@ "@gradio/statustracker": "workspace:^", "@gradio/utils": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/checkboxgroup/shared/Checkboxgroup.svelte b/js/checkboxgroup/shared/Checkboxgroup.svelte index 9dd9b4682e0da..ca801986ff885 100644 --- a/js/checkboxgroup/shared/Checkboxgroup.svelte +++ b/js/checkboxgroup/shared/Checkboxgroup.svelte @@ -58,7 +58,7 @@ dispatch("select", { index: i, value: choice[1], - selected: evt.currentTarget.checked, + selected: evt.currentTarget.checked })} on:keydown={(event) => { if (event.key === "Enter") { @@ -66,7 +66,7 @@ dispatch("select", { index: i, value: choice[1], - selected: !value.includes(choice[1]), + selected: !value.includes(choice[1]) }); } }} diff --git a/js/code/package.json b/js/code/package.json index 55fd93cbac0f7..a921a06a1006f 100644 --- a/js/code/package.json +++ b/js/code/package.json @@ -39,4 +39,4 @@ "./example": "./Example.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/code/shared/Code.svelte b/js/code/shared/Code.svelte index 101cb25569494..3e69f612f37c8 100644 --- a/js/code/shared/Code.svelte +++ b/js/code/shared/Code.svelte @@ -4,7 +4,7 @@ import { EditorView, keymap, - placeholder as placeholderExt, + placeholder as placeholderExt } from "@codemirror/view"; import { StateEffect, EditorState, type Extension } from "@codemirror/state"; import { indentWithTab } from "@codemirror/commands"; @@ -50,8 +50,8 @@ changes: { from: 0, to: view.state.doc.length, - insert: newDoc, - }, + insert: newDoc + } }); } } @@ -65,7 +65,7 @@ function createEditorView(): EditorView { return new EditorView({ parent: element, - state: createEditorState(value), + state: createEditorState(value) }); } @@ -119,7 +119,7 @@ ), FontTheme, ...getTheme(), - ...extensions, + ...extensions ]; return stateExtensions; } @@ -127,36 +127,36 @@ const FontTheme = EditorView.theme({ "&": { fontSize: "var(--text-sm)", - backgroundColor: "var(--border-color-secondary)", + backgroundColor: "var(--border-color-secondary)" }, ".cm-content": { paddingTop: "5px", paddingBottom: "5px", color: "var(--body-text-color)", fontFamily: "var(--font-mono)", - minHeight: "100%", + minHeight: "100%" }, ".cm-gutters": { marginRight: "1px", borderRight: "1px solid var(--border-color-primary)", backgroundColor: "transparent", - color: "var(--body-text-color-subdued)", + color: "var(--body-text-color-subdued)" }, ".cm-focused": { - outline: "none", + outline: "none" }, ".cm-scroller": { - height: "auto", + height: "auto" }, ".cm-cursor": { - borderLeftColor: "var(--body-text-color)", - }, + borderLeftColor: "var(--body-text-color)" + } }); function createEditorState(_value: string | null | undefined): EditorState { return EditorState.create({ doc: _value ?? undefined, - extensions: getExtensions(), + extensions: getExtensions() }); } @@ -170,7 +170,7 @@ const extensions: Extension[] = [ EditorView.editable.of(!readonly), EditorState.readOnly.of(readonly), - EditorView.contentAttributes.of({ "aria-label": "Code input container" }), + EditorView.contentAttributes.of({ "aria-label": "Code input container" }) ]; if (basic) { @@ -203,7 +203,7 @@ function reconfigure(): void { view?.dispatch({ - effects: StateEffect.reconfigure.of(getExtensions()), + effects: StateEffect.reconfigure.of(getExtensions()) }); } diff --git a/js/colorpicker/package.json b/js/colorpicker/package.json index b469481f91b12..71516bf5ed332 100644 --- a/js/colorpicker/package.json +++ b/js/colorpicker/package.json @@ -17,4 +17,4 @@ "@gradio/statustracker": "workspace:^", "@gradio/utils": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/column/package.json b/js/column/package.json index f2ec3d9406689..0cb169c327aec 100644 --- a/js/column/package.json +++ b/js/column/package.json @@ -11,4 +11,4 @@ ".": "./Index.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/dataframe/package.json b/js/dataframe/package.json index 9a7c6e6d746cd..bdee98a81ed5f 100644 --- a/js/dataframe/package.json +++ b/js/dataframe/package.json @@ -28,4 +28,4 @@ "./example": "./Example.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/dataset/package.json b/js/dataset/package.json index 1554b0e9a6efa..4cdc06fd80f76 100644 --- a/js/dataset/package.json +++ b/js/dataset/package.json @@ -16,4 +16,4 @@ "@gradio/utils": "workspace:^", "@gradio/upload": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/dropdown/package.json b/js/dropdown/package.json index 4c671fa94f92a..d051cf5e5b064 100644 --- a/js/dropdown/package.json +++ b/js/dropdown/package.json @@ -18,4 +18,4 @@ "@gradio/statustracker": "workspace:^", "@gradio/utils": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/dropdown/shared/Multiselect.svelte b/js/dropdown/shared/Multiselect.svelte index e7bd9fc70de7f..7fd1f31cc392c 100644 --- a/js/dropdown/shared/Multiselect.svelte +++ b/js/dropdown/shared/Multiselect.svelte @@ -20,7 +20,7 @@ export let container = true; export let allow_custom_value = false; export let filterable = true; - export let i18n: I18nFormatter + export let i18n: I18nFormatter; let filter_input: HTMLElement; let input_text = ""; @@ -113,7 +113,7 @@ typeof option_index === "number" ? choices_values[option_index] : option_index, - selected: false, + selected: false }); } @@ -126,7 +126,7 @@ typeof option_index === "number" ? choices_values[option_index] : option_index, - selected: true, + selected: true }); } if (selected_indices.length === max_choices) { diff --git a/js/fallback/package.json b/js/fallback/package.json index f59c55471ccdb..a46d64925781e 100644 --- a/js/fallback/package.json +++ b/js/fallback/package.json @@ -18,4 +18,4 @@ "@gradio/utils": "workspace:^", "@zerodevx/svelte-json-view": "^1.0.7" } -} \ No newline at end of file +} diff --git a/js/file/package.json b/js/file/package.json index b62599b73faef..70d2ce10eacc7 100644 --- a/js/file/package.json +++ b/js/file/package.json @@ -20,4 +20,4 @@ "./example": "./Example.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/fileexplorer/package.json b/js/fileexplorer/package.json index 0272685af2c1b..c5f479f38ba36 100644 --- a/js/fileexplorer/package.json +++ b/js/fileexplorer/package.json @@ -23,4 +23,4 @@ "./example": "./Example.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/form/package.json b/js/form/package.json index 0981e7e55c5b4..7a5c0e6456dc8 100644 --- a/js/form/package.json +++ b/js/form/package.json @@ -16,4 +16,4 @@ ".": "./Index.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/gallery/package.json b/js/gallery/package.json index 01e2bfc1a1d70..120388a4eff16 100644 --- a/js/gallery/package.json +++ b/js/gallery/package.json @@ -20,4 +20,4 @@ ".": "./Index.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/gallery/shared/Gallery.svelte b/js/gallery/shared/Gallery.svelte index c1731d80b7489..aedc48073bb4a 100644 --- a/js/gallery/shared/Gallery.svelte +++ b/js/gallery/shared/Gallery.svelte @@ -466,4 +466,4 @@ .icon-buttons a { margin: var(--size-1) 0; } - \ No newline at end of file + diff --git a/js/group/package.json b/js/group/package.json index 13b940d93e18d..8d98e7770b97c 100644 --- a/js/group/package.json +++ b/js/group/package.json @@ -11,4 +11,4 @@ ".": "./Index.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/highlightedtext/package.json b/js/highlightedtext/package.json index 537b9726b210c..d3de16e8b06da 100644 --- a/js/highlightedtext/package.json +++ b/js/highlightedtext/package.json @@ -18,4 +18,4 @@ ".": "./Index.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/html/package.json b/js/html/package.json index aa61ed5e2b9e6..e4324bbbe57fb 100644 --- a/js/html/package.json +++ b/js/html/package.json @@ -17,4 +17,4 @@ "./example": "./Example.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/image/package.json b/js/image/package.json index 29ca5559f4ae1..e75e5bf598d5b 100644 --- a/js/image/package.json +++ b/js/image/package.json @@ -23,4 +23,4 @@ "./example": "./Example.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/image/shared/Webcam.svelte b/js/image/shared/Webcam.svelte index b501b26e00bfd..160b11e1b2570 100644 --- a/js/image/shared/Webcam.svelte +++ b/js/image/shared/Webcam.svelte @@ -34,7 +34,7 @@ try { stream = await navigator.mediaDevices.getUserMedia({ video: true, - audio: include_audio, + audio: include_audio }); video_source.srcObject = stream; video_source.muted = true; @@ -105,7 +105,7 @@ return; } media_recorder = new MediaRecorder(stream, { - mimeType: mimeType, + mimeType: mimeType }); media_recorder.addEventListener("dataavailable", function (e) { recorded_blobs.push(e.data); diff --git a/js/json/package.json b/js/json/package.json index faa23b5c31f56..aaf1c0fdd454f 100644 --- a/js/json/package.json +++ b/js/json/package.json @@ -17,4 +17,4 @@ ".": "./Index.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/label/package.json b/js/label/package.json index 51a8cbc81177d..20c35add9b10d 100644 --- a/js/label/package.json +++ b/js/label/package.json @@ -17,4 +17,4 @@ ".": "./Index.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/markdown/package.json b/js/markdown/package.json index 2d1bacf9d208c..4e0aa49da4adb 100644 --- a/js/markdown/package.json +++ b/js/markdown/package.json @@ -25,4 +25,4 @@ "marked-highlight": "^2.0.1", "prismjs": "1.29.0" } -} \ No newline at end of file +} diff --git a/js/model3D/package.json b/js/model3D/package.json index 7781784105b2d..eac7e2c87339a 100644 --- a/js/model3D/package.json +++ b/js/model3D/package.json @@ -22,4 +22,4 @@ "./example": "./Example.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/number/package.json b/js/number/package.json index d2088810c7e14..a0a3d9c6eab5e 100644 --- a/js/number/package.json +++ b/js/number/package.json @@ -17,4 +17,4 @@ "@gradio/statustracker": "workspace:^", "@gradio/utils": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/plot/package.json b/js/plot/package.json index 110ae0829b8ff..0d48e8d6177de 100644 --- a/js/plot/package.json +++ b/js/plot/package.json @@ -23,4 +23,4 @@ ".": "./Index.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/preview/package.json b/js/preview/package.json index 8e811c1dd88ce..0f9d6bb553653 100644 --- a/js/preview/package.json +++ b/js/preview/package.json @@ -1,41 +1,41 @@ { - "name": "@gradio/preview", - "version": "0.1.0-beta.6", - "description": "Gradio UI packages", - "type": "module", - "main": "src/index.ts", - "author": "", - "license": "ISC", - "private": false, - "scripts": { - "build": "rollup -c" - }, - "devDependencies": { - "@rollup/plugin-commonjs": "^25.0.4", - "@rollup/plugin-json": "^6.0.0", - "@rollup/plugin-node-resolve": "^15.1.0", - "@rollup/plugin-typescript": "^11.1.2", - "rollup": "^3.28.0", - "svelte-hmr": "^0.15.3", - "vite": "^4.4.9" - }, - "dependencies": { - "@originjs/vite-plugin-commonjs": "^1.0.3", - "@rollup/plugin-sucrase": "^5.0.1", - "@sveltejs/vite-plugin-svelte": "^2.4.2", - "@types/which": "^3.0.0", - "coffeescript": "^2.7.0", - "css-tree": "2.3.1", - "esbuild-wasm": "^0.19.0", - "lightningcss": "^1.21.7", - "pug": "^3.0.2", - "rollup-plugin-ignore": "^1.0.10", - "sass": "^1.66.1", - "stylus": "^0.60.0", - "sucrase": "^3.34.0", - "sugarss": "^4.0.1", - "svelte": "^4.2.0", - "which": "4.0.0", - "yootils": "^0.3.1" - } -} \ No newline at end of file + "name": "@gradio/preview", + "version": "0.1.0-beta.6", + "description": "Gradio UI packages", + "type": "module", + "main": "src/index.ts", + "author": "", + "license": "ISC", + "private": false, + "scripts": { + "build": "rollup -c" + }, + "devDependencies": { + "@rollup/plugin-commonjs": "^25.0.4", + "@rollup/plugin-json": "^6.0.0", + "@rollup/plugin-node-resolve": "^15.1.0", + "@rollup/plugin-typescript": "^11.1.2", + "rollup": "^3.28.0", + "svelte-hmr": "^0.15.3", + "vite": "^4.4.9" + }, + "dependencies": { + "@originjs/vite-plugin-commonjs": "^1.0.3", + "@rollup/plugin-sucrase": "^5.0.1", + "@sveltejs/vite-plugin-svelte": "^2.4.2", + "@types/which": "^3.0.0", + "coffeescript": "^2.7.0", + "css-tree": "2.3.1", + "esbuild-wasm": "^0.19.0", + "lightningcss": "^1.21.7", + "pug": "^3.0.2", + "rollup-plugin-ignore": "^1.0.10", + "sass": "^1.66.1", + "stylus": "^0.60.0", + "sucrase": "^3.34.0", + "sugarss": "^4.0.1", + "svelte": "^4.2.0", + "which": "4.0.0", + "yootils": "^0.3.1" + } +} diff --git a/js/preview/test/imageslider/frontend/package.json b/js/preview/test/imageslider/frontend/package.json index 50368a26c972d..47718cc42d11c 100644 --- a/js/preview/test/imageslider/frontend/package.json +++ b/js/preview/test/imageslider/frontend/package.json @@ -1,27 +1,27 @@ { - "name": "imageslider", - "version": "0.2.1-beta.0", - "description": "Gradio UI packages", - "type": "module", - "main": "./index.svelte", - "author": "", - "license": "ISC", - "private": true, - "dependencies": { - "@gradio/atoms": "workspace:^", - "@gradio/icons": "workspace:^", - "@gradio/statustracker": "workspace:^", - "@gradio/upload": "workspace:^", - "@gradio/utils": "workspace:^", - "cropperjs": "^1.5.12", - "lazy-brush": "^1.0.1", - "resize-observer-polyfill": "^1.5.1" - }, - "main_changeset": true, - "exports": { - "./package.json": "./package.json", - "./interactive": "./interactive/index.ts", - "./static": "./static/index.ts", - "./example": "./example/index.ts" - } -} \ No newline at end of file + "name": "imageslider", + "version": "0.2.1-beta.0", + "description": "Gradio UI packages", + "type": "module", + "main": "./index.svelte", + "author": "", + "license": "ISC", + "private": true, + "dependencies": { + "@gradio/atoms": "workspace:^", + "@gradio/icons": "workspace:^", + "@gradio/statustracker": "workspace:^", + "@gradio/upload": "workspace:^", + "@gradio/utils": "workspace:^", + "cropperjs": "^1.5.12", + "lazy-brush": "^1.0.1", + "resize-observer-polyfill": "^1.5.1" + }, + "main_changeset": true, + "exports": { + "./package.json": "./package.json", + "./interactive": "./interactive/index.ts", + "./static": "./static/index.ts", + "./example": "./example/index.ts" + } +} diff --git a/js/preview/test/newtext/frontend/example/index.ts b/js/preview/test/newtext/frontend/example/index.ts index 5f87dcb3a1b3a..ccf7b447f6d29 100644 --- a/js/preview/test/newtext/frontend/example/index.ts +++ b/js/preview/test/newtext/frontend/example/index.ts @@ -1 +1 @@ -export { default } from "./newtext.svelte"; \ No newline at end of file +export { default } from "./newtext.svelte"; diff --git a/js/preview/test/newtext/frontend/example/newtext.svelte b/js/preview/test/newtext/frontend/example/newtext.svelte index e5e40bb4b2546..2ccd9894d9605 100644 --- a/js/preview/test/newtext/frontend/example/newtext.svelte +++ b/js/preview/test/newtext/frontend/example/newtext.svelte @@ -1,7 +1,7 @@ - - \ No newline at end of file + + diff --git a/js/preview/test/newtext/frontend/interactive/index.ts b/js/preview/test/newtext/frontend/interactive/index.ts index 5f87dcb3a1b3a..ccf7b447f6d29 100644 --- a/js/preview/test/newtext/frontend/interactive/index.ts +++ b/js/preview/test/newtext/frontend/interactive/index.ts @@ -1 +1 @@ -export { default } from "./newtext.svelte"; \ No newline at end of file +export { default } from "./newtext.svelte"; diff --git a/js/preview/test/newtext/frontend/interactive/newtext.svelte b/js/preview/test/newtext/frontend/interactive/newtext.svelte index e5e40bb4b2546..2ccd9894d9605 100644 --- a/js/preview/test/newtext/frontend/interactive/newtext.svelte +++ b/js/preview/test/newtext/frontend/interactive/newtext.svelte @@ -1,7 +1,7 @@ - - \ No newline at end of file + + diff --git a/js/preview/test/newtext/frontend/package.json b/js/preview/test/newtext/frontend/package.json index f9ce53615df98..c2d1cbae87841 100644 --- a/js/preview/test/newtext/frontend/package.json +++ b/js/preview/test/newtext/frontend/package.json @@ -1,20 +1,20 @@ { - "name": "newtext", - "version": "0.1.0-beta.0", - "description": "Custom Component", - "type": "module", - "main": "./index.svelte", - "author": "", - "license": "ISC", - "private": true, - "dependencies": { - "@zerodevx/svelte-json-view": "^1.0" - }, - "exports": { - ".": "./index.svelte", - "./package.json": "./package.json", - "./interactive": "./interactive/index.ts", - "./static": "./static/index.ts", - "./example": "./example/index.ts" - } -} \ No newline at end of file + "name": "newtext", + "version": "0.1.0-beta.0", + "description": "Custom Component", + "type": "module", + "main": "./index.svelte", + "author": "", + "license": "ISC", + "private": true, + "dependencies": { + "@zerodevx/svelte-json-view": "^1.0" + }, + "exports": { + ".": "./index.svelte", + "./package.json": "./package.json", + "./interactive": "./interactive/index.ts", + "./static": "./static/index.ts", + "./example": "./example/index.ts" + } +} diff --git a/js/preview/test/newtext/frontend/shared/index.ts b/js/preview/test/newtext/frontend/shared/index.ts index 5f87dcb3a1b3a..ccf7b447f6d29 100644 --- a/js/preview/test/newtext/frontend/shared/index.ts +++ b/js/preview/test/newtext/frontend/shared/index.ts @@ -1 +1 @@ -export { default } from "./newtext.svelte"; \ No newline at end of file +export { default } from "./newtext.svelte"; diff --git a/js/preview/test/newtext/frontend/shared/newtext.svelte b/js/preview/test/newtext/frontend/shared/newtext.svelte index e5e40bb4b2546..2ccd9894d9605 100644 --- a/js/preview/test/newtext/frontend/shared/newtext.svelte +++ b/js/preview/test/newtext/frontend/shared/newtext.svelte @@ -1,7 +1,7 @@ - - \ No newline at end of file + + diff --git a/js/preview/test/newtext/frontend/static/index.ts b/js/preview/test/newtext/frontend/static/index.ts index 5f87dcb3a1b3a..ccf7b447f6d29 100644 --- a/js/preview/test/newtext/frontend/static/index.ts +++ b/js/preview/test/newtext/frontend/static/index.ts @@ -1 +1 @@ -export { default } from "./newtext.svelte"; \ No newline at end of file +export { default } from "./newtext.svelte"; diff --git a/js/preview/test/newtext/frontend/static/newtext.svelte b/js/preview/test/newtext/frontend/static/newtext.svelte index e5e40bb4b2546..2ccd9894d9605 100644 --- a/js/preview/test/newtext/frontend/static/newtext.svelte +++ b/js/preview/test/newtext/frontend/static/newtext.svelte @@ -1,7 +1,7 @@ - - \ No newline at end of file + + diff --git a/js/radio/package.json b/js/radio/package.json index 21fa89780dbad..a7ee1a0983d14 100644 --- a/js/radio/package.json +++ b/js/radio/package.json @@ -17,4 +17,4 @@ "@gradio/statustracker": "workspace:^", "@gradio/utils": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/row/package.json b/js/row/package.json index 40bc259eaad07..4cbd798695f9b 100644 --- a/js/row/package.json +++ b/js/row/package.json @@ -14,4 +14,4 @@ "devDependencies": { "@gradio/image": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/slider/package.json b/js/slider/package.json index 77cf72a5092b1..aae4af8444c49 100644 --- a/js/slider/package.json +++ b/js/slider/package.json @@ -17,4 +17,4 @@ "@gradio/statustracker": "workspace:^", "@gradio/utils": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/state/package.json b/js/state/package.json index 2a67c1ec382a6..572593904f40f 100644 --- a/js/state/package.json +++ b/js/state/package.json @@ -11,4 +11,4 @@ ".": "./Index.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/storybook/design-tokens/Colors.stories.svelte b/js/storybook/design-tokens/Colors.stories.svelte index e324b2f3b643f..a29de50de88ff 100644 --- a/js/storybook/design-tokens/Colors.stories.svelte +++ b/js/storybook/design-tokens/Colors.stories.svelte @@ -36,7 +36,7 @@ { tokenName: "--neutral-700", value: "#374151" }, { tokenName: "--neutral-800", value: "#1f2937" }, { tokenName: "--neutral-900", value: "#111827" }, - { tokenName: "--neutral-950", value: "#0b0f19" }, + { tokenName: "--neutral-950", value: "#0b0f19" } ]; diff --git a/js/storybook/design-tokens/Icons.stories.svelte b/js/storybook/design-tokens/Icons.stories.svelte index 0ca6e1843f56e..c18de6ccd62cf 100644 --- a/js/storybook/design-tokens/Icons.stories.svelte +++ b/js/storybook/design-tokens/Icons.stories.svelte @@ -40,7 +40,7 @@ Tree, Undo, Video, - Warning, + Warning } from "../../icons/src"; const icons = [ @@ -81,7 +81,7 @@ { name: "Tree", value: Tree }, { name: "Undo", value: Undo }, { name: "Video", value: Video }, - { name: "Warning", value: Warning }, + { name: "Warning", value: Warning } ]; diff --git a/js/storybook/design-tokens/Radii.stories.svelte b/js/storybook/design-tokens/Radii.stories.svelte index f150a4347a982..f5293e2ac9def 100644 --- a/js/storybook/design-tokens/Radii.stories.svelte +++ b/js/storybook/design-tokens/Radii.stories.svelte @@ -10,7 +10,7 @@ { tokenName: "--radius-md", value: "6px" }, { tokenName: "--radius-lg", value: "8px" }, { tokenName: "--radius-xl", value: "12px" }, - { tokenName: "--radius-xxl", value: "22px" }, + { tokenName: "--radius-xxl", value: "22px" } ]; diff --git a/js/storybook/design-tokens/Spacing.stories.svelte b/js/storybook/design-tokens/Spacing.stories.svelte index a46d400916b45..5a65d0786b318 100644 --- a/js/storybook/design-tokens/Spacing.stories.svelte +++ b/js/storybook/design-tokens/Spacing.stories.svelte @@ -10,7 +10,7 @@ { tokenName: "--spacing-md", value: "6px" }, { tokenName: "--spacing-lg", value: "8px" }, { tokenName: "--spacing-xl", value: "10px" }, - { tokenName: "--spacing-xxl", value: "16px" }, + { tokenName: "--spacing-xxl", value: "16px" } ]; diff --git a/js/storybook/design-tokens/TextSize.stories.svelte b/js/storybook/design-tokens/TextSize.stories.svelte index 233e24332218b..8ab046ece69c9 100644 --- a/js/storybook/design-tokens/TextSize.stories.svelte +++ b/js/storybook/design-tokens/TextSize.stories.svelte @@ -10,7 +10,7 @@ { tokenName: "--text-md", value: "14px" }, { tokenName: "--text-lg", value: "16px" }, { tokenName: "--text-xl", value: "22px" }, - { tokenName: "--text-xxl", value: "26px" }, + { tokenName: "--text-xxl", value: "26px" } ]; diff --git a/js/tabitem/package.json b/js/tabitem/package.json index 348eb90b23f93..daae9c5cec82f 100644 --- a/js/tabitem/package.json +++ b/js/tabitem/package.json @@ -16,4 +16,4 @@ "@gradio/tabs": "workspace:^", "@gradio/utils": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/tabs/package.json b/js/tabs/package.json index 5e0c4d9deb2d4..90da3b3e4621c 100644 --- a/js/tabs/package.json +++ b/js/tabs/package.json @@ -14,4 +14,4 @@ "dependencies": { "@gradio/utils": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/textbox/package.json b/js/textbox/package.json index cda843dd4800f..1877042f916d5 100644 --- a/js/textbox/package.json +++ b/js/textbox/package.json @@ -18,4 +18,4 @@ "@gradio/statustracker": "workspace:^", "@gradio/utils": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/textbox/shared/Textbox.svelte b/js/textbox/shared/Textbox.svelte index b6169a9f61edb..02a4941a38f10 100644 --- a/js/textbox/shared/Textbox.svelte +++ b/js/textbox/shared/Textbox.svelte @@ -3,7 +3,7 @@ beforeUpdate, afterUpdate, createEventDispatcher, - tick, + tick } from "svelte"; import { BlockTitle } from "@gradio/atoms"; import { Copy, Check } from "@gradio/icons"; @@ -94,7 +94,7 @@ const text = target.value; const index: [number, number] = [ target.selectionStart as number, - target.selectionEnd as number, + target.selectionEnd as number ]; dispatch("select", { value: text.substring(...index), index: index }); } @@ -171,7 +171,7 @@ resize({ target: _el }); return { - destroy: () => _el.removeEventListener("input", resize), + destroy: () => _el.removeEventListener("input", resize) }; } diff --git a/js/uploadbutton/package.json b/js/uploadbutton/package.json index a55c9d8896bdb..ba7cf70de5736 100644 --- a/js/uploadbutton/package.json +++ b/js/uploadbutton/package.json @@ -17,4 +17,4 @@ "@gradio/upload": "workspace:^", "@gradio/utils": "workspace:^" } -} \ No newline at end of file +} diff --git a/js/video/package.json b/js/video/package.json index 17a604321a09e..c8981495c8f44 100644 --- a/js/video/package.json +++ b/js/video/package.json @@ -21,4 +21,4 @@ "./example": "./Example.svelte", "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/test/test_files/xray_config.json b/test/test_files/xray_config.json index 10976445406d9..374fa4bf86538 100644 --- a/test/test_files/xray_config.json +++ b/test/test_files/xray_config.json @@ -1,493 +1,460 @@ { - "version": "3.45.2", - "mode": "blocks", - "app_id": 9825271647306944906, - "dev_mode": false, - "analytics_enabled": true, - "components": [ - { - "id": 1, - "type": "markdown", - "props": { - "value": "# Detect Disease From Scan\nWith this model you can lorem ipsum\n- ipsum 1\n- ipsum 2", - "rtl": false, - "latex_delimiters": [ - { - "left": "$", - "right": "$", - "display": false - } - ], - "visible": true, - "sanitize_html": true, - "line_breaks": false, - "name": "markdown" - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 2, - "type": "checkboxgroup", - "props": { - "choices": [ - [ - "Covid", - "Covid" - ], - [ - "Malaria", - "Malaria" - ], - [ - "Lung Cancer", - "Lung Cancer" - ] - ], - "value": [], - "type": "value", - "label": "Disease to Scan For", - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "name": "checkboxgroup", - "selectable": false - }, - "serializer": "ListStringSerializable", - "api_info": { - "info": { - "type": "array", - "items": { - "type": "string" - } - }, - "serialized_info": false - }, - "example_inputs": { - "raw": [ - "Covid" - ], - "serialized": [ - "Covid" - ] - } - }, - { - "id": 3, - "type": "tabs", - "props": { - "visible": true, - "name": "tabs", - "selectable": false - } - }, - { - "id": 4, - "type": "tabitem", - "props": { - "label": "X-ray", - "name": "tabitem", - "selectable": false - } - }, - { - "id": 5, - "type": "row", - "props": { - "variant": "default", - "visible": true, - "equal_height": true, - "name": "row" - } - }, - { - "id": 6, - "type": "image", - "props": { - "image_mode": "RGB", - "invert_colors": false, - "source": "upload", - "tool": "editor", - "type": "numpy", - "show_label": true, - "show_download_button": true, - "container": true, - "min_width": 160, - "visible": true, - "streaming": false, - "mirror_webcam": true, - "brush_color": "#000000", - "mask_opacity": 0.7, - "show_share_button": false, - "name": "image", - "selectable": false - }, - "serializer": "ImgSerializable", - "api_info": { - "info": { - "type": "string", - "description": "base64 representation of an image" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": "", - "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" - } - }, - { - "id": 7, - "type": "json", - "props": { - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "name": "json" - }, - "serializer": "JSONSerializable", - "api_info": { - "info": { - "type": {}, - "description": "any valid json" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": { - "a": 1, - "b": 2 - }, - "serialized": null - } - }, - { - "id": 8, - "type": "button", - "props": { - "value": "Run", - "variant": "secondary", - "visible": true, - "interactive": true, - "name": "button" - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 9, - "type": "tabitem", - "props": { - "label": "CT Scan", - "name": "tabitem", - "selectable": false - } - }, - { - "id": 10, - "type": "row", - "props": { - "variant": "default", - "visible": true, - "equal_height": true, - "name": "row" - } - }, - { - "id": 11, - "type": "image", - "props": { - "image_mode": "RGB", - "invert_colors": false, - "source": "upload", - "tool": "editor", - "type": "numpy", - "show_label": true, - "show_download_button": true, - "container": true, - "min_width": 160, - "visible": true, - "streaming": false, - "mirror_webcam": true, - "brush_color": "#000000", - "mask_opacity": 0.7, - "show_share_button": false, - "name": "image", - "selectable": false - }, - "serializer": "ImgSerializable", - "api_info": { - "info": { - "type": "string", - "description": "base64 representation of an image" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": "", - "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" - } - }, - { - "id": 12, - "type": "json", - "props": { - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "name": "json" - }, - "serializer": "JSONSerializable", - "api_info": { - "info": { - "type": {}, - "description": "any valid json" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": { - "a": 1, - "b": 2 - }, - "serialized": null - } - }, - { - "id": 13, - "type": "button", - "props": { - "value": "Run", - "variant": "secondary", - "visible": true, - "interactive": true, - "name": "button" - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 14, - "type": "textbox", - "props": { - "value": "", - "lines": 1, - "max_lines": 20, - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "autofocus": false, - "autoscroll": true, - "type": "text", - "rtl": false, - "show_copy_button": false, - "name": "textbox", - "selectable": false - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 15, - "type": "form", - "props": { - "scale": 0, - "min_width": 0, - "name": "form" - } - }, - { - "id": 16, - "type": "form", - "props": { - "scale": 0, - "min_width": 0, - "name": "form" - } - } - ], - "css": null, - "title": "Gradio", - "space_id": null, - "enable_queue": null, - "show_error": true, - "show_api": true, - "is_colab": false, - "stylesheets": [ - "https://fonts.googleapis.com/css2?family=Source+Sans+Pro:wght@400;600&display=swap", - "https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;600&display=swap" - ], - "theme": "default", - "layout": { - "id": 0, - "children": [ - { - "id": 1 - }, - { - "id": 15, - "children": [ - { - "id": 2 - } - ] - }, - { - "id": 3, - "children": [ - { - "id": 4, - "children": [ - { - "id": 5, - "children": [ - { - "id": 6 - }, - { - "id": 7 - } - ] - }, - { - "id": 8 - } - ] - }, - { - "id": 9, - "children": [ - { - "id": 10, - "children": [ - { - "id": 11 - }, - { - "id": 12 - } - ] - }, - { - "id": 13 - } - ] - } - ] - }, - { - "id": 16, - "children": [ - { - "id": 14 - } - ] - } - ] - }, - "dependencies": [ - { - "targets": [ - [ - 8, - "click" - ] - ], - "inputs": [ - 2, - 6 - ], - "outputs": [ - 7 - ], - "backend_fn": true, - "js": null, - "queue": null, - "api_name": null, - "scroll_to_output": false, - "show_progress": "full", - "every": null, - "batch": false, - "max_batch_size": 4, - "cancels": [], - "types": { - "continuous": false, - "generator": false - }, - "collects_event_data": false, - "trigger_after": null, - "trigger_only_on_success": false - }, - { - "targets": [ - [ - 13, - "click" - ] - ], - "inputs": [ - 2, - 11 - ], - "outputs": [ - 12 - ], - "backend_fn": true, - "js": null, - "queue": null, - "api_name": null, - "scroll_to_output": false, - "show_progress": "full", - "every": null, - "batch": false, - "max_batch_size": 4, - "cancels": [], - "types": { - "continuous": false, - "generator": false - }, - "collects_event_data": false, - "trigger_after": null, - "trigger_only_on_success": false - } - ] -} \ No newline at end of file + "version": "3.45.2", + "mode": "blocks", + "app_id": 9825271647306944906, + "dev_mode": false, + "analytics_enabled": true, + "components": [ + { + "id": 1, + "type": "markdown", + "props": { + "value": "# Detect Disease From Scan\nWith this model you can lorem ipsum\n- ipsum 1\n- ipsum 2", + "rtl": false, + "latex_delimiters": [ + { + "left": "$", + "right": "$", + "display": false + } + ], + "visible": true, + "sanitize_html": true, + "line_breaks": false, + "name": "markdown" + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 2, + "type": "checkboxgroup", + "props": { + "choices": [ + ["Covid", "Covid"], + ["Malaria", "Malaria"], + ["Lung Cancer", "Lung Cancer"] + ], + "value": [], + "type": "value", + "label": "Disease to Scan For", + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "name": "checkboxgroup", + "selectable": false + }, + "serializer": "ListStringSerializable", + "api_info": { + "info": { + "type": "array", + "items": { + "type": "string" + } + }, + "serialized_info": false + }, + "example_inputs": { + "raw": ["Covid"], + "serialized": ["Covid"] + } + }, + { + "id": 3, + "type": "tabs", + "props": { + "visible": true, + "name": "tabs", + "selectable": false + } + }, + { + "id": 4, + "type": "tabitem", + "props": { + "label": "X-ray", + "name": "tabitem", + "selectable": false + } + }, + { + "id": 5, + "type": "row", + "props": { + "variant": "default", + "visible": true, + "equal_height": true, + "name": "row" + } + }, + { + "id": 6, + "type": "image", + "props": { + "image_mode": "RGB", + "invert_colors": false, + "source": "upload", + "tool": "editor", + "type": "numpy", + "show_label": true, + "show_download_button": true, + "container": true, + "min_width": 160, + "visible": true, + "streaming": false, + "mirror_webcam": true, + "brush_color": "#000000", + "mask_opacity": 0.7, + "show_share_button": false, + "name": "image", + "selectable": false + }, + "serializer": "ImgSerializable", + "api_info": { + "info": { + "type": "string", + "description": "base64 representation of an image" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": "", + "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" + } + }, + { + "id": 7, + "type": "json", + "props": { + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "name": "json" + }, + "serializer": "JSONSerializable", + "api_info": { + "info": { + "type": {}, + "description": "any valid json" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": { + "a": 1, + "b": 2 + }, + "serialized": null + } + }, + { + "id": 8, + "type": "button", + "props": { + "value": "Run", + "variant": "secondary", + "visible": true, + "interactive": true, + "name": "button" + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 9, + "type": "tabitem", + "props": { + "label": "CT Scan", + "name": "tabitem", + "selectable": false + } + }, + { + "id": 10, + "type": "row", + "props": { + "variant": "default", + "visible": true, + "equal_height": true, + "name": "row" + } + }, + { + "id": 11, + "type": "image", + "props": { + "image_mode": "RGB", + "invert_colors": false, + "source": "upload", + "tool": "editor", + "type": "numpy", + "show_label": true, + "show_download_button": true, + "container": true, + "min_width": 160, + "visible": true, + "streaming": false, + "mirror_webcam": true, + "brush_color": "#000000", + "mask_opacity": 0.7, + "show_share_button": false, + "name": "image", + "selectable": false + }, + "serializer": "ImgSerializable", + "api_info": { + "info": { + "type": "string", + "description": "base64 representation of an image" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": "", + "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" + } + }, + { + "id": 12, + "type": "json", + "props": { + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "name": "json" + }, + "serializer": "JSONSerializable", + "api_info": { + "info": { + "type": {}, + "description": "any valid json" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": { + "a": 1, + "b": 2 + }, + "serialized": null + } + }, + { + "id": 13, + "type": "button", + "props": { + "value": "Run", + "variant": "secondary", + "visible": true, + "interactive": true, + "name": "button" + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 14, + "type": "textbox", + "props": { + "value": "", + "lines": 1, + "max_lines": 20, + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "autofocus": false, + "autoscroll": true, + "type": "text", + "rtl": false, + "show_copy_button": false, + "name": "textbox", + "selectable": false + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 15, + "type": "form", + "props": { + "scale": 0, + "min_width": 0, + "name": "form" + } + }, + { + "id": 16, + "type": "form", + "props": { + "scale": 0, + "min_width": 0, + "name": "form" + } + } + ], + "css": null, + "title": "Gradio", + "space_id": null, + "enable_queue": null, + "show_error": true, + "show_api": true, + "is_colab": false, + "stylesheets": [ + "https://fonts.googleapis.com/css2?family=Source+Sans+Pro:wght@400;600&display=swap", + "https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;600&display=swap" + ], + "theme": "default", + "layout": { + "id": 0, + "children": [ + { + "id": 1 + }, + { + "id": 15, + "children": [ + { + "id": 2 + } + ] + }, + { + "id": 3, + "children": [ + { + "id": 4, + "children": [ + { + "id": 5, + "children": [ + { + "id": 6 + }, + { + "id": 7 + } + ] + }, + { + "id": 8 + } + ] + }, + { + "id": 9, + "children": [ + { + "id": 10, + "children": [ + { + "id": 11 + }, + { + "id": 12 + } + ] + }, + { + "id": 13 + } + ] + } + ] + }, + { + "id": 16, + "children": [ + { + "id": 14 + } + ] + } + ] + }, + "dependencies": [ + { + "targets": [[8, "click"]], + "inputs": [2, 6], + "outputs": [7], + "backend_fn": true, + "js": null, + "queue": null, + "api_name": null, + "scroll_to_output": false, + "show_progress": "full", + "every": null, + "batch": false, + "max_batch_size": 4, + "cancels": [], + "types": { + "continuous": false, + "generator": false + }, + "collects_event_data": false, + "trigger_after": null, + "trigger_only_on_success": false + }, + { + "targets": [[13, "click"]], + "inputs": [2, 11], + "outputs": [12], + "backend_fn": true, + "js": null, + "queue": null, + "api_name": null, + "scroll_to_output": false, + "show_progress": "full", + "every": null, + "batch": false, + "max_batch_size": 4, + "cancels": [], + "types": { + "continuous": false, + "generator": false + }, + "collects_event_data": false, + "trigger_after": null, + "trigger_only_on_success": false + } + ] +} diff --git a/test/test_files/xray_config_diff_ids.json b/test/test_files/xray_config_diff_ids.json index a60969a9c05c4..5c8ccab152e46 100644 --- a/test/test_files/xray_config_diff_ids.json +++ b/test/test_files/xray_config_diff_ids.json @@ -1,493 +1,460 @@ { - "version": "3.45.2", - "mode": "blocks", - "app_id": 3359633681304339607, - "dev_mode": false, - "analytics_enabled": true, - "components": [ - { - "id": 101, - "type": "markdown", - "props": { - "value": "# Detect Disease From Scan\nWith this model you can lorem ipsum\n- ipsum 1\n- ipsum 2", - "rtl": false, - "latex_delimiters": [ - { - "left": "$", - "right": "$", - "display": false - } - ], - "visible": true, - "sanitize_html": true, - "line_breaks": false, - "name": "markdown" - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 102, - "type": "checkboxgroup", - "props": { - "choices": [ - [ - "Covid", - "Covid" - ], - [ - "Malaria", - "Malaria" - ], - [ - "Lung Cancer", - "Lung Cancer" - ] - ], - "value": [], - "type": "value", - "label": "Disease to Scan For", - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "name": "checkboxgroup", - "selectable": false - }, - "serializer": "ListStringSerializable", - "api_info": { - "info": { - "type": "array", - "items": { - "type": "string" - } - }, - "serialized_info": false - }, - "example_inputs": { - "raw": [ - "Covid" - ], - "serialized": [ - "Covid" - ] - } - }, - { - "id": 103, - "type": "tabs", - "props": { - "visible": true, - "name": "tabs", - "selectable": false - } - }, - { - "id": 104, - "type": "tabitem", - "props": { - "label": "X-ray", - "name": "tabitem", - "selectable": false - } - }, - { - "id": 105, - "type": "row", - "props": { - "variant": "default", - "visible": true, - "equal_height": true, - "name": "row" - } - }, - { - "id": 106, - "type": "image", - "props": { - "image_mode": "RGB", - "invert_colors": false, - "source": "upload", - "tool": "editor", - "type": "numpy", - "show_label": true, - "show_download_button": true, - "container": true, - "min_width": 160, - "visible": true, - "streaming": false, - "mirror_webcam": true, - "brush_color": "#000000", - "mask_opacity": 0.7, - "show_share_button": false, - "name": "image", - "selectable": false - }, - "serializer": "ImgSerializable", - "api_info": { - "info": { - "type": "string", - "description": "base64 representation of an image" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": "", - "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" - } - }, - { - "id": 107, - "type": "json", - "props": { - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "name": "json" - }, - "serializer": "JSONSerializable", - "api_info": { - "info": { - "type": {}, - "description": "any valid json" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": { - "a": 1, - "b": 2 - }, - "serialized": null - } - }, - { - "id": 108, - "type": "button", - "props": { - "value": "Run", - "variant": "secondary", - "visible": true, - "interactive": true, - "name": "button" - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 109, - "type": "tabitem", - "props": { - "label": "CT Scan", - "name": "tabitem", - "selectable": false - } - }, - { - "id": 110, - "type": "row", - "props": { - "variant": "default", - "visible": true, - "equal_height": true, - "name": "row" - } - }, - { - "id": 111, - "type": "image", - "props": { - "image_mode": "RGB", - "invert_colors": false, - "source": "upload", - "tool": "editor", - "type": "numpy", - "show_label": true, - "show_download_button": true, - "container": true, - "min_width": 160, - "visible": true, - "streaming": false, - "mirror_webcam": true, - "brush_color": "#000000", - "mask_opacity": 0.7, - "show_share_button": false, - "name": "image", - "selectable": false - }, - "serializer": "ImgSerializable", - "api_info": { - "info": { - "type": "string", - "description": "base64 representation of an image" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": "", - "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" - } - }, - { - "id": 112, - "type": "json", - "props": { - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "name": "json" - }, - "serializer": "JSONSerializable", - "api_info": { - "info": { - "type": {}, - "description": "any valid json" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": { - "a": 1, - "b": 2 - }, - "serialized": null - } - }, - { - "id": 113, - "type": "button", - "props": { - "value": "Run", - "variant": "secondary", - "visible": true, - "interactive": true, - "name": "button" - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 114, - "type": "textbox", - "props": { - "value": "", - "lines": 1, - "max_lines": 20, - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "autofocus": false, - "autoscroll": true, - "type": "text", - "rtl": false, - "show_copy_button": false, - "name": "textbox", - "selectable": false - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 115, - "type": "form", - "props": { - "scale": 0, - "min_width": 0, - "name": "form" - } - }, - { - "id": 116, - "type": "form", - "props": { - "scale": 0, - "min_width": 0, - "name": "form" - } - } - ], - "css": null, - "title": "Gradio", - "space_id": null, - "enable_queue": null, - "show_error": true, - "show_api": true, - "is_colab": false, - "stylesheets": [ - "https://fonts.googleapis.com/css2?family=Source+Sans+Pro:wght@400;600&display=swap", - "https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;600&display=swap" - ], - "theme": "default", - "layout": { - "id": 100, - "children": [ - { - "id": 101 - }, - { - "id": 115, - "children": [ - { - "id": 102 - } - ] - }, - { - "id": 103, - "children": [ - { - "id": 104, - "children": [ - { - "id": 105, - "children": [ - { - "id": 106 - }, - { - "id": 107 - } - ] - }, - { - "id": 108 - } - ] - }, - { - "id": 109, - "children": [ - { - "id": 110, - "children": [ - { - "id": 111 - }, - { - "id": 112 - } - ] - }, - { - "id": 113 - } - ] - } - ] - }, - { - "id": 116, - "children": [ - { - "id": 114 - } - ] - } - ] - }, - "dependencies": [ - { - "targets": [ - [ - 108, - "click" - ] - ], - "inputs": [ - 102, - 106 - ], - "outputs": [ - 107 - ], - "backend_fn": true, - "js": null, - "queue": null, - "api_name": null, - "scroll_to_output": false, - "show_progress": "full", - "every": null, - "batch": false, - "max_batch_size": 4, - "cancels": [], - "types": { - "continuous": false, - "generator": false - }, - "collects_event_data": false, - "trigger_after": null, - "trigger_only_on_success": false - }, - { - "targets": [ - [ - 113, - "click" - ] - ], - "inputs": [ - 102, - 111 - ], - "outputs": [ - 112 - ], - "backend_fn": true, - "js": null, - "queue": null, - "api_name": null, - "scroll_to_output": false, - "show_progress": "full", - "every": null, - "batch": false, - "max_batch_size": 4, - "cancels": [], - "types": { - "continuous": false, - "generator": false - }, - "collects_event_data": false, - "trigger_after": null, - "trigger_only_on_success": false - } - ] -} \ No newline at end of file + "version": "3.45.2", + "mode": "blocks", + "app_id": 3359633681304339607, + "dev_mode": false, + "analytics_enabled": true, + "components": [ + { + "id": 101, + "type": "markdown", + "props": { + "value": "# Detect Disease From Scan\nWith this model you can lorem ipsum\n- ipsum 1\n- ipsum 2", + "rtl": false, + "latex_delimiters": [ + { + "left": "$", + "right": "$", + "display": false + } + ], + "visible": true, + "sanitize_html": true, + "line_breaks": false, + "name": "markdown" + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 102, + "type": "checkboxgroup", + "props": { + "choices": [ + ["Covid", "Covid"], + ["Malaria", "Malaria"], + ["Lung Cancer", "Lung Cancer"] + ], + "value": [], + "type": "value", + "label": "Disease to Scan For", + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "name": "checkboxgroup", + "selectable": false + }, + "serializer": "ListStringSerializable", + "api_info": { + "info": { + "type": "array", + "items": { + "type": "string" + } + }, + "serialized_info": false + }, + "example_inputs": { + "raw": ["Covid"], + "serialized": ["Covid"] + } + }, + { + "id": 103, + "type": "tabs", + "props": { + "visible": true, + "name": "tabs", + "selectable": false + } + }, + { + "id": 104, + "type": "tabitem", + "props": { + "label": "X-ray", + "name": "tabitem", + "selectable": false + } + }, + { + "id": 105, + "type": "row", + "props": { + "variant": "default", + "visible": true, + "equal_height": true, + "name": "row" + } + }, + { + "id": 106, + "type": "image", + "props": { + "image_mode": "RGB", + "invert_colors": false, + "source": "upload", + "tool": "editor", + "type": "numpy", + "show_label": true, + "show_download_button": true, + "container": true, + "min_width": 160, + "visible": true, + "streaming": false, + "mirror_webcam": true, + "brush_color": "#000000", + "mask_opacity": 0.7, + "show_share_button": false, + "name": "image", + "selectable": false + }, + "serializer": "ImgSerializable", + "api_info": { + "info": { + "type": "string", + "description": "base64 representation of an image" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": "", + "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" + } + }, + { + "id": 107, + "type": "json", + "props": { + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "name": "json" + }, + "serializer": "JSONSerializable", + "api_info": { + "info": { + "type": {}, + "description": "any valid json" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": { + "a": 1, + "b": 2 + }, + "serialized": null + } + }, + { + "id": 108, + "type": "button", + "props": { + "value": "Run", + "variant": "secondary", + "visible": true, + "interactive": true, + "name": "button" + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 109, + "type": "tabitem", + "props": { + "label": "CT Scan", + "name": "tabitem", + "selectable": false + } + }, + { + "id": 110, + "type": "row", + "props": { + "variant": "default", + "visible": true, + "equal_height": true, + "name": "row" + } + }, + { + "id": 111, + "type": "image", + "props": { + "image_mode": "RGB", + "invert_colors": false, + "source": "upload", + "tool": "editor", + "type": "numpy", + "show_label": true, + "show_download_button": true, + "container": true, + "min_width": 160, + "visible": true, + "streaming": false, + "mirror_webcam": true, + "brush_color": "#000000", + "mask_opacity": 0.7, + "show_share_button": false, + "name": "image", + "selectable": false + }, + "serializer": "ImgSerializable", + "api_info": { + "info": { + "type": "string", + "description": "base64 representation of an image" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": "", + "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" + } + }, + { + "id": 112, + "type": "json", + "props": { + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "name": "json" + }, + "serializer": "JSONSerializable", + "api_info": { + "info": { + "type": {}, + "description": "any valid json" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": { + "a": 1, + "b": 2 + }, + "serialized": null + } + }, + { + "id": 113, + "type": "button", + "props": { + "value": "Run", + "variant": "secondary", + "visible": true, + "interactive": true, + "name": "button" + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 114, + "type": "textbox", + "props": { + "value": "", + "lines": 1, + "max_lines": 20, + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "autofocus": false, + "autoscroll": true, + "type": "text", + "rtl": false, + "show_copy_button": false, + "name": "textbox", + "selectable": false + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 115, + "type": "form", + "props": { + "scale": 0, + "min_width": 0, + "name": "form" + } + }, + { + "id": 116, + "type": "form", + "props": { + "scale": 0, + "min_width": 0, + "name": "form" + } + } + ], + "css": null, + "title": "Gradio", + "space_id": null, + "enable_queue": null, + "show_error": true, + "show_api": true, + "is_colab": false, + "stylesheets": [ + "https://fonts.googleapis.com/css2?family=Source+Sans+Pro:wght@400;600&display=swap", + "https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;600&display=swap" + ], + "theme": "default", + "layout": { + "id": 100, + "children": [ + { + "id": 101 + }, + { + "id": 115, + "children": [ + { + "id": 102 + } + ] + }, + { + "id": 103, + "children": [ + { + "id": 104, + "children": [ + { + "id": 105, + "children": [ + { + "id": 106 + }, + { + "id": 107 + } + ] + }, + { + "id": 108 + } + ] + }, + { + "id": 109, + "children": [ + { + "id": 110, + "children": [ + { + "id": 111 + }, + { + "id": 112 + } + ] + }, + { + "id": 113 + } + ] + } + ] + }, + { + "id": 116, + "children": [ + { + "id": 114 + } + ] + } + ] + }, + "dependencies": [ + { + "targets": [[108, "click"]], + "inputs": [102, 106], + "outputs": [107], + "backend_fn": true, + "js": null, + "queue": null, + "api_name": null, + "scroll_to_output": false, + "show_progress": "full", + "every": null, + "batch": false, + "max_batch_size": 4, + "cancels": [], + "types": { + "continuous": false, + "generator": false + }, + "collects_event_data": false, + "trigger_after": null, + "trigger_only_on_success": false + }, + { + "targets": [[113, "click"]], + "inputs": [102, 111], + "outputs": [112], + "backend_fn": true, + "js": null, + "queue": null, + "api_name": null, + "scroll_to_output": false, + "show_progress": "full", + "every": null, + "batch": false, + "max_batch_size": 4, + "cancels": [], + "types": { + "continuous": false, + "generator": false + }, + "collects_event_data": false, + "trigger_after": null, + "trigger_only_on_success": false + } + ] +} diff --git a/test/test_files/xray_config_wrong.json b/test/test_files/xray_config_wrong.json index ef658fa20be50..70c6c3c390cd0 100644 --- a/test/test_files/xray_config_wrong.json +++ b/test/test_files/xray_config_wrong.json @@ -1,570 +1,530 @@ { - "version": "3.45.2", - "mode": "blocks", - "app_id": 14154062863405525567, - "dev_mode": false, - "analytics_enabled": true, - "components": [ - { - "id": 1, - "type": "markdown", - "props": { - "value": "# Detect Disease From Scan\nWith this model you can lorem ipsum\n- ipsum 1\n- ipsum 2", - "rtl": false, - "latex_delimiters": [ - { - "left": "$", - "right": "$", - "display": false - } - ], - "visible": true, - "sanitize_html": true, - "line_breaks": false, - "name": "markdown" - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 2, - "type": "checkboxgroup", - "props": { - "choices": [ - [ - "Covid", - "Covid" - ], - [ - "Malaria", - "Malaria" - ], - [ - "Lung Cancer", - "Lung Cancer" - ] - ], - "value": [], - "type": "value", - "label": "Disease to Scan For", - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "name": "checkboxgroup", - "selectable": false - }, - "serializer": "ListStringSerializable", - "api_info": { - "info": { - "type": "array", - "items": { - "type": "string" - } - }, - "serialized_info": false - }, - "example_inputs": { - "raw": [ - "Covid" - ], - "serialized": [ - "Covid" - ] - } - }, - { - "id": 3, - "type": "tabs", - "props": { - "visible": true, - "name": "tabs", - "selectable": false - } - }, - { - "id": 4, - "type": "tabitem", - "props": { - "label": "X-ray", - "name": "tabitem", - "selectable": false - } - }, - { - "id": 5, - "type": "row", - "props": { - "variant": "default", - "visible": true, - "equal_height": true, - "name": "row" - } - }, - { - "id": 6, - "type": "image", - "props": { - "image_mode": "RGB", - "invert_colors": false, - "source": "upload", - "tool": "editor", - "type": "numpy", - "show_label": true, - "show_download_button": true, - "container": true, - "min_width": 160, - "visible": true, - "streaming": false, - "mirror_webcam": true, - "brush_color": "#000000", - "mask_opacity": 0.7, - "show_share_button": false, - "name": "image", - "selectable": false - }, - "serializer": "ImgSerializable", - "api_info": { - "info": { - "type": "string", - "description": "base64 representation of an image" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": "", - "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" - } - }, - { - "id": 7, - "type": "json", - "props": { - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "name": "json" - }, - "serializer": "JSONSerializable", - "api_info": { - "info": { - "type": {}, - "description": "any valid json" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": { - "a": 1, - "b": 2 - }, - "serialized": null - } - }, - { - "id": 8, - "type": "button", - "props": { - "value": "Run", - "variant": "secondary", - "visible": true, - "interactive": true, - "name": "button" - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 9, - "type": "tabitem", - "props": { - "label": "CT Scan", - "name": "tabitem", - "selectable": false - } - }, - { - "id": 10, - "type": "row", - "props": { - "variant": "default", - "visible": true, - "equal_height": true, - "name": "row" - } - }, - { - "id": 11, - "type": "image", - "props": { - "image_mode": "RGB", - "invert_colors": false, - "source": "upload", - "tool": "editor", - "type": "numpy", - "show_label": true, - "show_download_button": true, - "container": true, - "min_width": 160, - "visible": true, - "streaming": false, - "mirror_webcam": true, - "brush_color": "#000000", - "mask_opacity": 0.7, - "show_share_button": false, - "name": "image", - "selectable": false - }, - "serializer": "ImgSerializable", - "api_info": { - "info": { - "type": "string", - "description": "base64 representation of an image" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": "", - "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" - } - }, - { - "id": 12, - "type": "json", - "props": { - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "name": "json" - }, - "serializer": "JSONSerializable", - "api_info": { - "info": { - "type": {}, - "description": "any valid json" - }, - "serialized_info": true - }, - "example_inputs": { - "raw": { - "a": 1, - "b": 2 - }, - "serialized": null - } - }, - { - "id": 13, - "type": "button", - "props": { - "value": "Run", - "variant": "secondary", - "visible": true, - "interactive": true, - "name": "button" - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 14, - "type": "textbox", - "props": { - "value": "", - "lines": 1, - "max_lines": 20, - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "autofocus": false, - "autoscroll": true, - "type": "text", - "rtl": false, - "show_copy_button": false, - "name": "textbox", - "selectable": false - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 15, - "type": "form", - "props": { - "scale": 0, - "min_width": 0, - "name": "form" - } - }, - { - "id": 16, - "type": "form", - "props": { - "scale": 0, - "min_width": 0, - "name": "form" - } - }, - { - "id": 118, - "type": "textbox", - "props": { - "value": "", - "lines": 1, - "max_lines": 20, - "show_label": true, - "container": true, - "min_width": 160, - "visible": true, - "autofocus": false, - "autoscroll": true, - "type": "text", - "rtl": false, - "show_copy_button": false, - "name": "textbox", - "selectable": false - }, - "serializer": "StringSerializable", - "api_info": { - "info": { - "type": "string" - }, - "serialized_info": false - }, - "example_inputs": { - "raw": "Howdy!", - "serialized": "Howdy!" - } - }, - { - "id": 119, - "type": "form", - "props": { - "scale": 0, - "min_width": 0, - "name": "form" - } - } - ], - "css": null, - "title": "Gradio", - "space_id": null, - "enable_queue": null, - "show_error": true, - "show_api": true, - "is_colab": false, - "stylesheets": [ - "https://fonts.googleapis.com/css2?family=Source+Sans+Pro:wght@400;600&display=swap", - "https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;600&display=swap" - ], - "theme": "default", - "layout": { - "id": 117, - "children": [ - { - "id": 1 - }, - { - "id": 15, - "children": [ - { - "id": 2 - } - ] - }, - { - "id": 3, - "children": [ - { - "id": 4, - "children": [ - { - "id": 5, - "children": [ - { - "id": 6 - }, - { - "id": 7 - } - ] - }, - { - "id": 8 - } - ] - }, - { - "id": 9, - "children": [ - { - "id": 10, - "children": [ - { - "id": 11 - }, - { - "id": 12 - } - ] - }, - { - "id": 13 - } - ] - } - ] - }, - { - "id": 16, - "children": [ - { - "id": 14 - } - ] - }, - { - "id": 119, - "children": [ - { - "id": 118 - } - ] - } - ] - }, - "dependencies": [ - { - "targets": [ - [ - 8, - "click" - ] - ], - "inputs": [ - 2, - 6 - ], - "outputs": [ - 7 - ], - "backend_fn": true, - "js": null, - "queue": null, - "api_name": null, - "scroll_to_output": false, - "show_progress": "full", - "every": null, - "batch": false, - "max_batch_size": 4, - "cancels": [], - "types": { - "continuous": false, - "generator": false - }, - "collects_event_data": false, - "trigger_after": null, - "trigger_only_on_success": false - }, - { - "targets": [ - [ - 13, - "click" - ] - ], - "inputs": [ - 2, - 11 - ], - "outputs": [ - 12 - ], - "backend_fn": true, - "js": null, - "queue": null, - "api_name": null, - "scroll_to_output": false, - "show_progress": "full", - "every": null, - "batch": false, - "max_batch_size": 4, - "cancels": [], - "types": { - "continuous": false, - "generator": false - }, - "collects_event_data": false, - "trigger_after": null, - "trigger_only_on_success": false - }, - { - "targets": [ - [ - null, - "load" - ] - ], - "inputs": [], - "outputs": [ - 118 - ], - "backend_fn": true, - "js": null, - "queue": null, - "api_name": null, - "scroll_to_output": false, - "show_progress": "full", - "every": null, - "batch": false, - "max_batch_size": 4, - "cancels": [], - "types": { - "continuous": false, - "generator": false - }, - "collects_event_data": false, - "trigger_after": null, - "trigger_only_on_success": false - } - ] -} \ No newline at end of file + "version": "3.45.2", + "mode": "blocks", + "app_id": 14154062863405525567, + "dev_mode": false, + "analytics_enabled": true, + "components": [ + { + "id": 1, + "type": "markdown", + "props": { + "value": "# Detect Disease From Scan\nWith this model you can lorem ipsum\n- ipsum 1\n- ipsum 2", + "rtl": false, + "latex_delimiters": [ + { + "left": "$", + "right": "$", + "display": false + } + ], + "visible": true, + "sanitize_html": true, + "line_breaks": false, + "name": "markdown" + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 2, + "type": "checkboxgroup", + "props": { + "choices": [ + ["Covid", "Covid"], + ["Malaria", "Malaria"], + ["Lung Cancer", "Lung Cancer"] + ], + "value": [], + "type": "value", + "label": "Disease to Scan For", + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "name": "checkboxgroup", + "selectable": false + }, + "serializer": "ListStringSerializable", + "api_info": { + "info": { + "type": "array", + "items": { + "type": "string" + } + }, + "serialized_info": false + }, + "example_inputs": { + "raw": ["Covid"], + "serialized": ["Covid"] + } + }, + { + "id": 3, + "type": "tabs", + "props": { + "visible": true, + "name": "tabs", + "selectable": false + } + }, + { + "id": 4, + "type": "tabitem", + "props": { + "label": "X-ray", + "name": "tabitem", + "selectable": false + } + }, + { + "id": 5, + "type": "row", + "props": { + "variant": "default", + "visible": true, + "equal_height": true, + "name": "row" + } + }, + { + "id": 6, + "type": "image", + "props": { + "image_mode": "RGB", + "invert_colors": false, + "source": "upload", + "tool": "editor", + "type": "numpy", + "show_label": true, + "show_download_button": true, + "container": true, + "min_width": 160, + "visible": true, + "streaming": false, + "mirror_webcam": true, + "brush_color": "#000000", + "mask_opacity": 0.7, + "show_share_button": false, + "name": "image", + "selectable": false + }, + "serializer": "ImgSerializable", + "api_info": { + "info": { + "type": "string", + "description": "base64 representation of an image" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": "", + "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" + } + }, + { + "id": 7, + "type": "json", + "props": { + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "name": "json" + }, + "serializer": "JSONSerializable", + "api_info": { + "info": { + "type": {}, + "description": "any valid json" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": { + "a": 1, + "b": 2 + }, + "serialized": null + } + }, + { + "id": 8, + "type": "button", + "props": { + "value": "Run", + "variant": "secondary", + "visible": true, + "interactive": true, + "name": "button" + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 9, + "type": "tabitem", + "props": { + "label": "CT Scan", + "name": "tabitem", + "selectable": false + } + }, + { + "id": 10, + "type": "row", + "props": { + "variant": "default", + "visible": true, + "equal_height": true, + "name": "row" + } + }, + { + "id": 11, + "type": "image", + "props": { + "image_mode": "RGB", + "invert_colors": false, + "source": "upload", + "tool": "editor", + "type": "numpy", + "show_label": true, + "show_download_button": true, + "container": true, + "min_width": 160, + "visible": true, + "streaming": false, + "mirror_webcam": true, + "brush_color": "#000000", + "mask_opacity": 0.7, + "show_share_button": false, + "name": "image", + "selectable": false + }, + "serializer": "ImgSerializable", + "api_info": { + "info": { + "type": "string", + "description": "base64 representation of an image" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": "", + "serialized": "https://raw.githubusercontent.com/gradio-app/gradio/main/test/test_files/bus.png" + } + }, + { + "id": 12, + "type": "json", + "props": { + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "name": "json" + }, + "serializer": "JSONSerializable", + "api_info": { + "info": { + "type": {}, + "description": "any valid json" + }, + "serialized_info": true + }, + "example_inputs": { + "raw": { + "a": 1, + "b": 2 + }, + "serialized": null + } + }, + { + "id": 13, + "type": "button", + "props": { + "value": "Run", + "variant": "secondary", + "visible": true, + "interactive": true, + "name": "button" + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 14, + "type": "textbox", + "props": { + "value": "", + "lines": 1, + "max_lines": 20, + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "autofocus": false, + "autoscroll": true, + "type": "text", + "rtl": false, + "show_copy_button": false, + "name": "textbox", + "selectable": false + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 15, + "type": "form", + "props": { + "scale": 0, + "min_width": 0, + "name": "form" + } + }, + { + "id": 16, + "type": "form", + "props": { + "scale": 0, + "min_width": 0, + "name": "form" + } + }, + { + "id": 118, + "type": "textbox", + "props": { + "value": "", + "lines": 1, + "max_lines": 20, + "show_label": true, + "container": true, + "min_width": 160, + "visible": true, + "autofocus": false, + "autoscroll": true, + "type": "text", + "rtl": false, + "show_copy_button": false, + "name": "textbox", + "selectable": false + }, + "serializer": "StringSerializable", + "api_info": { + "info": { + "type": "string" + }, + "serialized_info": false + }, + "example_inputs": { + "raw": "Howdy!", + "serialized": "Howdy!" + } + }, + { + "id": 119, + "type": "form", + "props": { + "scale": 0, + "min_width": 0, + "name": "form" + } + } + ], + "css": null, + "title": "Gradio", + "space_id": null, + "enable_queue": null, + "show_error": true, + "show_api": true, + "is_colab": false, + "stylesheets": [ + "https://fonts.googleapis.com/css2?family=Source+Sans+Pro:wght@400;600&display=swap", + "https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;600&display=swap" + ], + "theme": "default", + "layout": { + "id": 117, + "children": [ + { + "id": 1 + }, + { + "id": 15, + "children": [ + { + "id": 2 + } + ] + }, + { + "id": 3, + "children": [ + { + "id": 4, + "children": [ + { + "id": 5, + "children": [ + { + "id": 6 + }, + { + "id": 7 + } + ] + }, + { + "id": 8 + } + ] + }, + { + "id": 9, + "children": [ + { + "id": 10, + "children": [ + { + "id": 11 + }, + { + "id": 12 + } + ] + }, + { + "id": 13 + } + ] + } + ] + }, + { + "id": 16, + "children": [ + { + "id": 14 + } + ] + }, + { + "id": 119, + "children": [ + { + "id": 118 + } + ] + } + ] + }, + "dependencies": [ + { + "targets": [[8, "click"]], + "inputs": [2, 6], + "outputs": [7], + "backend_fn": true, + "js": null, + "queue": null, + "api_name": null, + "scroll_to_output": false, + "show_progress": "full", + "every": null, + "batch": false, + "max_batch_size": 4, + "cancels": [], + "types": { + "continuous": false, + "generator": false + }, + "collects_event_data": false, + "trigger_after": null, + "trigger_only_on_success": false + }, + { + "targets": [[13, "click"]], + "inputs": [2, 11], + "outputs": [12], + "backend_fn": true, + "js": null, + "queue": null, + "api_name": null, + "scroll_to_output": false, + "show_progress": "full", + "every": null, + "batch": false, + "max_batch_size": 4, + "cancels": [], + "types": { + "continuous": false, + "generator": false + }, + "collects_event_data": false, + "trigger_after": null, + "trigger_only_on_success": false + }, + { + "targets": [[null, "load"]], + "inputs": [], + "outputs": [118], + "backend_fn": true, + "js": null, + "queue": null, + "api_name": null, + "scroll_to_output": false, + "show_progress": "full", + "every": null, + "batch": false, + "max_batch_size": 4, + "cancels": [], + "types": { + "continuous": false, + "generator": false + }, + "collects_event_data": false, + "trigger_after": null, + "trigger_only_on_success": false + } + ] +}