@compilr-dev/cli 0.4.0 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (315) hide show
  1. package/README.md +30 -12
  2. package/dist/agent.d.ts +74 -1
  3. package/dist/agent.js +259 -76
  4. package/dist/anchors/index.d.ts +9 -0
  5. package/dist/anchors/index.js +9 -0
  6. package/dist/anchors/project-anchors.d.ts +79 -0
  7. package/dist/anchors/project-anchors.js +202 -0
  8. package/dist/commands/handler-types.d.ts +68 -0
  9. package/dist/commands/handler-types.js +8 -0
  10. package/dist/commands/handlers/agent-commands.d.ts +13 -0
  11. package/dist/commands/handlers/agent-commands.js +305 -0
  12. package/dist/commands/handlers/design-commands.d.ts +15 -0
  13. package/dist/commands/handlers/design-commands.js +334 -0
  14. package/dist/commands/handlers/index.d.ts +20 -0
  15. package/dist/commands/handlers/index.js +43 -0
  16. package/dist/commands/handlers/overlay-commands.d.ts +21 -0
  17. package/dist/commands/handlers/overlay-commands.js +287 -0
  18. package/dist/commands/handlers/project-commands.d.ts +11 -0
  19. package/dist/commands/handlers/project-commands.js +167 -0
  20. package/dist/commands/handlers/simple-commands.d.ts +19 -0
  21. package/dist/commands/handlers/simple-commands.js +144 -0
  22. package/dist/commands/index.d.ts +2 -1
  23. package/dist/commands/registry.d.ts +50 -0
  24. package/dist/commands/registry.js +75 -0
  25. package/dist/commands-v2/handlers/context.d.ts +13 -0
  26. package/dist/commands-v2/handlers/context.js +348 -0
  27. package/dist/commands-v2/handlers/core.d.ts +13 -0
  28. package/dist/commands-v2/handlers/core.js +165 -0
  29. package/dist/commands-v2/handlers/debug.d.ts +11 -0
  30. package/dist/commands-v2/handlers/debug.js +159 -0
  31. package/dist/commands-v2/handlers/index.d.ts +12 -0
  32. package/dist/commands-v2/handlers/index.js +24 -0
  33. package/dist/commands-v2/handlers/project.d.ts +22 -0
  34. package/dist/commands-v2/handlers/project.js +814 -0
  35. package/dist/commands-v2/handlers/settings.d.ts +15 -0
  36. package/dist/commands-v2/handlers/settings.js +235 -0
  37. package/dist/commands-v2/index.d.ts +13 -0
  38. package/dist/commands-v2/index.js +15 -0
  39. package/dist/commands-v2/registry.d.ts +37 -0
  40. package/dist/commands-v2/registry.js +80 -0
  41. package/dist/commands-v2/types.d.ts +75 -0
  42. package/dist/commands-v2/types.js +7 -0
  43. package/dist/commands.js +110 -7
  44. package/dist/index.js +288 -29
  45. package/dist/input-handlers/index.d.ts +7 -0
  46. package/dist/input-handlers/index.js +7 -0
  47. package/dist/input-handlers/memory-handler.d.ts +26 -0
  48. package/dist/input-handlers/memory-handler.js +68 -0
  49. package/dist/repl-helpers.d.ts +63 -0
  50. package/dist/repl-helpers.js +318 -0
  51. package/dist/repl-v2.d.ts +155 -0
  52. package/dist/repl-v2.js +774 -0
  53. package/dist/repl.d.ts +32 -4
  54. package/dist/repl.js +250 -977
  55. package/dist/settings/index.d.ts +23 -0
  56. package/dist/settings/index.js +48 -0
  57. package/dist/settings/paths.d.ts +110 -0
  58. package/dist/settings/paths.js +264 -0
  59. package/dist/templates/compilr-md.js +7 -4
  60. package/dist/templates/index.js +3 -4
  61. package/dist/themes/colors.js +3 -1
  62. package/dist/themes/registry.d.ts +5 -36
  63. package/dist/themes/registry.js +11 -95
  64. package/dist/themes/types.d.ts +3 -38
  65. package/dist/themes/types.js +2 -2
  66. package/dist/tools/anchor-tools.d.ts +31 -0
  67. package/dist/tools/anchor-tools.js +255 -0
  68. package/dist/tools/backlog-wrappers.d.ts +54 -0
  69. package/dist/tools/backlog-wrappers.js +338 -0
  70. package/dist/tools/backlog.js +1 -1
  71. package/dist/tools/db-tools.d.ts +65 -0
  72. package/dist/tools/db-tools.js +19 -0
  73. package/dist/tools/document-db.d.ts +43 -0
  74. package/dist/tools/document-db.js +220 -0
  75. package/dist/tools/project-db.d.ts +102 -0
  76. package/dist/tools/project-db.js +370 -0
  77. package/dist/tools/workitem-db.d.ts +103 -0
  78. package/dist/tools/workitem-db.js +549 -0
  79. package/dist/tools.js +13 -3
  80. package/dist/ui/agents-overlay-v2.d.ts +43 -0
  81. package/dist/ui/agents-overlay-v2.js +809 -0
  82. package/dist/ui/agents-overlay.d.ts +5 -5
  83. package/dist/ui/agents-overlay.js +782 -420
  84. package/dist/ui/anchors-overlay.d.ts +12 -0
  85. package/dist/ui/anchors-overlay.js +775 -0
  86. package/dist/ui/arch-type-overlay.d.ts +1 -6
  87. package/dist/ui/arch-type-overlay.js +175 -203
  88. package/dist/ui/ask-user-overlay-v2.d.ts +26 -0
  89. package/dist/ui/ask-user-overlay-v2.js +555 -0
  90. package/dist/ui/ask-user-overlay.d.ts +2 -2
  91. package/dist/ui/ask-user-overlay.js +443 -535
  92. package/dist/ui/ask-user-simple-overlay-v2.d.ts +25 -0
  93. package/dist/ui/ask-user-simple-overlay-v2.js +215 -0
  94. package/dist/ui/ask-user-simple-overlay.d.ts +2 -2
  95. package/dist/ui/ask-user-simple-overlay.js +182 -209
  96. package/dist/ui/backlog-overlay.d.ts +16 -1
  97. package/dist/ui/backlog-overlay.js +525 -659
  98. package/dist/ui/base/index.d.ts +26 -0
  99. package/dist/ui/base/index.js +33 -0
  100. package/dist/ui/base/inline-overlay-utils.d.ts +217 -0
  101. package/dist/ui/base/inline-overlay-utils.js +320 -0
  102. package/dist/ui/base/inline-overlay.d.ts +159 -0
  103. package/dist/ui/base/inline-overlay.js +257 -0
  104. package/dist/ui/base/key-utils.d.ts +15 -0
  105. package/dist/ui/base/key-utils.js +30 -0
  106. package/dist/ui/base/overlay-base-v2.d.ts +193 -0
  107. package/dist/ui/base/overlay-base-v2.js +246 -0
  108. package/dist/ui/base/overlay-base.d.ts +156 -0
  109. package/dist/ui/base/overlay-base.js +238 -0
  110. package/dist/ui/base/overlay-lifecycle.d.ts +65 -0
  111. package/dist/ui/base/overlay-lifecycle.js +159 -0
  112. package/dist/ui/base/overlay-types.d.ts +185 -0
  113. package/dist/ui/base/overlay-types.js +7 -0
  114. package/dist/ui/base/render-utils.d.ts +8 -0
  115. package/dist/ui/base/render-utils.js +11 -0
  116. package/dist/ui/base/screen-stack.d.ts +148 -0
  117. package/dist/ui/base/screen-stack.js +184 -0
  118. package/dist/ui/base/tabbed-list-overlay-v2.d.ts +103 -0
  119. package/dist/ui/base/tabbed-list-overlay-v2.js +317 -0
  120. package/dist/ui/base/tabbed-list-overlay.d.ts +153 -0
  121. package/dist/ui/base/tabbed-list-overlay.js +369 -0
  122. package/dist/ui/commands-overlay-v2.d.ts +33 -0
  123. package/dist/ui/commands-overlay-v2.js +441 -0
  124. package/dist/ui/commands-overlay.d.ts +7 -2
  125. package/dist/ui/commands-overlay.js +384 -355
  126. package/dist/ui/config-overlay.d.ts +5 -4
  127. package/dist/ui/config-overlay.js +243 -513
  128. package/dist/ui/conversation.d.ts +75 -4
  129. package/dist/ui/conversation.js +374 -161
  130. package/dist/ui/docs-overlay.d.ts +17 -0
  131. package/dist/ui/docs-overlay.js +303 -0
  132. package/dist/ui/ephemeral.d.ts +1 -1
  133. package/dist/ui/ephemeral.js +1 -1
  134. package/dist/ui/features/index.d.ts +34 -0
  135. package/dist/ui/features/index.js +34 -0
  136. package/dist/ui/features/input-feature.d.ts +85 -0
  137. package/dist/ui/features/input-feature.js +238 -0
  138. package/dist/ui/features/list-feature.d.ts +155 -0
  139. package/dist/ui/features/list-feature.js +244 -0
  140. package/dist/ui/features/pagination-feature.d.ts +154 -0
  141. package/dist/ui/features/pagination-feature.js +238 -0
  142. package/dist/ui/features/search-feature.d.ts +148 -0
  143. package/dist/ui/features/search-feature.js +185 -0
  144. package/dist/ui/features/tab-feature.d.ts +194 -0
  145. package/dist/ui/features/tab-feature.js +307 -0
  146. package/dist/ui/footer-v2.d.ts +222 -0
  147. package/dist/ui/footer-v2.js +1349 -0
  148. package/dist/ui/footer.d.ts +107 -0
  149. package/dist/ui/footer.js +359 -67
  150. package/dist/ui/guardrail-overlay.d.ts +29 -0
  151. package/dist/ui/guardrail-overlay.js +145 -0
  152. package/dist/ui/help-overlay-v2.d.ts +34 -0
  153. package/dist/ui/help-overlay-v2.js +309 -0
  154. package/dist/ui/help-overlay.d.ts +16 -0
  155. package/dist/ui/help-overlay.js +316 -0
  156. package/dist/ui/index.d.ts +1 -1
  157. package/dist/ui/index.js +1 -3
  158. package/dist/ui/init-overlay-v2.d.ts +34 -0
  159. package/dist/ui/init-overlay-v2.js +600 -0
  160. package/dist/ui/init-overlay.d.ts +12 -2
  161. package/dist/ui/init-overlay.js +349 -270
  162. package/dist/ui/input-prompt-v2.d.ts +1 -0
  163. package/dist/ui/input-prompt-v2.js +14 -6
  164. package/dist/ui/input-prompt.d.ts +116 -33
  165. package/dist/ui/input-prompt.js +536 -337
  166. package/dist/ui/iteration-limit-overlay-v2.d.ts +21 -0
  167. package/dist/ui/iteration-limit-overlay-v2.js +114 -0
  168. package/dist/ui/iteration-limit-overlay.d.ts +2 -2
  169. package/dist/ui/iteration-limit-overlay.js +92 -128
  170. package/dist/ui/keys-overlay-v2.d.ts +41 -0
  171. package/dist/ui/keys-overlay-v2.js +248 -0
  172. package/dist/ui/keys-overlay.d.ts +1 -0
  173. package/dist/ui/keys-overlay.js +203 -141
  174. package/dist/ui/line-utils.d.ts +88 -0
  175. package/dist/ui/line-utils.js +150 -0
  176. package/dist/ui/live-region.d.ts +161 -0
  177. package/dist/ui/live-region.js +387 -0
  178. package/dist/ui/mascot/expressions.d.ts +32 -0
  179. package/dist/ui/mascot/expressions.js +213 -0
  180. package/dist/ui/mascot/index.d.ts +8 -0
  181. package/dist/ui/mascot/index.js +8 -0
  182. package/dist/ui/mascot/renderer.d.ts +19 -0
  183. package/dist/ui/mascot/renderer.js +97 -0
  184. package/dist/ui/mascot-overlay-v2.d.ts +41 -0
  185. package/dist/ui/mascot-overlay-v2.js +138 -0
  186. package/dist/ui/mascot-overlay.d.ts +21 -0
  187. package/dist/ui/mascot-overlay.js +146 -0
  188. package/dist/ui/model-overlay-v2.d.ts +49 -0
  189. package/dist/ui/model-overlay-v2.js +118 -0
  190. package/dist/ui/model-overlay.d.ts +27 -0
  191. package/dist/ui/model-overlay.js +221 -0
  192. package/dist/ui/model-warning-overlay.js +3 -5
  193. package/dist/ui/new-overlay.d.ts +34 -0
  194. package/dist/ui/new-overlay.js +604 -0
  195. package/dist/ui/overlay/impl/agents-overlay-v2.d.ts +45 -0
  196. package/dist/ui/overlay/impl/agents-overlay-v2.js +825 -0
  197. package/dist/ui/overlay/impl/anchors-overlay-v2.d.ts +47 -0
  198. package/dist/ui/overlay/impl/anchors-overlay-v2.js +783 -0
  199. package/dist/ui/overlay/impl/arch-type-overlay-v2.d.ts +37 -0
  200. package/dist/ui/overlay/impl/arch-type-overlay-v2.js +240 -0
  201. package/dist/ui/overlay/impl/ask-user-overlay-v2.d.ts +72 -0
  202. package/dist/ui/overlay/impl/ask-user-overlay-v2.js +584 -0
  203. package/dist/ui/overlay/impl/ask-user-simple-overlay-v2.d.ts +46 -0
  204. package/dist/ui/overlay/impl/ask-user-simple-overlay-v2.js +204 -0
  205. package/dist/ui/overlay/impl/backlog-overlay-v2.d.ts +49 -0
  206. package/dist/ui/overlay/impl/backlog-overlay-v2.js +642 -0
  207. package/dist/ui/overlay/impl/commands-overlay-v2.d.ts +33 -0
  208. package/dist/ui/overlay/impl/commands-overlay-v2.js +441 -0
  209. package/dist/ui/overlay/impl/config-overlay-v2.d.ts +100 -0
  210. package/dist/ui/overlay/impl/config-overlay-v2.js +654 -0
  211. package/dist/ui/overlay/impl/dashboard-overlay-v2.d.ts +55 -0
  212. package/dist/ui/overlay/impl/dashboard-overlay-v2.js +359 -0
  213. package/dist/ui/overlay/impl/docs-overlay-v2.d.ts +45 -0
  214. package/dist/ui/overlay/impl/docs-overlay-v2.js +114 -0
  215. package/dist/ui/overlay/impl/document-detail-overlay-v2.d.ts +77 -0
  216. package/dist/ui/overlay/impl/document-detail-overlay-v2.js +1071 -0
  217. package/dist/ui/overlay/impl/guardrail-overlay-v2.d.ts +43 -0
  218. package/dist/ui/overlay/impl/guardrail-overlay-v2.js +114 -0
  219. package/dist/ui/overlay/impl/help-overlay-v2.d.ts +34 -0
  220. package/dist/ui/overlay/impl/help-overlay-v2.js +309 -0
  221. package/dist/ui/overlay/impl/init-overlay-v2.d.ts +77 -0
  222. package/dist/ui/overlay/impl/init-overlay-v2.js +593 -0
  223. package/dist/ui/overlay/impl/init-setup-overlay-v2.d.ts +25 -0
  224. package/dist/ui/overlay/impl/init-setup-overlay-v2.js +97 -0
  225. package/dist/ui/overlay/impl/iteration-limit-overlay-v2.d.ts +35 -0
  226. package/dist/ui/overlay/impl/iteration-limit-overlay-v2.js +105 -0
  227. package/dist/ui/overlay/impl/keys-overlay-v2.d.ts +41 -0
  228. package/dist/ui/overlay/impl/keys-overlay-v2.js +248 -0
  229. package/dist/ui/overlay/impl/mascot-overlay-v2.d.ts +41 -0
  230. package/dist/ui/overlay/impl/mascot-overlay-v2.js +138 -0
  231. package/dist/ui/overlay/impl/model-overlay-v2.d.ts +49 -0
  232. package/dist/ui/overlay/impl/model-overlay-v2.js +118 -0
  233. package/dist/ui/overlay/impl/model-warning-overlay-v2.d.ts +46 -0
  234. package/dist/ui/overlay/impl/model-warning-overlay-v2.js +132 -0
  235. package/dist/ui/overlay/impl/new-overlay-v2.d.ts +77 -0
  236. package/dist/ui/overlay/impl/new-overlay-v2.js +593 -0
  237. package/dist/ui/overlay/impl/permission-overlay-v2.d.ts +36 -0
  238. package/dist/ui/overlay/impl/permission-overlay-v2.js +380 -0
  239. package/dist/ui/overlay/impl/projects-overlay-v2.d.ts +36 -0
  240. package/dist/ui/overlay/impl/projects-overlay-v2.js +499 -0
  241. package/dist/ui/overlay/impl/theme-overlay-v2.d.ts +42 -0
  242. package/dist/ui/overlay/impl/theme-overlay-v2.js +135 -0
  243. package/dist/ui/overlay/impl/tools-overlay-v2.d.ts +47 -0
  244. package/dist/ui/overlay/impl/tools-overlay-v2.js +218 -0
  245. package/dist/ui/overlay/impl/tutorial-overlay-v2.d.ts +31 -0
  246. package/dist/ui/overlay/impl/tutorial-overlay-v2.js +1035 -0
  247. package/dist/ui/overlay/impl/workflow-overlay-v2.d.ts +80 -0
  248. package/dist/ui/overlay/impl/workflow-overlay-v2.js +637 -0
  249. package/dist/ui/overlay/index.d.ts +33 -0
  250. package/dist/ui/overlay/index.js +35 -0
  251. package/dist/ui/overlay/key-utils.d.ts +6 -0
  252. package/dist/ui/overlay/key-utils.js +6 -0
  253. package/dist/ui/overlay/overlay-types.d.ts +128 -0
  254. package/dist/ui/overlay/overlay-types.js +22 -0
  255. package/dist/ui/overlay/types.d.ts +135 -0
  256. package/dist/ui/overlay/types.js +22 -0
  257. package/dist/ui/overlays/help-overlay-v2.d.ts +28 -0
  258. package/dist/ui/overlays/help-overlay-v2.js +198 -0
  259. package/dist/ui/overlays/index.d.ts +11 -0
  260. package/dist/ui/overlays/index.js +11 -0
  261. package/dist/ui/overlays.d.ts +0 -4
  262. package/dist/ui/overlays.js +0 -444
  263. package/dist/ui/permission-overlay-v2.d.ts +36 -0
  264. package/dist/ui/permission-overlay-v2.js +380 -0
  265. package/dist/ui/permission-overlay.d.ts +1 -1
  266. package/dist/ui/permission-overlay.js +186 -298
  267. package/dist/ui/projects-overlay.d.ts +19 -0
  268. package/dist/ui/projects-overlay.js +484 -0
  269. package/dist/ui/providers/types.d.ts +178 -0
  270. package/dist/ui/providers/types.js +9 -0
  271. package/dist/ui/render-modes.d.ts +36 -0
  272. package/dist/ui/render-modes.js +44 -0
  273. package/dist/ui/startup-menu.d.ts +36 -0
  274. package/dist/ui/startup-menu.js +236 -0
  275. package/dist/ui/subagent-renderer.d.ts +117 -0
  276. package/dist/ui/subagent-renderer.js +334 -0
  277. package/dist/ui/terminal-codes.d.ts +94 -0
  278. package/dist/ui/terminal-codes.js +124 -0
  279. package/dist/ui/terminal-renderer.d.ts +221 -0
  280. package/dist/ui/terminal-renderer.js +751 -0
  281. package/dist/ui/terminal-ui.d.ts +463 -0
  282. package/dist/ui/terminal-ui.js +2296 -0
  283. package/dist/ui/terminal.d.ts +20 -0
  284. package/dist/ui/terminal.js +72 -0
  285. package/dist/ui/theme-overlay-v2.d.ts +42 -0
  286. package/dist/ui/theme-overlay-v2.js +135 -0
  287. package/dist/ui/theme-overlay.d.ts +24 -0
  288. package/dist/ui/theme-overlay.js +127 -0
  289. package/dist/ui/todo-zone.js +53 -25
  290. package/dist/ui/tool-formatters.d.ts +16 -0
  291. package/dist/ui/tool-formatters.js +516 -0
  292. package/dist/ui/tools-overlay-v2.d.ts +47 -0
  293. package/dist/ui/tools-overlay-v2.js +218 -0
  294. package/dist/ui/tools-overlay.d.ts +10 -2
  295. package/dist/ui/tools-overlay.js +172 -220
  296. package/dist/ui/tutorial-overlay-v2.d.ts +31 -0
  297. package/dist/ui/tutorial-overlay-v2.js +1035 -0
  298. package/dist/ui/tutorial-overlay.d.ts +1 -0
  299. package/dist/ui/tutorial-overlay.js +400 -302
  300. package/dist/ui/workflow-overlay.d.ts +22 -0
  301. package/dist/ui/workflow-overlay.js +636 -0
  302. package/dist/utils/debug-log.d.ts +28 -0
  303. package/dist/utils/debug-log.js +57 -0
  304. package/dist/utils/model-tiers.js +1 -1
  305. package/dist/utils/path-safety.d.ts +56 -0
  306. package/dist/utils/path-safety.js +239 -0
  307. package/dist/workflow/guided-mode-injector.d.ts +42 -0
  308. package/dist/workflow/guided-mode-injector.js +191 -0
  309. package/dist/workflow/index.d.ts +8 -0
  310. package/dist/workflow/index.js +8 -0
  311. package/dist/workflow/step-criteria.d.ts +62 -0
  312. package/dist/workflow/step-criteria.js +150 -0
  313. package/dist/workflow/step-tracker.d.ts +92 -0
  314. package/dist/workflow/step-tracker.js +141 -0
  315. package/package.json +12 -5
