Skip to main content

A package for converting streamlit apps to stlite apps to remove the need for hosting

Project description

stlitepack

stlitepack is a Python utility that helps you turn your existing Streamlit apps into stlite apps — lightweight, browser-only Streamlit apps that run entirely in the client without a server.

With stlitepack, you can:

  • 📦 Pack your Streamlit app into a stlite-ready format
  • 🗂️ Include additional resources like config.toml
  • 🚀 Generate GitHub Actions workflows to (almost) auto-deploy your app to GitHub Pages

📦 Installation

pip install stlitepack

🚀 Usage

from stlitepack import pack

# Pack your Streamlit app (e.g., "app.py") into a stlite bundle
pack("app.py")

This will create an index.html file with all of the required stlite additions, which you can then serve as a static file using a hosting platform such as github pages.

⚠️ Heads Up!

Opening index.html directly in your browser may show navigation or media errors if you use session state in multi-page apps or if you are loading in external file. This is normal — it only happens when using file:// URLs.

Fix: Serve the app over HTTP (e.g., python -m http.server) or deploy to GitHub Pages.

Everything will work correctly once served via a web server!

For local testing prior to deployment, try running

python -m http.server 8000

from the root of your local repository.

Then open http://localhost:8000/index.html (or change the path to reflect the final location of your created index.html file - e.g. http://localhost:8000/docs/index.html)

Documentation

Check out the quickstart guide at sammirosser.com/stlitepack/stlitepack_docs/stlitepack_quickstart.

You can also find the full reference for each function at sammirosser.com/stlitepack/reference/.

🔮 Roadmap

  • ✅ v0.1: Single-page app packing
  • ✅ v0.2: Helper functions for GitHub Pages auto-deploy (via GitHub Actions workflow generation)
  • ✅ v0.3: Multi-page app support (for pages/ subfolder method) and simple additional file inclusion
  • v0.4: Better support for resource bundling (images, CSVs, assets, config files etc.) of local or web-based files
  • v0.5: Better multi-page app support (for st.navigation() method)
  • v0.6: Auto-handling of stlite-specific required changes (e.g. asyncio vs sleep)
  • v0.7: Add support for generating the required package.json for desktop app bundling
  • v0.8: Add helpers for generating files for additional deployment options e.g. Docker, Caddy, Nginx, Apache
  • v0.9: TOML or YAML file support as optional alternative to the packing function
  • v1.0: Full toolkit for packaging, deploying, and managing stlite apps

Examples of Use

eFIT-tool

All credits go to Peter Saiu and collaborators for the original repository!

Non-elective Flow Simulation

All credits go to Helena Robinson and collaborators for the original repository!

🤝 Contributing

Contributions, feature requests, and feedback are welcome!

Open an issue or submit a pull request to help improve stlitepack.

📜 License

Apache 2.0 License. See LICENSE for details.

Acknowledgements

Generative AI Use Disclosure

This package was developed with the assistance of ChatGPT (OpenAI’s GPT-5 model) as a coding and documentation partner. All code and design decisions were reviewed and finalized by a human, and ChatGPT’s output was used as a foundation rather than a final product.

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

stlitepack-0.4.0.tar.gz (15.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

stlitepack-0.4.0-py3-none-any.whl (17.0 kB view details)

Uploaded Python 3

File details

Details for the file stlitepack-0.4.0.tar.gz.

File metadata

  • Download URL: stlitepack-0.4.0.tar.gz
  • Upload date:
  • Size: 15.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.28.1

File hashes

Hashes for stlitepack-0.4.0.tar.gz
Algorithm Hash digest
SHA256 518beeec5e7e979d4ddbcf022a10af1bb9d3cb759ef6d5989d7917dace0df33d
MD5 e596c7d9745f298f4e6f918c5d63346d
BLAKE2b-256 a7693edadb6b4a14e0c90dfcf5a6e35eec671112ea3e22dbec475591d50a5f7d

See more details on using hashes here.

File details

Details for the file stlitepack-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: stlitepack-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 17.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.28.1

File hashes

Hashes for stlitepack-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 42943e18fcf6ae0db417fb4fb0408b99683c1e60369395015be4a59bdc831798
MD5 9fe300dcd4089d1e340b298809fce8e0
BLAKE2b-256 15503727b18822376c9718189e7172b4894d2d16ffe4c4cd314039829309ab28

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page