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

A newer version of the Gradio SDK is available: 5.13.1

Upgrade

@gradio/chatbot

0.14.2

Dependency updates

0.14.1

Features

  • #9617 c163182 - Fix dark mode detection and container height. Thanks @pngwn!
  • #9623 5923c67 - Fix Chatbot Examples Error. Thanks @freddyaboulton!
  • #9614 5d98550 - Fix retry and undo reactivity in gr.Chatbot. Thanks @hannahblair!
  • #9619 1f3ee97 - Fix Functional Tests. Thanks @dawoodkhan82!

Fixes

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

Dependency updates

0.14.0

Features

Fixes

  • #8843 6f95286 - Ensure undo/try shows for final bot message in gr.Chatbot

Dependencies

0.14.0-beta.9

Fixes

  • #9600 9f71086 - Ensure undo/try shows for final bot message in gr.Chatbot. Thanks @hannahblair!

0.14.0-beta.8

Features

  • #9593 cc61fe7 - Some more chatbot fixes. Thanks @dawoodkhan82!
  • #9582 43a7f42 - Chatbot autoscroll. Thanks @whitphx!
  • #9598 ffc33fa - Fix markdown code copy/check button in gr.Chatbot. Thanks @hannahblair!
  • #9499 17e6c84 - Fix gr.Chatbot panels layout. Thanks @hannahblair!

Dependency updates

0.14.0-beta.7

Features

  • #9571 148345d - Fix chatinterface embedding height issues. Thanks @aliabid94!

Dependency updates

0.14.0-beta.6

Features

  • #9488 4e6a47f - Fixes: Chatbot examples for custom chatbot + rename suggestions -> examples. Thanks @dawoodkhan82!

Dependency updates

0.14.0-beta.5

Dependency updates

0.14.0-beta.4

Features

0.14.0-beta.3

Dependency updates

0.14.0-beta.2

Features

  • #9359 50c3a7f - Small tweak to how thoughts are shown in gr.Chatbot. Thanks @abidlabs!
  • #9323 06babda - Disable liking user message in chatbot by default but make it configurable. Thanks @freddyaboulton!
  • #8966 8e52b6a - Chatbot Examples. Thanks @dawoodkhan82!
  • #9261 73647a0 - Move icons into IconButtonWrapper. Thanks @hannahblair!
  • #9316 4338f29 - 9227 chatinterface retry bug. Thanks @freddyaboulton!
  • #9313 1fef9d9 - Standardize height across components and add max_height and min_height parameters where appropriate. Thanks @abidlabs!
  • #9339 4c8c6f2 - Ssr part 2. Thanks @pngwn!

Dependency updates

0.14.0-beta.1

Features

  • #9201 5492e74 - Move buttons from chat_interface into Chatbot. Thanks @freddyaboulton!
  • #9187 5bf00b7 - make all component SSR compatible. Thanks @pngwn!

Dependency updates

0.13.1

Features

  • #9187 5bf00b7 - make all component SSR compatible. Thanks @pngwn!

Fixes

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

Dependency updates

0.13.0

Features

  • #9013 5350f1f - Add copy all messages button to chatbot. Thanks @hannahblair!
  • #9118 e1c404d - setup npm-previews of all packages. Thanks @pngwn!
  • #9102 efdc323 - Initial SSR refactor. Thanks @pngwn!

Fixes

  • #9161 173c7b8 - Chatbot Image size and list fixes. Thanks @dawoodkhan82!

Dependency updates

0.12.4

Fixes

  • #8847 4d8a473 - Refactor Chatinterface to use Chatbot instead of gr.State variables. Thanks @freddyaboulton!

Dependency updates

0.12.3

Dependency updates

0.12.2

Fixes

  • #8865 2f630ab - Chatbot Examples Scroll Fix. Thanks @dawoodkhan82!

Dependency updates

0.12.1

Features

  • #8766 2b4636e - Fix width of assistant's chatbot bubble. Thanks @pngwn!

0.12.0

Highlights

