gsd-pi 2.82.0-dev.2841a1e44 → 2.82.0-dev.3a3c6509d

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 (377) hide show
  1. package/README.md +3 -3
  2. package/dist/resources/.managed-resources-content-hash +1 -1
  3. package/dist/resources/GSD-WORKFLOW.md +7 -0
  4. package/dist/resources/extensions/claude-code-cli/partial-builder.js +2 -1
  5. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +1 -1
  6. package/dist/resources/extensions/gsd/auto/infra-errors.js +9 -3
  7. package/dist/resources/extensions/gsd/auto/loop.js +5 -5
  8. package/dist/resources/extensions/gsd/auto/orchestrator.js +11 -0
  9. package/dist/resources/extensions/gsd/auto/phases.js +81 -31
  10. package/dist/resources/extensions/gsd/auto/workflow-memory-pressure.js +12 -0
  11. package/dist/resources/extensions/gsd/auto-dashboard.js +66 -1
  12. package/dist/resources/extensions/gsd/auto-direct-dispatch.js +1 -0
  13. package/dist/resources/extensions/gsd/auto-dispatch.js +20 -19
  14. package/dist/resources/extensions/gsd/auto-model-selection.js +2 -0
  15. package/dist/resources/extensions/gsd/auto-post-unit.js +71 -10
  16. package/dist/resources/extensions/gsd/auto-recovery.js +71 -14
  17. package/dist/resources/extensions/gsd/auto-start.js +87 -14
  18. package/dist/resources/extensions/gsd/auto-verification.js +17 -4
  19. package/dist/resources/extensions/gsd/auto-worktree.js +176 -10
  20. package/dist/resources/extensions/gsd/auto.js +37 -5
  21. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +31 -7
  22. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +10 -9
  23. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +4 -2
  24. package/dist/resources/extensions/gsd/bootstrap/subagent-input.js +5 -2
  25. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +14 -2
  26. package/dist/resources/extensions/gsd/commands/handlers/core.js +17 -1
  27. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +7 -2
  28. package/dist/resources/extensions/gsd/crash-recovery.js +43 -5
  29. package/dist/resources/extensions/gsd/db/milestone-leases.js +24 -0
  30. package/dist/resources/extensions/gsd/db/unit-dispatches.js +3 -2
  31. package/dist/resources/extensions/gsd/dispatch-guard.js +2 -2
  32. package/dist/resources/extensions/gsd/doctor-git-checks.js +46 -1
  33. package/dist/resources/extensions/gsd/doctor-runtime-checks.js +28 -11
  34. package/dist/resources/extensions/gsd/doctor.js +2 -28
  35. package/dist/resources/extensions/gsd/export-html.js +27 -425
  36. package/dist/resources/extensions/gsd/forensics.js +3 -3
  37. package/dist/resources/extensions/gsd/git-service.js +45 -3
  38. package/dist/resources/extensions/gsd/gsd-db.js +21 -6
  39. package/dist/resources/extensions/gsd/guided-flow-queue.js +4 -3
  40. package/dist/resources/extensions/gsd/guided-flow.js +101 -116
  41. package/dist/resources/extensions/gsd/guided-unit-context.js +23 -0
  42. package/dist/resources/extensions/gsd/migrate/parsers.js +10 -0
  43. package/dist/resources/extensions/gsd/migration-auto-check.js +12 -17
  44. package/dist/resources/extensions/gsd/milestone-actions.js +11 -4
  45. package/dist/resources/extensions/gsd/native-git-bridge.js +48 -12
  46. package/dist/resources/extensions/gsd/pending-auto-start.js +52 -0
  47. package/dist/resources/extensions/gsd/post-execution-checks.js +73 -2
  48. package/dist/resources/extensions/gsd/pre-execution-checks.js +28 -1
  49. package/dist/resources/extensions/gsd/prompt-loader.js +1 -1
  50. package/dist/resources/extensions/gsd/prompts/complete-milestone.md +1 -1
  51. package/dist/resources/extensions/gsd/prompts/complete-slice.md +1 -1
  52. package/dist/resources/extensions/gsd/prompts/discuss-headless.md +8 -8
  53. package/dist/resources/extensions/gsd/prompts/discuss.md +9 -9
  54. package/dist/resources/extensions/gsd/prompts/guided-discuss-project.md +4 -4
  55. package/dist/resources/extensions/gsd/prompts/guided-discuss-requirements.md +3 -3
  56. package/dist/resources/extensions/gsd/prompts/plan-slice.md +4 -4
  57. package/dist/resources/extensions/gsd/prompts/queue.md +4 -4
  58. package/dist/resources/extensions/gsd/prompts/refine-slice.md +2 -2
  59. package/dist/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
  60. package/dist/resources/extensions/gsd/queue-reorder-ui.js +30 -13
  61. package/dist/resources/extensions/gsd/smart-entry-routing.js +36 -0
  62. package/dist/resources/extensions/gsd/state-reconciliation/drift/merge-state.js +6 -1
  63. package/dist/resources/extensions/gsd/state-reconciliation/drift/project-md.js +9 -14
  64. package/dist/resources/extensions/gsd/state-reconciliation/drift/roadmap.js +19 -24
  65. package/dist/resources/extensions/gsd/state.js +1 -1
  66. package/dist/resources/extensions/gsd/status-guards.js +11 -0
  67. package/dist/resources/extensions/gsd/templates/plan.md +8 -5
  68. package/dist/resources/extensions/gsd/templates/task-plan.md +4 -2
  69. package/dist/resources/extensions/gsd/tools/complete-milestone.js +6 -8
  70. package/dist/resources/extensions/gsd/tools/complete-slice.js +6 -8
  71. package/dist/resources/extensions/gsd/tools/plan-milestone.js +7 -1
  72. package/dist/resources/extensions/gsd/tools/plan-slice.js +89 -14
  73. package/dist/resources/extensions/gsd/unit-context-manifest.js +7 -8
  74. package/dist/resources/extensions/gsd/validation.js +23 -1
  75. package/dist/resources/extensions/gsd/verification-gate.js +68 -7
  76. package/dist/resources/extensions/gsd/workflow-mcp.js +17 -1
  77. package/dist/resources/extensions/gsd/workflow-projections.js +6 -8
  78. package/dist/resources/extensions/gsd/worktree-lifecycle.js +33 -8
  79. package/dist/resources/extensions/gsd/worktree-manager.js +1 -1
  80. package/dist/resources/extensions/shared/html-shell.js +388 -0
  81. package/dist/resources/extensions/visual-brief/page-contract.js +2 -0
  82. package/dist/resources/extensions/visual-brief/prompts.js +29 -0
  83. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  84. package/dist/web/standalone/.next/BUILD_ID +1 -1
  85. package/dist/web/standalone/.next/app-path-routes-manifest.json +11 -11
  86. package/dist/web/standalone/.next/build-manifest.json +3 -3
  87. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  88. package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  89. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  90. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  91. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  92. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  93. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  94. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  95. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  96. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  97. package/dist/web/standalone/.next/server/app/_not-found/page.js +2 -2
  98. package/dist/web/standalone/.next/server/app/_not-found/page.js.nft.json +1 -1
  99. package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  100. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  101. package/dist/web/standalone/.next/server/app/_not-found.rsc +4 -7
  102. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +4 -7
  103. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  104. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +4 -5
  105. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  106. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  107. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -5
  108. package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
  109. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  110. package/dist/web/standalone/.next/server/app/index.html +1 -1
  111. package/dist/web/standalone/.next/server/app/index.rsc +4 -7
  112. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  113. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +4 -7
  114. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  115. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +4 -5
  116. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -5
  117. package/dist/web/standalone/.next/server/app/page.js +2 -2
  118. package/dist/web/standalone/.next/server/app/page.js.nft.json +1 -1
  119. package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  120. package/dist/web/standalone/.next/server/app-paths-manifest.json +11 -11
  121. package/dist/web/standalone/.next/server/chunks/4266.js +2 -0
  122. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  123. package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
  124. package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
  125. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  126. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  127. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  128. package/dist/web/standalone/.next/static/chunks/app/layout-8c10ec293ae0f1d5.js +1 -0
  129. package/dist/web/standalone/.next/static/chunks/{webpack-6a95bc41e0f7ec89.js → webpack-9a4db269f9ed63ad.js} +1 -1
  130. package/dist/web/standalone/.next/static/css/746ee28c929d1880.css +1 -0
  131. package/package.json +2 -2
  132. package/packages/mcp-server/src/workflow-tools.test.ts +1 -1
  133. package/packages/native/tsconfig.json +2 -1
  134. package/packages/native/tsconfig.tsbuildinfo +1 -1
  135. package/packages/pi-ai/dist/providers/google-gemini-cli.d.ts.map +1 -1
  136. package/packages/pi-ai/dist/providers/google-gemini-cli.js +5 -0
  137. package/packages/pi-ai/dist/providers/google-gemini-cli.js.map +1 -1
  138. package/packages/pi-ai/dist/providers/google-gemini-cli.test.d.ts +2 -0
  139. package/packages/pi-ai/dist/providers/google-gemini-cli.test.d.ts.map +1 -0
  140. package/packages/pi-ai/dist/providers/google-gemini-cli.test.js +41 -0
  141. package/packages/pi-ai/dist/providers/google-gemini-cli.test.js.map +1 -0
  142. package/packages/pi-ai/dist/providers/openai-codex-responses.d.ts.map +1 -1
  143. package/packages/pi-ai/dist/providers/openai-codex-responses.js +82 -1
  144. package/packages/pi-ai/dist/providers/openai-codex-responses.js.map +1 -1
  145. package/packages/pi-ai/dist/providers/openai-codex-responses.test.d.ts +2 -0
  146. package/packages/pi-ai/dist/providers/openai-codex-responses.test.d.ts.map +1 -0
  147. package/packages/pi-ai/dist/providers/openai-codex-responses.test.js +52 -0
  148. package/packages/pi-ai/dist/providers/openai-codex-responses.test.js.map +1 -0
  149. package/packages/pi-ai/dist/providers/simple-options.d.ts +2 -4
  150. package/packages/pi-ai/dist/providers/simple-options.d.ts.map +1 -1
  151. package/packages/pi-ai/dist/providers/simple-options.js +5 -6
  152. package/packages/pi-ai/dist/providers/simple-options.js.map +1 -1
  153. package/packages/pi-ai/dist/providers/simple-options.test.d.ts +2 -0
  154. package/packages/pi-ai/dist/providers/simple-options.test.d.ts.map +1 -0
  155. package/packages/pi-ai/dist/providers/simple-options.test.js +50 -0
  156. package/packages/pi-ai/dist/providers/simple-options.test.js.map +1 -0
  157. package/packages/pi-ai/src/providers/google-gemini-cli.test.ts +49 -0
  158. package/packages/pi-ai/src/providers/google-gemini-cli.ts +7 -0
  159. package/packages/pi-ai/src/providers/openai-codex-responses.test.ts +63 -0
  160. package/packages/pi-ai/src/providers/openai-codex-responses.ts +91 -1
  161. package/packages/pi-ai/src/providers/simple-options.test.ts +60 -0
  162. package/packages/pi-ai/src/providers/simple-options.ts +5 -6
  163. package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
  164. package/packages/pi-coding-agent/dist/core/agent-session-thinking-level.test.d.ts +2 -0
  165. package/packages/pi-coding-agent/dist/core/agent-session-thinking-level.test.d.ts.map +1 -0
  166. package/packages/pi-coding-agent/dist/core/agent-session-thinking-level.test.js +66 -0
  167. package/packages/pi-coding-agent/dist/core/agent-session-thinking-level.test.js.map +1 -0
  168. package/packages/pi-coding-agent/dist/core/agent-session.js +1 -1
  169. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  170. package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js +44 -3
  171. package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js.map +1 -1
  172. package/packages/pi-coding-agent/dist/core/sdk.js +1 -1
  173. package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
  174. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
  175. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +24 -6
  176. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
  177. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
  178. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js +71 -97
  179. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
  180. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js +12 -0
  181. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js.map +1 -1
  182. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  183. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +19 -8
  184. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  185. package/packages/pi-coding-agent/src/core/agent-session-thinking-level.test.ts +79 -0
  186. package/packages/pi-coding-agent/src/core/agent-session.ts +1 -1
  187. package/packages/pi-coding-agent/src/core/chat-controller-ordering.test.ts +53 -3
  188. package/packages/pi-coding-agent/src/core/sdk.ts +1 -1
  189. package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +23 -7
  190. package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +75 -102
  191. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode-ordering.test.ts +14 -0
  192. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +23 -8
  193. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
  194. package/packages/pi-tui/dist/__tests__/terminal.test.d.ts +2 -0
  195. package/packages/pi-tui/dist/__tests__/terminal.test.d.ts.map +1 -0
  196. package/packages/pi-tui/dist/__tests__/terminal.test.js +103 -0
  197. package/packages/pi-tui/dist/__tests__/terminal.test.js.map +1 -0
  198. package/packages/pi-tui/dist/terminal.d.ts +2 -0
  199. package/packages/pi-tui/dist/terminal.d.ts.map +1 -1
  200. package/packages/pi-tui/dist/terminal.js +12 -0
  201. package/packages/pi-tui/dist/terminal.js.map +1 -1
  202. package/packages/pi-tui/src/__tests__/terminal.test.ts +121 -0
  203. package/packages/pi-tui/src/terminal.ts +11 -0
  204. package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
  205. package/src/resources/GSD-WORKFLOW.md +7 -0
  206. package/src/resources/extensions/claude-code-cli/partial-builder.ts +2 -1
  207. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +1 -1
  208. package/src/resources/extensions/claude-code-cli/tests/partial-builder.test.ts +19 -2
  209. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +9 -0
  210. package/src/resources/extensions/gsd/auto/contracts.ts +14 -6
  211. package/src/resources/extensions/gsd/auto/infra-errors.ts +9 -3
  212. package/src/resources/extensions/gsd/auto/loop.ts +8 -5
  213. package/src/resources/extensions/gsd/auto/orchestrator.ts +11 -0
  214. package/src/resources/extensions/gsd/auto/phases.ts +90 -38
  215. package/src/resources/extensions/gsd/auto/workflow-memory-pressure.ts +13 -0
  216. package/src/resources/extensions/gsd/auto-dashboard.ts +72 -1
  217. package/src/resources/extensions/gsd/auto-direct-dispatch.ts +1 -0
  218. package/src/resources/extensions/gsd/auto-dispatch.ts +21 -19
  219. package/src/resources/extensions/gsd/auto-model-selection.ts +2 -1
  220. package/src/resources/extensions/gsd/auto-post-unit.ts +78 -8
  221. package/src/resources/extensions/gsd/auto-recovery.ts +74 -11
  222. package/src/resources/extensions/gsd/auto-start.ts +94 -12
  223. package/src/resources/extensions/gsd/auto-verification.ts +22 -2
  224. package/src/resources/extensions/gsd/auto-worktree.ts +193 -10
  225. package/src/resources/extensions/gsd/auto.ts +40 -5
  226. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +42 -7
  227. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +10 -9
  228. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +4 -2
  229. package/src/resources/extensions/gsd/bootstrap/subagent-input.ts +3 -1
  230. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +17 -2
  231. package/src/resources/extensions/gsd/commands/handlers/core.ts +17 -1
  232. package/src/resources/extensions/gsd/commands-prefs-wizard.ts +8 -3
  233. package/src/resources/extensions/gsd/crash-recovery.ts +44 -4
  234. package/src/resources/extensions/gsd/db/milestone-leases.ts +26 -0
  235. package/src/resources/extensions/gsd/db/unit-dispatches.ts +4 -3
  236. package/src/resources/extensions/gsd/dispatch-guard.ts +2 -2
  237. package/src/resources/extensions/gsd/doctor-git-checks.ts +45 -1
  238. package/src/resources/extensions/gsd/doctor-runtime-checks.ts +25 -13
  239. package/src/resources/extensions/gsd/doctor-types.ts +1 -0
  240. package/src/resources/extensions/gsd/doctor.ts +2 -27
  241. package/src/resources/extensions/gsd/export-html.ts +27 -427
  242. package/src/resources/extensions/gsd/forensics.ts +3 -3
  243. package/src/resources/extensions/gsd/git-service.ts +51 -4
  244. package/src/resources/extensions/gsd/gsd-db.ts +21 -6
  245. package/src/resources/extensions/gsd/guided-flow-queue.ts +4 -3
  246. package/src/resources/extensions/gsd/guided-flow.ts +134 -133
  247. package/src/resources/extensions/gsd/guided-unit-context.ts +30 -0
  248. package/src/resources/extensions/gsd/migrate/parsers.ts +11 -0
  249. package/src/resources/extensions/gsd/migration-auto-check.ts +15 -23
  250. package/src/resources/extensions/gsd/milestone-actions.ts +10 -4
  251. package/src/resources/extensions/gsd/native-git-bridge.ts +54 -12
  252. package/src/resources/extensions/gsd/pending-auto-start.ts +79 -0
  253. package/src/resources/extensions/gsd/post-execution-checks.ts +87 -2
  254. package/src/resources/extensions/gsd/pre-execution-checks.ts +32 -1
  255. package/src/resources/extensions/gsd/prompt-loader.ts +1 -1
  256. package/src/resources/extensions/gsd/prompts/complete-milestone.md +1 -1
  257. package/src/resources/extensions/gsd/prompts/complete-slice.md +1 -1
  258. package/src/resources/extensions/gsd/prompts/discuss-headless.md +8 -8
  259. package/src/resources/extensions/gsd/prompts/discuss.md +9 -9
  260. package/src/resources/extensions/gsd/prompts/guided-discuss-project.md +4 -4
  261. package/src/resources/extensions/gsd/prompts/guided-discuss-requirements.md +3 -3
  262. package/src/resources/extensions/gsd/prompts/plan-slice.md +4 -4
  263. package/src/resources/extensions/gsd/prompts/queue.md +4 -4
  264. package/src/resources/extensions/gsd/prompts/refine-slice.md +2 -2
  265. package/src/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
  266. package/src/resources/extensions/gsd/queue-reorder-ui.ts +31 -13
  267. package/src/resources/extensions/gsd/smart-entry-routing.ts +77 -0
  268. package/src/resources/extensions/gsd/state-reconciliation/drift/merge-state.ts +8 -1
  269. package/src/resources/extensions/gsd/state-reconciliation/drift/project-md.ts +12 -15
  270. package/src/resources/extensions/gsd/state-reconciliation/drift/roadmap.ts +17 -25
  271. package/src/resources/extensions/gsd/state.ts +1 -1
  272. package/src/resources/extensions/gsd/status-guards.ts +13 -0
  273. package/src/resources/extensions/gsd/templates/plan.md +8 -5
  274. package/src/resources/extensions/gsd/templates/task-plan.md +4 -2
  275. package/src/resources/extensions/gsd/tests/auto-dashboard.test.ts +71 -0
  276. package/src/resources/extensions/gsd/tests/auto-deterministic-error-classification-4973.test.ts +116 -0
  277. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +56 -0
  278. package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +80 -1
  279. package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +35 -7
  280. package/src/resources/extensions/gsd/tests/auto-phases-lifecycle.test.ts +53 -2
  281. package/src/resources/extensions/gsd/tests/auto-post-unit-step-message.test.ts +12 -1
  282. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +91 -6
  283. package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +1 -0
  284. package/src/resources/extensions/gsd/tests/auto-stop-notification.test.ts +20 -0
  285. package/src/resources/extensions/gsd/tests/auto-worktree-registry.test.ts +69 -1
  286. package/src/resources/extensions/gsd/tests/checkout-branch-stash-guard.test.ts +87 -0
  287. package/src/resources/extensions/gsd/tests/clear-stale-autostart.test.ts +11 -2
  288. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +4 -1
  289. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +5 -9
  290. package/src/resources/extensions/gsd/tests/complete-task.test.ts +3 -1
  291. package/src/resources/extensions/gsd/tests/crash-recovery-via-db.test.ts +86 -2
  292. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +2 -0
  293. package/src/resources/extensions/gsd/tests/db-authority-regression.test.ts +208 -0
  294. package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +59 -2
  295. package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +66 -0
  296. package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +27 -0
  297. package/src/resources/extensions/gsd/tests/doctor-empty-worktree.test.ts +65 -0
  298. package/src/resources/extensions/gsd/tests/export-html-enhancements.test.ts +8 -0
  299. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +11 -0
  300. package/src/resources/extensions/gsd/tests/guided-discuss-project-prompt-rendering.test.ts +2 -0
  301. package/src/resources/extensions/gsd/tests/guided-dispatch-root.test.ts +106 -0
  302. package/src/resources/extensions/gsd/tests/guided-flow-session-isolation.test.ts +59 -11
  303. package/src/resources/extensions/gsd/tests/guided-flow.test.ts +21 -0
  304. package/src/resources/extensions/gsd/tests/guided-tool-contract.test.ts +65 -0
  305. package/src/resources/extensions/gsd/tests/headless-milestone-parity.test.ts +7 -7
  306. package/src/resources/extensions/gsd/tests/hook-model-resolution.test.ts +5 -0
  307. package/src/resources/extensions/gsd/tests/infra-error.test.ts +2 -2
  308. package/src/resources/extensions/gsd/tests/infra-errors-cooldown.test.ts +9 -0
  309. package/src/resources/extensions/gsd/tests/integration/doctor-runtime.test.ts +20 -0
  310. package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +112 -1
  311. package/src/resources/extensions/gsd/tests/integration/state-machine-runtime-failures.test.ts +6 -1
  312. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +46 -0
  313. package/src/resources/extensions/gsd/tests/merge-db-cycle.test.ts +179 -0
  314. package/src/resources/extensions/gsd/tests/migrate-validator-parsers.test.ts +24 -1
  315. package/src/resources/extensions/gsd/tests/migration-auto-check.test.ts +26 -18
  316. package/src/resources/extensions/gsd/tests/native-git-bridge-exec-fallback.test.ts +63 -2
  317. package/src/resources/extensions/gsd/tests/orphaned-worktree-audit.test.ts +121 -1
  318. package/src/resources/extensions/gsd/tests/park-db-sync.test.ts +55 -1
  319. package/src/resources/extensions/gsd/tests/pending-autostart-scope.test.ts +29 -5
  320. package/src/resources/extensions/gsd/tests/pipeline-variant-dispatch.test.ts +2 -1
  321. package/src/resources/extensions/gsd/tests/plan-milestone.test.ts +26 -0
  322. package/src/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +2 -0
  323. package/src/resources/extensions/gsd/tests/plan-slice.test.ts +225 -1
  324. package/src/resources/extensions/gsd/tests/plan-task.test.ts +17 -0
  325. package/src/resources/extensions/gsd/tests/post-execution-checks.test.ts +86 -0
  326. package/src/resources/extensions/gsd/tests/post-unit-git-failure.test.ts +1 -1
  327. package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +53 -0
  328. package/src/resources/extensions/gsd/tests/prefs-wizard-coverage.test.ts +59 -0
  329. package/src/resources/extensions/gsd/tests/prompt-loader.test.ts +23 -0
  330. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +37 -1
  331. package/src/resources/extensions/gsd/tests/queue-reorder-ui.test.ts +54 -0
  332. package/src/resources/extensions/gsd/tests/remediation-completion-guard.test.ts +89 -2
  333. package/src/resources/extensions/gsd/tests/run-uat-replay-cap.test.ts +2 -3
  334. package/src/resources/extensions/gsd/tests/session-switch-abort-misclassification.test.ts +10 -0
  335. package/src/resources/extensions/gsd/tests/smart-entry-routing.test.ts +113 -0
  336. package/src/resources/extensions/gsd/tests/start-auto-detached.test.ts +53 -2
  337. package/src/resources/extensions/gsd/tests/state-reconciliation-drift.test.ts +119 -23
  338. package/src/resources/extensions/gsd/tests/status-guards.test.ts +13 -1
  339. package/src/resources/extensions/gsd/tests/stuck-state-via-db.test.ts +64 -1
  340. package/src/resources/extensions/gsd/tests/summary-render-parity.test.ts +7 -3
  341. package/src/resources/extensions/gsd/tests/unit-context-manifest.test.ts +82 -7
  342. package/src/resources/extensions/gsd/tests/validate-milestone-stuck-guard.test.ts +29 -2
  343. package/src/resources/extensions/gsd/tests/verification-gate.test.ts +110 -1
  344. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +19 -1
  345. package/src/resources/extensions/gsd/tests/workflow-memory-pressure.test.ts +21 -1
  346. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +1 -1
  347. package/src/resources/extensions/gsd/tests/worktree-git-pathspec.test.ts +39 -0
  348. package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +64 -12
  349. package/src/resources/extensions/gsd/tests/write-gate-planning-unit.test.ts +38 -0
  350. package/src/resources/extensions/gsd/tools/complete-milestone.ts +8 -10
  351. package/src/resources/extensions/gsd/tools/complete-slice.ts +6 -8
  352. package/src/resources/extensions/gsd/tools/plan-milestone.ts +5 -1
  353. package/src/resources/extensions/gsd/tools/plan-slice.ts +98 -12
  354. package/src/resources/extensions/gsd/types.ts +1 -1
  355. package/src/resources/extensions/gsd/unit-context-manifest.ts +12 -9
  356. package/src/resources/extensions/gsd/validation.ts +23 -1
  357. package/src/resources/extensions/gsd/verification-gate.ts +78 -6
  358. package/src/resources/extensions/gsd/workflow-mcp.ts +18 -1
  359. package/src/resources/extensions/gsd/workflow-projections.ts +6 -8
  360. package/src/resources/extensions/gsd/worktree-lifecycle.ts +41 -8
  361. package/src/resources/extensions/gsd/worktree-manager.ts +1 -1
  362. package/src/resources/extensions/shared/html-shell.ts +412 -0
  363. package/src/resources/extensions/visual-brief/page-contract.ts +2 -0
  364. package/src/resources/extensions/visual-brief/prompts.ts +37 -1
  365. package/src/resources/extensions/visual-brief/tests/visual-brief.test.ts +40 -0
  366. package/dist/web/standalone/.next/server/chunks/5822.js +0 -2
  367. package/dist/web/standalone/.next/static/chunks/app/layout-a16c7a7ecdf0c2cf.js +0 -1
  368. package/dist/web/standalone/.next/static/css/0262768ec1b89d34.css +0 -1
  369. package/dist/web/standalone/.next/static/css/de70bee13400563f.css +0 -1
  370. package/dist/web/standalone/.next/static/media/4cf2300e9c8272f7-s.p.woff2 +0 -0
  371. package/dist/web/standalone/.next/static/media/747892c23ea88013-s.woff2 +0 -0
  372. package/dist/web/standalone/.next/static/media/8d697b304b401681-s.woff2 +0 -0
  373. package/dist/web/standalone/.next/static/media/93f479601ee12b01-s.p.woff2 +0 -0
  374. package/dist/web/standalone/.next/static/media/9610d9e46709d722-s.woff2 +0 -0
  375. package/dist/web/standalone/.next/static/media/ba015fad6dcf6784-s.woff2 +0 -0
  376. /package/dist/web/standalone/.next/static/{Qgr2B_MRhPxC0z8fwv4vT → O6femb9LLl3nlgsDaYwS-}/_buildManifest.js +0 -0
  377. /package/dist/web/standalone/.next/static/{Qgr2B_MRhPxC0z8fwv4vT → O6femb9LLl3nlgsDaYwS-}/_ssgManifest.js +0 -0
