• Stars
    star
    134
  • Rank 270,967 (Top 6 %)
  • Language
    Python
  • License
    Apache License 2.0
  • Created over 3 years ago
  • Updated 4 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Datasette plugin providing data dashboards from metadata

datasette-dashboards

Datasette plugin providing data dashboards from metadata

PyPI CI/CD Coverage Status License

Try out a live demo at https://datasette-dashboards-demo.vercel.app

WARNING: this plugin is still experimental and not ready for production. Some breaking changes might happen between releases before reaching a stable version. Use it at your own risks!

Datasette Dashboards Demo

Installation

Install this plugin in the same environment as Datasette:

$ datasette install datasette-dashboards

Usage

Define dashboards within metadata.yml / metadata.json:

plugins:
  datasette-dashboards:
    my-dashboard:
      title: My Dashboard
      description: Showing some nice metrics
      layout:
        - [analysis-note, events-count]
        - [analysis-note, events-source]
      filters:
        date_start:
          name: Date Start
          type: date
          default: "2021-01-01"
        date_end:
          name: Date End
          type: date
        category:
          name: My Category
          type: select
          options: [Option 1, Option 2, Option 3]
        dynamic_category:
          name: My Dynamic Category
          type: select
          db: jobs
          query: SELECT region FROM jobs ORDER BY region ASC
      charts:
        analysis-note:
          library: markdown
          display: |-
            # Analysis notes
            > A quick rundown of events statistics and KPIs

        events-count:
          title: Total number of events
          db: jobs
          query: SELECT count(*) as count FROM events
          library: metric
          display:
            field: count
            prefix:
            suffix:

        events-source:
          title: Number of events by source
          db: jobs
          query: SELECT source, count(*) as count FROM events WHERE TRUE [[ AND date >= date(:date_start) ]] [[ AND date <= date(:date_end) ]] GROUP BY source ORDER BY count DESC
          library: vega-lite
          display:
            mark: { type: arc, tooltip: true }
            encoding:
              color: { field: source, type: nominal }
              theta: { field: count, type: quantitative }

A new menu entry is now available, pointing at /-/dashboards to access all defined dashboards.

Properties

Dashboard properties:

Property Type Description
title string Dashboard title
description string Dashboard description
settings object Dashboard settings
layout array Dashboard layout
filters object Dashboard filters

Dashboard settings:

Property Type Description
allow_fullscreen bool Allow dashboard to be toggled in fullscreen (default false)
autorefresh number Auto-refresh timeout in minutes

Dashboard filters:

Property Type Description
name string Filter display name
type string Filter type (text, date, number, select)
default string, number (optional) Filter default value
min number (optional) Filter minimum value
max number (optional) Filter maximum value
step number (optional) Filter stepping value
options list (optional) Select filter options list
db string (optional) Dynamic select filter database
query string (optional) Dynamic select filter query

Common chart properties for all chart types:

Property Type Description
title string Chart title
db string Database name against which to run the query
query string SQL query to run and extract data from
library string One of supported libraries: vega, vega-lite, markdown, metric, table, map
display object Chart display specification (depend on the used library)

To define SQL queries using dashboard filters:

SELECT * FROM mytable [[ WHERE col >= :my_filter ]]
SELECT * FROM mytable WHERE TRUE [[ AND col1 = :my_filter_1 ]] [[ AND col2 = :my_filter_2 ]]

Important notes:

  • When a select filter has more than 100 options, the dropdown list will be automatically converted to a text filter with autocompletion

Vega properties

Available configuration for vega charts:

Property Type Description
library string Must be set to vega
display object Vega specification object

Notes about the display property:

  • Requires a valid Vega specification object
  • Some fields are pre-defined: $schema, description, autosize, data, signals
  • All fields are passed along as-is (overriding pre-defined fields if any)
  • Only mark and encoding fields are required as the bare-minimum

Vega-Lite properties

Available configuration for vega-lite charts:

Property Type Description
library string Must be set to vega-lite
display object Vega specification object

Notes about the display property:

  • Requires a valid Vega-Lite specification object
  • Some fields are pre-defined: $schema, description, width, view, config, data
  • All fields are passed along as-is (overriding pre-defined fields if any)
  • Only mark and encoding fields are required as the bare-minimum

Markdown properties

Available configuration for markdown chart:

Property Type Description
library string Must be set to markdown
display string Multi-line string containing the Markdown content

Note :

  • Some common properties do not apply and can be omitted: title, db, query
  • Markdown rendering is done by datasette-render-markdown
  • To configure Markdown rendering, extensions can be enabled in metadata

Metric properties

Available configuration for metric chart:

Property Type Description
library string Must be set to metric
display.field string Numerical field to be displayed as metric
display.prefix string Prefix to be displayed before metric
display.suffix string Prefix to be displayed after metric

Note:

  • The display.field must reference a single-numerical value from the SQL query (e.g. numerical number field in SELECT count(*) as number FROM events)

Table properties

