@codeyam/codeyam-cli 0.1.0-staging.483fdc2 → 0.1.0-staging.57cd50f

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 (822) hide show
  1. package/analyzer-template/.build-info.json +7 -7
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +24 -24
  4. package/analyzer-template/packages/ai/index.ts +1 -0
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +23 -1
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
  8. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  9. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +101 -0
  10. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +6 -0
  12. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +588 -13
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  15. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +11 -2
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +2 -2
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +20 -1
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +84 -19
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  23. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
  24. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
  25. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +124 -7
  26. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +101 -2
  27. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +359 -142
  28. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
  29. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  30. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  31. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
  32. package/analyzer-template/packages/analyze/index.ts +2 -0
  33. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +19 -7
  34. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  35. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  36. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +69 -3
  37. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +13 -0
  38. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  39. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  40. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  41. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +4 -0
  42. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +59 -26
  43. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +277 -15
  44. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  45. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +395 -61
  46. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  47. package/analyzer-template/packages/aws/package.json +10 -10
  48. package/analyzer-template/packages/database/index.ts +1 -0
  49. package/analyzer-template/packages/database/package.json +4 -4
  50. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  51. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  52. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  53. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  54. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  55. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  56. package/analyzer-template/packages/database/src/lib/kysely/db.ts +14 -0
  57. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  58. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +82 -0
  59. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  60. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  61. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  62. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  63. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  64. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  65. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +151 -135
  66. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  67. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  68. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  69. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  70. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  71. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  72. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  73. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  74. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  75. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  76. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  77. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  78. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  79. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  80. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  81. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  82. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  83. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  85. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  86. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  87. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  88. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  89. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +8 -0
  90. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  91. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  92. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +24 -0
  93. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  94. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
  95. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  96. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  97. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  98. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  99. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  100. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  101. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  102. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  103. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  104. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  105. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  106. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  107. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  108. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  109. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  110. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  111. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  112. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  113. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  114. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  115. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +100 -89
  116. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  117. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  118. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  119. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  120. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  121. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  122. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  123. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  124. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  125. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  126. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  127. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  128. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  129. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  130. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  131. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  132. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  133. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  134. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  135. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  136. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  137. package/analyzer-template/packages/github/package.json +1 -1
  138. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  139. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  140. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  141. package/analyzer-template/packages/ui-components/package.json +1 -1
  142. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  143. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  144. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  145. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  146. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  147. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  148. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  149. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  150. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  151. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  152. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  153. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  154. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  155. package/analyzer-template/project/constructMockCode.ts +206 -51
  156. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  157. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  158. package/analyzer-template/project/start.ts +3 -0
  159. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  160. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  161. package/analyzer-template/project/writeMockDataTsx.ts +136 -17
  162. package/analyzer-template/project/writeScenarioComponents.ts +170 -29
  163. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  164. package/analyzer-template/tsconfig.json +13 -1
  165. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  166. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  167. package/background/src/lib/virtualized/project/constructMockCode.js +175 -42
  168. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  169. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  170. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  171. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  172. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  173. package/background/src/lib/virtualized/project/start.js +2 -0
  174. package/background/src/lib/virtualized/project/start.js.map +1 -1
  175. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  176. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  177. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  178. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  179. package/background/src/lib/virtualized/project/writeMockDataTsx.js +114 -13
  180. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  181. package/background/src/lib/virtualized/project/writeScenarioComponents.js +143 -27
  182. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  183. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  184. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  185. package/codeyam-cli/scripts/apply-setup.js +252 -21
  186. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  187. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  188. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  189. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  190. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  191. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  192. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  193. package/codeyam-cli/src/cli.js +33 -24
  194. package/codeyam-cli/src/cli.js.map +1 -1
  195. package/codeyam-cli/src/codeyam-cli.js +18 -2
  196. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  197. package/codeyam-cli/src/commands/analyze.js +21 -9
  198. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  199. package/codeyam-cli/src/commands/baseline.js +2 -0
  200. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  201. package/codeyam-cli/src/commands/debug.js +2 -0
  202. package/codeyam-cli/src/commands/debug.js.map +1 -1
  203. package/codeyam-cli/src/commands/default.js +44 -21
  204. package/codeyam-cli/src/commands/default.js.map +1 -1
  205. package/codeyam-cli/src/commands/editor.js +2868 -0
  206. package/codeyam-cli/src/commands/editor.js.map +1 -0
  207. package/codeyam-cli/src/commands/init.js +81 -260
  208. package/codeyam-cli/src/commands/init.js.map +1 -1
  209. package/codeyam-cli/src/commands/memory.js +97 -92
  210. package/codeyam-cli/src/commands/memory.js.map +1 -1
  211. package/codeyam-cli/src/commands/recapture.js +2 -0
  212. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  213. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  214. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  215. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  216. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  217. package/codeyam-cli/src/commands/test-startup.js +2 -0
  218. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  219. package/codeyam-cli/src/commands/verify.js +14 -2
  220. package/codeyam-cli/src/commands/verify.js.map +1 -1
  221. package/codeyam-cli/src/data/techStacks.js +77 -0
  222. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  223. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  224. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  225. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  226. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  227. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
  228. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  229. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +635 -0
  230. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  231. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  232. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  233. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  234. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  235. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  236. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  237. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  238. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  239. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  240. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  241. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  242. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  243. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  244. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  245. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  246. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  247. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +266 -0
  248. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  249. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  250. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  251. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  252. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  253. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  254. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  255. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +275 -0
  256. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  257. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  258. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  259. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  260. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  261. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  262. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  263. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  264. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  265. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  266. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  267. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +101 -0
  268. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  269. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  270. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  271. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  272. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  273. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  274. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  275. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  276. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  277. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +246 -0
  278. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  279. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +174 -86
  280. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  281. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  282. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  283. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  284. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  285. package/codeyam-cli/src/utils/analyzer.js +7 -0
  286. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  287. package/codeyam-cli/src/utils/backgroundServer.js +198 -29
  288. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  289. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  290. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  291. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  292. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  293. package/codeyam-cli/src/utils/devServerState.js +71 -0
  294. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  295. package/codeyam-cli/src/utils/editorApi.js +73 -0
  296. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  297. package/codeyam-cli/src/utils/editorAudit.js +159 -0
  298. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  299. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  300. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  301. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  302. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  303. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  304. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  305. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  306. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  307. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  308. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  309. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  310. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  311. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  312. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  313. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  314. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  315. package/codeyam-cli/src/utils/editorPreview.js +106 -0
  316. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  317. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  318. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  319. package/codeyam-cli/src/utils/editorScenarios.js +126 -0
  320. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  321. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  322. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  323. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  324. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  325. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  326. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  327. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  328. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  329. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  330. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  331. package/codeyam-cli/src/utils/generateReport.js +2 -2
  332. package/codeyam-cli/src/utils/git.js +103 -0
  333. package/codeyam-cli/src/utils/git.js.map +1 -1
  334. package/codeyam-cli/src/utils/install-skills.js +101 -56
  335. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  336. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  337. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  338. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  339. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  340. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  341. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  342. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  343. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  344. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  345. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  346. package/codeyam-cli/src/utils/progress.js +7 -0
  347. package/codeyam-cli/src/utils/progress.js.map +1 -1
  348. package/codeyam-cli/src/utils/project.js +15 -5
  349. package/codeyam-cli/src/utils/project.js.map +1 -1
  350. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  351. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  352. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  353. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  354. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  355. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  356. package/codeyam-cli/src/utils/queue/job.js +74 -1
  357. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  358. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  359. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  360. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  361. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  362. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  363. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  364. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  365. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  366. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  367. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  368. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  369. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  370. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  371. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  372. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  373. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  374. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  375. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  376. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  377. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  378. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  379. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  380. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  381. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  382. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  383. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  384. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  385. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  386. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  387. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  388. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  389. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  390. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  391. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  392. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  393. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  394. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  395. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  396. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  397. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  398. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  399. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  400. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  401. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  402. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  403. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  404. package/codeyam-cli/src/utils/rules/index.js +2 -0
  405. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  406. package/codeyam-cli/src/utils/rules/parser.js +16 -29
  407. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  408. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  409. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  410. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  411. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  412. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  413. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  414. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  415. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  416. package/codeyam-cli/src/utils/rules/staleness.js +16 -11
  417. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
  418. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  419. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  420. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  421. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  422. package/codeyam-cli/src/utils/scenariosManifest.js +112 -0
  423. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  424. package/codeyam-cli/src/utils/serverState.js +94 -12
  425. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  426. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +95 -47
  427. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  428. package/codeyam-cli/src/utils/simulationGateMiddleware.js +159 -0
  429. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  430. package/codeyam-cli/src/utils/syncMocksMiddleware.js +5 -24
  431. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  432. package/codeyam-cli/src/utils/testRunner.js +158 -0
  433. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  434. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  435. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  436. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  437. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  438. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  439. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  440. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +31 -0
  441. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  442. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  443. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  444. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +487 -0
  445. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  446. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  447. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  448. package/codeyam-cli/src/webserver/app/lib/database.js +56 -30
  449. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  450. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  451. package/codeyam-cli/src/webserver/app/lib/git.js +396 -0
  452. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  453. package/codeyam-cli/src/webserver/backgroundServer.js +166 -16
  454. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  455. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  456. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  457. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-BPXZwM4t.js +1 -0
  458. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-BcgbViKV.js} +3 -3
  459. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-g3saevPb.js} +1 -1
  460. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-CQIG2qda.js} +9 -9
  461. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  462. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-aht4aafF.js → InteractivePreview-DYFW3lDD.js} +3 -3
  463. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  464. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BU_OAEMP.js} +1 -1
  465. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-ceAyBX-H.js} +1 -1
  466. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-BzHcG7SE.js} +5 -10
  467. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-BED4B6sP.js} +1 -1
  468. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-0DY_NKil.js} +3 -3
  469. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  470. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  471. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  472. package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-DLxKhri3.js} +3 -3
  473. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-BcY3q6nt.js} +10 -15
  474. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  475. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  476. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  477. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  478. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bni3iiUj.js +22 -0
  479. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  480. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  481. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  482. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  483. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  484. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  485. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  486. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  487. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  488. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  489. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  490. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  491. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  492. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  493. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  494. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  495. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  496. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  497. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  498. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  499. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  500. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  501. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  502. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  503. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  504. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  505. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  506. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  507. package/codeyam-cli/src/webserver/build/client/assets/book-open-BYOypzCa.js +6 -0
  508. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-C_Pmso5S.js} +2 -2
  509. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-C4pqxYJB.js} +12 -12
  510. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-BVMi9VA5.js} +2 -2
  511. package/codeyam-cli/src/webserver/build/client/assets/copy-n2FB0_Sw.js +11 -0
  512. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  513. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Csi0_PMl.js +1 -0
  514. package/codeyam-cli/src/webserver/build/client/assets/editor-vgc8jrQL.js +10 -0
  515. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-BLQMSKZa.js +41 -0
  516. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BJUiQqZF.js → entity._sha._-BF4oLwaE.js} +12 -12
  517. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-C7YX6r3H.js +6 -0
  518. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CF164ouH.js +6 -0
  519. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  520. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  521. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-DTvKq3TY.js} +1 -1
  522. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-cPo8LiG3.js} +1 -1
  523. package/codeyam-cli/src/webserver/build/client/assets/{files-CJ6lTdTA.js → files-BZrlFE1F.js} +1 -1
  524. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  525. package/codeyam-cli/src/webserver/build/client/assets/globals-BkWJ_UNc.css +1 -0
  526. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-10oVnAAH.js} +1 -1
  527. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-BcvgDzbZ.js} +1 -1
  528. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  529. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  530. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-DaAZ_H2w.js} +2 -2
  531. package/codeyam-cli/src/webserver/build/client/assets/manifest-05e71e0b.js +1 -0
  532. package/codeyam-cli/src/webserver/build/client/assets/memory-Bl2rpw8u.js +96 -0
  533. package/codeyam-cli/src/webserver/build/client/assets/pause-f5-1lKBt.js +11 -0
  534. package/codeyam-cli/src/webserver/build/client/assets/root-ClvYBUSA.js +67 -0
  535. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-Di64LWVb.js} +2 -2
  536. package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +1 -0
  537. package/codeyam-cli/src/webserver/build/client/assets/{simulations-DwFIBT09.js → simulations-DWT-CvLy.js} +1 -1
  538. package/codeyam-cli/src/webserver/build/client/assets/terminal-Br7MOqts.js +11 -0
  539. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-BLdiCuG-.js} +2 -2
  540. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-CrAK28Bc.js +1 -0
  541. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  542. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DYxHZQuP.js → useReportContext-O-jkvSPx.js} +1 -1
  543. package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-9FIWuYfK.js} +1 -1
  544. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  545. package/codeyam-cli/src/webserver/build/server/assets/index-B4lc-hKc.js +1 -0
  546. package/codeyam-cli/src/webserver/build/server/assets/server-build-BbkD6mNV.js +426 -0
  547. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  548. package/codeyam-cli/src/webserver/build-info.json +5 -5
  549. package/codeyam-cli/src/webserver/devServer.js +39 -5
  550. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  551. package/codeyam-cli/src/webserver/editorProxy.js +846 -0
  552. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  553. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  554. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  555. package/codeyam-cli/src/webserver/server.js +258 -1
  556. package/codeyam-cli/src/webserver/server.js.map +1 -1
  557. package/codeyam-cli/src/webserver/terminalServer.js +726 -0
  558. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  559. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  560. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  561. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  562. package/codeyam-cli/templates/chrome-extension-react/package.json +26 -0
  563. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  564. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  565. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  566. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  567. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  568. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  569. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  570. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  571. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  572. package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
  573. package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
  574. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  575. package/codeyam-cli/templates/editor-step-hook.py +231 -0
  576. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  577. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  578. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  579. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  580. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  581. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  582. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  583. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  584. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  585. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  586. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  587. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  588. package/codeyam-cli/templates/expo-react-native/package.json +37 -0
  589. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  590. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  591. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  592. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  593. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  594. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  595. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  596. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  597. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  598. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  599. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  600. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  601. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  602. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  603. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  604. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  605. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  606. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  607. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  608. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  609. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  610. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  611. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  612. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +38 -0
  613. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  614. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  615. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  616. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  617. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  618. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  619. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  620. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  621. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  622. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  623. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  624. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  625. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  626. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  627. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  628. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  629. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  630. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  631. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +36 -0
  632. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  633. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  634. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  635. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  636. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  637. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  638. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  639. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  640. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  641. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  642. package/codeyam-cli/templates/rule-reflection-hook.py +574 -88
  643. package/codeyam-cli/templates/rules-instructions.md +45 -93
  644. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
  645. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  646. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +148 -0
  647. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  648. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  649. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  650. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  651. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  652. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  653. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  654. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  655. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  656. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  657. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  658. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  659. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  660. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  661. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  662. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  663. package/package.json +28 -21
  664. package/packages/ai/index.js +1 -1
  665. package/packages/ai/index.js.map +1 -1
  666. package/packages/ai/src/lib/analyzeScope.js +21 -1
  667. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  668. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  669. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  670. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  671. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  672. package/packages/ai/src/lib/astScopes/processExpression.js +78 -1
  673. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  674. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  675. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  676. package/packages/ai/src/lib/completionCall.js +10 -7
  677. package/packages/ai/src/lib/completionCall.js.map +1 -1
  678. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +495 -10
  679. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  680. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  681. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  682. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +11 -2
  683. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  684. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +2 -2
  685. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  686. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  687. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  688. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  689. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  690. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  691. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  692. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +15 -1
  693. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -1
  694. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +78 -17
  695. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  696. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  697. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  698. package/packages/ai/src/lib/dataStructureChunking.js +30 -11
  699. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  700. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  701. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  702. package/packages/ai/src/lib/generateEntityScenarioData.js +89 -5
  703. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  704. package/packages/ai/src/lib/generateExecutionFlows.js +86 -2
  705. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  706. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +242 -81
  707. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  708. package/packages/ai/src/lib/isolateScopes.js +39 -3
  709. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  710. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  711. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  712. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  713. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  714. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  715. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  716. package/packages/analyze/index.js +1 -0
  717. package/packages/analyze/index.js.map +1 -1
  718. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  719. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  720. package/packages/analyze/src/lib/asts/index.js +4 -2
  721. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  722. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  723. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  724. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +52 -2
  725. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  726. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +10 -0
  727. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  728. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  729. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  730. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  731. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  732. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  733. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  734. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +5 -1
  735. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  736. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +51 -14
  737. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  738. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +181 -13
  739. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  740. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  741. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  742. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +328 -49
  743. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  744. package/packages/analyze/src/lib/index.js +1 -0
  745. package/packages/analyze/src/lib/index.js.map +1 -1
  746. package/packages/database/index.js +1 -0
  747. package/packages/database/index.js.map +1 -1
  748. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  749. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  750. package/packages/database/src/lib/analysisToDb.js +1 -1
  751. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  752. package/packages/database/src/lib/branchToDb.js +1 -1
  753. package/packages/database/src/lib/branchToDb.js.map +1 -1
  754. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  755. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  756. package/packages/database/src/lib/commitToDb.js +1 -1
  757. package/packages/database/src/lib/commitToDb.js.map +1 -1
  758. package/packages/database/src/lib/fileToDb.js +1 -1
  759. package/packages/database/src/lib/fileToDb.js.map +1 -1
  760. package/packages/database/src/lib/kysely/db.js +8 -0
  761. package/packages/database/src/lib/kysely/db.js.map +1 -1
  762. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
  763. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  764. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  765. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  766. package/packages/database/src/lib/loadCommits.js +23 -13
  767. package/packages/database/src/lib/loadCommits.js.map +1 -1
  768. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  769. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  770. package/packages/database/src/lib/projectToDb.js +1 -1
  771. package/packages/database/src/lib/projectToDb.js.map +1 -1
  772. package/packages/database/src/lib/saveFiles.js +1 -1
  773. package/packages/database/src/lib/saveFiles.js.map +1 -1
  774. package/packages/database/src/lib/scenarioToDb.js +1 -1
  775. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  776. package/packages/database/src/lib/updateCommitMetadata.js +100 -89
  777. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  778. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  779. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  780. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  781. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  782. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  783. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  784. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  785. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  786. package/packages/types/src/enums/ProjectFramework.js +2 -0
  787. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  788. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  789. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  790. package/scripts/npm-post-install.cjs +34 -0
  791. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  792. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  793. package/codeyam-cli/src/commands/list.js +0 -31
  794. package/codeyam-cli/src/commands/list.js.map +0 -1
  795. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  796. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  797. package/codeyam-cli/src/utils/reviewedRules.js +0 -92
  798. package/codeyam-cli/src/utils/reviewedRules.js.map +0 -1
  799. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  800. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  801. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C8lyxW9k.js +0 -34
  802. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
  803. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
  804. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +0 -1
  805. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js +0 -6
  806. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D1T4TGjf.js +0 -6
  807. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
  808. package/codeyam-cli/src/webserver/build/client/assets/git-CPTZZ-JZ.js +0 -15
  809. package/codeyam-cli/src/webserver/build/client/assets/globals-CX9f-5xM.css +0 -1
  810. package/codeyam-cli/src/webserver/build/client/assets/manifest-bba56ec1.js +0 -1
  811. package/codeyam-cli/src/webserver/build/client/assets/memory-DuTFSyJ2.js +0 -92
  812. package/codeyam-cli/src/webserver/build/client/assets/root-DTfSQARG.js +0 -62
  813. package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
  814. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C1v1PQzo.js +0 -1
  815. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  816. package/codeyam-cli/src/webserver/build/server/assets/index-TD1f-DHV.js +0 -1
  817. package/codeyam-cli/src/webserver/build/server/assets/server-build-BQ-1XyEa.js +0 -258
  818. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  819. package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
  820. package/codeyam-cli/templates/codeyam:memory.md +0 -403
  821. package/codeyam-cli/templates/codeyam:new-rule.md +0 -52
  822. package/scripts/finalize-analyzer.cjs +0 -81
