Skip to main content

Custom Dashboards for Beancount in Fava

Project description

Fava Dashboards

Continuous Integration PyPI

fava-dashboards allows creating custom dashboards in Fava.

Example dashboards with random data: Overview Assets Income and Expenses Sankey

More screenshots

Installation

pip install "fava-dashboards>=2.0.0b6"

Enable this plugin in Fava by adding the following lines to your ledger:

2010-01-01 custom "fava-extension" "fava_dashboards"

Configuration

The plugin looks by default for a dashboards.tsx file (or .ts, .jsx, .js) in the directory of the Beancount ledger (e.g. if you run fava personal.beancount, the dashboards.tsx file should be in the same directory as personal.beancount). The location of the dashboards.tsx configuration file can be customized:

2010-01-01 custom "fava-extension" "fava_dashboards" "{
    'config': '/path/to/dashboards.tsx'
}"

To get TypeScript type support, download fava-dashboards.d.ts and place it next to dashboards.tsx. Please take a look at the example dashboards configuration dashboards.tsx, which uses most of the functionality described below.

To convert a legacy dashboards.yaml file from version 1 to the new dashboards.tsx format, you can run make deps && uv run scripts/convert_dashboards_yaml_to_tsx.py path/to/dashboards.yaml --output path/to/dashboards.tsx. This script covers most common cases, and does not perform TypeScript type inference.

The configuration file can contain multiple dashboards, and a dashboard contains one or more panels. A panel has a relative width (e.g. 50% for 2 columns, or 33.3% for 3 column layouts) and a absolute height.

Panel Properties

  • title: title of the panel. Default: unset
  • width: width of the panel. Default: 100%
  • height: height of the panel. Default: 400px
  • link: optional link target of the panel header.
  • kind: panel kind. Must be one of html, echarts, d3_sankey, table or react.
  • spec: a JavaScript function which generates a valid spec depending on the panel kind.

The following variables and functions are available:

  • panel: the current panel definition
  • ledger.dateFirst: start date of the current date filter, or first transaction date of the ledger
  • ledger.dateLast: end date of the current date filter, or last transaction date of the ledger
  • ledger.filterFirst: start date of the current date filter, or null if no date filter is set
  • ledger.filterLast: end date of the current date filter, or null if no date filter is set
  • ledger.operatingCurrencies: configured operating currencies of the ledger
  • ledger.ccy: shortcut for the first configured operating currency of the ledger
  • ledger.accounts: declared accounts of the ledger
  • ledger.commodities: declared commodities of the ledger
  • ledger.query(bql): executes the specified BQL query
  • ledger.urlFor(url): add current Fava filter parameters to url

HTML panel

The spec code of HTML panels must return valid HTML. The HTML code will be rendered in the panel.

ECharts panel

The spec code of Apache ECharts panels must return valid Apache ECharts chart options. Please take a look at the ECharts examples to get familiar with the available chart types and options.

d3-sankey panel

The spec code of d3-sankey panels must return valid d3-sankey chart options. Please take a look at the example dashboard configuration dashboards.tsx.

Table panel

The spec code of table panels must return valid MUI X Data Grid props.

React panel

The spec code of React panels must return a valid JSX element. Please note that the code must not return a Promise (i.e. async/await is not supported).

View Example Ledger

cd example; fava example.beancount

Contributing

This plugin consists of a Python backend and a TypeScript frontend.

Install uv and Node.js 22, run make deps to install the dependencies, and make dev to run the Fava dev server with auto-rebuild.

Before submitting a PR, please run make build to build the frontend in production mode, and add the compiled frontend to the PR.

Articles

Related Projects

Acknowledgements

Thanks to Martin Blais and all contributors of Beancount, Jakob Schnitzer, Dominik Aumayr and all contributors of Fava, and to all contributors of Apache ECharts, D3.js and d3-sankey.

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

fava_dashboards-2.0.0b8.tar.gz (5.0 MB view details)

Uploaded Source

Built Distribution

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

fava_dashboards-2.0.0b8-py3-none-any.whl (1.6 MB view details)

Uploaded Python 3

File details

Details for the file fava_dashboards-2.0.0b8.tar.gz.

File metadata

  • Download URL: fava_dashboards-2.0.0b8.tar.gz
  • Upload date:
  • Size: 5.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for fava_dashboards-2.0.0b8.tar.gz
Algorithm Hash digest
SHA256 3fffd72cbf5e1bd7b6a69612cf40f72a36cbdeea9dc70aa4573b4825ba9189c8
MD5 79bda826cf41e8da48511b326a44ff63
BLAKE2b-256 b95761a5894b67a7d10202383f31755fc0119378622466d196a3018980418595

See more details on using hashes here.

Provenance

The following attestation bundles were made for fava_dashboards-2.0.0b8.tar.gz:

Publisher: release.yml on andreasgerstmayr/fava-dashboards

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file fava_dashboards-2.0.0b8-py3-none-any.whl.

File metadata

File hashes

Hashes for fava_dashboards-2.0.0b8-py3-none-any.whl
Algorithm Hash digest
SHA256 b2b6bad8361d9e5fd9b5b52a72b2a510e4425ef597ec80e34f2887ba97733a8c
MD5 a263a9b9ac7e53b4bfce5e0a9e234cbe
BLAKE2b-256 307510d5d9358f8087586caedb6fe12a7df0cc5700322c65543c845c63a42490

See more details on using hashes here.

Provenance

The following attestation bundles were made for fava_dashboards-2.0.0b8-py3-none-any.whl:

Publisher: release.yml on andreasgerstmayr/fava-dashboards

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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