@@ -0,0 +1,412 @@
1
+ export interface HtmlShellLink {
2
+ href: string;
3
+ label: string;
4
+ }
5
+
6
+ export interface HtmlShellOptions {
7
+ title: string;
8
+ documentTitle?: string;
9
+ subtitle?: string;
10
+ kind: string;
11
+ version?: string;
12
+ generatedAt: string;
13
+ mainHtml: string;
14
+ toc?: readonly HtmlShellLink[];
15
+ headerActionsHtml?: string;
16
+ footerNote?: string;
17
+ }
18
+
19
+ export interface HtmlShellTemplateOptions extends Omit<HtmlShellOptions, "mainHtml" | "generatedAt"> {
20
+ mainPlaceholder: string;
21
+ generatedAtPlaceholder?: string;
22
+ }
23
+
24
+ export function renderHtmlShell(options: HtmlShellOptions): string {
25
+ const version = options.version ? `v${esc(options.version)}` : "";
26
+ const documentTitle = options.documentTitle ?? `${options.kind} - ${options.title}`;
27
+ const subtitle = options.subtitle ? `<span class="header-path">${esc(options.subtitle)}</span>` : "";
28
+ const toc = options.toc?.length
29
+ ? `<nav class="toc" aria-label="Report sections">
30
+ <ul>
31
+ ${options.toc.map((item) => ` <li><a href="${esc(item.href)}">${esc(item.label)}</a></li>`).join("\n")}
32
+ </ul>
33
+ </nav>`
34
+ : "";
35
+ const actions = options.headerActionsHtml ? `${options.headerActionsHtml}` : "";
36
+ const footerNote = options.footerNote ? `<span class="sep">/</span>\n <span>${esc(options.footerNote)}</span>` : "";
37
+
38
+ return `<!DOCTYPE html>
39
+ <html lang="en">
40
+ <head>
41
+ <meta charset="UTF-8">
42
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
43
+ <title>${esc(documentTitle)}</title>
44
+ <style>${HTML_SHELL_CSS}</style>
45
+ </head>
46
+ <body>
47
+ <header>
48
+ <div class="header-inner">
49
+ <div class="branding">
50
+ <span class="logo">GSD</span>
51
+ ${version ? `<span class="version">${version}</span>` : ""}
52
+ </div>
53
+ <div class="header-meta">
54
+ <h1>${esc(options.title)}</h1>
55
+ ${subtitle}
56
+ </div>
57
+ <div class="header-right">
58
+ ${actions}
59
+ <span class="kind-chip">${esc(options.kind)}</span>
60
+ <div class="generated">${formatDateLong(options.generatedAt)}</div>
61
+ </div>
62
+ </div>
63
+ </header>
64
+ ${toc}
65
+ <main>
66
+ ${options.mainHtml}
67
+ </main>
68
+ <footer>
69
+ <div class="footer-inner">
70
+ <span>GSD${version ? ` ${version}` : ""}</span>
71
+ <span class="sep">/</span>
72
+ <span>${esc(options.kind)}</span>
73
+ ${footerNote}
74
+ <span class="sep">/</span>
75
+ <span>${formatDateLong(options.generatedAt)}</span>
76
+ </div>
77
+ </footer>
78
+ <script>${HTML_SHELL_JS}</script>
79
+ </body>
80
+ </html>`;
81
+ }
82
+
83
+ export function renderHtmlShellTemplate(options: HtmlShellTemplateOptions): string {
84
+ return renderHtmlShell({
85
+ ...options,
86
+ generatedAt: options.generatedAtPlaceholder ?? "{{GENERATED_AT}}",
87
+ mainHtml: options.mainPlaceholder,
88
+ });
89
+ }
90
+
91
+ export function formatDateLong(iso: string): string {
92
+ if (/^\{\{[A-Z_]+\}\}$/.test(iso)) return iso;
93
+ try {
94
+ const d = new Date(iso);
95
+ return d.toLocaleString('en-US', { weekday: 'short', month: 'short', day: 'numeric', year: 'numeric', hour: '2-digit', minute: '2-digit', timeZoneName: 'short' });
96
+ } catch { return iso; }
97
+ }
98
+
99
+ export function esc(s: string | undefined | null): string {
100
+ if (s == null) return '';
101
+ return String(s).replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/"/g, '&quot;').replace(/'/g, '&#39;');
102
+ }
103
+
104
+ export const HTML_SHELL_CSS = `
105
+ *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
106
+ :root{
107
+ --bg-0:#0f1115;--bg-1:#16181d;--bg-2:#1e2028;--bg-3:#272a33;
108
+ --border-1:#2b2e38;--border-2:#3b3f4c;
109
+ --text-0:#ededef;--text-1:#a1a1aa;--text-2:#71717a;
110
+ --accent:#5e6ad2;--accent-subtle:rgba(94,106,210,.12);
111
+ --ok:#22c55e;--ok-subtle:rgba(34,197,94,.12);--warn:#ef4444;--caution:#eab308;
112
+ /* Chart palette - 6 hues for bar charts */
113
+ --c0:#5e6ad2;--c1:#e5796d;--c2:#14b8a6;--c3:#a78bfa;--c4:#f59e0b;--c5:#10b981;
114
+ /* Token breakdown - 4 distinct hues */
115
+ --tk-input:#5e6ad2;--tk-output:#e5796d;--tk-cache-r:#2dd4bf;--tk-cache-w:#64748b;
116
+ --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
117
+ --mono:'JetBrains Mono','Fira Code',ui-monospace,SFMono-Regular,monospace;
118
+ }
119
+ html{scroll-behavior:smooth;font-size:13px}
120
+ body{background:var(--bg-0);color:var(--text-0);font-family:var(--font);line-height:1.6;-webkit-font-smoothing:antialiased}
121
+ a{color:var(--accent);text-decoration:none}
122
+ a:hover{text-decoration:underline}
123
+ code{font-family:var(--mono);font-size:12px;background:var(--bg-3);padding:1px 5px;border-radius:3px}
124
+ .mono{font-family:var(--mono);font-size:12px}
125
+ .muted{color:var(--text-2)}
126
+ .accent{color:var(--accent)}
127
+ .sep{color:var(--border-2);margin:0 4px}
128
+ .empty{color:var(--text-2);padding:8px 0;font-size:13px}
129
+ .indent{padding-left:12px}
130
+ .num{font-variant-numeric:tabular-nums;text-align:right}
131
+ .dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0;vertical-align:middle}
132
+ .dot-sm{width:6px;height:6px}
133
+ .dot-complete{background:var(--ok);opacity:.6}
134
+ .dot-active{background:var(--accent)}
135
+ .dot-pending{background:transparent;border:1.5px solid var(--border-2)}
136
+ .dot-parked{background:var(--warn);opacity:.5}
137
+ header{background:var(--bg-1);border-bottom:1px solid var(--border-1);padding:12px 32px;position:sticky;top:0;z-index:200}
138
+ .header-inner{display:flex;align-items:center;gap:16px;max-width:1280px;margin:0 auto}
139
+ .branding{display:flex;align-items:baseline;gap:6px;flex-shrink:0}
140
+ .logo{font-size:18px;font-weight:800;letter-spacing:-.5px;color:var(--text-0)}
141
+ .version{font-size:10px;color:var(--text-2);font-family:var(--mono)}
142
+ .header-meta{flex:1;min-width:0}
143
+ .header-meta h1{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
144
+ .header-path{font-size:11px;color:var(--text-2);font-family:var(--mono);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
145
+ .header-right{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
146
+ .generated{font-size:11px;color:var(--text-2)}
147
+ .kind-chip{font-size:10px;font-weight:600;color:var(--accent);background:var(--accent-subtle);border:1px solid rgba(94,106,210,.25);border-radius:3px;padding:2px 7px;text-transform:uppercase;letter-spacing:.4px}
148
+ .back-link{font-size:12px;color:var(--text-1)}
149
+ .back-link:hover{color:var(--accent)}
150
+ .toc{background:var(--bg-1);border-bottom:1px solid var(--border-1);overflow-x:auto}
151
+ .toc ul{display:flex;list-style:none;max-width:1280px;margin:0 auto;padding:0 32px}
152
+ .toc a{display:inline-block;padding:8px 12px;color:var(--text-2);font-size:12px;font-weight:500;border-bottom:2px solid transparent;transition:color .12s,border-color .12s;white-space:nowrap;text-decoration:none}
153
+ .toc a:hover{color:var(--text-0);border-bottom-color:var(--border-2)}
154
+ .toc a.active{color:var(--text-0);border-bottom-color:var(--accent)}
155
+ main{max-width:1280px;margin:0 auto;padding:32px;display:flex;flex-direction:column;gap:48px}
156
+ section{scroll-margin-top:82px}
157
+ section>h2{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-1);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--border-1);display:flex;align-items:center;gap:8px}
158
+ h3{font-size:13px;font-weight:600;color:var(--text-1);margin:20px 0 8px}
159
+ .count{font-size:11px;font-weight:500;color:var(--text-2);background:var(--bg-3);border-radius:3px;padding:1px 6px}
160
+ .count-warn{color:var(--caution)}
161
+ .kv-grid{display:flex;flex-wrap:wrap;gap:1px;background:var(--border-1);border:1px solid var(--border-1);border-radius:4px;overflow:hidden;margin-bottom:16px}
162
+ .kv{background:var(--bg-1);padding:10px 16px;display:flex;flex-direction:column;gap:2px;min-width:110px;flex:1}
163
+ .kv-val{font-size:18px;font-weight:600;color:var(--text-0);font-variant-numeric:tabular-nums}
164
+ .kv-lbl{font-size:10px;color:var(--text-2);text-transform:uppercase;letter-spacing:.4px}
165
+ .progress-wrap{display:flex;align-items:center;gap:10px;margin-bottom:12px}
166
+ .progress-track{flex:1;height:4px;background:var(--bg-3);border-radius:2px;overflow:hidden}
167
+ .progress-fill{height:100%;background:var(--accent);border-radius:2px}
168
+ .progress-label{font-size:12px;font-weight:600;color:var(--text-1);min-width:40px;text-align:right}
169
+ .active-info{font-size:12px;color:var(--text-1);margin-bottom:4px}
170
+ .activity-line{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-1);padding:6px 0}
171
+ .tbl{width:100%;border-collapse:collapse;font-size:12px}
172
+ .tbl th{color:var(--text-2);font-weight:500;padding:6px 12px;text-align:left;border-bottom:1px solid var(--border-1);font-size:11px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}
173
+ .tbl td{padding:6px 12px;border-bottom:1px solid var(--border-1);vertical-align:top}
174
+ .tbl tr:last-child td{border-bottom:none}
175
+ .tbl tbody tr:hover td{background:var(--accent-subtle)}
176
+ .tbl-kv td:first-child{color:var(--text-2);width:180px}
177
+ .table-scroll{overflow-x:auto;border:1px solid var(--border-1);border-radius:4px}
178
+ .table-scroll .tbl{border:none}
179
+ .h-ok td:first-child{color:var(--text-1)}
180
+ .h-caution td{color:var(--caution)}
181
+ .h-warn td{color:var(--warn)}
182
+ .label{font-size:10px;font-weight:500;color:var(--accent);text-transform:uppercase;letter-spacing:.4px}
183
+ .risk{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}
184
+ .risk-low{color:var(--text-2)}
185
+ .risk-medium{color:var(--caution)}
186
+ .risk-high{color:var(--warn)}
187
+ .risk-unknown{color:var(--text-2)}
188
+ .tag-row{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}
189
+ .tag{font-size:11px;font-family:var(--mono);color:var(--text-2);background:var(--bg-3);border-radius:3px;padding:1px 6px}
190
+ .verif{font-size:12px;color:var(--text-1);padding:4px 0;margin-bottom:6px}
191
+ .verif-blocker{color:var(--warn)}
192
+ .detail-block{font-size:12px;color:var(--text-2);margin-bottom:6px}
193
+ .detail-label{font-weight:600;color:var(--text-1);display:block;margin-bottom:2px}
194
+ .detail-block ul{padding-left:16px;margin-top:2px}
195
+ .detail-block li{margin-bottom:1px}
196
+ .ms-block{border:1px solid var(--border-1);border-radius:4px;overflow:hidden;margin-bottom:8px}
197
+ .ms-summary{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;list-style:none;background:var(--bg-1);user-select:none;font-size:13px}
198
+ .ms-summary:hover{background:var(--bg-2)}
199
+ .ms-summary::-webkit-details-marker{display:none}
200
+ .ms-id{font-weight:600}
201
+ .ms-title{flex:1;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
202
+ .ms-body{padding:6px 12px 8px 24px;display:flex;flex-direction:column;gap:4px}
203
+ .sl-block{border:1px solid var(--border-1);border-radius:3px;overflow:hidden}
204
+ .sl-summary{display:flex;align-items:center;gap:6px;padding:6px 10px;cursor:pointer;list-style:none;background:var(--bg-2);font-size:12px;user-select:none}
205
+ .sl-summary:hover{background:var(--bg-3)}
206
+ .sl-summary::-webkit-details-marker{display:none}
207
+ .sl-crit{border-left:2px solid var(--accent)}
208
+ .sl-deps::before{content:'\\2190 ';color:var(--border-2)}
209
+ .sl-detail{padding:8px 12px;background:var(--bg-0);border-top:1px solid var(--border-1)}
210
+ .task-list{list-style:none;padding:4px 0 0;display:flex;flex-direction:column;gap:2px}
211
+ .task-row{display:flex;align-items:center;gap:6px;font-size:12px;padding:3px 6px;border-radius:2px}
212
+ .dep-block{margin-bottom:28px}
213
+ .dep-legend{display:flex;gap:14px;font-size:12px;color:var(--text-2);margin-bottom:8px;align-items:center}
214
+ .dep-legend span{display:flex;align-items:center;gap:4px}
215
+ .dep-wrap{overflow-x:auto;background:var(--bg-1);border:1px solid var(--border-1);border-radius:4px;padding:16px}
216
+ .dep-svg{display:block}
217
+ .edge{fill:none;stroke:var(--border-2);stroke-width:1.5}
218
+ .edge-crit{stroke:var(--accent);stroke-width:2}
219
+ .node rect{fill:var(--bg-2);stroke:var(--border-2);stroke-width:1}
220
+ .n-done rect{fill:var(--ok-subtle);stroke:rgba(34,197,94,.4)}
221
+ .n-active rect{fill:var(--accent-subtle);stroke:var(--accent)}
222
+ .n-crit rect{stroke:var(--accent)!important;stroke-width:1.5!important}
223
+ .n-id{font-family:var(--mono);font-size:10px;fill:var(--text-1);font-weight:600;text-anchor:middle}
224
+ .n-title{font-size:9px;fill:var(--text-2);text-anchor:middle}
225
+ .n-active .n-id{fill:var(--accent)}
226
+ .token-block{background:var(--bg-1);border:1px solid var(--border-1);border-radius:4px;padding:14px;margin-bottom:16px}
227
+ .token-bar{display:flex;height:16px;border-radius:2px;overflow:hidden;gap:1px;margin-bottom:8px}
228
+ .tseg{height:100%;min-width:2px}
229
+ .seg-1{background:var(--tk-input)}
230
+ .seg-2{background:var(--tk-output)}
231
+ .seg-3{background:var(--tk-cache-r)}
232
+ .seg-4{background:var(--tk-cache-w)}
233
+ .token-legend{display:flex;flex-wrap:wrap;gap:12px}
234
+ .leg-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-2)}
235
+ .leg-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
236
+ .chart-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:16px}
237
+ .chart-block{background:var(--bg-1);border:1px solid var(--border-1);border-radius:4px;padding:14px}
238
+ .bar-row{display:grid;grid-template-columns:120px 1fr 68px;align-items:center;gap:6px;margin-bottom:2px}
239
+ .bar-lbl{font-size:12px;color:var(--text-2);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
240
+ .bar-track{height:14px;background:var(--bg-3);border-radius:2px;overflow:hidden}
241
+ .bar-fill{height:100%;border-radius:2px;background:var(--c0)}
242
+ .bar-c0{background:var(--c0)}.bar-c1{background:var(--c1)}.bar-c2{background:var(--c2)}
243
+ .bar-c3{background:var(--c3)}.bar-c4{background:var(--c4)}.bar-c5{background:var(--c5)}
244
+ .bar-val{font-size:11px;font-variant-numeric:tabular-nums;color:var(--text-1)}
245
+ .bar-sub{font-size:10px;color:var(--text-2);padding-left:128px;margin-bottom:6px}
246
+ .cl-entry{border-bottom:1px solid var(--border-1);padding:12px 0}
247
+ .cl-entry:last-child{border-bottom:none}
248
+ .cl-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}
249
+ .cl-title{flex:1;font-weight:500}
250
+ .cl-date{margin-left:auto;white-space:nowrap}
251
+ .cl-liner{font-size:13px;color:var(--text-1);margin-bottom:6px}
252
+ .files-detail summary{font-size:12px;cursor:pointer}
253
+ .file-list{list-style:none;padding-left:10px;margin-top:4px;display:flex;flex-direction:column;gap:2px}
254
+ .file-list li{font-size:12px;color:var(--text-1)}
255
+ footer{border-top:1px solid var(--border-1);padding:20px 32px;margin-top:40px}
256
+ .footer-inner{display:flex;align-items:center;gap:6px;justify-content:center;font-size:11px;color:var(--text-2);flex-wrap:wrap}
257
+ .exec-summary{font-size:13px;color:var(--text-1);margin-bottom:12px;line-height:1.7}
258
+ .eta-line{font-size:12px;color:var(--accent);margin-top:4px}
259
+ .cost-svg{display:block;margin:8px 0;background:var(--bg-1);border:1px solid var(--border-1);border-radius:4px}
260
+ .cost-line{fill:none;stroke:var(--accent);stroke-width:2}
261
+ .cost-area{fill:var(--accent-subtle);stroke:none}
262
+ .cost-axis{fill:var(--text-2);font-family:var(--mono);font-size:10px}
263
+ .cost-grid{stroke:var(--border-1);stroke-width:1;stroke-dasharray:4,4}
264
+ .burndown-wrap{background:var(--bg-1);border:1px solid var(--border-1);border-radius:4px;padding:14px;margin-bottom:16px}
265
+ .burndown-bar{display:flex;height:20px;border-radius:3px;overflow:hidden;gap:1px;margin-bottom:8px}
266
+ .burndown-spent{background:var(--accent);height:100%}
267
+ .burndown-projected{background:var(--caution);height:100%;opacity:.6}
268
+ .burndown-overshoot{background:var(--warn);height:100%;opacity:.7}
269
+ .burndown-legend{display:flex;flex-wrap:wrap;gap:12px;font-size:11px;color:var(--text-2)}
270
+ .burndown-legend span{display:flex;align-items:center;gap:4px}
271
+ .burndown-dot{display:inline-block;width:8px;height:8px;border-radius:2px}
272
+ .blocker-card{border-left:3px solid var(--warn);background:var(--bg-1);border-radius:0 4px 4px 0;padding:10px 14px;margin-bottom:8px}
273
+ .blocker-id{font-family:var(--mono);font-size:12px;color:var(--warn);margin-bottom:2px}
274
+ .blocker-text{font-size:12px;color:var(--text-1)}
275
+ .blocker-risk{font-size:11px;color:var(--caution);margin-top:2px}
276
+ .gantt-wrap{overflow-x:auto;background:var(--bg-1);border:1px solid var(--border-1);border-radius:4px;padding:16px;margin-top:16px}
277
+ .gantt-svg{display:block}
278
+ .gantt-bar-done{fill:var(--ok);opacity:.7}
279
+ .gantt-bar-active{fill:var(--accent)}
280
+ .gantt-bar-pending{fill:var(--border-2)}
281
+ .gantt-label{fill:var(--text-2);font-family:var(--mono);font-size:10px}
282
+ .gantt-axis{fill:var(--text-2);font-family:var(--mono);font-size:9px}
283
+ .tl-filter{display:block;width:100%;padding:6px 10px;margin-bottom:8px;background:var(--bg-2);border:1px solid var(--border-1);border-radius:4px;color:var(--text-0);font-size:12px;font-family:var(--font);outline:none}
284
+ .tl-filter:focus{border-color:var(--accent)}
285
+ .tl-filter::placeholder{color:var(--text-2)}
286
+ .sec-toggle{background:none;border:1px solid var(--border-2);color:var(--text-2);width:20px;height:20px;border-radius:3px;cursor:pointer;font-size:14px;line-height:1;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
287
+ .sec-toggle:hover{border-color:var(--text-1);color:var(--text-1)}
288
+ .theme-toggle{background:var(--bg-3);border:1px solid var(--border-2);color:var(--text-1);padding:4px 10px;border-radius:4px;cursor:pointer;font-size:11px;font-family:var(--font)}
289
+ .theme-toggle:hover{border-color:var(--accent);color:var(--accent)}
290
+ .callout-info,.callout-warn,.callout-ok{border-left:3px solid var(--accent);background:var(--bg-1);border-radius:0 4px 4px 0;padding:10px 14px}
291
+ .callout-warn{border-left-color:var(--caution)}
292
+ .callout-ok{border-left-color:var(--ok)}
293
+ .card-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
294
+ .card{background:var(--bg-1);border:1px solid var(--border-1);border-radius:4px;padding:14px}
295
+ .light-theme{--bg-0:#fff;--bg-1:#fafafa;--bg-2:#f5f5f5;--bg-3:#ebebeb;--border-1:#e5e5e5;--border-2:#d4d4d4;--text-0:#1a1a1a;--text-1:#525252;--text-2:#a3a3a3;--accent:#4f46e5;--accent-subtle:rgba(79,70,229,.08);--ok:#16a34a;--ok-subtle:rgba(22,163,74,.08);--warn:#dc2626;--caution:#ca8a04;--c0:#4f46e5;--c1:#dc2626;--c2:#0d9488;--c3:#7c3aed;--c4:#d97706;--c5:#059669;--tk-input:#4f46e5;--tk-output:#dc2626;--tk-cache-r:#0d9488;--tk-cache-w:#64748b}
296
+ @media(max-width:768px){
297
+ header{padding:10px 16px}
298
+ .header-inner{flex-wrap:wrap;gap:8px}
299
+ .header-meta h1{font-size:13px}
300
+ main{padding:16px}
301
+ .kv-grid{gap:1px}
302
+ .kv{min-width:80px;padding:8px 10px}
303
+ .kv-val{font-size:14px}
304
+ .chart-row{grid-template-columns:1fr}
305
+ .toc ul{padding:0 16px}
306
+ .toc a{padding:6px 8px;font-size:11px}
307
+ .bar-row{grid-template-columns:80px 1fr 56px}
308
+ .ms-body{padding-left:12px}
309
+ }
310
+ @media(max-width:480px){
311
+ .kv{min-width:60px;padding:6px 8px}
312
+ .kv-val{font-size:12px}
313
+ .kv-lbl{font-size:9px}
314
+ .bar-row{grid-template-columns:60px 1fr 48px}
315
+ .bar-lbl{font-size:10px}
316
+ .toc ul{flex-wrap:wrap}
317
+ .header-right{display:none}
318
+ .gantt-wrap{overflow-x:auto}
319
+ }
320
+ @media print{
321
+ header,nav.toc{position:static}
322
+ body{background:#fff;color:#1a1a1a}
323
+ :root{--bg-0:#fff;--bg-1:#fafafa;--bg-2:#f5f5f5;--bg-3:#ebebeb;--border-1:#e5e5e5;--border-2:#d4d4d4;--text-0:#1a1a1a;--text-1:#525252;--text-2:#a3a3a3;--accent:#4f46e5;--ok:#16a34a;--ok-subtle:rgba(22,163,74,.08);--c0:#4f46e5;--c1:#dc2626;--c2:#0d9488;--c3:#7c3aed;--c4:#d97706;--c5:#059669;--tk-input:#4f46e5;--tk-output:#dc2626;--tk-cache-r:#0d9488;--tk-cache-w:#64748b}
324
+ section{page-break-inside:avoid}
325
+ .table-scroll{overflow:visible}
326
+ }
327
+ `;
328
+
329
+ export const HTML_SHELL_JS = `
330
+ (function(){
331
+ const sections=document.querySelectorAll('section[id]');
332
+ const links=document.querySelectorAll('.toc a');
333
+ if(!sections.length||!links.length)return;
334
+ const obs=new IntersectionObserver(entries=>{
335
+ for(const e of entries){
336
+ if(!e.isIntersecting)continue;
337
+ for(const l of links)l.classList.remove('active');
338
+ const a=document.querySelector('.toc a[href="#'+e.target.id+'"]');
339
+ if(a)a.classList.add('active');
340
+ }
341
+ },{rootMargin:'-10% 0px -80% 0px',threshold:0});
342
+ for(const s of sections)obs.observe(s);
343
+ })();
344
+ (function(){
345
+ var tl=document.getElementById('timeline');
346
+ if(!tl)return;
347
+ var table=tl.querySelector('.tbl');
348
+ if(!table)return;
349
+ var input=document.createElement('input');
350
+ input.className='tl-filter';
351
+ input.placeholder='Filter timeline\\u2026';
352
+ input.type='text';
353
+ table.parentNode.insertBefore(input,table);
354
+ var rows=table.querySelectorAll('tbody tr');
355
+ input.addEventListener('input',function(){
356
+ var q=this.value.toLowerCase();
357
+ for(var i=0;i<rows.length;i++){
358
+ rows[i].style.display=rows[i].textContent.toLowerCase().indexOf(q)>-1?'':'none';
359
+ }
360
+ });
361
+ })();
362
+ function safeLocalStorageSet(key,value){
363
+ try{localStorage.setItem(key,value)}catch(e){}
364
+ }
365
+ function safeLocalStorageGet(key){
366
+ try{return localStorage.getItem(key)}catch(e){return null}
367
+ }
368
+ (function(){
369
+ var saved={};
370
+ try{saved=JSON.parse(safeLocalStorageGet('gsd-collapsed')||'{}')}catch(e){}
371
+ document.querySelectorAll('section[id]').forEach(function(sec){
372
+ var h2=sec.querySelector('h2');
373
+ if(!h2)return;
374
+ var btn=document.createElement('button');
375
+ btn.className='sec-toggle';
376
+ btn.textContent=saved[sec.id]?'+':'-';
377
+ btn.setAttribute('aria-label','Toggle section');
378
+ h2.prepend(btn);
379
+ if(saved[sec.id])toggleSection(sec,true);
380
+ btn.addEventListener('click',function(e){
381
+ e.preventDefault();
382
+ var collapsed=btn.textContent==='-';
383
+ toggleSection(sec,collapsed);
384
+ btn.textContent=collapsed?'+':'-';
385
+ saved[sec.id]=collapsed;
386
+ safeLocalStorageSet('gsd-collapsed',JSON.stringify(saved));
387
+ });
388
+ });
389
+ function toggleSection(sec,hide){
390
+ var children=sec.children;
391
+ for(var i=0;i<children.length;i++){
392
+ if(children[i].tagName!=='H2')children[i].style.display=hide?'none':'';
393
+ }
394
+ }
395
+ })();
396
+ (function(){
397
+ var hr=document.querySelector('.header-right');
398
+ if(!hr)return;
399
+ var stored=safeLocalStorageGet('gsd-theme');
400
+ var btn=document.createElement('button');
401
+ btn.className='theme-toggle';
402
+ btn.textContent=stored==='light'?'Dark':'Light';
403
+ if(stored==='light')document.documentElement.classList.add('light-theme');
404
+ btn.addEventListener('click',function(){
405
+ document.documentElement.classList.toggle('light-theme');
406
+ var isLight=document.documentElement.classList.contains('light-theme');
407
+ btn.textContent=isLight?'Dark':'Light';
408
+ safeLocalStorageSet('gsd-theme',isLight?'light':'dark');
409
+ });
410
+ hr.prepend(btn);
411
+ })();
412
+ `;
@@ -126,6 +126,8 @@ export function getVisualBriefModeProfile(mode: VisualBriefMode, slides: boolean
126
126
  "Assumptions, limitations, and source references",
127
127
  ],
