/admin/profile is the per-principal page available to every authenticated user (owner, admin, member). Shows the caller's identity (username, role chip, email, id) plus a full API-key list/mint/revoke surface. Minting reveals the raw token exactly once in a yellow-bordered panel with a Copy button and an "I've saved it" acknowledgement gate before the Done button enables, matching the spec's one-shot secret-display pattern. Live mirrors the backend bound-key guard: picking an app from the binding dropdown drops any instance:* scopes from the selection and greys out their checkboxes with a tooltip, so submit never hits a 422 on that case. Also surfaces a one-shot info banner when /admin/users redirects a member here with ?denied=users. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
PiCloud Dashboard
SvelteKit SPA for the PiCloud control plane.
Stack
- SvelteKit 2 with
adapter-static(SPA fallback) - Svelte 5 (runes)
- TypeScript
- Vite
Scripts
npm install
npm run dev # vite dev server on :5173, proxies /api → PICLOUD_API
npm run build # static SPA bundle into ./build/
npm run check # svelte-check
npm run lint
npm run format
By default npm run dev proxies /api/* and /healthz to
http://127.0.0.1:18080. Override with PICLOUD_API=http://host:port npm run dev.
How it fits in
In production Caddy serves the contents of ./build/ as static files and
falls back to index.html for client-side routing. The dashboard only
talks to the control plane (/api/admin/* on the manager); data-plane
invocations go through /api/execute/* on the orchestrator and are not
issued from the dashboard directly during MVP.