Gradio Agents & MCP Hackathon
WinnersGradio Agents & MCP Hackathon
WinnersNew to Gradio? Start here: Getting Started
See the Release History
gradio.SelectData(···).select() event. When gr.SelectData is added as a type hint to an argument of an event listener method, a gr.SelectData object will automatically be passed as the value of that argument. The attributes of this object contains information about the event that triggered the listener. import gradio as gr
with gr.Blocks() as demo:
    table = gr.Dataframe([[1, 2, 3], [4, 5, 6]])
    gallery = gr.Gallery([("cat.jpg", "Cat"), ("dog.jpg", "Dog")])
    textbox = gr.Textbox("Hello World!")
    statement = gr.Textbox()
    def on_select(evt: gr.SelectData):
        return f"You selected {evt.value} at {evt.index} from {evt.target}"
    table.select(on_select, None, statement)
    gallery.select(on_select, None, statement)
    textbox.select(on_select, None, statement)
demo.launch()index: int | tuple[int, int]The index of the selected item. Is a tuple if the component is two dimensional or selection is a range.
row_value: list[float | str]The value of the entire row that the selected item belongs to, as a 1-D list. Only implemented for the `Dataframe` component, returns None for other components.
import gradio as gr
import numpy as np
with gr.Blocks() as demo:
    imgs = gr.State()
    gallery = gr.Gallery(allow_preview=False)
    def deselect_images():
        return gr.Gallery(selected_index=None)
    def generate_images():
        images = []
        for _ in range(9):
            image = np.ones((100, 100, 3), dtype=np.uint8) * np.random.randint(
                0, 255, 3
            )  # image is a solid single color
            images.append(image)
        return images, images
    demo.load(generate_images, None, [gallery, imgs])
    with gr.Row():
        selected = gr.Number(show_label=False)
        darken_btn = gr.Button("Darken selected")
    deselect_button = gr.Button("Deselect")
    deselect_button.click(deselect_images, None, gallery)
    def get_select_index(evt: gr.SelectData):
        return evt.index
    gallery.select(get_select_index, None, selected)
    def darken_img(imgs, index):
        index = int(index)
        imgs[index] = np.round(imgs[index] * 0.8).astype(np.uint8)
        return imgs, imgs
    darken_btn.click(darken_img, [imgs, selected], [imgs, gallery])
if __name__ == "__main__":
    demo.launch()