my_gradio / js /app /CHANGELOG.md
xray918's picture
Upload folder using huggingface_hub
0ad74ed verified

A newer version of the Gradio SDK is available: 5.12.0

Upgrade

@self/app

1.41.2

Fixes

Dependency updates

1.41.1

Features

  • #9617 c163182 - Fix dark mode detection and container height. Thanks @pngwn!
  • #9616 ca7cd79 - fix devmode. Thanks @pngwn!

Fixes

  • #9630 2eaa066 - Fix duplicate attribute error. Thanks @pngwn!

Dependency updates

1.41.0

Features

Dependencies

1.41.0-beta.7

Features

  • #9590 e853c41 - SSR e2e + fixes. Thanks @pngwn!
  • #9482 bd6c5f2 - Fix custom component CLI on main/5.0. Thanks @freddyaboulton!
  • #9576 430a26a - Fix reload mode. Thanks @freddyaboulton!
  • #9592 24fe222 - Fix favicon in ssr mode. Thanks @freddyaboulton!

Dependency updates

1.41.0-beta.6

Dependency updates

1.41.0-beta.5

Features

  • #9428 a17c7b6 - Ensure media queries work for SSR mode. Thanks @pngwn!

Dependency updates

1.41.0-beta.4

Dependency updates

1.41.0-beta.3

Features

Dependency updates

1.41.0-beta.2

Features

Dependency updates

1.41.0-beta.1

Features

Dependency updates

1.40.1-beta.0

Fixes

  • #9163 2b6cbf2 - fix exports and generate types. Thanks @pngwn!

1.40.0

Features

  • #8935 f6b2b97 - Initialize the client with the fake host for Lite server. Thanks @whitphx!
  • #9102 efdc323 - Initial SSR refactor. Thanks @pngwn!
  • #9110 e1e7ad3 - fix version + pkg name. Thanks @pngwn!

1.39.2

Dependency updates

1.39.1

Dependency updates

1.39.0

Features

  • #8832 e75f2ca - Fix build for pre-release. Thanks @pngwn!
  • #8846 76c1759 - add space header. Thanks @pngwn!
  • #8804 1d09925 - Fix Lite's . Thanks @whitphx!
  • #8807 a238af4 - Refactor plots to drop altair and use vega.js directly. Thanks @aliabid94!

Fixes

  • #8818 2de9a97 - Refactoring component making the code simpler and fixing a Playground mode bug. Thanks @whitphx!

Dependency updates

1.38.1

Dependency updates

1.38.0

Features

Fixes

  • #8505 2943d6d - Add Timer component. Thanks @aliabid94!
  • #8720 936c713 - Documents auth in the guides, in the view API page, and also types the Blocks.config object. Thanks @abidlabs!

Dependency updates

1.37.1

Dependency updates

1.37.0

Features

  • #8131 bb504b4 - Gradio components in gr.Chatbot(). Thanks @dawoodkhan82!
  • #8489 c2a0d05 - Control Display of Error, Info, Warning. Thanks @freddyaboulton!
  • #8571 a77877f - First time loading performance optimization. Thanks @baojianting!

Fixes

  • #8599 ca125b7 - Fix reload mode for jupyter notebook and stateful demos. Thanks @freddyaboulton!
  • #8521 900cf25 - Ensure frontend functions work when they don't return a value. Thanks @pngwn!

Dependency updates

1.36.2

Features

  • #8499 c5f6e77 - Cache break themes on change. Thanks @aliabid94!

Dependency updates

1.36.1

Dependency updates

1.36.0

Features

  • #8370 48eeea4 - Refactor Cancelling Logic To Use /cancel. Thanks @freddyaboulton!
  • #8460 8628899 - Support Bash in Api Recorder. Thanks @aliabd!
  • #8444 2cd02ff - Remove deprecated parameters from Python Client. Thanks @abidlabs!
  • #8473 8ca93d4 - Improve design of api recorder. Thanks @aliabd!
  • #8445 5c8915b - Add cURL to view API Page and add a dedicated Guide. Thanks @abidlabs!

Fixes

  • #8451 9d2d605 - Change client submit API to be an AsyncIterable and support more platforms. Thanks @pngwn!
  • #8439 63d36fb - Handle gradio apps using state in the JS Client. Thanks @hannahblair!

Dependency updates

1.35.9

Dependency updates

1.35.8

Fixes

1.35.7

Dependency updates

1.35.6

Features

  • #8243 55f664f - Add event listener support to render blocks. Thanks @aliabid94!
  • #8398 945ac83 - Improve rendering. Thanks @aliabid94!

Dependency updates

1.35.5

Dependency updates

1.35.4

Fixes