128
128
  };
129
+ default:
130
+ throw new Error(`Unknown visual brief mode: ${mode as string}`);
129
131
  }
130
132
  }
131
133
 
@@ -8,6 +8,7 @@ import {
8
8
  formatPageRules,
9
9
  getVisualBriefModeProfile,
10
10
  } from "./page-contract.js";
11
+ import { renderHtmlShellTemplate } from "../shared/html-shell.js";
11
12
 
12
13
  export type VisualBriefMode = "diagram" | "plan" | "diff" | "recap" | "table" | "slides";
13
14
 
@@ -63,6 +64,15 @@ export const VISUAL_BRIEF_MODES: readonly VisualBriefModeInfo[] = [
63
64
  export const VISUAL_BRIEF_USAGE =
64
65
  "Usage: /gsd brief <diagram|plan|diff|recap|table|slides> [topic] [--slides]";
65
66
 
67
+ const VISUAL_BRIEF_KIND: Record<VisualBriefMode, string> = {
68
+ diff: "Diff Brief",
69
+ recap: "Project Recap",
70
+ plan: "Implementation Plan",
71
+ diagram: "Diagram",
72
+ table: "Comparison",
73
+ slides: "Slide Deck",
74
+ };
75
+
66
76
  export function parseVisualBriefArgs(args: string): VisualBriefRequest | null {
67
77
  const rawArgs = args.trim();
68
78
  if (!rawArgs) return null;
@@ -88,13 +98,29 @@ export function parseVisualBriefArgs(args: string): VisualBriefRequest | null {
88
98
  };
89
99
  }
90
100
 
101
+ export interface VisualBriefPromptOptions {
102
+ outputDir: string;
103
+ /** GSD version rendered in the shell header/footer. Falls back to "0.0.0" when not provided. */
104
+ version?: string;
105
+ }
106
+
91
107
  export function buildVisualBriefPrompt(
92
108
  request: VisualBriefRequest,
93
- options: { outputDir: string },
109
+ options: VisualBriefPromptOptions,
94
110
  ): string {
95
111
  const profile = getVisualBriefModeProfile(request.mode, request.slides);
96
112
  const artifactPolicy = createVisualBriefArtifactPolicy(options.outputDir);
97
113
  const outputFormat = request.slides ? "slide deck" : "scrollable explanation page";
114
+ const version = options.version?.trim() || undefined;
115
+ const shell = renderHtmlShellTemplate({
116
+ title: request.subject,
117
+ documentTitle: `GSD ${VISUAL_BRIEF_KIND[request.mode]} - ${request.subject}`,
118
+ subtitle: "Visual brief",
119
+ kind: VISUAL_BRIEF_KIND[request.mode],
120
+ version,
121
+ mainPlaceholder: "{{MAIN_HTML}}",
122
+ footerNote: request.subject,
123
+ });
98
124
 
99
125
  return `Create a visual brief as a single HTML file.
100
126
 
@@ -118,6 +144,16 @@ ${formatPageRules()}
118
144
  3. Write the HTML file.
119
145
  ${formatArtifactPolicy(artifactPolicy).split("\n").map((line) => ` ${line}`).join("\n")}
120
146
 
147
+ ## Required HTML shell
148
+
149
+ Use this scaffold verbatim. Replace {{MAIN_HTML}} with the authored <main> contents and {{GENERATED_AT}} with the current ISO timestamp. Do not add new <style> blocks or replace the header, footer, CSS, or script. The <h1> is the subject only; the kind chip is the only visual carrier of artifact type.
150
+
151
+ \`\`\`html
152
+ ${shell}
153
+ \`\`\`
154
+
155
+ Author only section-level content for {{MAIN_HTML}}. Use the shell utility classes where they fit: .kv-grid, .tbl, .card-row, .card, .callout-info, .callout-warn, .callout-ok, .dot-active, .dot-complete, .dot-pending.
156
+
121
157
  ## Page sections
122
158
 
123
159
  ${profile.sections.map((section) => `- ${section}`).join("\n")}
@@ -88,6 +88,20 @@ test("builds a provider-neutral prompt with output instructions", () => {
88
88
  assert.ok(prompt.indexOf("Gather evidence before writing the page") < prompt.indexOf("Write the HTML file"));
89
89
  });
90
90
 
91
+ test("generated prompts require the shared GSD HTML shell", () => {
92
+ const request = parseVisualBriefArgs("diff");
93
+ assert.ok(request, "diff request should parse");
94
+
95
+ const prompt = buildVisualBriefPrompt(request, { outputDir: "/tmp/visual-brief" });
96
+
97
+ assert.match(prompt, /## Required HTML shell/);
98
+ assert.match(prompt, /<span class="logo">GSD<\/span>/);
99
+ assert.match(prompt, /<span class="kind-chip">Diff Brief<\/span>/);
100
+ assert.match(prompt, /{{MAIN_HTML}}/);
101
+ assert.match(prompt, /{{GENERATED_AT}}/);
102
+ assert.match(prompt, /Do not add new <style> blocks/);
103
+ });
104
+
91
105
  test("returns first-argument completions for visual brief modes", () => {
92
106
  const completions = getVisualBriefCompletions("di");
93
107
 
@@ -167,6 +181,32 @@ test("artifact output directory is under the configured GSD agent directory", ()
167
181
  assert.equal(getVisualBriefOutputDir("/tmp/gsd-agent-test"), join("/tmp/gsd-agent-test", "diagrams"));
168
182
  });
169
183
 
184
+ test("prompt embeds the GSD version in the shell when provided", () => {
185
+ const request = parseVisualBriefArgs("diff release branch changes");
186
+ assert.ok(request, "request should parse");
187
+
188
+ const prompt = buildVisualBriefPrompt(request, { outputDir: "/tmp/visual-brief", version: "9.9.9" });
189
+ assert.match(prompt, /v9\.9\.9/);
190
+ });
191
+
192
+ test("prompt omits the version chip when version is missing or blank", () => {
193
+ const request = parseVisualBriefArgs("diff release branch changes");
194
+ assert.ok(request, "request should parse");
195
+
196
+ const blank = buildVisualBriefPrompt(request, { outputDir: "/tmp/visual-brief", version: " " });
197
+ assert.doesNotMatch(blank, /class="version"/);
198
+
199
+ const missing = buildVisualBriefPrompt(request, { outputDir: "/tmp/visual-brief" });
200
+ assert.doesNotMatch(missing, /class="version"/);
201
+ });
202
+
203
+ test("getVisualBriefModeProfile throws on an unknown mode", () => {
204
+ assert.throws(
205
+ () => getVisualBriefModeProfile("not-a-real-mode" as unknown as Parameters<typeof getVisualBriefModeProfile>[0], false),
206
+ /Unknown visual brief mode: not-a-real-mode/,
207
+ );
208
+ });
209
+
170
210
  function escapeRegExp(value: string): string {
171
211
  return value.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
172
212
  }
@@ -1,2 +0,0 @@
1
- exports.id=5822,exports.ids=[5822],exports.modules={8696:(a,b,c)=>{"use strict";c.d(b,{D:()=>j,N:()=>k});var d=c(67484),e=(a,b,c,d,e,f,g,h)=>{let i=document.documentElement,j=["light","dark"];function k(b){var c;(Array.isArray(a)?a:[a]).forEach(a=>{let c="class"===a,d=c&&f?e.map(a=>f[a]||a):e;c?(i.classList.remove(...d),i.classList.add(f&&f[b]?f[b]:b)):i.setAttribute(a,b)}),c=b,h&&j.includes(c)&&(i.style.colorScheme=c)}if(d)k(d);else try{let a=localStorage.getItem(b)||c,d=g&&"system"===a?window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light":a;k(d)}catch(a){}},f=["light","dark"],g="(prefers-color-scheme: dark)",h=d.createContext(void 0),i={setTheme:a=>{},themes:[]},j=()=>{var a;return null!=(a=d.useContext(h))?a:i},k=a=>d.useContext(h)?d.createElement(d.Fragment,null,a.children):d.createElement(m,{...a}),l=["light","dark"],m=({forcedTheme:a,disableTransitionOnChange:b=!1,enableSystem:c=!0,enableColorScheme:e=!0,storageKey:i="theme",themes:j=l,defaultTheme:k=c?"system":"light",attribute:m="data-theme",value:r,children:s,nonce:t,scriptProps:u})=>{let[v,w]=d.useState(()=>o(i,k)),[x,y]=d.useState(()=>"system"===v?q():v),z=r?Object.values(r):j,A=d.useCallback(a=>{let d=a;if(!d)return;"system"===a&&c&&(d=q());let g=r?r[d]:d,h=b?p(t):null,i=document.documentElement,j=a=>{"class"===a?(i.classList.remove(...z),g&&i.classList.add(g)):a.startsWith("data-")&&(g?i.setAttribute(a,g):i.removeAttribute(a))};if(Array.isArray(m)?m.forEach(j):j(m),e){let a=f.includes(k)?k:null,b=f.includes(d)?d:a;i.style.colorScheme=b}null==h||h()},[t]),B=d.useCallback(a=>{let b="function"==typeof a?a(v):a;w(b);try{localStorage.setItem(i,b)}catch(a){}},[v]),C=d.useCallback(b=>{y(q(b)),"system"===v&&c&&!a&&A("system")},[v,a]);d.useEffect(()=>{let a=window.matchMedia(g);return a.addListener(C),C(a),()=>a.removeListener(C)},[C]),d.useEffect(()=>{let a=a=>{a.key===i&&(a.newValue?w(a.newValue):B(k))};return window.addEventListener("storage",a),()=>window.removeEventListener("storage",a)},[B]),d.useEffect(()=>{A(null!=a?a:v)},[a,v]);let D=d.useMemo(()=>({theme:v,setTheme:B,forcedTheme:a,resolvedTheme:"system"===v?x:v,themes:c?[...j,"system"]:j,systemTheme:c?x:void 0}),[v,B,a,x,c,j]);return d.createElement(h.Provider,{value:D},d.createElement(n,{forcedTheme:a,storageKey:i,attribute:m,enableSystem:c,enableColorScheme:e,defaultTheme:k,value:r,themes:j,nonce:t,scriptProps:u}),s)},n=d.memo(({forcedTheme:a,storageKey:b,attribute:c,enableSystem:f,enableColorScheme:g,defaultTheme:h,value:i,themes:j,nonce:k,scriptProps:l})=>{let m=JSON.stringify([c,b,h,a,j,i,f,g]).slice(1,-1);return d.createElement("script",{...l,suppressHydrationWarning:!0,nonce:k,dangerouslySetInnerHTML:{__html:`(${e.toString()})(${m})`}})}),o=(a,b)=>{},p=a=>{let b=document.createElement("style");return a&&b.setAttribute("nonce",a),b.appendChild(document.createTextNode("*,*::before,*::after{-webkit-transition:none!important;-moz-transition:none!important;-o-transition:none!important;-ms-transition:none!important;transition:none!important}")),document.head.appendChild(b),()=>{window.getComputedStyle(document.body),setTimeout(()=>{document.head.removeChild(b)},1)}},q=a=>(a||(a=window.matchMedia(g)),a.matches?"dark":"light")},55091:(a,b,c)=>{"use strict";Object.defineProperty(b,"__esModule",{value:!0}),Object.defineProperty(b,"default",{enumerable:!0,get:function(){return f}});let d=c(5735),e=c(22675);function f(){return(0,d.jsx)(e.HTTPAccessErrorFallback,{status:404,message:"This page could not be found."})}("function"==typeof b.default||"object"==typeof b.default&&null!==b.default)&&void 0===b.default.__esModule&&(Object.defineProperty(b.default,"__esModule",{value:!0}),Object.assign(b.default,b),a.exports=b.default)},65163:a=>{a.exports={style:{fontFamily:"'Geist Mono', 'Geist Mono Fallback'",fontStyle:"normal"},className:"__className_9a8899",variable:"__variable_9a8899"}},90707:(a,b,c)=>{"use strict";c.d(b,{l$:()=>s});var d=c(67484),e=c(74429),f=Array(12).fill(0),g=({visible:a,className:b})=>d.createElement("div",{className:["sonner-loading-wrapper",b].filter(Boolean).join(" "),"data-visible":a},d.createElement("div",{className:"sonner-spinner"},f.map((a,b)=>d.createElement("div",{className:"sonner-loading-bar",key:`spinner-bar-${b}`})))),h=d.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 20 20",fill:"currentColor",height:"20",width:"20"},d.createElement("path",{fillRule:"evenodd",d:"M10 18a8 8 0 100-16 8 8 0 000 16zm3.857-9.809a.75.75 0 00-1.214-.882l-3.483 4.79-1.88-1.88a.75.75 0 10-1.06 1.061l2.5 2.5a.75.75 0 001.137-.089l4-5.5z",clipRule:"evenodd"})),i=d.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor",height:"20",width:"20"},d.createElement("path",{fillRule:"evenodd",d:"M9.401 3.003c1.155-2 4.043-2 5.197 0l7.355 12.748c1.154 2-.29 4.5-2.599 4.5H4.645c-2.309 0-3.752-2.5-2.598-4.5L9.4 3.003zM12 8.25a.75.75 0 01.75.75v3.75a.75.75 0 01-1.5 0V9a.75.75 0 01.75-.75zm0 8.25a.75.75 0 100-1.5.75.75 0 000 1.5z",clipRule:"evenodd"})),j=d.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 20 20",fill:"currentColor",height:"20",width:"20"},d.createElement("path",{fillRule:"evenodd",d:"M18 10a8 8 0 11-16 0 8 8 0 0116 0zm-7-4a1 1 0 11-2 0 1 1 0 012 0zM9 9a.75.75 0 000 1.5h.253a.25.25 0 01.244.304l-.459 2.066A1.75 1.75 0 0010.747 15H11a.75.75 0 000-1.5h-.253a.25.25 0 01-.244-.304l.459-2.066A1.75 1.75 0 009.253 9H9z",clipRule:"evenodd"})),k=d.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 20 20",fill:"currentColor",height:"20",width:"20"},d.createElement("path",{fillRule:"evenodd",d:"M18 10a8 8 0 11-16 0 8 8 0 0116 0zm-8-5a.75.75 0 01.75.75v4.5a.75.75 0 01-1.5 0v-4.5A.75.75 0 0110 5zm0 10a1 1 0 100-2 1 1 0 000 2z",clipRule:"evenodd"})),l=d.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"},d.createElement("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),d.createElement("line",{x1:"6",y1:"6",x2:"18",y2:"18"})),m=1,n=new class{constructor(){this.subscribe=a=>(this.subscribers.push(a),()=>{let b=this.subscribers.indexOf(a);this.subscribers.splice(b,1)}),this.publish=a=>{this.subscribers.forEach(b=>b(a))},this.addToast=a=>{this.publish(a),this.toasts=[...this.toasts,a]},this.create=a=>{var b;let{message:c,...d}=a,e="number"==typeof(null==a?void 0:a.id)||(null==(b=a.id)?void 0:b.length)>0?a.id:m++,f=this.toasts.find(a=>a.id===e),g=void 0===a.dismissible||a.dismissible;return this.dismissedToasts.has(e)&&this.dismissedToasts.delete(e),f?this.toasts=this.toasts.map(b=>b.id===e?(this.publish({...b,...a,id:e,title:c}),{...b,...a,id:e,dismissible:g,title:c}):b):this.addToast({title:c,...d,dismissible:g,id:e}),e},this.dismiss=a=>(this.dismissedToasts.add(a),a||this.toasts.forEach(a=>{this.subscribers.forEach(b=>b({id:a.id,dismiss:!0}))}),this.subscribers.forEach(b=>b({id:a,dismiss:!0})),a),this.message=(a,b)=>this.create({...b,message:a}),this.error=(a,b)=>this.create({...b,message:a,type:"error"}),this.success=(a,b)=>this.create({...b,type:"success",message:a}),this.info=(a,b)=>this.create({...b,type:"info",message:a}),this.warning=(a,b)=>this.create({...b,type:"warning",message:a}),this.loading=(a,b)=>this.create({...b,type:"loading",message:a}),this.promise=(a,b)=>{let c;if(!b)return;void 0!==b.loading&&(c=this.create({...b,promise:a,type:"loading",message:b.loading,description:"function"!=typeof b.description?b.description:void 0}));let e=a instanceof Promise?a:a(),f=void 0!==c,g,h=e.then(async a=>{if(g=["resolve",a],d.isValidElement(a))f=!1,this.create({id:c,type:"default",message:a});else if(o(a)&&!a.ok){f=!1;let d="function"==typeof b.error?await b.error(`HTTP error! status: ${a.status}`):b.error,e="function"==typeof b.description?await b.description(`HTTP error! status: ${a.status}`):b.description;this.create({id:c,type:"error",message:d,description:e})}else if(void 0!==b.success){f=!1;let d="function"==typeof b.success?await b.success(a):b.success,e="function"==typeof b.description?await b.description(a):b.description;this.create({id:c,type:"success",message:d,description:e})}}).catch(async a=>{if(g=["reject",a],void 0!==b.error){f=!1;let d="function"==typeof b.error?await b.error(a):b.error,e="function"==typeof b.description?await b.description(a):b.description;this.create({id:c,type:"error",message:d,description:e})}}).finally(()=>{var a;f&&(this.dismiss(c),c=void 0),null==(a=b.finally)||a.call(b)}),i=()=>new Promise((a,b)=>h.then(()=>"reject"===g[0]?b(g[1]):a(g[1])).catch(b));return"string"!=typeof c&&"number"!=typeof c?{unwrap:i}:Object.assign(c,{unwrap:i})},this.custom=(a,b)=>{let c=(null==b?void 0:b.id)||m++;return this.create({jsx:a(c),id:c,...b}),c},this.getActiveToasts=()=>this.toasts.filter(a=>!this.dismissedToasts.has(a.id)),this.subscribers=[],this.toasts=[],this.dismissedToasts=new Set}},o=a=>a&&"object"==typeof a&&"ok"in a&&"boolean"==typeof a.ok&&"status"in a&&"number"==typeof a.status;function p(a){return void 0!==a.label}function q(...a){return a.filter(Boolean).join(" ")}Object.assign((a,b)=>{let c=(null==b?void 0:b.id)||m++;return n.addToast({title:a,...b,id:c}),c},{success:n.success,info:n.info,warning:n.warning,error:n.error,custom:n.custom,message:n.message,promise:n.promise,dismiss:n.dismiss,loading:n.loading},{getHistory:()=>n.toasts,getToasts:()=>n.getActiveToasts()}),!function(a,{insertAt:b}={}){if(!a||"u"<typeof document)return;let c=document.head||document.getElementsByTagName("head")[0],d=document.createElement("style");d.type="text/css","top"===b&&c.firstChild?c.insertBefore(d,c.firstChild):c.appendChild(d),d.styleSheet?d.styleSheet.cssText=a:d.appendChild(document.createTextNode(a))}(`:where(html[dir="ltr"]),:where([data-sonner-toaster][dir="ltr"]){--toast-icon-margin-start: -3px;--toast-icon-margin-end: 4px;--toast-svg-margin-start: -1px;--toast-svg-margin-end: 0px;--toast-button-margin-start: auto;--toast-button-margin-end: 0;--toast-close-button-start: 0;--toast-close-button-end: unset;--toast-close-button-transform: translate(-35%, -35%)}:where(html[dir="rtl"]),:where([data-sonner-toaster][dir="rtl"]){--toast-icon-margin-start: 4px;--toast-icon-margin-end: -3px;--toast-svg-margin-start: 0px;--toast-svg-margin-end: -1px;--toast-button-margin-start: 0;--toast-button-margin-end: auto;--toast-close-button-start: unset;--toast-close-button-end: 0;--toast-close-button-transform: translate(35%, -35%)}:where([data-sonner-toaster]){position:fixed;width:var(--width);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;--gray1: hsl(0, 0%, 99%);--gray2: hsl(0, 0%, 97.3%);--gray3: hsl(0, 0%, 95.1%);--gray4: hsl(0, 0%, 93%);--gray5: hsl(0, 0%, 90.9%);--gray6: hsl(0, 0%, 88.7%);--gray7: hsl(0, 0%, 85.8%);--gray8: hsl(0, 0%, 78%);--gray9: hsl(0, 0%, 56.1%);--gray10: hsl(0, 0%, 52.3%);--gray11: hsl(0, 0%, 43.5%);--gray12: hsl(0, 0%, 9%);--border-radius: 8px;box-sizing:border-box;padding:0;margin:0;list-style:none;outline:none;z-index:999999999;transition:transform .4s ease}:where([data-sonner-toaster][data-lifted="true"]){transform:translateY(-10px)}@media (hover: none) and (pointer: coarse){:where([data-sonner-toaster][data-lifted="true"]){transform:none}}:where([data-sonner-toaster][data-x-position="right"]){right:var(--offset-right)}:where([data-sonner-toaster][data-x-position="left"]){left:var(--offset-left)}:where([data-sonner-toaster][data-x-position="center"]){left:50%;transform:translate(-50%)}:where([data-sonner-toaster][data-y-position="top"]){top:var(--offset-top)}:where([data-sonner-toaster][data-y-position="bottom"]){bottom:var(--offset-bottom)}:where([data-sonner-toast]){--y: translateY(100%);--lift-amount: calc(var(--lift) * var(--gap));z-index:var(--z-index);position:absolute;opacity:0;transform:var(--y);filter:blur(0);touch-action:none;transition:transform .4s,opacity .4s,height .4s,box-shadow .2s;box-sizing:border-box;outline:none;overflow-wrap:anywhere}:where([data-sonner-toast][data-styled="true"]){padding:16px;background:var(--normal-bg);border:1px solid var(--normal-border);color:var(--normal-text);border-radius:var(--border-radius);box-shadow:0 4px 12px #0000001a;width:var(--width);font-size:13px;display:flex;align-items:center;gap:6px}:where([data-sonner-toast]:focus-visible){box-shadow:0 4px 12px #0000001a,0 0 0 2px #0003}:where([data-sonner-toast][data-y-position="top"]){top:0;--y: translateY(-100%);--lift: 1;--lift-amount: calc(1 * var(--gap))}:where([data-sonner-toast][data-y-position="bottom"]){bottom:0;--y: translateY(100%);--lift: -1;--lift-amount: calc(var(--lift) * var(--gap))}:where([data-sonner-toast]) :where([data-description]){font-weight:400;line-height:1.4;color:inherit}:where([data-sonner-toast]) :where([data-title]){font-weight:500;line-height:1.5;color:inherit}:where([data-sonner-toast]) :where([data-icon]){display:flex;height:16px;width:16px;position:relative;justify-content:flex-start;align-items:center;flex-shrink:0;margin-left:var(--toast-icon-margin-start);margin-right:var(--toast-icon-margin-end)}:where([data-sonner-toast][data-promise="true"]) :where([data-icon])>svg{opacity:0;transform:scale(.8);transform-origin:center;animation:sonner-fade-in .3s ease forwards}:where([data-sonner-toast]) :where([data-icon])>*{flex-shrink:0}:where([data-sonner-toast]) :where([data-icon]) svg{margin-left:var(--toast-svg-margin-start);margin-right:var(--toast-svg-margin-end)}:where([data-sonner-toast]) :where([data-content]){display:flex;flex-direction:column;gap:2px}[data-sonner-toast][data-styled=true] [data-button]{border-radius:4px;padding-left:8px;padding-right:8px;height:24px;font-size:12px;color:var(--normal-bg);background:var(--normal-text);margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end);border:none;cursor:pointer;outline:none;display:flex;align-items:center;flex-shrink:0;transition:opacity .4s,box-shadow .2s}:where([data-sonner-toast]) :where([data-button]):focus-visible{box-shadow:0 0 0 2px #0006}:where([data-sonner-toast]) :where([data-button]):first-of-type{margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end)}:where([data-sonner-toast]) :where([data-cancel]){color:var(--normal-text);background:rgba(0,0,0,.08)}:where([data-sonner-toast][data-theme="dark"]) :where([data-cancel]){background:rgba(255,255,255,.3)}:where([data-sonner-toast]) :where([data-close-button]){position:absolute;left:var(--toast-close-button-start);right:var(--toast-close-button-end);top:0;height:20px;width:20px;display:flex;justify-content:center;align-items:center;padding:0;color:var(--gray12);border:1px solid var(--gray4);transform:var(--toast-close-button-transform);border-radius:50%;cursor:pointer;z-index:1;transition:opacity .1s,background .2s,border-color .2s}[data-sonner-toast] [data-close-button]{background:var(--gray1)}:where([data-sonner-toast]) :where([data-close-button]):focus-visible{box-shadow:0 4px 12px #0000001a,0 0 0 2px #0003}:where([data-sonner-toast]) :where([data-disabled="true"]){cursor:not-allowed}:where([data-sonner-toast]):hover :where([data-close-button]):hover{background:var(--gray2);border-color:var(--gray5)}:where([data-sonner-toast][data-swiping="true"]):before{content:"";position:absolute;left:-50%;right:-50%;height:100%;z-index:-1}:where([data-sonner-toast][data-y-position="top"][data-swiping="true"]):before{bottom:50%;transform:scaleY(3) translateY(50%)}:where([data-sonner-toast][data-y-position="bottom"][data-swiping="true"]):before{top:50%;transform:scaleY(3) translateY(-50%)}:where([data-sonner-toast][data-swiping="false"][data-removed="true"]):before{content:"";position:absolute;inset:0;transform:scaleY(2)}:where([data-sonner-toast]):after{content:"";position:absolute;left:0;height:calc(var(--gap) + 1px);bottom:100%;width:100%}:where([data-sonner-toast][data-mounted="true"]){--y: translateY(0);opacity:1}:where([data-sonner-toast][data-expanded="false"][data-front="false"]){--scale: var(--toasts-before) * .05 + 1;--y: translateY(calc(var(--lift-amount) * var(--toasts-before))) scale(calc(-1 * var(--scale)));height:var(--front-toast-height)}:where([data-sonner-toast])>*{transition:opacity .4s}:where([data-sonner-toast][data-expanded="false"][data-front="false"][data-styled="true"])>*{opacity:0}:where([data-sonner-toast][data-visible="false"]){opacity:0;pointer-events:none}:where([data-sonner-toast][data-mounted="true"][data-expanded="true"]){--y: translateY(calc(var(--lift) * var(--offset)));height:var(--initial-height)}:where([data-sonner-toast][data-removed="true"][data-front="true"][data-swipe-out="false"]){--y: translateY(calc(var(--lift) * -100%));opacity:0}:where([data-sonner-toast][data-removed="true"][data-front="false"][data-swipe-out="false"][data-expanded="true"]){--y: translateY(calc(var(--lift) * var(--offset) + var(--lift) * -100%));opacity:0}:where([data-sonner-toast][data-removed="true"][data-front="false"][data-swipe-out="false"][data-expanded="false"]){--y: translateY(40%);opacity:0;transition:transform .5s,opacity .2s}:where([data-sonner-toast][data-removed="true"][data-front="false"]):before{height:calc(var(--initial-height) + 20%)}[data-sonner-toast][data-swiping=true]{transform:var(--y) translateY(var(--swipe-amount-y, 0px)) translate(var(--swipe-amount-x, 0px));transition:none}[data-sonner-toast][data-swiped=true]{user-select:none}[data-sonner-toast][data-swipe-out=true][data-y-position=bottom],[data-sonner-toast][data-swipe-out=true][data-y-position=top]{animation-duration:.2s;animation-timing-function:ease-out;animation-fill-mode:forwards}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=left]{animation-name:swipe-out-left}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=right]{animation-name:swipe-out-right}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=up]{animation-name:swipe-out-up}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=down]{animation-name:swipe-out-down}@keyframes swipe-out-left{0%{transform:var(--y) translate(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translate(calc(var(--swipe-amount-x) - 100%));opacity:0}}@keyframes swipe-out-right{0%{transform:var(--y) translate(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translate(calc(var(--swipe-amount-x) + 100%));opacity:0}}@keyframes swipe-out-up{0%{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) - 100%));opacity:0}}@keyframes swipe-out-down{0%{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) + 100%));opacity:0}}@media (max-width: 600px){[data-sonner-toaster]{position:fixed;right:var(--mobile-offset-right);left:var(--mobile-offset-left);width:100%}[data-sonner-toaster][dir=rtl]{left:calc(var(--mobile-offset-left) * -1)}[data-sonner-toaster] [data-sonner-toast]{left:0;right:0;width:calc(100% - var(--mobile-offset-left) * 2)}[data-sonner-toaster][data-x-position=left]{left:var(--mobile-offset-left)}[data-sonner-toaster][data-y-position=bottom]{bottom:var(--mobile-offset-bottom)}[data-sonner-toaster][data-y-position=top]{top:var(--mobile-offset-top)}[data-sonner-toaster][data-x-position=center]{left:var(--mobile-offset-left);right:var(--mobile-offset-right);transform:none}}[data-sonner-toaster][data-theme=light]{--normal-bg: #fff;--normal-border: var(--gray4);--normal-text: var(--gray12);--success-bg: hsl(143, 85%, 96%);--success-border: hsl(145, 92%, 91%);--success-text: hsl(140, 100%, 27%);--info-bg: hsl(208, 100%, 97%);--info-border: hsl(221, 91%, 91%);--info-text: hsl(210, 92%, 45%);--warning-bg: hsl(49, 100%, 97%);--warning-border: hsl(49, 91%, 91%);--warning-text: hsl(31, 92%, 45%);--error-bg: hsl(359, 100%, 97%);--error-border: hsl(359, 100%, 94%);--error-text: hsl(360, 100%, 45%)}[data-sonner-toaster][data-theme=light] [data-sonner-toast][data-invert=true]{--normal-bg: #000;--normal-border: hsl(0, 0%, 20%);--normal-text: var(--gray1)}[data-sonner-toaster][data-theme=dark] [data-sonner-toast][data-invert=true]{--normal-bg: #fff;--normal-border: var(--gray3);--normal-text: var(--gray12)}[data-sonner-toaster][data-theme=dark]{--normal-bg: #000;--normal-bg-hover: hsl(0, 0%, 12%);--normal-border: hsl(0, 0%, 20%);--normal-border-hover: hsl(0, 0%, 25%);--normal-text: var(--gray1);--success-bg: hsl(150, 100%, 6%);--success-border: hsl(147, 100%, 12%);--success-text: hsl(150, 86%, 65%);--info-bg: hsl(215, 100%, 6%);--info-border: hsl(223, 100%, 12%);--info-text: hsl(216, 87%, 65%);--warning-bg: hsl(64, 100%, 6%);--warning-border: hsl(60, 100%, 12%);--warning-text: hsl(46, 87%, 65%);--error-bg: hsl(358, 76%, 10%);--error-border: hsl(357, 89%, 16%);--error-text: hsl(358, 100%, 81%)}[data-sonner-toaster][data-theme=dark] [data-sonner-toast] [data-close-button]{background:var(--normal-bg);border-color:var(--normal-border);color:var(--normal-text)}[data-sonner-toaster][data-theme=dark] [data-sonner-toast] [data-close-button]:hover{background:var(--normal-bg-hover);border-color:var(--normal-border-hover)}[data-rich-colors=true][data-sonner-toast][data-type=success],[data-rich-colors=true][data-sonner-toast][data-type=success] [data-close-button]{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}[data-rich-colors=true][data-sonner-toast][data-type=info],[data-rich-colors=true][data-sonner-toast][data-type=info] [data-close-button]{background:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}[data-rich-colors=true][data-sonner-toast][data-type=warning],[data-rich-colors=true][data-sonner-toast][data-type=warning] [data-close-button]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}[data-rich-colors=true][data-sonner-toast][data-type=error],[data-rich-colors=true][data-sonner-toast][data-type=error] [data-close-button]{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.sonner-loading-wrapper{--size: 16px;height:var(--size);width:var(--size);position:absolute;inset:0;z-index:10}.sonner-loading-wrapper[data-visible=false]{transform-origin:center;animation:sonner-fade-out .2s ease forwards}.sonner-spinner{position:relative;top:50%;left:50%;height:var(--size);width:var(--size)}.sonner-loading-bar{animation:sonner-spin 1.2s linear infinite;background:var(--gray11);border-radius:6px;height:8%;left:-10%;position:absolute;top:-3.9%;width:24%}.sonner-loading-bar:nth-child(1){animation-delay:-1.2s;transform:rotate(.0001deg) translate(146%)}.sonner-loading-bar:nth-child(2){animation-delay:-1.1s;transform:rotate(30deg) translate(146%)}.sonner-loading-bar:nth-child(3){animation-delay:-1s;transform:rotate(60deg) translate(146%)}.sonner-loading-bar:nth-child(4){animation-delay:-.9s;transform:rotate(90deg) translate(146%)}.sonner-loading-bar:nth-child(5){animation-delay:-.8s;transform:rotate(120deg) translate(146%)}.sonner-loading-bar:nth-child(6){animation-delay:-.7s;transform:rotate(150deg) translate(146%)}.sonner-loading-bar:nth-child(7){animation-delay:-.6s;transform:rotate(180deg) translate(146%)}.sonner-loading-bar:nth-child(8){animation-delay:-.5s;transform:rotate(210deg) translate(146%)}.sonner-loading-bar:nth-child(9){animation-delay:-.4s;transform:rotate(240deg) translate(146%)}.sonner-loading-bar:nth-child(10){animation-delay:-.3s;transform:rotate(270deg) translate(146%)}.sonner-loading-bar:nth-child(11){animation-delay:-.2s;transform:rotate(300deg) translate(146%)}.sonner-loading-bar:nth-child(12){animation-delay:-.1s;transform:rotate(330deg) translate(146%)}@keyframes sonner-fade-in{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes sonner-fade-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.8)}}@keyframes sonner-spin{0%{opacity:1}to{opacity:.15}}@media (prefers-reduced-motion){[data-sonner-toast],[data-sonner-toast]>*,.sonner-loading-bar{transition:none!important;animation:none!important}}.sonner-loader{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transform-origin:center;transition:opacity .2s,transform .2s}.sonner-loader[data-visible=false]{opacity:0;transform:scale(.8) translate(-50%,-50%)}
2
- `);var r=a=>{var b,c,e,f,m,n,o,r,s,t,u,v,w,x;let{invert:y,toast:z,unstyled:A,interacting:B,setHeights:C,visibleToasts:D,heights:E,index:F,toasts:G,expanded:H,removeToast:I,defaultRichColors:J,closeButton:K,style:L,cancelButtonStyle:M,actionButtonStyle:N,className:O="",descriptionClassName:P="",duration:Q,position:R,gap:S,loadingIcon:T,expandByDefault:U,classNames:V,icons:W,closeButtonAriaLabel:X="Close toast",pauseWhenPageIsHidden:Y}=a,[Z,$]=d.useState(null),[_,aa]=d.useState(null),[ab,ac]=d.useState(!1),[ad,ae]=d.useState(!1),[af,ag]=d.useState(!1),[ah,ai]=d.useState(!1),[aj,ak]=d.useState(!1),[al,am]=d.useState(0),[an,ao]=d.useState(0),ap=d.useRef(z.duration||Q||4e3),aq=d.useRef(null),ar=d.useRef(null),as=0===F,at=F+1<=D,au=z.type,av=!1!==z.dismissible,aw=z.className||"",ax=z.descriptionClassName||"",ay=d.useMemo(()=>E.findIndex(a=>a.toastId===z.id)||0,[E,z.id]),az=d.useMemo(()=>{var a;return null!=(a=z.closeButton)?a:K},[z.closeButton,K]),aA=d.useMemo(()=>z.duration||Q||4e3,[z.duration,Q]),aB=d.useRef(0),aC=d.useRef(0),aD=d.useRef(0),aE=d.useRef(null),[aF,aG]=R.split("-"),aH=d.useMemo(()=>E.reduce((a,b,c)=>c>=ay?a:a+b.height,0),[E,ay]),aI=(()=>{let[a,b]=d.useState(document.hidden);return d.useEffect(()=>{let a=()=>{b(document.hidden)};return document.addEventListener("visibilitychange",a),()=>window.removeEventListener("visibilitychange",a)},[]),a})(),aJ=z.invert||y,aK="loading"===au;aC.current=d.useMemo(()=>ay*S+aH,[ay,aH]),d.useEffect(()=>{ap.current=aA},[aA]),d.useEffect(()=>{ac(!0)},[]),d.useEffect(()=>{let a=ar.current;if(a){let b=a.getBoundingClientRect().height;return ao(b),C(a=>[{toastId:z.id,height:b,position:z.position},...a]),()=>C(a=>a.filter(a=>a.toastId!==z.id))}},[C,z.id]),d.useLayoutEffect(()=>{if(!ab)return;let a=ar.current,b=a.style.height;a.style.height="auto";let c=a.getBoundingClientRect().height;a.style.height=b,ao(c),C(a=>a.find(a=>a.toastId===z.id)?a.map(a=>a.toastId===z.id?{...a,height:c}:a):[{toastId:z.id,height:c,position:z.position},...a])},[ab,z.title,z.description,C,z.id]);let aL=d.useCallback(()=>{ae(!0),am(aC.current),C(a=>a.filter(a=>a.toastId!==z.id)),setTimeout(()=>{I(z)},200)},[z,I,C,aC]);return d.useEffect(()=>{let a;if((!z.promise||"loading"!==au)&&z.duration!==1/0&&"loading"!==z.type)return H||B||Y&&aI?(()=>{if(aD.current<aB.current){let a=new Date().getTime()-aB.current;ap.current=ap.current-a}aD.current=new Date().getTime()})():ap.current!==1/0&&(aB.current=new Date().getTime(),a=setTimeout(()=>{var a;null==(a=z.onAutoClose)||a.call(z,z),aL()},ap.current)),()=>clearTimeout(a)},[H,B,z,au,Y,aI,aL]),d.useEffect(()=>{z.delete&&aL()},[aL,z.delete]),d.createElement("li",{tabIndex:0,ref:ar,className:q(O,aw,null==V?void 0:V.toast,null==(b=null==z?void 0:z.classNames)?void 0:b.toast,null==V?void 0:V.default,null==V?void 0:V[au],null==(c=null==z?void 0:z.classNames)?void 0:c[au]),"data-sonner-toast":"","data-rich-colors":null!=(e=z.richColors)?e:J,"data-styled":!(z.jsx||z.unstyled||A),"data-mounted":ab,"data-promise":!!z.promise,"data-swiped":aj,"data-removed":ad,"data-visible":at,"data-y-position":aF,"data-x-position":aG,"data-index":F,"data-front":as,"data-swiping":af,"data-dismissible":av,"data-type":au,"data-invert":aJ,"data-swipe-out":ah,"data-swipe-direction":_,"data-expanded":!!(H||U&&ab),style:{"--index":F,"--toasts-before":F,"--z-index":G.length-F,"--offset":`${ad?al:aC.current}px`,"--initial-height":U?"auto":`${an}px`,...L,...z.style},onDragEnd:()=>{ag(!1),$(null),aE.current=null},onPointerDown:a=>{aK||!av||(aq.current=new Date,am(aC.current),a.target.setPointerCapture(a.pointerId),"BUTTON"!==a.target.tagName&&(ag(!0),aE.current={x:a.clientX,y:a.clientY}))},onPointerUp:()=>{var a,b,c,d;if(ah||!av)return;aE.current=null;let e=Number((null==(a=ar.current)?void 0:a.style.getPropertyValue("--swipe-amount-x").replace("px",""))||0),f=Number((null==(b=ar.current)?void 0:b.style.getPropertyValue("--swipe-amount-y").replace("px",""))||0),g=new Date().getTime()-(null==(c=aq.current)?void 0:c.getTime()),h="x"===Z?e:f,i=Math.abs(h)/g;if(Math.abs(h)>=20||i>.11){am(aC.current),null==(d=z.onDismiss)||d.call(z,z),aa("x"===Z?e>0?"right":"left":f>0?"down":"up"),aL(),ai(!0),ak(!1);return}ag(!1),$(null)},onPointerMove:b=>{var c,d,e,f;if(!aE.current||!av||(null==(c=window.getSelection())?void 0:c.toString().length)>0)return;let g=b.clientY-aE.current.y,h=b.clientX-aE.current.x,i=null!=(d=a.swipeDirections)?d:function(a){let[b,c]=a.split("-"),d=[];return b&&d.push(b),c&&d.push(c),d}(R);!Z&&(Math.abs(h)>1||Math.abs(g)>1)&&$(Math.abs(h)>Math.abs(g)?"x":"y");let j={x:0,y:0};"y"===Z?(i.includes("top")||i.includes("bottom"))&&(i.includes("top")&&g<0||i.includes("bottom")&&g>0)&&(j.y=g):"x"===Z&&(i.includes("left")||i.includes("right"))&&(i.includes("left")&&h<0||i.includes("right")&&h>0)&&(j.x=h),(Math.abs(j.x)>0||Math.abs(j.y)>0)&&ak(!0),null==(e=ar.current)||e.style.setProperty("--swipe-amount-x",`${j.x}px`),null==(f=ar.current)||f.style.setProperty("--swipe-amount-y",`${j.y}px`)}},az&&!z.jsx?d.createElement("button",{"aria-label":X,"data-disabled":aK,"data-close-button":!0,onClick:aK||!av?()=>{}:()=>{var a;aL(),null==(a=z.onDismiss)||a.call(z,z)},className:q(null==V?void 0:V.closeButton,null==(f=null==z?void 0:z.classNames)?void 0:f.closeButton)},null!=(m=null==W?void 0:W.close)?m:l):null,z.jsx||(0,d.isValidElement)(z.title)?z.jsx?z.jsx:"function"==typeof z.title?z.title():z.title:d.createElement(d.Fragment,null,au||z.icon||z.promise?d.createElement("div",{"data-icon":"",className:q(null==V?void 0:V.icon,null==(n=null==z?void 0:z.classNames)?void 0:n.icon)},z.promise||"loading"===z.type&&!z.icon?z.icon||(null!=W&&W.loading?d.createElement("div",{className:q(null==V?void 0:V.loader,null==(v=null==z?void 0:z.classNames)?void 0:v.loader,"sonner-loader"),"data-visible":"loading"===au},W.loading):T?d.createElement("div",{className:q(null==V?void 0:V.loader,null==(w=null==z?void 0:z.classNames)?void 0:w.loader,"sonner-loader"),"data-visible":"loading"===au},T):d.createElement(g,{className:q(null==V?void 0:V.loader,null==(x=null==z?void 0:z.classNames)?void 0:x.loader),visible:"loading"===au})):null,"loading"!==z.type?z.icon||(null==W?void 0:W[au])||(a=>{switch(a){case"success":return h;case"info":return j;case"warning":return i;case"error":return k;default:return null}})(au):null):null,d.createElement("div",{"data-content":"",className:q(null==V?void 0:V.content,null==(o=null==z?void 0:z.classNames)?void 0:o.content)},d.createElement("div",{"data-title":"",className:q(null==V?void 0:V.title,null==(r=null==z?void 0:z.classNames)?void 0:r.title)},"function"==typeof z.title?z.title():z.title),z.description?d.createElement("div",{"data-description":"",className:q(P,ax,null==V?void 0:V.description,null==(s=null==z?void 0:z.classNames)?void 0:s.description)},"function"==typeof z.description?z.description():z.description):null),(0,d.isValidElement)(z.cancel)?z.cancel:z.cancel&&p(z.cancel)?d.createElement("button",{"data-button":!0,"data-cancel":!0,style:z.cancelButtonStyle||M,onClick:a=>{var b,c;p(z.cancel)&&av&&(null==(c=(b=z.cancel).onClick)||c.call(b,a),aL())},className:q(null==V?void 0:V.cancelButton,null==(t=null==z?void 0:z.classNames)?void 0:t.cancelButton)},z.cancel.label):null,(0,d.isValidElement)(z.action)?z.action:z.action&&p(z.action)?d.createElement("button",{"data-button":!0,"data-action":!0,style:z.actionButtonStyle||N,onClick:a=>{var b,c;p(z.action)&&(null==(c=(b=z.action).onClick)||c.call(b,a),a.defaultPrevented||aL())},className:q(null==V?void 0:V.actionButton,null==(u=null==z?void 0:z.classNames)?void 0:u.actionButton)},z.action.label):null))},s=(0,d.forwardRef)(function(a,b){let{invert:c,position:f="bottom-right",hotkey:g=["altKey","KeyT"],expand:h,closeButton:i,className:j,offset:k,mobileOffset:l,theme:m="light",richColors:o,duration:p,style:q,visibleToasts:s=3,toastOptions:t,dir:u="ltr",gap:v=14,loadingIcon:w,icons:x,containerAriaLabel:y="Notifications",pauseWhenPageIsHidden:z}=a,[A,B]=d.useState([]),C=d.useMemo(()=>Array.from(new Set([f].concat(A.filter(a=>a.position).map(a=>a.position)))),[A,f]),[D,E]=d.useState([]),[F,G]=d.useState(!1),[H,I]=d.useState(!1),[J,K]=d.useState("system"!==m?m:"light"),L=d.useRef(null),M=g.join("+").replace(/Key/g,"").replace(/Digit/g,""),N=d.useRef(null),O=d.useRef(!1),P=d.useCallback(a=>{B(b=>{var c;return null!=(c=b.find(b=>b.id===a.id))&&c.delete||n.dismiss(a.id),b.filter(({id:b})=>b!==a.id)})},[]);return d.useEffect(()=>n.subscribe(a=>{a.dismiss?B(b=>b.map(b=>b.id===a.id?{...b,delete:!0}:b)):setTimeout(()=>{e.flushSync(()=>{B(b=>{let c=b.findIndex(b=>b.id===a.id);return -1!==c?[...b.slice(0,c),{...b[c],...a},...b.slice(c+1)]:[a,...b]})})})}),[]),d.useEffect(()=>{"system"!==m?K(m):"system"===m&&(window.matchMedia&&window.matchMedia("(prefers-color-scheme: dark)").matches?K("dark"):K("light"))},[m]),d.useEffect(()=>{A.length<=1&&G(!1)},[A]),d.useEffect(()=>{let a=a=>{var b,c;g.every(b=>a[b]||a.code===b)&&(G(!0),null==(b=L.current)||b.focus()),"Escape"===a.code&&(document.activeElement===L.current||null!=(c=L.current)&&c.contains(document.activeElement))&&G(!1)};return document.addEventListener("keydown",a),()=>document.removeEventListener("keydown",a)},[g]),d.useEffect(()=>{if(L.current)return()=>{N.current&&(N.current.focus({preventScroll:!0}),N.current=null,O.current=!1)}},[L.current]),d.createElement("section",{ref:b,"aria-label":`${y} ${M}`,tabIndex:-1,"aria-live":"polite","aria-relevant":"additions text","aria-atomic":"false",suppressHydrationWarning:!0},C.map((b,e)=>{var f;let g,[m,n]=b.split("-");return A.length?d.createElement("ol",{key:b,dir:"auto"===u?"ltr":u,tabIndex:-1,ref:L,className:j,"data-sonner-toaster":!0,"data-theme":J,"data-y-position":m,"data-lifted":F&&A.length>1&&!h,"data-x-position":n,style:{"--front-toast-height":`${(null==(f=D[0])?void 0:f.height)||0}px`,"--width":"356px","--gap":`${v}px`,...q,...(g={},[k,l].forEach((a,b)=>{let c=1===b,d=c?"--mobile-offset":"--offset",e=c?"16px":"32px";function f(a){["top","right","bottom","left"].forEach(b=>{g[`${d}-${b}`]="number"==typeof a?`${a}px`:a})}"number"==typeof a||"string"==typeof a?f(a):"object"==typeof a?["top","right","bottom","left"].forEach(b=>{void 0===a[b]?g[`${d}-${b}`]=e:g[`${d}-${b}`]="number"==typeof a[b]?`${a[b]}px`:a[b]}):f(e)}),g)},onBlur:a=>{O.current&&!a.currentTarget.contains(a.relatedTarget)&&(O.current=!1,N.current&&(N.current.focus({preventScroll:!0}),N.current=null))},onFocus:a=>{a.target instanceof HTMLElement&&"false"===a.target.dataset.dismissible||O.current||(O.current=!0,N.current=a.relatedTarget)},onMouseEnter:()=>G(!0),onMouseMove:()=>G(!0),onMouseLeave:()=>{H||G(!1)},onDragEnd:()=>G(!1),onPointerDown:a=>{a.target instanceof HTMLElement&&"false"===a.target.dataset.dismissible||I(!0)},onPointerUp:()=>I(!1)},A.filter(a=>!a.position&&0===e||a.position===b).map((e,f)=>{var g,j;return d.createElement(r,{key:e.id,icons:x,index:f,toast:e,defaultRichColors:o,duration:null!=(g=null==t?void 0:t.duration)?g:p,className:null==t?void 0:t.className,descriptionClassName:null==t?void 0:t.descriptionClassName,invert:c,visibleToasts:s,closeButton:null!=(j=null==t?void 0:t.closeButton)?j:i,interacting:H,position:b,style:null==t?void 0:t.style,unstyled:null==t?void 0:t.unstyled,classNames:null==t?void 0:t.classNames,cancelButtonStyle:null==t?void 0:t.cancelButtonStyle,actionButtonStyle:null==t?void 0:t.actionButtonStyle,removeToast:P,toasts:A.filter(a=>a.position==e.position),heights:D.filter(a=>a.position==e.position),setHeights:E,expandByDefault:h,gap:v,loadingIcon:w,expanded:F,pauseWhenPageIsHidden:z,swipeDirections:a.swipeDirections})})):null}))})},94487:a=>{a.exports={style:{fontFamily:"'Geist', 'Geist Fallback'",fontStyle:"normal"},className:"__className_188709",variable:"__variable_188709"}}};
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[7177],{21942:(e,r,s)=>{"use strict";s.d(r,{ThemeProvider:()=>o});var a=s(95155);s(12115);var t=s(70460);function o({children:e,...r}){return(0,a.jsx)(t.N,{...r,children:e})}},35696:e=>{e.exports={style:{fontFamily:"'Geist Mono', 'Geist Mono Fallback'",fontStyle:"normal"},className:"__className_9a8899",variable:"__variable_9a8899"}},39040:(e,r,s)=>{Promise.resolve().then(s.bind(s,21942)),Promise.resolve().then(s.bind(s,61549)),Promise.resolve().then(s.t.bind(s,85048,23)),Promise.resolve().then(s.t.bind(s,35696,23)),Promise.resolve().then(s.t.bind(s,66872,23))},61549:(e,r,s)=>{"use strict";s.d(r,{Toaster:()=>l});var a=s(95155),t=s(70460),o=s(66609);let l=({...e})=>{let{theme:r="system"}=(0,t.D)();return(0,a.jsx)(o.l$,{theme:r,className:"toaster group",style:{"--normal-bg":"var(--popover)","--normal-text":"var(--popover-foreground)","--normal-border":"var(--border)"},...e})}},66872:()=>{},85048:e=>{e.exports={style:{fontFamily:"'Geist', 'Geist Fallback'",fontStyle:"normal"},className:"__className_188709",variable:"__variable_188709"}}},e=>{e.O(0,[2557,7513,4986,8441,3794,7358],()=>e(e.s=39040)),_N_E=e.O()}]);