@codeyam/codeyam-cli 0.1.0-staging.eb21b2f → 0.1.0-staging.f777668

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 (544) 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 +21 -21
  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 +68 -0
  27. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  28. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  29. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +151 -135
  30. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  31. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  32. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  33. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  34. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  35. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  36. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  37. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  38. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -0
  39. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  40. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +5 -0
  41. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  42. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +22 -0
  43. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  44. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +51 -0
  45. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  46. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  47. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  48. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  49. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  50. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  51. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  52. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  53. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  54. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  55. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +100 -89
  56. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  57. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  58. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  59. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  60. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  61. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  62. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  63. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  64. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  65. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  66. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  67. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  68. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  69. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  70. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  71. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  72. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  73. package/analyzer-template/packages/github/package.json +1 -1
  74. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +1 -0
  75. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  76. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  77. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  78. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  79. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  80. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  81. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +6 -2
  82. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  83. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +14 -2
  84. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  85. package/analyzer-template/project/constructMockCode.ts +168 -48
  86. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  87. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  88. package/analyzer-template/project/start.ts +3 -0
  89. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  90. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  91. package/analyzer-template/project/writeMockDataTsx.ts +17 -0
  92. package/analyzer-template/project/writeScenarioComponents.ts +96 -17
  93. package/analyzer-template/tsconfig.json +13 -1
  94. package/background/src/lib/virtualized/project/constructMockCode.js +143 -39
  95. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  96. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  97. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  98. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  99. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  100. package/background/src/lib/virtualized/project/start.js +2 -0
  101. package/background/src/lib/virtualized/project/start.js.map +1 -1
  102. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  103. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  104. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  105. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  106. package/background/src/lib/virtualized/project/writeMockDataTsx.js +12 -0
  107. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  108. package/background/src/lib/virtualized/project/writeScenarioComponents.js +73 -12
  109. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  110. package/codeyam-cli/scripts/apply-setup.js +208 -11
  111. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  112. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  113. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  114. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  115. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  116. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  117. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  118. package/codeyam-cli/src/cli.js +32 -25
  119. package/codeyam-cli/src/cli.js.map +1 -1
  120. package/codeyam-cli/src/commands/analyze.js +17 -7
  121. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  122. package/codeyam-cli/src/commands/default.js +14 -2
  123. package/codeyam-cli/src/commands/default.js.map +1 -1
  124. package/codeyam-cli/src/commands/editor.js +2607 -0
  125. package/codeyam-cli/src/commands/editor.js.map +1 -0
  126. package/codeyam-cli/src/commands/init.js +40 -11
  127. package/codeyam-cli/src/commands/init.js.map +1 -1
  128. package/codeyam-cli/src/commands/memory.js +29 -58
  129. package/codeyam-cli/src/commands/memory.js.map +1 -1
  130. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  131. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  132. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
  133. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  134. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +635 -0
  135. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  136. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  137. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  138. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +155 -0
  139. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  140. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  141. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  142. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  143. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  144. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  145. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  146. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +393 -0
  147. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  148. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  149. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  150. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  151. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  152. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +266 -0
  153. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  154. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  155. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  156. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  157. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  158. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +221 -0
  159. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  160. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  161. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  162. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1686 -0
  163. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  164. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  165. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  166. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  167. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  168. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +6 -0
  169. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -1
  170. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +101 -0
  171. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  172. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  173. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  174. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  175. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  176. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  177. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  178. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +246 -0
  179. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  180. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +50 -4
  181. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  182. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +50 -0
  183. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  184. package/codeyam-cli/src/utils/backgroundServer.js +21 -5
  185. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  186. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  187. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  188. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  189. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  190. package/codeyam-cli/src/utils/devServerState.js +71 -0
  191. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  192. package/codeyam-cli/src/utils/editorApi.js +73 -0
  193. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  194. package/codeyam-cli/src/utils/editorAudit.js +159 -0
  195. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  196. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  197. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  198. package/codeyam-cli/src/utils/editorDevServer.js +109 -0
  199. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  200. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  201. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  202. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  203. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  204. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  205. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  206. package/codeyam-cli/src/utils/editorLoaderHelpers.js +81 -0
  207. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  208. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  209. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  210. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  211. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  212. package/codeyam-cli/src/utils/editorPreview.js +106 -0
  213. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  214. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  215. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  216. package/codeyam-cli/src/utils/editorScenarios.js +96 -0
  217. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  218. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  219. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  220. package/codeyam-cli/src/utils/entityChangeStatus.js +337 -0
  221. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  222. package/codeyam-cli/src/utils/entityChangeStatus.server.js +107 -0
  223. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  224. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  225. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  226. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  227. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  228. package/codeyam-cli/src/utils/git.js +103 -0
  229. package/codeyam-cli/src/utils/git.js.map +1 -1
  230. package/codeyam-cli/src/utils/install-skills.js +57 -15
  231. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  232. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  233. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  234. package/codeyam-cli/src/utils/npmVersionCheck.js +2 -2
  235. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -1
  236. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  237. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  238. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  239. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  240. package/codeyam-cli/src/utils/project.js +15 -5
  241. package/codeyam-cli/src/utils/project.js.map +1 -1
  242. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  243. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  244. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  245. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  246. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  247. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  248. package/codeyam-cli/src/utils/queue/job.js +70 -1
  249. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  250. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  251. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  252. package/codeyam-cli/src/utils/requireSimulations.js +1 -1
  253. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -1
  254. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +5 -6
  255. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -1
  256. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +1 -1
  257. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -1
  258. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +0 -1
  259. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -1
  260. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +2 -4
  261. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -1
  262. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +2 -5
  263. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -1
  264. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  265. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  266. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  267. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  268. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  269. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  270. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  271. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  272. package/codeyam-cli/src/utils/rules/index.js +1 -0
  273. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  274. package/codeyam-cli/src/utils/rules/parser.js +14 -4
  275. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  276. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  277. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  278. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  279. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  280. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  281. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  282. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  283. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  284. package/codeyam-cli/src/utils/scenariosManifest.js +112 -0
  285. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  286. package/codeyam-cli/src/utils/serverState.js +27 -2
  287. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  288. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +82 -11
  289. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  290. package/codeyam-cli/src/utils/simulationGateMiddleware.js +159 -0
  291. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  292. package/codeyam-cli/src/utils/syncMocksMiddleware.js +5 -24
  293. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  294. package/codeyam-cli/src/utils/testRunner.js +158 -0
  295. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  296. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  297. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  298. package/codeyam-cli/src/utils/versionInfo.js +21 -0
  299. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  300. package/codeyam-cli/src/utils/webappDetection.js +14 -2
  301. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  302. package/codeyam-cli/src/webserver/app/lib/database.js +41 -27
  303. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  304. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  305. package/codeyam-cli/src/webserver/app/lib/git.js +396 -0
  306. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  307. package/codeyam-cli/src/webserver/backgroundServer.js +118 -18
  308. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  309. package/codeyam-cli/src/webserver/build/client/assets/{CopyButton-jNYXRRNI.js → CopyButton-DmJveP3T.js} +1 -1
  310. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-bwuHPyTa.js → EntityItem-C76mRRiF.js} +1 -1
  311. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-CvzqMxcu.js → EntityTypeBadge-g3saevPb.js} +1 -1
  312. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-BH0XDim7.js → EntityTypeIcon-CobE682z.js} +1 -1
  313. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  314. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-yjIHlOGa.js → InteractivePreview-DYFW3lDD.js} +3 -3
  315. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-Cq5o8jL4.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  316. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-BvMu2i-g.js → LoadingDots-BU_OAEMP.js} +1 -1
  317. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-kgBTLoJD.js → LogViewer-ceAyBX-H.js} +1 -1
  318. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-BzPgx-xO.js → ReportIssueModal-djPLI-WV.js} +1 -1
  319. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-CwZrv-Ok.js → SafeScreenshot-BED4B6sP.js} +1 -1
  320. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-BX2Ny2Qj.js → ScenarioViewer-ZlRKbhrq.js} +3 -3
  321. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  322. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-CDpEprKa.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  323. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  324. package/codeyam-cli/src/webserver/build/client/assets/{_index-BRx8ZGZo.js → _index-C96V0n15.js} +1 -1
  325. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-4S4yPfFw.js → activity.(_tab)-BpKzcsJz.js} +1 -1
  326. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  327. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  328. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  329. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  330. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-D9hemwl6.js +22 -0
  331. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  332. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  333. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  334. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  335. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  336. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  337. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  338. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  339. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  340. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  341. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  342. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  343. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  344. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  345. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  346. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  347. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  348. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  349. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  350. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  351. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  352. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  353. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  354. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  355. package/codeyam-cli/src/webserver/build/client/assets/{book-open-D4IPYH_y.js → book-open-D_nMCFmP.js} +1 -1
  356. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-CG65viiV.js → chevron-down-BH2h1Ea2.js} +1 -1
  357. package/codeyam-cli/src/webserver/build/client/assets/{chunk-JZWAC4HX-DB3aFuEO.js → chunk-JZWAC4HX-C4pqxYJB.js} +1 -1
  358. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-igfMr5DY.js → circle-check-DyIKORY6.js} +1 -1
  359. package/codeyam-cli/src/webserver/build/client/assets/{copy-Coc4o_8c.js → copy-NDbZjXao.js} +1 -1
  360. package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-D1zB-pYc.js → createLucideIcon-CMT1jU2q.js} +1 -1
  361. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-CltMNppm.js +1 -0
  362. package/codeyam-cli/src/webserver/build/client/assets/editor-DTEBHY7Z.js +10 -0
  363. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-B7ztwLut.js +41 -0
  364. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-B0h9AqE6.js → entity._sha._-DItJnD8s.js} +10 -10
  365. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-D5rYBT5x.js +6 -0
  366. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CF164ouH.js +6 -0
  367. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  368. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-PePWg17F.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  369. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-I-Wo99C_.js → entry.client-DTvKq3TY.js} +1 -1
  370. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-9sMMAiWJ.js → fileTableUtils-cPo8LiG3.js} +1 -1
  371. package/codeyam-cli/src/webserver/build/client/assets/{files-Co65J0s3.js → files-DO4CZ16O.js} +1 -1
  372. package/codeyam-cli/src/webserver/build/client/assets/git-CdN8sCqs.js +1 -0
  373. package/codeyam-cli/src/webserver/build/client/assets/globals-JMY99HpD.css +1 -0
  374. package/codeyam-cli/src/webserver/build/client/assets/{index-CUM5iXwc.js → index-10oVnAAH.js} +1 -1
  375. package/codeyam-cli/src/webserver/build/client/assets/{index-_417gcQW.js → index-BcvgDzbZ.js} +1 -1
  376. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  377. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  378. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-TzRHMVog.js → loader-circle-BAXYRVEO.js} +1 -1
  379. package/codeyam-cli/src/webserver/build/client/assets/manifest-7aab51c4.js +1 -0
  380. package/codeyam-cli/src/webserver/build/client/assets/memory-Dg0mvYrI.js +96 -0
  381. package/codeyam-cli/src/webserver/build/client/assets/{pause-hjzB7t2z.js → pause-DTAcYxBt.js} +1 -1
  382. package/codeyam-cli/src/webserver/build/client/assets/root-FRztnN-P.js +67 -0
  383. package/codeyam-cli/src/webserver/build/client/assets/{search-DcAwD_Ln.js → search-fKo7v0Zo.js} +1 -1
  384. package/codeyam-cli/src/webserver/build/client/assets/settings-DfuTtcJP.js +1 -0
  385. package/codeyam-cli/src/webserver/build/client/assets/{simulations-DVNJVQgD.js → simulations-B3aOzpCZ.js} +1 -1
  386. package/codeyam-cli/src/webserver/build/client/assets/{terminal-DbEAHMbA.js → terminal-BG4heKCG.js} +1 -1
  387. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-CAD5b1o_.js → triangle-alert-DtSmdtM4.js} +1 -1
  388. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-CrAK28Bc.js +1 -0
  389. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  390. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DZlYx2c4.js → useReportContext-O-jkvSPx.js} +1 -1
  391. package/codeyam-cli/src/webserver/build/client/assets/{useToast-ihdMtlf6.js → useToast-9FIWuYfK.js} +1 -1
  392. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  393. package/codeyam-cli/src/webserver/build/server/assets/index-Cz751Dm2.js +1 -0
  394. package/codeyam-cli/src/webserver/build/server/assets/server-build-DSylnYVM.js +367 -0
  395. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  396. package/codeyam-cli/src/webserver/build-info.json +5 -5
  397. package/codeyam-cli/src/webserver/devServer.js +39 -5
  398. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  399. package/codeyam-cli/src/webserver/editorProxy.js +431 -0
  400. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  401. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  402. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  403. package/codeyam-cli/src/webserver/server.js +258 -1
  404. package/codeyam-cli/src/webserver/server.js.map +1 -1
  405. package/codeyam-cli/src/webserver/terminalServer.js +706 -0
  406. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  407. package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
  408. package/codeyam-cli/templates/editor-step-hook.py +208 -0
  409. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  410. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  411. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  412. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  413. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  414. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  415. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  416. package/codeyam-cli/templates/nextjs-prisma-sqlite/PRISMA_SETUP.md +84 -0
  417. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  418. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  419. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  420. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  421. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +19 -0
  422. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  423. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  424. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  425. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  426. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +38 -0
  427. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  428. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  429. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +37 -0
  430. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  431. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +89 -0
  432. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  433. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  434. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  435. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  436. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  437. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  438. package/codeyam-cli/templates/rule-notification-hook.py +44 -17
  439. package/codeyam-cli/templates/rule-reflection-hook.py +24 -4
  440. package/codeyam-cli/templates/rules-instructions.md +34 -88
  441. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  442. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +136 -0
  443. package/codeyam-cli/templates/{codeyam-memory.md → skills/codeyam-memory/SKILL.md} +215 -0
  444. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  445. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  446. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  447. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  448. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  449. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  450. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  451. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  452. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  453. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  454. package/codeyam-cli/templates/{codeyam-new-rule.md → skills/codeyam-new-rule/SKILL.md} +0 -2
  455. package/package.json +21 -14
  456. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  457. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  458. package/packages/ai/src/lib/completionCall.js +10 -7
  459. package/packages/ai/src/lib/completionCall.js.map +1 -1
  460. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +234 -3
  461. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  462. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  463. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  464. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  465. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  466. package/packages/ai/src/lib/generateEntityScenarioData.js +57 -2
  467. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  468. package/packages/ai/src/lib/generateExecutionFlows.js +0 -11
  469. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  470. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  471. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  472. package/packages/analyze/src/lib/asts/index.js +4 -2
  473. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  474. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  475. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  476. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +8 -1
  477. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  478. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  479. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  480. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  481. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  482. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +54 -27
  483. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -1
  484. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +65 -0
  485. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  486. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  487. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  488. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +18 -4
  489. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  490. package/packages/database/index.js +1 -0
  491. package/packages/database/index.js.map +1 -1
  492. package/packages/database/src/lib/kysely/db.js +5 -0
  493. package/packages/database/src/lib/kysely/db.js.map +1 -1
  494. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +51 -0
  495. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  496. package/packages/database/src/lib/loadCommits.js +23 -13
  497. package/packages/database/src/lib/loadCommits.js.map +1 -1
  498. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  499. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  500. package/packages/database/src/lib/updateCommitMetadata.js +100 -89
  501. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  502. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  503. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  504. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  505. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  506. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  507. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  508. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  509. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  510. package/packages/utils/src/lib/fs/rsyncCopy.js +6 -2
  511. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  512. package/scripts/npm-post-install.cjs +34 -0
  513. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -120
  514. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  515. package/codeyam-cli/src/commands/list.js +0 -31
  516. package/codeyam-cli/src/commands/list.js.map +0 -1
  517. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  518. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  519. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  520. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  521. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-EhOseatT.js +0 -34
  522. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DHKuQSmR.js +0 -17
  523. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-JTAjQ54M.js +0 -1
  524. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DjLxr2JB.js +0 -6
  525. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-CtYowLOt.js +0 -6
  526. package/codeyam-cli/src/webserver/build/client/assets/git-BdHOxVfg.js +0 -15
  527. package/codeyam-cli/src/webserver/build/client/assets/globals-CCgBKWy4.css +0 -1
  528. package/codeyam-cli/src/webserver/build/client/assets/labs-BK0C1H1T.js +0 -1
  529. package/codeyam-cli/src/webserver/build/client/assets/manifest-390cb8fa.js +0 -1
  530. package/codeyam-cli/src/webserver/build/client/assets/memory-CzZySbBE.js +0 -78
  531. package/codeyam-cli/src/webserver/build/client/assets/root-DnbDhvTU.js +0 -62
  532. package/codeyam-cli/src/webserver/build/client/assets/settings-CclxrcPK.js +0 -1
  533. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BqgrAzs3.js +0 -1
  534. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-DAFqfEDH.js +0 -2
  535. package/codeyam-cli/src/webserver/build/server/assets/index-CXfuiwt3.js +0 -1
  536. package/codeyam-cli/src/webserver/build/server/assets/server-build-BSvme_Ao.js +0 -259
  537. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  538. package/scripts/finalize-analyzer.cjs +0 -13
  539. /package/codeyam-cli/templates/{codeyam-diagnose.md → commands/codeyam-diagnose.md} +0 -0
  540. /package/codeyam-cli/templates/{codeyam-debug.md → skills/codeyam-debug/SKILL.md} +0 -0
  541. /package/codeyam-cli/templates/{codeyam-setup.md → skills/codeyam-setup/SKILL.md} +0 -0
  542. /package/codeyam-cli/templates/{codeyam-sim.md → skills/codeyam-sim/SKILL.md} +0 -0
  543. /package/codeyam-cli/templates/{codeyam-test.md → skills/codeyam-test/SKILL.md} +0 -0
  544. /package/codeyam-cli/templates/{codeyam-verify.md → skills/codeyam-verify/SKILL.md} +0 -0
