A Streamlit custom component to allow one click scrolling to different locations on your page
Project description
streamlit-scroll-to-top
Streamlit component which provides a hacky workaround to utilise streamlit buttons, iframes and state management to redirect users to different points on a page.
How does it work?
The component works by creaing an invisible iframe in the location you want to scroll to and then tells the parent window to move the focus to that iframe. See the Example usage further below to get a further idea of how it works/how to implement it in your code. There are other ways to do this however I wanted a way I could easily use streamlit buttons & the session state to move the user to different locations.
This may stop working at any moment or indeed may not work on some browsers. I've tested on Edge, Chrome, Firefox & Opera and all appears to be OK
Features
- Scroll to the top of a page (or any point) easily using existing Streamlit buttons.
Installation
pip install streamlit-scroll-to-top
Example Usage
Copy this code snippet:
import streamlit as st
from scroll_component import scroll_to_here
# Step 1: Initialize scroll state in session_state
if 'scroll_to_top' not in st.session_state:
st.session_state.scroll_to_top = False
if 'scroll_to_header' not in st.session_state:
st.session_state.scroll_to_header = False
# Step 2: Handle the scroll-to-top action
if st.session_state.scroll_to_top:
scroll_to_here(0, key='top') # Scroll to the top of the page
st.session_state.scroll_to_top = False # Reset the state after scrolling
# Step 3: Define a scroll function to trigger the state change
def scroll():
st.session_state.scroll_to_top = True
def scrollheader():
st.session_state.scroll_to_header = True
# Step 4: Add some dummy content to simulate a long page
st.title("Dummy Content")
st.write("Scroll down to see the 'Scroll to Top' button.")
for i in range(50): # Generate dummy content
if i == 25:
if st.session_state.scroll_to_header:
scroll_to_here(0, key='header') # Scroll to the top of the page
st.session_state.scroll_to_header = False # Reset the state after scrolling
st.header("Or scroll here")
st.text(f"Line {i + 1}: This is some dummy content.")
# Step 5: Add a button to trigger the scroll to top action. Both ways work... personal preference
st.button("Scroll to Top", on_click=scroll)
if st.button("Scroll to Top 2"):
st.session_state.scroll_to_top = True
st.rerun()
# Step 5: Add a button to trigger the scroll to header action. Both ways work... personal preference
st.button("Scroll to Header", on_click=scrollheader)
if st.button("Scroll to Header 2"):
st.session_state.scroll_to_header = True
st.rerun()
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_scroll_to_top-0.0.1.tar.gz.
File metadata
- Download URL: streamlit_scroll_to_top-0.0.1.tar.gz
- Upload date:
- Size: 3.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9b451b03efad9a0e62fecc2019b86ae18d0336bb667c098661f8ae826592bde0
|
|
| MD5 |
6847507d22241b14858d9f89890369ff
|
|
| BLAKE2b-256 |
f8482956ded75593513366a0478883c6d126a0094f9a885da695df59a59ec7ed
|
File details
Details for the file streamlit_scroll_to_top-0.0.1-py3-none-any.whl.
File metadata
- Download URL: streamlit_scroll_to_top-0.0.1-py3-none-any.whl
- Upload date:
- Size: 4.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3f1fec72936692ab6f866eadf88554dfbc50315702d4ac13043425baea59d7c6
|
|
| MD5 |
6ed628890ae6514b2bc272d9ff9b5eec
|
|
| BLAKE2b-256 |
62b5cf5a49a73eb7e476362a4d42425aab71b5422251c28e7590d888af40bbb0
|