@codeyam/codeyam-cli 0.1.0-staging.4c0c3c9 → 0.1.0-staging.5370992

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 (861) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +24 -24
  4. package/analyzer-template/packages/ai/package.json +3 -3
  5. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
  6. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +135 -0
  7. package/analyzer-template/packages/ai/src/lib/astScopes/nodeToSource.ts +19 -0
  8. package/analyzer-template/packages/ai/src/lib/astScopes/paths.ts +11 -4
  9. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  10. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +295 -14
  11. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.ts +10 -3
  12. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +16 -6
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  15. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +15 -6
  16. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +78 -2
  17. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +96 -33
  18. package/analyzer-template/packages/analyze/index.ts +4 -1
  19. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +19 -7
  20. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  21. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  22. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +28 -2
  23. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +14 -37
  24. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  25. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +22 -6
  26. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +9 -12
  27. package/analyzer-template/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.ts +21 -0
  28. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +82 -10
  29. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +4 -0
  30. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +4 -0
  31. package/analyzer-template/packages/analyze/src/lib/files/analyzeNextRoute.ts +8 -3
  32. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +65 -28
  33. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +322 -58
  34. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  35. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +1707 -1466
  36. package/analyzer-template/packages/aws/package.json +10 -10
  37. package/analyzer-template/packages/database/index.ts +1 -0
  38. package/analyzer-template/packages/database/package.json +4 -4
  39. package/analyzer-template/packages/database/src/lib/kysely/db.ts +8 -0
  40. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +164 -0
  41. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +25 -15
  42. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  43. package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
  44. package/analyzer-template/packages/database/src/lib/loadEntity.ts +19 -8
  45. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  46. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +94 -143
  47. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  48. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  49. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  50. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  51. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  52. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  53. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  54. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  55. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -0
  56. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  57. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +5 -0
  58. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  59. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +29 -0
  60. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  61. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  62. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  63. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  64. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  65. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  66. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +7 -1
  67. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  68. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  69. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  70. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  71. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  72. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
  73. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  74. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts +4 -1
  75. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts.map +1 -1
  76. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js +5 -5
  77. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js.map +1 -1
  78. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  79. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  80. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  81. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  82. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +76 -90
  83. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  85. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  86. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  87. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  88. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  89. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  90. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  91. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  92. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  93. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  94. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  95. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  96. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  97. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  98. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  99. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  100. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  101. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  102. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  103. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  104. package/analyzer-template/packages/github/package.json +1 -1
  105. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  106. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +1 -0
  107. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  108. package/analyzer-template/packages/ui-components/package.json +1 -1
  109. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  110. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  111. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  112. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  113. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  114. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  115. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  116. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  117. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts +3 -1
  118. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  119. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +28 -3
  120. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  121. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +41 -2
  122. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  123. package/analyzer-template/project/analyzeFileEntities.ts +26 -0
  124. package/analyzer-template/project/constructMockCode.ts +168 -48
  125. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  126. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  127. package/analyzer-template/project/runMultiScenarioServer.ts +26 -3
  128. package/analyzer-template/project/start.ts +3 -0
  129. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  130. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  131. package/analyzer-template/project/writeMockDataTsx.ts +17 -0
  132. package/analyzer-template/project/writeScenarioComponents.ts +110 -17
  133. package/analyzer-template/tsconfig.json +13 -1
  134. package/background/src/lib/virtualized/project/analyzeFileEntities.js +22 -0
  135. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  136. package/background/src/lib/virtualized/project/constructMockCode.js +143 -39
  137. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  138. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  139. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  140. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  141. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  142. package/background/src/lib/virtualized/project/runMultiScenarioServer.js +23 -3
  143. package/background/src/lib/virtualized/project/runMultiScenarioServer.js.map +1 -1
  144. package/background/src/lib/virtualized/project/start.js +2 -0
  145. package/background/src/lib/virtualized/project/start.js.map +1 -1
  146. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  147. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  148. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  149. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  150. package/background/src/lib/virtualized/project/writeMockDataTsx.js +12 -0
  151. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  152. package/background/src/lib/virtualized/project/writeScenarioComponents.js +83 -12
  153. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  154. package/codeyam-cli/scripts/apply-setup.js +208 -11
  155. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  156. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  157. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  158. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  159. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  160. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  161. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  162. package/codeyam-cli/src/cli.js +56 -25
  163. package/codeyam-cli/src/cli.js.map +1 -1
  164. package/codeyam-cli/src/commands/__tests__/editor.analyzeImportsArgs.test.js +47 -0
  165. package/codeyam-cli/src/commands/__tests__/editor.analyzeImportsArgs.test.js.map +1 -0
  166. package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js +71 -0
  167. package/codeyam-cli/src/commands/__tests__/editor.auditNoAutoAnalysis.test.js.map +1 -0
  168. package/codeyam-cli/src/commands/__tests__/editor.designSystem.test.js +30 -0
  169. package/codeyam-cli/src/commands/__tests__/editor.designSystem.test.js.map +1 -0
  170. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js +51 -0
  171. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js.map +1 -0
  172. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +56 -0
  173. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  174. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  175. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  176. package/codeyam-cli/src/commands/analyze.js +17 -7
  177. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  178. package/codeyam-cli/src/commands/default.js +14 -2
  179. package/codeyam-cli/src/commands/default.js.map +1 -1
  180. package/codeyam-cli/src/commands/editor.js +5900 -0
  181. package/codeyam-cli/src/commands/editor.js.map +1 -0
  182. package/codeyam-cli/src/commands/editorAnalyzeImportsArgs.js +23 -0
  183. package/codeyam-cli/src/commands/editorAnalyzeImportsArgs.js.map +1 -0
  184. package/codeyam-cli/src/commands/editorIsolateArgs.js +25 -0
  185. package/codeyam-cli/src/commands/editorIsolateArgs.js.map +1 -0
  186. package/codeyam-cli/src/commands/init.js +109 -45
  187. package/codeyam-cli/src/commands/init.js.map +1 -1
  188. package/codeyam-cli/src/commands/memory.js +89 -75
  189. package/codeyam-cli/src/commands/memory.js.map +1 -1
  190. package/codeyam-cli/src/commands/telemetry.js +37 -0
  191. package/codeyam-cli/src/commands/telemetry.js.map +1 -0
  192. package/codeyam-cli/src/data/designSystems.js +27 -0
  193. package/codeyam-cli/src/data/designSystems.js.map +1 -0
  194. package/codeyam-cli/src/data/techStacks.js +77 -0
  195. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  196. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  197. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  198. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  199. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  200. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  201. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  202. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +181 -0
  203. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  204. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +4014 -0
  205. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  206. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js +76 -0
  207. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js.map +1 -0
  208. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  209. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  210. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js +137 -0
  211. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js.map +1 -0
  212. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js +100 -0
  213. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js.map +1 -0
  214. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  215. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  216. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +194 -0
  217. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  218. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js +381 -0
  219. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js.map +1 -0
  220. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js +67 -0
  221. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js.map +1 -0
  222. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  223. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  224. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  225. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  226. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +594 -0
  227. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  228. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js +435 -0
  229. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js.map +1 -0
  230. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  231. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  232. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  233. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  234. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +361 -0
  235. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  236. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  237. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  238. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  239. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  240. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +291 -0
  241. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  242. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1768 -0
  243. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  244. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +329 -0
  245. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  246. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js +143 -0
  247. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js.map +1 -0
  248. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js +66 -0
  249. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js.map +1 -0
  250. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js +53 -0
  251. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js.map +1 -0
  252. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +2121 -0
  253. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  254. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  255. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  256. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js +177 -0
  257. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js.map +1 -0
  258. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +122 -0
  259. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  260. package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js +302 -0
  261. package/codeyam-cli/src/utils/__tests__/manualEntityAnalysis.test.js.map +1 -0
  262. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +26 -20
  263. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -1
  264. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  265. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  266. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  267. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  268. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  269. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  270. package/codeyam-cli/src/utils/__tests__/registerScenarioResult.test.js +127 -0
  271. package/codeyam-cli/src/utils/__tests__/registerScenarioResult.test.js.map +1 -0
  272. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js +118 -0
  273. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js.map +1 -0
  274. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +284 -0
  275. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  276. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  277. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  278. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +672 -0
  279. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  280. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js +84 -0
  281. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js.map +1 -0
  282. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +51 -4
  283. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  284. package/codeyam-cli/src/utils/__tests__/telemetry.test.js +159 -0
  285. package/codeyam-cli/src/utils/__tests__/telemetry.test.js.map +1 -0
  286. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  287. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  288. package/codeyam-cli/src/utils/__tests__/testRunner.test.js +217 -0
  289. package/codeyam-cli/src/utils/__tests__/testRunner.test.js.map +1 -0
  290. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +148 -0
  291. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  292. package/codeyam-cli/src/utils/analysisRunner.js +39 -8
  293. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  294. package/codeyam-cli/src/utils/analyzer.js +19 -0
  295. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  296. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  297. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  298. package/codeyam-cli/src/utils/backgroundServer.js +105 -13
  299. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  300. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  301. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  302. package/codeyam-cli/src/utils/database.js +37 -2
  303. package/codeyam-cli/src/utils/database.js.map +1 -1
  304. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  305. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  306. package/codeyam-cli/src/utils/devServerState.js +71 -0
  307. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  308. package/codeyam-cli/src/utils/editorApi.js +95 -0
  309. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  310. package/codeyam-cli/src/utils/editorAudit.js +827 -0
  311. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  312. package/codeyam-cli/src/utils/editorBroadcastViewport.js +26 -0
  313. package/codeyam-cli/src/utils/editorBroadcastViewport.js.map +1 -0
  314. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  315. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  316. package/codeyam-cli/src/utils/editorDeleteScenario.js +67 -0
  317. package/codeyam-cli/src/utils/editorDeleteScenario.js.map +1 -0
  318. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  319. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  320. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +50 -0
  321. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  322. package/codeyam-cli/src/utils/editorEntityHelpers.js +144 -0
  323. package/codeyam-cli/src/utils/editorEntityHelpers.js.map +1 -0
  324. package/codeyam-cli/src/utils/editorGuard.js +36 -0
  325. package/codeyam-cli/src/utils/editorGuard.js.map +1 -0
  326. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  327. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  328. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  329. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  330. package/codeyam-cli/src/utils/editorLoaderHelpers.js +152 -0
  331. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  332. package/codeyam-cli/src/utils/editorMigration.js +224 -0
  333. package/codeyam-cli/src/utils/editorMigration.js.map +1 -0
  334. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  335. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  336. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  337. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  338. package/codeyam-cli/src/utils/editorPreview.js +139 -0
  339. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  340. package/codeyam-cli/src/utils/editorRecapture.js +109 -0
  341. package/codeyam-cli/src/utils/editorRecapture.js.map +1 -0
  342. package/codeyam-cli/src/utils/editorScenarioSwitch.js +134 -0
  343. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  344. package/codeyam-cli/src/utils/editorScenarios.js +677 -0
  345. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  346. package/codeyam-cli/src/utils/editorSeedAdapter.js +462 -0
  347. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  348. package/codeyam-cli/src/utils/editorShouldRevalidate.js +21 -0
  349. package/codeyam-cli/src/utils/editorShouldRevalidate.js.map +1 -0
  350. package/codeyam-cli/src/utils/entityChangeStatus.js +394 -0
  351. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  352. package/codeyam-cli/src/utils/entityChangeStatus.server.js +227 -0
  353. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  354. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  355. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  356. package/codeyam-cli/src/utils/fileWatcher.js +63 -9
  357. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  358. package/codeyam-cli/src/utils/git.js +103 -0
  359. package/codeyam-cli/src/utils/git.js.map +1 -1
  360. package/codeyam-cli/src/utils/glossaryAdd.js +74 -0
  361. package/codeyam-cli/src/utils/glossaryAdd.js.map +1 -0
  362. package/codeyam-cli/src/utils/install-skills.js +71 -15
  363. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  364. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  365. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  366. package/codeyam-cli/src/utils/manualEntityAnalysis.js +196 -0
  367. package/codeyam-cli/src/utils/manualEntityAnalysis.js.map +1 -0
  368. package/codeyam-cli/src/utils/npmVersionCheck.js +2 -2
  369. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -1
  370. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  371. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  372. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  373. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  374. package/codeyam-cli/src/utils/progress.js +2 -2
  375. package/codeyam-cli/src/utils/progress.js.map +1 -1
  376. package/codeyam-cli/src/utils/project.js +15 -5
  377. package/codeyam-cli/src/utils/project.js.map +1 -1
  378. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  379. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  380. package/codeyam-cli/src/utils/queue/__tests__/job.interactiveStart.test.js +159 -0
  381. package/codeyam-cli/src/utils/queue/__tests__/job.interactiveStart.test.js.map +1 -0
  382. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  383. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  384. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  385. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  386. package/codeyam-cli/src/utils/queue/job.js +105 -7
  387. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  388. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  389. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  390. package/codeyam-cli/src/utils/registerScenarioResult.js +52 -0
  391. package/codeyam-cli/src/utils/registerScenarioResult.js.map +1 -0
  392. package/codeyam-cli/src/utils/requireSimulations.js +1 -1
  393. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -1
  394. package/codeyam-cli/src/utils/routePatternMatching.js +129 -0
  395. package/codeyam-cli/src/utils/routePatternMatching.js.map +1 -0
  396. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +5 -6
  397. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -1
  398. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +1 -1
  399. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -1
  400. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +0 -1
  401. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -1
  402. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +2 -4
  403. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -1
  404. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +4 -6
  405. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -1
  406. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +1 -1
  407. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -1
  408. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  409. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  410. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  411. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  412. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  413. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  414. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  415. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  416. package/codeyam-cli/src/utils/rules/index.js +1 -0
  417. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  418. package/codeyam-cli/src/utils/rules/parser.js +14 -4
  419. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  420. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  421. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  422. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  423. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  424. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  425. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  426. package/codeyam-cli/src/utils/scenarioCoverage.js +77 -0
  427. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  428. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  429. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  430. package/codeyam-cli/src/utils/scenariosManifest.js +313 -0
  431. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  432. package/codeyam-cli/src/utils/screenshotHash.js +26 -0
  433. package/codeyam-cli/src/utils/screenshotHash.js.map +1 -0
  434. package/codeyam-cli/src/utils/serverState.js +57 -2
  435. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  436. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +83 -11
  437. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  438. package/codeyam-cli/src/utils/simulationGateMiddleware.js +175 -0
  439. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  440. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  441. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  442. package/codeyam-cli/src/utils/syncMocksMiddleware.js +7 -26
  443. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  444. package/codeyam-cli/src/utils/telemetry.js +106 -0
  445. package/codeyam-cli/src/utils/telemetry.js.map +1 -0
  446. package/codeyam-cli/src/utils/telemetryMiddleware.js +22 -0
  447. package/codeyam-cli/src/utils/telemetryMiddleware.js.map +1 -0
  448. package/codeyam-cli/src/utils/testResultCache.js +53 -0
  449. package/codeyam-cli/src/utils/testResultCache.js.map +1 -0
  450. package/codeyam-cli/src/utils/testResultCache.server.js +81 -0
  451. package/codeyam-cli/src/utils/testResultCache.server.js.map +1 -0
  452. package/codeyam-cli/src/utils/testResultCache.server.test.js +187 -0
  453. package/codeyam-cli/src/utils/testResultCache.server.test.js.map +1 -0
  454. package/codeyam-cli/src/utils/testResultCache.test.js +230 -0
  455. package/codeyam-cli/src/utils/testResultCache.test.js.map +1 -0
  456. package/codeyam-cli/src/utils/testRunner.js +356 -0
  457. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  458. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  459. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  460. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  461. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  462. package/codeyam-cli/src/utils/webappDetection.js +38 -3
  463. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  464. package/codeyam-cli/src/webserver/__tests__/api.interactive-switch-scenario.test.js +98 -0
  465. package/codeyam-cli/src/webserver/__tests__/api.interactive-switch-scenario.test.js.map +1 -0
  466. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js +35 -0
  467. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js.map +1 -0
  468. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +107 -0
  469. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  470. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +647 -0
  471. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  472. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +315 -0
  473. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  474. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js +135 -0
  475. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js.map +1 -0
  476. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +86 -0
  477. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  478. package/codeyam-cli/src/webserver/app/lib/database.js +41 -27
  479. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  480. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  481. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  482. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  483. package/codeyam-cli/src/webserver/app/routes/api.interactive-switch-scenario.js +34 -0
  484. package/codeyam-cli/src/webserver/app/routes/api.interactive-switch-scenario.js.map +1 -0
  485. package/codeyam-cli/src/webserver/app/types/editor.js +8 -0
  486. package/codeyam-cli/src/webserver/app/types/editor.js.map +1 -0
  487. package/codeyam-cli/src/webserver/backgroundServer.js +141 -42
  488. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  489. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CLe80MMu.js +1 -0
  490. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-bwuHPyTa.js → EntityItem-Crt_KN_U.js} +5 -5
  491. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CQgyEGV-.js +1 -0
  492. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-BH0XDim7.js → EntityTypeIcon-CD7lGABo.js} +9 -9
  493. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-CgTNOhnu.js +1 -0
  494. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-DtYTSPL2.js +25 -0
  495. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-D3s1MFkb.js +3 -0
  496. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-BvMu2i-g.js → LoadingDots-By5zI316.js} +1 -1
  497. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-kgBTLoJD.js → LogViewer-CM5zg40N.js} +3 -3
  498. package/codeyam-cli/src/webserver/build/client/assets/MiniClaudeChat-CQENLSrF.js +36 -0
  499. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-BzPgx-xO.js → ReportIssueModal-C2PLkej3.js} +4 -4
  500. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DanvyBPb.js +1 -0
  501. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-BX2Ny2Qj.js → ScenarioViewer-CefgqbCr.js} +3 -3
  502. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bc8BG-Lw.js +34 -0
  503. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CK7-NaPZ.js +1 -0
  504. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-BA_Ry-rs.js +1 -0
  505. package/codeyam-cli/src/webserver/build/client/assets/{_index-BRx8ZGZo.js → _index-C1YkzTAV.js} +4 -4
  506. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-4S4yPfFw.js → activity.(_tab)-yH46LLUz.js} +8 -8
  507. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  508. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  509. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-CHx25PAe.js +1 -0
  510. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  511. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bg3e7q4S.js +22 -0
  512. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  513. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  514. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  515. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  516. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  517. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  518. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  519. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  520. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  521. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  522. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  523. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  524. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  525. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  526. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  527. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  528. package/codeyam-cli/src/webserver/build/client/assets/api.editor-recapture-stale-l0sNRNKZ.js +1 -0
  529. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  530. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  531. package/codeyam-cli/src/webserver/build/client/assets/api.editor-rename-scenario-l0sNRNKZ.js +1 -0
  532. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-scenario-data-l0sNRNKZ.js +1 -0
  533. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-seed-state-l0sNRNKZ.js +1 -0
  534. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  535. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  536. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  537. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-prompt-l0sNRNKZ.js +1 -0
  538. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  539. package/codeyam-cli/src/webserver/build/client/assets/api.editor-schema-l0sNRNKZ.js +1 -0
  540. package/codeyam-cli/src/webserver/build/client/assets/api.editor-session-l0sNRNKZ.js +1 -0
  541. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  542. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  543. package/codeyam-cli/src/webserver/build/client/assets/api.editor-verify-routes-l0sNRNKZ.js +1 -0
  544. package/codeyam-cli/src/webserver/build/client/assets/api.interactive-switch-scenario-l0sNRNKZ.js +1 -0
  545. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  546. package/codeyam-cli/src/webserver/build/client/assets/{book-open-D4IPYH_y.js → book-open-CL-lMgHh.js} +2 -2
  547. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-CG65viiV.js → chevron-down-GmAjGS9-.js} +2 -2
  548. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-BAdwhyCx.js +43 -0
  549. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-igfMr5DY.js → circle-check-DFcQkN5j.js} +2 -2
  550. package/codeyam-cli/src/webserver/build/client/assets/{copy-Coc4o_8c.js → copy-C6iF61Xs.js} +3 -3
  551. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-4ImjHTVC.js +41 -0
  552. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-Coe5NhbS.js +1 -0
  553. package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-CCKUIm0S.svg → cy-logo-cli-DoA97ML3.svg} +2 -2
  554. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-CRepiabR.js +1 -0
  555. package/codeyam-cli/src/webserver/build/client/assets/editor._tab-Gbk_i5Js.js +1 -0
  556. package/codeyam-cli/src/webserver/build/client/assets/editor.entity.(_sha)-DLM1-ZMt.js +96 -0
  557. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-CluPkvXJ.js +41 -0
  558. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-B0h9AqE6.js → entity._sha._-DYJRGiDI.js} +14 -13
  559. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-wdiwx5-Z.js +6 -0
  560. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-BrkN-40Y.js +6 -0
  561. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DxfhekTZ.js +6 -0
  562. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-PePWg17F.js → entity._sha_.edit._scenarioId-CRXJWmpB.js} +2 -2
  563. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-I-Wo99C_.js → entry.client-SuW9syRS.js} +6 -6
  564. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-Daa96Fr1.js +1 -0
  565. package/codeyam-cli/src/webserver/build/client/assets/files-D-xGrg29.js +1 -0
  566. package/codeyam-cli/src/webserver/build/client/assets/git-Bq_fbXP5.js +1 -0
  567. package/codeyam-cli/src/webserver/build/client/assets/globals-9EkC9j9I.css +1 -0
  568. package/codeyam-cli/src/webserver/build/client/assets/{index-_417gcQW.js → index-Bp1l4hSv.js} +1 -1
  569. package/codeyam-cli/src/webserver/build/client/assets/{index-CUM5iXwc.js → index-CWV9XZiG.js} +1 -1
  570. package/codeyam-cli/src/webserver/build/client/assets/index-DE3jI_dv.js +15 -0
  571. package/codeyam-cli/src/webserver/build/client/assets/jsx-runtime-D_zvdyIk.js +9 -0
  572. package/codeyam-cli/src/webserver/build/client/assets/labs-B_IX45ih.js +1 -0
  573. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-TzRHMVog.js → loader-circle-De-7qQ2u.js} +2 -2
  574. package/codeyam-cli/src/webserver/build/client/assets/manifest-7e749098.js +1 -0
  575. package/codeyam-cli/src/webserver/build/client/assets/memory-Cx2xEx7s.js +101 -0
  576. package/codeyam-cli/src/webserver/build/client/assets/{pause-hjzB7t2z.js → pause-CFxEKL1u.js} +3 -3
  577. package/codeyam-cli/src/webserver/build/client/assets/root-DGtly3mb.js +80 -0
  578. package/codeyam-cli/src/webserver/build/client/assets/{search-DcAwD_Ln.js → search-BdBb5aqc.js} +2 -2
  579. package/codeyam-cli/src/webserver/build/client/assets/settings-DdE-Untf.js +1 -0
  580. package/codeyam-cli/src/webserver/build/client/assets/simulations-DSCdE99u.js +1 -0
  581. package/codeyam-cli/src/webserver/build/client/assets/{terminal-DbEAHMbA.js → terminal-CrplD4b1.js} +3 -3
  582. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-CAD5b1o_.js → triangle-alert-DqJ0j69l.js} +2 -2
  583. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-DhXHbEjP.js +1 -0
  584. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-D9QZKaLJ.js +2 -0
  585. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-Cy5Qg_UR.js +1 -0
  586. package/codeyam-cli/src/webserver/build/client/assets/useToast-5HR2j9ZE.js +1 -0
  587. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  588. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  589. package/codeyam-cli/src/webserver/build/server/assets/analysisRunner-CO8xocj3.js +16 -0
  590. package/codeyam-cli/src/webserver/build/server/assets/index-QKPqlUgg.js +1 -0
  591. package/codeyam-cli/src/webserver/build/server/assets/init-DlspChIk.js +10 -0
  592. package/codeyam-cli/src/webserver/build/server/assets/progress-CHTtrxFG.js +1 -0
  593. package/codeyam-cli/src/webserver/build/server/assets/server-build-ChzicV-B.js +689 -0
  594. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  595. package/codeyam-cli/src/webserver/build-info.json +5 -5
  596. package/codeyam-cli/src/webserver/devServer.js +39 -5
  597. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  598. package/codeyam-cli/src/webserver/editorProxy.js +1028 -0
  599. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  600. package/codeyam-cli/src/webserver/idleDetector.js +130 -0
  601. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  602. package/codeyam-cli/src/webserver/mockStateEvents.js +28 -0
  603. package/codeyam-cli/src/webserver/mockStateEvents.js.map +1 -0
  604. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  605. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  606. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +283 -0
  607. package/codeyam-cli/src/webserver/server.js +379 -1
  608. package/codeyam-cli/src/webserver/server.js.map +1 -1
  609. package/codeyam-cli/src/webserver/terminalServer.js +952 -0
  610. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  611. package/codeyam-cli/templates/__tests__/editor-step-hook.prompt-capture.test.ts +118 -0
  612. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  613. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  614. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  615. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  616. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  617. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  618. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  619. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  620. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  621. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  622. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  623. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  624. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  625. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  626. package/codeyam-cli/templates/codeyam-editor-claude.md +149 -0
  627. package/codeyam-cli/templates/codeyam-editor-reference.md +216 -0
  628. package/codeyam-cli/templates/design-systems/clean-dashboard-design-system.md +255 -0
  629. package/codeyam-cli/templates/design-systems/editorial-design-system.md +267 -0
  630. package/codeyam-cli/templates/design-systems/mono-brutalist-design-system.md +256 -0
  631. package/codeyam-cli/templates/design-systems/neo-brutalist-design-system.md +294 -0
  632. package/codeyam-cli/templates/editor-step-hook.py +368 -0
  633. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +204 -0
  634. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  635. package/codeyam-cli/templates/expo-react-native/__tests__/.gitkeep +0 -0
  636. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  637. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  638. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  639. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +13 -0
  640. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  641. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  642. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  643. package/codeyam-cli/templates/expo-react-native/global.css +10 -0
  644. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  645. package/codeyam-cli/templates/expo-react-native/lib/theme.ts +73 -0
  646. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  647. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  648. package/codeyam-cli/templates/expo-react-native/package.json +48 -0
  649. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  650. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  651. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  652. package/codeyam-cli/templates/isolation-route/expo-router.tsx.template +54 -0
  653. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  654. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  655. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  656. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  657. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  658. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  659. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  660. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  661. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  662. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  663. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  664. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  665. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  666. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  667. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  668. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  669. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  670. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  671. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  672. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  673. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  674. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  675. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  676. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  677. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  678. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  679. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +140 -0
  680. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  681. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  682. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  683. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  684. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  685. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  686. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  687. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  688. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  689. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  690. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  691. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  692. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  693. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  694. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  695. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  696. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  697. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  698. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  699. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  700. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  701. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  702. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  703. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  704. package/codeyam-cli/templates/rule-notification-hook.py +44 -17
  705. package/codeyam-cli/templates/rule-reflection-hook.py +25 -5
  706. package/codeyam-cli/templates/rules-instructions.md +34 -88
  707. package/codeyam-cli/templates/seed-adapters/supabase.ts +291 -0
  708. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  709. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +244 -0
  710. package/codeyam-cli/templates/{codeyam-memory.md → skills/codeyam-memory/SKILL.md} +215 -0
  711. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  712. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  713. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  714. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  715. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  716. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  717. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  718. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  719. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  720. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  721. package/codeyam-cli/templates/{codeyam-new-rule.md → skills/codeyam-new-rule/SKILL.md} +0 -2
  722. package/package.json +22 -14
  723. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  724. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  725. package/packages/ai/src/lib/astScopes/methodSemantics.js +99 -0
  726. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  727. package/packages/ai/src/lib/astScopes/nodeToSource.js +16 -0
  728. package/packages/ai/src/lib/astScopes/nodeToSource.js.map +1 -1
  729. package/packages/ai/src/lib/astScopes/paths.js +12 -3
  730. package/packages/ai/src/lib/astScopes/paths.js.map +1 -1
  731. package/packages/ai/src/lib/completionCall.js +10 -7
  732. package/packages/ai/src/lib/completionCall.js.map +1 -1
  733. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +261 -13
  734. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  735. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js +9 -2
  736. package/packages/ai/src/lib/dataStructure/equivalencyManagers/ParentScopeManager.js.map +1 -1
  737. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +14 -4
  738. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  739. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  740. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  741. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  742. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  743. package/packages/ai/src/lib/dataStructureChunking.js +9 -5
  744. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  745. package/packages/ai/src/lib/generateEntityScenarioData.js +57 -2
  746. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  747. package/packages/ai/src/lib/generateExecutionFlows.js +81 -11
  748. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  749. package/packages/analyze/index.js +1 -1
  750. package/packages/analyze/index.js.map +1 -1
  751. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  752. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  753. package/packages/analyze/src/lib/asts/index.js +4 -2
  754. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  755. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  756. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  757. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +16 -2
  758. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  759. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +14 -27
  760. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  761. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  762. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  763. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +12 -2
  764. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  765. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +9 -7
  766. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  767. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js +14 -0
  768. package/packages/analyze/src/lib/files/analyze/trackEntityCircularDependencies.js.map +1 -1
  769. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +44 -11
  770. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  771. package/packages/analyze/src/lib/files/analyzeChange.js +1 -0
  772. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  773. package/packages/analyze/src/lib/files/analyzeInitial.js +1 -0
  774. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  775. package/packages/analyze/src/lib/files/analyzeNextRoute.js +5 -1
  776. package/packages/analyze/src/lib/files/analyzeNextRoute.js.map +1 -1
  777. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +54 -27
  778. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -1
  779. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +185 -28
  780. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  781. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  782. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  783. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +1386 -1197
  784. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  785. package/packages/database/index.js +1 -0
  786. package/packages/database/index.js.map +1 -1
  787. package/packages/database/src/lib/kysely/db.js +5 -0
  788. package/packages/database/src/lib/kysely/db.js.map +1 -1
  789. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  790. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  791. package/packages/database/src/lib/loadAnalysis.js +7 -1
  792. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  793. package/packages/database/src/lib/loadCommits.js +23 -13
  794. package/packages/database/src/lib/loadCommits.js.map +1 -1
  795. package/packages/database/src/lib/loadEntities.js +0 -6
  796. package/packages/database/src/lib/loadEntities.js.map +1 -1
  797. package/packages/database/src/lib/loadEntity.js +5 -5
  798. package/packages/database/src/lib/loadEntity.js.map +1 -1
  799. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  800. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  801. package/packages/database/src/lib/updateCommitMetadata.js +76 -90
  802. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  803. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  804. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  805. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  806. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  807. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  808. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  809. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  810. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  811. package/packages/types/src/enums/ProjectFramework.js +2 -0
  812. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  813. package/packages/utils/src/lib/fs/rsyncCopy.js +28 -3
  814. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  815. package/scripts/npm-post-install.cjs +34 -0
  816. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -120
  817. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  818. package/codeyam-cli/src/commands/list.js +0 -31
  819. package/codeyam-cli/src/commands/list.js.map +0 -1
  820. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  821. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  822. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  823. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  824. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-jNYXRRNI.js +0 -1
  825. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CvzqMxcu.js +0 -1
  826. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-EhOseatT.js +0 -34
  827. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-yjIHlOGa.js +0 -25
  828. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-Cq5o8jL4.js +0 -3
  829. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-CwZrv-Ok.js +0 -1
  830. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CDpEprKa.js +0 -1
  831. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DHKuQSmR.js +0 -17
  832. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-DB3aFuEO.js +0 -51
  833. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-D1zB-pYc.js +0 -21
  834. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +0 -1
  835. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-JTAjQ54M.js +0 -1
  836. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DjLxr2JB.js +0 -6
  837. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-CtYowLOt.js +0 -6
  838. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-9sMMAiWJ.js +0 -1
  839. package/codeyam-cli/src/webserver/build/client/assets/files-Co65J0s3.js +0 -1
  840. package/codeyam-cli/src/webserver/build/client/assets/git-BdHOxVfg.js +0 -15
  841. package/codeyam-cli/src/webserver/build/client/assets/globals-CCgBKWy4.css +0 -1
  842. package/codeyam-cli/src/webserver/build/client/assets/labs-BK0C1H1T.js +0 -1
  843. package/codeyam-cli/src/webserver/build/client/assets/manifest-390cb8fa.js +0 -1
  844. package/codeyam-cli/src/webserver/build/client/assets/memory-CzZySbBE.js +0 -78
  845. package/codeyam-cli/src/webserver/build/client/assets/root-DnbDhvTU.js +0 -62
  846. package/codeyam-cli/src/webserver/build/client/assets/settings-CclxrcPK.js +0 -1
  847. package/codeyam-cli/src/webserver/build/client/assets/simulations-DVNJVQgD.js +0 -1
  848. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BqgrAzs3.js +0 -1
  849. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-DAFqfEDH.js +0 -2
  850. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-DZlYx2c4.js +0 -1
  851. package/codeyam-cli/src/webserver/build/client/assets/useToast-ihdMtlf6.js +0 -1
  852. package/codeyam-cli/src/webserver/build/server/assets/index-CxaRxKVt.js +0 -1
  853. package/codeyam-cli/src/webserver/build/server/assets/server-build-D4DT0nM_.js +0 -259
  854. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  855. package/scripts/finalize-analyzer.cjs +0 -13
  856. /package/codeyam-cli/templates/{codeyam-diagnose.md → commands/codeyam-diagnose.md} +0 -0
  857. /package/codeyam-cli/templates/{codeyam-debug.md → skills/codeyam-debug/SKILL.md} +0 -0
  858. /package/codeyam-cli/templates/{codeyam-setup.md → skills/codeyam-setup/SKILL.md} +0 -0
  859. /package/codeyam-cli/templates/{codeyam-sim.md → skills/codeyam-sim/SKILL.md} +0 -0
  860. /package/codeyam-cli/templates/{codeyam-test.md → skills/codeyam-test/SKILL.md} +0 -0
  861. /package/codeyam-cli/templates/{codeyam-verify.md → skills/codeyam-verify/SKILL.md} +0 -0
