@codeyam/codeyam-cli 0.1.7 → 0.1.9

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 (576) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +9 -9
  4. package/analyzer-template/packages/ai/package.json +1 -1
  5. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
  6. package/analyzer-template/packages/ai/src/lib/completionCall.ts +14 -2
  7. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +27 -0
  8. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  9. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +78 -2
  10. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +0 -33
  11. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +19 -7
  12. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  13. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +9 -1
  14. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  15. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  16. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +65 -28
  17. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +83 -0
  18. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  19. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +23 -4
  20. package/analyzer-template/packages/aws/package.json +2 -2
  21. package/analyzer-template/packages/database/index.ts +1 -0
  22. package/analyzer-template/packages/database/package.json +3 -3
  23. package/analyzer-template/packages/database/src/lib/kysely/db.ts +8 -0
  24. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +93 -0
  25. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  26. package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
  27. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  28. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +94 -143
  29. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  30. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  31. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  32. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  33. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  34. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  35. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  36. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  37. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -0
  38. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  39. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +5 -0
  40. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  41. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +25 -0
  42. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  43. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +76 -0
  44. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  45. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  46. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  47. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  48. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  49. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  50. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  51. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
  52. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  53. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  54. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  55. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  56. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  57. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +76 -90
  58. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  59. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  60. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  61. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  62. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  63. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  64. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  65. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  66. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  67. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  68. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  69. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  70. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  71. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  72. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  73. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  74. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  75. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  76. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  77. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  78. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  79. package/analyzer-template/packages/github/package.json +1 -1
  80. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  81. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +1 -0
  82. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  83. package/analyzer-template/packages/ui-components/package.json +1 -1
  84. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  85. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  86. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  87. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  88. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  89. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  90. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  91. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  92. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  93. package/analyzer-template/project/constructMockCode.ts +136 -43
  94. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  95. package/analyzer-template/project/start.ts +3 -0
  96. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  97. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  98. package/analyzer-template/project/writeMockDataTsx.ts +17 -0
  99. package/analyzer-template/project/writeScenarioComponents.ts +36 -7
  100. package/analyzer-template/tsconfig.json +13 -1
  101. package/background/src/lib/virtualized/project/constructMockCode.js +115 -34
  102. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  103. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  104. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  105. package/background/src/lib/virtualized/project/start.js +2 -0
  106. package/background/src/lib/virtualized/project/start.js.map +1 -1
  107. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  108. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  109. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  110. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  111. package/background/src/lib/virtualized/project/writeMockDataTsx.js +12 -0
  112. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  113. package/background/src/lib/virtualized/project/writeScenarioComponents.js +29 -7
  114. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  115. package/codeyam-cli/scripts/apply-setup.js +208 -11
  116. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  117. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  118. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  119. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  120. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  121. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  122. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  123. package/codeyam-cli/src/cli.js +2 -0
  124. package/codeyam-cli/src/cli.js.map +1 -1
  125. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +45 -0
  126. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  127. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  128. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  129. package/codeyam-cli/src/commands/analyze.js +17 -7
  130. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  131. package/codeyam-cli/src/commands/default.js +14 -2
  132. package/codeyam-cli/src/commands/default.js.map +1 -1
  133. package/codeyam-cli/src/commands/editor.js +3215 -0
  134. package/codeyam-cli/src/commands/editor.js.map +1 -0
  135. package/codeyam-cli/src/commands/init.js +107 -45
  136. package/codeyam-cli/src/commands/init.js.map +1 -1
  137. package/codeyam-cli/src/data/techStacks.js +77 -0
  138. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  139. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +144 -0
  140. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  141. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  142. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  143. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  144. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  145. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
  146. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  147. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +855 -0
  148. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  149. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  150. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  151. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  152. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  153. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  154. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  155. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  156. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  157. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  158. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  159. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  160. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  161. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  162. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  163. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  164. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  165. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +339 -0
  166. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  167. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  168. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  169. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  170. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  171. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  172. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  173. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +855 -0
  174. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  175. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  176. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  177. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  178. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  179. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  180. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  181. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  182. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  183. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +101 -0
  184. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  185. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  186. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  187. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  188. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  189. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  190. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  191. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  192. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  193. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +300 -0
  194. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  195. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +50 -4
  196. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  197. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  198. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  199. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  200. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  201. package/codeyam-cli/src/utils/analyzer.js +9 -0
  202. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  203. package/codeyam-cli/src/utils/analyzerFinalization.js +96 -0
  204. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  205. package/codeyam-cli/src/utils/backgroundServer.js +104 -12
  206. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  207. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  208. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  209. package/codeyam-cli/src/utils/database.js +37 -2
  210. package/codeyam-cli/src/utils/database.js.map +1 -1
  211. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  212. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  213. package/codeyam-cli/src/utils/devServerState.js +71 -0
  214. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  215. package/codeyam-cli/src/utils/editorApi.js +73 -0
  216. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  217. package/codeyam-cli/src/utils/editorAudit.js +176 -0
  218. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  219. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  220. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  221. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  222. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  223. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  224. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  225. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  226. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  227. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  228. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  229. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  230. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  231. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  232. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  233. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  234. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  235. package/codeyam-cli/src/utils/editorPreview.js +132 -0
  236. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  237. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  238. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  239. package/codeyam-cli/src/utils/editorScenarios.js +332 -0
  240. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  241. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  242. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  243. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  244. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  245. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  246. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  247. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  248. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  249. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  250. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  251. package/codeyam-cli/src/utils/git.js +103 -0
  252. package/codeyam-cli/src/utils/git.js.map +1 -1
  253. package/codeyam-cli/src/utils/install-skills.js +55 -13
  254. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  255. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  256. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  257. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  258. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  259. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  260. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  261. package/codeyam-cli/src/utils/project.js +15 -5
  262. package/codeyam-cli/src/utils/project.js.map +1 -1
  263. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  264. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  265. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  266. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  267. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  268. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  269. package/codeyam-cli/src/utils/queue/job.js +70 -1
  270. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  271. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  272. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  273. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  274. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  275. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  276. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  277. package/codeyam-cli/src/utils/scenariosManifest.js +159 -0
  278. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  279. package/codeyam-cli/src/utils/serverState.js +57 -2
  280. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  281. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +82 -11
  282. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  283. package/codeyam-cli/src/utils/simulationGateMiddleware.js +8 -1
  284. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -1
  285. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  286. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  287. package/codeyam-cli/src/utils/syncMocksMiddleware.js +2 -2
  288. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  289. package/codeyam-cli/src/utils/testRunner.js +158 -0
  290. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  291. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  292. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  293. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +40 -0
  294. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  295. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +567 -0
  296. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  297. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  298. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  299. package/codeyam-cli/src/webserver/app/lib/database.js +41 -27
  300. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  301. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  302. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  303. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  304. package/codeyam-cli/src/webserver/backgroundServer.js +108 -18
  305. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  306. package/codeyam-cli/src/webserver/build/client/assets/{CopyButton-CtmbP4Gl.js → CopyButton-BPXZwM4t.js} +1 -1
  307. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DlMph_Hm.js → EntityItem-BcgbViKV.js} +3 -3
  308. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-B-0PjGOU.js → EntityTypeBadge-g3saevPb.js} +1 -1
  309. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-DN9eiJAO.js → EntityTypeIcon-CQIG2qda.js} +9 -9
  310. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  311. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-rE_fI2h2.js → InteractivePreview-DYFW3lDD.js} +3 -3
  312. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CnatsCw2.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  313. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-CSP6DZrh.js → LoadingDots-BU_OAEMP.js} +1 -1
  314. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-CMK8Q7yk.js → LogViewer-ceAyBX-H.js} +1 -1
  315. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-TCV_HBjy.js → ReportIssueModal-BzHcG7SE.js} +3 -3
  316. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-CG2uh31y.js → SafeScreenshot-BED4B6sP.js} +1 -1
  317. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-CU_TDYd8.js → ScenarioViewer-Bd-hxofb.js} +3 -3
  318. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  319. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-D7IoaWUW.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  320. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  321. package/codeyam-cli/src/webserver/build/client/assets/{_index-B8z7mjR-.js → _index-DLxKhri3.js} +3 -3
  322. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-DZu78RI1.js → activity.(_tab)-BcY3q6nt.js} +6 -6
  323. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  324. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  325. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  326. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  327. package/codeyam-cli/src/webserver/build/client/assets/{agent-transcripts-Dm5RS9il.js → agent-transcripts-Bni3iiUj.js} +5 -5
  328. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  329. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  330. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  331. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  332. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  333. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  334. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  335. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  336. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  337. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  338. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  339. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  340. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  341. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  342. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  343. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  344. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  345. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  346. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  347. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  348. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  349. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  350. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  351. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  352. package/codeyam-cli/src/webserver/build/client/assets/{book-open-Bp5FLkd4.js → book-open-BYOypzCa.js} +2 -2
  353. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-DQJA9f4o.js → chevron-down-C_Pmso5S.js} +2 -2
  354. package/codeyam-cli/src/webserver/build/client/assets/{chunk-JZWAC4HX-7VptmeIr.js → chunk-JZWAC4HX-C4pqxYJB.js} +1 -1
  355. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-B6C4LY9o.js → circle-check-BVMi9VA5.js} +2 -2
  356. package/codeyam-cli/src/webserver/build/client/assets/{copy-6nzYCu0G.js → copy-n2FB0_Sw.js} +3 -3
  357. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  358. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BsDh6TSF.js +1 -0
  359. package/codeyam-cli/src/webserver/build/client/assets/editor-PBc_6L9R.js +10 -0
  360. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-4FzHlcNn.js +41 -0
  361. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-C6PQhwY5.js → entity._sha._-BsDXNp45.js} +9 -9
  362. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-BgAqUtTZ.js +6 -0
  363. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-Bmshgrij.js +6 -0
  364. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  365. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-C7ysA4Jq.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  366. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CU6EUArK.js → entry.client-DTvKq3TY.js} +1 -1
  367. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-EWpfFU4X.js → fileTableUtils-cPo8LiG3.js} +1 -1
  368. package/codeyam-cli/src/webserver/build/client/assets/{files-CrxAoWIL.js → files-BZrlFE1F.js} +1 -1
  369. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  370. package/codeyam-cli/src/webserver/build/client/assets/globals-B8vTTNy2.css +1 -0
  371. package/codeyam-cli/src/webserver/build/client/assets/{index-7-1FmlHo.js → index-10oVnAAH.js} +1 -1
  372. package/codeyam-cli/src/webserver/build/client/assets/{index-DuYcwYp_.js → index-BcvgDzbZ.js} +1 -1
  373. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  374. package/codeyam-cli/src/webserver/build/client/assets/{labs-CPPVOSWB.js → labs-Zk7ryIM1.js} +1 -1
  375. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-BnDcD54R.js → loader-circle-DaAZ_H2w.js} +2 -2
  376. package/codeyam-cli/src/webserver/build/client/assets/manifest-65850841.js +1 -0
  377. package/codeyam-cli/src/webserver/build/client/assets/memory-9gnxSZlb.js +101 -0
  378. package/codeyam-cli/src/webserver/build/client/assets/{pause-DhQX2g22.js → pause-f5-1lKBt.js} +3 -3
  379. package/codeyam-cli/src/webserver/build/client/assets/root-BwX8YgFb.js +67 -0
  380. package/codeyam-cli/src/webserver/build/client/assets/{search-DborVoKD.js → search-Di64LWVb.js} +2 -2
  381. package/codeyam-cli/src/webserver/build/client/assets/{settings-BWunYSXt.js → settings-0OrEMU6J.js} +1 -1
  382. package/codeyam-cli/src/webserver/build/client/assets/{simulations-BtrtCYJg.js → simulations-DWT-CvLy.js} +1 -1
  383. package/codeyam-cli/src/webserver/build/client/assets/{terminal-Bs4NC-VZ.js → terminal-Br7MOqts.js} +3 -3
  384. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-DTf3Jojp.js → triangle-alert-BLdiCuG-.js} +2 -2
  385. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BE43Hjti.js +1 -0
  386. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  387. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-BsQb6rFd.js → useReportContext-O-jkvSPx.js} +1 -1
  388. package/codeyam-cli/src/webserver/build/client/assets/{useToast-BOur3mUv.js → useToast-9FIWuYfK.js} +1 -1
  389. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  390. package/codeyam-cli/src/webserver/build/server/assets/index-DEEQf4pi.js +1 -0
  391. package/codeyam-cli/src/webserver/build/server/assets/init-CkWmyFY2.js +10 -0
  392. package/codeyam-cli/src/webserver/build/server/assets/server-build-BHi-9O8W.js +439 -0
  393. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  394. package/codeyam-cli/src/webserver/build-info.json +5 -5
  395. package/codeyam-cli/src/webserver/devServer.js +39 -5
  396. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  397. package/codeyam-cli/src/webserver/editorProxy.js +877 -0
  398. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  399. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  400. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  401. package/codeyam-cli/src/webserver/server.js +258 -1
  402. package/codeyam-cli/src/webserver/server.js.map +1 -1
  403. package/codeyam-cli/src/webserver/terminalServer.js +726 -0
  404. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  405. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  406. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  407. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  408. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  409. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  410. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  411. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  412. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  413. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  414. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  415. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  416. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  417. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  418. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  419. package/codeyam-cli/templates/codeyam-editor-claude.md +147 -0
  420. package/codeyam-cli/templates/editor-step-hook.py +236 -0
  421. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  422. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  423. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  424. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  425. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  426. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  427. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  428. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  429. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  430. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  431. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  432. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  433. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  434. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  435. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  436. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  437. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  438. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  439. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  440. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  441. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  442. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  443. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  444. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  445. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  446. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  447. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  448. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  449. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  450. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  451. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  452. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  453. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  454. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  455. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  456. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  457. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  458. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  459. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  460. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  461. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  462. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  463. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  464. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  465. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  466. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  467. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  468. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  469. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  470. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  471. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  472. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  473. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  474. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  475. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  476. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  477. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  478. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  479. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  480. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  481. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  482. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  483. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  484. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  485. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +148 -0
  486. package/codeyam-cli/templates/{codeyam-memory.md → skills/codeyam-memory/SKILL.md} +215 -0
  487. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  488. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  489. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  490. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  491. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  492. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  493. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  494. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  495. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  496. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  497. package/package.json +17 -10
  498. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  499. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  500. package/packages/ai/src/lib/completionCall.js +10 -2
  501. package/packages/ai/src/lib/completionCall.js.map +1 -1
  502. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +21 -0
  503. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  504. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  505. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  506. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  507. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  508. package/packages/ai/src/lib/generateEntityScenarioData.js +57 -2
  509. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  510. package/packages/ai/src/lib/generateExecutionFlows.js +0 -11
  511. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  512. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  513. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  514. package/packages/analyze/src/lib/asts/index.js +4 -2
  515. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  516. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +8 -1
  517. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  518. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  519. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  520. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  521. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  522. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +54 -27
  523. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -1
  524. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +65 -0
  525. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  526. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  527. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  528. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +18 -4
  529. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  530. package/packages/database/index.js +1 -0
  531. package/packages/database/index.js.map +1 -1
  532. package/packages/database/src/lib/kysely/db.js +5 -0
  533. package/packages/database/src/lib/kysely/db.js.map +1 -1
  534. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +76 -0
  535. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  536. package/packages/database/src/lib/loadCommits.js +23 -13
  537. package/packages/database/src/lib/loadCommits.js.map +1 -1
  538. package/packages/database/src/lib/loadEntities.js +0 -6
  539. package/packages/database/src/lib/loadEntities.js.map +1 -1
  540. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  541. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  542. package/packages/database/src/lib/updateCommitMetadata.js +76 -90
  543. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  544. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  545. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  546. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  547. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  548. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  549. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  550. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  551. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  552. package/packages/types/src/enums/ProjectFramework.js +2 -0
  553. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  554. package/scripts/npm-post-install.cjs +34 -0
  555. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C1rIyZdV.js +0 -34
  556. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-D-QUFOwe.js +0 -21
  557. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-DmzSmblj.js +0 -1
  558. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DVTcUnur.js +0 -6
  559. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-BVgNO76F.js +0 -6
  560. package/codeyam-cli/src/webserver/build/client/assets/git-BldHtKeW.js +0 -15
  561. package/codeyam-cli/src/webserver/build/client/assets/globals-CLmFdUae.css +0 -1
  562. package/codeyam-cli/src/webserver/build/client/assets/manifest-717e346a.js +0 -1
  563. package/codeyam-cli/src/webserver/build/client/assets/memory-0wMU4KXe.js +0 -93
  564. package/codeyam-cli/src/webserver/build/client/assets/root-DqfSDjyQ.js +0 -62
  565. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-D_bDZyDU.js +0 -1
  566. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-DZp6rrQD.js +0 -2
  567. package/codeyam-cli/src/webserver/build/server/assets/index-B8jmgmn2.js +0 -1
  568. package/codeyam-cli/src/webserver/build/server/assets/server-build-9OU4lmvL.js +0 -285
  569. package/scripts/finalize-analyzer.cjs +0 -13
  570. /package/codeyam-cli/templates/{codeyam-diagnose.md → commands/codeyam-diagnose.md} +0 -0
  571. /package/codeyam-cli/templates/{codeyam-debug.md → skills/codeyam-debug/SKILL.md} +0 -0
  572. /package/codeyam-cli/templates/{codeyam-new-rule.md → skills/codeyam-new-rule/SKILL.md} +0 -0
  573. /package/codeyam-cli/templates/{codeyam-setup.md → skills/codeyam-setup/SKILL.md} +0 -0
  574. /package/codeyam-cli/templates/{codeyam-sim.md → skills/codeyam-sim/SKILL.md} +0 -0
  575. /package/codeyam-cli/templates/{codeyam-test.md → skills/codeyam-test/SKILL.md} +0 -0
  576. /package/codeyam-cli/templates/{codeyam-verify.md → skills/codeyam-verify/SKILL.md} +0 -0
