Skip to main content

Provides access to functionality common to creating a data dashboard.

Project description

Gov UK dashboards

This package contains functionality which is common to UK Government plotly dashboards.

Table of Contents

Background

This package is to enable quicker development of government data dashboards, such as the government colour schemes and plotly components.

Install

For installation using pip:

pip install gov-uk-dashboards

or for a specific version:

pip install gov-uk-dashboards~=6.7.0

For installation using conda, paste the following code into the environment configuration file:

 - pip:
     - gov-uk-dashboards~=6.7.0

Usage

Using Government dashboard template with dash:

import dash
from gov_uk_dashboards.template import read_template

app = dash.Dash(__name__, suppress_callback_exceptions=True)
app.index_string = read_template()

For colours:

from gov_uk_dashboards.colours import GovUKColours

GovUKColours.DLUHC_BLUE.value

For components:

from gov_uk_dashboards.components.plotly import banners

banners.message_banner('category','message')

For formatting:

from gov_uk_dashboards.formatting.human_readable import format_as_human_readable

format_as_human_readable(1200,prefix='£')

For figures:

from gov_uk_dashboards import figures

chart_data = figures.ChartData(
    dataframe,
    x_column = "Date",
    y_column = "Value",
    category_column = "Category"
)

line_chart = figures.line_chart(
    data = chart_data,
    title = "Chart title"
    line_style = {
        "Category 1": figures.format.LineFormat(
            color = "#000000",
            dash_pattern = figures.enums.DashPatterns.SOLID,
        ),
    }
)

Updating the CSS

We use SCSS to generate our CSS - NEVER directly alter the dashboard.css file in the assets folder. To update CSS:

  • Add your changes to dashboard.scss in the sccs folder
  • Run npm install if you haven't recently (/ever)
  • Run npm run sass to generate CSS from SCSS
  • Change package version in setup.py
  • Push your changes to a new branch
  • Try new CSS on dashboard repo using pip install git+https://github.com/communitiesuk/pkg_gov_uk_dashboards.git@

Updating govuk-frontend CSS

  • Update govuk-frontend version in package.json
  • Run npm run sass to generate CSS from SCSS
  • Follow steps above to test new CSS on dashboard repo

Updating the package

When making changes to the package, the following should be done:

  • Update version in setup.py accordingly
    • Style: Major.Minor.Patch, e.g. 1.2.3
    • Major - any breaking changes to previous functionality.
    • Minor - additional functionality that doesn't effect backward compatibility. When updated the patch version should be reset to zero. eg. 2.3.1 goes to 2.4.0 for minor update.
    • Patch - bug fixes that don't effect backward compatibility. For more information see here
  • After merging with main, go here to add a new version tag.
    • Click 'Draft a new release'
    • Under 'Choose a tag' dropdown, enter 'v<version number>'. Click 'Create new tag'
    • Give the tag a release title, this should be the same as the tag name.
    • Give a bullet point list of changes in the "Describe this release" section.
    • Make sure 'Target' is set to 'main'.
    • Click 'Publish release'.
    • The release will be uploaded to PyPI.org automatically.
  • Update the package references within projects where the package is used, by following the Installation section.

Trying out changes to the package from other repositories

When you want to make changes to the package to use in another repository, it can be useful to see what changes would look like before commiting to the package repo. You can do this by making changes directly to the package files in the conda environment of the repository you're working in.

  • Open the file you wish to change in the conda environment
  • Do this by clicking into functions from the package in your IDE or by finding the file you wish to change in your file system, e.g. .../anaconda3/envs/*repo*/lib/python3.9/site-packages/gov_uk_dashboards/components/...
  • Make the changes to the package file and you should see the changes in your localhost on refresh
  • If you want to undo your changes: pip install --upgrade --force-reinstall <package_name>~=<package_version>

When you're happy, you can make the changes on a branch in the package repo and install it locally to check it works as expected when imported before merging into main in the package repo:

  • You can update the environment.yml to point at your branch or run pip install with the url: git+https://github.com/communitiesuk/pkg_gov_uk_dashboards.git@<your-branch>

License

MIT Copyright (c) 2022 Crown Copyright (Department for Levelling Up, Housing and Communities)

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gov_uk_dashboards-31.15.0.tar.gz (4.4 MB view details)

Uploaded Source

Built Distribution

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

gov_uk_dashboards-31.15.0-py3-none-any.whl (4.5 MB view details)

Uploaded Python 3

File details

Details for the file gov_uk_dashboards-31.15.0.tar.gz.

File metadata

  • Download URL: gov_uk_dashboards-31.15.0.tar.gz
  • Upload date:
  • Size: 4.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for gov_uk_dashboards-31.15.0.tar.gz
Algorithm Hash digest
SHA256 0eac81f2fb9553759b29154cd28e5f8909c59ebc48f5eb7aa38126c54acb05a1
MD5 95136974915d855d039bc68b462a25a9
BLAKE2b-256 c4308e6be158086d990fa25d8b5a3f04bd63cc1b1bc28a63b1cda8a2e3318145

See more details on using hashes here.

File details

Details for the file gov_uk_dashboards-31.15.0-py3-none-any.whl.

File metadata

File hashes

Hashes for gov_uk_dashboards-31.15.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d6168b6b0ebadd2036292d05440ea0c97a72d38abe78afb7ccbd348516a961a5
MD5 a40d5eb78fc082c8f9c653e4e6542d7e
BLAKE2b-256 7c744e4f0df182401c6a9701a0110524b621f552d57dea970a27d9efe2a4f0b9

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