1.35.3

Features

  • #8279 4350215 - Link to troubleshooting guide in the custom component loading status. Thanks @freddyaboulton!

Dependency updates

1.35.2

Dependency updates

1.35.1

Features

  • #8263 de52f0e - Reduce the analytics that are collected in Gradio. Thanks @abidlabs!

Fixes

  • #8272 fbf4edd - ensure client works for private spaces. Thanks @pngwn!

Dependency updates

1.35.0

Features

  • #8219 32d915a - Apply clean_indent() to the file contents specified with tags. Thanks @whitphx!
  • #8110 5436031 - Render decorator 2. Thanks @aliabid94!
  • #8197 e09b4e8 - Add support for passing keyword args to data in JS client. Thanks @hannahblair!

Fixes

Dependency updates

1.34.0

Features

  • #8121 f5b710c - chore(deps): update dependency eslint to v9. Thanks @renovate!
  • #8174 a81e369 - Remove hatch installation in js/app/package.json which is no longer needed. Thanks @whitphx!
  • #8209 b9afe93 - Rename eventSource_Factory and fetch_implementation. Thanks @hannahblair!
  • #8109 bed2f82 - Implement JS Client tests. Thanks @hannahblair!
  • #8106 d0a759f - Pass Error status in /dev/reload stream. Thanks @freddyaboulton!
  • #7855 611c927 - Lite wheel optimization. Thanks @whitphx!

Fixes

  • #8179 6a218b4 - rework upload to be a class method + pass client into each component. Thanks @pngwn!
  • #8181 cf52ca6 - Ensure connectivity to private HF spaces with SSE protocol. Thanks @hannahblair!

Dependency updates

1.33.0

Highlights

