Skip to main content

A Bottom bar for Gradio Interface

Project description


tags: [gradio-custom-component, SideBar] title: gradio_bottombar short_description: A Bottom bar for Gradio Interface colorFrom: blue colorTo: yellow sdk: gradio pinned: false app_file: space.py

gradio_bottombar

PyPI - Version

A Bottom bar for Gradio Interface

Installation

pip install gradio_bottombar

Usage

# demo/app.py

import gradio as gr
import time
from gradio_bottombar import BottomBar

def chat_response(message, history):    
    history = history or ""
    history += f"You: {message}\n"
    time.sleep(1) # Simulate thinking
    history += f"Bot: Thanks for the message! You said: '{message}'\n"
    return history, ""

def update_label(value):
    return f"Current temperature is: {value}"

with gr.Blocks(theme=gr.themes.Ocean(), title="Full Layout Demo") as demo:
    gr.Markdown(
        """
        # Full Layout Demo: BottomBar with Sidebars
        This demo shows the `BottomBar` with `bring_to_front=True`. Notice how it now renders
        **on top of** the sidebars when they overlap.
        """
    )
       
    with BottomBar(open=False, height=180, bring_to_front=True, rounded_borders=True) as bottom_bar:
        with gr.Row():
            message_box = gr.Textbox(
                show_label=False,
                placeholder="Type your message here...",
                elem_id="message-input",
                scale=7
            )
            send_button = gr.Button("Send", variant="primary", scale=1)
        with gr.Row():
            gr.Button("Upload File")
            gr.Button("Record Audio")
            gr.ClearButton([message_box])

    with gr.Row(equal_height=True):
        with gr.Sidebar(position="left"):
            gr.Markdown("### ⚙️ Settings")
            model_temp = gr.Slider(0, 1, value=0.7, label="Model Temperature")
            temp_label = gr.Markdown(update_label(0.7))
            gr.CheckboxGroup(
                ["Enable History", "Use Profanity Filter", "Stream Response"],
                label="Chat Options",
                value=["Enable History", "Stream Response"]
            )

        with gr.Column(scale=3):
            gr.Markdown("### 🤖 Chat Interface")
            chatbot_display = gr.Textbox(
                label="Chat History",
                lines=25,
                interactive=False
            )

        with gr.Sidebar(position="right"):
            gr.Markdown("### ℹ️ Information")
            gr.Radio(
                ["GPT-4", "Claude 3", "Llama 3"],
                label="Current Model",
                value="Claude 3"
            )
            gr.Dropdown(
                ["English", "Spanish", "Portuguese"],
                label="Language",
                value="Portuguese"
            )
    
    send_button.click(
        fn=chat_response,
        inputs=[message_box, chatbot_display],
        outputs=[chatbot_display, message_box]
    )
    message_box.submit(
        fn=chat_response,
        inputs=[message_box, chatbot_display],
        outputs=[chatbot_display, message_box]
    )
    model_temp.change(
        fn=update_label,
        inputs=model_temp,
        outputs=temp_label
    )

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

BottomBar

Initialization

name type default description
label
str | gradio.i18n.I18nData | None
None name of the bottom bar. Not displayed to the user.
open
bool
True if True, bottom bar is open by default.
visible
bool
True If False, the component will be hidden.
elem_id
str | None
None An optional string that is assigned as the id of this component in the HTML DOM. Can be used for targeting CSS styles.
elem_classes
list[str] | str | None
None An optional string or list of strings that are assigned as the class of this component in the HTML DOM. Can be used for targeting CSS styles.
render
bool
True If False, this layout will not be rendered in the Blocks context. Should be used if the intention is to assign event listeners now but render the component later.
height
int | str
320 The height of the bottom bar, specified in pixels if a number is passed, or in CSS units if a string is passed.
width
int | str
"100%" The width of the bottom bar, specified in pixels if a number is passed, or in CSS units (like "80%") if a string is passed. The bar will be horizontally centered.
bring_to_front
bool
False If True, the BottomBar will be rendered on top of all other elements with a higher z-index. Defaults to False.
rounded_borders
bool
False None
key
int | str | tuple[int | str, Ellipsis] | None
None in a gr.render, Components with the same key across re-renders are treated as the same component, not a new component. Properties set in 'preserved_by_key' are not reset across a re-render.
preserved_by_key
list[str] | str | None
None A list of parameters from this component's constructor. Inside a gr.render() function, if a component is re-rendered with the same key, these (and only these) parameters will be preserved in the UI (if they have been changed by the user or an event listener) instead of re-rendered based on the values provided during constructor.

Events

name description
expand This listener is triggered when the BottomBar is expanded.
collapse This listener is triggered when the BottomBar is collapsed.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gradio_bottombar-0.0.2.tar.gz (145.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gradio_bottombar-0.0.2-py3-none-any.whl (83.1 kB view details)

Uploaded Python 3

File details

Details for the file gradio_bottombar-0.0.2.tar.gz.

File metadata

  • Download URL: gradio_bottombar-0.0.2.tar.gz
  • Upload date:
  • Size: 145.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.11

File hashes

Hashes for gradio_bottombar-0.0.2.tar.gz
Algorithm Hash digest
SHA256 6fb64a121860dd7e7f1baff6045fa572857e1d2465e54b146723c0682bbaf34e
MD5 ba26ee47900e68ae6265e11140df954d
BLAKE2b-256 692846d6d526f2ac45a29ea1af43cecf49428dfc823c440f5a50da3a56f2a479

See more details on using hashes here.

File details

Details for the file gradio_bottombar-0.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for gradio_bottombar-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 389876f37a32523090ec2b3fad61392b2c8a86ffb1aa6533035efb5eecc5ac24
MD5 e2439ce44f1efe4749338dd4b845723b
BLAKE2b-256 410f766d3205c1cb1a1a79e9f94831c10bec390669f5a856242971633599d4ae

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page