New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

streamlit-state-model

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

streamlit-state-model

A package that provides a StateModel for Streamlit applications, allowing easy management of session state through class attributes.

  • 0.2.5
  • Source
  • PyPI
  • Socket score

Maintainers
1

Streamlit State Model

I love Streamlit, but working with st.session_state can be tedious. Coming from an OOP background, I cringe at managing each key in st.session_state individually, checking if it exists, and losing intellisense for names and types.

So I made streamlit-state-model which offers a base class StateModel that you can subclass to push your class' attribute I/O directly into st.session_state. This means you define what should exist in st.session_state once in the form of a normal python class, and then access those values anywhere in your Streamlit app with the expected statefulness of st.session_state.

Features

  • Persistence: Class instance storage is pushed to st.session_state so class attribute values are retained across page refreshes and switches (in multi-page apps).
  • Easy Setup: StateModel can be used with existing or new class definitions.
  • Default Values: Define the default state of st.session_state with normal class' default annotations and gain the ability to reset them all to defaults with a single function call.
  • Debugging: When debugging, you can now see the current values in st.session_state by inspecting your class' attribute values.
  • Intellisense Support: Retain normal docstrings and type intellisense that you normally lose when working with st.session_state.
  • Inline Integration: Declare your class instance inline with the rest of your code and eliminate spaghetti if checks around current state of st.session_state.
  • Docstring Access: Retrieve attribute docstrings via the docstrings dictionary within your app.

Getting Started

Install the package using pip:

pip install streamlit-state-model

Take your existing class and subclass StateModel:

import streamlit_state_model as ssm 

class Session(ssm.StateModel):
    favorite_color: str = "#252D3D"
    "The user's favorite color as a hex string."
    favorite_number: int = 0
    "The user's favorite number."

At the entry point of your app, initialize your class in "build" mode.

# streamlit_app.py
session = Session(mode="build")
st.write(session.favorite_number)  # outputs default value of 0
session.favorite_number = 1  # set to a new value 

Anywhere else in your app you can initialize in lazy (default) mode to access current values:

# pages/page_1.py
session = Session() # init in lazy mode
st.write(session.favorite_number) # outputs 1 as set in streamlit_app.py  
""

Example

Explore our demo Streamlit app in the /demo_app directory for an example of integrating StateModel into a multipage app on Streamlit Community Cloud. Check out: state-model-demo-app.

We're also working on generating API docs for StateModel since it already includes many helper functions such as:

  • dump(): Dump all class attribute values to a JSON string (often paired with st.json).
  • Widget interaction helpers: Utilize widgets with StateModel following Streamlit's recommended patterns. (See the Streamlit Documentation on Multipage Apps for details.)
  • Reset function: Reset all attribute values to their defaults.

Development

For details on contributing and the CI/CD process, please refer to the development documentation.

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc