@hiai-gg/hiai-opencode 0.2.1 → 0.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env.example +4 -0
- package/AGENTS.md +34 -38
- package/ARCHITECTURE.md +4 -3
- package/LICENSE.md +14 -0
- package/README.md +52 -21
- package/config/hiai-opencode.schema.json +11 -13
- package/dist/agents/{bob.d.ts → bob/claude.d.ts} +6 -2
- package/dist/agents/bob/core.d.ts +6 -0
- package/dist/agents/bob/gpt.d.ts +11 -0
- package/dist/agents/bob/index.d.ts +3 -0
- package/dist/agents/coder/core.d.ts +4 -0
- package/dist/agents/coder/gpt.d.ts +1 -4
- package/dist/agents/coder/index.d.ts +1 -0
- package/dist/agents/manager/agent.d.ts +1 -1
- package/dist/agents/manager/default-prompt-sections.d.ts +3 -3
- package/dist/agents/manager/guard-integration.d.ts +1 -0
- package/dist/agents/prompt-library/index.d.ts +0 -1
- package/dist/agents/prompt-library/shared-execution.d.ts +9 -0
- package/dist/agents/strategist/behavioral-summary.d.ts +1 -1
- package/dist/agents/strategist/identity-constraints.d.ts +1 -1
- package/dist/agents/strategist/plan-generation.d.ts +1 -1
- package/dist/agents/types.d.ts +2 -1
- package/dist/config/defaults.d.ts +1 -0
- package/dist/config/platform-schema.d.ts +26 -26
- package/dist/config/schema/agent-names.d.ts +6 -6
- package/dist/config/schema/agent-overrides.d.ts +0 -128
- package/dist/config/schema/hiai-opencode-config.d.ts +0 -128
- package/dist/config/types.d.ts +2 -2
- package/dist/features/background-agent/manager-notifier.d.ts +46 -0
- package/dist/features/background-agent/manager-types.d.ts +40 -0
- package/dist/features/background-agent/manager.d.ts +3 -19
- package/dist/features/background-agent/polling-manager.d.ts +51 -0
- package/dist/features/boulder-state/storage.d.ts +1 -0
- package/dist/features/builtin-commands/templates/loop.d.ts +2 -0
- package/dist/features/builtin-commands/templates/start-work.d.ts +1 -1
- package/dist/features/builtin-skills/skills/interview-me.d.ts +2 -0
- package/dist/features/builtin-skills/skills/planning-and-task-breakdown.d.ts +2 -0
- package/dist/hooks/reasoning-content-cache/hook.d.ts +11 -0
- package/dist/hooks/reasoning-content-cache/index.d.ts +1 -0
- package/dist/hooks/session-recovery/checkpoint.d.ts +48 -0
- package/dist/hooks/session-recovery/enhanced-hook.d.ts +30 -0
- package/dist/hooks/session-recovery/state-backup.d.ts +76 -0
- package/dist/hooks/shared/compaction-in-progress.d.ts +4 -0
- package/dist/hooks/start-work/git-operations.d.ts +47 -0
- package/dist/hooks/token-budget.d.ts +30 -0
- package/dist/index.js +1185 -1078
- package/dist/mcp/rate-limiter.d.ts +68 -0
- package/dist/plugin/chat-message.d.ts +8 -0
- package/dist/plugin/command-execute-before.d.ts +1 -1
- package/dist/plugin/event-handlers/message-updated.d.ts +2 -0
- package/dist/plugin/event-handlers/session-error.d.ts +2 -0
- package/dist/plugin/event-handlers/session-status.d.ts +2 -0
- package/dist/plugin/event-handlers/types.d.ts +62 -0
- package/dist/plugin/event-handlers/utils.d.ts +11 -0
- package/dist/plugin/event.d.ts +1 -1
- package/dist/shared/data-path.d.ts +1 -1
- package/dist/shared/errors.d.ts +70 -0
- package/dist/shared/extract-session-id.d.ts +8 -0
- package/dist/shared/git-worktree/get-git-state-summary.d.ts +14 -0
- package/dist/shared/index.d.ts +67 -68
- package/dist/shared/internal-initiator-marker.d.ts +1 -1
- package/dist/shared/logger.d.ts +5 -1
- package/dist/shared/reasoning-content-cache.d.ts +68 -0
- package/dist/shared/safe-create-hook.d.ts +4 -4
- package/dist/tools/call-hiai-agent/constants.d.ts +2 -2
- package/dist/tools/delegate-task/sub-agent.d.ts +1 -1
- package/dist/tools/look-at/constants.d.ts +1 -1
- package/docs/architecture/bob-manager-architecture.md +244 -0
- package/docs/hiai-opencode/adr/ADR-001-agent-identity-section-injection.md +66 -0
- package/docs/hiai-opencode/adr/ADR-002-anti-loop-guard-priority.md +63 -0
- package/docs/hiai-opencode/adr/ADR-003-compaction-mechanism.md +71 -0
- package/docs/hiai-opencode/adr/ADR-004-session-recovery.md +76 -0
- package/docs/hiai-opencode/api.md +305 -0
- package/docs/hiai-opencode/hooks-architecture.md +225 -0
- package/docs/hiai-opencode/migration.md +209 -0
- package/docs/skill-discovery.md +288 -0
- package/package.json +1 -1
- package/skills/agent-browser/SKILL.md +193 -0
- package/skills/apple-hig/SKILL.md +43 -0
- package/skills/article-magazine/SKILL.md +46 -0
- package/skills/article-magazine/example.html +81 -0
- package/skills/article-magazine/example.md +38 -0
- package/skills/canvas-design/SKILL.md +45 -0
- package/skills/design-templates/audio-jingle/SKILL.md +132 -0
- package/skills/design-templates/audio-jingle/example.html +128 -0
- package/skills/design-templates/blog-post/SKILL.md +80 -0
- package/skills/design-templates/blog-post/example.html +80 -0
- package/skills/design-templates/clinical-case-report/SKILL.md +209 -0
- package/skills/design-templates/clinical-case-report/example.html +698 -0
- package/skills/design-templates/clinical-case-report/examples/example-stemi.html +698 -0
- package/skills/design-templates/clinical-case-report/references/case-formats.md +94 -0
- package/skills/design-templates/clinical-case-report/references/checklist.md +41 -0
- package/skills/design-templates/critique/SKILL.md +258 -0
- package/skills/design-templates/critique/example.html +671 -0
- package/skills/design-templates/dashboard/SKILL.md +76 -0
- package/skills/design-templates/dashboard/example.html +118 -0
- package/skills/design-templates/dating-web/SKILL.md +92 -0
- package/skills/design-templates/dating-web/example.html +265 -0
- package/skills/design-templates/dcf-valuation/SKILL.md +140 -0
- package/skills/design-templates/dcf-valuation/references/sector-wacc.md +42 -0
- package/skills/design-templates/digital-eguide/SKILL.md +94 -0
- package/skills/design-templates/digital-eguide/example.html +204 -0
- package/skills/design-templates/docs-page/SKILL.md +80 -0
- package/skills/design-templates/docs-page/example.html +122 -0
- package/skills/design-templates/email-marketing/SKILL.md +84 -0
- package/skills/design-templates/email-marketing/example.html +159 -0
- package/skills/design-templates/eng-runbook/SKILL.md +51 -0
- package/skills/design-templates/eng-runbook/example.html +250 -0
- package/skills/design-templates/finance-report/SKILL.md +61 -0
- package/skills/design-templates/finance-report/example.html +242 -0
- package/skills/design-templates/flowai-live-dashboard-template/SKILL.md +87 -0
- package/skills/design-templates/flowai-live-dashboard-template/assets/template.html +387 -0
- package/skills/design-templates/flowai-live-dashboard-template/example.html +13 -0
- package/skills/design-templates/flowai-live-dashboard-template/references/checklist.md +35 -0
- package/skills/design-templates/gamified-app/SKILL.md +108 -0
- package/skills/design-templates/gamified-app/example.html +292 -0
- package/skills/design-templates/github-dashboard/SKILL.md +130 -0
- package/skills/design-templates/github-dashboard/example.html +473 -0
- package/skills/design-templates/github-dashboard/references/README.md +10 -0
- package/skills/design-templates/github-dashboard/references/artifact-example.json +15 -0
- package/skills/design-templates/github-dashboard/references/example-data.json +138 -0
- package/skills/design-templates/github-dashboard/references/provenance-example.json +92 -0
- package/skills/design-templates/github-dashboard/references/template.html +473 -0
- package/skills/design-templates/guizang-ppt/LICENSE +21 -0
- package/skills/design-templates/guizang-ppt/README.en.md +119 -0
- package/skills/design-templates/guizang-ppt/README.md +120 -0
- package/skills/design-templates/guizang-ppt/README.pt-BR.md +121 -0
- package/skills/design-templates/guizang-ppt/SKILL.md +313 -0
- package/skills/design-templates/guizang-ppt/assets/example-slides.html +318 -0
- package/skills/design-templates/guizang-ppt/assets/template.html +647 -0
- package/skills/design-templates/guizang-ppt/references/checklist.md +265 -0
- package/skills/design-templates/guizang-ppt/references/components.md +363 -0
- package/skills/design-templates/guizang-ppt/references/layouts.md +630 -0
- package/skills/design-templates/guizang-ppt/references/styles.md +195 -0
- package/skills/design-templates/guizang-ppt/references/themes.md +122 -0
- package/skills/design-templates/hr-onboarding/SKILL.md +52 -0
- package/skills/design-templates/hr-onboarding/example.html +219 -0
- package/skills/design-templates/html-ppt/.clawscan-allow +12 -0
- package/skills/design-templates/html-ppt/LICENSE +21 -0
- package/skills/design-templates/html-ppt/README.md +234 -0
- package/skills/design-templates/html-ppt/README.pt-BR.md +239 -0
- package/skills/design-templates/html-ppt/README.zh-CN.md +238 -0
- package/skills/design-templates/html-ppt/SKILL.md +250 -0
- package/skills/design-templates/html-ppt/assets/animations/animations.css +138 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/_util.js +63 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/chain-react.js +41 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/confetti-cannon.js +49 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/constellation.js +44 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/counter-explosion.js +58 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/data-stream.js +45 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/firework.js +51 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/galaxy-swirl.js +33 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/gradient-blob.js +39 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/knowledge-graph.js +69 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/letter-explode.js +50 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/magnetic-field.js +40 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/matrix-rain.js +33 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/neural-net.js +75 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/orbit-ring.js +38 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/particle-burst.js +42 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/shockwave.js +39 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/sparkle-trail.js +62 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/starfield.js +30 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/typewriter-multi.js +51 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/word-cascade.js +47 -0
- package/skills/design-templates/html-ppt/assets/animations/fx-runtime.js +99 -0
- package/skills/design-templates/html-ppt/assets/base.css +150 -0
- package/skills/design-templates/html-ppt/assets/fonts.css +9 -0
- package/skills/design-templates/html-ppt/assets/runtime.js +960 -0
- package/skills/design-templates/html-ppt/assets/themes/academic-paper.css +23 -0
- package/skills/design-templates/html-ppt/assets/themes/arctic-cool.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/aurora.css +20 -0
- package/skills/design-templates/html-ppt/assets/themes/bauhaus.css +16 -0
- package/skills/design-templates/html-ppt/assets/themes/blueprint.css +19 -0
- package/skills/design-templates/html-ppt/assets/themes/catppuccin-latte.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/catppuccin-mocha.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/corporate-clean.css +19 -0
- package/skills/design-templates/html-ppt/assets/themes/cyberpunk-neon.css +23 -0
- package/skills/design-templates/html-ppt/assets/themes/dracula.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/editorial-serif.css +18 -0
- package/skills/design-templates/html-ppt/assets/themes/engineering-whiteprint.css +26 -0
- package/skills/design-templates/html-ppt/assets/themes/glassmorphism.css +21 -0
- package/skills/design-templates/html-ppt/assets/themes/gruvbox-dark.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/japanese-minimal.css +21 -0
- package/skills/design-templates/html-ppt/assets/themes/magazine-bold.css +21 -0
- package/skills/design-templates/html-ppt/assets/themes/memphis-pop.css +20 -0
- package/skills/design-templates/html-ppt/assets/themes/midcentury.css +19 -0
- package/skills/design-templates/html-ppt/assets/themes/minimal-white.css +16 -0
- package/skills/design-templates/html-ppt/assets/themes/neo-brutalism.css +17 -0
- package/skills/design-templates/html-ppt/assets/themes/news-broadcast.css +20 -0
- package/skills/design-templates/html-ppt/assets/themes/nord.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/pitch-deck-vc.css +21 -0
- package/skills/design-templates/html-ppt/assets/themes/rainbow-gradient.css +16 -0
- package/skills/design-templates/html-ppt/assets/themes/retro-tv.css +22 -0
- package/skills/design-templates/html-ppt/assets/themes/rose-pine.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/sharp-mono.css +17 -0
- package/skills/design-templates/html-ppt/assets/themes/soft-pastel.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/solarized-light.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/sunset-warm.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/swiss-grid.css +17 -0
- package/skills/design-templates/html-ppt/assets/themes/terminal-green.css +18 -0
- package/skills/design-templates/html-ppt/assets/themes/tokyo-night.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/vaporwave.css +21 -0
- package/skills/design-templates/html-ppt/assets/themes/xiaohongshu-white.css +16 -0
- package/skills/design-templates/html-ppt/assets/themes/y2k-chrome.css +20 -0
- package/skills/design-templates/html-ppt/docs/readme/_theme-cell.html +56 -0
- package/skills/design-templates/html-ppt/docs/readme/animations.png +0 -0
- package/skills/design-templates/html-ppt/docs/readme/hero.gif +0 -0
- package/skills/design-templates/html-ppt/docs/readme/layouts-live.gif +0 -0
- package/skills/design-templates/html-ppt/docs/readme/layouts.png +0 -0
- package/skills/design-templates/html-ppt/docs/readme/montage-animations.html +61 -0
- package/skills/design-templates/html-ppt/docs/readme/montage-layouts.html +72 -0
- package/skills/design-templates/html-ppt/docs/readme/montage-templates.html +72 -0
- package/skills/design-templates/html-ppt/docs/readme/montage-themes.html +38 -0
- package/skills/design-templates/html-ppt/docs/readme/presenter-mode.png +0 -0
- package/skills/design-templates/html-ppt/docs/readme/templates.png +0 -0
- package/skills/design-templates/html-ppt/docs/readme/themes.png +0 -0
- package/skills/design-templates/html-ppt/examples/demo-deck/index.html +161 -0
- package/skills/design-templates/html-ppt/references/animations.md +147 -0
- package/skills/design-templates/html-ppt/references/authoring-guide.md +141 -0
- package/skills/design-templates/html-ppt/references/full-decks.md +98 -0
- package/skills/design-templates/html-ppt/references/layouts.md +103 -0
- package/skills/design-templates/html-ppt/references/presenter-mode.md +240 -0
- package/skills/design-templates/html-ppt/references/themes.md +107 -0
- package/skills/design-templates/html-ppt/scripts/new-deck.sh +46 -0
- package/skills/design-templates/html-ppt/scripts/render.sh +71 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_01.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_02.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_03.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_04.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_05.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_06.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_07.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_08.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_09.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_10.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_11.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_12.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_13.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_14.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_15.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_16.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_17.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_18.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_19.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_20.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_01.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_02.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_03.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_04.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_05.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_06.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_07.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_08.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_09.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_10.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_11.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_12.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_13.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_14.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_15.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_16.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_17.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_18.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_19.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_20.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_21.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_22.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_23.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_24.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_25.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_26.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_27.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_28.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_29.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_30.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_31.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_32.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_33.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_34.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_35.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_36.png +0 -0
- package/skills/design-templates/html-ppt/templates/animation-showcase.html +172 -0
- package/skills/design-templates/html-ppt/templates/deck.html +69 -0
- package/skills/design-templates/html-ppt/templates/full-decks/course-module/README.md +8 -0
- package/skills/design-templates/html-ppt/templates/full-decks/course-module/index.html +189 -0
- package/skills/design-templates/html-ppt/templates/full-decks/course-module/style.css +46 -0
- package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/index.html +138 -0
- package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/style.css +60 -0
- package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/index.html +180 -0
- package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/style.css +54 -0
- package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/index.html +199 -0
- package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/style.css +55 -0
- package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/index.html +190 -0
- package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/style.css +49 -0
- package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/index.html +144 -0
- package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/style.css +59 -0
- package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/README.md +9 -0
- package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/index.html +148 -0
- package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/style.css +40 -0
- package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/README.md +102 -0
- package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/index.html +187 -0
- package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/style.css +216 -0
- package/skills/design-templates/html-ppt/templates/full-decks/product-launch/README.md +8 -0
- package/skills/design-templates/html-ppt/templates/full-decks/product-launch/index.html +121 -0
- package/skills/design-templates/html-ppt/templates/full-decks/product-launch/style.css +39 -0
- package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/README.md +8 -0
- package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/index.html +156 -0
- package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/style.css +49 -0
- package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/index.html +183 -0
- package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/style.css +62 -0
- package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/README.md +8 -0
- package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/index.html +127 -0
- package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/style.css +55 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/index.html +147 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/style.css +66 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/README.md +9 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/index.html +133 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/style.css +47 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/index.html +187 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/style.css +63 -0
- package/skills/design-templates/html-ppt/templates/full-decks-index.html +82 -0
- package/skills/design-templates/html-ppt/templates/layout-showcase.html +47 -0
- package/skills/design-templates/html-ppt/templates/single-page/arch-diagram.html +46 -0
- package/skills/design-templates/html-ppt/templates/single-page/big-quote.html +18 -0
- package/skills/design-templates/html-ppt/templates/single-page/bullets.html +19 -0
- package/skills/design-templates/html-ppt/templates/single-page/chart-bar.html +30 -0
- package/skills/design-templates/html-ppt/templates/single-page/chart-line.html +35 -0
- package/skills/design-templates/html-ppt/templates/single-page/chart-pie.html +36 -0
- package/skills/design-templates/html-ppt/templates/single-page/chart-radar.html +31 -0
- package/skills/design-templates/html-ppt/templates/single-page/code.html +33 -0
- package/skills/design-templates/html-ppt/templates/single-page/comparison.html +47 -0
- package/skills/design-templates/html-ppt/templates/single-page/cover.html +32 -0
- package/skills/design-templates/html-ppt/templates/single-page/cta.html +27 -0
- package/skills/design-templates/html-ppt/templates/single-page/diff.html +35 -0
- package/skills/design-templates/html-ppt/templates/single-page/flow-diagram.html +33 -0
- package/skills/design-templates/html-ppt/templates/single-page/gantt.html +29 -0
- package/skills/design-templates/html-ppt/templates/single-page/image-grid.html +34 -0
- package/skills/design-templates/html-ppt/templates/single-page/image-hero.html +33 -0
- package/skills/design-templates/html-ppt/templates/single-page/kpi-grid.html +19 -0
- package/skills/design-templates/html-ppt/templates/single-page/mindmap.html +38 -0
- package/skills/design-templates/html-ppt/templates/single-page/process-steps.html +27 -0
- package/skills/design-templates/html-ppt/templates/single-page/pros-cons.html +31 -0
- package/skills/design-templates/html-ppt/templates/single-page/roadmap.html +46 -0
- package/skills/design-templates/html-ppt/templates/single-page/section-divider.html +17 -0
- package/skills/design-templates/html-ppt/templates/single-page/stat-highlight.html +17 -0
- package/skills/design-templates/html-ppt/templates/single-page/table.html +33 -0
- package/skills/design-templates/html-ppt/templates/single-page/terminal.html +35 -0
- package/skills/design-templates/html-ppt/templates/single-page/thanks.html +21 -0
- package/skills/design-templates/html-ppt/templates/single-page/three-column.html +18 -0
- package/skills/design-templates/html-ppt/templates/single-page/timeline.html +32 -0
- package/skills/design-templates/html-ppt/templates/single-page/toc.html +26 -0
- package/skills/design-templates/html-ppt/templates/single-page/todo-checklist.html +33 -0
- package/skills/design-templates/html-ppt/templates/single-page/two-column.html +39 -0
- package/skills/design-templates/html-ppt/templates/theme-showcase.html +151 -0
- package/skills/design-templates/html-ppt-course-module/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-course-module/example.html +542 -0
- package/skills/design-templates/html-ppt-dir-key-nav-minimal/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-dir-key-nav-minimal/example.html +366 -0
- package/skills/design-templates/html-ppt-graphify-dark-graph/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-graphify-dark-graph/example.html +402 -0
- package/skills/design-templates/html-ppt-hermes-cyber-terminal/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-hermes-cyber-terminal/example.html +422 -0
- package/skills/design-templates/html-ppt-knowledge-arch-blueprint/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-knowledge-arch-blueprint/example.html +407 -0
- package/skills/design-templates/html-ppt-obsidian-claude-gradient/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-obsidian-claude-gradient/example.html +371 -0
- package/skills/design-templates/html-ppt-pitch-deck/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-pitch-deck/example.html +495 -0
- package/skills/design-templates/html-ppt-presenter-mode-reveal/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-presenter-mode-reveal/example.html +725 -0
- package/skills/design-templates/html-ppt-product-launch/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-product-launch/example.html +467 -0
- package/skills/design-templates/html-ppt-taste-brutalist/SKILL.md +70 -0
- package/skills/design-templates/html-ppt-taste-brutalist/example.html +774 -0
- package/skills/design-templates/html-ppt-taste-editorial/SKILL.md +62 -0
- package/skills/design-templates/html-ppt-taste-editorial/example.html +689 -0
- package/skills/design-templates/html-ppt-tech-sharing/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-tech-sharing/example.html +512 -0
- package/skills/design-templates/html-ppt-testing-safety-alert/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-testing-safety-alert/example.html +413 -0
- package/skills/design-templates/html-ppt-weekly-report/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-weekly-report/example.html +489 -0
- package/skills/design-templates/html-ppt-xhs-pastel-card/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-xhs-pastel-card/example.html +381 -0
- package/skills/design-templates/html-ppt-xhs-post/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-xhs-post/example.html +487 -0
- package/skills/design-templates/html-ppt-xhs-white-editorial/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-xhs-white-editorial/example.html +418 -0
- package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/example.html +1640 -0
- package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/template.json +48 -0
- package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/example.html +833 -0
- package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/template.json +49 -0
- package/skills/design-templates/html-ppt-zhangzara-block-frame/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-block-frame/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-block-frame/example.html +1453 -0
- package/skills/design-templates/html-ppt-zhangzara-block-frame/template.json +47 -0
- package/skills/design-templates/html-ppt-zhangzara-blue-professional/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-blue-professional/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-blue-professional/example.html +1423 -0
- package/skills/design-templates/html-ppt-zhangzara-blue-professional/template.json +44 -0
- package/skills/design-templates/html-ppt-zhangzara-bold-poster/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-bold-poster/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-bold-poster/example.html +876 -0
- package/skills/design-templates/html-ppt-zhangzara-bold-poster/template.json +45 -0
- package/skills/design-templates/html-ppt-zhangzara-broadside/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-broadside/SKILL.md +92 -0
- package/skills/design-templates/html-ppt-zhangzara-broadside/example.html +2144 -0
- package/skills/design-templates/html-ppt-zhangzara-broadside/template.json +49 -0
- package/skills/design-templates/html-ppt-zhangzara-capsule/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-capsule/SKILL.md +92 -0
- package/skills/design-templates/html-ppt-zhangzara-capsule/example.html +1413 -0
- package/skills/design-templates/html-ppt-zhangzara-capsule/template.json +51 -0
- package/skills/design-templates/html-ppt-zhangzara-cartesian/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-cartesian/SKILL.md +92 -0
- package/skills/design-templates/html-ppt-zhangzara-cartesian/example.html +1136 -0
- package/skills/design-templates/html-ppt-zhangzara-cartesian/template.json +47 -0
- package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/example.html +1205 -0
- package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/template.json +49 -0
- package/skills/design-templates/html-ppt-zhangzara-coral/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-coral/SKILL.md +92 -0
- package/skills/design-templates/html-ppt-zhangzara-coral/example.html +1487 -0
- package/skills/design-templates/html-ppt-zhangzara-coral/template.json +45 -0
- package/skills/design-templates/html-ppt-zhangzara-creative-mode/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-creative-mode/SKILL.md +99 -0
- package/skills/design-templates/html-ppt-zhangzara-creative-mode/assets/deck-stage.js +619 -0
- package/skills/design-templates/html-ppt-zhangzara-creative-mode/example.html +636 -0
- package/skills/design-templates/html-ppt-zhangzara-creative-mode/template.json +47 -0
- package/skills/design-templates/html-ppt-zhangzara-daisy-days/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-daisy-days/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-daisy-days/example.html +469 -0
- package/skills/design-templates/html-ppt-zhangzara-daisy-days/template.json +54 -0
- package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/SKILL.md +98 -0
- package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/assets/deck-stage.js +619 -0
- package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/example.html +737 -0
- package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/template.json +44 -0
- package/skills/design-templates/html-ppt-zhangzara-grove/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-grove/SKILL.md +92 -0
- package/skills/design-templates/html-ppt-zhangzara-grove/example.html +1676 -0
- package/skills/design-templates/html-ppt-zhangzara-grove/template.json +51 -0
- package/skills/figma-code-connect-components/SKILL.md +42 -0
- package/skills/figma-create-design-system-rules/SKILL.md +42 -0
- package/skills/figma-create-new-file/SKILL.md +41 -0
- package/skills/figma-generate-design/SKILL.md +42 -0
- package/skills/figma-generate-library/SKILL.md +42 -0
- package/skills/figma-implement-design/SKILL.md +42 -0
- package/skills/figma-use/SKILL.md +42 -0
- package/skills/full-page-screenshot/SKILL.md +42 -0
- package/skills/interview-me/SKILL.md +64 -0
- package/skills/planning-and-task-breakdown/SKILL.md +52 -0
- package/skills/sora/SKILL.md +43 -0
- package/skills/theme-factory/SKILL.md +43 -0
- package/skills/web-design-guidelines/SKILL.md +42 -0
- package/dist/agents/prompt-library/orchestration.d.ts +0 -4
- package/skills/brainstorming/SKILL.md +0 -164
- package/skills/brainstorming/scripts/frame-template.html +0 -214
- package/skills/brainstorming/scripts/helper.js +0 -88
- package/skills/brainstorming/scripts/server.cjs +0 -354
- package/skills/brainstorming/scripts/start-server.sh +0 -148
- package/skills/brainstorming/scripts/stop-server.sh +0 -56
- package/skills/brainstorming/spec-document-reviewer-prompt.md +0 -49
- package/skills/brainstorming/visual-companion.md +0 -287
|
@@ -0,0 +1,250 @@
|
|
|
1
|
+
<!doctype html>
|
|
2
|
+
<html lang="en">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="utf-8" />
|
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
6
|
+
<title>Auth Service · Runbook</title>
|
|
7
|
+
<style>
|
|
8
|
+
:root {
|
|
9
|
+
--bg: #0c0e14;
|
|
10
|
+
--paper: #14171f;
|
|
11
|
+
--paper-2: #1c2030;
|
|
12
|
+
--ink: #eaecf3;
|
|
13
|
+
--muted: #8b94ad;
|
|
14
|
+
--line: #262b3b;
|
|
15
|
+
--accent: #6ee7b7;
|
|
16
|
+
--accent-soft: rgba(110,231,183,0.1);
|
|
17
|
+
--warn: #fbbf24;
|
|
18
|
+
--danger: #f87171;
|
|
19
|
+
--display: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
|
|
20
|
+
--body: -apple-system, BlinkMacSystemFont, 'Segoe UI', Inter, sans-serif;
|
|
21
|
+
--mono: ui-monospace, 'JetBrains Mono', SFMono-Regular, Menlo, monospace;
|
|
22
|
+
}
|
|
23
|
+
* { box-sizing: border-box; }
|
|
24
|
+
body { margin: 0; background: var(--bg); color: var(--ink); font-family: var(--body); font-size: 14px; line-height: 1.6; }
|
|
25
|
+
.page { max-width: 1100px; margin: 0 auto; padding: 32px 28px 64px; }
|
|
26
|
+
|
|
27
|
+
/* Header */
|
|
28
|
+
.head { display: flex; justify-content: space-between; align-items: flex-end; padding-bottom: 24px; border-bottom: 1px solid var(--line); margin-bottom: 28px; }
|
|
29
|
+
.head-left { display: flex; flex-direction: column; gap: 6px; }
|
|
30
|
+
.crumb { font-family: var(--mono); font-size: 11.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; }
|
|
31
|
+
h1 { font-family: var(--display); font-size: 36px; margin: 4px 0; font-weight: 700; letter-spacing: -0.02em; }
|
|
32
|
+
.head-meta { font-family: var(--mono); font-size: 11.5px; color: var(--muted); }
|
|
33
|
+
.head-meta span { color: var(--accent); }
|
|
34
|
+
.pill {
|
|
35
|
+
display: inline-flex; align-items: center; gap: 6px; padding: 5px 12px; border-radius: 999px;
|
|
36
|
+
font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600;
|
|
37
|
+
}
|
|
38
|
+
.pill.tier { background: var(--accent-soft); color: var(--accent); border: 1px solid rgba(110,231,183,0.3); }
|
|
39
|
+
.pill .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
|
|
40
|
+
|
|
41
|
+
section { margin-top: 40px; }
|
|
42
|
+
h2 { font-family: var(--display); font-size: 22px; margin: 0 0 14px; letter-spacing: -0.005em; font-weight: 700; }
|
|
43
|
+
h2 .index { font-family: var(--mono); font-size: 12px; color: var(--muted); margin-right: 12px; vertical-align: middle; }
|
|
44
|
+
|
|
45
|
+
/* Summary */
|
|
46
|
+
.summary { display: grid; grid-template-columns: 1.4fr 1fr; gap: 14px; }
|
|
47
|
+
.panel { padding: 22px 24px; background: var(--paper); border: 1px solid var(--line); border-radius: 12px; }
|
|
48
|
+
.panel p { margin: 0 0 12px; }
|
|
49
|
+
.panel p:last-child { margin: 0; }
|
|
50
|
+
.deps h3 { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); margin: 0 0 10px; font-weight: 500; }
|
|
51
|
+
.deps ul { padding: 0; margin: 0; list-style: none; display: flex; flex-direction: column; gap: 8px; font-family: var(--mono); font-size: 12.5px; }
|
|
52
|
+
.deps li { display: flex; justify-content: space-between; padding: 8px 12px; background: var(--paper-2); border-radius: 6px; }
|
|
53
|
+
.deps li .ok { color: var(--accent); }
|
|
54
|
+
.deps li .warn { color: var(--warn); }
|
|
55
|
+
|
|
56
|
+
/* Tables */
|
|
57
|
+
table { width: 100%; border-collapse: collapse; background: var(--paper); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
|
|
58
|
+
th, td { text-align: left; padding: 12px 16px; border-bottom: 1px solid var(--line); font-size: 13px; vertical-align: top; }
|
|
59
|
+
th { font-family: var(--mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); background: var(--paper-2); }
|
|
60
|
+
tr:last-child td { border-bottom: none; }
|
|
61
|
+
td.code, .panel code { font-family: var(--mono); }
|
|
62
|
+
.sev { display: inline-flex; align-items: center; gap: 6px; padding: 3px 9px; border-radius: 4px; font-family: var(--mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.04em; font-weight: 600; }
|
|
63
|
+
.sev-1 { background: rgba(248,113,113,0.15); color: var(--danger); }
|
|
64
|
+
.sev-2 { background: rgba(251,191,36,0.15); color: var(--warn); }
|
|
65
|
+
.sev-3 { background: rgba(110,231,183,0.15); color: var(--accent); }
|
|
66
|
+
|
|
67
|
+
/* Procedure cards */
|
|
68
|
+
.procs { display: flex; flex-direction: column; gap: 14px; }
|
|
69
|
+
.proc { padding: 18px 22px; background: var(--paper); border: 1px solid var(--line); border-radius: 12px; }
|
|
70
|
+
.proc-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 10px; }
|
|
71
|
+
.proc-head h3 { margin: 0; font-family: var(--display); font-size: 17px; }
|
|
72
|
+
.proc-head .when { font-family: var(--mono); font-size: 11px; color: var(--muted); }
|
|
73
|
+
pre { background: var(--paper-2); border: 1px solid var(--line); border-radius: 8px; padding: 14px 16px; overflow-x: auto; font-family: var(--mono); font-size: 12.5px; line-height: 1.6; color: #cdd6f4; margin: 8px 0 0; }
|
|
74
|
+
pre .cmt { color: var(--muted); }
|
|
75
|
+
pre .var { color: var(--warn); }
|
|
76
|
+
pre .ok { color: var(--accent); }
|
|
77
|
+
|
|
78
|
+
/* On-call */
|
|
79
|
+
.rota { background: var(--paper); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
|
|
80
|
+
|
|
81
|
+
/* Checklist */
|
|
82
|
+
.checklist { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
|
|
83
|
+
.step { padding: 18px 20px; background: var(--paper); border: 1px solid var(--line); border-radius: 12px; display: flex; gap: 16px; align-items: flex-start; }
|
|
84
|
+
.step-num { flex: 0 0 36px; width: 36px; height: 36px; border-radius: 50%; background: var(--accent); color: var(--bg); display: inline-flex; align-items: center; justify-content: center; font-weight: 700; font-family: var(--display); font-size: 16px; }
|
|
85
|
+
.step h4 { margin: 0 0 6px; font-family: var(--display); font-size: 15px; }
|
|
86
|
+
.step p { margin: 0; color: var(--muted); font-size: 13px; }
|
|
87
|
+
.step code { font-family: var(--mono); background: var(--paper-2); padding: 2px 6px; border-radius: 4px; font-size: 12px; color: var(--accent); }
|
|
88
|
+
|
|
89
|
+
footer { margin-top: 56px; padding-top: 18px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; font-family: var(--mono); font-size: 11.5px; color: var(--muted); }
|
|
90
|
+
|
|
91
|
+
@media (max-width: 880px) {
|
|
92
|
+
.summary, .checklist { grid-template-columns: 1fr; }
|
|
93
|
+
h1 { font-size: 26px; }
|
|
94
|
+
}
|
|
95
|
+
</style>
|
|
96
|
+
</head>
|
|
97
|
+
<body>
|
|
98
|
+
<div class="page">
|
|
99
|
+
<header class="head">
|
|
100
|
+
<div class="head-left">
|
|
101
|
+
<div class="crumb">Northwind / Identity / Auth</div>
|
|
102
|
+
<h1>auth-service</h1>
|
|
103
|
+
<div class="head-meta">Owned by <span>@identity-platform</span> · v4.7.2 · Last reviewed 14 Oct 2025</div>
|
|
104
|
+
</div>
|
|
105
|
+
<span class="pill tier"><span class="dot"></span>Tier 0 · production-critical</span>
|
|
106
|
+
</header>
|
|
107
|
+
|
|
108
|
+
<section>
|
|
109
|
+
<h2><span class="index">01</span>Service summary</h2>
|
|
110
|
+
<div class="summary">
|
|
111
|
+
<div class="panel">
|
|
112
|
+
<p><strong>auth-service</strong> issues, validates, and revokes session tokens for every Northwind product surface — web, mobile, and the public API. It owns the password store, the TOTP/WebAuthn enrollments, and the audit-log writer for all auth events.</p>
|
|
113
|
+
<p>If <code>auth-service</code> is down, customers cannot log in or refresh sessions. Existing valid sessions continue to work for their TTL (15 minutes) but no new auth happens.</p>
|
|
114
|
+
</div>
|
|
115
|
+
<div class="panel deps">
|
|
116
|
+
<h3>Dependencies</h3>
|
|
117
|
+
<ul>
|
|
118
|
+
<li><span>Postgres · auth-db</span><span class="ok">healthy</span></li>
|
|
119
|
+
<li><span>Redis · session-cache</span><span class="ok">healthy</span></li>
|
|
120
|
+
<li><span>KMS · auth-keyring</span><span class="ok">healthy</span></li>
|
|
121
|
+
<li><span>SES · transactional</span><span class="warn">degraded</span></li>
|
|
122
|
+
<li><span>Pager · oncall.northwind</span><span class="ok">healthy</span></li>
|
|
123
|
+
</ul>
|
|
124
|
+
</div>
|
|
125
|
+
</div>
|
|
126
|
+
</section>
|
|
127
|
+
|
|
128
|
+
<section>
|
|
129
|
+
<h2><span class="index">02</span>Alerts you might wake up to</h2>
|
|
130
|
+
<table>
|
|
131
|
+
<thead><tr><th>Alert</th><th>Severity</th><th>What it means</th><th>First response</th></tr></thead>
|
|
132
|
+
<tbody>
|
|
133
|
+
<tr>
|
|
134
|
+
<td class="code">auth.login_5xx_rate > 1%</td>
|
|
135
|
+
<td><span class="sev sev-1">SEV-1</span></td>
|
|
136
|
+
<td>Login endpoint returning errors. Customers are locked out.</td>
|
|
137
|
+
<td>Check Postgres + Redis dashboards. Roll back last deploy if < 30 min old.</td>
|
|
138
|
+
</tr>
|
|
139
|
+
<tr>
|
|
140
|
+
<td class="code">auth.token_refresh_lag_p95 > 800ms</td>
|
|
141
|
+
<td><span class="sev sev-2">SEV-2</span></td>
|
|
142
|
+
<td>Refresh path is slow. Web app starts to feel sluggish.</td>
|
|
143
|
+
<td>Inspect Redis CPU + connection count. Scale read replicas if needed.</td>
|
|
144
|
+
</tr>
|
|
145
|
+
<tr>
|
|
146
|
+
<td class="code">auth.signup_failure > 10/min</td>
|
|
147
|
+
<td><span class="sev sev-2">SEV-2</span></td>
|
|
148
|
+
<td>New signups are failing. Often SES bounces or SMTP auth.</td>
|
|
149
|
+
<td>Check SES bounce rate. Failover transactional queue to backup region.</td>
|
|
150
|
+
</tr>
|
|
151
|
+
<tr>
|
|
152
|
+
<td class="code">auth.kms_signing_errors > 0</td>
|
|
153
|
+
<td><span class="sev sev-1">SEV-1</span></td>
|
|
154
|
+
<td>KMS can't sign session tokens. New logins fail; existing sessions OK.</td>
|
|
155
|
+
<td>Page the security team. Do not roll keys without a security engineer.</td>
|
|
156
|
+
</tr>
|
|
157
|
+
<tr>
|
|
158
|
+
<td class="code">auth.audit_writer_backlog > 5k</td>
|
|
159
|
+
<td><span class="sev sev-3">SEV-3</span></td>
|
|
160
|
+
<td>Audit log writer is falling behind. Compliance impact.</td>
|
|
161
|
+
<td>Drain manually. Open a ticket; not a wake-up.</td>
|
|
162
|
+
</tr>
|
|
163
|
+
</tbody>
|
|
164
|
+
</table>
|
|
165
|
+
</section>
|
|
166
|
+
|
|
167
|
+
<section>
|
|
168
|
+
<h2><span class="index">03</span>Common procedures</h2>
|
|
169
|
+
<div class="procs">
|
|
170
|
+
<div class="proc">
|
|
171
|
+
<div class="proc-head"><h3>Deploy a new version</h3><span class="when">Use during business hours</span></div>
|
|
172
|
+
<p>Deploys are blue/green. The script waits for two consecutive healthchecks before promoting traffic.</p>
|
|
173
|
+
<pre><span class="cmt"># Deploy auth-service v4.7.3 to production</span>
|
|
174
|
+
$ nw deploy auth-service --tag <span class="var">v4.7.3</span> --env production
|
|
175
|
+
|
|
176
|
+
<span class="cmt"># Wait for two consecutive healthchecks (~90 s), then promote.</span>
|
|
177
|
+
$ nw deploy promote auth-service --env production
|
|
178
|
+
<span class="ok">→ traffic shifted: 10% / 50% / 100%</span></pre>
|
|
179
|
+
</div>
|
|
180
|
+
<div class="proc">
|
|
181
|
+
<div class="proc-head"><h3>Roll back to last known good</h3><span class="when">Use when error rate > 1% post-deploy</span></div>
|
|
182
|
+
<pre><span class="cmt"># Rolls back to the previously promoted version, no rebuild.</span>
|
|
183
|
+
$ nw deploy rollback auth-service --env production
|
|
184
|
+
<span class="ok">→ rolled back to v4.7.2 in 38 s</span></pre>
|
|
185
|
+
</div>
|
|
186
|
+
<div class="proc">
|
|
187
|
+
<div class="proc-head"><h3>Rotate signing keys</h3><span class="when">Schedule with security; never solo</span></div>
|
|
188
|
+
<pre><span class="cmt"># 1. Generate the new signing key in KMS</span>
|
|
189
|
+
$ nw kms create-key --alias auth-signing-<span class="var">$(date +%Y%m%d)</span>
|
|
190
|
+
|
|
191
|
+
<span class="cmt"># 2. Mark the new key as the primary; old key remains valid for 24h</span>
|
|
192
|
+
$ nw kms set-primary auth-signing --key <span class="var"><arn></span>
|
|
193
|
+
|
|
194
|
+
<span class="cmt"># 3. After 24h, schedule deletion of the previous key</span>
|
|
195
|
+
$ nw kms schedule-deletion auth-signing --key <span class="var"><old-arn></span> --days 30</pre>
|
|
196
|
+
</div>
|
|
197
|
+
<div class="proc">
|
|
198
|
+
<div class="proc-head"><h3>Drain audit-log backlog</h3><span class="when">Use when audit_writer_backlog alert fires</span></div>
|
|
199
|
+
<pre>$ nw exec auth-service -- bin/audit-drain --batch <span class="var">5000</span>
|
|
200
|
+
<span class="ok">→ drained 4,812 entries in 12 s; backlog now 0</span></pre>
|
|
201
|
+
</div>
|
|
202
|
+
</div>
|
|
203
|
+
</section>
|
|
204
|
+
|
|
205
|
+
<section>
|
|
206
|
+
<h2><span class="index">04</span>On-call rotation · this month</h2>
|
|
207
|
+
<table class="rota">
|
|
208
|
+
<thead><tr><th>Week</th><th>Primary</th><th>Secondary</th><th>Backup (escalation)</th></tr></thead>
|
|
209
|
+
<tbody>
|
|
210
|
+
<tr><td>Oct 27 – Nov 02</td><td>Devon Park</td><td>Priya Banerjee</td><td>Sasha Lin</td></tr>
|
|
211
|
+
<tr><td>Nov 03 – Nov 09</td><td>Caleb Renner</td><td>Devon Park</td><td>Sasha Lin</td></tr>
|
|
212
|
+
<tr><td>Nov 10 – Nov 16</td><td>Priya Banerjee</td><td>Caleb Renner</td><td>Mira Reddy</td></tr>
|
|
213
|
+
<tr><td>Nov 17 – Nov 23</td><td>Sasha Lin</td><td>Priya Banerjee</td><td>Mira Reddy</td></tr>
|
|
214
|
+
</tbody>
|
|
215
|
+
</table>
|
|
216
|
+
</section>
|
|
217
|
+
|
|
218
|
+
<section>
|
|
219
|
+
<h2><span class="index">05</span>Incident response — first 30 minutes</h2>
|
|
220
|
+
<div class="checklist">
|
|
221
|
+
<div class="step">
|
|
222
|
+
<div class="step-num">1</div>
|
|
223
|
+
<div><h4>Acknowledge the page within 5 min.</h4><p>Type <code>/ack</code> in <code>#incidents-auth</code>. The bot stops re-paging and tags the on-call.</p></div>
|
|
224
|
+
</div>
|
|
225
|
+
<div class="step">
|
|
226
|
+
<div class="step-num">2</div>
|
|
227
|
+
<div><h4>Open the incident channel.</h4><p>Run <code>/incident open auth-service "<short title>"</code>. Slack bot creates a dedicated channel and pages the secondary.</p></div>
|
|
228
|
+
</div>
|
|
229
|
+
<div class="step">
|
|
230
|
+
<div class="step-num">3</div>
|
|
231
|
+
<div><h4>Post a status snapshot.</h4><p>Customer-impact in one line, what you know, what you're checking next. Re-post every 10 minutes.</p></div>
|
|
232
|
+
</div>
|
|
233
|
+
<div class="step">
|
|
234
|
+
<div class="step-num">4</div>
|
|
235
|
+
<div><h4>Mitigate before you diagnose.</h4><p>If a recent deploy is suspect, roll back. If KMS is degraded, fail open is <em>never</em> the answer for auth — escalate to security.</p></div>
|
|
236
|
+
</div>
|
|
237
|
+
<div class="step">
|
|
238
|
+
<div class="step-num">5</div>
|
|
239
|
+
<div><h4>Hand off or stand down.</h4><p>If you can't resolve in 30 min, hand to the secondary. When healthy, close with <code>/incident close</code>; postmortem is owed within 5 business days.</p></div>
|
|
240
|
+
</div>
|
|
241
|
+
</div>
|
|
242
|
+
</section>
|
|
243
|
+
|
|
244
|
+
<footer>
|
|
245
|
+
<span>Northwind Identity Platform · runbook v3.2</span>
|
|
246
|
+
<span>Source: ops-docs/auth-service.md</span>
|
|
247
|
+
</footer>
|
|
248
|
+
</div>
|
|
249
|
+
</body>
|
|
250
|
+
</html>
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: finance-report
|
|
3
|
+
description: |
|
|
4
|
+
Quarterly / monthly financial report — masthead with KPIs, revenue and
|
|
5
|
+
burn charts, P&L summary table, top-line highlights, and an outlook
|
|
6
|
+
paragraph. Use when the brief mentions "financial report", "Q3 report",
|
|
7
|
+
"MRR review", "P&L", or "财报".
|
|
8
|
+
triggers:
|
|
9
|
+
- "financial report"
|
|
10
|
+
- "finance report"
|
|
11
|
+
- "quarterly report"
|
|
12
|
+
- "p&l"
|
|
13
|
+
- "mrr review"
|
|
14
|
+
- "财报"
|
|
15
|
+
- "财务报告"
|
|
16
|
+
od:
|
|
17
|
+
mode: prototype
|
|
18
|
+
platform: desktop
|
|
19
|
+
scenario: finance
|
|
20
|
+
preview:
|
|
21
|
+
type: html
|
|
22
|
+
entry: index.html
|
|
23
|
+
design_system:
|
|
24
|
+
requires: true
|
|
25
|
+
sections: [color, typography, layout, components]
|
|
26
|
+
craft:
|
|
27
|
+
requires: [rtl-and-bidi]
|
|
28
|
+
example_prompt: "Build me a Q3 financial report for an early-stage SaaS — MRR, burn, gross margin, top accounts."
|
|
29
|
+
---
|
|
30
|
+
|
|
31
|
+
# Finance Report Skill
|
|
32
|
+
|
|
33
|
+
Produce a single-screen financial report in one self-contained HTML file.
|
|
34
|
+
|
|
35
|
+
## Workflow
|
|
36
|
+
|
|
37
|
+
1. **Read the active DESIGN.md.** Tables, KPI cards, and chart strokes use
|
|
38
|
+
palette tokens — never invent new ones.
|
|
39
|
+
2. **Classify** the period (monthly / quarterly / yearly) and entity
|
|
40
|
+
(startup, division, project) from the brief. If unspecified, assume a
|
|
41
|
+
quarterly SaaS report and pick believable numbers.
|
|
42
|
+
3. **Layout** the page in this order:
|
|
43
|
+
- Masthead: company / period / "Confidential — Finance" badge.
|
|
44
|
+
- Headline KPI strip (4 cards): Revenue, Net new MRR, Gross margin, Cash runway.
|
|
45
|
+
- Revenue trend chart (inline SVG line + area).
|
|
46
|
+
- Cost breakdown chart (inline SVG bar) with a 2–3 bullet caption.
|
|
47
|
+
- P&L summary table (Revenue / Gross profit / Opex / Net) with current vs prior period.
|
|
48
|
+
- Top accounts table with logo placeholders, plan, ARR, status badge.
|
|
49
|
+
- Outlook paragraph + footer with author + signature line.
|
|
50
|
+
4. **Write** one self-contained HTML doc (CSS in one inline `<style>` block).
|
|
51
|
+
5. **Self-check**: every number ties to a labelled chart or table; deltas
|
|
52
|
+
show direction and percentage; accent colour used at most twice.
|
|
53
|
+
|
|
54
|
+
## Output contract
|
|
55
|
+
|
|
56
|
+
```
|
|
57
|
+
<artifact identifier="finance-report-q3" type="text/html" title="Q3 Finance Report">
|
|
58
|
+
<!doctype html>
|
|
59
|
+
<html>...</html>
|
|
60
|
+
</artifact>
|
|
61
|
+
```
|
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
<!doctype html>
|
|
2
|
+
<html lang="en">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="utf-8" />
|
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
6
|
+
<title>Northwind — Q3 Financial Report</title>
|
|
7
|
+
<style>
|
|
8
|
+
:root {
|
|
9
|
+
--bg: #f7f6f2;
|
|
10
|
+
--paper: #ffffff;
|
|
11
|
+
--ink: #11141a;
|
|
12
|
+
--muted: #5f6573;
|
|
13
|
+
--line: #e6e3dd;
|
|
14
|
+
--line-strong: #c8c2b6;
|
|
15
|
+
--accent: #1f6e8c;
|
|
16
|
+
--accent-soft: #e7f0f4;
|
|
17
|
+
--positive: #1f8c5c;
|
|
18
|
+
--negative: #b13b3b;
|
|
19
|
+
--display: 'Iowan Old Style', 'Charter', 'Iowan', Georgia, serif;
|
|
20
|
+
--body: -apple-system, BlinkMacSystemFont, 'Segoe UI', Inter, sans-serif;
|
|
21
|
+
--mono: ui-monospace, SFMono-Regular, Menlo, monospace;
|
|
22
|
+
}
|
|
23
|
+
* { box-sizing: border-box; }
|
|
24
|
+
body {
|
|
25
|
+
margin: 0;
|
|
26
|
+
background: var(--bg);
|
|
27
|
+
color: var(--ink);
|
|
28
|
+
font-family: var(--body);
|
|
29
|
+
font-size: 14px;
|
|
30
|
+
line-height: 1.55;
|
|
31
|
+
}
|
|
32
|
+
.page {
|
|
33
|
+
max-width: 980px;
|
|
34
|
+
margin: 32px auto;
|
|
35
|
+
padding: 56px 64px;
|
|
36
|
+
background: var(--paper);
|
|
37
|
+
border: 1px solid var(--line);
|
|
38
|
+
border-radius: 12px;
|
|
39
|
+
box-shadow: 0 24px 60px rgba(28,27,26,0.06);
|
|
40
|
+
}
|
|
41
|
+
header.masthead { display: flex; justify-content: space-between; align-items: flex-end; padding-bottom: 18px; border-bottom: 2px solid var(--ink); margin-bottom: 28px; }
|
|
42
|
+
.mast-left { display: flex; flex-direction: column; gap: 6px; }
|
|
43
|
+
.mast-co { font-family: var(--display); font-size: 32px; letter-spacing: -0.01em; font-weight: 700; }
|
|
44
|
+
.mast-meta { font-family: var(--mono); font-size: 11.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; }
|
|
45
|
+
.mast-badge {
|
|
46
|
+
font-family: var(--mono); font-size: 11px; padding: 5px 10px; border-radius: 4px;
|
|
47
|
+
border: 1px solid var(--ink); color: var(--ink); text-transform: uppercase; letter-spacing: 0.08em;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
h2 { font-family: var(--display); font-size: 19px; margin: 36px 0 14px; letter-spacing: -0.005em; font-weight: 700; }
|
|
51
|
+
h2 .accent { color: var(--accent); }
|
|
52
|
+
.lede { color: var(--muted); max-width: 64ch; }
|
|
53
|
+
|
|
54
|
+
/* KPI strip */
|
|
55
|
+
.kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin: 8px 0 28px; }
|
|
56
|
+
.kpi { padding: 16px 18px; background: var(--paper); border: 1px solid var(--line); border-radius: 10px; }
|
|
57
|
+
.kpi .label { font-family: var(--mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); }
|
|
58
|
+
.kpi .value { font-family: var(--display); font-size: 28px; font-weight: 700; margin-top: 6px; line-height: 1; letter-spacing: -0.01em; }
|
|
59
|
+
.kpi .delta { font-family: var(--mono); font-size: 11.5px; margin-top: 6px; }
|
|
60
|
+
.delta.up { color: var(--positive); }
|
|
61
|
+
.delta.down { color: var(--negative); }
|
|
62
|
+
.delta.flat { color: var(--muted); }
|
|
63
|
+
|
|
64
|
+
/* Charts */
|
|
65
|
+
.chart-row { display: grid; grid-template-columns: 1.6fr 1fr; gap: 14px; }
|
|
66
|
+
.card { padding: 18px 20px; background: var(--paper); border: 1px solid var(--line); border-radius: 10px; }
|
|
67
|
+
.card h3 { margin: 0 0 4px; font-size: 14px; font-weight: 600; }
|
|
68
|
+
.card .sub { font-size: 12px; color: var(--muted); }
|
|
69
|
+
.chart svg { width: 100%; height: 200px; display: block; margin-top: 8px; }
|
|
70
|
+
.legend { display: flex; gap: 14px; font-size: 11.5px; color: var(--muted); margin-top: 6px; }
|
|
71
|
+
.legend .swatch { display: inline-block; width: 8px; height: 8px; border-radius: 2px; margin-right: 6px; vertical-align: middle; }
|
|
72
|
+
.legend .a { background: var(--accent); }
|
|
73
|
+
.legend .b { background: var(--ink); opacity: 0.6; }
|
|
74
|
+
|
|
75
|
+
/* Bars */
|
|
76
|
+
.bars { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
|
|
77
|
+
.bar-row { display: grid; grid-template-columns: 110px 1fr 60px; gap: 10px; align-items: center; font-size: 12.5px; }
|
|
78
|
+
.bar-row .label { color: var(--muted); }
|
|
79
|
+
.bar-track { background: var(--accent-soft); border-radius: 4px; height: 10px; position: relative; overflow: hidden; }
|
|
80
|
+
.bar-fill { background: var(--accent); height: 100%; border-radius: 4px; }
|
|
81
|
+
.bar-value { font-family: var(--mono); font-size: 11.5px; text-align: right; color: var(--ink); }
|
|
82
|
+
|
|
83
|
+
/* Tables */
|
|
84
|
+
table { width: 100%; border-collapse: collapse; margin-top: 6px; }
|
|
85
|
+
th, td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--line); font-size: 13px; vertical-align: middle; }
|
|
86
|
+
th { font-family: var(--mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); border-bottom: 1px solid var(--line-strong); }
|
|
87
|
+
td.num, th.num { text-align: right; font-family: var(--mono); }
|
|
88
|
+
tr.total td { font-weight: 700; border-top: 2px solid var(--ink); border-bottom: none; padding-top: 14px; }
|
|
89
|
+
.badge { display: inline-block; padding: 2px 8px; font-size: 11px; border-radius: 999px; font-weight: 500; }
|
|
90
|
+
.badge.green { background: #e7f4ee; color: var(--positive); }
|
|
91
|
+
.badge.amber { background: #fbf0d6; color: #8a6912; }
|
|
92
|
+
.badge.red { background: #f7e1e1; color: var(--negative); }
|
|
93
|
+
.logo { display: inline-flex; width: 22px; height: 22px; border-radius: 6px; background: linear-gradient(135deg, var(--accent), #2c98c5); margin-right: 10px; vertical-align: middle; }
|
|
94
|
+
|
|
95
|
+
/* Outlook */
|
|
96
|
+
.outlook { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 12px; }
|
|
97
|
+
.outlook .quote { padding: 18px; background: var(--accent-soft); border-left: 3px solid var(--accent); border-radius: 6px; font-family: var(--display); font-size: 16px; line-height: 1.5; }
|
|
98
|
+
.outlook .signoff { font-size: 13px; color: var(--muted); }
|
|
99
|
+
.outlook .signoff strong { color: var(--ink); display: block; font-family: var(--display); font-size: 16px; margin-bottom: 2px; }
|
|
100
|
+
footer { margin-top: 40px; padding-top: 18px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; font-family: var(--mono); font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; }
|
|
101
|
+
|
|
102
|
+
@media (max-width: 760px) {
|
|
103
|
+
.page { padding: 32px 24px; margin: 0; border-radius: 0; }
|
|
104
|
+
.kpis { grid-template-columns: 1fr 1fr; }
|
|
105
|
+
.chart-row { grid-template-columns: 1fr; }
|
|
106
|
+
.outlook { grid-template-columns: 1fr; }
|
|
107
|
+
}
|
|
108
|
+
</style>
|
|
109
|
+
</head>
|
|
110
|
+
<body>
|
|
111
|
+
<div class="page">
|
|
112
|
+
<header class="masthead">
|
|
113
|
+
<div class="mast-left">
|
|
114
|
+
<div class="mast-meta">Northwind Trading · Q3 FY25</div>
|
|
115
|
+
<div class="mast-co">Quarterly Financial Report</div>
|
|
116
|
+
<div class="mast-meta">Prepared by Finance · Issued 14 October 2025</div>
|
|
117
|
+
</div>
|
|
118
|
+
<div class="mast-badge">Confidential</div>
|
|
119
|
+
</header>
|
|
120
|
+
|
|
121
|
+
<p class="lede">Q3 closed ahead of plan on revenue and gross margin, with cash runway extending to 27 months on the back of a leaner cost base. Mid-market and enterprise both expanded; SMB churn remains the watch item heading into Q4.</p>
|
|
122
|
+
|
|
123
|
+
<h2>Headline KPIs</h2>
|
|
124
|
+
<div class="kpis">
|
|
125
|
+
<div class="kpi">
|
|
126
|
+
<div class="label">Revenue</div>
|
|
127
|
+
<div class="value">$8.42M</div>
|
|
128
|
+
<div class="delta up">▲ 14.6% QoQ</div>
|
|
129
|
+
</div>
|
|
130
|
+
<div class="kpi">
|
|
131
|
+
<div class="label">Net new MRR</div>
|
|
132
|
+
<div class="value">$184k</div>
|
|
133
|
+
<div class="delta up">▲ 22.0% QoQ</div>
|
|
134
|
+
</div>
|
|
135
|
+
<div class="kpi">
|
|
136
|
+
<div class="label">Gross margin</div>
|
|
137
|
+
<div class="value">82%</div>
|
|
138
|
+
<div class="delta up">▲ 3 pp YoY</div>
|
|
139
|
+
</div>
|
|
140
|
+
<div class="kpi">
|
|
141
|
+
<div class="label">Cash runway</div>
|
|
142
|
+
<div class="value">27 mo</div>
|
|
143
|
+
<div class="delta up">▲ 4 mo QoQ</div>
|
|
144
|
+
</div>
|
|
145
|
+
</div>
|
|
146
|
+
|
|
147
|
+
<h2>Revenue & costs</h2>
|
|
148
|
+
<div class="chart-row">
|
|
149
|
+
<div class="card">
|
|
150
|
+
<h3>Revenue · trailing 12 months</h3>
|
|
151
|
+
<div class="sub">USD millions, monthly</div>
|
|
152
|
+
<div class="chart">
|
|
153
|
+
<svg viewBox="0 0 720 200" preserveAspectRatio="none">
|
|
154
|
+
<defs>
|
|
155
|
+
<linearGradient id="lg" x1="0" x2="0" y1="0" y2="1">
|
|
156
|
+
<stop offset="0%" stop-color="var(--accent)" stop-opacity="0.32"/>
|
|
157
|
+
<stop offset="100%" stop-color="var(--accent)" stop-opacity="0"/>
|
|
158
|
+
</linearGradient>
|
|
159
|
+
</defs>
|
|
160
|
+
<polygon fill="url(#lg)" points="20,180 20,150 80,140 140,128 200,118 260,110 320,98 380,92 440,80 500,72 560,60 620,52 680,40 700,40 700,180" />
|
|
161
|
+
<polyline fill="none" stroke="var(--accent)" stroke-width="2.5" stroke-linejoin="round" stroke-linecap="round"
|
|
162
|
+
points="20,150 80,140 140,128 200,118 260,110 320,98 380,92 440,80 500,72 560,60 620,52 680,40" />
|
|
163
|
+
<polyline fill="none" stroke="#11141a" stroke-opacity="0.45" stroke-width="1.5" stroke-dasharray="3 3"
|
|
164
|
+
points="20,165 80,158 140,150 200,142 260,134 320,128 380,122 440,116 500,108 560,102 620,96 680,90" />
|
|
165
|
+
<circle cx="680" cy="40" r="3.5" fill="var(--accent)"/>
|
|
166
|
+
</svg>
|
|
167
|
+
<div class="legend">
|
|
168
|
+
<span><span class="swatch a"></span>Revenue</span>
|
|
169
|
+
<span><span class="swatch b"></span>Plan</span>
|
|
170
|
+
</div>
|
|
171
|
+
</div>
|
|
172
|
+
</div>
|
|
173
|
+
<div class="card">
|
|
174
|
+
<h3>Operating costs</h3>
|
|
175
|
+
<div class="sub">USD thousands, Q3</div>
|
|
176
|
+
<div class="bars">
|
|
177
|
+
<div class="bar-row"><span class="label">R&D</span><div class="bar-track"><div class="bar-fill" style="width: 78%"></div></div><span class="bar-value">$1.42M</span></div>
|
|
178
|
+
<div class="bar-row"><span class="label">Sales & GTM</span><div class="bar-track"><div class="bar-fill" style="width: 60%"></div></div><span class="bar-value">$1.10M</span></div>
|
|
179
|
+
<div class="bar-row"><span class="label">G&A</span><div class="bar-track"><div class="bar-fill" style="width: 36%"></div></div><span class="bar-value">$660k</span></div>
|
|
180
|
+
<div class="bar-row"><span class="label">Marketing</span><div class="bar-track"><div class="bar-fill" style="width: 28%"></div></div><span class="bar-value">$510k</span></div>
|
|
181
|
+
<div class="bar-row"><span class="label">Infrastructure</span><div class="bar-track"><div class="bar-fill" style="width: 18%"></div></div><span class="bar-value">$330k</span></div>
|
|
182
|
+
</div>
|
|
183
|
+
</div>
|
|
184
|
+
</div>
|
|
185
|
+
|
|
186
|
+
<h2>P&L summary</h2>
|
|
187
|
+
<table>
|
|
188
|
+
<thead>
|
|
189
|
+
<tr>
|
|
190
|
+
<th>Line item</th>
|
|
191
|
+
<th class="num">Q3 FY25</th>
|
|
192
|
+
<th class="num">Q2 FY25</th>
|
|
193
|
+
<th class="num">Δ QoQ</th>
|
|
194
|
+
<th class="num">Q3 FY24</th>
|
|
195
|
+
<th class="num">Δ YoY</th>
|
|
196
|
+
</tr>
|
|
197
|
+
</thead>
|
|
198
|
+
<tbody>
|
|
199
|
+
<tr><td>Revenue</td><td class="num">$8.42M</td><td class="num">$7.34M</td><td class="num" style="color: var(--positive);">+14.6%</td><td class="num">$5.92M</td><td class="num" style="color: var(--positive);">+42.2%</td></tr>
|
|
200
|
+
<tr><td>Cost of revenue</td><td class="num">($1.51M)</td><td class="num">($1.46M)</td><td class="num" style="color: var(--negative);">+3.4%</td><td class="num">($1.18M)</td><td class="num" style="color: var(--negative);">+28.0%</td></tr>
|
|
201
|
+
<tr><td>Gross profit</td><td class="num">$6.91M</td><td class="num">$5.88M</td><td class="num" style="color: var(--positive);">+17.5%</td><td class="num">$4.74M</td><td class="num" style="color: var(--positive);">+45.8%</td></tr>
|
|
202
|
+
<tr><td>Operating expenses</td><td class="num">($4.02M)</td><td class="num">($4.18M)</td><td class="num" style="color: var(--positive);">−3.8%</td><td class="num">($3.66M)</td><td class="num" style="color: var(--negative);">+9.8%</td></tr>
|
|
203
|
+
<tr class="total"><td>Operating income</td><td class="num">$2.89M</td><td class="num">$1.70M</td><td class="num" style="color: var(--positive);">+70.0%</td><td class="num">$1.08M</td><td class="num" style="color: var(--positive);">+167.5%</td></tr>
|
|
204
|
+
</tbody>
|
|
205
|
+
</table>
|
|
206
|
+
|
|
207
|
+
<h2>Top accounts</h2>
|
|
208
|
+
<table>
|
|
209
|
+
<thead>
|
|
210
|
+
<tr>
|
|
211
|
+
<th>Customer</th>
|
|
212
|
+
<th>Plan</th>
|
|
213
|
+
<th>Region</th>
|
|
214
|
+
<th class="num">ARR</th>
|
|
215
|
+
<th>Status</th>
|
|
216
|
+
</tr>
|
|
217
|
+
</thead>
|
|
218
|
+
<tbody>
|
|
219
|
+
<tr><td><span class="logo"></span>Pioneer Robotics</td><td>Enterprise</td><td>EMEA</td><td class="num">$612k</td><td><span class="badge green">Renewed</span></td></tr>
|
|
220
|
+
<tr><td><span class="logo"></span>Atlas Cooperative</td><td>Enterprise</td><td>APAC</td><td class="num">$486k</td><td><span class="badge green">Expanded</span></td></tr>
|
|
221
|
+
<tr><td><span class="logo"></span>Foundry Group</td><td>Team Plus</td><td>NA</td><td class="num">$320k</td><td><span class="badge amber">In renewal</span></td></tr>
|
|
222
|
+
<tr><td><span class="logo"></span>Voltage Co.</td><td>Enterprise</td><td>NA</td><td class="num">$298k</td><td><span class="badge green">Renewed</span></td></tr>
|
|
223
|
+
<tr><td><span class="logo"></span>Lattice Health</td><td>Team Plus</td><td>EMEA</td><td class="num">$214k</td><td><span class="badge red">At risk</span></td></tr>
|
|
224
|
+
</tbody>
|
|
225
|
+
</table>
|
|
226
|
+
|
|
227
|
+
<h2>Outlook · Q4</h2>
|
|
228
|
+
<div class="outlook">
|
|
229
|
+
<div class="quote">"We're entering Q4 with the strongest pipeline coverage of the year — 3.4× plan — and the operating leverage to convert it without expanding the cost base."</div>
|
|
230
|
+
<div class="signoff">
|
|
231
|
+
<strong>Mira Okafor, CFO</strong>
|
|
232
|
+
We expect revenue of $9.1–9.4M, net new MRR of $200–220k, and gross margin holding above 80%. The two open items are SMB churn (we'll publish a recovery plan with the November update) and the EMEA infra migration, which moves to GA in mid-November.
|
|
233
|
+
</div>
|
|
234
|
+
</div>
|
|
235
|
+
|
|
236
|
+
<footer>
|
|
237
|
+
<span>Northwind Trading · Q3 FY25 · Internal use only</span>
|
|
238
|
+
<span>Page 1 of 1</span>
|
|
239
|
+
</footer>
|
|
240
|
+
</div>
|
|
241
|
+
</body>
|
|
242
|
+
</html>
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: flowai-live-dashboard-template
|
|
3
|
+
description: |
|
|
4
|
+
Team-management dashboard skill in the FlowAI aesthetic — three tabs
|
|
5
|
+
(Team Members, Team Details, Activity Log), KPI stat row, member table,
|
|
6
|
+
role distribution bar chart, online presence and activity sparklines,
|
|
7
|
+
and a top-contributors panel, all in a single self-contained HTML file
|
|
8
|
+
with light/dark theming, hoverable chart tooltips, click-to-zoom panels,
|
|
9
|
+
and CSV export. Use when the brief asks for a team / workspace admin
|
|
10
|
+
dashboard, an interactive admin dashboard with charts, or names FlowAI.
|
|
11
|
+
triggers:
|
|
12
|
+
- "flowai dashboard"
|
|
13
|
+
- "team dashboard"
|
|
14
|
+
- "team management dashboard"
|
|
15
|
+
- "interactive admin dashboard"
|
|
16
|
+
- "workspace admin dashboard"
|
|
17
|
+
- "团队管理后台"
|
|
18
|
+
- "可交互后台"
|
|
19
|
+
od:
|
|
20
|
+
mode: prototype
|
|
21
|
+
platform: desktop
|
|
22
|
+
scenario: operations
|
|
23
|
+
preview:
|
|
24
|
+
type: html
|
|
25
|
+
entry: index.html
|
|
26
|
+
reload: debounce-100
|
|
27
|
+
design_system:
|
|
28
|
+
requires: true
|
|
29
|
+
sections: [color, typography, layout, components]
|
|
30
|
+
craft:
|
|
31
|
+
requires: [state-coverage, accessibility-baseline]
|
|
32
|
+
example_prompt: "Create a FlowAI-style team management dashboard with Team Members, Team Details and Activity Log tabs, KPI cards, a member table with status badges, a role-distribution bar chart, an online-presence sparkline, top contributors, light/dark mode, and CSV export."
|
|
33
|
+
---
|
|
34
|
+
|
|
35
|
+
# FlowAI Dashboard Skill
|
|
36
|
+
|
|
37
|
+
Produce a single-screen, multi-tab team management dashboard inspired by the
|
|
38
|
+
FlowAI aesthetic. The output is a self-contained HTML file (no external runtime
|
|
39
|
+
dependencies) with built-in interactions: tab switching, an animated bar chart,
|
|
40
|
+
hover tooltips on charts, click-to-zoom panels, dark mode toggle, and CSV
|
|
41
|
+
export of the visible team table.
|
|
42
|
+
|
|
43
|
+
## Resource map
|
|
44
|
+
|
|
45
|
+
```
|
|
46
|
+
flowai-live-dashboard-template/
|
|
47
|
+
├── SKILL.md
|
|
48
|
+
├── assets/
|
|
49
|
+
│ └── template.html # reference seed used as the starting structure
|
|
50
|
+
├── references/
|
|
51
|
+
│ └── checklist.md # P0/P1/P2 quality gates
|
|
52
|
+
└── example.html # complete hand-built sample (gallery preview)
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
## Workflow
|
|
56
|
+
|
|
57
|
+
1. **Read the active DESIGN.md** (injected above). Map color, typography,
|
|
58
|
+
spacing, and component styling tokens to the CSS variables used by
|
|
59
|
+
`assets/template.html`. Do not invent new tokens.
|
|
60
|
+
2. Start from `assets/template.html`; never generate the shell from blank.
|
|
61
|
+
3. Keep three tabs: `Team Members`, `Team Details`, `Activity Log`. Tabs must
|
|
62
|
+
actually switch and only one view is visible at a time.
|
|
63
|
+
4. Generate plausible, specific sample data (real-looking names, IDs, roles,
|
|
64
|
+
departments, dates, percentages). No `Member A / Metric B` placeholders.
|
|
65
|
+
5. Required interactions:
|
|
66
|
+
- tab switching with hash sync (`#members | #details | #activity`)
|
|
67
|
+
- role bar chart animates with easing on first reveal of the details tab
|
|
68
|
+
- chart hover tooltips with precise label + value
|
|
69
|
+
- click any panel/card to zoom; click again or press Esc to restore
|
|
70
|
+
- dark mode toggle that re-derives chart colors from CSS variables
|
|
71
|
+
- "Export CSV" button that exports every row currently in the team table,
|
|
72
|
+
including the `Workflow` column
|
|
73
|
+
6. Run through `references/checklist.md` before final output.
|
|
74
|
+
|
|
75
|
+
## Output contract
|
|
76
|
+
|
|
77
|
+
Emit one short orientation sentence, then the artifact:
|
|
78
|
+
|
|
79
|
+
```xml
|
|
80
|
+
<artifact identifier="flowai-team-dashboard" type="text/html" title="FlowAI Team Dashboard">
|
|
81
|
+
<!doctype html>
|
|
82
|
+
<html>...</html>
|
|
83
|
+
</artifact>
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
The artifact must render correctly when opened directly from disk with no
|
|
87
|
+
build step and no network access.
|