The frontend for the Open Electricity platform — an open-source project exploring Australia's electricity system through data visualisation and analysis.
For the Data Tracker (a.k.a. OpenNEM), see opennem/opennem-fe.
- SvelteKit with Svelte 5 (runes)
- Tailwind CSS 4 with shadcn-svelte components
- LayerCake + D3.js for data visualisation
- Sanity CMS for editorial content
- Cloudflare Pages for deployment
- Clerk for authentication
bun install
cp .env.example .env # fill in your own keys — see "Environment variables" below
bun run devThe dev server starts at http://localhost:5173.
Open Electricity is an open-source project, and contributors are expected to bring their own credentials for the external services they want to exercise locally (Open Electricity API, Sanity, Clerk, Mailchimp, etc.). The default workflow uses a plain .env file so anyone can clone the repo and run it without further tooling:
- Copy
.env.exampleto.env. - Fill in keys for the services you need. Most
PUBLIC_*URLs in the example are sensible defaults; the API keys are yours to provide. - Run
bun run dev.
.env is gitignored. Only .env.example is checked in — keep it up to date when adding new variables.
Core maintainers use Doppler to share secrets across machines. If you have access to the Doppler project:
brew install dopplerhq/cli/doppler
doppler login
doppler setup # link this directory to the openelectricity project + dev config
bun run doppler-dev # runs vite dev with secrets injected from Dopplerdoppler-dev, doppler-build, and doppler-preview are maintainer conveniences that wrap their plain counterparts in doppler run --. The plain scripts (with a local .env) remain the canonical path for contributors and forks — no Doppler account required.
| Command | Description |
|---|---|
bun run dev |
Start dev server using .env (default) |
bun run doppler-dev |
Start dev server with secrets injected from Doppler (maintainers) |
bun run build |
Production build |
bun run doppler-build |
Production build with secrets injected from Doppler (maintainers) |
bun run preview |
Preview production build |
bun run doppler-preview |
Preview production build with secrets injected from Doppler (maintainers) |
bun run check |
Type check with svelte-check |
bun run lint |
Lint with Prettier + ESLint |
bun run format |
Auto-format with Prettier |
bun run test |
Run unit tests (Vitest) |
bun run test:e2e |
Run end-to-end tests (Playwright) |
src/
├── lib/
│ ├── components/ # UI and chart components
│ │ ├── charts/ # LayerCake-based visualisations
│ │ ├── form-elements/ # Reusable form controls
│ │ ├── info-graphics/ # Interactive homepage visuals
│ │ └── ui/ # shadcn-svelte components
│ ├── fuel-tech-groups/ # Energy source categorisation
│ ├── models/ # Static scenario data
│ ├── opennem/ # OpenNEM API integration
│ ├── stores/ # Global state (Svelte stores)
│ ├── theme/ # Colour palettes and theming
│ ├── types/ # TypeScript definitions (JSDoc)
│ └── utils/ # Data processing utilities
├── routes/
│ ├── (main)/ # Primary app routes
│ │ ├── about/ # Team and project info
│ │ ├── analysis/ # Editorial articles (Sanity CMS)
│ │ ├── facilities/ # Power station explorer
│ │ ├── records/ # Historical electricity records
│ │ ├── scenarios/ # Future energy modelling
│ │ └── studio/ # Data exploration tools
│ │ ├── strata/ # Published chart detail pages
│ │ └── strata-community/ # Community chart gallery
│ ├── (micro)/ # Embeddable widgets and micro-apps
│ │ ├── record/ # Minimal record displays
│ │ ├── strata-embed/ # Strata chart iframe embeds
│ │ ├── stratify/ # Stratify chart builder (closed beta)
│ │ └── widget/ # Grid status widget
│ └── api/ # Server-side data endpoints
└── ...
| Branch | Environment |
|---|---|
main |
Production — openelectricity.org.au |
dev |
Staging — dev.openelectricity.org.au |
Production deployments are triggered via a Cloudflare deploy hook on version tags:
npm version patch # or minor / major
git push # push.followTags pushes the tag automaticallyGitHub Actions picks up the v* tag and triggers the Cloudflare build.
See LICENSE for details.