No description
  • TypeScript 36.6%
  • Vue 29.3%
  • PHP 26.7%
  • Shell 4.6%
  • CSS 2.5%
  • Other 0.2%
Find a file
blade34242 654740409e
Some checks failed
Nextcloud Server Tests / version-consistency (push) Successful in 26s
Nextcloud Server Tests / matrix-config (push) Has been cancelled
ci: install python3 in forgejo release workflow
2026-04-23 16:35:59 +07:00
.forgejo/workflows ci: install python3 in forgejo release workflow 2026-04-23 16:35:59 +07:00
.github feat: add nextcloud 33 support 2026-04-23 16:05:44 +07:00
img Refresh marketplace media set and demo video 2026-03-07 14:39:20 +07:00
opsdash feat: add nextcloud 33 support 2026-04-23 16:05:44 +07:00
tools feat: add nextcloud 33 support 2026-04-23 16:05:44 +07:00
.gitignore Split internal docs from app repo 2026-04-17 12:39:28 +07:00
CHANGELOG.md chore: remove github leftovers 2026-04-20 14:07:53 +07:00
CI_ROADMAP.md ci: temporarily disable forgejo playwright smoke 2026-04-23 16:00:20 +07:00
CONTRIBUTING.md feat: add nextcloud 33 support 2026-04-23 16:05:44 +07:00
docker-compose.yml feat: add nextcloud 33 support 2026-04-23 16:05:44 +07:00
docker-compose30.yml Split internal docs from app repo 2026-04-17 12:39:28 +07:00
docker-compose31.yml Split internal docs from app repo 2026-04-17 12:39:28 +07:00
docker-compose32.yml Split internal docs from app repo 2026-04-17 12:39:28 +07:00
docker-compose33.yml feat: add nextcloud 33 support 2026-04-23 16:05:44 +07:00
Makefile feat: add nextcloud 33 support 2026-04-23 16:05:44 +07:00
pack.whitelist fix: stabilize calendar selection and capture known issues 2025-10-28 15:57:06 +07:00
pack_opsdash.sh fix: stabilize calendar selection and capture known issues 2025-10-28 15:57:06 +07:00
README.md feat: add nextcloud 33 support 2026-04-23 16:05:44 +07:00
SECURITY.md feat: add nextcloud 33 support 2026-04-23 16:05:44 +07:00

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 new window now share one large overlay shell and interaction model.
  • Release notes in-app new versions can auto-open a What's new view 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 cards widget plus a compact Deck stats widget, 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

Overview (Light)

Widgets (Light) Widgets (Dark)
Widgets Light Widgets Dark
Onboarding (Light) Onboarding (Dark)
Onboarding Light Onboarding Dark
What's New Overlay
What's New Overlay
Calendar Table (Light) Calendar Table (Dark)
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 start starts the local Nextcloud 33 dev container on http://localhost:8093.
  • make start33 starts the same Nextcloud 33 stack explicitly.
  • make start32 starts the Nextcloud 32 container on http://localhost:8092.
  • make start31 starts the Nextcloud 31 container on http://localhost:8088.
  • The checked-out app is mounted into the dev container from ./opsdash by default. Override with APP_SOURCE_DIR=/abs/path/to/opsdash if you need a different source path.
  • make status / make logs help 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, and SECURITY.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

  1. Keep PRs focused.
  2. Update docs and fixtures when payloads change.
  3. Run unit tests before opening a PR.