@@ -257,7 +257,8 @@ options) {
257
257
  let dataStructureValue;
258
258
  let foundEntityWithSignature = false;
259
259
  let signatureSchema;
260
- for (const filePath in dependencySchemas) {
260
+ let baseSchemaHasMethodCalls = false;
261
+ entitySearch: for (const filePath in dependencySchemas) {
261
262
  for (const entityName in dependencySchemas[filePath]) {
262
263
  // Match entity by base name (without generics/args)
263
264
  const entityBaseName = entityName.split(/[<(]/)[0];
@@ -281,15 +282,51 @@ options) {
281
282
  pathParts[mockNameParts.length - 1].startsWith(mockNameParts[mockNameParts.length - 1]));
282
283
  });
283
284
  if (dataStructurePath) {
285
+ // Start with the base entity's return value schema
286
+ const baseReturnValueSchema = dependencySchemas[filePath][entityName]?.returnValueSchema;
287
+ const mergedSchema = {
288
+ ...baseReturnValueSchema,
289
+ };
290
+ // Check if the base schema has method-call entries (e.g., .map().functionCallReturnValue)
291
+ // When it does, the scenario data is stored as an object with method keys, and
292
+ // array prototype methods need mock implementations. When it doesn't, the data
293
+ // is a raw array and native methods like .includes() work directly.
294
+ if (baseReturnValueSchema) {
295
+ baseSchemaHasMethodCalls = Object.keys(baseReturnValueSchema).some((k) => k.startsWith(baseMockName + '.') &&
296
+ k.includes('(') &&
297
+ k.includes('.functionCallReturnValue'));
298
+ }
299
+ // Merge in method-call dependencies that are separate entries.
300
+ // e.g., "activityTypes.find((a) => a.value === type)" is a separate dependency
301
+ // for a .find() call on activityTypes. We need to include these with a
302
+ // .functionCallReturnValue path so constructMockCode generates callable mock methods.
303
+ for (const otherEntityName in dependencySchemas[filePath]) {
304
+ if (otherEntityName === entityName)
305
+ continue;
306
+ if (otherEntityName.startsWith(baseMockName + '.') &&
307
+ otherEntityName.includes('(')) {
308
+ // Add a functionCallReturnValue entry for this method call.
309
+ // This ensures constructMockCode treats it as a function that returns data,
310
+ // generating a proper mock method with data lookup.
311
+ const fcrvPath = `${otherEntityName}.functionCallReturnValue`;
312
+ if (!mergedSchema[fcrvPath]) {
313
+ // Infer the return type from the method-call dependency's schema
314
+ const otherSchema = dependencySchemas[filePath][otherEntityName]?.returnValueSchema;
315
+ // Look for element type (baseMockName[]) or fall back to 'unknown'
316
+ const elementType = otherSchema?.[`${baseMockName}[]`];
317
+ mergedSchema[fcrvPath] = elementType || 'unknown';
318
+ }
319
+ }
320
+ }
284
321
  relevantReturnValueSchema = fillInDirectSchemaGapsAndUnknowns({
285
- schema: dependencySchemas[filePath][entityName]?.returnValueSchema,
322
+ schema: mergedSchema,
286
323
  });
287
324
  // NOTE: clearAttributesFromMapping is disabled because it deletes
288
325
  // method calls on arrays (like .eq() after functionCallReturnValue: 'array')
289
326
  // However, we still need to remove duplicate function calls that create invalid syntax
290
327
  removeDuplicateFunctionCalls(relevantReturnValueSchema);
291
328
  dataStructureValue = relevantReturnValueSchema?.[dataStructurePath];
292
- break;
329
+ break entitySearch;
293
330
  }
294
331
  }
295
332
  }
