- TypeScript 36.6%
- Vue 29.3%
- PHP 26.7%
- Shell 4.6%
- CSS 2.5%
- Other 0.2%
| .forgejo/workflows | ||
| .github | ||
| img | ||
| opsdash | ||
| tools | ||
| .gitignore | ||
| CHANGELOG.md | ||
| CI_ROADMAP.md | ||
| CONTRIBUTING.md | ||
| docker-compose.yml | ||
| docker-compose30.yml | ||
| docker-compose31.yml | ||
| docker-compose32.yml | ||
| docker-compose33.yml | ||
| Makefile | ||
| pack.whitelist | ||
| pack_opsdash.sh | ||
| README.md | ||
| SECURITY.md | ||
Opsdash - Operational Calendar Dashboard
CI runs in Forgejo Actions on the Forgejo-hosted repository.
Opsdash is an independent third-party app that turns Nextcloud Calendar data into a practical operations dashboard: what happened, what is on target, and where your time is drifting.
Opsdash is not affiliated with, endorsed by, sponsored by, or officially maintained by Nextcloud GmbH or the Nextcloud project.
🚀 Feature Rundown
- 📅 Dashboard – KPIs for week/month, busiest days, averages, weekend share, top categories, longest events, and multi-tab layouts.
- 🎯 Targets & pacing – per-calendar and per-category goals, pace hints, trend context, and forecast signals.
- ⏱️ Current period done vs planned – active week/month separates elapsed hours from future hours so “done” metrics stop at now and upcoming time stays clearly labeled.
- ⚖️ Balance – share cards, stacked bars, relations/ratios, heatmaps, lookback trends, and daypart toggles.
- 🧠 Notes – edit “This week/month”, view “Last week/month”, and optionally surface notes in cards.
- 🧩 Shared overlays – onboarding, profiles, and the in-app
What's newwindow now share one large overlay shell and interaction model. - ✨ Release notes in-app – new versions can auto-open a
What's newview with short highlights, preview images, and a clickable version history from the sidebar. - 🗓️ Activity & schedule – event and active-day KPIs plus “Days off” trend heatmaps.
- 🔐 Runs inside Nextcloud – same session, same permissions, CSRF-protected writes, no external API calls.
- 🗂️ Deck widgets – a management-focused
Deck cardswidget plus a compactDeck statswidget, both with per-widget board/stack/tag filters and range-aware Deck summaries. - 📨 Report tab (preview) – configure weekly/monthly digest preferences and reminder behavior.
- 📐 Widget sizing controls – per-widget width/height plus scale/dense options for layout tuning.
Screenshots
| Widgets (Light) | Widgets (Dark) |
|---|---|
![]() |
![]() |
| Onboarding (Light) | Onboarding (Dark) |
|---|---|
![]() |
![]() |
| What's New Overlay |
|---|
![]() |
| Calendar Table (Light) | Calendar Table (Dark) |
|---|---|
![]() |
![]() |
Compatibility
Opsdash supports Nextcloud installations, but it is an independent third-party app and not an official Nextcloud app.
| Branch | Nextcloud | App version |
|---|---|---|
master |
30-33 | 0.7.5 |
release/0.5.x |
30-33 | Store-ready line |
Install
Install from the Nextcloud App Store as a third-party app (when published) or place opsdash in custom_apps/ and enable it:
occ app:enable opsdash
Development
make start
cd opsdash
npm ci
composer install
npm run build
npm run test:unit
composer run test:unit
PLAYWRIGHT_BASE_URL=http://localhost:8093 npm run test:e2e
make startstarts the local Nextcloud 33 dev container onhttp://localhost:8093.make start33starts the same Nextcloud 33 stack explicitly.make start32starts the Nextcloud 32 container onhttp://localhost:8092.make start31starts the Nextcloud 31 container onhttp://localhost:8088.- The checked-out app is mounted into the dev container from
./opsdashby default. Override withAPP_SOURCE_DIR=/abs/path/to/opsdashif you need a different source path. make status/make logshelp confirm the stack is up before testing.
Quick smoke check:
make smoke
Packaging
make release VERSION=0.7.5
One-step release helper:
- bumps
appinfo/info.xml,package.json,package-lock.json,opsdash/VERSION, andSECURITY.md - runs the packaged app build
- creates
build/dist/opsdash-<version>.tar.gz
Manual packaging only:
make appstore VERSION=0.7.5
Produces build/dist/opsdash-<version>.tar.gz (unsigned).
Sign separately with:
make sign VERSION=0.7.5 SIGN_PRIVATE_KEY_FILE=/secure/path/privkey.pem SIGN_CERT_FILE=/secure/path/cert.crt SIGN_CONTAINER=nc33-dev
Upload the signed tarball with:
FORGEJO_TOKEN=<token> make upload VERSION=0.7.5 RELEASE_TAG=v0.7.5
Push to the Nextcloud App Store with:
APPSTORE_TOKEN=<token> SIGN_PRIVATE_KEY_FILE=/secure/path/privkey.pem DOWNLOAD_URL=https://public-host/opsdash-0.7.5.tar.gz make appstore-push VERSION=0.7.5
Long-form internal release and runbook documentation now lives in the separate opsdash-docs and opsdash-ops workspace repos. Keep this repo focused on the app, its generic release commands, and contributor-facing basics.
Contributing
- Keep PRs focused.
- Update docs and fixtures when payloads change.
- Run unit tests before opening a PR.