Setting File Upload Limits (#7909 2afca65)

We have added a max_file_size size parameter to launch() that limits to size of files uploaded to the server. This limit applies to each individual file. This parameter can be specified as a string or an integer (corresponding to the size in bytes).

The following code snippet sets a max file size of 5 megabytes.

import gradio as gr

demo = gr.Interface(lambda x: x, "image", "image")

demo.launch(max_file_size="5mb")
# or
demo.launch(max_file_size=5 * gr.FileSize.MB)

max_file_size_upload

Error states can now be cleared

When a component encounters an error, the error state shown in the UI can now be cleared by clicking on the x icon in the top right of the component. This applies to all types of errors, whether it's raised in the UI or the server.

error_modal_calculator

Thanks @freddyaboulton!

Features

  • #8092 659d3c5 - chore(deps): update dependency iframe-resizer to v4.3.11. Thanks @renovate!
  • #8067 0fb058e - Fix the Lite custom element parser so it doesn't add the .code option when the entrypoint file is already specified. Thanks @whitphx!
  • #8051 d665f40 - Fix custom JS function caller to concat the outputs of a dep to the inputs as the arguments. Thanks @whitphx!
  • #8056 2e469a5 - Using keys to preserve values between reloads. Thanks @aliabid94!
  • #7646 450b8cc - Refactor JS Client. Thanks @hannahblair!
  • #8115 595ebf7 - Cache an error from app.submit() and show it on frontend. Thanks @whitphx!
  • #8084 1c99570 - Adjust View Api container z-index. Thanks @hannahblair!

Dependency updates

1.32.0

Features

  • #8062 cecd6e4 - Update dependency iframe-resizer to v4.3.10. Thanks @renovate!
  • #7887 5f0248e - When authenticating with HF OAuth, stay in same tab. Thanks @Wauplin!
  • #7975 c9ddd84 - Update the Lite custom element parser. Thanks @whitphx!

Fixes

  • #8028 6fafce0 - ensure maps are correctly shallow cloned when updating state. Thanks @pngwn!
  • #7981 c1df2f8 - Fix example loading for custom components. Thanks @freddyaboulton!

Dependency updates

1.31.0

Features

  • #7811 b43055b - Lite playground design changes. Thanks @aliabd!
  • #7850 2bae1cf - Adds an "API Recorder" to the view API page, some internal methods have been made async. Thanks @abidlabs!

Fixes

  • #7963 1eb4c20 - ensure kwargs are always in sync across the whole application. Thanks @pngwn!
  • #7916 7c9a964 - Fix programmatic tab selection. Thanks @aliabid94!

Dependency updates

1.30.1

Fixes

  • #7865 7bbc3b6 - JS functions break entire app if there's no input, fixed. Thanks @aliabid94!

Dependency updates

1.30.0

Features

  • #7852 72661e3 - Revert the minify setting in vite.config.js which was mistakingly introduced in #6261. Thanks @whitphx!

Dependency updates

1.29.0

Features

  • #7684 755157f - Do not reload code inside gr.NO_RELOAD context. Thanks @freddyaboulton!
  • #7732 2efb05e - Adds support for kwargs and default arguments in the python client, and improves how parameter information is displayed in the "view API" page. Thanks @abidlabs!

Dependency updates

1.28.0

Features

  • #7420 15da39f - Multimodal Textbox (Chat Input Component). Thanks @dawoodkhan82!
  • #7660 f739bef - Add Playground to Lite Custom Element. Thanks @aliabd!
  • #7710 0a3870d - Call handle_darkmode() even if window.__gradio_mode__ === "website" but enforce the light theme. Thanks @whitphx!

Fixes

  • #7564 5d1e8da - batch UI updates on a per frame basis. Thanks @pngwn!
  • #7691 84f81fe - Fix race condition between state updates and loading_status updates. Thanks @aliabid94!
  • #7709 f67759d - Fix wasm_proxied_mount_css to not reuse an existing style element. Thanks @whitphx!
  • #7703 598ad7b - fix dev mode. Thanks @pngwn!

Dependency updates

1.27.0

Features

  • #7577 7c66a29 - Fix the Lite custom element to initialize the app in the connected callback and dispose the app in the disconnected callback. Thanks @whitphx!

Fixes

  • #7643 9482c7a - fix: redundant meta tags that are unwanted. Thanks @qkdxorjs1002!
  • #7628 ba8cc48 - feature detect CSSStylesheet. Thanks @pngwn!
  • #7575 d0688b3 - Files should now be supplied as file(...) in the Client, and some fixes to gr.load() as well. Thanks @abidlabs!

Dependency updates

1.26.1

Patch Changes

1.26.0

Features

Fixes

1.25.2

Fixes

1.25.1

Patch Changes

1.25.0

Fixes

1.24.0

Features

Fixes

1.23.0

Features

Fixes

1.22.0

Features

Fixes

1.21.0

Highlights

Custom component documentation generator (#7030 3a944ed)

If your custom component has type hints and docstrings for both parameters and return values, you can now automatically generate a documentation page and README.md with no additional effort. Simply run the following command:

gradio cc docs

This will generate a Gradio app that you can upload to spaces providing rich documentation for potential users. The documentation page includes:

  • Installation instructions.
  • A live embedded demo and working code snippet, pulled from your demo app.
  • An API reference for initialising the component, with types, default values and descriptions.
  • An explanation of how the component affects the user's predict function inputs and outputs.
  • Any additional interfaces or classes that are necessary to understand the API reference.
  • Optional links to GitHub, PyPi, and Hugging Face Spaces.

A README will also be generated detailing the same information but in a format that is optimised for viewing on GitHub or PyPi!

Thanks @pngwn!

1.20.0

Features

Fixes

1.19.0

Features

1.18.0

Features

Fixes

  • #6863 d406855 - Fix JS Client when app is running behind a proxy. Thanks @freddyaboulton!
  • #6846 48d6534 - Add show_api parameter to events, and fix gr.load(). Also makes some minor improvements to the "view API" page when running on Spaces. Thanks @abidlabs!

1.17.0

Features

Fixes

1.16.2

Patch Changes

1.16.1

Patch Changes

1.16.0

Features

Fixes

1.15.0

Features

1.14.0

Features

Fixes

1.13.1

Fixes

1.13.0

Highlights

New ImageEditor component (#6169 9caddc17b)

A brand new component, completely separate from Image that provides simple editing capabilities.

  • Set background images from file uploads, webcam, or just paste!
  • Crop images with an improved cropping UI. App authors can event set specific crop size, or crop ratios (1:1, etc)
  • Paint on top of any image (or no image) and erase any mistakes!
  • The ImageEditor supports layers, confining draw and erase actions to that layer.
  • More flexible access to data. The image component returns a composite image representing the final state of the canvas as well as providing the background and all layers as individual images.
  • Fully customisable. All features can be enabled and disabled. Even the brush color swatches can be customised.


def fn(im):
    im["composite"] # the full canvas
    im["background"] # the background image
    im["layers"] # a list of individual layers


im = gr.ImageEditor(
    # decide which sources you'd like to accept
    sources=["upload", "webcam", "clipboard"],
    # set a cropsize constraint, can either be a ratio or a concrete [width, height]
    crop_size="1:1",
    # enable crop (or disable it)
    transforms=["crop"],
    # customise the brush
    brush=Brush(
      default_size="25", # or leave it as 'auto'
      color_mode="fixed", # 'fixed' hides the user swatches and colorpicker, 'defaults' shows it
      default_color="hotpink", # html names are supported
      colors=[
        "rgba(0, 150, 150, 1)", # rgb(a)
        "#fff", # hex rgb
        "hsl(360, 120, 120)" # in fact any valid colorstring
      ]
    ),
    brush=Eraser(default_size="25")
)

Thanks @pngwn!

1.12.0

Features

Fixes

1.11.0

Features

Fixes

1.10.3

Patch Changes

1.10.2

Patch Changes

1.10.1

Patch Changes

1.10.0

Features

Fixes

1.9.2

Fixes

1.9.1

Features

1.9.0

Features

Fixes

1.9.0-beta.3

Features

1.9.0-beta.2

Features

Fixes

1.9.0-beta.1

Patch Changes

1.9.0-beta.0

Features

  • #5960 319c30f3f - rererefactor frontend files. Thanks @pngwn!
  • #5956 f769876e0 - Apply formatter (and small refactoring) to the Lite-related frontend code. Thanks @whitphx!
  • #5498 85ba6de13 - Adds the ability to build the frontend and backend of custom components in preparation for publishing to pypi using gradio_component build. Thanks @pngwn!

Fixes

1.8.0

Features

  • #5627 b67115e8e - Lite: Make the Examples component display media files using pseudo HTTP requests to the Wasm server. Thanks @whitphx!
  • #5886 121f25b2d - Lite: Fix is_self_host() to detect 127.0.0.1 as localhost as well. Thanks @whitphx!

1.7.1

Patch Changes

1.7.0

Highlights

new FileExplorer component (#5672 e4a307ed6)

Thanks to a new capability that allows components to communicate directly with the server without passing data via the value, we have created a new FileExplorer component.

This component allows you to populate the explorer by passing a glob, but only provides the selected file(s) in your prediction function.

Users can then navigate the virtual filesystem and select files which will be accessible in your predict function. This component will allow developers to build more complex spaces, with more flexible input options.

output

For more information check the FileExplorer documentation.

Thanks @aliabid94!

Fixes

1.6.4

Features

1.6.3

Patch Changes

1.6.2

Features

Fixes

1.6.1

Patch Changes

1.6.0

Features

1.5.4

Features

1.5.3

Fixes

1.5.2

Patch Changes

1.5.1

Patch Changes

1.5.0

Features

1.4.3

Patch Changes

1.4.2

Fixes

1.4.1

Patch Changes

1.4.0

Features

1.3.2

Patch Changes

1.3.1

Fixes

1.3.0

Highlights

Improve startup performance and markdown support (#5279 fe057300)

Improved markdown support

We now have better support for markdown in gr.Markdown and gr.Dataframe. Including syntax highlighting and Github Flavoured Markdown. We also have more consistent markdown behaviour and styling.

Various performance improvements

These improvements will be particularly beneficial to large applications.

  • Rather than attaching events manually, they are now delegated, leading to a significant performance improvement and addressing a performance regression introduced in a recent version of Gradio. App startup for large applications is now around twice as fast.
  • Optimised the mounting of individual components, leading to a modest performance improvement during startup (~30%).
  • Corrected an issue that was causing markdown to re-render infinitely.
  • Ensured that the gr.3DModel does re-render prematurely.

Thanks @pngwn!

Add render function to <gradio-app> (#5158 804fcc05)

We now have an event render on the web component, which is triggered once the embedded space has finished rendering.

<script>
  function handleLoadComplete() {
    console.log("Embedded space has finished rendering");
  }
  const gradioApp = document.querySelector("gradio-app");
  gradioApp.addEventListener("render", handleLoadComplete);
</script>

Thanks @hannahblair!

Features

  • #5215 fbdad78a - Lazy load interactive or static variants of a component individually, rather than loading both variants regardless. This change will improve performance for many applications. Thanks @pngwn!
  • #5216 4b58ea6d - Update i18n tokens and locale files. Thanks @hannahblair!
  • #5219 e8fd4e4e - Add api_name parameter to gr.Interface. Additionally, completely hide api page if show_api=False. Thanks @freddyaboulton!
  • #5264 46a2b600 - ensure translations for audio work correctly. Thanks @hannahblair!

Fixes

1.2.0

Highlights

Client.predict will now return the final output for streaming endpoints (#5057 35856f8b)

This is a breaking change (for gradio_client only)!

Previously, Client.predict would only return the first output of an endpoint that streamed results. This was causing confusion for developers that wanted to call these streaming demos via the client.

We realize that developers using the client don't know the internals of whether a demo streams or not, so we're changing the behavior of predict to match developer expectations.

Using Client.predict will now return the final output of a streaming endpoint. This will make it even easier to use gradio apps via the client.

Thanks @freddyaboulton!

Features

1.1.0

Features