@@ -0,0 +1,414 @@
1
+ /**
2
+ * Node.js preload module for CodeYam editor proxy.
3
+ *
4
+ * Loaded via NODE_OPTIONS='--import /path/to/codeyam-preload.mjs' in the
5
+ * dev server process. Patches global fetch and http/https.request to:
6
+ *
7
+ * 1. **Direct mock matching** — reads the active scenario data from disk and
8
+ * returns mock responses for ANY matching URL (internal API routes, external
9
+ * APIs like Stripe/weather, etc.) without a network round-trip.
10
+ *
11
+ * 2. **Proxy redirect** — for dev-server-targeting requests that don't match
12
+ * a mock route, redirects them through the CodeYam proxy.
13
+ *
14
+ * Must be .mjs (native ESM) because --import requires it.
15
+ * No TypeScript, no build step, no dependencies.
16
+ */
17
+
18
+ import http from 'node:http';
19
+ import https from 'node:https';
20
+ import fs from 'node:fs';
21
+ import path from 'node:path';
22
+ import { Readable } from 'node:stream';
23
+ import { EventEmitter } from 'node:events';
24
+
25
+ let proxyConfig = null;
26
+ let configLoaded = false;
27
+
28
+ /**
29
+ * Lazily load the proxy config from .codeyam/proxy-config.json.
30
+ * Returns null if the file doesn't exist yet (proxy still starting).
31
+ */
32
+ function getProxyConfig() {
33
+ if (configLoaded && proxyConfig) return proxyConfig;
34
+
35
+ // Try env var first (most reliable)
36
+ const proxyUrl = process.env.CODEYAM_PROXY_URL;
37
+ const devServerUrl = process.env.CODEYAM_DEV_SERVER_URL;
38
+ if (proxyUrl && devServerUrl) {
39
+ proxyConfig = { proxyUrl, devServerUrl };
40
+ configLoaded = true;
41
+ return proxyConfig;
42
+ }
43
+
44
+ // Fall back to config file
45
+ try {
46
+ const cwd = process.cwd();
47
+ const configPath = path.join(cwd, '.codeyam', 'proxy-config.json');
48
+ if (fs.existsSync(configPath)) {
49
+ const raw = fs.readFileSync(configPath, 'utf-8');
50
+ proxyConfig = JSON.parse(raw);
51
+ configLoaded = true;
52
+ return proxyConfig;
53
+ }
54
+ } catch {
55
+ // File doesn't exist yet or is invalid — that's fine
56
+ }
57
+
58
+ return null;
59
+ }
60
+
61
+ // --- Scenario data for direct mock matching (SSR + external APIs) ---
62
+
63
+ let scenarioCache = { data: null, timestamp: 0 };
64
+ const SCENARIO_CACHE_TTL = 500;
65
+
66
+ /**
67
+ * Read the active scenario's mock data from disk, with brief caching.
68
+ * Returns null if no active scenario or data file is missing.
69
+ *
70
+ * For application/user scenarios (seed-based): only returns externalApis
71
+ * as routes. DB-backed routes are served by the real app from seeded data.
72
+ */
73
+ function readScenarioData() {
74
+ const now = Date.now();
75
+ if (scenarioCache.data !== null && now - scenarioCache.timestamp < SCENARIO_CACHE_TTL) {
76
+ return scenarioCache.data;
77
+ }
78
+
79
+ try {
80
+ const cwd = process.cwd();
81
+ const activePath = path.join(cwd, '.codeyam', 'active-scenario.json');
82
+ if (!fs.existsSync(activePath)) {
83
+ scenarioCache = { data: null, timestamp: now };
84
+ return null;
85
+ }
86
+
87
+ const active = JSON.parse(fs.readFileSync(activePath, 'utf-8'));
88
+ if (!active.scenarioId) {
89
+ scenarioCache = { data: null, timestamp: now };
90
+ return null;
91
+ }
92
+
93
+ const dataPath = path.join(cwd, '.codeyam', 'editor-scenarios', `${active.scenarioId}.json`);
94
+ if (!fs.existsSync(dataPath)) {
95
+ scenarioCache = { data: null, timestamp: now };
96
+ return null;
97
+ }
98
+
99
+ const rawData = JSON.parse(fs.readFileSync(dataPath, 'utf-8'));
100
+
101
+ // Type-aware: for seed-based scenarios, only intercept externalApis
102
+ const scenarioType = active.type || rawData.type || null;
103
+ let mockData;
104
+
105
+ if ((scenarioType === 'application' || scenarioType === 'user') && rawData.seed) {
106
+ if (rawData.externalApis && typeof rawData.externalApis === 'object') {
107
+ mockData = { routes: rawData.externalApis };
108
+ } else {
109
+ mockData = null;
110
+ }
111
+ } else {
112
+ mockData = rawData;
113
+ }
114
+
115
+ scenarioCache = { data: mockData, timestamp: now };
116
+ return mockData;
117
+ } catch {
118
+ scenarioCache = { data: null, timestamp: now };
119
+ return null;
120
+ }
121
+ }
122
+
123
+ /**
124
+ * Match a request URL against scenario mock data routes.
125
+ * Mirrors the logic in editorPreloadHelpers.ts matchScenarioRoute().
126
+ *
127
+ * Supports:
128
+ * - Path-only routes: "/api/drinks"
129
+ * - Full URL routes: "https://api.stripe.com/v1/charges"
130
+ * - Method-prefixed: "POST /api/drinks"
131
+ */
132
+ function matchScenarioRoute(requestUrl, method, scenarioData) {
133
+ const routes = scenarioData.routes;
134
+ if (!routes || typeof routes !== 'object') return null;
135
+
136
+ let pathname;
137
+ try {
138
+ pathname = new URL(requestUrl).pathname;
139
+ } catch {
140
+ pathname = requestUrl.split('?')[0];
141
+ }
142
+
143
+ const upperMethod = method.toUpperCase();
144
+
145
+ for (const [routeKey, routeValue] of Object.entries(routes)) {
146
+ if (!routeValue || typeof routeValue !== 'object') continue;
147
+
148
+ // Method-prefixed: "POST /api/drinks"
149
+ const spaceIdx = routeKey.indexOf(' ');
150
+ if (spaceIdx !== -1) {
151
+ const routeMethod = routeKey.slice(0, spaceIdx).toUpperCase();
152
+ const routePath = routeKey.slice(spaceIdx + 1);
153
+ if (routeMethod === upperMethod && routePath === pathname) {
154
+ return {
155
+ body: routeValue.body ?? routeValue,
156
+ status: typeof routeValue.status === 'number' ? routeValue.status : 200,
157
+ };
158
+ }
159
+ continue;
160
+ }
161
+
162
+ // Full URL: "https://api.stripe.com/v1/charges"
163
+ if (routeKey.startsWith('http://') || routeKey.startsWith('https://')) {
164
+ try {
165
+ const routeParsed = new URL(routeKey);
166
+ const reqParsed = new URL(requestUrl);
167
+ if (
168
+ routeParsed.hostname === reqParsed.hostname &&
169
+ routeParsed.port === reqParsed.port &&
170
+ routeParsed.pathname === reqParsed.pathname
171
+ ) {
172
+ return {
173
+ body: routeValue.body ?? routeValue,
174
+ status: typeof routeValue.status === 'number' ? routeValue.status : 200,
175
+ };
176
+ }
177
+ } catch {
178
+ // Invalid URL in route key — skip
179
+ }
180
+ continue;
181
+ }
182
+
183
+ // Path-only: "/api/drinks"
184
+ if (routeKey === pathname) {
185
+ return {
186
+ body: routeValue.body ?? routeValue,
187
+ status: typeof routeValue.status === 'number' ? routeValue.status : 200,
188
+ };
189
+ }
190
+ }
191
+
192
+ return null;
193
+ }
194
+
195
+ /**
196
+ * Create a mock http.ClientRequest that delivers a mock response.
197
+ * Used to intercept http.request/http.get calls for matched routes.
198
+ */
199
+ function createMockRequest(mockResult, callback) {
200
+ const body = JSON.stringify(mockResult.body);
201
+
202
+ const mockResponse = new Readable({
203
+ read() {
204
+ this.push(body);
205
+ this.push(null);
206
+ },
207
+ });
208
+ mockResponse.statusCode = mockResult.status;
209
+ mockResponse.statusMessage = 'OK';
210
+ mockResponse.headers = { 'content-type': 'application/json', 'x-codeyam-mock': 'preload' };
211
+ mockResponse.rawHeaders = ['content-type', 'application/json', 'x-codeyam-mock', 'preload'];
212
+
213
+ const mockReq = new EventEmitter();
214
+ mockReq.write = () => true;
215
+ mockReq.end = () => {
216
+ process.nextTick(() => {
217
+ if (callback) callback(mockResponse);
218
+ mockReq.emit('response', mockResponse);
219
+ });
220
+ };
221
+ mockReq.abort = () => {};
222
+ mockReq.destroy = () => {};
223
+ mockReq.setTimeout = () => mockReq;
224
+ mockReq.setNoDelay = () => {};
225
+ mockReq.setSocketKeepAlive = () => {};
226
+
227
+ return mockReq;
228
+ }
229
+
230
+ /**
231
+ * Check if a URL string targets the dev server and return the redirected URL.
232
+ */
233
+ function redirectUrl(urlStr, config) {
234
+ try {
235
+ const parsed = new URL(urlStr);
236
+ const dev = new URL(config.devServerUrl);
237
+ const proxy = new URL(config.proxyUrl);
238
+
239
+ if (parsed.hostname === dev.hostname && parsed.port === dev.port) {
240
+ parsed.hostname = proxy.hostname;
241
+ parsed.port = proxy.port;
242
+ parsed.protocol = proxy.protocol;
243
+ return parsed.toString();
244
+ }
245
+ } catch {
246
+ // Invalid URL — pass through
247
+ }
248
+ return urlStr;
249
+ }
250
+
251
+ /**
252
+ * Check if http.request options target the dev server and patch them.
253
+ */
254
+ function redirectOptions(options, config) {
255
+ const dev = new URL(config.devServerUrl);
256
+ const proxy = new URL(config.proxyUrl);
257
+ const devPort = parseInt(dev.port, 10);
258
+ const proxyPort = parseInt(proxy.port, 10);
259
+
260
+ if (options.hostname && parseInt(String(options.port), 10) === devPort && options.hostname === dev.hostname) {
261
+ return {
262
+ ...options,
263
+ hostname: proxy.hostname,
264
+ port: proxyPort,
265
+ headers: options.headers
266
+ ? { ...options.headers, host: `${proxy.hostname}:${proxyPort}` }
267
+ : options.headers,
268
+ };
269
+ }
270
+
271
+ if (options.host) {
272
+ const expectedHost = `${dev.hostname}:${devPort}`;
273
+ if (options.host === expectedHost) {
274
+ return {
275
+ ...options,
276
+ host: `${proxy.hostname}:${proxyPort}`,
277
+ };
278
+ }
279
+ }
280
+
281
+ return options;
282
+ }
283
+
284
+ // --- Patch global fetch ---
285
+
286
+ const originalFetch = globalThis.fetch;
287
+
288
+ if (originalFetch) {
289
+ globalThis.fetch = function patchedFetch(input, init) {
290
+ // Try direct mock matching first (handles both internal and external URLs)
291
+ const scenarioData = readScenarioData();
292
+ if (scenarioData) {
293
+ let url = '';
294
+ let method = (init?.method || 'GET').toUpperCase();
295
+
296
+ if (typeof input === 'string') {
297
+ url = input;
298
+ } else if (input instanceof URL) {
299
+ url = input.toString();
300
+ } else if (input instanceof Request) {
301
+ url = input.url;
302
+ method = input.method || method;
303
+ }
304
+
305
+ if (url) {
306
+ const match = matchScenarioRoute(url, method, scenarioData);
307
+ if (match) {
308
+ return Promise.resolve(
309
+ new Response(JSON.stringify(match.body), {
310
+ status: match.status,
311
+ headers: {
312
+ 'Content-Type': 'application/json',
313
+ 'X-CodeYam-Mock': 'preload',
314
+ },
315
+ }),
316
+ );
317
+ }
318
+ }
319
+ }
320
+
321
+ // Fall back to proxy redirect for dev-server-targeting requests
322
+ const config = getProxyConfig();
323
+ if (!config) return originalFetch.call(this, input, init);
324
+
325
+ if (typeof input === 'string') {
326
+ const redirected = redirectUrl(input, config);
327
+ if (redirected !== input) {
328
+ return originalFetch.call(this, redirected, init);
329
+ }
330
+ } else if (input instanceof URL) {
331
+ const redirected = redirectUrl(input.toString(), config);
332
+ if (redirected !== input.toString()) {
333
+ return originalFetch.call(this, redirected, init);
334
+ }
335
+ } else if (input instanceof Request) {
336
+ const redirected = redirectUrl(input.url, config);
337
+ if (redirected !== input.url) {
338
+ return originalFetch.call(this, new Request(redirected, input), init);
339
+ }
340
+ }
341
+
342
+ return originalFetch.call(this, input, init);
343
+ };
344
+ }
345
+
346
+ // --- Patch http.request and https.request ---
347
+
348
+ function patchModule(mod, protocol) {
349
+ const originalRequest = mod.request;
350
+ const originalGet = mod.get;
351
+
352
+ mod.request = function patchedRequest(urlOrOptions, optionsOrCallback, callback) {
353
+ // Try direct mock matching first (handles external API calls from SSR)
354
+ const scenarioData = readScenarioData();
355
+ if (scenarioData) {
356
+ let urlStr = '';
357
+ let method = 'GET';
358
+ let cb = typeof optionsOrCallback === 'function' ? optionsOrCallback : callback;
359
+
360
+ if (typeof urlOrOptions === 'string' || urlOrOptions instanceof URL) {
361
+ urlStr = typeof urlOrOptions === 'string' ? urlOrOptions : urlOrOptions.toString();
362
+ if (typeof optionsOrCallback === 'object' && optionsOrCallback !== null) {
363
+ method = optionsOrCallback.method || method;
364
+ }
365
+ } else if (urlOrOptions && typeof urlOrOptions === 'object') {
366
+ // Build URL from options
367
+ const hostname = urlOrOptions.hostname || urlOrOptions.host?.split(':')[0] || 'localhost';
368
+ const port = urlOrOptions.port || (protocol === 'https' ? 443 : 80);
369
+ const urlPath = urlOrOptions.path || '/';
370
+ urlStr = `${protocol}://${hostname}:${port}${urlPath}`;
371
+ method = urlOrOptions.method || method;
372
+ cb = typeof optionsOrCallback === 'function' ? optionsOrCallback : callback;
373
+ }
374
+
375
+ if (urlStr) {
376
+ const match = matchScenarioRoute(urlStr, method, scenarioData);
377
+ if (match) {
378
+ return createMockRequest(match, cb);
379
+ }
380
+ }
381
+ }
382
+
383
+ // Fall back to proxy redirect for dev-server-targeting requests
384
+ const config = getProxyConfig();
385
+ if (!config) return originalRequest.call(this, urlOrOptions, optionsOrCallback, callback);
386
+
387
+ // http.request(url, options, callback)
388
+ if (typeof urlOrOptions === 'string' || urlOrOptions instanceof URL) {
389
+ const urlStr = typeof urlOrOptions === 'string' ? urlOrOptions : urlOrOptions.toString();
390
+ const redirected = redirectUrl(urlStr, config);
391
+ if (redirected !== urlStr) {
392
+ // Redirect to proxy — force http since proxy is always http
393
+ return http.request.call(http, redirected, optionsOrCallback, callback);
394
+ }
395
+ return originalRequest.call(this, urlOrOptions, optionsOrCallback, callback);
396
+ }
397
+
398
+ // http.request(options, callback)
399
+ const redirected = redirectOptions(urlOrOptions, config);
400
+ if (redirected !== urlOrOptions) {
401
+ return http.request.call(http, redirected, optionsOrCallback);
402
+ }
403
+ return originalRequest.call(this, urlOrOptions, optionsOrCallback, callback);
404
+ };
405
+
406
+ mod.get = function patchedGet(urlOrOptions, optionsOrCallback, callback) {
407
+ const req = mod.request(urlOrOptions, optionsOrCallback, callback);
408
+ req.end();
409
+ return req;
410
+ };
411
+ }
412
+
413
+ patchModule(http, 'http');
414
+ patchModule(https, 'https');
@@ -0,0 +1,230 @@
1
+ #!/usr/bin/env npx tsx
2
+ /**
3
+ * Lightweight Playwright script for journal screenshots.
4
+ * No DB lookups, no mock data regeneration — just navigate and screenshot.
5
+ *
6
+ * Usage: npx tsx journalCapture.ts '<json-args>'
7
+ * Args: { url, outputPath, viewportWidth?, viewportHeight? }
8
+ */
9
+
10
+ import { chromium, Page } from 'playwright';
11
+
12
+ /**
13
+ * Wait until DOM mutations stop for `quietMs`, or until `maxWaitMs` elapsed.
14
+ * Uses MutationObserver to detect when React has finished rendering,
15
+ * including data-driven re-renders from useEffect fetches.
16
+ *
17
+ * Same pattern used in takeElementScreenshot.ts (background package).
18
+ *
19
+ * Uses string-based evaluate to avoid tsx/esbuild __name decorator issues
20
+ * when the function is serialized for browser execution.
21
+ */
22
+ async function waitForDomIdle(
23
+ page: Page,
24
+ quietMs: number,
25
+ maxWaitMs: number,
26
+ ): Promise<void> {
27
+ await page.evaluate(`
28
+ new Promise(function(resolve) {
29
+ var timer;
30
+ var startTime = Date.now();
31
+
32
+ function finish() {
33
+ clearTimeout(timer);
34
+ observer.disconnect();
35
+ resolve();
36
+ }
37
+
38
+ function reset() {
39
+ clearTimeout(timer);
40
+ if (Date.now() - startTime >= ${maxWaitMs}) { finish(); return; }
41
+ timer = setTimeout(finish, ${quietMs});
42
+ }
43
+
44
+ var observer = new MutationObserver(reset);
45
+ observer.observe(document, {
46
+ childList: true,
47
+ subtree: true,
48
+ attributes: true
49
+ });
50
+
51
+ setTimeout(finish, ${maxWaitMs});
52
+ reset();
53
+ })
54
+ `);
55
+ }
56
+
57
+ /**
58
+ * Stabilize the page before taking a screenshot.
59
+ *
60
+ * Handles client-side rendered content (React useEffect + fetch pattern):
61
+ * 1. Wait for DOM to settle after initial hydration
62
+ * 2. Wait for any network requests triggered by client JS (useEffect fetches)
63
+ * 3. Wait for DOM to settle again after data-driven re-renders
64
+ * 4. Wait for web fonts to load
65
+ */
66
+ async function stabilizePage(page: Page): Promise<void> {
67
+ // 1. Wait for React hydration / initial client rendering to settle
68
+ await waitForDomIdle(page, DOM_IDLE_QUIET_MS, DOM_IDLE_MAX_WAIT_MS);
69
+
70
+ // 2. Wait for any network requests triggered by client-side JS
71
+ // (e.g. useEffect → fetch('/api/data')). This catches in-flight requests
72
+ // that started during or after hydration.
73
+ try {
74
+ await page.waitForLoadState('networkidle', {
75
+ timeout: POST_LOAD_NETWORK_TIMEOUT_MS,
76
+ });
77
+ } catch {
78
+ // Timeout is OK — some pages have persistent connections (WebSocket, SSE)
79
+ }
80
+
81
+ // 3. Wait for data-driven re-renders to settle
82
+ await waitForDomIdle(page, DOM_IDLE_QUIET_MS, DOM_IDLE_MAX_WAIT_MS);
83
+
84
+ // 4. Wait for web fonts (string-based to avoid tsx __name decorator issues)
85
+ try {
86
+ await page.waitForFunction(
87
+ `document.fonts ? document.fonts.status === 'loaded' : true`,
88
+ { timeout: FONTS_TIMEOUT_MS },
89
+ );
90
+ } catch {
91
+ // Font loading timeout — continue anyway
92
+ }
93
+ }
94
+
95
+ interface CaptureArgs {
96
+ url: string;
97
+ outputPath: string;
98
+ viewportWidth?: number;
99
+ viewportHeight?: number;
100
+ /** CSS selector for element-level screenshot (e.g. '#codeyam-capture').
101
+ * If provided, screenshots just that element instead of the full page. */
102
+ selector?: string;
103
+ }
104
+
105
+ const MAX_RETRIES = 2;
106
+ const GOTO_TIMEOUT_MS = 15_000;
107
+ const DOM_IDLE_QUIET_MS = 500;
108
+ const DOM_IDLE_MAX_WAIT_MS = 5_000;
109
+ const POST_LOAD_NETWORK_TIMEOUT_MS = 5_000;
110
+ const FONTS_TIMEOUT_MS = 5_000;
111
+
112
+ async function main() {
113
+ const args = process.argv.slice(2);
114
+ if (args.length < 1) {
115
+ console.error('Usage: journalCapture.ts <json-args>');
116
+ process.exit(1);
117
+ }
118
+
119
+ const config: CaptureArgs = JSON.parse(args[0]);
120
+ const {
121
+ url,
122
+ outputPath,
123
+ viewportWidth = 1280,
124
+ viewportHeight = 720,
125
+ selector,
126
+ } = config;
127
+
128
+ console.log(`[JournalCapture] URL: ${url}`);
129
+ console.log(`[JournalCapture] Output: ${outputPath}`);
130
+ console.log(`[JournalCapture] Viewport: ${viewportWidth}x${viewportHeight}`);
131
+
132
+ const browser = await chromium.launch({ headless: true });
133
+
134
+ try {
135
+ const context = await browser.newContext({
136
+ viewport: { width: viewportWidth, height: viewportHeight },
137
+ });
138
+ const page = await context.newPage();
139
+
140
+ // Log console messages from the page for debugging
141
+ page.on('console', (msg) => {
142
+ if (msg.type() === 'error') {
143
+ console.log(`[JournalCapture] Page console.error: ${msg.text()}`);
144
+ }
145
+ });
146
+
147
+ // Log failed network requests
148
+ page.on('requestfailed', (request) => {
149
+ console.log(
150
+ `[JournalCapture] Network failed: ${request.method()} ${request.url()} — ${request.failure()?.errorText || 'unknown'}`,
151
+ );
152
+ });
153
+
154
+ let lastError: Error | null = null;
155
+
156
+ for (let attempt = 1; attempt <= MAX_RETRIES; attempt++) {
157
+ try {
158
+ console.log(
159
+ `[JournalCapture] Navigating (attempt ${attempt}/${MAX_RETRIES})...`,
160
+ );
161
+
162
+ const response = await page.goto(url, {
163
+ waitUntil: 'networkidle',
164
+ timeout: GOTO_TIMEOUT_MS,
165
+ });
166
+
167
+ if (response) {
168
+ console.log(
169
+ `[JournalCapture] Page loaded: status=${response.status()}, url=${response.url()}`,
170
+ );
171
+ }
172
+
173
+ // Wait for client-side rendering to complete (React hydration,
174
+ // useEffect data fetches, font loading, etc.)
175
+ await stabilizePage(page);
176
+
177
+ const pageTitle = await page.title();
178
+ console.log(`[JournalCapture] Page title: ${pageTitle}`);
179
+
180
+ if (selector) {
181
+ // Element-level screenshot — captures just the wrapper element
182
+ const element = page.locator(selector);
183
+ try {
184
+ await element.waitFor({ state: 'visible', timeout: 5000 });
185
+ await element.screenshot({ path: outputPath });
186
+ console.log(
187
+ `[JournalCapture] Element screenshot: selector=${selector}`,
188
+ );
189
+ } catch {
190
+ // Selector not found — fall back to full-page screenshot
191
+ console.warn(
192
+ `[JournalCapture] Selector "${selector}" not found, falling back to full page`,
193
+ );
194
+ await page.screenshot({ path: outputPath, fullPage: true });
195
+ }
196
+ } else {
197
+ await page.screenshot({ path: outputPath, fullPage: true });
198
+ }
199
+
200
+ console.log(
201
+ `[JournalCapture] RESULT:${JSON.stringify({ success: true, path: outputPath })}`,
202
+ );
203
+ return; // Success
204
+ } catch (error) {
205
+ lastError = error instanceof Error ? error : new Error(String(error));
206
+ console.warn(
207
+ `[JournalCapture] Attempt ${attempt} failed: ${lastError.message}`,
208
+ );
209
+
210
+ if (attempt < MAX_RETRIES) {
211
+ // Wait a bit before retrying (server might still be starting)
212
+ const backoffMs = attempt * 2000;
213
+ console.log(`[JournalCapture] Retrying in ${backoffMs}ms...`);
214
+ await new Promise((r) => setTimeout(r, backoffMs));
215
+ }
216
+ }
217
+ }
218
+
219
+ // All retries exhausted
220
+ const message = lastError?.message || 'Unknown error';
221
+ console.error(
222
+ `[JournalCapture] All ${MAX_RETRIES} attempts failed: ${message}`,
223
+ );
224
+ process.exit(1);
225
+ } finally {
226
+ await browser.close();
227
+ }
228
+ }
229
+
230
+ void main();