There is no required configured in display, so you can either ignored or leave it empty for table charts.

Some advice for a nice table chart:

  • Set proper column names in the SELECT clause
  • Limit the number of columns in the SELECT clause
  • Limit the number of rows with the LIMIT clause
  • Order the rows explicitely with the ORDER BY clause
  • Use SQLite string concatenation operator (||) to format column data (for instance to include HTML markup!)

Map properties

Available configuration for map chart:

Property Type Description
library string Must be set to map
display.latitude_column string Name of the latitude column (default: latitude)
display.longitude_column string Name of the latitude column (default: longitude)
display.show_latlng_popup boolean Whether or not to display latitude and longitude values in popup (default: false)

Warning: do not try to load more than a thousand rows for a map at the risk of slugginess and being unreadable. Make sensible use of the LIMIT clause to reduce the number of items to display on the map.

Dashboard layout

The default dashboard layout will present two charts per row (one per row on mobile). To make use of custom dashboard layout using CSS Grid Layout, define the layout array property as a grid / matrix:

  • Each entry represents a row of charts
  • Each column is referring a chart by its property name
  • An empty slot in the grid can be specified using the . (full stop) placeholder

WARNINGS:

  • All rows must specify the same number of columns
  • All charts must be placed somewhere on the custom layout

Here is a simple 2x3 grid example with 4 different charts:

layout:
  - [chart1, chart2, chart3]
  - [chart1, chart4, chart4]

Here is a more subtle example involving an empty spot at the end of the second row:

layout:
  - [chart1, chart2, chart3]
  - [chart1, chart4, .]

Embedding dashboards and charts

Dashboards can be embedded within an HTML page using an iframe element:

<iframe
  src="/-/dashboards/my-dashboard/embed?start_date=2023-01-01&end_date=2023-12-31"
  frameborder="0"
  width="100%"
  height="600"
  allowtransparency
>
</iframe>

Same goes for charts:

<iframe
  src="/-/dashboards/my-dashboard/my-chart/embed?start_date=2023-01-01&end_date=2023-12-31"
  frameborder="0"
  width="100%"
  height="600"
  allowtransparency
>
</iframe>

Development

To set up this plugin locally, first checkout the code. Then create a new virtual environment and the required dependencies:

poetry install
poetry shell

To run the QA suite:

black --check datasette_dashboards tests
flake8 datasette_dashboards tests
mypy datasette_dashboards tests
pytest -v --cov=datasette_dashboards --cov=tests --cov-branch --cov-report=term-missing tests

Demo

With the developmnent environment setup, you can run the demo locally:

datasette \
  --metadata demo/metadata.yml \
  --template-dir demo/templates \
  demo/jobs.db

License

Licensed under Apache License, Version 2.0

Copyright (c) 2021 - present Romain Clement

More Repositories

1

mailer

Dead-simple mailer micro-service for static websites
Python
58
star
2

sqlite-ml

An SQLite extension for machine learning
Python
46
star
3

business-card-generator

Generate digital QR-code business cards
Python
35
star
4

dokku-matomo

Deploy Matomo on Dokku
24
star
5

yodel

The Swiss Army knife for your sound
Python
18
star
6

datasette-ml

A Datasette plugin providing an MLOps platform to train, eval and predict machine learning models
Python
15
star
7

meeblip-controller

MIDI controller for the Meeblip Anode synthesizer
C++
11
star
8

dokku-logstash

Deploy Logstash on Dokku
7
star
9

sqlite-utils-ml

An sqlite-utils plugin to perform machine-learning workloads
Python
7
star
10

dokku-kibana

Deploy Kibana (with LogTrail) on Dokku
5
star
11

flask-pretty

Flask extension to output prettified HTML pages
Python
5
star
12

openfaas-templates

Custom templates for OpenFaaS
Dockerfile
4
star
13

pyconfr2023-djangoadmin

PyConFR 2023 - Django Admin comme framework pour dรฉvelopper des outils internes
Python
3
star
14

romain-clement.net

Freelance Software Engineer & Trainer
HTML
3
star
15

flask-language

Flask extension handling client-side language cookie
Python
2
star
16

grape

GRAPE is Romain's Audio Plug-in Extension classes for the JUCE framework
C++
2
star
17

presidentielle-2022-nlp

Analyse des programmes des candidats avec des outils NLP
Jupyter Notebook
2
star
18

docker-swarm-deploy

Automated Docker Swarm cluster setup/provisioning/deployment using Ansible
1
star
19

carnet

Static website generator framework
1
star
20

cozy-konnector-thomann

Cozy konnector to fetch bills from Thomann
JavaScript
1
star
21

password-police

Password policies list for online services ๐Ÿ”๐Ÿšจ
JavaScript
1
star
22

launchtime

Standalone step-sequencing app for the Novation Launchpad
1
star
23

nuxt-chiffre

Chiffre Analytics for Nuxt.js
TypeScript
1
star
24

feedit

Generate static RSS/Atom feeds for websites without it
Python
1
star