Skip to main content

A collection of Streamlit components that use or are inspired by the GOV.UK Design System

Project description

streamlit-gov-uk-components

A collection of Streamlit components that use or are inspired by the GOV.UK Design System

Installation

pip install streamlit-gov-uk-components

Available components

Usage

Checkbox (example)

Checkbox example
from streamlit_gov_uk_components import gov_uk_checkbox

selected = gov_uk_checkbox(
    label="Waste from animal carcasses",  # Label shown in browser
    id="waste-from-animal-carcasses",     # ID of checkbox in HTML
    key="waste-from-animal-carcasses",    # Streamlit component instance key
    default=True,                         # Initially selected?
)

Smaller checkbox (example)

Smaller checkbox example
from streamlit_gov_uk_components import gov_uk_checkbox_small

selected = gov_uk_checkbox_small(
    label="HM Revenue and Customs (HMRC)",  # Label shown in browser
    id="hmrc",                              # ID of checkbox in HTML
    key="hmrc",                             # Streamlit component instance key
    default=True,                           # Initially selected?
)

Checkbox list (example)

Smaller checkbox example
from streamlit_gov_uk_components import gov_uk_checkbox_list

selected = gov_uk_checkbox_list(
    # Tuple of (ID, label) pairs
    options=(
        ("waste-from-animal-carcasses", "Waste from animal carcasses"),
        ("waste-from-mines-or-quarries", "Waste from mines or quarries"),
        ("farm-or-agricultural-waste", "Farm or agricultural wastes"),
    ),
    key="waste",
    # Tuple of initially selected IDs
    default=("waste-from-animal-carcasses",),
)

Smaller checkbox list (example)

Smaller checkbox list example
from streamlit_gov_uk_components import gov_uk_checkbox_small_list

selected = gov_uk_checkbox_small_list(
    # Tuple of (ID, label) pairs
    options=(
        ("hm-revenue-and-customs", "HM Revenue and Customs (HMRC)"),
        ("employment-tribunal", "Employment Tribunal"),
        ("ministry-of-defence", "Ministry of Defence"),
        ("department-for-transport", "Department for Transport"),
    ),
    key="waste",
    # Tuple of initially selected IDs
    default=("hm-revenue-and-customs",),
)

Radio list (example)

Radio list example
from streamlit_gov_uk_components import gov_uk_radio_list

selected = gov_uk_radio_list(
    # Tuple of (ID, label) pairs
    options=(
        ("england", "England"),
        ("scotland", "Scotland"),
        ("wales", "Wales"),
        ("northern-ireland", "Northern Ireland"),
    ),
    id="where-do-you-live",   # Base of HTML IDs for radios
    key="where-do-you-live",  # Streamlit component instance key
    default="england",        # Initially selected ID
)

Smaller radio list (example)

Radio list example
from streamlit_gov_uk_components import gov_uk_radio_small_list

selected = gov_uk_radio_small_list(
    # Tuple of (ID, label) pairs
    options=(
        ("monthly", "Monthly"),
        ("yearly", "Yearly"),
    ),
    id="filter",        # Base of HTML IDs for radios
    key="filter",       # Streamlit component instance key
    default="monthly",  # Initially selected ID
)

Local development

The examples serve as reasonable mini Streamlit applications that allow development of the components themselves. Two terminal session are typically needed.

One to run Streamlit itself...

pip install streamlit
STREAMLIT_GOV_UK_COMPONENTS_DEV=True streamlit run example_checkbox.py

... and one to run a development server that automatically recompiles and serves the HTML and Javascript of the front end of each component.

cd streamlit_gov_uk_components/frontend_checkbox
yarn install
./fix.sh
yarn run start

Releasing to PyPI

  1. Ensure that each frontend component has been built. Each frontend component must be built, not just those that have changed, since the production builds of each are not checked into the repository.

    cd streamlit_gov_uk_components/frontend_checkbox
    yarn install
    ./fix.sh
    yarn run build
    
  2. Ensure that there is a line in MANIFEST.in for each frontend component.

  3. Bump the version inside setup.py

  4. Commit with a Conventional Commit message with the bumped version, tag the commit with the bumped version, and push to GitHub.

    git add setup.py
    git commit -m "build(release): v0.0.4"
    git tag v0.0.4
    git push origin main --tags
    
  5. Build and release to PyPI

    pip install build twine
    rm -r -f build dist && python -m build && python -m twine upload dist/*
    

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

streamlit-gov-uk-components-0.0.14.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

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

streamlit_gov_uk_components-0.0.14-py3-none-any.whl (1.1 MB view details)

Uploaded Python 3

File details

Details for the file streamlit-gov-uk-components-0.0.14.tar.gz.

File metadata

File hashes

Hashes for streamlit-gov-uk-components-0.0.14.tar.gz
Algorithm Hash digest
SHA256 50778e462f677d3013209b26979fb28debe99cd541d4d8cf2db9f068d12025a8
MD5 f2b8261a42d3ab55bc2c1c4c3f5befa6
BLAKE2b-256 861a382e48d9e3e611e71c3f97360d1b6db3f1d5fcde6162e82bbec8df84cc23

See more details on using hashes here.

File details

Details for the file streamlit_gov_uk_components-0.0.14-py3-none-any.whl.

File metadata

File hashes

Hashes for streamlit_gov_uk_components-0.0.14-py3-none-any.whl
Algorithm Hash digest
SHA256 854d65016c9d4721377908fff7faa66932b074d89b744899e99f19d14d3283fa
MD5 b1e6569076b87652ec57dd63dbacc0f1
BLAKE2b-256 9d15c5c0f0b7a866469417347330f627f5722da92958175d321b7c8f09f913f6

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