A Streamlit custom component for selecting and reordering multiple string values.
Project description
streamlit-sortable-multiselect
A Streamlit custom component for searching, selecting, and reordering multiple string values.
Install
python -m pip install streamlit-sortable-multiselect
For local development:
python -m pip install -e ".[dev]"
For frontend development:
cd streamlit_sortable_multiselect/frontend
npm install
npm run dev
Usage
import streamlit as st
from streamlit_sortable_multiselect import sortable_multiselect
selected = sortable_multiselect(
"Favorite frameworks",
options=[
{"label": "Streamlit", "value": "streamlit", "icon_url": "https://streamlit.io/images/brand/streamlit-mark-color.png"},
{"label": "FastAPI", "value": "fastapi", "icon_url": "https://fastapi.tiangolo.com/img/favicon.png"},
{"label": "Django", "value": "django"},
{"label": "Flask", "value": "flask"},
],
default=["streamlit"],
placeholder="Search frameworks...",
show_move_buttons=True,
show_numbers=True,
base_color="#eef2ff",
order_colors={1: "#fee2e2", 2: "#dcfce7"},
max_selections=3,
max_selections_placeholder="Choose up to 3 frameworks",
empty_message="No frameworks selected",
no_options_placeholder="All frameworks selected",
selected_position="top",
)
st.write(selected)
Settings
sortable_multiselect returns the selected option values as a list[str] in the current display order.
| Argument | Type | Default | Description |
|---|---|---|---|
label |
str |
required | Label displayed above the component. |
options |
Sequence[str | Mapping[str, Any]] |
required | Available options. Each option can be a plain string, or a dictionary with label, value, and optional icon_url. Option values must be unique. |
default |
Sequence[str] | None |
None |
Initially selected values, in the initial order. Values must exist in options and must not contain duplicates. |
placeholder |
str |
"Select..." |
Placeholder shown in the search/add input when options are available. |
disabled |
bool |
False |
Disables searching, selecting, removing, dragging, and move buttons. |
show_move_buttons |
bool |
True |
Shows up/down buttons on selected items. Drag sorting remains available unless disabled=True. |
show_numbers |
bool |
False |
Shows 1-based position numbers before selected item labels. |
base_color |
str | None |
None |
Background color applied to all selected items. Accepts CSS color values such as "#eef2ff" or "lightblue". |
order_colors |
Mapping[int, str] | None |
None |
Per-position selected item background colors. Keys are 1-based positions, for example {1: "#fee2e2", 2: "#dcfce7"}. These override base_color for matching positions. |
max_selections |
int | None |
None |
Maximum number of selected items. None means no limit. Use 0 to prevent any selections. |
max_selections_placeholder |
str |
"Selection limit reached" |
Placeholder shown when max_selections has been reached. This takes precedence over placeholder and no_options_placeholder. |
empty_message |
str |
"No items selected" |
Message shown where the selected list appears when no items are selected. |
no_options_placeholder |
str |
"No more options" |
Placeholder shown when every option is already selected and there are no more options to add. |
selected_position |
str |
"bottom" |
Position of the selected item list relative to the search/add input. Use "bottom" or "top". |
key |
str | None |
None |
Optional Streamlit component key. Use this when rendering multiple sortable multiselects. |
Option dictionaries use this shape:
{"label": "Python", "value": "python", "icon_url": "https://www.python.org/static/favicon.ico"}
icon_url may be omitted. The returned value is always the value, not the display label.
Build the frontend before packaging or using release mode:
cd streamlit_sortable_multiselect/frontend
npm run build
Run the example app:
streamlit run examples/basic.py
Release
Build and check the distribution files:
cd streamlit_sortable_multiselect/frontend
npm install
npm run build
cd ../..
python -m pip install -e ".[dev]"
python -m build
python -m twine check dist/*
Upload to PyPI with an API token:
python -m twine upload dist/*
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file streamlit_sortable_multiselect-0.7.1.tar.gz.
File metadata
- Download URL: streamlit_sortable_multiselect-0.7.1.tar.gz
- Upload date:
- Size: 117.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c1e67459e95d67c39848cc8f323e26cb6ebb09bccba058babd79f926ed80351e
|
|
| MD5 |
5f689201753b6d4a4b157438d430359e
|
|
| BLAKE2b-256 |
c1f615f1956c303d89fdb380ecd60c22b9c71ec4d657a3d4759e7cf771c2bc3d
|
File details
Details for the file streamlit_sortable_multiselect-0.7.1-py3-none-any.whl.
File metadata
- Download URL: streamlit_sortable_multiselect-0.7.1-py3-none-any.whl
- Upload date:
- Size: 115.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a8aea6cc7086b44dbbe9b6cd8e190a4cd3f25824799893526f01e1e5ea46a3e8
|
|
| MD5 |
b1aaed58d39e2baea80331b75392eede
|
|
| BLAKE2b-256 |
82443ee228b324990e1a32f25fccea1109d66132674563753a27daf42ca69425
|