@@ -0,0 +1,600 @@
1
+ /**
2
+ * Init Overlay (Refactored)
3
+ *
4
+ * Modal overlay for the /init wizard - creates new projects with structured workflow.
5
+ * Uses InlineOverlay base class for consistent lifecycle management.
6
+ *
7
+ * Steps:
8
+ * 0. Project type (new vs existing)
9
+ * 1. Project name
10
+ * 2. Description
11
+ * 3. Repo pattern (single vs two-repo)
12
+ * 4. Tech stack
13
+ * 5. Coding standards
14
+ * 6. Initialize git?
15
+ * 7. Track with project database?
16
+ * 8. Workflow mode (if tracking enabled)
17
+ * 9. Confirmation
18
+ */
19
+ import chalk from 'chalk';
20
+ import * as terminal from './terminal.js';
21
+ import { getStyles } from '../themes/index.js';
22
+ import { InlineOverlay } from './base/inline-overlay.js';
23
+ import { TECH_STACK_LABELS, CODING_STANDARDS_LABELS, REPO_PATTERN_LABELS, generateProject, isValidProjectName, projectExists, } from '../templates/index.js';
24
+ // =============================================================================
25
+ // Constants
26
+ // =============================================================================
27
+ const TECH_STACK_OPTIONS = ['react-node-pg', 'react-python-pg', 'vue-node-pg', 'custom'];
28
+ const CODING_STANDARDS_OPTIONS = ['strict', 'relaxed', 'custom'];
29
+ const REPO_PATTERN_OPTIONS = ['single', 'two-repo'];
30
+ const WORKFLOW_MODE_OPTIONS = ['flexible', 'guided'];
31
+ const WORKFLOW_MODE_LABELS = {
32
+ flexible: 'Flexible (user-driven, exploratory)',
33
+ guided: 'Guided (structured step-by-step workflow)',
34
+ };
35
+ // =============================================================================
36
+ // Rendering Helpers
37
+ // =============================================================================
38
+ function renderHeader(step) {
39
+ const s = getStyles();
40
+ const lines = [];
41
+ const cols = terminal.getTerminalWidth();
42
+ lines.push(s.muted('─'.repeat(Math.max(1, cols - 1))));
43
+ lines.push(' ' + s.primaryBold('Initialize New Project') + s.muted(` [${String(step)}/9]`));
44
+ lines.push('');
45
+ return lines;
46
+ }
47
+ function renderFooter(step) {
48
+ const s = getStyles();
49
+ const lines = [];
50
+ lines.push('');
51
+ if (step === 0) {
52
+ lines.push(s.muted(' ↑↓/jk Navigate · Enter Select · q/Esc Cancel'));
53
+ }
54
+ else if (step === 9) {
55
+ lines.push(s.muted(' ↑↓/jk Navigate · Enter Confirm · Esc Back'));
56
+ }
57
+ else if (isSelectionStep(step)) {
58
+ lines.push(s.muted(' ↑↓/jk Navigate · Enter Select · Esc Back'));
59
+ }
60
+ else {
61
+ lines.push(s.muted(' Enter Confirm · Esc Back'));
62
+ }
63
+ return lines;
64
+ }
65
+ function renderSelectionOption(index, selectedIndex, label, disabled = false) {
66
+ const s = getStyles();
67
+ const isSelected = index === selectedIndex;
68
+ const prefix = isSelected ? ' ❯ ' : ' ';
69
+ if (disabled) {
70
+ return s.muted(prefix + label + ' (coming soon)');
71
+ }
72
+ return isSelected ? s.primary(prefix + label) : s.muted(prefix + label);
73
+ }
74
+ // =============================================================================
75
+ // Step Renderers
76
+ // =============================================================================
77
+ function renderStep0(state) {
78
+ const s = getStyles();
79
+ const lines = [];
80
+ lines.push(chalk.bold(' What would you like to do?'));
81
+ lines.push('');
82
+ lines.push(renderSelectionOption(0, state.selectedIndex, '1. Start a new project'));
83
+ lines.push(renderSelectionOption(1, state.selectedIndex, '2. Add workflow to existing project', true));
84
+ lines.push('');
85
+ lines.push(s.muted(' Start fresh with a structured project layout'));
86
+ lines.push(s.muted(' optimized for AI-assisted development.'));
87
+ return lines;
88
+ }
89
+ function renderStep1(state) {
90
+ const s = getStyles();
91
+ const lines = [];
92
+ lines.push(chalk.bold(' Project name'));
93
+ lines.push('');
94
+ lines.push(` > ${state.inputBuffer}█`);
95
+ lines.push('');
96
+ if (state.error) {
97
+ lines.push(s.error(` ${state.error}`));
98
+ }
99
+ else {
100
+ lines.push(s.muted(' Use lowercase letters, numbers, hyphens (e.g., my-saas-app)'));
101
+ lines.push(s.muted(' 2-50 characters, must start with a letter'));
102
+ }
103
+ return lines;
104
+ }
105
+ function renderStep2(state) {
106
+ const s = getStyles();
107
+ const lines = [];
108
+ lines.push(chalk.bold(' What are you building?'));
109
+ lines.push('');
110
+ lines.push(` > ${state.inputBuffer}█`);
111
+ lines.push('');
112
+ if (state.error) {
113
+ lines.push(s.error(` ${state.error}`));
114
+ }
115
+ else {
116
+ lines.push(s.muted(' Brief description (1-2 sentences)'));
117
+ lines.push(s.muted(' Example: "A task management SaaS for small teams"'));
118
+ }
119
+ return lines;
120
+ }
121
+ function renderStep3(state) {
122
+ const s = getStyles();
123
+ const lines = [];
124
+ lines.push(chalk.bold(' Documentation structure'));
125
+ lines.push('');
126
+ for (let i = 0; i < REPO_PATTERN_OPTIONS.length; i++) {
127
+ const pattern = REPO_PATTERN_OPTIONS[i];
128
+ lines.push(renderSelectionOption(i, state.selectedIndex, `${String(i + 1)}. ${REPO_PATTERN_LABELS[pattern]}`));
129
+ }
130
+ lines.push('');
131
+ lines.push(s.muted(' Single repo: All files in one repository'));
132
+ lines.push(s.muted(' Two repos: Code and docs in separate repositories'));
133
+ return lines;
134
+ }
135
+ function renderStep4(state) {
136
+ const s = getStyles();
137
+ const lines = [];
138
+ lines.push(chalk.bold(' Tech stack'));
139
+ lines.push('');
140
+ for (let i = 0; i < TECH_STACK_OPTIONS.length; i++) {
141
+ const stack = TECH_STACK_OPTIONS[i];
142
+ lines.push(renderSelectionOption(i, state.selectedIndex, `${String(i + 1)}. ${TECH_STACK_LABELS[stack]}`));
143
+ }
144
+ lines.push('');
145
+ lines.push(s.muted(' Choose a preset or configure later'));
146
+ return lines;
147
+ }
148
+ function renderStep5(state) {
149
+ const s = getStyles();
150
+ const lines = [];
151
+ lines.push(chalk.bold(' Coding standards preset'));
152
+ lines.push('');
153
+ for (let i = 0; i < CODING_STANDARDS_OPTIONS.length; i++) {
154
+ const standard = CODING_STANDARDS_OPTIONS[i];
155
+ lines.push(renderSelectionOption(i, state.selectedIndex, `${String(i + 1)}. ${CODING_STANDARDS_LABELS[standard]}`));
156
+ }
157
+ lines.push('');
158
+ lines.push(s.muted(' Strict: Full TypeScript with strict mode + ESLint'));
159
+ lines.push(s.muted(' Relaxed: TypeScript with basic strict mode'));
160
+ lines.push(s.muted(' Custom: Configure your own standards later'));
161
+ return lines;
162
+ }
163
+ function renderStep6(state) {
164
+ const s = getStyles();
165
+ const lines = [];
166
+ lines.push(chalk.bold(' Initialize git repository?'));
167
+ lines.push('');
168
+ lines.push(renderSelectionOption(0, state.selectedIndex, 'Yes'));
169
+ lines.push(renderSelectionOption(1, state.selectedIndex, 'No'));
170
+ lines.push('');
171
+ lines.push(s.muted(' Creates git repo with initial commit'));
172
+ return lines;
173
+ }
174
+ function renderStep7(state) {
175
+ const s = getStyles();
176
+ const lines = [];
177
+ lines.push(chalk.bold(' Track with project database?'));
178
+ lines.push('');
179
+ lines.push(renderSelectionOption(0, state.selectedIndex, 'Yes (recommended)'));
180
+ lines.push(renderSelectionOption(1, state.selectedIndex, 'No'));
181
+ lines.push('');
182
+ lines.push(s.muted(' Enables persistent project tracking, backlog management,'));
183
+ lines.push(s.muted(' and workflow features across sessions.'));
184
+ return lines;
185
+ }
186
+ function renderStep8(state) {
187
+ const s = getStyles();
188
+ const lines = [];
189
+ lines.push(chalk.bold(' Workflow mode'));
190
+ lines.push('');
191
+ for (let i = 0; i < WORKFLOW_MODE_OPTIONS.length; i++) {
192
+ const mode = WORKFLOW_MODE_OPTIONS[i];
193
+ const suffix = i === 0 ? ' (recommended)' : '';
194
+ lines.push(renderSelectionOption(i, state.selectedIndex, `${String(i + 1)}. ${WORKFLOW_MODE_LABELS[mode]}${suffix}`));
195
+ }
196
+ lines.push('');
197
+ lines.push(s.muted(' Flexible: Work at your own pace, agent responds to requests'));
198
+ lines.push(s.muted(' Guided: Agent suggests next steps, tracks work item progress'));
199
+ return lines;
200
+ }
201
+ function renderStep9(state) {
202
+ const s = getStyles();
203
+ const lines = [];
204
+ lines.push(chalk.bold(' Ready to create project?'));
205
+ lines.push('');
206
+ lines.push(` Project: ${s.primary(state.projectName)}`);
207
+ lines.push(` Location: ${s.primary('./' + state.projectName + '/')}`);
208
+ lines.push(` Structure: ${s.primary(state.repoPattern === 'single' ? 'Single repo' : 'Two repos')}`);
209
+ lines.push(` Tech: ${s.primary(state.techStack ? TECH_STACK_LABELS[state.techStack] : 'Not set')}`);
210
+ lines.push(` Standards: ${s.primary(state.codingStandards ? CODING_STANDARDS_LABELS[state.codingStandards] : 'Not set')}`);
211
+ lines.push(` Git: ${s.primary(state.initGit ? 'Yes' : 'No')}`);
212
+ lines.push(` DB Tracking: ${s.primary(state.trackInDatabase ? 'Yes' : 'No')}`);
213
+ if (state.trackInDatabase) {
214
+ lines.push(` Workflow: ${s.primary(WORKFLOW_MODE_LABELS[state.workflowMode])}`);
215
+ }
216
+ if (state.repoPattern === 'two-repo') {
217
+ lines.push('');
218
+ lines.push(s.muted(` Docs repo: ./${state.projectName}-docs/`));
219
+ }
220
+ lines.push('');
221
+ if (state.error) {
222
+ lines.push(s.error(` ${state.error}`));
223
+ lines.push('');
224
+ }
225
+ lines.push(renderSelectionOption(0, state.selectedIndex, 'Create'));
226
+ lines.push(renderSelectionOption(1, state.selectedIndex, 'Cancel'));
227
+ return lines;
228
+ }
229
+ function renderGenerating(state) {
230
+ const lines = [];
231
+ lines.push('');
232
+ lines.push(chalk.cyan(` Creating project "${state.projectName}"...`));
233
+ lines.push('');
234
+ return lines;
235
+ }
236
+ // =============================================================================
237
+ // Step Helpers
238
+ // =============================================================================
239
+ function getMaxOptionsForStep(step) {
240
+ switch (step) {
241
+ case 0:
242
+ return 2;
243
+ case 3:
244
+ return REPO_PATTERN_OPTIONS.length;
245
+ case 4:
246
+ return TECH_STACK_OPTIONS.length;
247
+ case 5:
248
+ return CODING_STANDARDS_OPTIONS.length;
249
+ case 6:
250
+ return 2;
251
+ case 7:
252
+ return 2;
253
+ case 8:
254
+ return WORKFLOW_MODE_OPTIONS.length;
255
+ case 9:
256
+ return 2;
257
+ default:
258
+ return 0;
259
+ }
260
+ }
261
+ function isSelectionStep(step) {
262
+ return [0, 3, 4, 5, 6, 7, 8, 9].includes(step);
263
+ }
264
+ function isInputStep(step) {
265
+ return [1, 2].includes(step);
266
+ }
267
+ // =============================================================================
268
+ // Init Overlay Implementation
269
+ // =============================================================================
270
+ class InitOverlayImpl extends InlineOverlay {
271
+ getInitialState() {
272
+ return {
273
+ step: 0,
274
+ projectType: null,
275
+ projectName: '',
276
+ description: '',
277
+ repoPattern: null,
278
+ techStack: null,
279
+ codingStandards: null,
280
+ initGit: true,
281
+ trackInDatabase: true,
282
+ workflowMode: 'flexible',
283
+ selectedIndex: 0,
284
+ inputBuffer: '',
285
+ error: null,
286
+ isGenerating: false,
287
+ };
288
+ }
289
+ render() {
290
+ // Show generating state if applicable
291
+ if (this.state.isGenerating) {
292
+ return renderGenerating(this.state);
293
+ }
294
+ const lines = [];
295
+ lines.push(...renderHeader(this.state.step));
296
+ switch (this.state.step) {
297
+ case 0:
298
+ lines.push(...renderStep0(this.state));
299
+ break;
300
+ case 1:
301
+ lines.push(...renderStep1(this.state));
302
+ break;
303
+ case 2:
304
+ lines.push(...renderStep2(this.state));
305
+ break;
306
+ case 3:
307
+ lines.push(...renderStep3(this.state));
308
+ break;
309
+ case 4:
310
+ lines.push(...renderStep4(this.state));
311
+ break;
312
+ case 5:
313
+ lines.push(...renderStep5(this.state));
314
+ break;
315
+ case 6:
316
+ lines.push(...renderStep6(this.state));
317
+ break;
318
+ case 7:
319
+ lines.push(...renderStep7(this.state));
320
+ break;
321
+ case 8:
322
+ lines.push(...renderStep8(this.state));
323
+ break;
324
+ case 9:
325
+ lines.push(...renderStep9(this.state));
326
+ break;
327
+ }
328
+ lines.push(...renderFooter(this.state.step));
329
+ return lines;
330
+ }
331
+ async handleKey(data) {
332
+ // Ctrl+C always cancels
333
+ if (this.isCtrlCKey(data)) {
334
+ return { type: 'close', result: { created: false } };
335
+ }
336
+ // q key on step 0 cancels
337
+ const char = data.length === 1 && data[0] >= 0x20 && data[0] < 0x7f ? String.fromCharCode(data[0]) : null;
338
+ if (this.state.step === 0 && char === 'q') {
339
+ return { type: 'close', result: { created: false } };
340
+ }
341
+ // Escape on step 0 cancels, otherwise goes back
342
+ if (this.isEscapeKey(data)) {
343
+ if (this.state.step === 0) {
344
+ return { type: 'close', result: { created: false } };
345
+ }
346
+ this.prevStep();
347
+ return { type: 'continue' };
348
+ }
349
+ // Handle selection steps
350
+ if (isSelectionStep(this.state.step)) {
351
+ const maxOptions = getMaxOptionsForStep(this.state.step);
352
+ // j/k for vim-style navigation
353
+ if (char === 'j' && this.state.selectedIndex < maxOptions - 1) {
354
+ this.state.selectedIndex++;
355
+ return { type: 'continue' };
356
+ }
357
+ if (char === 'k' && this.state.selectedIndex > 0) {
358
+ this.state.selectedIndex--;
359
+ return { type: 'continue' };
360
+ }
361
+ if (this.isUpArrowKey(data) && this.state.selectedIndex > 0) {
362
+ this.state.selectedIndex--;
363
+ return { type: 'continue' };
364
+ }
365
+ if (this.isDownArrowKey(data) && this.state.selectedIndex < maxOptions - 1) {
366
+ this.state.selectedIndex++;
367
+ return { type: 'continue' };
368
+ }
369
+ if (this.isEnterKey(data)) {
370
+ // Step 0 - only allow "new" option
371
+ if (this.state.step === 0 && this.state.selectedIndex === 1) {
372
+ this.state.error = 'This option is coming soon';
373
+ return { type: 'continue' };
374
+ }
375
+ // Step 9 - confirmation
376
+ if (this.state.step === 9) {
377
+ if (this.state.selectedIndex === 1) {
378
+ // Cancel
379
+ return { type: 'close', result: { created: false } };
380
+ }
381
+ // Verify all required fields are set
382
+ if (!this.state.repoPattern || !this.state.techStack || !this.state.codingStandards) {
383
+ this.state.error = 'Missing configuration values';
384
+ return { type: 'continue' };
385
+ }
386
+ // Show generating state
387
+ this.state.isGenerating = true;
388
+ this.requestRender();
389
+ // Create project
390
+ const config = {
391
+ name: this.state.projectName,
392
+ description: this.state.description,
393
+ repoPattern: this.state.repoPattern,
394
+ techStack: this.state.techStack,
395
+ codingStandards: this.state.codingStandards,
396
+ initGit: this.state.initGit,
397
+ };
398
+ try {
399
+ const result = await generateProject(config);
400
+ if (result.success) {
401
+ return {
402
+ type: 'close',
403
+ result: {
404
+ created: true,
405
+ projectPath: result.projectPath,
406
+ docsPath: result.docsPath,
407
+ filesCreated: result.filesCreated,
408
+ trackInDatabase: this.state.trackInDatabase,
409
+ workflowMode: this.state.workflowMode,
410
+ projectName: this.state.projectName,
411
+ description: this.state.description,
412
+ },
413
+ };
414
+ }
415
+ else {
416
+ this.state.isGenerating = false;
417
+ this.state.error = result.error ?? 'Unknown error';
418
+ return { type: 'continue' };
419
+ }
420
+ }
421
+ catch (error) {
422
+ this.state.isGenerating = false;
423
+ this.state.error = error.message;
424
+ return { type: 'continue' };
425
+ }
426
+ }
427
+ this.nextStep();
428
+ return { type: 'continue' };
429
+ }
430
+ }
431
+ // Handle input steps
432
+ if (isInputStep(this.state.step)) {
433
+ if (this.isEnterKey(data)) {
434
+ if (this.validateInput()) {
435
+ this.nextStep();
436
+ }
437
+ return { type: 'continue' };
438
+ }
439
+ if (this.isBackspaceKey(data)) {
440
+ this.state.inputBuffer = this.state.inputBuffer.slice(0, -1);
441
+ this.state.error = null;
442
+ return { type: 'continue' };
443
+ }
444
+ // Regular character input
445
+ const inputChar = this.getPrintableChar(data);
446
+ if (inputChar) {
447
+ this.state.inputBuffer += inputChar;
448
+ this.state.error = null;
449
+ return { type: 'continue' };
450
+ }
451
+ }
452
+ return { type: 'continue' };
453
+ }
454
+ getCleanupSummary(result) {
455
+ if (!result.created) {
456
+ return chalk.yellow(' Init cancelled');
457
+ }
458
+ return null;
459
+ }
460
+ // ===========================================================================
461
+ // Private Helpers
462
+ // ===========================================================================
463
+ nextStep() {
464
+ switch (this.state.step) {
465
+ case 0:
466
+ if (this.state.selectedIndex === 0) {
467
+ this.state.projectType = 'new';
468
+ this.state.step = 1;
469
+ this.state.inputBuffer = '';
470
+ this.state.selectedIndex = 0;
471
+ }
472
+ break;
473
+ case 1:
474
+ this.state.projectName = this.state.inputBuffer.trim();
475
+ this.state.step = 2;
476
+ this.state.inputBuffer = '';
477
+ break;
478
+ case 2:
479
+ this.state.description = this.state.inputBuffer.trim();
480
+ this.state.step = 3;
481
+ this.state.selectedIndex = 0;
482
+ break;
483
+ case 3:
484
+ this.state.repoPattern = REPO_PATTERN_OPTIONS[this.state.selectedIndex];
485
+ this.state.step = 4;
486
+ this.state.selectedIndex = 0;
487
+ break;
488
+ case 4:
489
+ this.state.techStack = TECH_STACK_OPTIONS[this.state.selectedIndex];
490
+ this.state.step = 5;
491
+ this.state.selectedIndex = 0;
492
+ break;
493
+ case 5:
494
+ this.state.codingStandards = CODING_STANDARDS_OPTIONS[this.state.selectedIndex];
495
+ this.state.step = 6;
496
+ this.state.selectedIndex = 0;
497
+ break;
498
+ case 6:
499
+ this.state.initGit = this.state.selectedIndex === 0;
500
+ this.state.step = 7;
501
+ this.state.selectedIndex = 0;
502
+ break;
503
+ case 7:
504
+ this.state.trackInDatabase = this.state.selectedIndex === 0;
505
+ // If tracking in DB, ask for workflow mode; otherwise skip to confirmation
506
+ this.state.step = this.state.trackInDatabase ? 8 : 9;
507
+ this.state.selectedIndex = 0;
508
+ break;
509
+ case 8:
510
+ this.state.workflowMode = WORKFLOW_MODE_OPTIONS[this.state.selectedIndex];
511
+ this.state.step = 9;
512
+ this.state.selectedIndex = 0;
513
+ break;
514
+ }
515
+ this.state.error = null;
516
+ }
517
+ prevStep() {
518
+ switch (this.state.step) {
519
+ case 1:
520
+ this.state.step = 0;
521
+ this.state.selectedIndex = 0;
522
+ break;
523
+ case 2:
524
+ this.state.step = 1;
525
+ this.state.inputBuffer = this.state.projectName;
526
+ break;
527
+ case 3:
528
+ this.state.step = 2;
529
+ this.state.inputBuffer = this.state.description;
530
+ break;
531
+ case 4:
532
+ this.state.step = 3;
533
+ this.state.selectedIndex = this.state.repoPattern ? REPO_PATTERN_OPTIONS.indexOf(this.state.repoPattern) : 0;
534
+ break;
535
+ case 5:
536
+ this.state.step = 4;
537
+ this.state.selectedIndex = this.state.techStack ? TECH_STACK_OPTIONS.indexOf(this.state.techStack) : 0;
538
+ break;
539
+ case 6:
540
+ this.state.step = 5;
541
+ this.state.selectedIndex = this.state.codingStandards ? CODING_STANDARDS_OPTIONS.indexOf(this.state.codingStandards) : 0;
542
+ break;
543
+ case 7:
544
+ this.state.step = 6;
545
+ this.state.selectedIndex = this.state.initGit ? 0 : 1;
546
+ break;
547
+ case 8:
548
+ this.state.step = 7;
549
+ this.state.selectedIndex = this.state.trackInDatabase ? 0 : 1;
550
+ break;
551
+ case 9:
552
+ // Go back to workflow mode if DB tracking is on, otherwise go to DB tracking step
553
+ this.state.step = this.state.trackInDatabase ? 8 : 7;
554
+ this.state.selectedIndex = this.state.trackInDatabase
555
+ ? WORKFLOW_MODE_OPTIONS.indexOf(this.state.workflowMode)
556
+ : 1;
557
+ break;
558
+ }
559
+ this.state.error = null;
560
+ }
561
+ validateInput() {
562
+ if (this.state.step === 1) {
563
+ const name = this.state.inputBuffer.trim();
564
+ if (!name) {
565
+ this.state.error = 'Project name is required';
566
+ return false;
567
+ }
568
+ if (!isValidProjectName(name)) {
569
+ this.state.error = 'Invalid name. Use lowercase letters, numbers, hyphens (2-50 chars, start with letter)';
570
+ return false;
571
+ }
572
+ if (projectExists(name)) {
573
+ this.state.error = `Directory "${name}" already exists`;
574
+ return false;
575
+ }
576
+ }
577
+ if (this.state.step === 2) {
578
+ const desc = this.state.inputBuffer.trim();
579
+ if (!desc) {
580
+ this.state.error = 'Description is required';
581
+ return false;
582
+ }
583
+ if (desc.length < 10) {
584
+ this.state.error = 'Description too short (min 10 characters)';
585
+ return false;
586
+ }
587
+ }
588
+ return true;
589
+ }
590
+ }
591
+ // =============================================================================
592
+ // Main Export
593
+ // =============================================================================
594
+ /**
595
+ * Show the init wizard overlay
596
+ */
597
+ export async function showInitOverlay() {
598
+ const overlay = new InitOverlayImpl();
599
+ return overlay.show();
600
+ }
@@ -1,7 +1,9 @@
1
1
  /**
2
- * Init Overlay
2
+ * Init Overlay (Refactored)
3
3
  *
4
4
  * Modal overlay for the /init wizard - creates new projects with structured workflow.
5
+ * Uses InlineOverlay base class for consistent lifecycle management.
6
+ *
5
7
  * Steps:
6
8
  * 0. Project type (new vs existing)
7
9
  * 1. Project name
@@ -10,15 +12,23 @@
10
12
  * 4. Tech stack
11
13
  * 5. Coding standards
12
14
  * 6. Initialize git?
13
- * 7. Confirmation
15
+ * 7. Track with project database?
16
+ * 8. Workflow mode (if tracking enabled)
17
+ * 9. Confirmation
14
18
  */
19
+ type WorkflowMode = 'flexible' | 'guided';
15
20
  export interface InitResult {
16
21
  created: boolean;
17
22
  projectPath?: string;
18
23
  docsPath?: string;
19
24
  filesCreated?: string[];
25
+ trackInDatabase?: boolean;
26
+ workflowMode?: WorkflowMode;
27
+ projectName?: string;
28
+ description?: string;
20
29
  }
21
30
  /**
22
31
  * Show the init wizard overlay
23
32
  */
24
33
  export declare function showInitOverlay(): Promise<InitResult>;
34
+ export {};