@codeyam/codeyam-cli 0.1.0-staging.483fdc2 → 0.1.0-staging.50df560

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 (958) 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/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 +21 -6
  40. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +9 -12
  41. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  42. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +4 -0
  43. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +59 -26
  44. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +277 -15
  45. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  46. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +395 -61
  47. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  48. package/analyzer-template/packages/aws/package.json +10 -10
  49. package/analyzer-template/packages/database/index.ts +1 -0
  50. package/analyzer-template/packages/database/package.json +4 -4
  51. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  52. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  53. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  54. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  55. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  56. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  57. package/analyzer-template/packages/database/src/lib/kysely/db.ts +14 -0
  58. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  59. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +164 -0
  60. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  61. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +19 -15
  62. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  63. package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
  64. package/analyzer-template/packages/database/src/lib/loadEntity.ts +8 -4
  65. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  66. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  67. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  68. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  69. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +94 -143
  70. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  71. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  72. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  73. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  74. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  75. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  76. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  77. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  78. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  79. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  80. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  81. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  82. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  83. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  85. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  86. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  87. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  88. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  89. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  90. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  91. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  92. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  93. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +8 -0
  94. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  95. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  96. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +29 -0
  97. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  98. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  99. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  100. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  101. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  102. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  103. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  104. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  105. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  106. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  107. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +1 -1
  108. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  109. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  110. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  111. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  112. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  113. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
  114. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  115. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.d.ts.map +1 -1
  116. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js +1 -1
  117. package/analyzer-template/packages/github/dist/database/src/lib/loadEntity.js.map +1 -1
  118. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  119. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  120. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  121. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  122. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  123. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  124. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  125. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  126. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  127. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  128. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +76 -90
  129. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  130. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  131. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  132. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  133. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  134. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  135. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  136. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  137. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  138. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  139. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  140. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  141. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  142. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  143. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  144. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  145. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  146. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  147. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  148. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  149. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  150. package/analyzer-template/packages/github/package.json +1 -1
  151. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  152. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  153. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  154. package/analyzer-template/packages/ui-components/package.json +1 -1
  155. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  156. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  157. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  158. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  159. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  160. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  161. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  162. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  163. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  164. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  165. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  166. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  167. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  168. package/analyzer-template/project/analyzeFileEntities.ts +26 -0
  169. package/analyzer-template/project/constructMockCode.ts +206 -51
  170. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  171. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  172. package/analyzer-template/project/start.ts +3 -0
  173. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  174. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  175. package/analyzer-template/project/writeMockDataTsx.ts +136 -17
  176. package/analyzer-template/project/writeScenarioComponents.ts +170 -29
  177. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  178. package/analyzer-template/tsconfig.json +13 -1
  179. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  180. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  181. package/background/src/lib/virtualized/project/analyzeFileEntities.js +22 -0
  182. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  183. package/background/src/lib/virtualized/project/constructMockCode.js +175 -42
  184. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  185. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  186. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  187. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  188. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  189. package/background/src/lib/virtualized/project/start.js +2 -0
  190. package/background/src/lib/virtualized/project/start.js.map +1 -1
  191. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  192. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  193. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  194. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  195. package/background/src/lib/virtualized/project/writeMockDataTsx.js +114 -13
  196. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  197. package/background/src/lib/virtualized/project/writeScenarioComponents.js +143 -27
  198. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  199. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  200. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  201. package/codeyam-cli/scripts/apply-setup.js +252 -21
  202. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  203. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  204. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  205. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  206. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  207. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  208. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  209. package/codeyam-cli/src/cli.js +57 -24
  210. package/codeyam-cli/src/cli.js.map +1 -1
  211. package/codeyam-cli/src/codeyam-cli.js +18 -2
  212. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  213. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js +51 -0
  214. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js.map +1 -0
  215. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +56 -0
  216. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  217. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  218. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  219. package/codeyam-cli/src/commands/analyze.js +21 -9
  220. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  221. package/codeyam-cli/src/commands/baseline.js +2 -0
  222. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  223. package/codeyam-cli/src/commands/debug.js +2 -0
  224. package/codeyam-cli/src/commands/debug.js.map +1 -1
  225. package/codeyam-cli/src/commands/default.js +44 -21
  226. package/codeyam-cli/src/commands/default.js.map +1 -1
  227. package/codeyam-cli/src/commands/editor.js +5080 -0
  228. package/codeyam-cli/src/commands/editor.js.map +1 -0
  229. package/codeyam-cli/src/commands/editorIsolateArgs.js +25 -0
  230. package/codeyam-cli/src/commands/editorIsolateArgs.js.map +1 -0
  231. package/codeyam-cli/src/commands/init.js +148 -292
  232. package/codeyam-cli/src/commands/init.js.map +1 -1
  233. package/codeyam-cli/src/commands/memory.js +97 -92
  234. package/codeyam-cli/src/commands/memory.js.map +1 -1
  235. package/codeyam-cli/src/commands/recapture.js +2 -0
  236. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  237. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  238. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  239. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  240. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  241. package/codeyam-cli/src/commands/telemetry.js +37 -0
  242. package/codeyam-cli/src/commands/telemetry.js.map +1 -0
  243. package/codeyam-cli/src/commands/test-startup.js +2 -0
  244. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  245. package/codeyam-cli/src/commands/verify.js +14 -2
  246. package/codeyam-cli/src/commands/verify.js.map +1 -1
  247. package/codeyam-cli/src/data/techStacks.js +77 -0
  248. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  249. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  250. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  251. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  252. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  253. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  254. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  255. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +137 -0
  256. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  257. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +2952 -0
  258. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  259. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js +76 -0
  260. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js.map +1 -0
  261. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  262. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  263. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js +137 -0
  264. package/codeyam-cli/src/utils/__tests__/editorCaptureScenarioSeeding.test.js.map +1 -0
  265. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js +100 -0
  266. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js.map +1 -0
  267. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  268. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  269. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +194 -0
  270. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  271. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js +381 -0
  272. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js.map +1 -0
  273. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js +67 -0
  274. package/codeyam-cli/src/utils/__tests__/editorGuardMiddleware.test.js.map +1 -0
  275. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  276. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  277. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  278. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  279. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +594 -0
  280. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  281. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js +435 -0
  282. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js.map +1 -0
  283. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  284. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  285. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  286. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  287. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +353 -0
  288. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  289. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  290. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  291. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  292. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  293. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +291 -0
  294. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  295. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1629 -0
  296. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  297. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +280 -0
  298. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  299. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js +143 -0
  300. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js.map +1 -0
  301. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js +66 -0
  302. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js.map +1 -0
  303. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js +53 -0
  304. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js.map +1 -0
  305. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +2089 -0
  306. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  307. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  308. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  309. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js +177 -0
  310. package/codeyam-cli/src/utils/__tests__/glossaryAdd.test.js.map +1 -0
  311. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +122 -0
  312. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  313. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  314. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  315. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  316. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  317. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  318. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  319. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  320. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  321. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js +118 -0
  322. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js.map +1 -0
  323. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +284 -0
  324. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  325. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  326. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  327. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +672 -0
  328. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  329. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js +84 -0
  330. package/codeyam-cli/src/utils/__tests__/screenshotHash.test.js.map +1 -0
  331. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +175 -86
  332. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  333. package/codeyam-cli/src/utils/__tests__/telemetry.test.js +159 -0
  334. package/codeyam-cli/src/utils/__tests__/telemetry.test.js.map +1 -0
  335. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  336. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  337. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  338. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  339. package/codeyam-cli/src/utils/analysisRunner.js +11 -7
  340. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  341. package/codeyam-cli/src/utils/analyzer.js +16 -0
  342. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  343. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  344. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  345. package/codeyam-cli/src/utils/backgroundServer.js +193 -30
  346. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  347. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  348. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  349. package/codeyam-cli/src/utils/database.js +37 -2
  350. package/codeyam-cli/src/utils/database.js.map +1 -1
  351. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  352. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  353. package/codeyam-cli/src/utils/devServerState.js +71 -0
  354. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  355. package/codeyam-cli/src/utils/editorApi.js +79 -0
  356. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  357. package/codeyam-cli/src/utils/editorAudit.js +595 -0
  358. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  359. package/codeyam-cli/src/utils/editorBroadcastViewport.js +26 -0
  360. package/codeyam-cli/src/utils/editorBroadcastViewport.js.map +1 -0
  361. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  362. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  363. package/codeyam-cli/src/utils/editorDeleteScenario.js +67 -0
  364. package/codeyam-cli/src/utils/editorDeleteScenario.js.map +1 -0
  365. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  366. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  367. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +50 -0
  368. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  369. package/codeyam-cli/src/utils/editorEntityHelpers.js +144 -0
  370. package/codeyam-cli/src/utils/editorEntityHelpers.js.map +1 -0
  371. package/codeyam-cli/src/utils/editorGuard.js +36 -0
  372. package/codeyam-cli/src/utils/editorGuard.js.map +1 -0
  373. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  374. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  375. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  376. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  377. package/codeyam-cli/src/utils/editorLoaderHelpers.js +152 -0
  378. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  379. package/codeyam-cli/src/utils/editorMigration.js +224 -0
  380. package/codeyam-cli/src/utils/editorMigration.js.map +1 -0
  381. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  382. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  383. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  384. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  385. package/codeyam-cli/src/utils/editorPreview.js +137 -0
  386. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  387. package/codeyam-cli/src/utils/editorRecapture.js +109 -0
  388. package/codeyam-cli/src/utils/editorRecapture.js.map +1 -0
  389. package/codeyam-cli/src/utils/editorScenarioSwitch.js +134 -0
  390. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  391. package/codeyam-cli/src/utils/editorScenarios.js +616 -0
  392. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  393. package/codeyam-cli/src/utils/editorSeedAdapter.js +422 -0
  394. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  395. package/codeyam-cli/src/utils/editorShouldRevalidate.js +21 -0
  396. package/codeyam-cli/src/utils/editorShouldRevalidate.js.map +1 -0
  397. package/codeyam-cli/src/utils/entityChangeStatus.js +394 -0
  398. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  399. package/codeyam-cli/src/utils/entityChangeStatus.server.js +196 -0
  400. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  401. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  402. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  403. package/codeyam-cli/src/utils/fileWatcher.js +63 -9
  404. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  405. package/codeyam-cli/src/utils/generateReport.js +2 -2
  406. package/codeyam-cli/src/utils/git.js +103 -0
  407. package/codeyam-cli/src/utils/git.js.map +1 -1
  408. package/codeyam-cli/src/utils/glossaryAdd.js +74 -0
  409. package/codeyam-cli/src/utils/glossaryAdd.js.map +1 -0
  410. package/codeyam-cli/src/utils/install-skills.js +115 -56
  411. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  412. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  413. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  414. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  415. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  416. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  417. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  418. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  419. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  420. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  421. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  422. package/codeyam-cli/src/utils/progress.js +8 -1
  423. package/codeyam-cli/src/utils/progress.js.map +1 -1
  424. package/codeyam-cli/src/utils/project.js +15 -5
  425. package/codeyam-cli/src/utils/project.js.map +1 -1
  426. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  427. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  428. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  429. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  430. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  431. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  432. package/codeyam-cli/src/utils/queue/job.js +80 -4
  433. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  434. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  435. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  436. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  437. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  438. package/codeyam-cli/src/utils/routePatternMatching.js +129 -0
  439. package/codeyam-cli/src/utils/routePatternMatching.js.map +1 -0
  440. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  441. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  442. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  443. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  444. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  445. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  446. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  447. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  448. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  449. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  450. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  451. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  452. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  453. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  454. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  455. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  456. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  457. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  458. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  459. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  460. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  461. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  462. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  463. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  464. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  465. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  466. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  467. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  468. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  469. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  470. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  471. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  472. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  473. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  474. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  475. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  476. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  477. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  478. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  479. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  480. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  481. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  482. package/codeyam-cli/src/utils/rules/index.js +2 -0
  483. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  484. package/codeyam-cli/src/utils/rules/parser.js +16 -29
  485. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  486. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  487. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  488. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  489. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  490. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  491. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  492. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  493. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  494. package/codeyam-cli/src/utils/rules/staleness.js +16 -11
  495. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
  496. package/codeyam-cli/src/utils/scenarioCoverage.js +77 -0
  497. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  498. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  499. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  500. package/codeyam-cli/src/utils/scenariosManifest.js +307 -0
  501. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  502. package/codeyam-cli/src/utils/screenshotHash.js +26 -0
  503. package/codeyam-cli/src/utils/screenshotHash.js.map +1 -0
  504. package/codeyam-cli/src/utils/serverState.js +94 -12
  505. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  506. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +96 -47
  507. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  508. package/codeyam-cli/src/utils/simulationGateMiddleware.js +175 -0
  509. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  510. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  511. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  512. package/codeyam-cli/src/utils/syncMocksMiddleware.js +7 -26
  513. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  514. package/codeyam-cli/src/utils/telemetry.js +106 -0
  515. package/codeyam-cli/src/utils/telemetry.js.map +1 -0
  516. package/codeyam-cli/src/utils/telemetryMiddleware.js +22 -0
  517. package/codeyam-cli/src/utils/telemetryMiddleware.js.map +1 -0
  518. package/codeyam-cli/src/utils/testRunner.js +158 -0
  519. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  520. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  521. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  522. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  523. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  524. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  525. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  526. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js +35 -0
  527. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js.map +1 -0
  528. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +107 -0
  529. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  530. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  531. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  532. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +628 -0
  533. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  534. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +248 -0
  535. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  536. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js +135 -0
  537. package/codeyam-cli/src/webserver/__tests__/stripClaudeCommand.test.js.map +1 -0
  538. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +83 -0
  539. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  540. package/codeyam-cli/src/webserver/app/lib/database.js +56 -30
  541. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  542. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  543. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  544. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  545. package/codeyam-cli/src/webserver/app/types/editor.js +8 -0
  546. package/codeyam-cli/src/webserver/app/types/editor.js.map +1 -0
  547. package/codeyam-cli/src/webserver/backgroundServer.js +186 -37
  548. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  549. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  550. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  551. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CLe80MMu.js +1 -0
  552. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-Crt_KN_U.js} +5 -5
  553. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CQgyEGV-.js +1 -0
  554. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-CD7lGABo.js} +9 -9
  555. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-CgTNOhnu.js +1 -0
  556. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-CKeQT5Ty.js +25 -0
  557. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-D3s1MFkb.js +3 -0
  558. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-By5zI316.js} +1 -1
  559. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-CM5zg40N.js} +3 -3
  560. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-C2PLkej3.js} +5 -10
  561. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DanvyBPb.js +1 -0
  562. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-DUMfcNVK.js} +3 -3
  563. package/codeyam-cli/src/webserver/build/client/assets/Spinner-D0LgAaSa.js +34 -0
  564. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CK7-NaPZ.js +1 -0
  565. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-BA_Ry-rs.js +1 -0
  566. package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-BAWd-Xjf.js} +4 -4
  567. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-BOARiB-g.js} +10 -15
  568. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  569. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  570. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-CHx25PAe.js +1 -0
  571. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  572. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bg3e7q4S.js +22 -0
  573. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  574. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  575. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  576. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  577. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  578. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  579. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  580. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  581. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  582. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  583. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  584. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  585. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  586. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  587. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  588. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  589. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  590. package/codeyam-cli/src/webserver/build/client/assets/api.editor-recapture-stale-l0sNRNKZ.js +1 -0
  591. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  592. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  593. package/codeyam-cli/src/webserver/build/client/assets/api.editor-rename-scenario-l0sNRNKZ.js +1 -0
  594. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-seed-state-l0sNRNKZ.js +1 -0
  595. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  596. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  597. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  598. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-prompt-l0sNRNKZ.js +1 -0
  599. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  600. package/codeyam-cli/src/webserver/build/client/assets/api.editor-session-l0sNRNKZ.js +1 -0
  601. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  602. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  603. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  604. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  605. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  606. package/codeyam-cli/src/webserver/build/client/assets/book-open-CL-lMgHh.js +6 -0
  607. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-GmAjGS9-.js} +2 -2
  608. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-BAdwhyCx.js +43 -0
  609. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-DFcQkN5j.js} +2 -2
  610. package/codeyam-cli/src/webserver/build/client/assets/copy-C6iF61Xs.js +11 -0
  611. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-4ImjHTVC.js +41 -0
  612. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-C8y4mmyv.js +1 -0
  613. package/codeyam-cli/src/webserver/build/client/assets/editor._tab-Gbk_i5Js.js +1 -0
  614. package/codeyam-cli/src/webserver/build/client/assets/editor.entity.(_sha)-DII1pg_z.js +58 -0
  615. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-oepecPae.js +41 -0
  616. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BJUiQqZF.js → entity._sha._-Blfy9UlN.js} +12 -12
  617. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-KTQuL0aj.js +6 -0
  618. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-C6eeL24i.js +6 -0
  619. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DQM8E7L4.js +6 -0
  620. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-CAoXLsQr.js} +2 -2
  621. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-SuW9syRS.js} +6 -6
  622. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-Daa96Fr1.js +1 -0
  623. package/codeyam-cli/src/webserver/build/client/assets/files-D-xGrg29.js +1 -0
  624. package/codeyam-cli/src/webserver/build/client/assets/git-Bq_fbXP5.js +1 -0
  625. package/codeyam-cli/src/webserver/build/client/assets/globals-Yn9W3zp3.css +1 -0
  626. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-Bp1l4hSv.js} +1 -1
  627. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-CWV9XZiG.js} +1 -1
  628. package/codeyam-cli/src/webserver/build/client/assets/index-DE3jI_dv.js +15 -0
  629. package/codeyam-cli/src/webserver/build/client/assets/jsx-runtime-D_zvdyIk.js +9 -0
  630. package/codeyam-cli/src/webserver/build/client/assets/labs-B_IX45ih.js +1 -0
  631. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-De-7qQ2u.js} +2 -2
  632. package/codeyam-cli/src/webserver/build/client/assets/manifest-cdf2c0a7.js +1 -0
  633. package/codeyam-cli/src/webserver/build/client/assets/memory-Cx2xEx7s.js +101 -0
  634. package/codeyam-cli/src/webserver/build/client/assets/pause-CFxEKL1u.js +11 -0
  635. package/codeyam-cli/src/webserver/build/client/assets/root-BxUQigda.js +67 -0
  636. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-BdBb5aqc.js} +2 -2
  637. package/codeyam-cli/src/webserver/build/client/assets/settings-DdE-Untf.js +1 -0
  638. package/codeyam-cli/src/webserver/build/client/assets/simulations-DSCdE99u.js +1 -0
  639. package/codeyam-cli/src/webserver/build/client/assets/terminal-CrplD4b1.js +11 -0
  640. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-DqJ0j69l.js} +2 -2
  641. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-DhXHbEjP.js +1 -0
  642. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-BNd5hYuW.js +2 -0
  643. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-Cy5Qg_UR.js +1 -0
  644. package/codeyam-cli/src/webserver/build/client/assets/useToast-5HR2j9ZE.js +1 -0
  645. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  646. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  647. package/codeyam-cli/src/webserver/build/server/assets/analysisRunner-B_PsTAb1.js +13 -0
  648. package/codeyam-cli/src/webserver/build/server/assets/index-CjLhfz6Z.js +1 -0
  649. package/codeyam-cli/src/webserver/build/server/assets/init-BEqlbI84.js +10 -0
  650. package/codeyam-cli/src/webserver/build/server/assets/progress-CHTtrxFG.js +1 -0
  651. package/codeyam-cli/src/webserver/build/server/assets/server-build-YI63xTu4.js +553 -0
  652. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  653. package/codeyam-cli/src/webserver/build-info.json +5 -5
  654. package/codeyam-cli/src/webserver/devServer.js +39 -5
  655. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  656. package/codeyam-cli/src/webserver/editorProxy.js +976 -0
  657. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  658. package/codeyam-cli/src/webserver/idleDetector.js +106 -0
  659. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  660. package/codeyam-cli/src/webserver/mockStateEvents.js +28 -0
  661. package/codeyam-cli/src/webserver/mockStateEvents.js.map +1 -0
  662. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  663. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  664. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +283 -0
  665. package/codeyam-cli/src/webserver/server.js +379 -1
  666. package/codeyam-cli/src/webserver/server.js.map +1 -1
  667. package/codeyam-cli/src/webserver/terminalServer.js +938 -0
  668. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  669. package/codeyam-cli/templates/__tests__/editor-step-hook.prompt-capture.test.ts +118 -0
  670. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  671. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  672. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  673. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  674. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  675. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  676. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  677. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  678. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  679. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  680. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  681. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  682. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  683. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  684. package/codeyam-cli/templates/codeyam-editor-claude.md +149 -0
  685. package/codeyam-cli/templates/codeyam-editor-reference.md +214 -0
  686. package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
  687. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  688. package/codeyam-cli/templates/editor-step-hook.py +368 -0
  689. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  690. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  691. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  692. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  693. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  694. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  695. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  696. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  697. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  698. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  699. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  700. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  701. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  702. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  703. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  704. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  705. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  706. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  707. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  708. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  709. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  710. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  711. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  712. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  713. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  714. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  715. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  716. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  717. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  718. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  719. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  720. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  721. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  722. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  723. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  724. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  725. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  726. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  727. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  728. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  729. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  730. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  731. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  732. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +127 -0
  733. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  734. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  735. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  736. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  737. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  738. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  739. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  740. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  741. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  742. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  743. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  744. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  745. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  746. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  747. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  748. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  749. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  750. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  751. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  752. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  753. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  754. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  755. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  756. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  757. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  758. package/codeyam-cli/templates/rule-reflection-hook.py +574 -88
  759. package/codeyam-cli/templates/rules-instructions.md +45 -93
  760. package/codeyam-cli/templates/seed-adapters/supabase.ts +282 -0
  761. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
  762. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  763. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +229 -0
  764. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  765. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  766. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  767. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  768. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  769. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  770. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  771. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  772. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  773. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  774. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  775. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  776. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  777. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  778. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  779. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  780. package/package.json +29 -21
  781. package/packages/ai/index.js +1 -1
  782. package/packages/ai/index.js.map +1 -1
  783. package/packages/ai/src/lib/analyzeScope.js +21 -1
  784. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  785. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  786. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  787. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  788. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  789. package/packages/ai/src/lib/astScopes/processExpression.js +78 -1
  790. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  791. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  792. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  793. package/packages/ai/src/lib/completionCall.js +10 -7
  794. package/packages/ai/src/lib/completionCall.js.map +1 -1
  795. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +495 -10
  796. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  797. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  798. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  799. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +11 -2
  800. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  801. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +2 -2
  802. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  803. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  804. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  805. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  806. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  807. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  808. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  809. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +15 -1
  810. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -1
  811. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +78 -17
  812. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  813. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  814. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  815. package/packages/ai/src/lib/dataStructureChunking.js +30 -11
  816. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  817. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  818. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  819. package/packages/ai/src/lib/generateEntityScenarioData.js +89 -5
  820. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  821. package/packages/ai/src/lib/generateExecutionFlows.js +86 -2
  822. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  823. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +242 -81
  824. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  825. package/packages/ai/src/lib/isolateScopes.js +39 -3
  826. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  827. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  828. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  829. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  830. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  831. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  832. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  833. package/packages/analyze/index.js +1 -0
  834. package/packages/analyze/index.js.map +1 -1
  835. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  836. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  837. package/packages/analyze/src/lib/asts/index.js +4 -2
  838. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  839. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  840. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  841. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +52 -2
  842. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  843. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +10 -0
  844. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  845. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  846. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  847. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +11 -2
  848. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  849. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +9 -7
  850. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  851. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  852. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  853. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +5 -1
  854. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  855. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +51 -14
  856. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  857. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +181 -13
  858. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  859. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  860. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  861. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +328 -49
  862. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  863. package/packages/analyze/src/lib/index.js +1 -0
  864. package/packages/analyze/src/lib/index.js.map +1 -1
  865. package/packages/database/index.js +1 -0
  866. package/packages/database/index.js.map +1 -1
  867. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  868. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  869. package/packages/database/src/lib/analysisToDb.js +1 -1
  870. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  871. package/packages/database/src/lib/branchToDb.js +1 -1
  872. package/packages/database/src/lib/branchToDb.js.map +1 -1
  873. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  874. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  875. package/packages/database/src/lib/commitToDb.js +1 -1
  876. package/packages/database/src/lib/commitToDb.js.map +1 -1
  877. package/packages/database/src/lib/fileToDb.js +1 -1
  878. package/packages/database/src/lib/fileToDb.js.map +1 -1
  879. package/packages/database/src/lib/kysely/db.js +8 -0
  880. package/packages/database/src/lib/kysely/db.js.map +1 -1
  881. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  882. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  883. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  884. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  885. package/packages/database/src/lib/loadAnalysis.js +1 -1
  886. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  887. package/packages/database/src/lib/loadCommits.js +23 -13
  888. package/packages/database/src/lib/loadCommits.js.map +1 -1
  889. package/packages/database/src/lib/loadEntities.js +0 -6
  890. package/packages/database/src/lib/loadEntities.js.map +1 -1
  891. package/packages/database/src/lib/loadEntity.js +1 -1
  892. package/packages/database/src/lib/loadEntity.js.map +1 -1
  893. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  894. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  895. package/packages/database/src/lib/projectToDb.js +1 -1
  896. package/packages/database/src/lib/projectToDb.js.map +1 -1
  897. package/packages/database/src/lib/saveFiles.js +1 -1
  898. package/packages/database/src/lib/saveFiles.js.map +1 -1
  899. package/packages/database/src/lib/scenarioToDb.js +1 -1
  900. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  901. package/packages/database/src/lib/updateCommitMetadata.js +76 -90
  902. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  903. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  904. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  905. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  906. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  907. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  908. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  909. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  910. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  911. package/packages/types/src/enums/ProjectFramework.js +2 -0
  912. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  913. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  914. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  915. package/scripts/npm-post-install.cjs +34 -0
  916. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  917. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  918. package/codeyam-cli/src/commands/list.js +0 -31
  919. package/codeyam-cli/src/commands/list.js.map +0 -1
  920. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  921. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  922. package/codeyam-cli/src/utils/reviewedRules.js +0 -92
  923. package/codeyam-cli/src/utils/reviewedRules.js.map +0 -1
  924. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  925. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  926. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-DLqD3qNt.js +0 -1
  927. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C8lyxW9k.js +0 -34
  928. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-aht4aafF.js +0 -25
  929. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-CVtiBnY5.js +0 -3
  930. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DuDvi0jm.js +0 -1
  931. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-DyFZkK0l.js +0 -1
  932. package/codeyam-cli/src/webserver/build/client/assets/chunk-EPOLDU6W-CXRTFQ3F.js +0 -51
  933. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
  934. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
  935. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +0 -1
  936. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js +0 -6
  937. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D1T4TGjf.js +0 -6
  938. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
  939. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-DMJ7zii9.js +0 -1
  940. package/codeyam-cli/src/webserver/build/client/assets/files-CJ6lTdTA.js +0 -1
  941. package/codeyam-cli/src/webserver/build/client/assets/git-CPTZZ-JZ.js +0 -15
  942. package/codeyam-cli/src/webserver/build/client/assets/globals-CX9f-5xM.css +0 -1
  943. package/codeyam-cli/src/webserver/build/client/assets/manifest-bba56ec1.js +0 -1
  944. package/codeyam-cli/src/webserver/build/client/assets/memory-DuTFSyJ2.js +0 -92
  945. package/codeyam-cli/src/webserver/build/client/assets/root-DTfSQARG.js +0 -62
  946. package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
  947. package/codeyam-cli/src/webserver/build/client/assets/simulations-DwFIBT09.js +0 -1
  948. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C1v1PQzo.js +0 -1
  949. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  950. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-DYxHZQuP.js +0 -1
  951. package/codeyam-cli/src/webserver/build/client/assets/useToast-mBRpZPiu.js +0 -1
  952. package/codeyam-cli/src/webserver/build/server/assets/index-TD1f-DHV.js +0 -1
  953. package/codeyam-cli/src/webserver/build/server/assets/server-build-BQ-1XyEa.js +0 -258
  954. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  955. package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
  956. package/codeyam-cli/templates/codeyam:memory.md +0 -403
  957. package/codeyam-cli/templates/codeyam:new-rule.md +0 -52
  958. package/scripts/finalize-analyzer.cjs +0 -81