@@ -0,0 +1,726 @@
1
+ var _a, _b;
2
+ import { WebSocketServer, WebSocket } from 'ws';
3
+ import crypto from 'crypto';
4
+ import fs from 'fs';
5
+ import path from 'path';
6
+ import * as pty from 'node-pty';
7
+ import { createMarkerTransformer } from "../utils/scenarioMarkers.js";
8
+ // Use globalThis so the sessions Set is shared across module instances.
9
+ // In Vite dev mode, this file is loaded twice: once by the Vite plugin (Node.js native)
10
+ // and once by the SSR context (ssrLoadModule). Without globalThis, each instance
11
+ // gets its own empty Set — so broadcastPreviewRefresh() called from the SSR instance
12
+ // (via the /api/dev-mode-preview endpoint) would broadcast to 0 sessions.
13
+ const sessions = ((_a = globalThis).__codeyamTerminalSessions ?? (_a.__codeyamTerminalSessions = new Set()));
14
+ // Detached PTYs waiting for reconnection (keyed by sessionId).
15
+ // When a WebSocket drops, the PTY is moved here with a grace timer
16
+ // instead of being killed immediately, allowing the client to reconnect.
17
+ const detachedPtys = ((_b = globalThis).__codeyamDetachedPtys ?? (_b.__codeyamDetachedPtys = new Map()));
18
+ const PING_INTERVAL_MS = 30000;
19
+ const DETACH_GRACE_MS = 60000;
20
+ const OUTPUT_BUFFER_MAX = 8 * 1024; // 8KB
21
+ // Ping interval reference — shared so cleanup can clear it
22
+ let pingInterval = globalThis.__codeyamPingInterval ?? null;
23
+ // Keys to forward from the server env into the PTY shell.
24
+ // Keeps the env clean (no giant CODEYAM_PROJECT JSON blobs) while
25
+ // preserving everything Claude Code and the user's shell need.
26
+ const ENV_PASSTHROUGH_KEYS = [
27
+ 'PATH',
28
+ 'HOME',
29
+ 'USER',
30
+ 'LOGNAME',
31
+ 'SHELL',
32
+ 'TERM',
33
+ 'LANG',
34
+ 'LC_ALL',
35
+ 'LC_CTYPE',
36
+ 'EDITOR',
37
+ 'VISUAL',
38
+ 'TMPDIR',
39
+ 'XDG_CONFIG_HOME',
40
+ 'XDG_DATA_HOME',
41
+ 'XDG_CACHE_HOME',
42
+ // API keys Claude Code may need
43
+ 'ANTHROPIC_API_KEY',
44
+ 'OPENAI_API_KEY',
45
+ // nvm / fnm / volta node version managers
46
+ 'NVM_DIR',
47
+ 'NVM_BIN',
48
+ 'FNM_DIR',
49
+ 'VOLTA_HOME',
50
+ // Homebrew
51
+ 'HOMEBREW_PREFIX',
52
+ 'HOMEBREW_CELLAR',
53
+ 'HOMEBREW_REPOSITORY',
54
+ ];
55
+ function buildPtyEnv() {
56
+ const env = {};
57
+ for (const key of ENV_PASSTHROUGH_KEYS) {
58
+ const val = process.env[key];
59
+ if (val != null)
60
+ env[key] = val;
61
+ }
62
+ // Always set TERM for proper terminal behavior
63
+ if (!env.TERM)
64
+ env.TERM = 'xterm-256color';
65
+ return env;
66
+ }
67
+ /**
68
+ * Convert a name to a safe file name matching CodeYam's convention.
69
+ * e.g. "Default Scenario" -> "Default_Scenario"
70
+ */
71
+ function safeFileName(name) {
72
+ const safe = name.replace(/[^a-zA-Z0-9_]+/g, '_').replace(/^_+|_+$/g, '');
73
+ return safe.slice(0, 1).toUpperCase() + safe.slice(1);
74
+ }
75
+ /**
76
+ * Find the actual mock data file for a scenario in the tmp project.
77
+ * Tries a fast heuristic (extract app dir from entity file path) first,
78
+ * then falls back to a shallow directory search.
79
+ */
80
+ function findMockDataFile(projectRoot, entityFilePath, scenarioName) {
81
+ const scenarioSlug = safeFileName(scenarioName);
82
+ const mockFile = `MockData_${scenarioSlug}.tsx`;
83
+ // Heuristic: the __codeyamMocks__ dir lives at the app directory level.
84
+ // Extract "app/" (or "src/", "pages/") from the entity's file path.
85
+ if (entityFilePath) {
86
+ const parts = entityFilePath.split('/');
87
+ for (let i = 0; i < parts.length; i++) {
88
+ if (['app', 'src', 'pages'].includes(parts[i])) {
89
+ const appDir = parts.slice(0, i + 1).join('/');
90
+ const candidate = path.join(projectRoot, appDir, '__codeyamMocks__', mockFile);
91
+ if (fs.existsSync(candidate))
92
+ return candidate;
93
+ }
94
+ }
95
+ }
96
+ // Fallback: search __codeyamMocks__ directories up to 5 levels deep
97
+ function searchDir(dir, depth) {
98
+ if (depth > 5)
99
+ return null;
100
+ try {
101
+ for (const entry of fs.readdirSync(dir)) {
102
+ if (entry === 'node_modules' ||
103
+ entry === '.git' ||
104
+ entry === 'coverage')
105
+ continue;
106
+ const full = path.join(dir, entry);
107
+ if (entry === '__codeyamMocks__') {
108
+ const candidate = path.join(full, mockFile);
109
+ if (fs.existsSync(candidate))
110
+ return candidate;
111
+ continue;
112
+ }
113
+ try {
114
+ if (fs.statSync(full).isDirectory()) {
115
+ const result = searchDir(full, depth + 1);
116
+ if (result)
117
+ return result;
118
+ }
119
+ }
120
+ catch {
121
+ // Permission error or broken symlink
122
+ }
123
+ }
124
+ }
125
+ catch {
126
+ // Directory unreadable
127
+ }
128
+ return null;
129
+ }
130
+ return searchDir(projectRoot, 0);
131
+ }
132
+ /**
133
+ * Write a structured context file for the codeyam-dev-mode skill.
134
+ * The skill reads this file on startup instead of receiving a long CLI argument.
135
+ * Returns true if context was written successfully, false otherwise.
136
+ */
137
+ function writeDevModeContext(ctx) {
138
+ if (!ctx.entityName)
139
+ return false;
140
+ const codeyamRoot = process.env.CODEYAM_ROOT_PATH || process.cwd();
141
+ const contextDir = path.join(codeyamRoot, '.codeyam');
142
+ const contextPath = path.join(contextDir, 'dev-mode-context.md');
143
+ try {
144
+ fs.mkdirSync(contextDir, { recursive: true });
145
+ const lines = ['# Dev Mode Context', ''];
146
+ // Entity section
147
+ lines.push('## Entity');
148
+ lines.push(`- **Name:** ${ctx.entityName}`);
149
+ if (ctx.entityType)
150
+ lines.push(`- **Type:** ${ctx.entityType}`);
151
+ if (ctx.entitySha)
152
+ lines.push(`- **SHA:** ${ctx.entitySha}`);
153
+ if (ctx.entityFilePath)
154
+ lines.push(`- **Source file:** ${ctx.entityFilePath}`);
155
+ lines.push('');
156
+ // Scenario section
157
+ if (ctx.scenarioName) {
158
+ lines.push('## Scenario');
159
+ lines.push(`- **Name:** ${ctx.scenarioName}`);
160
+ if (ctx.scenarioDescription)
161
+ lines.push(`- **Description:** ${ctx.scenarioDescription}`);
162
+ if (ctx.analysisId)
163
+ lines.push(`- **Analysis ID:** ${ctx.analysisId}`);
164
+ lines.push('');
165
+ }
166
+ // Files section
167
+ lines.push('## Files');
168
+ if (ctx.entityFilePath) {
169
+ lines.push(`- **Source file:** ${ctx.entityFilePath}`);
170
+ }
171
+ if (ctx.projectSlug && ctx.scenarioName) {
172
+ const tmpBase = `/tmp/codeyam/local-dev/${ctx.projectSlug}`;
173
+ const tmpProject = `${tmpBase}/project`;
174
+ const mockDataPath = findMockDataFile(tmpProject, ctx.entityFilePath, ctx.scenarioName);
175
+ if (mockDataPath) {
176
+ lines.push(`- **Mock data:** ${mockDataPath}`);
177
+ }
178
+ else {
179
+ const scenarioSlug = safeFileName(ctx.scenarioName);
180
+ lines.push(`- **Mock data:** search for \`MockData_${scenarioSlug}.tsx\` in \`__codeyamMocks__\` under ${tmpProject}`);
181
+ }
182
+ lines.push(`- **Dev server project:** ${tmpProject}`);
183
+ lines.push(`- **Server log:** ${tmpBase}/codeyam/log.txt`);
184
+ }
185
+ lines.push('');
186
+ // Database
187
+ lines.push('## Database');
188
+ lines.push(`- **Path:** .codeyam/db.sqlite3`);
189
+ lines.push('');
190
+ // Server
191
+ const serverPort = process.env.CODEYAM_PORT || '3111';
192
+ lines.push('## Server');
193
+ lines.push(`- **Refresh preview:** \`curl -X POST http://localhost:${serverPort}/api/dev-mode-preview\``);
194
+ lines.push('');
195
+ fs.writeFileSync(contextPath, lines.join('\n'), 'utf8');
196
+ return true;
197
+ }
198
+ catch (error) {
199
+ console.error('[terminalServer] Failed to write dev-mode-context.md:', error);
200
+ return false;
201
+ }
202
+ }
203
+ /**
204
+ * Write a structured context file for the codeyam-editor skill.
205
+ * Returns true if context was written successfully, false otherwise.
206
+ */
207
+ function writeEditorModeContext(ctx) {
208
+ if (!ctx.projectSlug)
209
+ return false;
210
+ const codeyamRoot = process.env.CODEYAM_ROOT_PATH || process.cwd();
211
+ const contextDir = path.join(codeyamRoot, '.codeyam');
212
+ const contextPath = path.join(contextDir, 'editor-mode-context.md');
213
+ try {
214
+ fs.mkdirSync(contextDir, { recursive: true });
215
+ const serverPort = process.env.CODEYAM_PORT || '3111';
216
+ const proxyPort = parseInt(serverPort, 10) + 1;
217
+ const lines = [
218
+ '# Editor Mode Context',
219
+ '',
220
+ '## Project',
221
+ `- **Root:** ${codeyamRoot}`,
222
+ `- **Slug:** ${ctx.projectSlug}`,
223
+ '',
224
+ '## Server',
225
+ `- **Port:** ${serverPort}`,
226
+ `- **Dashboard:** http://localhost:${serverPort}/editor`,
227
+ `- **Proxy:** http://localhost:${proxyPort} (used by the browser iframe only — do NOT use for health checks)`,
228
+ '',
229
+ '## Workflow',
230
+ '- **Guided steps:** Run `codeyam editor steps` for the next step (plan → prototype → confirm → deconstruct → extract → glossary → analyze → app scenarios → user scenarios → verify → journal → review → present → commit → finalize → push)',
231
+ '- Each feature follows 16 steps: `codeyam editor 1` through `codeyam editor 16`',
232
+ '- Steps 1, 3, 13, and 16 require user confirmation before proceeding',
233
+ '',
234
+ '## Preview Updates',
235
+ '- **Refresh the preview frequently** — the user watches the preview as you work. Refresh after every meaningful change (new page, UI section, data seeding, styling), not just at the end.',
236
+ `- **Refresh command:** \`curl -s -X POST http://localhost:${serverPort}/api/dev-mode-preview\``,
237
+ '- Aim for 4-8+ preview updates during a typical building session.',
238
+ '',
239
+ '## Verifying the Dev Server',
240
+ '- Get the dev server URL: `curl -s http://localhost:' +
241
+ serverPort +
242
+ '/api/editor-dev-server` → look at the `"url"` field (e.g., `http://localhost:3000`)',
243
+ '- Check the page loads: `curl -s -o /dev/null -w "%{http_code}" http://localhost:3000` (use the actual dev server URL, NOT the proxy)',
244
+ '- Check API routes work: `curl -s http://localhost:3000/api/your-route` (should return JSON, not "Internal Server Error")',
245
+ '- **NEVER check localhost:' +
246
+ proxyPort +
247
+ ' for health** — the proxy returns 200 even when the app is broken',
248
+ '',
249
+ '## API Endpoints',
250
+ `- **Register scenario (auto-captures screenshot):** \`codeyam editor register '{"name":"...","url":"/page-to-screenshot","type":"application","seed":{...}}'\` — ALWAYS include "url" for the page to screenshot. For large payloads, write JSON to a file and use @ prefix: \`codeyam editor register @/tmp/scenario.json\``,
251
+ `- **Get active scenario data:** \`curl http://localhost:${serverPort}/api/editor-scenario-data\``,
252
+ `- **Refresh/navigate/switch preview:** \`curl -X POST http://localhost:${serverPort}/api/dev-mode-preview\` (no body = refresh; with \`{"path":"/route"}\` = navigate; with \`{"scenarioId":"..."}\` = switch scenario). Clears logs, waits for HMR, checks SSR health. This is the ONE command for all iframe preview control.`,
253
+ `- **Refresh config:** \`curl -X POST http://localhost:${serverPort}/api/editor-refresh\` (also starts dev server if a webapp is detected)`,
254
+ `- **Dev server status:** \`curl http://localhost:${serverPort}/api/editor-dev-server\``,
255
+ `- **Start dev server:** \`curl -X POST http://localhost:${serverPort}/api/editor-dev-server -H 'Content-Type: application/json' -d '{"action":"start"}'\``,
256
+ `- **Restart dev server:** \`curl -X POST http://localhost:${serverPort}/api/editor-dev-server -H 'Content-Type: application/json' -d '{"action":"restart"}'\``,
257
+ `- **Re-capture scenario screenshot:** \`curl -X POST http://localhost:${serverPort}/api/editor-capture-scenario -H 'Content-Type: application/json' -d '{"scenarioId":"...","url":"..."}'\` (for manual re-capture; register auto-captures)`,
258
+ `- **Journal screenshot:** \`curl -X POST http://localhost:${serverPort}/api/editor-journal-screenshot -H 'Content-Type: application/json' -d '{"url":"...","filename":"..."}'\``,
259
+ `- **Journal entry:** \`curl -X POST http://localhost:${serverPort}/api/editor-journal-entry -H 'Content-Type: application/json' -d '{"title":"...","type":"feature","description":"..."}'\``,
260
+ '',
261
+ '## Scenario Data Format',
262
+ '- Use **route-keyed** mock data: keys are the API paths your app fetches',
263
+ '- Example: `{ "routes": { "/api/tasks": { "body": [...] }, "/api/users": { "body": [...] } } }`',
264
+ '- Error scenarios: `{ "routes": { "/api/tasks": { "status": 500, "body": { "error": "..." } } } }`',
265
+ '- The proxy intercepts GET requests to matching routes and returns the mock data',
266
+ '- POST/PUT/DELETE always go through to the real dev server',
267
+ '',
268
+ '## Component Isolation Routes',
269
+ '- Create isolation route dirs: `codeyam editor isolate ComponentA ComponentB ...`',
270
+ ' - This creates the layout guard and a directory per component under `app/isolated-components/`',
271
+ '- Create ONE isolation route page per component:',
272
+ ' - **Remix:** `app/routes/isolated-components.ComponentName.tsx` → `/isolated-components/ComponentName`',
273
+ ' - **Next.js:** `app/isolated-components/ComponentName/page.tsx` → `/isolated-components/ComponentName`',
274
+ '- The route defines a `scenarios` object mapping scenario names to props, reads `?s=ScenarioName` from the URL, and renders the component',
275
+ '- Wrap the component in a centered container: `<div style="display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px"><div style="width:100%;max-width:...">` — set max-width to match the component\'s real container (e.g. card in 3-col grid → 24rem)',
276
+ '- **Create multiple scenarios per component** (like tests): default/happy path, edge cases (empty data, long text, max items), different visual states (loading, error, disabled)',
277
+ '- Register each scenario: `codeyam editor register \'{"name":"ComponentName - Scenario","componentName":"ComponentName","componentPath":"path/to/file.tsx","url":"/isolated-components/ComponentName?s=Scenario","mockData":{"routes":{"/api/...":{"body":[...]}}}}\'`',
278
+ '- The url is a PATH, not a full URL — the proxy appends it and intercepts API calls the component makes',
279
+ '- `mockData.routes` provides data for any API calls the component makes internally (omit if none)',
280
+ '- Isolation routes stay in the project so the editor preview can display them',
281
+ '- Ensure `.gitignore` includes `**/isolated-components*` so they are not committed',
282
+ '',
283
+ '## Files',
284
+ '- **Scenario data:** .codeyam/editor-scenarios/{scenario-id}.json',
285
+ '- **Scenario screenshots:** .codeyam/editor-scenarios/screenshots/{scenario-id}.png',
286
+ '- **Active scenario:** .codeyam/active-scenario.json',
287
+ '- **Database:** .codeyam/db.sqlite3',
288
+ '- **Journal:** .codeyam/journal/ (daily .md files + index.json + screenshots/)',
289
+ '',
290
+ ];
291
+ // Check if package.json exists to give context about project state
292
+ const hasPackageJson = fs.existsSync(path.join(codeyamRoot, 'package.json'));
293
+ if (!hasPackageJson) {
294
+ lines.push('## Status');
295
+ lines.push('- **Empty project** — no package.json found. Ask the user what they want to build.');
296
+ lines.push('');
297
+ }
298
+ fs.writeFileSync(contextPath, lines.join('\n'), 'utf8');
299
+ return true;
300
+ }
301
+ catch (error) {
302
+ console.error('[terminalServer] Failed to write editor-mode-context.md:', error);
303
+ return false;
304
+ }
305
+ }
306
+ /**
307
+ * Attach a WebSocket server at /ws/terminal to an existing HTTP server.
308
+ * Each WS connection spawns a PTY running the user's shell, then auto-starts `claude`.
309
+ *
310
+ * Features:
311
+ * - Ping/pong keepalive (30s interval) to detect dead connections
312
+ * - PTY detach/reattach: on WS close the PTY survives for 60s, allowing the client
313
+ * to reconnect with ?reconnectId=<sessionId> and reattach to the same PTY
314
+ * - Session IDs sent to client on connection for reconnect tracking
315
+ */
316
+ export function attachTerminalServer(httpServer) {
317
+ const wss = new WebSocketServer({ server: httpServer, path: '/ws/terminal' });
318
+ // --- Ping/pong keepalive ---
319
+ // The browser's native WebSocket automatically responds to ping frames with pong.
320
+ if (pingInterval)
321
+ clearInterval(pingInterval);
322
+ pingInterval = setInterval(() => {
323
+ for (const session of sessions) {
324
+ if (!session.isAlive) {
325
+ // Didn't respond to last ping — terminate
326
+ console.log(`[terminalServer] Session ${session.sessionId} ping timeout, terminating`);
327
+ session.ws.terminate();
328
+ continue;
329
+ }
330
+ session.isAlive = false;
331
+ session.ws.ping();
332
+ }
333
+ }, PING_INTERVAL_MS);
334
+ globalThis.__codeyamPingInterval = pingInterval;
335
+ wss.on('connection', (ws, req) => {
336
+ // Parse entity context from query params
337
+ const url = new URL(req.url || '', `http://${req.headers.host}`);
338
+ const entityName = url.searchParams.get('entityName') || '';
339
+ const entityType = url.searchParams.get('entityType') || '';
340
+ const entitySha = url.searchParams.get('entitySha') || '';
341
+ const entityFilePath = url.searchParams.get('entityFilePath') || '';
342
+ const scenarioName = url.searchParams.get('scenarioName') || '';
343
+ const scenarioDescription = url.searchParams.get('scenarioDescription') || '';
344
+ const analysisId = url.searchParams.get('analysisId') || '';
345
+ const projectSlug = url.searchParams.get('projectSlug') || '';
346
+ const editorMode = url.searchParams.get('editorMode') === 'true';
347
+ const reconnectId = url.searchParams.get('reconnectId') || '';
348
+ // --- Reconnection: reattach to a detached PTY ---
349
+ if (reconnectId && detachedPtys.has(reconnectId)) {
350
+ const detached = detachedPtys.get(reconnectId);
351
+ clearTimeout(detached.graceTimer);
352
+ detachedPtys.delete(reconnectId);
353
+ console.log(`[terminalServer] Reattaching session ${reconnectId}`);
354
+ const session = {
355
+ ws,
356
+ ptyProcess: detached.ptyProcess,
357
+ sessionId: detached.sessionId,
358
+ isAlive: true,
359
+ };
360
+ sessions.add(session);
361
+ // Send session ID so client can track it
362
+ ws.send(JSON.stringify({ type: 'session-id', sessionId: session.sessionId }));
363
+ // Send buffered output so client catches up
364
+ if (detached.outputBuffer) {
365
+ ws.send(JSON.stringify({ type: 'output', data: detached.outputBuffer }));
366
+ }
367
+ // Re-wire PTY output -> new WebSocket
368
+ // node-pty's onData returns a disposable; the old listener was still attached
369
+ // and was buffering output into detached.outputBuffer. We need to replace it.
370
+ // Unfortunately node-pty doesn't expose removeListener, so we use a closure flag.
371
+ let detachedFlag = false;
372
+ const reconnectPort = process.env.CODEYAM_PORT || '3111';
373
+ const reconnectTransformMarkers = createMarkerTransformer(reconnectPort);
374
+ detached.ptyProcess.onData((data) => {
375
+ if (detachedFlag)
376
+ return; // Superseded by a newer listener
377
+ if (ws.readyState === WebSocket.OPEN) {
378
+ if (!detached.hasClearedScreen &&
379
+ detached.hasContext &&
380
+ data.includes('╭')) {
381
+ detached.hasClearedScreen = true;
382
+ ws.send(JSON.stringify({ type: 'output', data: '\x1b[2J\x1b[H' }));
383
+ }
384
+ const transformed = reconnectTransformMarkers(data);
385
+ if (transformed.length > 0) {
386
+ ws.send(JSON.stringify({ type: 'output', data: transformed }));
387
+ }
388
+ const stripped = data.replace(/\x1b\[[0-9;]*[a-zA-Z]/g, '');
389
+ if (stripped.includes('Editor Mode \u2014')) {
390
+ console.log('[terminalServer] Detected claude-idle signal (reconnect)');
391
+ ws.send(JSON.stringify({ type: 'claude-idle' }));
392
+ }
393
+ }
394
+ });
395
+ detached.ptyProcess.onExit(() => {
396
+ sessions.delete(session);
397
+ if (ws.readyState === WebSocket.OPEN) {
398
+ ws.close();
399
+ }
400
+ });
401
+ // WebSocket messages -> PTY
402
+ ws.on('message', (raw) => {
403
+ try {
404
+ const msg = JSON.parse(raw.toString());
405
+ if (msg.type === 'input') {
406
+ detached.ptyProcess.write(msg.data);
407
+ }
408
+ else if (msg.type === 'resize' && msg.cols && msg.rows) {
409
+ detached.ptyProcess.resize(msg.cols, msg.rows);
410
+ }
411
+ }
412
+ catch {
413
+ detached.ptyProcess.write(raw.toString());
414
+ }
415
+ });
416
+ ws.on('pong', () => {
417
+ session.isAlive = true;
418
+ });
419
+ ws.on('close', () => {
420
+ detachedFlag = true;
421
+ detachSession(session, detached.hasContext, detached.hasClearedScreen);
422
+ });
423
+ return;
424
+ }
425
+ // --- New connection: spawn a fresh PTY ---
426
+ const shell = process.env.SHELL || '/bin/zsh';
427
+ const cwd = process.env.CODEYAM_ROOT_PATH || process.cwd();
428
+ // Verify cwd exists, fall back to HOME
429
+ const safeCwd = fs.existsSync(cwd) ? cwd : process.env.HOME || '/tmp';
430
+ // Spawn PTY with a clean env (no giant JSON blobs from CODEYAM_PROJECT etc.)
431
+ let ptyProcess;
432
+ try {
433
+ ptyProcess = pty.spawn(shell, ['-l'], {
434
+ name: 'xterm-256color',
435
+ cols: 120,
436
+ rows: 30,
437
+ cwd: safeCwd,
438
+ env: buildPtyEnv(),
439
+ });
440
+ }
441
+ catch (error) {
442
+ console.error('[terminalServer] Failed to spawn PTY:', {
443
+ shell,
444
+ cwd: safeCwd,
445
+ error,
446
+ });
447
+ ws.send(JSON.stringify({
448
+ type: 'output',
449
+ data: `\r\nFailed to start terminal: ${error.message}\r\n`,
450
+ }));
451
+ ws.close();
452
+ return;
453
+ }
454
+ const sessionId = crypto.randomUUID();
455
+ const session = {
456
+ ws,
457
+ ptyProcess,
458
+ sessionId,
459
+ isAlive: true,
460
+ };
461
+ sessions.add(session);
462
+ // Send session ID so client can use it for reconnection
463
+ ws.send(JSON.stringify({ type: 'session-id', sessionId }));
464
+ // Write context file for the appropriate skill (dev-mode or editor)
465
+ const hasContext = editorMode
466
+ ? writeEditorModeContext({ projectSlug })
467
+ : writeDevModeContext({
468
+ entityName,
469
+ entityType,
470
+ entitySha,
471
+ entityFilePath,
472
+ scenarioName,
473
+ scenarioDescription,
474
+ analysisId,
475
+ projectSlug,
476
+ });
477
+ let hasClearedScreen = false;
478
+ // Rolling buffer of trailing text to detect "Editor Mode —" across PTY chunks.
479
+ let idleDetectBuffer = '';
480
+ const IDLE_MARKER = 'Editor Mode \u2014';
481
+ // PTY output -> WebSocket
482
+ const serverPort = process.env.CODEYAM_PORT || '3111';
483
+ // Stateful transformer that buffers partial {{scenario:...}} markers
484
+ // across PTY chunks so they don't appear as raw text.
485
+ const transformMarkers = createMarkerTransformer(serverPort);
486
+ ptyProcess.onData((data) => {
487
+ if (ws.readyState === WebSocket.OPEN) {
488
+ // When Claude Code starts (indicated by its box-drawing welcome banner),
489
+ // clear the screen to hide the raw shell command.
490
+ if (!hasClearedScreen && hasContext && data.includes('╭')) {
491
+ hasClearedScreen = true;
492
+ ws.send(JSON.stringify({ type: 'output', data: '\x1b[2J\x1b[H' }));
493
+ }
494
+ // Transform {{scenario:Name:ID}} markers into OSC 8 clickable hyperlinks.
495
+ // Uses stateful buffering to handle markers split across PTY chunks.
496
+ const transformed = transformMarkers(data);
497
+ if (transformed.length > 0) {
498
+ ws.send(JSON.stringify({ type: 'output', data: transformed }));
499
+ }
500
+ // Detect the Stop hook output — signals Claude is waiting for user input.
501
+ // The hook outputs "Editor Mode —" when Claude finishes a turn.
502
+ // Strip ANSI escape codes and check buffer+current to handle cross-chunk splits.
503
+ const stripped = data.replace(/\x1b\[[0-9;]*[a-zA-Z]/g, '');
504
+ const combined = idleDetectBuffer + stripped;
505
+ if (combined.includes(IDLE_MARKER)) {
506
+ console.log('[terminalServer] Detected claude-idle signal');
507
+ ws.send(JSON.stringify({ type: 'claude-idle' }));
508
+ idleDetectBuffer = '';
509
+ }
510
+ else {
511
+ // Keep trailing chars in case the marker spans two chunks
512
+ idleDetectBuffer = stripped.slice(-(IDLE_MARKER.length - 1));
513
+ }
514
+ }
515
+ });
516
+ ptyProcess.onExit(() => {
517
+ sessions.delete(session);
518
+ // Also clean up from detachedPtys if it was detached
519
+ if (detachedPtys.has(sessionId)) {
520
+ clearTimeout(detachedPtys.get(sessionId).graceTimer);
521
+ detachedPtys.delete(sessionId);
522
+ }
523
+ if (ws.readyState === WebSocket.OPEN) {
524
+ ws.close();
525
+ }
526
+ });
527
+ // WebSocket messages -> PTY
528
+ ws.on('message', (raw) => {
529
+ try {
530
+ const msg = JSON.parse(raw.toString());
531
+ if (msg.type === 'input') {
532
+ ptyProcess.write(msg.data);
533
+ }
534
+ else if (msg.type === 'resize' && msg.cols && msg.rows) {
535
+ ptyProcess.resize(msg.cols, msg.rows);
536
+ }
537
+ }
538
+ catch {
539
+ // Non-JSON message, treat as raw input
540
+ ptyProcess.write(raw.toString());
541
+ }
542
+ });
543
+ ws.on('pong', () => {
544
+ session.isAlive = true;
545
+ });
546
+ ws.on('close', () => {
547
+ detachSession(session, hasContext, hasClearedScreen);
548
+ });
549
+ // Start Claude Code with the appropriate skill.
550
+ // Using a skill avoids shell escaping issues and multi-line paste detection.
551
+ setTimeout(() => {
552
+ if (editorMode && hasContext) {
553
+ ptyProcess.write("claude '/codeyam-editor'\r");
554
+ }
555
+ else if (hasContext) {
556
+ ptyProcess.write("claude '/codeyam-dev-mode'\r");
557
+ }
558
+ else {
559
+ ptyProcess.write('claude\r');
560
+ }
561
+ }, 500);
562
+ });
563
+ console.log('[terminalServer] WebSocket terminal server attached at /ws/terminal');
564
+ }
565
+ /**
566
+ * Detach a session's PTY instead of killing it, giving the client time to reconnect.
567
+ * The PTY is moved to `detachedPtys` with a grace timer; if the client reconnects
568
+ * within DETACH_GRACE_MS, the PTY is reattached. Otherwise it's killed.
569
+ */
570
+ function detachSession(session, hasContext = false, hasClearedScreen = false) {
571
+ sessions.delete(session);
572
+ const { sessionId, ptyProcess } = session;
573
+ // If already detached (shouldn't happen), skip
574
+ if (detachedPtys.has(sessionId))
575
+ return;
576
+ let outputBuffer = '';
577
+ // Buffer PTY output during detachment so the client can catch up on reconnect
578
+ ptyProcess.onData((data) => {
579
+ outputBuffer += data;
580
+ // Cap buffer size
581
+ if (outputBuffer.length > OUTPUT_BUFFER_MAX) {
582
+ outputBuffer = outputBuffer.slice(-OUTPUT_BUFFER_MAX);
583
+ }
584
+ });
585
+ const graceTimer = setTimeout(() => {
586
+ console.log(`[terminalServer] Grace period expired for session ${sessionId}, killing PTY`);
587
+ detachedPtys.delete(sessionId);
588
+ try {
589
+ ptyProcess.kill();
590
+ }
591
+ catch {
592
+ /* already dead */
593
+ }
594
+ }, DETACH_GRACE_MS);
595
+ detachedPtys.set(sessionId, {
596
+ ptyProcess,
597
+ sessionId,
598
+ graceTimer,
599
+ outputBuffer,
600
+ hasContext,
601
+ hasClearedScreen,
602
+ });
603
+ console.log(`[terminalServer] Session ${sessionId} detached, PTY kept alive for ${DETACH_GRACE_MS / 1000}s`);
604
+ }
605
+ /**
606
+ * Send a refresh-preview message to all connected terminal WebSocket clients.
607
+ * The Terminal component relays this to the parent page to reload the iframe.
608
+ */
609
+ export function broadcastPreviewRefresh(path, scenarioId) {
610
+ const msg = JSON.stringify({
611
+ type: 'refresh-preview',
612
+ ...(path && { path }),
613
+ ...(scenarioId && { scenarioId }),
614
+ });
615
+ let count = 0;
616
+ for (const session of sessions) {
617
+ try {
618
+ if (session.ws.readyState === WebSocket.OPEN) {
619
+ session.ws.send(msg);
620
+ count++;
621
+ }
622
+ }
623
+ catch {
624
+ // Ignore send errors
625
+ }
626
+ }
627
+ return count;
628
+ }
629
+ /**
630
+ * Show the results panel below the terminal in the Build tab.
631
+ * Triggered by Claude at end of step 12.
632
+ */
633
+ export function broadcastShowResults() {
634
+ const msg = JSON.stringify({ type: 'show-results' });
635
+ let count = 0;
636
+ for (const session of sessions) {
637
+ try {
638
+ if (session.ws.readyState === WebSocket.OPEN) {
639
+ session.ws.send(msg);
640
+ count++;
641
+ }
642
+ }
643
+ catch {
644
+ // Ignore send errors
645
+ }
646
+ }
647
+ return count;
648
+ }
649
+ /**
650
+ * Hide the results panel (e.g. after Save & Commit).
651
+ */
652
+ export function broadcastHideResults() {
653
+ const msg = JSON.stringify({ type: 'hide-results' });
654
+ let count = 0;
655
+ for (const session of sessions) {
656
+ try {
657
+ if (session.ws.readyState === WebSocket.OPEN) {
658
+ session.ws.send(msg);
659
+ count++;
660
+ }
661
+ }
662
+ catch {
663
+ // Ignore send errors
664
+ }
665
+ }
666
+ return count;
667
+ }
668
+ /**
669
+ * Send a set-viewport message to all connected terminal WebSocket clients.
670
+ * The Terminal component relays this to the parent page to update the preview viewport.
671
+ */
672
+ export function broadcastSetViewport(viewport) {
673
+ const msg = JSON.stringify({ type: 'set-viewport', ...viewport });
674
+ let count = 0;
675
+ for (const session of sessions) {
676
+ try {
677
+ if (session.ws.readyState === WebSocket.OPEN) {
678
+ session.ws.send(msg);
679
+ count++;
680
+ }
681
+ }
682
+ catch {
683
+ // Ignore send errors
684
+ }
685
+ }
686
+ return count;
687
+ }
688
+ /**
689
+ * Kill all active PTY sessions and detached PTYs. Call during shutdown.
690
+ */
691
+ export function cleanupAllTerminalSessions() {
692
+ // Clear ping interval
693
+ if (pingInterval) {
694
+ clearInterval(pingInterval);
695
+ pingInterval = null;
696
+ globalThis.__codeyamPingInterval = null;
697
+ }
698
+ // Clean up active sessions
699
+ for (const session of Array.from(sessions)) {
700
+ try {
701
+ session.ptyProcess.kill();
702
+ }
703
+ catch {
704
+ // Already dead
705
+ }
706
+ try {
707
+ session.ws.close();
708
+ }
709
+ catch {
710
+ // Already closed
711
+ }
712
+ }
713
+ sessions.clear();
714
+ // Clean up detached PTYs
715
+ for (const [, detached] of detachedPtys) {
716
+ clearTimeout(detached.graceTimer);
717
+ try {
718
+ detached.ptyProcess.kill();
719
+ }
720
+ catch {
721
+ // Already dead
722
+ }
723
+ }
724
+ detachedPtys.clear();
725
+ }
726
+ //# sourceMappingURL=terminalServer.js.map