@@ -0,0 +1,647 @@
1
+ import http from 'http';
2
+ import zlib from 'zlib';
3
+ import { injectHealthScript, PREVIEW_HEALTH_SCRIPT, getPreviewHealthReport, resetPreviewHealth, } from "../editorProxy.js";
4
+ describe('editorProxy', () => {
5
+ describe('normalizeTargetUrl', () => {
6
+ it('should leave localhost as-is (no longer normalizes to 127.0.0.1)', () => {
7
+ const { normalizeTargetUrl } = require('../editorProxy');
8
+ expect(normalizeTargetUrl('http://localhost:3112')).toBe('http://localhost:3112');
9
+ });
10
+ it('should leave 127.0.0.1 unchanged', () => {
11
+ const { normalizeTargetUrl } = require('../editorProxy');
12
+ expect(normalizeTargetUrl('http://127.0.0.1:3112')).toBe('http://127.0.0.1:3112');
13
+ });
14
+ it('should leave other hostnames unchanged', () => {
15
+ const { normalizeTargetUrl } = require('../editorProxy');
16
+ expect(normalizeTargetUrl('http://myhost:3112')).toBe('http://myhost:3112');
17
+ });
18
+ it('should strip trailing slash', () => {
19
+ const { normalizeTargetUrl } = require('../editorProxy');
20
+ expect(normalizeTargetUrl('http://localhost:3112/')).toBe('http://localhost:3112');
21
+ });
22
+ });
23
+ describe('resolveLoopbackAddress', () => {
24
+ let server;
25
+ afterEach((done) => {
26
+ if (server?.listening) {
27
+ server.close(done);
28
+ }
29
+ else {
30
+ done();
31
+ }
32
+ });
33
+ it('should resolve to 127.0.0.1 when server binds to IPv4', async () => {
34
+ const { resolveLoopbackAddress } = require('../editorProxy');
35
+ server = http.createServer((_req, res) => res.end('ok'));
36
+ await new Promise((resolve) => server.listen(0, '127.0.0.1', () => resolve()));
37
+ const port = server.address().port;
38
+ const host = await resolveLoopbackAddress(port);
39
+ expect(host).toBe('127.0.0.1');
40
+ });
41
+ it('should resolve to ::1 when server binds to IPv6 only', async () => {
42
+ const { resolveLoopbackAddress } = require('../editorProxy');
43
+ server = http.createServer((_req, res) => res.end('ok'));
44
+ await new Promise((resolve) => server.listen(0, '::1', () => resolve()));
45
+ const port = server.address().port;
46
+ const host = await resolveLoopbackAddress(port);
47
+ expect(host).toBe('::1');
48
+ });
49
+ it('should return null when no server is listening', async () => {
50
+ const { resolveLoopbackAddress } = require('../editorProxy');
51
+ const host = await resolveLoopbackAddress(19876);
52
+ expect(host).toBeNull();
53
+ });
54
+ });
55
+ describe('proxy forwarding uses 127.0.0.1', () => {
56
+ let targetServer;
57
+ let targetPort;
58
+ afterEach((done) => {
59
+ if (targetServer?.listening) {
60
+ targetServer.close(done);
61
+ }
62
+ else {
63
+ done();
64
+ }
65
+ });
66
+ it('should forward requests to target and return correct response', async () => {
67
+ const { startEditorProxy, stopEditorProxy } = require('../editorProxy');
68
+ // Start a target server that returns 200
69
+ targetServer = http.createServer((_req, res) => {
70
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
71
+ res.end('OK from target');
72
+ });
73
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
74
+ targetPort = targetServer.address().port;
75
+ // Start proxy pointing to the target using localhost URL
76
+ const result = await startEditorProxy({
77
+ port: 0, // let OS pick
78
+ targetUrl: `http://localhost:${targetPort}`,
79
+ });
80
+ expect(result).not.toBeNull();
81
+ // Make a request through the proxy
82
+ const response = await fetch(`http://127.0.0.1:${result.port}/`);
83
+ expect(response.status).toBe(200);
84
+ const body = await response.text();
85
+ expect(body).toBe('OK from target');
86
+ await stopEditorProxy();
87
+ });
88
+ it('should log when target returns non-2xx status', async () => {
89
+ const { startEditorProxy, stopEditorProxy } = require('../editorProxy');
90
+ // Start a target that returns 404
91
+ targetServer = http.createServer((_req, res) => {
92
+ res.writeHead(404, { 'Content-Type': 'text/plain' });
93
+ res.end('Not Found');
94
+ });
95
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
96
+ targetPort = targetServer.address().port;
97
+ const warnSpy = jest.spyOn(console, 'warn').mockImplementation();
98
+ const result = await startEditorProxy({
99
+ port: 0,
100
+ targetUrl: `http://localhost:${targetPort}`,
101
+ });
102
+ const response = await fetch(`http://127.0.0.1:${result.port}/test-path`);
103
+ expect(response.status).toBe(404);
104
+ // Verify a warning was logged about the non-2xx response
105
+ expect(warnSpy.mock.calls.some((call) => String(call[0]).includes('[editorProxy]') &&
106
+ String(call[0]).includes('404') &&
107
+ String(call[0]).includes('/test-path'))).toBe(true);
108
+ warnSpy.mockRestore();
109
+ await stopEditorProxy();
110
+ });
111
+ it('should verify forwarding works after start via self-test', async () => {
112
+ const { startEditorProxy, stopEditorProxy, verifyProxyForwarding, } = require('../editorProxy');
113
+ // Start a target that returns 200
114
+ targetServer = http.createServer((_req, res) => {
115
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
116
+ res.end('healthy');
117
+ });
118
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
119
+ targetPort = targetServer.address().port;
120
+ const result = await startEditorProxy({
121
+ port: 0,
122
+ targetUrl: `http://localhost:${targetPort}`,
123
+ });
124
+ const verified = await verifyProxyForwarding();
125
+ expect(verified).toBe(true);
126
+ await stopEditorProxy();
127
+ });
128
+ it('should report verification failure when target is down', async () => {
129
+ const { startEditorProxy, stopEditorProxy, verifyProxyForwarding, } = require('../editorProxy');
130
+ const result = await startEditorProxy({
131
+ port: 0,
132
+ targetUrl: 'http://127.0.0.1:19876',
133
+ });
134
+ const verified = await verifyProxyForwarding();
135
+ expect(verified).toBe(false);
136
+ await stopEditorProxy();
137
+ });
138
+ it('should return false for verification when proxy is not running', async () => {
139
+ const { verifyProxyForwarding, stopEditorProxy, } = require('../editorProxy');
140
+ await stopEditorProxy();
141
+ const verified = await verifyProxyForwarding();
142
+ expect(verified).toBe(false);
143
+ });
144
+ it('should return 502 when target is unreachable', async () => {
145
+ const { startEditorProxy, stopEditorProxy } = require('../editorProxy');
146
+ // Start proxy pointing to a port with nothing listening
147
+ const result = await startEditorProxy({
148
+ port: 0,
149
+ targetUrl: 'http://localhost:19876',
150
+ });
151
+ expect(result).not.toBeNull();
152
+ const response = await fetch(`http://127.0.0.1:${result.port}/`);
153
+ expect(response.status).toBe(502);
154
+ await stopEditorProxy();
155
+ });
156
+ it('should forward requests to an IPv6-only target server', async () => {
157
+ const { startEditorProxy, stopEditorProxy } = require('../editorProxy');
158
+ // Start a target server bound to IPv6 only (::1) — this is what Vite 6 does on macOS
159
+ targetServer = http.createServer((_req, res) => {
160
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
161
+ res.end('OK from IPv6 target');
162
+ });
163
+ await new Promise((resolve) => targetServer.listen(0, '::1', () => resolve()));
164
+ targetPort = targetServer.address().port;
165
+ // Start proxy with a localhost URL (simulating Vite's "Local: http://localhost:PORT")
166
+ const result = await startEditorProxy({
167
+ port: 0,
168
+ targetUrl: `http://localhost:${targetPort}`,
169
+ });
170
+ expect(result).not.toBeNull();
171
+ // The proxy should successfully forward to the IPv6-only target
172
+ const response = await fetch(`http://127.0.0.1:${result.port}/`);
173
+ expect(response.status).toBe(200);
174
+ const body = await response.text();
175
+ expect(body).toBe('OK from IPv6 target');
176
+ await stopEditorProxy();
177
+ });
178
+ });
179
+ describe('injectHealthScript', () => {
180
+ it('should inject before </head> when present', () => {
181
+ const html = '<html><head><title>Test</title></head><body>Hello</body></html>';
182
+ const result = injectHealthScript(html);
183
+ expect(result).toContain(PREVIEW_HEALTH_SCRIPT + '</head>');
184
+ expect(result).toContain('<title>Test</title>');
185
+ });
186
+ it('should inject before </body> when no </head>', () => {
187
+ const html = '<html><body>Hello</body></html>';
188
+ const result = injectHealthScript(html);
189
+ expect(result).toContain(PREVIEW_HEALTH_SCRIPT + '</body>');
190
+ });
191
+ it('should append when no </head> or </body>', () => {
192
+ const html = '<div>Hello</div>';
193
+ const result = injectHealthScript(html);
194
+ expect(result).toBe('<div>Hello</div>' + PREVIEW_HEALTH_SCRIPT);
195
+ });
196
+ it('should include the data-codeyam-health attribute', () => {
197
+ const html = '<html><head></head><body></body></html>';
198
+ const result = injectHealthScript(html);
199
+ expect(result).toContain('data-codeyam-health');
200
+ });
201
+ it('should use 100ms settle delay for network-idle detection', () => {
202
+ // The settle delay determines how long after all fetch() calls complete
203
+ // before the preview is shown. 100ms is enough for React to re-render.
204
+ expect(PREVIEW_HEALTH_SCRIPT).toContain('}, 100)');
205
+ });
206
+ it('should use 200ms fallback for static pages with no fetches', () => {
207
+ expect(PREVIEW_HEALTH_SCRIPT).toContain('}, 200)');
208
+ });
209
+ });
210
+ describe('preview health endpoint', () => {
211
+ let targetServer;
212
+ let targetPort;
213
+ afterEach(async () => {
214
+ const { stopEditorProxy } = require('../editorProxy');
215
+ await stopEditorProxy();
216
+ if (targetServer?.listening) {
217
+ await new Promise((resolve) => targetServer.close(() => resolve()));
218
+ }
219
+ resetPreviewHealth();
220
+ });
221
+ it('should intercept POST /__codeyam__/preview-health and store errors', async () => {
222
+ const { startEditorProxy } = require('../editorProxy');
223
+ // Start a target that returns 200
224
+ targetServer = http.createServer((_req, res) => {
225
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
226
+ res.end('ok');
227
+ });
228
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
229
+ targetPort = targetServer.address().port;
230
+ const result = await startEditorProxy({
231
+ port: 0,
232
+ targetUrl: `http://localhost:${targetPort}`,
233
+ });
234
+ expect(result).not.toBeNull();
235
+ // Post error data to the health endpoint
236
+ const response = await fetch(`http://127.0.0.1:${result.port}/__codeyam__/preview-health`, {
237
+ method: 'POST',
238
+ headers: { 'Content-Type': 'application/json' },
239
+ body: JSON.stringify({
240
+ errors: [
241
+ {
242
+ type: 'error',
243
+ message: 'Cannot read properties of undefined',
244
+ timestamp: 1710000000,
245
+ },
246
+ ],
247
+ url: 'http://localhost:3112/',
248
+ }),
249
+ });
250
+ expect(response.status).toBe(204);
251
+ // Check the stored health data
252
+ const health = getPreviewHealthReport();
253
+ expect(health).not.toBeNull();
254
+ expect(health.errors).toHaveLength(1);
255
+ expect(health.errors[0].message).toBe('Cannot read properties of undefined');
256
+ expect(health.url).toBe('http://localhost:3112/');
257
+ });
258
+ it('should store loaded/hasContent from load report', async () => {
259
+ const { startEditorProxy } = require('../editorProxy');
260
+ targetServer = http.createServer((_req, res) => {
261
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
262
+ res.end('ok');
263
+ });
264
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
265
+ targetPort = targetServer.address().port;
266
+ const result = await startEditorProxy({
267
+ port: 0,
268
+ targetUrl: `http://localhost:${targetPort}`,
269
+ });
270
+ // Post load report
271
+ await fetch(`http://127.0.0.1:${result.port}/__codeyam__/preview-health`, {
272
+ method: 'POST',
273
+ headers: { 'Content-Type': 'application/json' },
274
+ body: JSON.stringify({
275
+ loaded: true,
276
+ hasContent: true,
277
+ url: 'http://localhost:3112/',
278
+ errorCount: 0,
279
+ }),
280
+ });
281
+ const health = getPreviewHealthReport();
282
+ expect(health).not.toBeNull();
283
+ expect(health.loaded).toBe(true);
284
+ expect(health.hasContent).toBe(true);
285
+ });
286
+ it('should inject health script into HTML responses', async () => {
287
+ const { startEditorProxy } = require('../editorProxy');
288
+ // Target that returns HTML
289
+ targetServer = http.createServer((_req, res) => {
290
+ res.writeHead(200, { 'Content-Type': 'text/html' });
291
+ res.end('<html><head><title>App</title></head><body><div>Hello</div></body></html>');
292
+ });
293
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
294
+ targetPort = targetServer.address().port;
295
+ const result = await startEditorProxy({
296
+ port: 0,
297
+ targetUrl: `http://localhost:${targetPort}`,
298
+ });
299
+ const response = await fetch(`http://127.0.0.1:${result.port}/`);
300
+ const body = await response.text();
301
+ expect(body).toContain('data-codeyam-health');
302
+ expect(body).toContain('/__codeyam__/preview-health');
303
+ expect(body).toContain('<title>App</title>');
304
+ expect(body).toContain('<div>Hello</div>');
305
+ });
306
+ it('should NOT inject health script into non-HTML responses', async () => {
307
+ const { startEditorProxy } = require('../editorProxy');
308
+ targetServer = http.createServer((_req, res) => {
309
+ res.writeHead(200, { 'Content-Type': 'application/json' });
310
+ res.end('{"data": "test"}');
311
+ });
312
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
313
+ targetPort = targetServer.address().port;
314
+ const result = await startEditorProxy({
315
+ port: 0,
316
+ targetUrl: `http://localhost:${targetPort}`,
317
+ });
318
+ const response = await fetch(`http://127.0.0.1:${result.port}/api/data`);
319
+ const body = await response.text();
320
+ expect(body).toBe('{"data": "test"}');
321
+ expect(body).not.toContain('data-codeyam-health');
322
+ });
323
+ it('should accumulate errors across multiple health reports', async () => {
324
+ const { startEditorProxy } = require('../editorProxy');
325
+ targetServer = http.createServer((_req, res) => {
326
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
327
+ res.end('ok');
328
+ });
329
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
330
+ targetPort = targetServer.address().port;
331
+ const result = await startEditorProxy({
332
+ port: 0,
333
+ targetUrl: `http://localhost:${targetPort}`,
334
+ });
335
+ // First error report
336
+ await fetch(`http://127.0.0.1:${result.port}/__codeyam__/preview-health`, {
337
+ method: 'POST',
338
+ headers: { 'Content-Type': 'application/json' },
339
+ body: JSON.stringify({
340
+ errors: [{ type: 'error', message: 'Error 1', timestamp: 1 }],
341
+ url: 'http://localhost:3112/',
342
+ }),
343
+ });
344
+ // Second error report
345
+ await fetch(`http://127.0.0.1:${result.port}/__codeyam__/preview-health`, {
346
+ method: 'POST',
347
+ headers: { 'Content-Type': 'application/json' },
348
+ body: JSON.stringify({
349
+ errors: [
350
+ { type: 'console.error', message: 'Error 2', timestamp: 2 },
351
+ ],
352
+ url: 'http://localhost:3112/',
353
+ }),
354
+ });
355
+ const health = getPreviewHealthReport();
356
+ expect(health).not.toBeNull();
357
+ expect(health.errors).toHaveLength(2);
358
+ expect(health.errors[0].message).toBe('Error 1');
359
+ expect(health.errors[1].message).toBe('Error 2');
360
+ });
361
+ });
362
+ describe('buildLocalStorageScript', () => {
363
+ it('should clean up previous keys when no localStorage config but scenarioId is present', () => {
364
+ const { buildLocalStorageScript } = require('../editorProxy');
365
+ // When switching to a scenario WITHOUT localStorage from one that HAD it,
366
+ // the script must clean up the previous scenario's keys so stale filters
367
+ // don't persist and hide data.
368
+ const script = buildLocalStorageScript(null, 'scenario-123');
369
+ expect(script).toContain('__codeyam_ls_keys__');
370
+ expect(script).toContain('removeItem');
371
+ expect(script).toContain('clear:scenario-123');
372
+ });
373
+ it('should return empty string when no localStorage config and no scenarioId', () => {
374
+ const { buildLocalStorageScript } = require('../editorProxy');
375
+ expect(buildLocalStorageScript(null, '')).toBe('');
376
+ expect(buildLocalStorageScript(undefined, '')).toBe('');
377
+ });
378
+ it('should emit cleanup script when localStorage config is empty object', () => {
379
+ // BUG FIX: When switching from a scenario with localStorage data to one
380
+ // with empty localStorage (e.g. "First Launch - Welcome"), we must still
381
+ // clean up the previous scenario's keys. Otherwise the app reads stale data.
382
+ const { buildLocalStorageScript } = require('../editorProxy');
383
+ const script = buildLocalStorageScript({}, 'scenario-123');
384
+ expect(script).not.toBe('');
385
+ // Should clean up previous keys
386
+ expect(script).toContain('localStorage.removeItem');
387
+ expect(script).toContain('__codeyam_ls_keys__');
388
+ expect(script).toContain('__codeyam_ls_sid__');
389
+ // Should NOT set any new keys (empty config)
390
+ expect(script).not.toContain('localStorage.setItem(\"margo');
391
+ });
392
+ it('should generate a script that sets localStorage entries', () => {
393
+ const { buildLocalStorageScript } = require('../editorProxy');
394
+ const config = {
395
+ margo_articles: [{ id: 'a1', title: 'Test Article' }],
396
+ margo_collections: [{ id: 'c1', name: 'Test Collection' }],
397
+ };
398
+ const script = buildLocalStorageScript(config, 'scenario-abc');
399
+ // Should be wrapped in a script tag
400
+ expect(script).toMatch(/^<script data-codeyam-ls>/);
401
+ expect(script).toMatch(/<\/script>$/);
402
+ // Should gate on scenario ID to avoid re-seeding on reload
403
+ expect(script).toContain('scenario-abc');
404
+ expect(script).toContain('__codeyam_ls_sid__');
405
+ // Should set the localStorage entries
406
+ expect(script).toContain('margo_articles');
407
+ expect(script).toContain('margo_collections');
408
+ expect(script).toContain('localStorage.setItem');
409
+ // Should track which keys were set for cleanup
410
+ expect(script).toContain('__codeyam_ls_keys__');
411
+ });
412
+ it('should emit gated localStorage.clear() when prototypeId is provided and config is null', () => {
413
+ const { buildLocalStorageScript } = require('../editorProxy');
414
+ const script = buildLocalStorageScript(null, 'scenario-123', 'proto-abc');
415
+ // Should not be empty — prototypeId triggers a clear script
416
+ expect(script).not.toBe('');
417
+ expect(script).toContain('localStorage.clear()');
418
+ // Should be gated by the __codeyam_proto__ marker
419
+ expect(script).toContain('__codeyam_proto__');
420
+ expect(script).toContain('proto-abc');
421
+ });
422
+ it('should clean up previous keys when prototypeId is absent but scenarioId is present', () => {
423
+ const { buildLocalStorageScript } = require('../editorProxy');
424
+ // No prototypeId but scenarioId — cleanup previous scenario's keys
425
+ const script1 = buildLocalStorageScript(null, 'scenario-123');
426
+ expect(script1).toContain('removeItem');
427
+ const script2 = buildLocalStorageScript(null, 'scenario-123', null);
428
+ expect(script2).toContain('removeItem');
429
+ });
430
+ it('should clean up keys from previous scenario before setting new ones', () => {
431
+ const { buildLocalStorageScript } = require('../editorProxy');
432
+ const config = { my_key: 'my_value' };
433
+ const script = buildLocalStorageScript(config, 'scenario-xyz');
434
+ // Should read previous keys and remove them
435
+ expect(script).toContain('__codeyam_ls_keys__');
436
+ expect(script).toContain('localStorage.removeItem');
437
+ });
438
+ it('should JSON.stringify non-string values', () => {
439
+ const { buildLocalStorageScript } = require('../editorProxy');
440
+ const config = {
441
+ string_key: 'plain string',
442
+ object_key: { nested: true },
443
+ array_key: [1, 2, 3],
444
+ };
445
+ const script = buildLocalStorageScript(config, 'scenario-1');
446
+ // Object/array values should be JSON-stringified and embedded as JS string literals.
447
+ // JSON.stringify is applied twice: once to serialize the value, once to make it a safe JS string.
448
+ // So {"nested":true} becomes "{\"nested\":true}" in the script source.
449
+ expect(script).toContain('object_key');
450
+ expect(script).toContain('nested');
451
+ expect(script).toContain('array_key');
452
+ expect(script).toContain('[1,2,3]');
453
+ });
454
+ it('should include localStorage mutation watcher that sends postMessage on changes', () => {
455
+ const { buildLocalStorageScript } = require('../editorProxy');
456
+ const config = { my_key: 'my_value' };
457
+ const script = buildLocalStorageScript(config, 'scenario-1');
458
+ // Should hook setItem, removeItem, and clear
459
+ expect(script).toContain('__codeyam_orig_setItem__');
460
+ expect(script).toContain('__codeyam_orig_removeItem__');
461
+ expect(script).toContain('__codeyam_orig_clear__');
462
+ // Should send postMessage to parent
463
+ expect(script).toContain('codeyam-localstorage-changed');
464
+ expect(script).toContain('postMessage');
465
+ // Should filter out internal codeyam keys
466
+ expect(script).toContain('__codeyam_');
467
+ });
468
+ it('should include localStorage mutation watcher even for empty localStorage config', () => {
469
+ const { buildLocalStorageScript } = require('../editorProxy');
470
+ const script = buildLocalStorageScript({}, 'scenario-1');
471
+ // Empty config still needs the watcher since the app may write to localStorage
472
+ expect(script).toContain('codeyam-localstorage-changed');
473
+ });
474
+ it('should include a listener for codeyam-get-localstorage requests', () => {
475
+ const { buildLocalStorageScript } = require('../editorProxy');
476
+ const config = { my_key: 'my_value' };
477
+ const script = buildLocalStorageScript(config, 'scenario-1');
478
+ // Should listen for get-localstorage requests from parent
479
+ expect(script).toContain('codeyam-get-localstorage');
480
+ expect(script).toContain('codeyam-localstorage-state');
481
+ });
482
+ it('should not include mutation watcher when no localStorage config and no scenarioId', () => {
483
+ const { buildLocalStorageScript } = require('../editorProxy');
484
+ // No config AND no scenarioId — returns empty string
485
+ expect(buildLocalStorageScript(null, '')).toBe('');
486
+ });
487
+ it('should re-seed localStorage when scenario data changes even if ID is the same', () => {
488
+ // BUG: When a scenario is re-registered with updated data (e.g., adding
489
+ // collections to articles), the scenario ID stays the same. The guard
490
+ // checked only the ID, so the browser skipped re-seeding and showed stale
491
+ // data. The screenshot (captured by Playwright with a fresh browser)
492
+ // showed the new data, but the live preview didn't.
493
+ const { buildLocalStorageScript } = require('../editorProxy');
494
+ const originalData = {
495
+ articles: '[{"id":"a1","title":"Test"}]',
496
+ };
497
+ const updatedData = {
498
+ articles: '[{"id":"a1","title":"Test","collectionIds":["c1"]}]',
499
+ collections: '[{"id":"c1","name":"Dev"}]',
500
+ };
501
+ const script1 = buildLocalStorageScript(originalData, 'scenario-abc');
502
+ const script2 = buildLocalStorageScript(updatedData, 'scenario-abc');
503
+ // Both scripts use the same scenario ID
504
+ expect(script1).toContain('scenario-abc');
505
+ expect(script2).toContain('scenario-abc');
506
+ // The guard values must be DIFFERENT so the browser re-seeds
507
+ // Extract the guard comparison value from each script
508
+ const guardPattern = /__codeyam_ls_sid__.*?===\s*([^\)]+)\)/;
509
+ const guard1 = script1.match(guardPattern)?.[1];
510
+ const guard2 = script2.match(guardPattern)?.[1];
511
+ expect(guard1).toBeDefined();
512
+ expect(guard2).toBeDefined();
513
+ expect(guard1).not.toEqual(guard2);
514
+ });
515
+ });
516
+ describe('localStorage injection in HTML responses', () => {
517
+ it('should inject localStorage script before health script in HTML', () => {
518
+ const { buildLocalStorageScript, injectHealthScript, } = require('../editorProxy');
519
+ const lsScript = buildLocalStorageScript({ items: [1, 2] }, 'scenario-1');
520
+ // localStorage script should be injected before the health script
521
+ // (needs to run before app loads)
522
+ const html = '<html><head><title>Test</title></head><body>Hello</body></html>';
523
+ const result = injectHealthScript(html, lsScript);
524
+ expect(result).toContain('data-codeyam-ls');
525
+ expect(result).toContain('data-codeyam-health');
526
+ // localStorage script should appear BEFORE health script in the output
527
+ const lsIdx = result.indexOf('data-codeyam-ls');
528
+ const healthIdx = result.indexOf('data-codeyam-health');
529
+ expect(lsIdx).toBeLessThan(healthIdx);
530
+ });
531
+ it('should not inject localStorage script when none provided', () => {
532
+ const html = '<html><head><title>Test</title></head><body>Hello</body></html>';
533
+ const result = injectHealthScript(html);
534
+ expect(result).toContain('data-codeyam-health');
535
+ expect(result).not.toContain('data-codeyam-ls');
536
+ });
537
+ });
538
+ describe('compressed response handling', () => {
539
+ let targetServer;
540
+ let targetPort;
541
+ afterEach(async () => {
542
+ const { stopEditorProxy } = require('../editorProxy');
543
+ await stopEditorProxy();
544
+ if (targetServer?.listening) {
545
+ await new Promise((resolve) => targetServer.close(() => resolve()));
546
+ }
547
+ resetPreviewHealth();
548
+ });
549
+ it('should strip accept-encoding so target returns uncompressed HTML for injection', async () => {
550
+ const { startEditorProxy } = require('../editorProxy');
551
+ const originalHtml = '<html><head><title>Compressed</title></head><body><div>Gzipped</div></body></html>';
552
+ // Target server that compresses only when client sends Accept-Encoding
553
+ // (simulates real dev servers like Next.js/Vite)
554
+ targetServer = http.createServer((req, res) => {
555
+ const acceptEncoding = req.headers['accept-encoding'] || '';
556
+ if (acceptEncoding.includes('gzip')) {
557
+ const compressed = zlib.gzipSync(Buffer.from(originalHtml));
558
+ res.writeHead(200, {
559
+ 'Content-Type': 'text/html',
560
+ 'Content-Encoding': 'gzip',
561
+ 'Content-Length': compressed.length,
562
+ });
563
+ res.end(compressed);
564
+ }
565
+ else {
566
+ res.writeHead(200, { 'Content-Type': 'text/html' });
567
+ res.end(originalHtml);
568
+ }
569
+ });
570
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
571
+ targetPort = targetServer.address().port;
572
+ const result = await startEditorProxy({
573
+ port: 0,
574
+ targetUrl: `http://localhost:${targetPort}`,
575
+ });
576
+ expect(result).not.toBeNull();
577
+ // Request through proxy WITH Accept-Encoding (simulating a real browser)
578
+ const response = await fetch(`http://127.0.0.1:${result.port}/`, {
579
+ headers: { 'Accept-Encoding': 'gzip, deflate, br' },
580
+ });
581
+ // The proxy should return a valid, readable response
582
+ expect(response.status).toBe(200);
583
+ const body = await response.text();
584
+ // Should contain the original HTML content (not corrupted binary)
585
+ expect(body).toContain('<title>Compressed</title>');
586
+ expect(body).toContain('<div>Gzipped</div>');
587
+ // Should have injected the health script
588
+ expect(body).toContain('data-codeyam-health');
589
+ // Should NOT have Content-Encoding since the proxy serves uncompressed
590
+ expect(response.headers.get('content-encoding')).toBeNull();
591
+ });
592
+ });
593
+ describe('Cache-Control on HTML responses', () => {
594
+ let targetServer;
595
+ let targetPort;
596
+ afterEach(async () => {
597
+ const { stopEditorProxy } = require('../editorProxy');
598
+ await stopEditorProxy();
599
+ if (targetServer?.listening) {
600
+ await new Promise((resolve) => targetServer.close(() => resolve()));
601
+ }
602
+ resetPreviewHealth();
603
+ });
604
+ it('should add Cache-Control: no-store to proxied HTML responses', async () => {
605
+ const { startEditorProxy } = require('../editorProxy');
606
+ // Target server that serves plain HTML without cache headers
607
+ targetServer = http.createServer((_req, res) => {
608
+ res.writeHead(200, { 'Content-Type': 'text/html' });
609
+ res.end('<html><head><title>Test</title></head><body>Hello</body></html>');
610
+ });
611
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
612
+ targetPort = targetServer.address().port;
613
+ const result = await startEditorProxy({
614
+ port: 0,
615
+ targetUrl: `http://localhost:${targetPort}`,
616
+ });
617
+ expect(result).not.toBeNull();
618
+ const response = await fetch(`http://127.0.0.1:${result.port}/`);
619
+ expect(response.status).toBe(200);
620
+ // Proxy must set no-store so the browser doesn't cache pages between
621
+ // scenario switches (application scenarios share the same proxy URL
622
+ // but differ in seed data).
623
+ expect(response.headers.get('cache-control')).toBe('no-store, must-revalidate');
624
+ });
625
+ it('should NOT add Cache-Control: no-store to non-HTML responses', async () => {
626
+ const { startEditorProxy } = require('../editorProxy');
627
+ // Target server that serves JSON without cache headers
628
+ targetServer = http.createServer((_req, res) => {
629
+ res.writeHead(200, { 'Content-Type': 'application/json' });
630
+ res.end(JSON.stringify({ ok: true }));
631
+ });
632
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
633
+ targetPort = targetServer.address().port;
634
+ const result = await startEditorProxy({
635
+ port: 0,
636
+ targetUrl: `http://localhost:${targetPort}`,
637
+ });
638
+ expect(result).not.toBeNull();
639
+ const response = await fetch(`http://127.0.0.1:${result.port}/api/data`);
640
+ expect(response.status).toBe(200);
641
+ // Non-HTML responses pass through the target's original headers;
642
+ // the proxy only forces no-store on HTML.
643
+ expect(response.headers.get('cache-control')).toBeNull();
644
+ });
645
+ });
646
+ });
647
+ //# sourceMappingURL=editorProxy.test.js.map