A Tethys App for no code/low code web application development app
Project description
TethysDash
This app was created using an experimental Tethys + React app scaffold. It uses React for the frontend of the app and Tethys as the backend. For more detailed information, check the official TethysDash documentation
Quick Installation
- If creating a new python environment, create and activate it
python3 -m venv test_env
source test_env/bin/activate
- Install TethysDash
pip install tethysdash
- Setup Tethys and TethysDash Databases and Services
tethysdash setup
- Start Tethys Portal
tethysdash start
Development Installation
You need to install both the Tethys dependencies and the node dependencies:
- If creating a new python environment, create and activate it
python3 -m venv test_env
source test_env/bin/activate
- Clone the Repo
git clone https://github.com/tethysplatform/tethysapp-tethys_dash
- Install the app in Tethys Platform
cd tethysapp-tethys_dash/
pip install -e .
- Setup Tethys and TethysDash Databases and Services
tethysdash setup
- Install Plugin Examples (not necessary but recommended)
cd ..
git clone https://github.com/FIRO-Tethys/tethysdash_examples
cd tethysdash_examples
pip install -e .
- Start Tethys Portal
tethysdash start
Frontend Development
The webpack dev server is configured to proxy the Tethys development server (see webpack.config.js). The app endpoint will be handled by the webpack development server and all other endpoints will be handled by the Tethys (Django) development server. As such, you will need to start both in separate terminals.
- Install the node and dependencies
cd tethysapp-tethys_dash/
npm install --dev
- Start Tethys development server
tethys manage start
- Start webpack development server (in separate terminal)
npm start
Frontend Build
Webpack is configured to bundle and build the React app into the tethysapp/<app_package>/public/frontend directory. Before building a Python distribution for release, you should build using this command:
npm run build
Note: The compiled frontend in
tethysapp/tethysdash/public/frontend/is not committed to the repository — CI builds it when publishing a release. When running the app from a clone, you must build it yourself first: either runnpm run buildbeforetethysdash start, or use the webpack dev server (npm start) which serves the bundle from memory. Without one of these, Django has no frontend bundle to serve.
Serving the built frontend in development
The production build emits content-hashed filenames (e.g. main.<hash>.js) and a manifest.json mapping logical names to the hashed files. Mode detection is automatic:
- Hit Django directly (e.g.
localhost:8000/apps/tethysdash/) → the page loads the hashed bundle named inmanifest.json, served straight from the app'spublic/frontend/directory. - Hit the webpack dev server (e.g.
localhost:8080) → the dev server proxies the page request to Django with anX-Webpack-Dev-Serverheader. Django detects it and renders the unhashedmain.jsURL, which the dev server serves from memory.
No environment variable or DEBUG toggle is required to switch between the two.
Frontend Test
Use the following commands to lint and test the React portion of the app.
npm run lint
npm run test
The linting capability is powered by eslint and a number of plugins for React. The testing capabilities include jest, jsdom, testing-framework, user-event, and a few other JavaScript testing utilties to make it easy to test the frontend of the React-Tethys app.
Backend Lint and Test
The Python backend is linted with ruff and tested with pytest:
ruff check .
python -m pytest --reuse-db
Continuous Integration and Releasing
CI runs in GitHub Actions (.github/workflows/):
- On every pull request to
main(ci.yml): the frontend (eslint, prettier, jest) and backend (ruff, pytest) suites must pass. - On a version tag (
release.yml): the suite re-runs, then the package is built and published to PyPI.
The package version is dynamic — it is derived from the git tag at build time by setuptools_scm, not stored in pyproject.toml. To cut a release, push a v-prefixed semantic-version tag from main:
git tag v0.19.17
git push origin v0.19.17
This triggers the release workflow, which publishes tethysdash 0.19.17 to PyPI (via PyPI Trusted Publishing) and creates a GitHub Release. Tags must use the v prefix for the workflow to fire.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tethysdash-0.19.19.tar.gz.
File metadata
- Download URL: tethysdash-0.19.19.tar.gz
- Upload date:
- Size: 58.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9870a20775c650a2e3de0e5c4220c0239ec14f414c1f59cb311107ceee2680bd
|
|
| MD5 |
21f5fb2196f38af807af092dacb7f0e5
|
|
| BLAKE2b-256 |
0c91c960d377bd6c604f16175baa4e4994f2fddb816d9861098930f793fe2808
|
Provenance
The following attestation bundles were made for tethysdash-0.19.19.tar.gz:
Publisher:
release.yml on tethysplatform/tethysapp-tethys_dash
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tethysdash-0.19.19.tar.gz -
Subject digest:
9870a20775c650a2e3de0e5c4220c0239ec14f414c1f59cb311107ceee2680bd - Sigstore transparency entry: 1945304673
- Sigstore integration time:
-
Permalink:
tethysplatform/tethysapp-tethys_dash@d85e3f3d9a093d9cd0f8333d4864b693874b2f41 -
Branch / Tag:
refs/tags/v0.19.19 - Owner: https://github.com/tethysplatform
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d85e3f3d9a093d9cd0f8333d4864b693874b2f41 -
Trigger Event:
push
-
Statement type:
File details
Details for the file tethysdash-0.19.19-py3-none-any.whl.
File metadata
- Download URL: tethysdash-0.19.19-py3-none-any.whl
- Upload date:
- Size: 10.7 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
95808f7138b441b434f856c9e27f58ab367b924d30df789c6ced9f42f209894b
|
|
| MD5 |
74f45aeadcbfba9be2459099f0b4419a
|
|
| BLAKE2b-256 |
a09f0f646ff03ac0cdb88b84b8042d33808b1fc4a274a7d32ae4af4f1fd03282
|
Provenance
The following attestation bundles were made for tethysdash-0.19.19-py3-none-any.whl:
Publisher:
release.yml on tethysplatform/tethysapp-tethys_dash
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tethysdash-0.19.19-py3-none-any.whl -
Subject digest:
95808f7138b441b434f856c9e27f58ab367b924d30df789c6ced9f42f209894b - Sigstore transparency entry: 1945304774
- Sigstore integration time:
-
Permalink:
tethysplatform/tethysapp-tethys_dash@d85e3f3d9a093d9cd0f8333d4864b693874b2f41 -
Branch / Tag:
refs/tags/v0.19.19 - Owner: https://github.com/tethysplatform
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d85e3f3d9a093d9cd0f8333d4864b693874b2f41 -
Trigger Event:
push
-
Statement type: