Python library for easily interacting with trained machine learning models
Project description
tags: [gradio-custom-component, Dataset] title: gradio_dataset short_description: A gradio custom component colorFrom: blue colorTo: yellow sdk: gradio pinned: false app_file: space.py
gradio_dataset
Python library for easily interacting with trained machine learning models
Installation
pip install gradio_dataset
Usage
import gradio as gr
from gradio_dataset import dataset
from gradio_modal_component import modal_component
# Initialize a three-column dataset for testing
def init_ds_three_col():
ds = [
[
"Text 1",
"<img src='https://dev-to-uploads.s3.amazonaws.com/uploads/articles/1u64v34tov7a3tdqitrz.png' width='100px' height='100px'>",
"Description 1",
],
[
"Text 2",
"<img src='https://dev-to-uploads.s3.amazonaws.com/uploads/articles/1u64v34tov7a3tdqitrz.png' width='100px' height='100px'>",
"Description 2",
],
[
"Text 3",
"<img src='https://dev-to-uploads.s3.amazonaws.com/uploads/articles/1u64v34tov7a3tdqitrz.png' width='100px' height='100px'>",
"Description 3",
],
[
"Text 4",
"<img src='https://dev-to-uploads.s3.amazonaws.com/uploads/articles/1u64v34tov7a3tdqitrz.png' width='100px' height='100px'>",
"Description 4",
],
[
"Text 5",
"<img src='https://dev-to-uploads.s3.amazonaws.com/uploads/articles/1u64v34tov7a3tdqitrz.png' width='100px' height='100px'>",
"Description 5",
],
]
return ds
# Function to handle selection
def get_selection(evt: gr.SelectData):
print("Selection Event Triggered")
print(f"Index: {evt.index}")
print(f"Value: {evt.value}")
print(f"RowData: {evt.row_value}")
try:
# Check the action taken and display the modal accordingly
if isinstance(evt.value, dict):
if evt.value["menu_choice"] == "View Profile":
# Display the modal with the selected value
content = f"""
# View Profile
- You are viewing the profile number `{evt.index}`
- Profile content:
- {evt.row_value}"""
return gr.update(visible=True), content
if evt.value["menu_choice"] == "Edit":
# Display the modal with the selected value
content = f"""
# Edit Profile
- You are editting the profile number `{evt.index}`
- Profile content:
- {evt.row_value}"""
return gr.update(visible=True), content
except Exception as e:
pass
# Return to hide the modal
return gr.update(visible=False), ""
with gr.Blocks() as demo:
# Modal that shows the content dynamically based on user selection
with modal_component(
visible=False, width=500, height=300, bg_blur=0
) as profileModal:
modal_text = gr.Markdown(f"")
gr.Markdown("""
# Dataset Component
- Trigger click envents, this will tracking and return (check log in terminal):
- `evt.index`: **list[row, col]** - index of the selected cell
- `evt.value`: **str** - The selected cell value
- `evt.row_value`: **list[str]** - The selected row value by this you can get the value of a specific column by `evt.row_value[col]`
- Action column:
- `menu_choice`: **list[str]** - Modify the menu choices to add the action column
- `menu_icon`: **str** - Add the icon to the menu choices, if not there will be a default icon
- When user select the action, it will trigger an event:
- `evt.index`: **str** - index of the selected row
- `evt.value`: **dict{"menu_choice": "action"}** - The selected action value
- `evt.row_value`: **list[str]** - The selected row value
- Header Sort:
- `header_sort`: **bool** - Enable the header sort
- This will sort the dataset based on the header column at UI level, however this event will be trigger
- `evt.index`: **str** - index of the selected Col
- `evt.value`: **dict{"columns": col, "order": "descending" | "ascending"}** - Column and order of the sort
- Manual Sort:
- `manual_sort`: **bool** - Enable the manual sort
- This will enable sort icon on UI and sort event only (for trigger purpose), User will have to tracking the event and sort the dataset manually
## Test case 1:
- `menu_icon`: not set
- `header_sort`: True
""")
# Define the three-column dataset
three_col_ds = dataset(
components=[
gr.Textbox(visible=False, interactive=True),
gr.HTML(visible=False),
gr.Textbox(visible=False, interactive=True), # Added third column
],
headers=[
"Textbox",
"Image",
"Description",
], # Updated headers for three columns
label="Test Case 1",
samples=init_ds_three_col(), # Use the new three-column dataset
menu_choices=["View Profile", "Edit", "Delete"],
# menu_icon="https://cdn-icons-png.flaticon.com/512/18/18659.png",
header_sort=True,
# manual_sort=True,
)
# Set the select event to update modal visibility and content
three_col_ds.select(
fn=get_selection, inputs=None, outputs=[profileModal, modal_text]
)
## Test Case 2
gr.Markdown("""
# Test case 2
- `menu_icon`: enable
- `manual_sort`: True
""")
# Define the three-column dataset
three_col_ds2 = dataset(
components=[
gr.Textbox(visible=False, interactive=True),
gr.HTML(visible=False),
gr.Textbox(visible=False, interactive=True), # Added third column
],
headers=[
"Textbox",
"Image",
"Description",
], # Updated headers for three columns
label="Test Case 2",
samples=init_ds_three_col(), # Use the new three-column dataset
menu_choices=["View Profile", "Edit", "Delete"],
menu_icon="https://cdn-icons-png.flaticon.com/512/18/18659.png",
# header_sort=True,
manual_sort=True,
)
# Set the select event to update modal visibility and content
three_col_ds2.select(
fn=get_selection, inputs=None, outputs=[profileModal, modal_text]
)
if __name__ == "__main__":
demo.launch()
dataset
Initialization
name | type | default | description |
---|---|---|---|
label |
str | None
|
None |
The label for this component, appears above the component. |
components |
Sequence[gradio.components.base.Component]
| list[str]
| None
|
None |
Which component types to show in this dataset widget, can be passed in as a list of string names or Components instances. The following components are supported in a dataset: Audio, Checkbox, CheckboxGroup, ColorPicker, Dataframe, Dropdown, File, HTML, Image, Markdown, Model3D, Number, Radio, Slider, Textbox, TimeSeries, Video |
component_props |
list[dict[str, Any]] | None
|
None |
None |
samples |
list[list[Any]] | None
|
None |
a nested list of samples. Each sublist within the outer list represents a data sample, and each element within the sublist represents an value for each component |
headers |
list[str] | None
|
None |
Column headers in the dataset widget, should be the same len as components. If not provided, inferred from component labels |
type |
"values" | "index" | "tuple"
|
"values" |
"values" if clicking on a sample should pass the value of the sample, "index" if it should pass the index of the sample, or "tuple" if it should pass both the index and the value of the sample. |
samples_per_page |
int
|
10 |
how many examples to show per page. |
visible |
bool
|
True |
If False, 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 list of strings that are assigned as the classes of this component in the HTML DOM. Can be used for targeting CSS styles. |
render |
bool
|
True |
If False, component will not render be rendered in the Blocks context. Should be used if the intention is to assign event listeners now but render the component later. |
key |
int | str | None
|
None |
if assigned, will be used to assume identity across a re-render. Components that have the same key across a re-render will have their value preserved. |
container |
bool
|
True |
If True, will place the component in a container - providing some extra padding around the border. |
scale |
int | None
|
None |
relative size compared to adjacent Components. For example if Components A and B are in a Row, and A has scale=2, and B has scale=1, A will be twice as wide as B. Should be an integer. scale applies in Rows, and to top-level Components in Blocks where fill_height=True. |
min_width |
int
|
160 |
minimum pixel width, will wrap if not sufficient screen space to satisfy this value. If a certain scale value results in this Component being narrower than min_width, the min_width parameter will be respected first. |
proxy_url |
str | None
|
None |
The URL of the external Space used to load this component. Set automatically when using `gr.load()`. This should not be set manually. |
sample_labels |
list[str] | None
|
None |
A list of labels for each sample. If provided, the length of this list should be the same as the number of samples, and these labels will be used in the UI instead of rendering the sample values. |
menu_icon |
str | None
|
None |
None |
menu_choices |
list[str] | None
|
None |
None |
header_sort |
bool
|
False |
None |
manual_sort |
bool
|
False |
None |
Events
name | description |
---|---|
click |
Triggered when the dataset is clicked. |
select |
Event listener for when the user selects or deselects the dataset. Uses event data gradio.SelectData to carry value referring to the label of the dataset, and selected to refer to state of the dataset. See EventData documentation on how to use this event data |
User function
The impact on the users predict function varies depending on whether the component is used as an input or output for an event (or both).
- When used as an Input, the component only impacts the input signature of the user function.
- When used as an output, the component only impacts the return signature of the user function.
The code snippet below is accurate in cases where the component is used as both an input and an output.
- As output: Is passed, passes the selected sample either as a
list
of data corresponding to each input component (iftype
is "value") or as anint
index (iftype
is "index"), or as atuple
of the index and the data (iftype
is "tuple"). - As input: Should return, expects an
int
index orlist
of sample data. Returns the index of the sample in the dataset orNone
if the sample is not found.
def predict(
value: int | list | tuple[int, list] | None
) -> int | list | None:
return value
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
gradio_dataset-0.0.1.tar.gz
(116.8 kB
view details)
Built Distribution
File details
Details for the file gradio_dataset-0.0.1.tar.gz
.
File metadata
- Download URL: gradio_dataset-0.0.1.tar.gz
- Upload date:
- Size: 116.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 85782a4d64b68a84d26bda96302f3699c5000b3e1b9e7dca6cecf2836004c530 |
|
MD5 | af26d6f212b724e835da51b4e5a63dcb |
|
BLAKE2b-256 | ddae49d6255a969a41874f1e68cc747e726729fb01c8c654a8fb375acdef4e2e |
File details
Details for the file gradio_dataset-0.0.1-py3-none-any.whl
.
File metadata
- Download URL: gradio_dataset-0.0.1-py3-none-any.whl
- Upload date:
- Size: 32.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1eeafba211f04c0a2fb9878bf36edd4eb3d15f6002e7873d591e3dc67542751b |
|
MD5 | 4fb922a6be91513b11dd4192aebc1455 |
|
BLAKE2b-256 | e79d01cda022f3d6194e09ddba1216d39494fa805a5c623c2487f168d6b34093 |