@@ -8,6 +8,7 @@ import type { AnyNode } from 'domhandler';
8
8
  import { safeFileName } from '~codeyam/utils';
9
9
  import { cleanOutBoundary } from '~codeyam/ai';
10
10
  import { reconcileMockDataKeys } from './reconcileMockDataKeys';
11
+ import coerceObjectsToPrimitivesBySchema from '~codeyam/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema';
11
12
 
12
13
  /**
13
14
  * Normalize useParams mock data by fixing the React Router splat param (*).
@@ -192,6 +193,36 @@ const safeString = (s: string, level: number) => {
192
193
  return s?.replace ? s.replace(/"/g, "'").replace(/\n/g, '\\n') : s;
193
194
  };
194
195
 
196
+ /**
197
+ * Clean up malformed LLM-generated function values.
198
+ * The LLM sometimes generates function values with an invalid "(function)" prefix like:
199
+ * - "(function)() => {}"
200
+ * - "(function)(event) => {}"
201
+ * - "(function)(id) => {}"
202
+ *
203
+ * This strips the prefix and adds TypeScript `any` type annotations to parameters.
204
+ * Returns null if the value doesn't match the malformed pattern.
205
+ */
206
+ const cleanMalformedFunctionValue = (value: string): string | null => {
207
+ // Match "(function)" followed by optional params in parens, then "=>"
208
+ const match = value.match(/^\(function\)(\([^)]*\))\s*=>\s*(.*)$/);
209
+ if (!match) return null;
210
+
211
+ const [, paramsWithParens, body] = match;
212
+
213
+ // Extract parameter names and add `: any` type annotation
214
+ // e.g., "(event)" -> "(event: any)", "()" -> "()"
215
+ const params = paramsWithParens.slice(1, -1).trim(); // Remove outer parens
216
+ const typedParams = params
217
+ ? params
218
+ .split(',')
219
+ .map((p) => `${p.trim()}: any`)
220
+ .join(', ')
221
+ : '';
222
+
223
+ return `(${typedParams}) => ${body}`;
224
+ };
225
+
195
226
  /**
196
227
  * Check if a mock key's schema indicates it should be instantiated as a Map.
197
228
  * A Map is indicated by:
@@ -310,6 +341,38 @@ function extractAllKeys(obj: JsonTypeDefinition | undefined): string[] {
310
341
  */
