Streamlit component that implement the wonderful Driver.js library. It allows you to start a tour that takes the user through the component that you want
Project description
:camera: streamlit-tour
A Driver.js integration for Streamlit - add beautiful, interactive guided tours to your Streamlit apps with a single Python call.
Features
- :link: Bind tour steps to any Streamlit widget by its
key - :window: Element-free info steps - show contextual popups not anchored to any component
- :white_check_mark: One-time tours - automatically skip tours the user has already completed (via
localStorage) - :leftwards_arrow_with_hook: State feedback - know exactly when a tour was finished, dismissed, or skipped
- :art: Configurable - control overlay opacity, animations, progress indicators, and popover alignment
Installation
pip install streamlit-tour
Or in a more modern way:
uv add streamlit-tour
Quickstart
import streamlit as st
from streamlit_tour import Tour
st.title("My App")
st.text_input("Name", key="name_input")
if st.button("Start Tour"):
Tour.start(
steps=[
Tour.bind("name_input", title="Your Name", desc="Enter your name here."),
Tour.info(title="That's it!", desc="You're ready to go."),
]
)
Usage
Tour.start()
Launches the tour. Call this inside any conditional block (e.g. a button click).
result = Tour.start(
steps=[...],
show_progress=True, # Show "Step 1/3" counter
animate=True, # Animate transitions between steps
overlay_opacity=0.75, # Background overlay darkness (0.0–1.0)
one_time_tour=False, # If True, skip the tour after first completion
key="my_tour", # Unique key - change it for each tour
)
Return value - a dict with the tour's final state:
| Key | Type | Description |
|---|---|---|
currentStep |
int |
Last step index the user reached |
dismissed |
bool |
True if the user closed the tour before finishing |
finished |
bool |
True if the user completed all steps |
skipped |
bool |
True if the tour was skipped (one-time, already seen) |
Tour.bind()
Attaches a tour step to a Streamlit widget via its key.
Tour.bind(
key="my_widget_key", # Must match the widget's key= argument
title="Step Title",
desc="Step description text.",
side="bottom", # "top" | "bottom" | "left" | "right" (optional)
align="center", # "start" | "center" | "end" (optional)
)
How it works:
Tour.bindresolves the widget using Streamlit's.st-key-<key>CSS class, which is automatically injected on any widget that has akey=argument.
Tour.info()
Creates a floating step with no element anchor - useful for introductory or summary slides.
Tour.info(
title="Welcome!",
desc="This tour will walk you through the main features of this app.",
)
One-Time Tour
Set one_time_tour=True to automatically skip the tour for users who have already seen it. Completion is tracked in the browser's localStorage using the tour's key.
Tour.start(
steps=[...],
one_time_tour=True,
key="onboarding_tour", # Must be unique and stable across reruns
)
To reset the tour (e.g. for testing), clear localStorage in your browser's DevTools, or use a different key.
Check out example.py file for a complete example of usage.
Tips
- Always provide a
keywhen usingone_time_tour=Trueor when you have multiple tours on the same page. - Widgets must have a
key=argument forTour.bind()to locate them. Anonymous widgets (nokey) are not bindable. - Re-triggering a tour: Change the
keyvalue between Streamlit reruns to force the tour to restart. - Column layouts: Use
sideandalignonTour.bind()to control which side the popover appears on narrow widgets.
Roadmap / Possible Improvements
- Better output - make the Tour returns an object instead of a simple dict
- Custom button labels - override "Next", "Previous", "Done" text per step or globally
- Step grouping - define multiple named tours and selectively launch them
-
Tour.reset(key)- a utility function to clear the one-time-tour flag fromlocalStorage - Theme support - CSS variable overrides to match Streamlit's light/dark mode
- Driver.js parameters - implement all the other Driver.js options
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_tour-0.1.1.tar.gz.
File metadata
- Download URL: streamlit_tour-0.1.1.tar.gz
- Upload date:
- Size: 31.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eacd266f46c3d834ad3f91be99571504c83cc032e919319e8018e8edc8fb4f0c
|
|
| MD5 |
ab6cbf22a2222d0d77a4736aed483d13
|
|
| BLAKE2b-256 |
e70ddcc61cde0fc8ebde762c77d64c3ebebf553dc2485a5bc1df5cf51f9f29af
|
File details
Details for the file streamlit_tour-0.1.1-py3-none-any.whl.
File metadata
- Download URL: streamlit_tour-0.1.1-py3-none-any.whl
- Upload date:
- Size: 30.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4bd53109c8ff2b2f38a393c4c49d2c41fee80256127a036a906fe444a5a3cb56
|
|
| MD5 |
c3ba50162f4a268602b296e5f88f46af
|
|
| BLAKE2b-256 |
8ceb3c35ee3157d88c6ea4112ce94a3f8ed3220b8bef0893bd3fe18b8d235c57
|