pip install streamlit-permalink
The streamlit_permalink
(shorthand: stp
) namespace contains url-aware versions of almost all input widgets from Streamlit:
stp.checkbox, stp.radio, stp.selectbox, stp.multiselect, stp.slider, stp.select_slider, stp.text_input
stp.number_input, stp.text_area, stp.date_input, stp.time_input, stp.color_picker, stp.form_submit_button
In addition to standard input widgets, it also has an url-aware version of the streamlit-option-menu component: stp.option_menu
. For this to work, streamlit-option-menu
must be installed separately.
General usage of input widgets is described in Streamlit docs. Url-aware widgets additionally take one more keyword argument: url_key
. It is the name of the query parameter in the URL under which the widget’s state will be persisted:
import streamlit_permalink as stp
text = stp.text_input('Type some text', url_key='secret')
# If the user typed 'foobar' into the above text field, the
# URL would end with '?secret=foobar' at this point.
Once widget state is saved into the URL, it can be shared and whoever opens the URL will see the same widget state as the person that has shared it.
Widget state will be url-persisted only if url_key
is present, otherwise stp.<widget-name>
behaves exactly the same as st.<widget-name>
:
import streamlit_permalink as stp
text = stp.text_input('Type some text')
# URL query string will be empty at this point,
# no matter whether the above text field is empty or not
By default, the value of url_key
is also used as the key
parameter of the Streamlit widget:
import streamlit as st
import streamlit_permalink as stp
text = stp.text_input('Type some text', url_key='secret')
st.write(st.session_state.secret)
However, it is possible to provide different values of url_key
and key
:
import streamlit as st
import streamlit_permalink as stp
text = stp.text_input('Type some text', url_key='secret', key='different_name')
st.write(st.session_state.different_name)
To use URL-aware widgets inside Streamlit forms, you need to use stp.form
and stp.form_submit_button
, which are the URL-aware counterparts of st.form
and st.form_submit_button
:
import streamlit_permalink as stp
with stp.form('some-form'):
text = stp.text_input('Text field inside form', url_key='secret')
# At this point the URL query string is empty / unchanged, even
# if the user has edited the text field.
if stp.form_submit_button('Submit'):
# URL is updated only when users hit the submit button
st.write(text)
Or with alternative syntax:
import streamlit_permalink as stp
form = stp.form('some-form')
form.text_input('Text field inside form', url_key='secret')
# At this point the URL query string is empty / unchanged, even
# if the user has edited the text field.
if form.form_submit_button('Submit'):
# URL is updated only when users hit the submit button
st.write(text)
\