@codeyam/codeyam-cli 0.1.0-staging.d3e886e → 0.1.0-staging.d57a578

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