Support message format in chatbot 💬 (#8422 4221290)

gr.Chatbot and gr.ChatInterface now support the Messages API, which is fully compatible with LLM API providers such as Hugging Face Text Generation Inference, OpenAI's chat completions API, and Llama.cpp server.

Building Gradio applications around these LLM solutions is now even easier!

gr.Chatbot and gr.ChatInterface now have a type parameter that can accept two values - 'tuples' and 'messages'. If set to 'tuples', the default chatbot data format is expected. If set to 'messages', a list of dictionaries with content and role keys is expected. See below -

def chat_greeter(msg, history):
    history.append({"role": "assistant", "content": "Hello!"})
    return history

Additionally, gradio now exposes a gr.ChatMessage dataclass you can use for IDE type hints and auto completion.

image

Tool use in Chatbot 🛠️

The Gradio Chatbot can now natively display tool usage and intermediate thoughts common in Agent and chain-of-thought workflows!

If you are using the new "messages" format, simply add a metadata key with a dictionary containing a title key and value. This will display the assistant message in an expandable message box to show the result of a tool or intermediate step.

import gradio as gr
from gradio import ChatMessage
import time

def generate_response(history):
    history.append(ChatMessage(role="user", content="What is the weather in San Francisco right now?"))
    yield history
    time.sleep(0.25)
    history.append(ChatMessage(role="assistant",
                               content="In order to find the current weather in San Francisco, I will need to use my weather tool.")
                               )
    yield history
    time.sleep(0.25)

    history.append(ChatMessage(role="assistant",
                               content="API Error when connecting to weather service.",
                              metadata={"title": "💥 Error using tool 'Weather'"})
                  )
    yield history
    time.sleep(0.25)

    history.append(ChatMessage(role="assistant",
                               content="I will try again",
                              ))
    yield history
    time.sleep(0.25)

    history.append(ChatMessage(role="assistant",
                               content="Weather 72 degrees Fahrenheit with 20% chance of rain.",
                                metadata={"title": "🛠️ Used tool 'Weather'"}
                              ))
    yield history
    time.sleep(0.25)

    history.append(ChatMessage(role="assistant",
                               content="Now that the API succeeded I can complete my task.",
                              ))
    yield history
    time.sleep(0.25)

    history.append(ChatMessage(role="assistant",
                               content="It's a sunny day in San Francisco with a current temperature of 72 degrees Fahrenheit and a 20% chance of rain. Enjoy the weather!",
                              ))
    yield history


with gr.Blocks() as demo:
    chatbot  = gr.Chatbot(type="messages")
    button = gr.Button("Get San Francisco Weather")
    button.click(generate_response, chatbot, chatbot)

if __name__ == "__main__":
    demo.launch()

tool-box-demo

Thanks @freddyaboulton!

Fixes

Dependency updates

0.11.1

Fixes

  • #8655 3896398 - Ensure copy button on chatbot shows when appropriate. Thanks @pngwn!
  • #8631 9b8840a - Ensure chatbot messages are visible to screenreaders. Thanks @hannahblair!

Dependency updates

0.11.0

Features

  • #8131 bb504b4 - Gradio components in gr.Chatbot(). Thanks @dawoodkhan82!
  • #8607 c7cd0a0 - Ensure chatbot background is consistent with other components. Thanks @pngwn!
  • #8555 7fc7455 - support html in chatbot. Thanks @pngwn!

Fixes

Dependency updates

0.10.11

Dependency updates

0.10.10

Dependency updates

0.10.9

Dependency updates

0.10.8

Features

  • #8377 341844f - Click to preview images in chatbot. Thanks @dawoodkhan82!

0.10.7

Dependency updates

0.10.6

Dependency updates

0.10.5

Features

  • #8311 35905c5 - Cleanup markdown styling. Thanks @aliabid94!

Dependency updates

0.10.4

Dependency updates

0.10.3

Dependency updates

0.10.2

Dependency updates

0.10.1

Features

  • #8226 892181b - chore(deps): update dependency @types/prismjs to v1.26.4. Thanks @renovate!

Dependency updates

0.10.0

Features

  • #8121 f5b710c - chore(deps): update dependency eslint to v9. Thanks @renovate!

Dependency updates

0.9.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!

Fixes

  • #8066 624f9b9 - make gradio dev tools a local dependency rather than bundling. Thanks @pngwn!

Dependency updates

0.8.3

Features

  • #7998 06bdf0e - Restore chatbot formatting. Thanks @aliabid94!

Fixes

  • #8025 55ef4a5 - Fixes Chatbot Image Sizing. Thanks @dawoodkhan82!

Dependency updates

0.8.2

Dependency updates

0.8.1

Dependency updates

0.8.0

Features

  • #7849 7af3cd7 - Adds a placeholder argument to gr.Chatbot. Thanks @abidlabs!

Dependency updates

0.7.8

Dependency updates

0.7.7

Dependency updates

0.7.6

Dependency updates

0.7.5

Patch Changes

0.7.4

Features

  • #7528 eda33b3 - Refactors get_fetchable_url_or_file() to remove it from the frontend. Thanks @abidlabs!

0.7.3

Patch Changes

0.7.2

Patch Changes

0.7.1

Patch Changes

0.7.0

Features

  • #7183 49d9c48 - [WIP] Refactor file normalization to be in the backend and remove it from the frontend of each component. Thanks @abidlabs!

0.6.4

Patch Changes

0.6.3

Patch Changes

0.6.2

Patch Changes

0.6.1

Fixes

0.6.0

Features

Fixes

  • #6899 bd11d6e - Remove the styles on the audio elements in the Chatbot component. Thanks @whitphx!

0.5.6

Patch Changes

0.5.5

Patch Changes

0.5.4

Patch Changes

0.5.3

Patch Changes

0.5.2

Features

0.5.1

Fixes

0.5.0

Features

0.4.8

Features

0.4.7

Patch Changes

0.4.6

Patch Changes

0.4.5

Fixes

0.4.4

Patch Changes

0.4.3

Fixes

0.4.2

Patch Changes

0.4.1

Patch Changes

0.4.0

Features

0.4.0-beta.9

Features

0.4.0-beta.8

Features

Fixes

0.4.0-beta.7

Features

0.5.3

Fixes

0.5.2

Patch Changes

0.5.1

Fixes

0.5.0

Features

Fixes

0.4.1

Patch Changes

0.4.0

Features

Fixes

0.3.2

Fixes

0.3.1

Patch Changes

0.3.0

Highlights

Like/Dislike Button for Chatbot (#5391 abf1c57d)

Thanks @dawoodkhan82!

Features

Fixes

0.2.2

Fixes

0.2.1

Patch Changes

0.2.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!

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!
  • #5112 1cefee7f - chore(deps): update dependency marked to v7. Thanks @renovate!
  • #5258 92282cea - Chatbot Avatar Images. Thanks @dawoodkhan82!

Fixes

0.1.0

Features

0.0.2

Patch Changes