@@ -352,7 +389,10 @@ options) {
352
389
  args.push('...rest');
353
390
  const argsString = args.join(', ');
354
391
  // Generate empty mock function
355
- return `function ${mockName}(${argsString}) {
392
+ // Use baseMockName (not mockName) because mockName may contain a full call
393
+ // signature with argument expressions (e.g., "logSignOutAction(sessionUser.id, ...)")
394
+ // which would produce invalid syntax as function parameter names.
395
+ return `function ${baseMockName}(${argsString}) {
356
396
  // Empty mock - original function mocked out
357
397
  }`;
358
398
  }
@@ -391,12 +431,12 @@ options) {
391
431
  : false;
392
432
  if (firstArgIsFunctionOrUnknown && returnsFunction) {
393
433
  // HOC pattern detected - return the first argument
394
- return `function ${mockName}(${argsString}) {
434
+ return `function ${baseMockName}(${argsString}) {
395
435
  return arg1;
396
436
  }`;
397
437
  }
398
438
  // Generate empty mock function
399
- return `function ${mockName}(${argsString}) {
439
+ return `function ${baseMockName}(${argsString}) {
400
440
  // Empty mock - original function mocked out
401
441
  }`;
402
442
  }
@@ -536,17 +576,23 @@ options) {
536
576
  return [];
537
577
  }
538
578
  const addReturnValueFunctionAccessor = (dataPath) => {
539
- // Add function call accessor if:
540
- // - There are actual arguments, OR
541
- // - This is a callable (not a method that returns an array directly)
542
- // For methods like getAll() that return arrays, the data is at ["getAll()"] not ["getAll()"]["()"]
543
579
  if (returnValue.returnsFunctionArgs &&
544
580
  (returnValue.returnsFunctionArgs.length > 0 ||
545
581
  !returnValue.returnsFunctionArray)) {
546
582
  if (returnValue.isArray) {
547
583
  dataPath = `${dataPath}${optionalAccess('[0]')}`;
548
584
  }
549
- dataPath = `${dataPath}${optionalAccess(`(${safeString(returnValue.returnsFunctionArgs.join(', '))})`)}`;
585
+ // Only add the function call accessor ?.["(args)"] when there are actual
586
+ // arguments. When returnsFunctionArgs is empty [] (function-returns-function
587
+ // with no specific arg patterns), skip the ?.["()"] because:
588
+ // 1. preprocessSchemaForMocks collapses nested functionCallReturnValue chains
589
+ // into flat entries (e.g., getTranslate() = string, not {(): string})
590
+ // 2. The mock data is a flat value, so ?.["()"] on a string returns undefined
591
+ // 3. constructContent still wraps the return in a function (via returnsFunctionArgs)
592
+ // so the function-returns-function behavior is preserved without data nesting
593
+ if (returnValue.returnsFunctionArgs.length > 0) {
594
+ dataPath = `${dataPath}${optionalAccess(`(${safeString(returnValue.returnsFunctionArgs.join(', '))})`)}`;
595
+ }
550
596
  }
551
597
  return dataPath;
552
598
  };
@@ -572,20 +618,6 @@ options) {
572
618
  };
573
619
  const constructContent = (dataPaths) => {
574
620
  const { name, args, nested, isArray, isGenericArray, returnsFunctionArgs, returnsFunctionArray, isAsyncFunction, hasNoReturnData, } = returnValue;
575
- // When an array has differentiated indices ([0], [1], etc.), filter out any
576
- // non-index items from nested. These non-index items come from generic [] paths
577
- // like [].filter or [].sort, which describe element properties, not array elements.
578
- // Including them would generate invalid syntax like "sort: ..." inside an array literal.
579
- const hasDifferentiatedIndices = isArray &&
580
- nested &&
581
- nested.some((n) => n.name.match(/^\[\d+\]$/) && n.name !== '[0]');
582
- const filteredNested = hasDifferentiatedIndices && nested
583
- ? nested.filter((n) => n.name.match(/^\[\d+\]$/))
584
- : nested;
585
- const nestedContent = (filteredNested ?? []).map((nestedItem) => {
586
- const nestedContent = constructReturnValueString(nestedItem, dataPaths);
587
- return nestedContent;
588
- });
589
621
  // Array prototype methods that should be ignored when building mocks
590
622
  // (these work on any array - we don't need to mock them)
591
623
  const ARRAY_PROTOTYPE_METHODS = new Set([
@@ -629,6 +661,36 @@ options) {
629
661
  'with',
630
662
  'length',
631
663
  ]);
664
+ // When an array has differentiated indices ([0], [1], etc.), filter out any
665
+ // non-index items from nested. These non-index items come from generic [] paths
666
+ // like [].filter or [].sort, which describe element properties, not array elements.
667
+ // Including them would generate invalid syntax like "sort: ..." inside an array literal.
668
+ const hasDifferentiatedIndices = isArray &&
669
+ nested &&
670
+ nested.some((n) => n.name.match(/^\[\d+\]$/) && n.name !== '[0]');
671
+ let filteredNested = hasDifferentiatedIndices && nested
672
+ ? nested.filter((n) => n.name.match(/^\[\d+\]$/))
673
+ : nested;
674
+ // When a variable IS an array (not a function returning an array),
675
+ // filter out array prototype methods like .includes(), .filter(), etc.
676
+ // ONLY when the base schema has no method-call entries. When the base
677
+ // schema has methods (e.g., .map().functionCallReturnValue), the scenario
678
+ // data is stored as an object with method-call keys, and ALL methods
679
+ // need mock implementations. When the base schema has no methods, the
680
+ // data is a raw array and native methods like .includes() work directly.
681
+ if (isArray &&
682
+ !returnsFunctionArray &&
683
+ !baseSchemaHasMethodCalls &&
684
+ filteredNested) {
685
+ filteredNested = filteredNested.filter((n) => {
686
+ const methodName = n.name.replace(/[<(].*$/, '');
687
+ return !ARRAY_PROTOTYPE_METHODS.has(methodName);
688
+ });
689
+ }
690
+ const nestedContent = (filteredNested ?? []).map((nestedItem) => {
691
+ const nestedContent = constructReturnValueString(nestedItem, dataPaths);
692
+ return nestedContent;
693
+ });
632
694
  const levelContentItems = [];
633
695
  // Add spread for data paths when:
634
696
  // - Not a function returning an array, OR function returns array with custom methods
@@ -1170,6 +1232,16 @@ options) {
1170
1232
  returnValueContents = `${arrayBasePath}?.map((__item__, __idx__) => (\n${indent(trimmedContent)}\n))`;
1171
1233
  }
1172
1234
  else {
1235
+ // When generating object-wrapped .map(), ensure original item data is preserved.
1236
+ // If no data spread was included (e.g., because this is a plain array property,
1237
+ // not a function return), add ...__item__ to spread the original item properties.
1238
+ // Without this, the .map() would create new objects with only nested function
1239
+ // properties, losing data like filePath, frontmatter, body, etc.
1240
+ const hasDataSpread = mappedContents.includes('...scenarios()') ||
1241
+ mappedContents.includes('...__item__');
1242
+ if (!hasDataSpread) {
1243
+ mappedContents = `...__item__,\n${mappedContents}`;
1244
+ }
1173
1245
  returnValueContents = `${arrayBasePath}?.map((__item__, __idx__) => ({\n${indent(mappedContents)}\n}))`;
1174
1246
  }
1175
1247
  } // Close the empty content check else block
@@ -1231,6 +1303,13 @@ options) {
1231
1303
  mappedContents = filterOutArrowFunctions(mappedContents);
1232
1304
  mappedContents = filterOutBareObjects(mappedContents, true);
1233
1305
  mappedContents = cleanupContent(mappedContents);
1306
+ // Same as needsWrapper branch: ensure item data is preserved in .map()
1307
+ const hasDataSpreadInner = mappedContents.includes('...scenarios()') ||
1308
+ mappedContents.includes('...__item__');
1309
+ if (!hasDataSpreadInner && mappedContents.trim().length > 0) {
1310
+ // Insert ...__item__ after the opening brace
1311
+ mappedContents = mappedContents.replace(/^\s*\{/, '{\n...__item__,');
1312
+ }
1234
1313
  returnValueContents = `${arrayBasePath}?.map((__item__, __idx__) => (\n${indent(mappedContents)}\n))`;
1235
1314
  }
1236
1315
  }
@@ -1343,20 +1422,39 @@ options) {
1343
1422
  content = `${cleanOutTypes(name)}: ${isAsyncFunction ? 'async ' : ''}(${argsString}) => {\n${indent(funcContents)}\n}`;
1344
1423
  }
1345
1424
  else {
1346
- // No argument variants - use existing behavior
1347
- // But if there's nested content, we need to include it in the return object
1348
- // (similar to how argument variant branches handle this at line 1070-1072)
1349
- const hasNestedContent = validNestedContent.length > 0;
1350
- let funcReturnContents;
1351
- if (hasNestedContent && levelContentItems.length > 1) {
1352
- // Include both spread and nested content in the return
1353
- funcReturnContents = `{\n${indent(levelContents)}\n}`;
1425
+ // No argument variants
1426
+ // Check if this is an array method callback containing JSX.
1427
+ // JSX can't be serialized to JSON, so the LLM generates [{}] as data.
1428
+ // Instead of returning that unusable data, generate a passthrough that
1429
+ // calls the real callback on the best available array data from siblings.
1430
+ const containsJsx = dataPaths.some((p) => /<[A-Z]/.test(p));
1431
+ const isArrayMethod = ARRAY_PROTOTYPE_METHODS.has(name);
1432
+ if (containsJsx && isArrayMethod && dataPaths.length > 0) {
1433
+ // Extract parent data path by removing the last ?.["..."] segment
1434
+ const parentPath = dataPaths[0].replace(/\?\.\["[^"]*"\]$/, '');
1435
+ const funcLines = [
1436
+ `const _d = ${parentPath};`,
1437
+ `const _a = Object.values(_d || {}).filter(v => Array.isArray(v) && v.length > 0 && v.some(i => i && typeof i === "object" && Object.keys(i).length > 0)).sort((a, b) => b.length - a.length);`,
1438
+ `return _a[0] ? _a[0].${name}(${argsString}) : []`,
1439
+ ];
1440
+ const funcContents = funcLines.join('\n');
1441
+ content = `${cleanOutTypes(name)}: ${isAsyncFunction ? 'async ' : ''}(${argsString}) => {\n${indent(funcContents)}\n}`;
1354
1442
  }
1355
1443
  else {
1356
- funcReturnContents = returnValueContents;
1444
+ // But if there's nested content, we need to include it in the return object
1445
+ // (similar to how argument variant branches handle this at line 1070-1072)
1446
+ const hasNestedContent = validNestedContent.length > 0;
1447
+ let funcReturnContents;
1448
+ if (hasNestedContent && levelContentItems.length > 1) {
1449
+ // Include both spread and nested content in the return
1450
+ funcReturnContents = `{\n${indent(levelContents)}\n}`;
1451
+ }
1452
+ else {
1453
+ funcReturnContents = returnValueContents;
1454
+ }
1455
+ const funcContents = `return ${funcReturnContents}`;
1456
+ content = `${cleanOutTypes(name)}: ${isAsyncFunction ? 'async ' : ''}(${argsString}) => {\n${indent(funcContents)}\n}`;
1357
1457
  }
1358
- const funcContents = `return ${funcReturnContents}`;
1359
- content = `${cleanOutTypes(name)}: ${isAsyncFunction ? 'async ' : ''}(${argsString}) => {\n${indent(funcContents)}\n}`;
1360
1458
  }
1361
1459
  }
1362
1460
  else {
@@ -1900,6 +1998,20 @@ options) {
1900
1998
  returnValueSection = relevantPart;
1901
1999
  }
1902
2000
  }
2001
+ // Post-processing: When the root functionCallReturnValue is typed as "function" but the
2002
+ // return value also has nested properties (methods like .from(), .auth, etc.), it's actually
2003
+ // an object, not a function to be called. Clear returnsFunctionArgs to prevent double-wrapping
2004
+ // (adding an extra () => { return { ... } } wrapper and ["()"] data paths).
2005
+ // This handles cases like Supabase's createClient() which returns an object with methods.
2006
+ // Only applied to the root level - nested parts that are functions with methods (like
2007
+ // useSearchParams()[1] which is a setter function with .set() and .delete()) should keep
2008
+ // their returnsFunctionArgs since they genuinely ARE functions.
2009
+ if (returnValueParts.returnsFunctionArgs &&
2010
+ returnValueParts.returnsFunctionArgs.length === 0 &&
2011
+ returnValueParts.nested &&
2012
+ returnValueParts.nested.length > 0) {
2013
+ returnValueParts.returnsFunctionArgs = undefined;
2014
+ }
1903
2015
  const contents = constructReturnValueString(returnValueParts);
1904
2016
  if (mockNameParts.length > 1) {
1905
2017
  const originalLib = `${mockNameParts[0]}__cyOriginal`;
@@ -1961,15 +2073,24 @@ options) {
1961
2073
  const nameAssignment = isErrorSubclass
1962
2074
  ? `this.name = '${baseMockName}';`
1963
2075
  : '';
1964
- // Use the safe function name for the class definition
1965
- const className = mockNameIsCallSignature
1966
- ? derivedFunctionName
1967
- : baseMockName;
2076
+ // Use the base class name for the class definition, not the call-signature-derived name.
2077
+ // When mockName is "StatsCalculator(supabase)", baseMockName is "StatsCalculator"
2078
+ // and derivedFunctionName would be "StatsCalculator_supabase" which is wrong.
2079
+ // Classes are instantiated with `new ClassName(args)` so the name must match the original.
2080
+ const className = baseMockName;
2081
+ // Use the already-generated contents (which has proper function wrappers for methods)
2082
+ // instead of raw scenarios().data() which would create non-callable string-keyed properties.
2083
+ // For classes with methods like calculateStats(), the contents will have:
2084
+ // { calculateStats: (...args) => scenarios().data()?.["key"]?.["calculateStats(...)"], ... }
2085
+ // which makes methods callable on the instance.
2086
+ const classContents = enhancedContents.trim().startsWith('{')
2087
+ ? enhancedContents
2088
+ : `scenarios().data()?.${quotePropertyKey(dataKey)} || {}`;
1968
2089
  return `class ${className}${isErrorSubclass ? ' extends Error' : ''} {
1969
2090
  constructor(message) {
1970
2091
  ${superCall}
1971
2092
  ${nameAssignment}
1972
- Object.assign(this, scenarios().data()?.${quotePropertyKey(dataKey)} || {});
2093
+ Object.assign(this, ${classContents});
1973
2094
  }
1974
2095
  }`;
1975
2096
  }
@@ -2047,7 +2168,19 @@ options) {
2047
2168
  const safeReturnValue = isSimpleDataPath
2048
2169
  ? `${returnValue} ?? {}`
2049
2170
  : returnValue;
2050
- return `${isRootAsyncFunction ? 'async ' : ''}function ${safeFunctionName}(...args) {\n${indent(`return ${safeReturnValue};`)}\n}`;
2171
+ const refName = `_${safeFunctionName}Ref`;
2172
+ const assignment = `${refName}.current = ${safeReturnValue};`;
2173
+ const ifBlock = `if (!${refName}.current) {\n${indent(assignment)}\n}`;
2174
+ const body = `${ifBlock}\nreturn ${refName}.current;`;
2175
+ return [
2176
+ `// PATCHED: memoize to return stable reference (prevents infinite useEffect re-triggers)`,
2177
+ `const ${refName} = {`,
2178
+ ` current: null,`,
2179
+ `};`,
2180
+ `${isRootAsyncFunction ? 'async ' : ''}function ${safeFunctionName}(...args) {`,
2181
+ indent(body),
2182
+ `}`,
2183
+ ].join('\n');
2051
2184
  }
2052
2185
  else {
2053
2186
  // Generate safe const name: