@jaimevalasek/aioson 1.4.0 → 1.6.0

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.
Files changed (301) hide show
  1. package/CHANGELOG.md +31 -1
  2. package/LICENSE +661 -21
  3. package/README.md +9 -1
  4. package/docs/design-previews/aurora-command-ui-website.html +884 -0
  5. package/docs/design-previews/aurora-command-ui.html +682 -0
  6. package/docs/design-previews/bold-editorial-ui-website.html +658 -0
  7. package/docs/design-previews/bold-editorial-ui.html +717 -0
  8. package/docs/design-previews/clean-saas-ui-website.html +1202 -0
  9. package/docs/design-previews/clean-saas-ui.html +549 -0
  10. package/docs/design-previews/cognitive-core-ui-website.html +1009 -0
  11. package/docs/design-previews/cognitive-core-ui.html +463 -0
  12. package/docs/design-previews/glassmorphism-ui-website.html +572 -0
  13. package/docs/design-previews/glassmorphism-ui.html +886 -0
  14. package/docs/design-previews/index.html +699 -0
  15. package/docs/design-previews/interface-design-website.html +1187 -0
  16. package/docs/design-previews/interface-design.html +513 -0
  17. package/docs/design-previews/neo-brutalist-ui-website.html +621 -0
  18. package/docs/design-previews/neo-brutalist-ui.html +797 -0
  19. package/docs/design-previews/premium-command-center-ui-website.html +1217 -0
  20. package/docs/design-previews/premium-command-center-ui.html +552 -0
  21. package/docs/design-previews/warm-craft-ui-website.html +684 -0
  22. package/docs/design-previews/warm-craft-ui.html +739 -0
  23. package/docs/en/cli-reference.md +20 -9
  24. package/docs/en/squad-dashboard.md +372 -0
  25. package/docs/openclaw-bridge.md +308 -0
  26. package/docs/pt/README.md +7 -0
  27. package/docs/pt/agent-sharding.md +132 -0
  28. package/docs/pt/agentes.md +131 -11
  29. package/docs/pt/busca-de-contexto.md +129 -0
  30. package/docs/pt/cache-de-contexto.md +156 -0
  31. package/docs/pt/cenarios.md +46 -2
  32. package/docs/pt/comandos-cli.md +88 -1
  33. package/docs/pt/design-hybrid-forge.md +107 -0
  34. package/docs/pt/inicio-rapido.md +72 -5
  35. package/docs/pt/inteligencia-adaptativa.md +324 -0
  36. package/docs/pt/monitor-de-contexto.md +104 -0
  37. package/docs/pt/recuperacao-de-sessao.md +125 -0
  38. package/docs/pt/sandbox.md +125 -0
  39. package/docs/pt/skills.md +98 -6
  40. package/docs/pt/squad-dashboard.md +373 -0
  41. package/docs/testing/genome-2.0-matrix.md +5 -5
  42. package/docs/testing/genome-2.0-rollout.md +9 -9
  43. package/package.json +2 -2
  44. package/src/agent-loader.js +280 -0
  45. package/src/backup-local.js +74 -0
  46. package/src/cli.js +192 -0
  47. package/src/commands/agent-loader.js +85 -0
  48. package/src/commands/backup-local-cmd.js +25 -0
  49. package/src/commands/context-cache.js +90 -0
  50. package/src/commands/context-monitor.js +92 -0
  51. package/src/commands/context-search.js +66 -0
  52. package/src/commands/design-hybrid-options.js +385 -0
  53. package/src/commands/health.js +214 -0
  54. package/src/commands/init.js +54 -13
  55. package/src/commands/install.js +52 -13
  56. package/src/commands/learning-evolve.js +355 -0
  57. package/src/commands/live.js +34 -0
  58. package/src/commands/recovery.js +43 -0
  59. package/src/commands/runtime.js +242 -0
  60. package/src/commands/sandbox.js +37 -0
  61. package/src/commands/setup-context.js +29 -4
  62. package/src/commands/setup.js +178 -0
  63. package/src/commands/skill.js +79 -32
  64. package/src/commands/squad-daemon.js +209 -0
  65. package/src/commands/squad-dashboard.js +39 -0
  66. package/src/commands/squad-deploy.js +64 -0
  67. package/src/commands/squad-doctor.js +52 -0
  68. package/src/commands/squad-mcp.js +270 -0
  69. package/src/commands/squad-processes.js +56 -0
  70. package/src/commands/squad-recovery.js +42 -0
  71. package/src/commands/squad-roi.js +291 -0
  72. package/src/commands/squad-score.js +250 -0
  73. package/src/commands/squad-status.js +37 -1
  74. package/src/commands/squad-validate.js +62 -1
  75. package/src/commands/squad-webhook.js +160 -0
  76. package/src/commands/squad-worker.js +191 -0
  77. package/src/commands/squad-worktrees.js +75 -0
  78. package/src/commands/tool-registry-cmd.js +232 -0
  79. package/src/commands/update.js +7 -0
  80. package/src/commands/web-map.js +70 -0
  81. package/src/commands/web-scrape.js +71 -0
  82. package/src/constants.js +17 -0
  83. package/src/context-cache.js +159 -0
  84. package/src/context-search.js +326 -0
  85. package/src/context-writer.js +45 -1
  86. package/src/design-variation-catalog.js +503 -0
  87. package/src/i18n/messages/en.js +159 -3
  88. package/src/i18n/messages/es.js +147 -2
  89. package/src/i18n/messages/fr.js +147 -2
  90. package/src/i18n/messages/pt-BR.js +158 -3
  91. package/src/install-animation.js +260 -0
  92. package/src/install-profile.js +143 -0
  93. package/src/install-wizard.js +474 -0
  94. package/src/installer.js +38 -10
  95. package/src/lib/webhook-server.js +328 -0
  96. package/src/mcp-connectors/registry.js +602 -0
  97. package/src/parser.js +7 -1
  98. package/src/recovery-context-session.js +154 -0
  99. package/src/runtime-store.js +355 -2
  100. package/src/sandbox.js +177 -0
  101. package/src/squad/external-session.js +180 -0
  102. package/src/squad/inter-squad.js +74 -0
  103. package/src/squad/recovery-context.js +201 -0
  104. package/src/squad/worktree-manager.js +114 -0
  105. package/src/squad-daemon.js +490 -0
  106. package/src/squad-dashboard/api.js +223 -0
  107. package/src/squad-dashboard/attachment-handler.js +93 -0
  108. package/src/squad-dashboard/context-monitor.js +157 -0
  109. package/src/squad-dashboard/execution-logs.js +115 -0
  110. package/src/squad-dashboard/hunk-review.js +209 -0
  111. package/src/squad-dashboard/metrics.js +133 -0
  112. package/src/squad-dashboard/process-monitor.js +125 -0
  113. package/src/squad-dashboard/renderer.js +858 -0
  114. package/src/squad-dashboard/server.js +232 -0
  115. package/src/squad-dashboard/styles.js +525 -0
  116. package/src/squad-dashboard/token-tracker.js +99 -0
  117. package/src/tool-executor.js +94 -0
  118. package/src/updater.js +11 -3
  119. package/src/web.js +284 -0
  120. package/src/worker-runner.js +339 -0
  121. package/template/.aioson/agents/analyst.md +62 -3
  122. package/template/.aioson/agents/architect.md +42 -0
  123. package/template/.aioson/agents/design-hybrid-forge.md +127 -0
  124. package/template/.aioson/agents/dev.md +223 -11
  125. package/template/.aioson/agents/deyvin.md +65 -0
  126. package/template/.aioson/agents/neo.md +152 -0
  127. package/template/.aioson/agents/orache.md +17 -0
  128. package/template/.aioson/agents/orchestrator.md +26 -0
  129. package/template/.aioson/agents/pm.md +58 -0
  130. package/template/.aioson/agents/product.md +88 -12
  131. package/template/.aioson/agents/qa.md +80 -0
  132. package/template/.aioson/agents/setup.md +128 -22
  133. package/template/.aioson/agents/sheldon.md +704 -0
  134. package/template/.aioson/agents/squad.md +191 -0
  135. package/template/.aioson/agents/tester.md +410 -0
  136. package/template/.aioson/agents/ux-ui.md +12 -0
  137. package/template/.aioson/config.md +21 -0
  138. package/template/.aioson/context/forensics/.gitkeep +0 -0
  139. package/template/.aioson/context/seeds/seed-example.md +27 -0
  140. package/template/.aioson/context/user-profile.md +42 -0
  141. package/template/.aioson/locales/en/agents/analyst.md +8 -0
  142. package/template/.aioson/locales/en/agents/architect.md +8 -0
  143. package/template/.aioson/locales/en/agents/dev.md +66 -7
  144. package/template/.aioson/locales/en/agents/deyvin.md +8 -0
  145. package/template/.aioson/locales/en/agents/neo.md +8 -0
  146. package/template/.aioson/locales/en/agents/orchestrator.md +26 -0
  147. package/template/.aioson/locales/en/agents/qa.md +49 -0
  148. package/template/.aioson/locales/en/agents/setup.md +35 -2
  149. package/template/.aioson/locales/en/agents/sheldon.md +340 -0
  150. package/template/.aioson/locales/en/agents/ux-ui.md +8 -0
  151. package/template/.aioson/locales/es/agents/analyst.md +8 -0
  152. package/template/.aioson/locales/es/agents/architect.md +8 -0
  153. package/template/.aioson/locales/es/agents/dev.md +66 -7
  154. package/template/.aioson/locales/es/agents/deyvin.md +8 -0
  155. package/template/.aioson/locales/es/agents/neo.md +48 -0
  156. package/template/.aioson/locales/es/agents/orchestrator.md +26 -0
  157. package/template/.aioson/locales/es/agents/qa.md +26 -0
  158. package/template/.aioson/locales/es/agents/setup.md +35 -2
  159. package/template/.aioson/locales/es/agents/sheldon.md +192 -0
  160. package/template/.aioson/locales/es/agents/squad.md +63 -0
  161. package/template/.aioson/locales/es/agents/ux-ui.md +8 -0
  162. package/template/.aioson/locales/fr/agents/analyst.md +8 -0
  163. package/template/.aioson/locales/fr/agents/architect.md +8 -0
  164. package/template/.aioson/locales/fr/agents/dev.md +66 -7
  165. package/template/.aioson/locales/fr/agents/deyvin.md +8 -0
  166. package/template/.aioson/locales/fr/agents/neo.md +48 -0
  167. package/template/.aioson/locales/fr/agents/orchestrator.md +26 -0
  168. package/template/.aioson/locales/fr/agents/qa.md +26 -0
  169. package/template/.aioson/locales/fr/agents/setup.md +35 -2
  170. package/template/.aioson/locales/fr/agents/sheldon.md +192 -0
  171. package/template/.aioson/locales/fr/agents/squad.md +63 -0
  172. package/template/.aioson/locales/fr/agents/ux-ui.md +8 -0
  173. package/template/.aioson/locales/pt-BR/agents/analyst.md +19 -0
  174. package/template/.aioson/locales/pt-BR/agents/architect.md +19 -0
  175. package/template/.aioson/locales/pt-BR/agents/dev.md +75 -12
  176. package/template/.aioson/locales/pt-BR/agents/deyvin.md +8 -0
  177. package/template/.aioson/locales/pt-BR/agents/neo.md +147 -0
  178. package/template/.aioson/locales/pt-BR/agents/orchestrator.md +26 -0
  179. package/template/.aioson/locales/pt-BR/agents/product.md +8 -3
  180. package/template/.aioson/locales/pt-BR/agents/qa.md +60 -0
  181. package/template/.aioson/locales/pt-BR/agents/setup.md +35 -2
  182. package/template/.aioson/locales/pt-BR/agents/sheldon.md +192 -0
  183. package/template/.aioson/locales/pt-BR/agents/squad.md +105 -0
  184. package/template/.aioson/locales/pt-BR/agents/ux-ui.md +8 -0
  185. package/template/.aioson/schemas/squad-blueprint.schema.json +21 -0
  186. package/template/.aioson/schemas/squad-manifest.schema.json +178 -1
  187. package/template/.aioson/skills/design/aurora-command-ui/SKILL.md +243 -0
  188. package/template/.aioson/skills/design/aurora-command-ui/references/art-direction.md +293 -0
  189. package/template/.aioson/skills/design/aurora-command-ui/references/components.md +827 -0
  190. package/template/.aioson/skills/design/aurora-command-ui/references/dashboards.md +250 -0
  191. package/template/.aioson/skills/design/aurora-command-ui/references/design-tokens.md +585 -0
  192. package/template/.aioson/skills/design/aurora-command-ui/references/motion.md +365 -0
  193. package/template/.aioson/skills/design/aurora-command-ui/references/patterns.md +482 -0
  194. package/template/.aioson/skills/design/aurora-command-ui/references/websites.md +387 -0
  195. package/template/.aioson/skills/design/bold-editorial-ui/SKILL.md +205 -0
  196. package/template/.aioson/skills/design/bold-editorial-ui/references/art-direction.md +338 -0
  197. package/template/.aioson/skills/design/bold-editorial-ui/references/components.md +977 -0
  198. package/template/.aioson/skills/design/bold-editorial-ui/references/dashboards.md +218 -0
  199. package/template/.aioson/skills/design/bold-editorial-ui/references/design-tokens.md +326 -0
  200. package/template/.aioson/skills/design/bold-editorial-ui/references/motion.md +461 -0
  201. package/template/.aioson/skills/design/bold-editorial-ui/references/patterns.md +293 -0
  202. package/template/.aioson/skills/design/bold-editorial-ui/references/websites.md +352 -0
  203. package/template/.aioson/skills/design/clean-saas-ui/SKILL.md +210 -0
  204. package/template/.aioson/skills/design/clean-saas-ui/references/art-direction.md +319 -0
  205. package/template/.aioson/skills/design/clean-saas-ui/references/components.md +365 -0
  206. package/template/.aioson/skills/design/clean-saas-ui/references/dashboards.md +196 -0
  207. package/template/.aioson/skills/design/clean-saas-ui/references/design-tokens.md +244 -0
  208. package/template/.aioson/skills/design/clean-saas-ui/references/motion.md +235 -0
  209. package/template/.aioson/skills/design/clean-saas-ui/references/patterns.md +215 -0
  210. package/template/.aioson/skills/design/clean-saas-ui/references/websites.md +295 -0
  211. package/template/.aioson/skills/design/cognitive-core-ui/SKILL.md +55 -9
  212. package/template/.aioson/skills/design/cognitive-core-ui/references/art-direction.md +339 -0
  213. package/template/.aioson/skills/design/cognitive-core-ui/references/components.md +1 -1
  214. package/template/.aioson/skills/design/cognitive-core-ui/references/dashboards.md +100 -0
  215. package/template/.aioson/skills/design/cognitive-core-ui/references/design-tokens.md +43 -9
  216. package/template/.aioson/skills/design/cognitive-core-ui/references/motion.md +40 -0
  217. package/template/.aioson/skills/design/cognitive-core-ui/references/patterns.md +1 -1
  218. package/template/.aioson/skills/design/cognitive-core-ui/references/websites.md +99 -12
  219. package/template/.aioson/skills/design/glassmorphism-ui/SKILL.md +222 -0
  220. package/template/.aioson/skills/design/glassmorphism-ui/references/art-direction.md +159 -0
  221. package/template/.aioson/skills/design/glassmorphism-ui/references/components.md +498 -0
  222. package/template/.aioson/skills/design/glassmorphism-ui/references/dashboards.md +236 -0
  223. package/template/.aioson/skills/design/glassmorphism-ui/references/design-tokens.md +274 -0
  224. package/template/.aioson/skills/design/glassmorphism-ui/references/motion.md +355 -0
  225. package/template/.aioson/skills/design/glassmorphism-ui/references/patterns.md +198 -0
  226. package/template/.aioson/skills/design/glassmorphism-ui/references/websites.md +307 -0
  227. package/template/.aioson/skills/design/neo-brutalist-ui/SKILL.md +213 -0
  228. package/template/.aioson/skills/design/neo-brutalist-ui/references/art-direction.md +228 -0
  229. package/template/.aioson/skills/design/neo-brutalist-ui/references/components.md +855 -0
  230. package/template/.aioson/skills/design/neo-brutalist-ui/references/dashboards.md +334 -0
  231. package/template/.aioson/skills/design/neo-brutalist-ui/references/design-tokens.md +342 -0
  232. package/template/.aioson/skills/design/neo-brutalist-ui/references/motion.md +286 -0
  233. package/template/.aioson/skills/design/neo-brutalist-ui/references/patterns.md +458 -0
  234. package/template/.aioson/skills/design/neo-brutalist-ui/references/websites.md +723 -0
  235. package/template/.aioson/skills/design/warm-craft-ui/SKILL.md +209 -0
  236. package/template/.aioson/skills/design/warm-craft-ui/references/art-direction.md +324 -0
  237. package/template/.aioson/skills/design/warm-craft-ui/references/components.md +508 -0
  238. package/template/.aioson/skills/design/warm-craft-ui/references/dashboards.md +223 -0
  239. package/template/.aioson/skills/design/warm-craft-ui/references/design-tokens.md +374 -0
  240. package/template/.aioson/skills/design/warm-craft-ui/references/motion.md +356 -0
  241. package/template/.aioson/skills/design/warm-craft-ui/references/patterns.md +288 -0
  242. package/template/.aioson/skills/design/warm-craft-ui/references/websites.md +289 -0
  243. package/template/.aioson/skills/premium-visual-design/SKILL.md +83 -0
  244. package/template/.aioson/skills/premium-visual-design/components/agent-badge.md +92 -0
  245. package/template/.aioson/skills/premium-visual-design/components/dependency-node.md +102 -0
  246. package/template/.aioson/skills/premium-visual-design/components/mention-autocomplete.md +136 -0
  247. package/template/.aioson/skills/premium-visual-design/components/notification-center.md +136 -0
  248. package/template/.aioson/skills/premium-visual-design/components/review-action-bar.md +188 -0
  249. package/template/.aioson/skills/premium-visual-design/components/team-switcher.md +131 -0
  250. package/template/.aioson/skills/premium-visual-design/patterns/agent-message-thread.md +198 -0
  251. package/template/.aioson/skills/premium-visual-design/patterns/notification-panel.md +275 -0
  252. package/template/.aioson/skills/premium-visual-design/patterns/review-workflow-ui.md +234 -0
  253. package/template/.aioson/skills/premium-visual-design/patterns/task-dependency-graph.md +147 -0
  254. package/template/.aioson/skills/premium-visual-design/tokens/status-extended.md +142 -0
  255. package/template/.aioson/skills/process/aioson-spec-driven/SKILL.md +45 -0
  256. package/template/.aioson/skills/process/aioson-spec-driven/references/approval-gates.md +109 -0
  257. package/template/.aioson/skills/process/aioson-spec-driven/references/artifact-map.md +44 -0
  258. package/template/.aioson/skills/process/aioson-spec-driven/references/classification-map.md +37 -0
  259. package/template/.aioson/skills/process/aioson-spec-driven/references/hardening-lane.md +49 -0
  260. package/template/.aioson/skills/process/aioson-spec-driven/references/maintenance-and-state.md +66 -0
  261. package/template/.aioson/skills/process/aioson-spec-driven/references/ui-language.md +75 -0
  262. package/template/.aioson/skills/process/design-hybrid-forge/SKILL.md +144 -0
  263. package/template/.aioson/skills/process/design-hybrid-forge/references/crossover-protocol.md +221 -0
  264. package/template/.aioson/skills/process/design-hybrid-forge/references/naming-registry.md +88 -0
  265. package/template/.aioson/skills/process/design-hybrid-forge/references/output-contract.md +291 -0
  266. package/template/.aioson/skills/process/design-hybrid-forge/references/pair-compatibility.md +117 -0
  267. package/template/.aioson/skills/process/design-hybrid-forge/references/quality-gates.md +188 -0
  268. package/template/.aioson/skills/process/design-hybrid-forge/references/variation-library.md +125 -0
  269. package/template/.aioson/skills/squad/formats/catalog.json +15 -0
  270. package/template/.aioson/skills/squad/formats/content/blog-post.md +47 -0
  271. package/template/.aioson/skills/squad/formats/content/newsletter.md +47 -0
  272. package/template/.aioson/skills/squad/formats/creative/podcast-script.md +43 -0
  273. package/template/.aioson/skills/squad/formats/creative/video-script.md +41 -0
  274. package/template/.aioson/skills/squad/formats/social/instagram-feed.md +42 -0
  275. package/template/.aioson/skills/squad/formats/social/linkedin-post.md +42 -0
  276. package/template/.aioson/skills/squad/formats/social/tiktok.md +39 -0
  277. package/template/.aioson/skills/squad/formats/social/twitter-thread.md +39 -0
  278. package/template/.aioson/skills/squad/formats/social/youtube-long.md +47 -0
  279. package/template/.aioson/skills/squad/formats/social/youtube-shorts.md +39 -0
  280. package/template/.aioson/skills/squad/patterns/multi-platform-pattern.md +108 -0
  281. package/template/.aioson/skills/squad/patterns/persona-based-pattern.md +98 -0
  282. package/template/.aioson/skills/squad/patterns/pipeline-pattern.md +106 -0
  283. package/template/.aioson/skills/squad/patterns/review-loop-pattern.md +81 -0
  284. package/template/.aioson/skills/squad/references/checklist-templates.md +122 -0
  285. package/template/.aioson/skills/squad/references/executor-archetypes.md +123 -0
  286. package/template/.aioson/skills/squad/references/workflow-templates.md +169 -0
  287. package/template/.aioson/skills/static/debugging-protocol.md +42 -0
  288. package/template/.aioson/skills/static/git-worktrees.md +36 -0
  289. package/template/.aioson/tasks/implementation-plan.md +19 -0
  290. package/template/.aioson/tasks/squad-design.md +28 -0
  291. package/template/.aioson/tasks/squad-profile.md +48 -0
  292. package/template/.aioson/tasks/squad-review.md +61 -0
  293. package/template/.aioson/tasks/squad-task-decompose.md +66 -0
  294. package/template/.claude/commands/aioson/agent/neo.md +5 -0
  295. package/template/.claude/commands/aioson/agent/tester.md +5 -0
  296. package/template/.gemini/GEMINI.md +1 -0
  297. package/template/.gemini/commands/aios-neo.toml +4 -0
  298. package/template/.gemini/commands/aios-tester.toml +6 -0
  299. package/template/AGENTS.md +26 -1
  300. package/template/CLAUDE.md +6 -2
  301. package/template/OPENCODE.md +2 -0
@@ -0,0 +1,525 @@
1
+ 'use strict';
2
+
3
+ function getInlineCSS() {
4
+ return `
5
+ :root {
6
+ --bg: #0f1117;
7
+ --bg-card: #1a1d27;
8
+ --bg-hover: #222632;
9
+ --border: #2a2e3a;
10
+ --text: #e1e4eb;
11
+ --text-muted: #8b8fa3;
12
+ --accent: #6c8aff;
13
+ --accent-dim: rgba(108,138,255,0.15);
14
+ --success: #4ade80;
15
+ --success-dim: rgba(74,222,128,0.15);
16
+ --warning: #fbbf24;
17
+ --warning-dim: rgba(251,191,36,0.15);
18
+ --danger: #f87171;
19
+ --danger-dim: rgba(248,113,113,0.15);
20
+ --radius: 8px;
21
+ --font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, monospace;
22
+ }
23
+ * { margin: 0; padding: 0; box-sizing: border-box; }
24
+ body {
25
+ font-family: var(--font);
26
+ background: var(--bg);
27
+ color: var(--text);
28
+ line-height: 1.6;
29
+ min-height: 100vh;
30
+ }
31
+ a { color: var(--accent); text-decoration: none; }
32
+ a:hover { text-decoration: underline; }
33
+
34
+ /* Layout */
35
+ .layout { display: flex; min-height: 100vh; }
36
+ .sidebar {
37
+ width: 240px;
38
+ background: var(--bg-card);
39
+ border-right: 1px solid var(--border);
40
+ padding: 20px 0;
41
+ position: fixed;
42
+ top: 0; left: 0; bottom: 0;
43
+ overflow-y: auto;
44
+ }
45
+ .main { margin-left: 240px; padding: 24px; flex: 1; width: calc(100% - 240px); }
46
+
47
+ .sidebar h1 {
48
+ font-size: 14px;
49
+ font-weight: 600;
50
+ color: var(--text-muted);
51
+ text-transform: uppercase;
52
+ letter-spacing: 0.5px;
53
+ padding: 0 20px 16px;
54
+ border-bottom: 1px solid var(--border);
55
+ margin-bottom: 8px;
56
+ }
57
+ .sidebar a {
58
+ display: block;
59
+ padding: 8px 20px;
60
+ color: var(--text);
61
+ font-size: 14px;
62
+ transition: background 0.15s;
63
+ }
64
+ .sidebar a:hover { background: var(--bg-hover); text-decoration: none; }
65
+ .sidebar a.active { background: var(--accent-dim); color: var(--accent); border-right: 2px solid var(--accent); }
66
+ .sidebar .squad-mode {
67
+ display: inline-block;
68
+ font-size: 10px;
69
+ padding: 1px 6px;
70
+ border-radius: 4px;
71
+ background: var(--accent-dim);
72
+ color: var(--accent);
73
+ margin-left: 6px;
74
+ vertical-align: middle;
75
+ }
76
+
77
+ /* Header */
78
+ .page-header {
79
+ display: flex;
80
+ align-items: center;
81
+ justify-content: space-between;
82
+ margin-bottom: 24px;
83
+ padding-bottom: 16px;
84
+ border-bottom: 1px solid var(--border);
85
+ }
86
+ .page-header h2 { font-size: 20px; font-weight: 600; }
87
+ .badge {
88
+ display: inline-block;
89
+ padding: 2px 10px;
90
+ border-radius: 12px;
91
+ font-size: 12px;
92
+ font-weight: 500;
93
+ }
94
+ .badge-content { background: var(--accent-dim); color: var(--accent); }
95
+ .badge-software { background: var(--success-dim); color: var(--success); }
96
+ .badge-research { background: var(--warning-dim); color: var(--warning); }
97
+ .badge-mixed { background: var(--bg-hover); color: var(--text-muted); }
98
+
99
+ /* Cards */
100
+ .grid { display: grid; gap: 16px; }
101
+ .grid-2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
102
+ .grid-3 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
103
+ .grid-4 { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
104
+ .card {
105
+ background: var(--bg-card);
106
+ border: 1px solid var(--border);
107
+ border-radius: var(--radius);
108
+ padding: 16px;
109
+ }
110
+ .card h3 {
111
+ font-size: 12px;
112
+ text-transform: uppercase;
113
+ color: var(--text-muted);
114
+ margin-bottom: 8px;
115
+ letter-spacing: 0.3px;
116
+ }
117
+ .card .value {
118
+ font-size: 28px;
119
+ font-weight: 700;
120
+ color: var(--text);
121
+ }
122
+ .card .sub { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
123
+
124
+ /* Tabs */
125
+ .tabs {
126
+ display: flex;
127
+ gap: 0;
128
+ border-bottom: 1px solid var(--border);
129
+ margin-bottom: 20px;
130
+ }
131
+ .tab {
132
+ padding: 10px 20px;
133
+ cursor: pointer;
134
+ font-size: 14px;
135
+ color: var(--text-muted);
136
+ border-bottom: 2px solid transparent;
137
+ transition: all 0.15s;
138
+ background: none;
139
+ border-top: none;
140
+ border-left: none;
141
+ border-right: none;
142
+ font-family: var(--font);
143
+ }
144
+ .tab:hover { color: var(--text); }
145
+ .tab.active { color: var(--accent); border-bottom-color: var(--accent); }
146
+ .tab-content { display: none; }
147
+ .tab-content.active { display: block; }
148
+
149
+ /* Table */
150
+ table { width: 100%; border-collapse: collapse; }
151
+ th {
152
+ text-align: left;
153
+ font-size: 11px;
154
+ text-transform: uppercase;
155
+ color: var(--text-muted);
156
+ padding: 8px 12px;
157
+ border-bottom: 1px solid var(--border);
158
+ letter-spacing: 0.3px;
159
+ }
160
+ td {
161
+ padding: 10px 12px;
162
+ border-bottom: 1px solid var(--border);
163
+ font-size: 13px;
164
+ }
165
+ tr:hover td { background: var(--bg-hover); }
166
+
167
+ /* Status dots */
168
+ .status-dot {
169
+ display: inline-block;
170
+ width: 8px; height: 8px;
171
+ border-radius: 50%;
172
+ margin-right: 6px;
173
+ vertical-align: middle;
174
+ }
175
+ .status-active { background: var(--success); }
176
+ .status-stale { background: var(--warning); }
177
+ .status-error { background: var(--danger); }
178
+ .status-inactive { background: var(--text-muted); }
179
+
180
+ /* Timeline */
181
+ .timeline { border-left: 2px solid var(--border); margin-left: 12px; padding-left: 20px; }
182
+ .timeline-item { position: relative; padding-bottom: 16px; }
183
+ .timeline-item::before {
184
+ content: '';
185
+ position: absolute;
186
+ left: -25px; top: 6px;
187
+ width: 10px; height: 10px;
188
+ border-radius: 50%;
189
+ background: var(--accent);
190
+ border: 2px solid var(--bg);
191
+ }
192
+ .timeline-item .time { font-size: 11px; color: var(--text-muted); }
193
+ .timeline-item .event { font-size: 13px; }
194
+
195
+ /* Empty state */
196
+ .empty {
197
+ text-align: center;
198
+ padding: 48px 20px;
199
+ color: var(--text-muted);
200
+ }
201
+ .empty h3 { font-size: 16px; margin-bottom: 8px; color: var(--text); }
202
+
203
+ /* Progress bar */
204
+ .progress-bar {
205
+ height: 6px;
206
+ background: var(--bg-hover);
207
+ border-radius: 3px;
208
+ overflow: hidden;
209
+ margin-top: 8px;
210
+ }
211
+ .progress-fill {
212
+ height: 100%;
213
+ background: var(--accent);
214
+ border-radius: 3px;
215
+ transition: width 0.3s;
216
+ }
217
+
218
+ /* Context category colors */
219
+ :root {
220
+ --ctx-system: #6c8aff;
221
+ --ctx-history: #4ade80;
222
+ --ctx-tools: #fbbf24;
223
+ --ctx-files: #c084fc;
224
+ --ctx-inline: #22d3ee;
225
+ --ctx-other: #64748b;
226
+ }
227
+
228
+ /* Context donut widget */
229
+ .ctx-donut-wrap {
230
+ display: flex;
231
+ align-items: center;
232
+ gap: 16px;
233
+ flex-wrap: wrap;
234
+ }
235
+ .ctx-donut-svg { flex-shrink: 0; }
236
+ .ctx-donut-track { fill: none; stroke: var(--bg-hover); stroke-width: 10; }
237
+ .ctx-legend { display: flex; flex-direction: column; gap: 4px; }
238
+ .ctx-legend-item {
239
+ display: flex;
240
+ align-items: center;
241
+ gap: 6px;
242
+ font-size: 11px;
243
+ color: var(--text-muted);
244
+ }
245
+ .ctx-legend-dot {
246
+ width: 8px; height: 8px;
247
+ border-radius: 2px;
248
+ flex-shrink: 0;
249
+ }
250
+ .ctx-center-text { font-size: 13px; font-weight: 700; fill: var(--text); }
251
+ .ctx-center-sub { font-size: 7px; fill: var(--text-muted); }
252
+
253
+ /* Warning level badges */
254
+ .ctx-badge {
255
+ display: inline-block;
256
+ padding: 2px 8px;
257
+ border-radius: 10px;
258
+ font-size: 11px;
259
+ font-weight: 600;
260
+ }
261
+ .ctx-badge-normal { background: var(--success-dim); color: var(--success); }
262
+ .ctx-badge-warning { background: var(--warning-dim); color: var(--warning); }
263
+ .ctx-badge-critical { background: var(--danger-dim); color: var(--danger); }
264
+ .ctx-badge-overflow { background: var(--danger); color: #fff; }
265
+ .ctx-badge-unknown { background: var(--bg-hover); color: var(--text-muted); }
266
+
267
+ /* Token stacked bar */
268
+ .token-bar-wrap { margin-top: 8px; }
269
+ .token-stacked-bar {
270
+ display: flex;
271
+ height: 14px;
272
+ border-radius: 4px;
273
+ overflow: hidden;
274
+ background: var(--bg-hover);
275
+ }
276
+ .token-bar-seg { height: 100%; transition: width 0.3s; }
277
+ .token-bar-seg:first-child { border-radius: 4px 0 0 4px; }
278
+ .token-bar-seg:last-child { border-radius: 0 4px 4px 0; }
279
+ .token-bar-legend {
280
+ display: flex;
281
+ flex-wrap: wrap;
282
+ gap: 6px 14px;
283
+ margin-top: 6px;
284
+ }
285
+ .token-bar-legend-item {
286
+ display: flex;
287
+ align-items: center;
288
+ gap: 5px;
289
+ font-size: 11px;
290
+ color: var(--text-muted);
291
+ }
292
+ .token-bar-legend-dot {
293
+ width: 8px; height: 8px;
294
+ border-radius: 2px;
295
+ flex-shrink: 0;
296
+ }
297
+
298
+ /* Waste hint */
299
+ .waste-hint {
300
+ display: flex;
301
+ align-items: center;
302
+ gap: 8px;
303
+ padding: 8px 12px;
304
+ background: var(--warning-dim);
305
+ border: 1px solid var(--warning);
306
+ border-radius: var(--radius);
307
+ font-size: 12px;
308
+ color: var(--warning);
309
+ margin-top: 8px;
310
+ }
311
+
312
+ /* Process panel */
313
+ .proc-pid { font-family: monospace; font-size: 12px; color: var(--text-muted); }
314
+ .proc-elapsed { font-family: monospace; font-size: 12px; }
315
+ .proc-stop-btn {
316
+ padding: 3px 10px;
317
+ border-radius: 4px;
318
+ font-size: 11px;
319
+ cursor: pointer;
320
+ background: var(--danger-dim);
321
+ color: var(--danger);
322
+ border: 1px solid var(--danger);
323
+ transition: background 0.15s;
324
+ }
325
+ .proc-stop-btn:hover { background: var(--danger); color: #fff; }
326
+
327
+ /* Autonomy badges */
328
+ .autonomy-badge {
329
+ display: inline-flex;
330
+ align-items: center;
331
+ gap: 4px;
332
+ font-size: 11px;
333
+ font-weight: 600;
334
+ padding: 2px 8px;
335
+ border-radius: 99px;
336
+ vertical-align: middle;
337
+ }
338
+ .autonomy-auto { background: var(--success-dim); color: var(--success); border: 1px solid var(--success); }
339
+ .autonomy-semi { background: var(--warning-dim); color: var(--warning); border: 1px solid var(--warning); }
340
+ .autonomy-approve { background: var(--accent-dim); color: var(--accent); border: 1px solid var(--accent); }
341
+
342
+ .autonomy-select {
343
+ font-size: 12px;
344
+ background: var(--bg-hover);
345
+ color: var(--text);
346
+ border: 1px solid var(--border);
347
+ border-radius: 4px;
348
+ padding: 2px 6px;
349
+ cursor: pointer;
350
+ }
351
+ .autonomy-select:focus { outline: none; border-color: var(--accent); }
352
+
353
+ /* Agent cards (tasks panel) */
354
+ .agent-card { padding: 14px 16px; }
355
+ .agent-card-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 6px; gap: 8px; flex-wrap: wrap; }
356
+ .agent-card-slug { font-size: 11px; color: var(--text-muted); font-family: monospace; }
357
+ .agent-role { font-size: 12px; color: var(--text-muted); margin-bottom: 6px; }
358
+ .agent-focus { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 8px; }
359
+ .tag { font-size: 11px; padding: 1px 7px; border-radius: 99px; background: var(--bg-hover); color: var(--text-muted); border: 1px solid var(--border); }
360
+ .agent-autonomy-row { display: flex; align-items: center; gap: 8px; margin-top: 8px; }
361
+ .agent-autonomy-label { font-size: 11px; color: var(--text-muted); }
362
+
363
+ /* Execution logs timeline */
364
+ .log-session {}
365
+ .log-session-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; flex-wrap: wrap; }
366
+ .log-summary { font-size: 12px; color: var(--text-muted); font-style: italic; }
367
+ .log-timeline { display: flex; flex-direction: column; gap: 6px; }
368
+ .log-entry { padding: 8px 10px; border-radius: var(--radius); border-left: 3px solid var(--border); font-size: 13px; }
369
+ .log-entry-header { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
370
+ .log-icon { font-size: 14px; flex-shrink: 0; }
371
+ .log-ts { font-size: 11px; color: var(--text-muted); margin-left: auto; font-family: monospace; }
372
+ .log-dur { font-size: 11px; color: var(--text-muted); font-family: monospace; }
373
+ .log-tool-name { font-family: monospace; color: var(--accent); }
374
+ .log-tool-call { border-left-color: var(--accent); background: rgba(108,138,255,0.04); }
375
+ .log-reasoning { border-left-color: var(--text-muted); background: rgba(139,143,163,0.07); }
376
+ .log-reasoning-text { font-size: 12px; color: var(--text-muted); margin-top: 4px; line-height: 1.5; white-space: pre-wrap; }
377
+ .log-milestone { border-left-color: var(--success); background: var(--success-dim); }
378
+ .log-error { border-left-color: var(--danger); background: var(--danger-dim); }
379
+ .log-error-msg { color: var(--danger); font-family: monospace; }
380
+ .log-toggle {
381
+ font-size: 11px;
382
+ padding: 1px 8px;
383
+ border-radius: 4px;
384
+ cursor: pointer;
385
+ background: var(--bg-hover);
386
+ color: var(--text-muted);
387
+ border: 1px solid var(--border);
388
+ margin-left: 4px;
389
+ }
390
+ .log-toggle:hover { color: var(--text); }
391
+ .log-detail { margin-top: 8px; }
392
+ .log-section-label { font-size: 10px; text-transform: uppercase; color: var(--text-muted); margin-top: 6px; margin-bottom: 2px; letter-spacing: 0.05em; }
393
+ .log-pre { font-size: 11px; background: var(--bg); border: 1px solid var(--border); border-radius: 4px; padding: 8px; overflow-x: auto; white-space: pre-wrap; word-break: break-all; max-height: 300px; overflow-y: auto; }
394
+ .log-stack { color: var(--danger); }
395
+
396
+ /* Responsive */
397
+ @media (max-width: 768px) {
398
+ .sidebar { display: none; }
399
+ .main { margin-left: 0; width: 100%; }
400
+ .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
401
+ }
402
+ `;
403
+ }
404
+
405
+ function getInlineJS() {
406
+ return `
407
+ (function() {
408
+ // Tab switching
409
+ document.querySelectorAll('.tab').forEach(function(tab) {
410
+ tab.addEventListener('click', function() {
411
+ var group = this.closest('.tab-group');
412
+ group.querySelectorAll('.tab').forEach(function(t) { t.classList.remove('active'); });
413
+ group.querySelectorAll('.tab-content').forEach(function(c) { c.classList.remove('active'); });
414
+ this.classList.add('active');
415
+ var target = document.getElementById(this.dataset.tab);
416
+ if (target) target.classList.add('active');
417
+ });
418
+ });
419
+
420
+ // Processes: elapsed timers
421
+ function updateElapsed() {
422
+ document.querySelectorAll('.proc-elapsed[data-startedat]').forEach(function(el) {
423
+ var startedAt = el.dataset.startedat;
424
+ if (!startedAt) { el.textContent = '—'; return; }
425
+ var elapsed = Math.floor((Date.now() - new Date(startedAt).getTime()) / 1000);
426
+ if (isNaN(elapsed) || elapsed < 0) { el.textContent = '—'; return; }
427
+ if (elapsed < 60) el.textContent = elapsed + 's';
428
+ else if (elapsed < 3600) el.textContent = Math.floor(elapsed / 60) + 'm' + (elapsed % 60) + 's';
429
+ else el.textContent = Math.floor(elapsed / 3600) + 'h' + Math.floor((elapsed % 3600) / 60) + 'm';
430
+ });
431
+ }
432
+ updateElapsed();
433
+ setInterval(updateElapsed, 1000);
434
+
435
+ // Processes: SSE live updates
436
+ if (typeof EventSource !== 'undefined') {
437
+ var sse = new EventSource('/api/events/processes');
438
+ sse.onmessage = function(e) {
439
+ try {
440
+ var data = JSON.parse(e.data);
441
+ if (data && data.processes) {
442
+ // Simple refresh: reload if we're on the processes tab
443
+ var procTab = document.getElementById('panel-processes');
444
+ if (procTab && procTab.classList.contains('active')) {
445
+ // Could do DOM diff here; for now just mark stale
446
+ }
447
+ }
448
+ } catch(err) { /* ignore */ }
449
+ };
450
+ }
451
+
452
+ // Processes: stop handler
453
+ window.procStop = function(pid) {
454
+ if (!window.confirm('Stop process ' + pid + '?')) return;
455
+ fetch('/api/processes/' + pid + '/stop', { method: 'POST' })
456
+ .then(function(r) { return r.json(); })
457
+ .then(function(result) {
458
+ if (result.ok) {
459
+ var btn = document.querySelector('[data-pid="' + pid + '"]');
460
+ if (btn) {
461
+ btn.disabled = true;
462
+ btn.textContent = 'Stopped';
463
+ btn.style.opacity = '0.5';
464
+ var row = btn.closest('tr');
465
+ if (row) {
466
+ var statusCell = row.querySelector('td:first-child');
467
+ if (statusCell) {
468
+ statusCell.innerHTML = '<span class="status-dot status-inactive"></span>stopped';
469
+ }
470
+ }
471
+ }
472
+ } else {
473
+ alert('Failed to stop process: ' + (result.error || 'Unknown error'));
474
+ }
475
+ })
476
+ .catch(function() { alert('Request failed'); });
477
+ };
478
+
479
+ // Execution logs: toggle input/output detail
480
+ window.toggleLogDetail = function(btn) {
481
+ var entry = btn.closest('.log-entry');
482
+ var detail = entry && entry.querySelector('.log-detail');
483
+ if (!detail) return;
484
+ var open = detail.style.display !== 'none';
485
+ detail.style.display = open ? 'none' : 'block';
486
+ btn.textContent = open ? '▶ input/output' : '▼ input/output';
487
+ };
488
+
489
+ // Autonomy selector: POST level change
490
+ window.setAutonomy = function(agentSlug, level) {
491
+ var slug = document.body.dataset.squad;
492
+ if (!slug) return;
493
+ fetch('/api/squads/' + encodeURIComponent(slug) + '/agents/' + encodeURIComponent(agentSlug) + '/autonomy', {
494
+ method: 'POST',
495
+ headers: { 'Content-Type': 'application/json' },
496
+ body: JSON.stringify({ autonomyLevel: level })
497
+ }).then(function(r) { return r.json(); })
498
+ .then(function(result) {
499
+ if (!result.ok) { console.warn('setAutonomy failed', result); }
500
+ })
501
+ .catch(function() {});
502
+ };
503
+
504
+ // Auto-refresh
505
+ var slug = document.body.dataset.squad;
506
+ if (slug) {
507
+ setInterval(function() {
508
+ fetch('/api/squad/' + slug + '/data.json')
509
+ .then(function(r) { return r.json(); })
510
+ .then(function(data) {
511
+ if (data.metrics) {
512
+ Object.keys(data.metrics).forEach(function(key) {
513
+ var el = document.getElementById('metric-' + key);
514
+ if (el) el.textContent = data.metrics[key];
515
+ });
516
+ }
517
+ })
518
+ .catch(function() {});
519
+ }, 10000);
520
+ }
521
+ })();
522
+ `;
523
+ }
524
+
525
+ module.exports = { getInlineCSS, getInlineJS };
@@ -0,0 +1,99 @@
1
+ 'use strict';
2
+
3
+ const fs = require('node:fs/promises');
4
+ const path = require('node:path');
5
+
6
+ const SQUADS_DIR = path.join('.aioson', 'squads');
7
+
8
+ // Approximate USD cost per 1M tokens for a mid-tier model (Sonnet-class)
9
+ const COST_PER_M = {
10
+ input_tokens: 3.0,
11
+ output_tokens: 15.0,
12
+ tool_use_input: 3.0,
13
+ tool_outputs: 3.0,
14
+ cache_write: 3.75,
15
+ cache_read: 0.30
16
+ };
17
+
18
+ // Token breakdown categories (6) — order determines stacked bar segment order
19
+ const TOKEN_CATEGORIES = [
20
+ 'input_tokens',
21
+ 'output_tokens',
22
+ 'tool_use_input',
23
+ 'tool_outputs',
24
+ 'cache_write',
25
+ 'cache_read'
26
+ ];
27
+
28
+ // Waste threshold: tool_outputs > 60% of total tokens
29
+ const WASTE_THRESHOLD = 0.60;
30
+
31
+ function estimateSessionCost(breakdown) {
32
+ if (!breakdown) return 0;
33
+ let cost = 0;
34
+ for (const [key, rate] of Object.entries(COST_PER_M)) {
35
+ cost += ((breakdown[key] || 0) / 1e6) * rate;
36
+ }
37
+ return Math.round(cost * 10000) / 10000;
38
+ }
39
+
40
+ function computeSessionTotal(breakdown) {
41
+ if (!breakdown) return 0;
42
+ return TOKEN_CATEGORIES.reduce((sum, k) => sum + (breakdown[k] || 0), 0);
43
+ }
44
+
45
+ function detectWaste(sessions) {
46
+ if (!sessions || sessions.length === 0) return false;
47
+ let total = 0;
48
+ let toolOutputs = 0;
49
+ for (const session of sessions) {
50
+ const bd = session.breakdown || {};
51
+ total += computeSessionTotal(bd);
52
+ toolOutputs += bd.tool_outputs || 0;
53
+ }
54
+ return total > 0 && toolOutputs / total > WASTE_THRESHOLD;
55
+ }
56
+
57
+ /**
58
+ * Read token-usage.json for a squad and compute cost + waste flags.
59
+ * @param {string} projectDir
60
+ * @param {string} squadSlug
61
+ * @param {boolean} breakdown — if true, include per-session breakdown
62
+ * @returns {object|null}
63
+ */
64
+ async function getTokenUsage(projectDir, squadSlug, breakdown) {
65
+ const filePath = path.join(projectDir, SQUADS_DIR, squadSlug, 'token-usage.json');
66
+ let data;
67
+ try {
68
+ const raw = await fs.readFile(filePath, 'utf8');
69
+ data = JSON.parse(raw);
70
+ } catch {
71
+ return null;
72
+ }
73
+
74
+ const agents = data.agents || {};
75
+ const result = { squadSlug, updatedAt: data.updatedAt, agents: {} };
76
+
77
+ for (const [slug, agent] of Object.entries(agents)) {
78
+ const sessions = agent.sessions || [];
79
+ const enrichedSessions = sessions.map(s => ({
80
+ ...s,
81
+ totalTokens: s.totalTokens != null ? s.totalTokens : computeSessionTotal(s.breakdown),
82
+ estimatedCostUsd: s.estimatedCostUsd != null ? s.estimatedCostUsd : estimateSessionCost(s.breakdown)
83
+ }));
84
+
85
+ const totalCostUsd = enrichedSessions.reduce((sum, s) => sum + s.estimatedCostUsd, 0);
86
+ const wasteFlag = detectWaste(enrichedSessions);
87
+
88
+ result.agents[slug] = {
89
+ totalTokens: agent.totalTokens || enrichedSessions.reduce((s, e) => s + e.totalTokens, 0),
90
+ totalCostUsd: Math.round(totalCostUsd * 10000) / 10000,
91
+ wasteFlag,
92
+ sessions: breakdown ? enrichedSessions : undefined
93
+ };
94
+ }
95
+
96
+ return result;
97
+ }
98
+
99
+ module.exports = { getTokenUsage, estimateSessionCost, detectWaste, TOKEN_CATEGORIES, WASTE_THRESHOLD };