311
342
  const BARE_TYPE_MARKERS = ['function', 'async-function'];
312
343
 
344
+ /**
345
+ * Check if a string is a TypeScript arrow function type annotation rather than
346
+ * a valid JavaScript arrow function expression.
347
+ *
348
+ * TypeScript arrow types look like function expressions (they contain '=>') but
349
+ * their "body" is a type name, not a JS expression:
350
+ * - "() => void"
351
+ * - "(event: MouseEvent) => void"
352
+ * - "() => string"
353
+ * - "() => Promise<void>"
354
+ * - "(id: string, name: string) => boolean"
355
+ *
356
+ * Valid JS arrow functions have actual expression bodies:
357
+ * - "() => {}"
358
+ * - "() => 'hello'"
359
+ * - "(x) => x + 1"
360
+ * - "() => { console.log('hi'); }"
361
+ */
362
+ const ARROW_TYPE_RETURN_TYPES =
363
+ /^(void|string|number|boolean|any|unknown|never|null|undefined|object|Date|Promise<\w+>)$/i;
364
+
365
+ const isArrowFunctionTypeAnnotation = (value: string): boolean => {
366
+ const arrowIndex = value.indexOf('=>');
367
+ if (arrowIndex === -1) return false;
368
+
369
+ const body = value.slice(arrowIndex + 2).trim();
370
+
371
+ // A real JS function would have {}, an expression, a string literal, etc.
372
+ // A type annotation has a bare type keyword as the "body".
373
+ return ARROW_TYPE_RETURN_TYPES.test(body);
374
+ };
375
+
313
376
  /**
314
377
  * Check if a value is a bare function type marker that should be filtered out.
315
378
  * These markers indicate the LLM detected a function but couldn't generate meaningful mock data.
@@ -811,22 +874,49 @@ const jsonToCode = (
811
874
  `CodeYam: Nested func transform (string->function): "${key}" -> "${funcName}": () => {}`,
812
875
  );
813
876
  } else if (looksLikeFunction) {
814
- // Handle newlines in function expressions:
815
- // - Newlines inside string literals must be escaped to avoid
816
- // "unterminated string literal" errors
817
- // - Structural newlines (between statements) should be kept as-is
818
- // to produce valid multi-line JavaScript
819
- //
820
- // We escape ONLY newlines that appear inside string literals (single,
821
- // double, or template quotes). Structural newlines are preserved.
822
- if (hasNewlines) {
823
- outputValue = escapeNewlinesInStringLiterals(stringValue);
877
+ // Check for "[native code]" in function body — this is what
878
+ // Function.prototype.toString() returns for built-in functions.
879
+ // The LLM sometimes generates "function () { [native code] }" which
880
+ // is not valid JavaScript (the "[" is parsed as array destructuring).
881
+ if (stringValue.includes('[native code]')) {
882
+ outputValue = '() => {}';
883
+ console.log(
884
+ `CodeYam: Nested func transform (native-code->noop): "${key}" -> "${funcName}": () => {}`,
885
+ );
886
+ } else if (cleanMalformedFunctionValue(stringValue)) {
887
+ // Check for malformed LLM-generated function values like "(function)() => {}"
888
+ // These have an invalid "(function)" prefix that must be stripped
889
+ outputValue = cleanMalformedFunctionValue(stringValue)!;
890
+ console.log(
891
+ `CodeYam: Nested func transform (malformed->clean): "${key}" -> "${funcName}": ${outputValue}`,
892
+ );
893
+ } else if (isArrowFunctionTypeAnnotation(stringValue)) {
894
+ // TypeScript arrow function type annotations like "() => void",
895
+ // "(event: MouseEvent) => void", "() => Promise<void>" contain '=>'
896
+ // so they pass the looksLikeFunction check, but they are TYPE syntax,
897
+ // not valid JavaScript expressions. Convert to a no-op function.
898
+ outputValue = '() => {}';
899
+ console.log(
900
+ `CodeYam: Nested func transform (type-annotation->function): "${key}" -> "${funcName}": () => {}`,
901
+ );
824
902
  } else {
825
- outputValue = stringValue;
903
+ // Handle newlines in function expressions:
904
+ // - Newlines inside string literals must be escaped to avoid
905
+ // "unterminated string literal" errors
906
+ // - Structural newlines (between statements) should be kept as-is
907
+ // to produce valid multi-line JavaScript
908
+ //
909
+ // We escape ONLY newlines that appear inside string literals (single,
910
+ // double, or template quotes). Structural newlines are preserved.
911
+ if (hasNewlines) {
912
+ outputValue = escapeNewlinesInStringLiterals(stringValue);
913
+ } else {
914
+ outputValue = stringValue;
915
+ }
916
+ console.log(
917
+ `CodeYam: Nested func transform (string): "${key}" -> "${funcName}": ${stringValue.substring(0, 30)}...`,
918
+ );
826
919
  }
827
- console.log(
828
- `CodeYam: Nested func transform (string): "${key}" -> "${funcName}": ${stringValue.substring(0, 30)}...`,
829
- );
830
920
  } else {
831
921
  // Plain string value - must be quoted
832
922
  outputValue = `"${safeString(stringValue, level)}"`;
@@ -854,9 +944,22 @@ const jsonToCode = (
854
944
  if (isBareTypeMarker(stringValue)) {
855
945
  continue;
856
946
  }
857
- keyStrings.push(
858
- `${levelSpacing}"${safeString(key, level)}": "${safeString(stringValue, level)}"`,
859
- );
947
+ // Check for malformed LLM-generated function values like "(function)(id) => {}"
948
+ // These can appear on plain keys (e.g., "closeToast") and need to be output as
949
+ // actual functions, not quoted strings
950
+ const cleanedPlainKeyFn = cleanMalformedFunctionValue(stringValue);
951
+ if (cleanedPlainKeyFn) {
952
+ keyStrings.push(
953
+ `${levelSpacing}"${safeString(key, level)}": ${cleanedPlainKeyFn}`,
954
+ );
955
+ console.log(
956
+ `CodeYam: Plain key func transform (malformed->clean): "${key}": ${cleanedPlainKeyFn}`,
957
+ );
958
+ } else {
959
+ keyStrings.push(
960
+ `${levelSpacing}"${safeString(key, level)}": "${safeString(stringValue, level)}"`,
961
+ );
962
+ }
860
963
  }
861
964
  } else {
862
965
  // Skip plain keys that have function-call versions (at the same nesting level where
@@ -927,6 +1030,14 @@ export default async function writeMockDataTsx(
927
1030
  expectedKeys,
928
1031
  );
929
1032
 
1033
+ // Coerce objects/arrays to primitives when the schema expects a primitive type.
1034
+ // Defense-in-depth: the generation pipeline already runs this coercion, but
1035
+ // data in the DB may have wrong types from older code versions or edge cases.
1036
+ // This prevents runtime errors like "TypeError: body.match is not a function".
1037
+ if (dataForMocks) {
1038
+ coerceObjectsToPrimitivesBySchema(reconciledMockData, dataForMocks);
1039
+ }
1040
+
930
1041
  // Convert comma-separated strings to arrays for fields that should be arrays
931
1042
  // This handles cases where LLM generates "color,size" instead of ["color", "size"]
932
1043
  const defaultMockData =
@@ -974,6 +1085,14 @@ import React from 'react';
974
1085
  expectedKeys,
975
1086
  );
976
1087
 
1088
+ // Coerce objects/arrays to primitives for non-default scenario data too
1089
+ if (dataForMocks) {
1090
+ coerceObjectsToPrimitivesBySchema(
1091
+ reconciledScenarioMockData,
1092
+ dataForMocks,
1093
+ );
1094
+ }
1095
+
977
1096
  // Convert comma-separated strings to arrays for scenario data
978
1097
  const scenarioMockData = convertCommaSeparatedStringsToArrays(
979
1098
  reconciledScenarioMockData,
@@ -987,10 +987,19 @@ function addMockToContent(
987
987
  /[.*+?^${}()|[\]\\]/g,
988
988
  '\\$&',
989
989
  );
990
- // Create regex that matches the call (with optional whitespace variations)
990
+ // Create regex that matches the call (with optional whitespace variations).
991
+ // TypeScript formatters commonly break type parameters across lines, e.g.:
992
+ // useLoaderData<
993
+ // typeof loader
994
+ // >()
995
+ // So we allow optional whitespace around < and > delimiters, not just
996
+ // where whitespace already exists in the call signature string.
991
997
  const callRegex = new RegExp(
992
- escapedCallSignature.replace(/\s+/g, '\\s*'),
993
- 'g',
998
+ escapedCallSignature
999
+ .replace(/\s+/g, '\\s*')
1000
+ .replace(/</g, '\\s*<\\s*')
1001
+ .replace(/>/g, '\\s*>\\s*'),
1002
+ 'gs',
994
1003
  );
995
1004
  fileContent = fileContent.replace(callRegex, `${mockFunctionName}()`);
996
1005
  }
@@ -1012,15 +1021,29 @@ function addMockToContent(
1012
1021
  rootAnalysis.metadata?.scenariosDataStructure?.dataForMocks;
1013
1022
 
1014
1023
  // Find matching call signature key in dataForMocks
1024
+ // IMPORTANT: First try exact match with type parameters (e.g., "useLoaderData<LoaderData>()")
1025
+ // to avoid picking the wrong variant (e.g., "useLoaderData<typeof loader>()" which may
1026
+ // have different properties). Fall back to base name matching only if exact match fails.
1015
1027
  const hookBaseName = importedExport.name.split(/[<(]/)[0];
1016
- const callSignatureKey = dataForMocks
1017
- ? Object.keys(dataForMocks).find((key) => {
1028
+ const expectedKey = importedExport.calls?.[0];
1029
+ let callSignatureKey: string | undefined;
1030
+
1031
+ if (dataForMocks) {
1032
+ const keys = Object.keys(dataForMocks);
1033
+
1034
+ // First try exact match with the expected call signature
1035
+ if (expectedKey && keys.includes(expectedKey)) {
1036
+ callSignatureKey = expectedKey;
1037
+ } else {
1038
+ // Fall back to base name matching
1039
+ callSignatureKey = keys.find((key) => {
1018
1040
  // Split on ., <, or ( to get the true base name
1019
1041
  // This handles both "useFlags()" -> "useFlags" and "trpc.useUtils()" -> "trpc"
1020
1042
  const keyBaseName = key.split(/[.<(]/)[0];
1021
1043
  return keyBaseName === hookBaseName;
1022
- })
1023
- : undefined;
1044
+ });
1045
+ }
1046
+ }
1024
1047
 
1025
1048
  // Use the call signature if found, otherwise construct it
1026
1049
  const dataKey =
@@ -1032,11 +1055,17 @@ function addMockToContent(
1032
1055
  // use the base name (e.g., "trpc") when calling constructMockCode. This ensures
1033
1056
  // constructMockCode generates a complete nested mock from the schema without
1034
1057
  // referencing __cyOriginal variables.
1058
+ // NOTE: Only check for dots BEFORE the first open paren. Function calls with
1059
+ // dotted arguments like "getSurveyWithMetadata(params.surveyId)" have dots
1060
+ // INSIDE parens — these are NOT method chains and should keep the full signature.
1035
1061
  const dataKeyBaseName = dataKey.split(/[.<(]/)[0];
1062
+ const firstParenIndex = dataKey.indexOf('(');
1063
+ const partBeforeFirstParen =
1064
+ firstParenIndex >= 0 ? dataKey.substring(0, firstParenIndex) : dataKey;
1036
1065
  const isMethodChainDataKey =
1037
1066
  dataKeyBaseName === importedExport.name &&
1038
1067
  dataKey !== importedExport.name &&
1039
- dataKey.includes('.');
1068
+ partBeforeFirstParen.includes('.');
1040
1069
  const mockNameToUse = isMethodChainDataKey
1041
1070
  ? importedExport.name
1042
1071
  : dataKey;
@@ -1061,18 +1090,36 @@ function addMockToContent(
1061
1090
  // IMPORTANT: We inline scenarios().data() inside the function rather than
1062
1091
  // storing in a const - see comment in constructMockCode.ts for why.
1063
1092
  if (!mockCode) {
1064
- mockCode = `function ${importedExport.name}(...args) {
1065
- return scenarios().data()?.["${dataKey}"];
1093
+ mockCode = `// PATCHED: memoize to return stable reference (prevents infinite useEffect re-triggers)
1094
+ const _${importedExport.name}Ref = {
1095
+ current: null,
1096
+ };
1097
+ function ${importedExport.name}(...args) {
1098
+ if (!_${importedExport.name}Ref.current) {
1099
+ _${importedExport.name}Ref.current = scenarios().data()?.["${dataKey}"];
1100
+ }
1101
+ return _${importedExport.name}Ref.current;
1066
1102
  }`;
1067
1103
  }
1068
1104
  } else {
1069
1105
  // Helper to find matching call signature key from dataForMocks
1106
+ // IMPORTANT: First try exact match with type parameters (e.g., "useLoaderData<LoaderData>()")
1107
+ // to avoid picking the wrong variant. Fall back to base name matching only if needed.
1070
1108
  const hookBaseName = importedExport.name.split(/[<(]/)[0];
1109
+ const expectedKey = importedExport.calls?.[0];
1071
1110
  const findMatchingKey = (
1072
1111
  dataForMocks: Record<string, unknown> | undefined,
1073
1112
  ): string | undefined => {
1074
1113
  if (!dataForMocks) return undefined;
1075
- return Object.keys(dataForMocks).find((key) => {
1114
+ const keys = Object.keys(dataForMocks);
1115
+
1116
+ // First try exact match with the expected call signature
1117
+ if (expectedKey && keys.includes(expectedKey)) {
1118
+ return expectedKey;
1119
+ }
1120
+
1121
+ // Fall back to base name matching
1122
+ return keys.find((key) => {
1076
1123
  // Split on ., <, or ( to get the true base name
1077
1124
  // This handles both "useFlags()" -> "useFlags" and "trpc.useUtils()" -> "trpc"
1078
1125
  const keyBaseName = key.split(/[.<(]/)[0];
@@ -1104,12 +1151,20 @@ function addMockToContent(
1104
1151
  // referencing __cyOriginal variables. The __cyOriginal pattern is only needed
1105
1152
  // for partial mocking where we preserve some original methods, not for complete
1106
1153
  // method-chain mocks where we provide all implementations.
1154
+ // NOTE: Only check for dots BEFORE the first open paren. Function calls with
1155
+ // dotted arguments like "getSurveyWithMetadata(params.surveyId)" have dots
1156
+ // INSIDE parens — these are NOT method chains and should keep the full signature.
1107
1157
  const dataKeyBaseName = dataKey?.split(/[.<(]/)[0];
1158
+ const elseFirstParenIndex = dataKey?.indexOf('(') ?? -1;
1159
+ const elsePartBeforeFirstParen =
1160
+ dataKey && elseFirstParenIndex >= 0
1161
+ ? dataKey.substring(0, elseFirstParenIndex)
1162
+ : dataKey;
1108
1163
  const isMethodChainDataKey =
1109
1164
  dataKey &&
1110
1165
  dataKeyBaseName === importedExport.name &&
1111
1166
  dataKey !== importedExport.name &&
1112
- dataKey.includes('.');
1167
+ (elsePartBeforeFirstParen?.includes('.') ?? false);
1113
1168
  const mockNameToUse = isMethodChainDataKey
1114
1169
  ? importedExport.name
1115
1170
  : (dataKey ?? importedExport.calls?.[0] ?? `${importedExport.name}()`);
@@ -1131,8 +1186,15 @@ function addMockToContent(
1131
1186
  // IMPORTANT: We inline scenarios().data() inside the function rather than
1132
1187
  // storing in a const - see comment in constructMockCode.ts for why.
1133
1188
  if (!mockCode && dataKey) {
1134
- mockCode = `function ${importedExport.name}(...args) {
1135
- return scenarios().data()?.["${dataKey}"];
1189
+ mockCode = `// PATCHED: memoize to return stable reference (prevents infinite useEffect re-triggers)
1190
+ const _${importedExport.name}Ref = {
1191
+ current: null,
1192
+ };
1193
+ function ${importedExport.name}(...args) {
1194
+ if (!_${importedExport.name}Ref.current) {
1195
+ _${importedExport.name}Ref.current = scenarios().data()?.["${dataKey}"];
1196
+ }
1197
+ return _${importedExport.name}Ref.current;
1136
1198
  }`;
1137
1199
  }
1138
1200
  }
@@ -1872,6 +1934,17 @@ export default async function writeScenarioComponents({
1872
1934
  dataFileContent = stripServerOnlyImport(dataFileContent);
1873
1935
  dataFileContent = applyServerOnlyMocks(dataFileContent);
1874
1936
 
1937
+ // Process transitive imports: if the data entity file imports from files
1938
+ // that have `import "server-only"`, rewrite those imports to transitive
1939
+ // copies with server-only stripped. Without this, data entity files that
1940
+ // end up in a client bundle (e.g., via a stripped "use server" boundary)
1941
+ // would pull in server-only code and cause build failures.
1942
+ dataFileContent = await processTransitiveImportsRecursively(
1943
+ dataFileContent,
1944
+ fileNotMocked.path,
1945
+ dataScenarioPath,
1946
+ );
1947
+
1875
1948
  // Write the transformed data entity file
1876
1949
  await writeFile(dataScenarioPath, dataFileContent);
1877
1950
  scenarioComponentPaths.push(dataScenarioPath);
@@ -1897,9 +1970,9 @@ export default async function writeScenarioComponents({
1897
1970
  importedExport.name,
1898
1971
  );
1899
1972
 
1900
- // Don't recurse - data entities don't need their dependencies processed
1901
- // The import rewriting will happen later in this same loop iteration
1902
- // (at lines ~1590-1702) to point imports to this transformed file
1973
+ // Don't recurse into full writeScenarioComponents - data entities don't
1974
+ // need mock generation for their dependencies. Transitive server-only
1975
+ // import processing is already handled above via processTransitiveImportsRecursively.
1903
1976
  } else {
1904
1977
  // For visual/library entities, recurse to process their dependencies
1905
1978
 
@@ -1972,20 +2045,25 @@ export default async function writeScenarioComponents({
1972
2045
  // that stubbing would break (e.g., Zod schemas with .superRefine())
1973
2046
  const isDataEntity = entityType === 'data' || entityType === 'type';
1974
2047
 
1975
- // Heuristic: Zod schemas are often misclassified as 'library' but should be preserved
1976
- // Detect by: name starts with Z + uppercase letter, AND has Zod method calls
1977
- const looksLikeZodSchema =
1978
- entityType === 'library' &&
1979
- /^Z[A-Z]/.test(importedExport.name) &&
1980
- importedExport.calls?.some((call: string) =>
1981
- /\.(superRefine|refine|transform|default|optional|nullable|array|object|string|number|boolean|parse|safeParse)\s*\(/.test(
1982
- call,
1983
- ),
1984
- );
2048
+ // If calls data shows the entity is only accessed via properties/methods
2049
+ // (e.g., formValidator.validate(), schema.superRefine()) and never directly
2050
+ // invoked (e.g., getInitialProps()), it's used as an object and should be
2051
+ // preserved rather than replaced with a Proxy stub.
2052
+ const onlyPropertyAccessed =
2053
+ importedExport.calls?.length > 0 &&
2054
+ !importedExport.calls.some((call: string) => {
2055
+ const afterName = call.slice(importedExport.name.length);
2056
+ return afterName.startsWith('(') || afterName.startsWith('<');
2057
+ });
1985
2058
 
1986
- // Callable entities can be safely stubbed (but not Zod schemas)
2059
+ // Callable entities can be safely stubbed. Entities that are only
2060
+ // property-accessed should be preserved (their methods need to work).
2061
+ // 'other' entities are unknown types — safer to preserve than stub.
1987
2062
  const isCallable =
1988
- !isDataEntity && !looksLikeZodSchema && entityType !== undefined;
2063
+ !isDataEntity &&
2064
+ !onlyPropertyAccessed &&
2065
+ entityType !== undefined &&
2066
+ entityType !== 'other';
1989
2067
 
1990
2068
  // Determine what action to take
1991
2069
  const shouldStripAndReplace = hasMock;
@@ -2685,6 +2763,20 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
2685
2763
  debugLog(
2686
2764
  `[REMAINING LOOP] import ${remainingImportIndex}/${remainingImportPaths.length}: ${importPath}`,
2687
2765
  );
2766
+
2767
+ // Skip imports that point to generated CodeYam files (same skip logic as
2768
+ // rewriteRelativeModuleImports). Without this, MockData files from earlier
2769
+ // captures that get discovered by the TypeScript compiler would be treated as
2770
+ // regular imports, creating transitive copies with stale content.
2771
+ const scenarioFilePattern = /[a-f0-9]{64}_\w+_[A-Z]\w*$/;
2772
+ const mockDataPattern = /__codeyamMocks__\//;
2773
+ if (
2774
+ scenarioFilePattern.test(importPath) ||
2775
+ mockDataPattern.test(importPath)
2776
+ ) {
2777
+ continue;
2778
+ }
2779
+
2688
2780
  // Resolve the import path to a project file path
2689
2781
  const resolvedFilePath = resolveImportPath(importPath, file.path, project);
2690
2782
 
@@ -2959,6 +3051,55 @@ ${exportKeyword}const ${functionName} = new Proxy(() => scenarios().data()?.["${
2959
3051
  }
2960
3052
  }
2961
3053
 
3054
+ // For route components (page.tsx, layout.tsx), the component IS the Next.js page.
3055
+ // There's no wrapper page to inject argumentsData as props (unlike non-route components
3056
+ // which get a scenarioComponent wrapper). We need to wrap the default export so that
3057
+ // the scenario's argumentsData is passed as props to the component.
3058
+ if (
3059
+ isFrameworkRoute(file, entity, framework, file === rootFile) &&
3060
+ rootAnalysis.metadata?.scenariosDataStructure?.arguments?.length > 0
3061
+ ) {
3062
+ const positionalArguments =
3063
+ rootAnalysis.metadata.scenariosDataStructure.arguments;
3064
+ const hasNamedArgs =
3065
+ positionalArguments.length === 1 &&
3066
+ typeof positionalArguments[0] === 'object';
3067
+
3068
+ if (hasNamedArgs) {
3069
+ // Match: export default function Name(
3070
+ // Also: export default async function Name(
3071
+ const defaultExportMatch = fileContent.match(
3072
+ /export\s+default\s+(async\s+)?function\s+(\w+)\s*\(/,
3073
+ );
3074
+
3075
+ if (defaultExportMatch) {
3076
+ const funcName = defaultExportMatch[2];
3077
+
3078
+ // Remove "export default" from the original function declaration
3079
+ fileContent = fileContent.replace(
3080
+ /export\s+default\s+(async\s+)?function\s+(\w+)\s*\(/,
3081
+ '$1function $2(',
3082
+ );
3083
+
3084
+ // Ensure scenarios import is present
3085
+ const mockDataPath = `${relativeMocksDir}/MockData_${safeFileName(scenario.name)}`;
3086
+ if (fileContent.indexOf('import { scenarios } from') === -1) {
3087
+ fileContent = `import { scenarios } from "${mockDataPath}";\n\n${fileContent}`;
3088
+ }
3089
+
3090
+ // Add wrapper default export that injects argumentsData as props.
3091
+ // Filter null values: the LLM uses null to mean "don't pass this prop"
3092
+ // but spreading { prop: null } explicitly passes null, which differs from
3093
+ // undefined (absent) and crashes components that check `prop !== undefined`.
3094
+ fileContent += `\n\nexport default function _CYRouteWrapper(props: any) {
3095
+ const _cyArgs = scenarios().data()?.['arguments']?.[0] ?? {};
3096
+ const _cyCleanArgs = Object.fromEntries(Object.entries(_cyArgs).filter(([_, v]) => v !== null));
3097
+ return <${funcName} {...props} {..._cyCleanArgs} />;
3098
+ }\n`;
3099
+ }
3100
+ }
3101
+ }
3102
+
2962
3103
  // Use the directive that was extracted at the beginning of processing
2963
3104
  // This ensures it stays at the very top even after imports are prepended
2964
3105
  // NOTE: We only preserve "use client" directives, NOT "use server" directives.
@@ -277,16 +277,17 @@ export default async function writeSimpleRoot(
277
277
  let mockKey: string | undefined;
278
278
 
279
279
  if (matchingKeys.length > 1) {
280
- // Parse root.tsx to find how this hook is used
281
- // Look for patterns like: const { prop1, prop2 } = useLoaderData()
282
- // or: const result = useLoaderData()
280
+ // Parse root.tsx to find how this hook is used, INCLUDING type parameters
281
+ // Look for patterns like: const { prop1, prop2 } = useLoaderData<LoaderData>()
282
+ // or: const result = useLoaderData<typeof loader>()
283
283
  const hookUsageRegex = new RegExp(
284
- `(?:const|let|var)\\s+(?:\\{([^}]+)\\}|([a-zA-Z_][a-zA-Z0-9_]*))\\s*=\\s*${entityName}(?:<[^>]*>)?\\s*\\(`,
284
+ `(?:const|let|var)\\s+(?:\\{([^}]+)\\}|([a-zA-Z_][a-zA-Z0-9_]*))\\s*=\\s*${entityName}(<[^>]+>)?\\s*\\(`,
285
285
  'g',
286
286
  );
287
287
 
288
288
  const matches = [...newContent.matchAll(hookUsageRegex)];
289
289
  const rootPropertyNames: string[] = [];
290
+ const typeParamsUsed: Set<string> = new Set();
290
291
 
291
292
  for (const match of matches) {
292
293
  if (match[1]) {
@@ -300,17 +301,26 @@ export default async function writeSimpleRoot(
300
301
  // Simple assignment: const result = ...
301
302
  rootPropertyNames.push(match[2]);
302
303
  }
304
+ // Capture type parameters used (e.g., "<LoaderData>", "<typeof loader>")
305
+ if (match[3]) {
306
+ typeParamsUsed.add(match[3]);
307
+ }
303
308
  }
304
309
 
305
- // Find a key that matches by call signature
306
- // For call signature format (e.g., "useLoaderData()"), just use the first match
307
- mockKey = matchingKeys[0];
310
+ // First, try to find a key that matches the exact type parameters used in the source
311
+ // e.g., if source has useLoaderData<LoaderData>(), prefer "useLoaderData<LoaderData>()" key
312
+ if (typeParamsUsed.size > 0) {
313
+ for (const typeParam of typeParamsUsed) {
314
+ const exactKey = `${entityName}${typeParam}()`;
315
+ if (matchingKeys.includes(exactKey)) {
316
+ mockKey = exactKey;
317
+ break;
318
+ }
319
+ }
320
+ }
308
321
 
309
- // Fallback: if no match found but there are multiple keys,
310
- // exclude the route's key (which we can identify from mockedImports variable names)
322
+ // Fallback: if no exact type parameter match, use the first match
311
323
  if (!mockKey) {
312
- // The route's variable names would be in its own analysis
313
- // For simplicity, just use the first key that's different from the most common pattern
314
324
  mockKey = matchingKeys[0];
315
325
  }
316
326
  } else if (matchingKeys.length === 1) {
@@ -15,6 +15,18 @@
15
15
  "~codeyam/*": ["./packages/*"]
16
16
  },
17
17
  "sourceMap": true,
18
- "skipLibCheck": true
18
+ "skipLibCheck": true,
19
+ "types": [
20
+ "node",
21
+ "jest",
22
+ "jsdom",
23
+ "better-sqlite3",
24
+ "yargs",
25
+ "pg",
26
+ "ws",
27
+ "react",
28
+ "react-dom",
29
+ "react-resizable"
30
+ ]
19
31
  }
20
32
  }
@@ -16,7 +16,7 @@ export async function createAnalyzerTemplate(absoluteCodeyamRootPath) {
16
16
  await copyFolderToArchive({
17
17
  source: folder,
18
18
  destination: `${absoluteCodeyamRootPath}/${folderName}`,
19
- exclude: ['__tests__'],
19
+ exclude: ['__tests__', 'node_modules'],
20
20
  recursive: true,
21
21
  });
22
22
  }
@@ -1 +1 @@
1
- {"version":3,"file":"createLocalAnalyzer.js","sourceRoot":"","sources":["../../../../../../background/src/lib/local/createLocalAnalyzer.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"createLocalAnalyzer.js","sourceRoot":"","sources":["../../../../../../background/src/lib/local/createLocalAnalyzer.ts"],"names":[],"mappings":"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"}
@@ -60,6 +60,28 @@ export default async function analyzeFileEntities({ project, projectAnalyzer, co
60
60
  }
61
61
  }
62
62
  }
63
+ // If still not found at the old file path, search all project files.
64
+ // This handles entity extraction: e.g., MyComponent was moved from
65
+ // src/library/MonolithPage.tsx to src/components/MyComponent.tsx.
66
+ if (!basicEntity && dbEntity) {
67
+ for (const f of filesToIterate) {
68
+ if (f.path === dbEntity.filePath)
69
+ continue; // already checked above
70
+ // Ensure entities are loaded for this file when using fileStore
71
+ let fileToCheck = f;
72
+ if (fileStore && !fileStore.isEntitiesLoaded(f.path)) {
73
+ fileToCheck = await fileStore.ensureEntities(f.path);
74
+ }
75
+ const match = (fileToCheck.entities || []).find((e) => e.name === dbEntity.name);
76
+ if (match) {
77
+ console.log(`CodeYam: Entity "${dbEntity.name}" moved from ${dbEntity.filePath} to ${fileToCheck.path} (old SHA: ${entitySha}, new SHA: ${match.sha})`);
78
+ match.file = fileToCheck;
79
+ basicEntity = match;
80
+ entityShas[ii] = match.sha;
81
+ break;
82
+ }
83
+ }
84
+ }
63
85
  }
64
86
  if (!basicEntity) {
65
87
  // This should be very rare now that we have early validation in prep.ts