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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1199) 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 +27 -27
  4. package/analyzer-template/packages/ai/index.ts +21 -5
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/__mocks__/completionCall.ts +122 -0
  7. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +226 -24
  8. package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
  9. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +217 -13
  10. package/analyzer-template/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.ts +644 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +181 -23
  12. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  13. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.ts +18 -0
  14. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.ts +15 -0
  15. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +181 -1
  16. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +1215 -29
  17. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  18. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +265 -6
  19. package/analyzer-template/packages/ai/src/lib/completionCall.ts +247 -66
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +2020 -334
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +205 -0
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +10 -2
  24. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  25. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  26. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +54 -3
  27. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +129 -20
  28. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  29. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  30. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  31. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  32. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  33. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +393 -90
  34. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
  35. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  36. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +183 -0
  37. package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
  38. package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
  39. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarioData.ts +4 -3
  40. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarios.ts +86 -149
  41. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +59 -3
  42. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +1458 -65
  43. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +200 -196
  44. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +677 -0
  45. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +528 -0
  46. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +2484 -0
  47. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
  48. package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromDescription.ts +5 -5
  49. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +328 -7
  50. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  51. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +111 -87
  52. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  53. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
  54. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.ts +1 -1
  55. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.ts +28 -170
  56. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
  57. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
  58. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +110 -6
  59. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.ts +14 -89
  60. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.ts +58 -0
  61. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.ts +11 -11
  62. package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
  63. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +824 -0
  64. package/analyzer-template/packages/ai/src/lib/splitOutsideParentheses.ts +5 -1
  65. package/analyzer-template/packages/ai/src/lib/validateExecutionFlowPaths.ts +531 -0
  66. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +122 -3
  67. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +114 -2
  68. package/analyzer-template/packages/analyze/index.ts +2 -0
  69. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +65 -59
  70. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +132 -33
  71. package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +44 -4
  72. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  73. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  74. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  75. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  76. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  77. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  78. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  79. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  80. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +447 -255
  81. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +39 -4
  82. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  83. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
  84. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +33 -10
  85. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +14 -14
  86. package/analyzer-template/packages/analyze/src/lib/files/analyzeEntity.ts +4 -4
  87. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +11 -12
  88. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  89. package/analyzer-template/packages/analyze/src/lib/files/enums/steps.ts +1 -1
  90. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  91. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  92. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +193 -76
  93. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +203 -41
  94. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.ts +28 -188
  95. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +355 -23
  96. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +166 -0
  97. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarioData.ts +1 -0
  98. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarios.ts +2 -3
  99. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +845 -72
  100. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +56 -11
  101. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  102. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  103. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  104. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  105. package/analyzer-template/packages/aws/package.json +10 -10
  106. package/analyzer-template/packages/database/index.ts +1 -0
  107. package/analyzer-template/packages/database/package.json +4 -4
  108. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  109. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  110. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  111. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  112. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  113. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  114. package/analyzer-template/packages/database/src/lib/kysely/db.ts +22 -1
  115. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +6 -0
  116. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +17 -1
  117. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +138 -0
  118. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  119. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +58 -1
  120. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +13 -0
  121. package/analyzer-template/packages/database/src/lib/loadBranch.ts +16 -1
  122. package/analyzer-template/packages/database/src/lib/loadCommit.ts +11 -0
  123. package/analyzer-template/packages/database/src/lib/loadCommits.ts +58 -19
  124. package/analyzer-template/packages/database/src/lib/loadEntities.ts +26 -9
  125. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +12 -0
  126. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +5 -6
  127. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  128. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  129. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  130. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +96 -152
  131. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  132. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  133. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  134. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  135. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  136. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  137. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  138. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  139. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  140. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  141. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  142. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  143. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  144. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  145. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  146. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  147. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  148. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  149. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  150. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  151. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  152. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  153. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  154. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +16 -1
  155. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  156. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts +1 -18
  157. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -1
  158. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +1 -0
  159. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -1
  160. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +3 -0
  161. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  162. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +17 -1
  163. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts.map +1 -1
  164. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
  165. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +27 -0
  166. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  167. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +121 -0
  168. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  169. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  170. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  171. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  172. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  173. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +6 -6
  174. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  175. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +2 -0
  176. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -1
  177. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +45 -2
  178. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -1
  179. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  180. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +8 -0
  181. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  182. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +11 -1
  183. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -1
  184. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -1
  185. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +7 -0
  186. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -1
  187. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +3 -1
  188. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  189. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +45 -14
  190. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  191. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +3 -1
  192. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  193. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +23 -10
  194. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  195. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -1
  196. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +9 -0
  197. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -1
  198. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  199. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +5 -5
  200. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  201. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  202. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  203. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  204. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  205. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  206. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  207. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +2 -2
  208. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  209. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +76 -89
  210. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  211. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  212. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  213. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  214. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  215. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  216. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  217. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  218. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  219. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  220. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  221. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  222. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  223. package/analyzer-template/packages/github/dist/types/index.d.ts +3 -4
  224. package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -1
  225. package/analyzer-template/packages/github/dist/types/index.js +0 -1
  226. package/analyzer-template/packages/github/dist/types/index.js.map +1 -1
  227. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  228. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  229. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  230. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  231. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +71 -27
  232. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -1
  233. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +2 -0
  234. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -1
  235. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  236. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  237. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +13 -54
  238. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  239. package/analyzer-template/packages/github/dist/types/src/types/Scenario.js +1 -21
  240. package/analyzer-template/packages/github/dist/types/src/types/Scenario.js.map +1 -1
  241. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +153 -5
  242. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  243. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  244. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  245. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts +2 -0
  246. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  247. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +9 -1
  248. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  249. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +29 -3
  250. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -1
  251. package/analyzer-template/packages/github/package.json +2 -2
  252. package/analyzer-template/packages/types/index.ts +3 -6
  253. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  254. package/analyzer-template/packages/types/src/types/Analysis.ts +87 -27
  255. package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
  256. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  257. package/analyzer-template/packages/types/src/types/Scenario.ts +13 -77
  258. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +181 -5
  259. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  260. package/analyzer-template/packages/types/src/types/StatementInfo.ts +2 -0
  261. package/analyzer-template/packages/ui-components/package.json +1 -1
  262. package/analyzer-template/packages/utils/dist/types/index.d.ts +3 -4
  263. package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -1
  264. package/analyzer-template/packages/utils/dist/types/index.js +0 -1
  265. package/analyzer-template/packages/utils/dist/types/index.js.map +1 -1
  266. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  267. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  268. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  269. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  270. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +71 -27
  271. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -1
  272. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +2 -0
  273. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -1
  274. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  275. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  276. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +13 -54
  277. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  278. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js +1 -21
  279. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.js.map +1 -1
  280. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +153 -5
  281. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  282. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  283. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  284. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts +2 -0
  285. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  286. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  287. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  288. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  289. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +9 -1
  290. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  291. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +29 -3
  292. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -1
  293. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  294. package/analyzer-template/packages/utils/src/lib/safeFileName.ts +48 -3
  295. package/analyzer-template/playwright/capture.ts +20 -8
  296. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  297. package/analyzer-template/playwright/captureStatic.ts +1 -1
  298. package/analyzer-template/playwright/getCodeYamInfo.ts +12 -7
  299. package/analyzer-template/project/analyzeBaselineCommit.ts +9 -0
  300. package/analyzer-template/project/analyzeBranchCommit.ts +4 -0
  301. package/analyzer-template/project/analyzeFileEntities.ts +4 -0
  302. package/analyzer-template/project/analyzeRegularCommit.ts +9 -0
  303. package/analyzer-template/project/captureLibraryFunctionDirect.ts +29 -26
  304. package/analyzer-template/project/constructMockCode.ts +593 -91
  305. package/analyzer-template/project/controller/startController.ts +16 -1
  306. package/analyzer-template/project/createEntitiesAndSortFiles.ts +83 -0
  307. package/analyzer-template/project/executeLibraryFunctionDirect.ts +7 -3
  308. package/analyzer-template/project/loadReadyToBeCaptured.ts +65 -41
  309. package/analyzer-template/project/mocks/analyzeFileMock.ts +8 -7
  310. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
  311. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +18 -7
  312. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
  313. package/analyzer-template/project/orchestrateCapture.ts +75 -7
  314. package/analyzer-template/project/reconcileMockDataKeys.ts +220 -1
  315. package/analyzer-template/project/runAnalysis.ts +6 -0
  316. package/analyzer-template/project/start.ts +49 -12
  317. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  318. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  319. package/analyzer-template/project/writeMockDataTsx.ts +312 -10
  320. package/analyzer-template/project/writeScenarioComponents.ts +314 -43
  321. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  322. package/analyzer-template/scripts/comboWorkerLoop.cjs +98 -50
  323. package/analyzer-template/tsconfig.json +14 -1
  324. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  325. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  326. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +7 -1
  327. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
  328. package/background/src/lib/virtualized/project/analyzeBranchCommit.js +2 -1
  329. package/background/src/lib/virtualized/project/analyzeBranchCommit.js.map +1 -1
  330. package/background/src/lib/virtualized/project/analyzeFileEntities.js +2 -1
  331. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  332. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +7 -1
  333. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
  334. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +3 -3
  335. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -1
  336. package/background/src/lib/virtualized/project/constructMockCode.js +493 -52
  337. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  338. package/background/src/lib/virtualized/project/controller/startController.js +11 -1
  339. package/background/src/lib/virtualized/project/controller/startController.js.map +1 -1
  340. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +73 -1
  341. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -1
  342. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js +6 -3
  343. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js.map +1 -1
  344. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +19 -8
  345. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -1
  346. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js +7 -7
  347. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js.map +1 -1
  348. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +2 -2
  349. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -1
  350. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +7 -5
  351. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
  352. package/background/src/lib/virtualized/project/orchestrateCapture.js +62 -7
  353. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  354. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +184 -1
  355. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  356. package/background/src/lib/virtualized/project/runAnalysis.js +5 -0
  357. package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
  358. package/background/src/lib/virtualized/project/start.js +44 -12
  359. package/background/src/lib/virtualized/project/start.js.map +1 -1
  360. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  361. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  362. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  363. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  364. package/background/src/lib/virtualized/project/writeMockDataTsx.js +263 -6
  365. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  366. package/background/src/lib/virtualized/project/writeScenarioComponents.js +237 -41
  367. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  368. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  369. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  370. package/codeyam-cli/scripts/apply-setup.js +386 -9
  371. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  372. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  373. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  374. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  375. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  376. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  377. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  378. package/codeyam-cli/src/cli.js +35 -24
  379. package/codeyam-cli/src/cli.js.map +1 -1
  380. package/codeyam-cli/src/codeyam-cli.js +18 -2
  381. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  382. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +45 -0
  383. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  384. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  385. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  386. package/codeyam-cli/src/commands/analyze.js +21 -9
  387. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  388. package/codeyam-cli/src/commands/baseline.js +10 -11
  389. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  390. package/codeyam-cli/src/commands/debug.js +37 -23
  391. package/codeyam-cli/src/commands/debug.js.map +1 -1
  392. package/codeyam-cli/src/commands/default.js +43 -35
  393. package/codeyam-cli/src/commands/default.js.map +1 -1
  394. package/codeyam-cli/src/commands/editor.js +3375 -0
  395. package/codeyam-cli/src/commands/editor.js.map +1 -0
  396. package/codeyam-cli/src/commands/init.js +146 -292
  397. package/codeyam-cli/src/commands/init.js.map +1 -1
  398. package/codeyam-cli/src/commands/memory.js +278 -0
  399. package/codeyam-cli/src/commands/memory.js.map +1 -0
  400. package/codeyam-cli/src/commands/recapture.js +31 -18
  401. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  402. package/codeyam-cli/src/commands/report.js +46 -1
  403. package/codeyam-cli/src/commands/report.js.map +1 -1
  404. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  405. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  406. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  407. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  408. package/codeyam-cli/src/commands/start.js +8 -12
  409. package/codeyam-cli/src/commands/start.js.map +1 -1
  410. package/codeyam-cli/src/commands/test-startup.js +2 -0
  411. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  412. package/codeyam-cli/src/commands/verify.js +14 -2
  413. package/codeyam-cli/src/commands/verify.js.map +1 -1
  414. package/codeyam-cli/src/data/techStacks.js +77 -0
  415. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  416. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  417. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  418. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  419. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  420. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  421. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  422. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +137 -0
  423. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  424. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +987 -0
  425. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  426. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  427. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  428. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  429. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  430. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  431. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  432. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  433. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  434. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  435. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  436. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  437. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  438. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  439. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  440. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  441. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  442. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +353 -0
  443. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  444. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  445. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  446. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  447. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  448. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  449. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  450. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1059 -0
  451. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  452. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  453. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  454. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  455. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  456. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  457. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  458. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  459. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  460. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  461. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  462. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  463. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  464. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  465. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  466. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  467. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  468. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  469. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  470. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  471. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  472. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +454 -0
  473. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  474. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js +81 -0
  475. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js.map +1 -0
  476. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +174 -82
  477. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  478. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  479. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  480. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  481. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  482. package/codeyam-cli/src/utils/analysisRunner.js +29 -15
  483. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  484. package/codeyam-cli/src/utils/analyzer.js +16 -0
  485. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  486. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  487. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  488. package/codeyam-cli/src/utils/backgroundServer.js +202 -29
  489. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  490. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  491. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  492. package/codeyam-cli/src/utils/database.js +37 -2
  493. package/codeyam-cli/src/utils/database.js.map +1 -1
  494. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  495. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  496. package/codeyam-cli/src/utils/devServerState.js +71 -0
  497. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  498. package/codeyam-cli/src/utils/editorApi.js +79 -0
  499. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  500. package/codeyam-cli/src/utils/editorAudit.js +210 -0
  501. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  502. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  503. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  504. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  505. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  506. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  507. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  508. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  509. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  510. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  511. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  512. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  513. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  514. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  515. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  516. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  517. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  518. package/codeyam-cli/src/utils/editorPreview.js +137 -0
  519. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  520. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  521. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  522. package/codeyam-cli/src/utils/editorScenarios.js +387 -0
  523. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  524. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  525. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  526. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  527. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  528. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  529. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  530. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  531. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  532. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  533. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  534. package/codeyam-cli/src/utils/generateReport.js +4 -3
  535. package/codeyam-cli/src/utils/generateReport.js.map +1 -1
  536. package/codeyam-cli/src/utils/git.js +103 -0
  537. package/codeyam-cli/src/utils/git.js.map +1 -1
  538. package/codeyam-cli/src/utils/install-skills.js +120 -39
  539. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  540. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  541. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  542. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  543. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  544. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  545. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  546. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  547. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  548. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  549. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  550. package/codeyam-cli/src/utils/progress.js +8 -1
  551. package/codeyam-cli/src/utils/progress.js.map +1 -1
  552. package/codeyam-cli/src/utils/project.js +15 -5
  553. package/codeyam-cli/src/utils/project.js.map +1 -1
  554. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  555. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  556. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  557. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  558. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  559. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  560. package/codeyam-cli/src/utils/queue/job.js +75 -1
  561. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  562. package/codeyam-cli/src/utils/queue/manager.js +7 -0
  563. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  564. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  565. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  566. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  567. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  568. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  569. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  570. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  571. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  572. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  573. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  574. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  575. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  576. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  577. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  578. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  579. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  580. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  581. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  582. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  583. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  584. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  585. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  586. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  587. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  588. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  589. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  590. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  591. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  592. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  593. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  594. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  595. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  596. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  597. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  598. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  599. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  600. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  601. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  602. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  603. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  604. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  605. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  606. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  607. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  608. package/codeyam-cli/src/utils/rules/index.js +7 -0
  609. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  610. package/codeyam-cli/src/utils/rules/parser.js +93 -0
  611. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  612. package/codeyam-cli/src/utils/rules/pathMatcher.js +49 -0
  613. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  614. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  615. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  616. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  617. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  618. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  619. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  620. package/codeyam-cli/src/utils/rules/staleness.js +137 -0
  621. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  622. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  623. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  624. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  625. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  626. package/codeyam-cli/src/utils/scenariosManifest.js +241 -0
  627. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  628. package/codeyam-cli/src/utils/serverState.js +94 -12
  629. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  630. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +95 -45
  631. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  632. package/codeyam-cli/src/utils/simulationGateMiddleware.js +166 -0
  633. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  634. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  635. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  636. package/codeyam-cli/src/utils/syncMocksMiddleware.js +7 -26
  637. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  638. package/codeyam-cli/src/utils/testRunner.js +158 -0
  639. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  640. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  641. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  642. package/codeyam-cli/src/utils/versionInfo.js +67 -15
  643. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  644. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  645. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  646. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +40 -0
  647. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  648. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  649. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  650. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +567 -0
  651. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  652. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +146 -0
  653. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  654. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  655. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  656. package/codeyam-cli/src/webserver/app/lib/database.js +63 -33
  657. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  658. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  659. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  660. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  661. package/codeyam-cli/src/webserver/backgroundServer.js +166 -16
  662. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  663. package/codeyam-cli/src/webserver/bootstrap.js +51 -0
  664. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  665. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-BPXZwM4t.js +1 -0
  666. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-BcgbViKV.js +11 -0
  667. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-g3saevPb.js} +1 -1
  668. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-CQIG2qda.js +41 -0
  669. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  670. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-DYFW3lDD.js +25 -0
  671. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  672. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BU_OAEMP.js} +1 -1
  673. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-ceAyBX-H.js} +1 -1
  674. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-BzHcG7SE.js +11 -0
  675. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-BED4B6sP.js} +1 -1
  676. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-TSD3C211.js +10 -0
  677. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  678. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  679. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  680. package/codeyam-cli/src/webserver/build/client/assets/_index-DLxKhri3.js +11 -0
  681. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BcY3q6nt.js +27 -0
  682. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  683. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  684. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  685. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  686. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bni3iiUj.js +22 -0
  687. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  688. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  689. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  690. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  691. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  692. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  693. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  694. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  695. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  696. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  697. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  698. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  699. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  700. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  701. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  702. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  703. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  704. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  705. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  706. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  707. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  708. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  709. package/codeyam-cli/src/webserver/build/client/assets/api.health-l0sNRNKZ.js +1 -0
  710. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  711. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  712. package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
  713. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  714. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  715. package/codeyam-cli/src/webserver/build/client/assets/book-open-BYOypzCa.js +6 -0
  716. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-C_Pmso5S.js} +2 -2
  717. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-C4pqxYJB.js} +12 -12
  718. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-BVMi9VA5.js} +2 -2
  719. package/codeyam-cli/src/webserver/build/client/assets/copy-n2FB0_Sw.js +11 -0
  720. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  721. package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-C1gnJVOL.svg → cy-logo-cli-CCKUIm0S.svg} +2 -2
  722. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +1 -0
  723. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Ii3inc0_.js +1 -0
  724. package/codeyam-cli/src/webserver/build/client/assets/editor-COWCNVyV.js +10 -0
  725. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-CNB06EIa.js +41 -0
  726. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-D0-YwkBh.js → entity._sha._-DwCV5__E.js} +13 -13
  727. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-CXSi2aeZ.js +6 -0
  728. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CHMiAog3.js +6 -0
  729. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  730. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-C1H_a_Y3.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  731. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-DTvKq3TY.js} +1 -1
  732. package/codeyam-cli/src/webserver/build/client/assets/executionFlowCoverage-BWhdfn70.js +1 -0
  733. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-cPo8LiG3.js} +1 -1
  734. package/codeyam-cli/src/webserver/build/client/assets/files-BZrlFE1F.js +1 -0
  735. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  736. package/codeyam-cli/src/webserver/build/client/assets/globals-phvmGvat.css +1 -0
  737. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-10oVnAAH.js} +1 -1
  738. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-BcvgDzbZ.js} +1 -1
  739. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  740. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  741. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-DaAZ_H2w.js} +2 -2
  742. package/codeyam-cli/src/webserver/build/client/assets/manifest-6134dc40.js +1 -0
  743. package/codeyam-cli/src/webserver/build/client/assets/memory-9gnxSZlb.js +101 -0
  744. package/codeyam-cli/src/webserver/build/client/assets/pause-f5-1lKBt.js +11 -0
  745. package/codeyam-cli/src/webserver/build/client/assets/root-BWAyuj0r.js +67 -0
  746. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-Di64LWVb.js} +2 -2
  747. package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +1 -0
  748. package/codeyam-cli/src/webserver/build/client/assets/simulations-DWT-CvLy.js +1 -0
  749. package/codeyam-cli/src/webserver/build/client/assets/terminal-Br7MOqts.js +11 -0
  750. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-BLdiCuG-.js} +2 -2
  751. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C-_hOl_g.js +1 -0
  752. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  753. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-O-jkvSPx.js +1 -0
  754. package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-9FIWuYfK.js} +1 -1
  755. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  756. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  757. package/codeyam-cli/src/webserver/build/server/assets/index-ChX0hPcu.js +1 -0
  758. package/codeyam-cli/src/webserver/build/server/assets/init-kSNsMjj8.js +10 -0
  759. package/codeyam-cli/src/webserver/build/server/assets/server-build-Bm2xIhmh.js +439 -0
  760. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  761. package/codeyam-cli/src/webserver/build-info.json +5 -5
  762. package/codeyam-cli/src/webserver/devServer.js +39 -5
  763. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  764. package/codeyam-cli/src/webserver/editorProxy.js +877 -0
  765. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  766. package/codeyam-cli/src/webserver/idleDetector.js +73 -0
  767. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  768. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  769. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  770. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  771. package/codeyam-cli/src/webserver/server.js +335 -26
  772. package/codeyam-cli/src/webserver/server.js.map +1 -1
  773. package/codeyam-cli/src/webserver/terminalServer.js +735 -0
  774. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  775. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  776. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  777. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  778. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  779. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  780. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  781. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  782. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  783. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  784. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  785. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  786. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  787. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  788. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  789. package/codeyam-cli/templates/codeyam-editor-claude.md +147 -0
  790. package/codeyam-cli/templates/codeyam-memory-hook.sh +199 -0
  791. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  792. package/codeyam-cli/templates/editor-step-hook.py +237 -0
  793. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  794. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  795. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  796. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  797. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  798. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  799. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  800. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  801. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  802. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  803. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  804. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  805. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  806. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  807. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  808. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  809. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  810. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  811. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  812. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  813. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  814. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  815. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  816. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  817. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  818. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  819. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  820. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  821. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  822. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  823. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  824. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  825. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  826. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  827. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  828. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  829. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  830. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  831. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  832. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  833. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  834. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  835. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  836. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  837. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  838. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  839. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  840. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  841. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  842. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  843. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  844. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  845. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  846. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  847. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  848. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  849. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  850. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  851. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  852. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  853. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  854. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  855. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  856. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  857. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  858. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  859. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  860. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  861. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  862. package/codeyam-cli/templates/rule-reflection-hook.py +647 -0
  863. package/codeyam-cli/templates/rules-instructions.md +78 -0
  864. package/codeyam-cli/templates/{codeyam-debug-skill.md → skills/codeyam-debug/SKILL.md} +48 -4
  865. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  866. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +149 -0
  867. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  868. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  869. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  870. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  871. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  872. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  873. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  874. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  875. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  876. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  877. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  878. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  879. package/codeyam-cli/templates/{codeyam-setup-skill.md → skills/codeyam-setup/SKILL.md} +13 -1
  880. package/codeyam-cli/templates/{codeyam-sim-skill.md → skills/codeyam-sim/SKILL.md} +1 -1
  881. package/codeyam-cli/templates/{codeyam-test-skill.md → skills/codeyam-test/SKILL.md} +1 -1
  882. package/codeyam-cli/templates/{codeyam-verify-skill.md → skills/codeyam-verify/SKILL.md} +1 -1
  883. package/package.json +32 -22
  884. package/packages/ai/index.js +8 -6
  885. package/packages/ai/index.js.map +1 -1
  886. package/packages/ai/src/lib/analyzeScope.js +179 -13
  887. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  888. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
  889. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
  890. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +160 -13
  891. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  892. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js +435 -0
  893. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js.map +1 -0
  894. package/packages/ai/src/lib/astScopes/methodSemantics.js +138 -23
  895. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  896. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  897. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  898. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js +8 -0
  899. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js.map +1 -1
  900. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js +7 -0
  901. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js.map +1 -1
  902. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +138 -1
  903. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
  904. package/packages/ai/src/lib/astScopes/processExpression.js +931 -29
  905. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  906. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  907. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  908. package/packages/ai/src/lib/completionCall.js +188 -38
  909. package/packages/ai/src/lib/completionCall.js.map +1 -1
  910. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +1600 -189
  911. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  912. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  913. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  914. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +179 -0
  915. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -1
  916. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +7 -1
  917. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -1
  918. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  919. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  920. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  921. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  922. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +52 -3
  923. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  924. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +111 -14
  925. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  926. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  927. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  928. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  929. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  930. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  931. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  932. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  933. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  934. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  935. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  936. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +333 -81
  937. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  938. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
  939. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
  940. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  941. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  942. package/packages/ai/src/lib/dataStructureChunking.js +130 -0
  943. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
  944. package/packages/ai/src/lib/e2eDataTracking.js +241 -0
  945. package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
  946. package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
  947. package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
  948. package/packages/ai/src/lib/generateChangesEntityScenarioData.js +4 -3
  949. package/packages/ai/src/lib/generateChangesEntityScenarioData.js.map +1 -1
  950. package/packages/ai/src/lib/generateChangesEntityScenarios.js +78 -120
  951. package/packages/ai/src/lib/generateChangesEntityScenarios.js.map +1 -1
  952. package/packages/ai/src/lib/generateEntityDataStructure.js +47 -2
  953. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  954. package/packages/ai/src/lib/generateEntityScenarioData.js +1153 -60
  955. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  956. package/packages/ai/src/lib/generateEntityScenarios.js +177 -163
  957. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  958. package/packages/ai/src/lib/generateExecutionFlows.js +484 -0
  959. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -0
  960. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js +380 -0
  961. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js.map +1 -0
  962. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +1807 -0
  963. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -0
  964. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
  965. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
  966. package/packages/ai/src/lib/guessScenarioDataFromDescription.js +2 -2
  967. package/packages/ai/src/lib/guessScenarioDataFromDescription.js.map +1 -1
  968. package/packages/ai/src/lib/isolateScopes.js +270 -7
  969. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  970. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  971. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  972. package/packages/ai/src/lib/mergeStatements.js +88 -46
  973. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  974. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  975. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  976. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
  977. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  978. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js +1 -1
  979. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js.map +1 -1
  980. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js +21 -119
  981. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js.map +1 -1
  982. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
  983. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
  984. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +83 -6
  985. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  986. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js +10 -70
  987. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js.map +1 -1
  988. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js +45 -0
  989. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js.map +1 -0
  990. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js +9 -9
  991. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js.map +1 -1
  992. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
  993. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
  994. package/packages/ai/src/lib/resolvePathToControllable.js +677 -0
  995. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -0
  996. package/packages/ai/src/lib/splitOutsideParentheses.js +3 -1
  997. package/packages/ai/src/lib/splitOutsideParentheses.js.map +1 -1
  998. package/packages/ai/src/lib/worker/SerializableDataStructure.js +29 -0
  999. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  1000. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +94 -1
  1001. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
  1002. package/packages/analyze/index.js +1 -0
  1003. package/packages/analyze/index.js.map +1 -1
  1004. package/packages/analyze/src/lib/FileAnalyzer.js +60 -36
  1005. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  1006. package/packages/analyze/src/lib/ProjectAnalyzer.js +109 -30
  1007. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  1008. package/packages/analyze/src/lib/analysisContext.js +30 -5
  1009. package/packages/analyze/src/lib/analysisContext.js.map +1 -1
  1010. package/packages/analyze/src/lib/asts/index.js +4 -2
  1011. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  1012. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  1013. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  1014. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  1015. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  1016. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  1017. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  1018. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  1019. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  1020. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  1021. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  1022. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  1023. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  1024. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  1025. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  1026. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +189 -41
  1027. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  1028. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +28 -4
  1029. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  1030. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  1031. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  1032. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
  1033. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  1034. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +31 -10
  1035. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  1036. package/packages/analyze/src/lib/files/analyzeChange.js +10 -10
  1037. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  1038. package/packages/analyze/src/lib/files/analyzeEntity.js +4 -4
  1039. package/packages/analyze/src/lib/files/analyzeEntity.js.map +1 -1
  1040. package/packages/analyze/src/lib/files/analyzeInitial.js +9 -10
  1041. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  1042. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  1043. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  1044. package/packages/analyze/src/lib/files/enums/steps.js +1 -1
  1045. package/packages/analyze/src/lib/files/enums/steps.js.map +1 -1
  1046. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  1047. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  1048. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  1049. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  1050. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +164 -68
  1051. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  1052. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +178 -31
  1053. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  1054. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js +29 -129
  1055. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js.map +1 -1
  1056. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +252 -21
  1057. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  1058. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +104 -0
  1059. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -0
  1060. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js +1 -0
  1061. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js.map +1 -1
  1062. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js +2 -3
  1063. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js.map +1 -1
  1064. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +686 -55
  1065. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  1066. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +46 -9
  1067. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -1
  1068. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  1069. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  1070. package/packages/analyze/src/lib/index.js +1 -0
  1071. package/packages/analyze/src/lib/index.js.map +1 -1
  1072. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  1073. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  1074. package/packages/database/index.js +1 -0
  1075. package/packages/database/index.js.map +1 -1
  1076. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  1077. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  1078. package/packages/database/src/lib/analysisToDb.js +1 -1
  1079. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  1080. package/packages/database/src/lib/branchToDb.js +1 -1
  1081. package/packages/database/src/lib/branchToDb.js.map +1 -1
  1082. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  1083. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  1084. package/packages/database/src/lib/commitToDb.js +1 -1
  1085. package/packages/database/src/lib/commitToDb.js.map +1 -1
  1086. package/packages/database/src/lib/fileToDb.js +1 -1
  1087. package/packages/database/src/lib/fileToDb.js.map +1 -1
  1088. package/packages/database/src/lib/kysely/db.js +16 -1
  1089. package/packages/database/src/lib/kysely/db.js.map +1 -1
  1090. package/packages/database/src/lib/kysely/tables/commitsTable.js +3 -0
  1091. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  1092. package/packages/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
  1093. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +121 -0
  1094. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  1095. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  1096. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  1097. package/packages/database/src/lib/loadAnalyses.js +45 -2
  1098. package/packages/database/src/lib/loadAnalyses.js.map +1 -1
  1099. package/packages/database/src/lib/loadAnalysis.js +8 -0
  1100. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  1101. package/packages/database/src/lib/loadBranch.js +11 -1
  1102. package/packages/database/src/lib/loadBranch.js.map +1 -1
  1103. package/packages/database/src/lib/loadCommit.js +7 -0
  1104. package/packages/database/src/lib/loadCommit.js.map +1 -1
  1105. package/packages/database/src/lib/loadCommits.js +45 -14
  1106. package/packages/database/src/lib/loadCommits.js.map +1 -1
  1107. package/packages/database/src/lib/loadEntities.js +23 -10
  1108. package/packages/database/src/lib/loadEntities.js.map +1 -1
  1109. package/packages/database/src/lib/loadEntityBranches.js +9 -0
  1110. package/packages/database/src/lib/loadEntityBranches.js.map +1 -1
  1111. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +5 -5
  1112. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  1113. package/packages/database/src/lib/projectToDb.js +1 -1
  1114. package/packages/database/src/lib/projectToDb.js.map +1 -1
  1115. package/packages/database/src/lib/saveFiles.js +1 -1
  1116. package/packages/database/src/lib/saveFiles.js.map +1 -1
  1117. package/packages/database/src/lib/scenarioToDb.js +1 -1
  1118. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  1119. package/packages/database/src/lib/updateCommitMetadata.js +76 -89
  1120. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  1121. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  1122. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  1123. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  1124. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  1125. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  1126. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  1127. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  1128. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  1129. package/packages/types/index.js +0 -1
  1130. package/packages/types/index.js.map +1 -1
  1131. package/packages/types/src/enums/ProjectFramework.js +2 -0
  1132. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  1133. package/packages/types/src/types/Scenario.js +1 -21
  1134. package/packages/types/src/types/Scenario.js.map +1 -1
  1135. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  1136. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  1137. package/packages/utils/src/lib/safeFileName.js +29 -3
  1138. package/packages/utils/src/lib/safeFileName.js.map +1 -1
  1139. package/scripts/npm-post-install.cjs +34 -0
  1140. package/analyzer-template/packages/ai/src/lib/findMatchingAttribute.ts +0 -109
  1141. package/analyzer-template/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.ts +0 -584
  1142. package/analyzer-template/packages/ai/src/lib/generateChangesEntityKeyAttributes.ts +0 -341
  1143. package/analyzer-template/packages/ai/src/lib/generateEntityKeyAttributes.ts +0 -495
  1144. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.ts +0 -67
  1145. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.ts +0 -120
  1146. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  1147. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  1148. package/codeyam-cli/src/commands/list.js +0 -31
  1149. package/codeyam-cli/src/commands/list.js.map +0 -1
  1150. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  1151. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  1152. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  1153. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  1154. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-Cmysw5OP.js +0 -1
  1155. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-CAneekK2.js +0 -41
  1156. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-Cu16OUmx.js +0 -25
  1157. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-DcAUIpD_.js +0 -11
  1158. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-BMKg0SAF.js +0 -15
  1159. package/codeyam-cli/src/webserver/build/client/assets/_index-DSmTpjmK.js +0 -11
  1160. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BF_aK4y6.js +0 -32
  1161. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
  1162. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-CKnwPCDr.js +0 -1
  1163. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-RJCf3Tvw.js +0 -1
  1164. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-EylcgScH.js +0 -1
  1165. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DMe7kvgo.js +0 -1
  1166. package/codeyam-cli/src/webserver/build/client/assets/files-BW7Cyeyi.js +0 -1
  1167. package/codeyam-cli/src/webserver/build/client/assets/git-CZu4fif0.js +0 -15
  1168. package/codeyam-cli/src/webserver/build/client/assets/globals-wHVy_II5.css +0 -1
  1169. package/codeyam-cli/src/webserver/build/client/assets/keyAttributeCoverage-CTlFMihX.js +0 -1
  1170. package/codeyam-cli/src/webserver/build/client/assets/manifest-2d191949.js +0 -1
  1171. package/codeyam-cli/src/webserver/build/client/assets/root-FHgpM6gc.js +0 -56
  1172. package/codeyam-cli/src/webserver/build/client/assets/settings-6D8k8Jp5.js +0 -1
  1173. package/codeyam-cli/src/webserver/build/client/assets/simulations-CDJZnWhN.js +0 -1
  1174. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-Dv18q8LD.js +0 -1
  1175. package/codeyam-cli/src/webserver/build/client/assets/useInteractiveMode-0ToGk4K3.js +0 -1
  1176. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  1177. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-1BX144Eg.js +0 -1
  1178. package/codeyam-cli/src/webserver/build/server/assets/index-pU0o5t1o.js +0 -1
  1179. package/codeyam-cli/src/webserver/build/server/assets/server-build-YzfkRwdn.js +0 -178
  1180. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  1181. package/codeyam-cli/templates/debug-codeyam.md +0 -625
  1182. package/packages/ai/src/lib/findMatchingAttribute.js +0 -81
  1183. package/packages/ai/src/lib/findMatchingAttribute.js.map +0 -1
  1184. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js +0 -425
  1185. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js.map +0 -1
  1186. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js +0 -267
  1187. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js.map +0 -1
  1188. package/packages/ai/src/lib/generateEntityKeyAttributes.js +0 -408
  1189. package/packages/ai/src/lib/generateEntityKeyAttributes.js.map +0 -1
  1190. package/packages/ai/src/lib/isFrontend.js +0 -5
  1191. package/packages/ai/src/lib/isFrontend.js.map +0 -1
  1192. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js +0 -40
  1193. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js.map +0 -1
  1194. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js +0 -77
  1195. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js.map +0 -1
  1196. package/scripts/finalize-analyzer.cjs +0 -81
  1197. /package/codeyam-cli/src/webserver/build/client/assets/{api.link-scenario-value-l0sNRNKZ.js → api.agent-transcripts-l0sNRNKZ.js} +0 -0
  1198. /package/codeyam-cli/src/webserver/build/client/assets/{api.update-key-attributes-l0sNRNKZ.js → api.dev-mode-events-l0sNRNKZ.js} +0 -0
  1199. /package/codeyam-cli/src/webserver/build/client/assets/{api.update-valid-values-l0sNRNKZ.js → api.editor-audit-l0sNRNKZ.js} +0 -0
@@ -3,8 +3,245 @@ import * as crypto from 'crypto';
3
3
  import { StructuredPath } from "./paths.js";
4
4
  import { nodeToSource } from "./nodeToSource.js";
5
5
  import { methodRegistry, ArrayPushSemantics } from "./methodSemantics.js";
6
- import { isArithmeticOperator, isAssignmentOperator, isBitwiseCompoundOperator, isComparisonOperator, isDefinedType, isNumericCompoundOperator, leftOrRightType, unwrapExpression, } from "./sharedPatterns.js";
6
+ import { getComparisonOperatorString, isArithmeticOperator, isAssignmentOperator, isBitwiseCompoundOperator, isComparisonOperator, isDefinedType, isNumericCompoundOperator, leftOrRightType, unwrapExpression, } from "./sharedPatterns.js";
7
7
  import { processBindingPattern } from "./processBindings.js";
8
+ import { extractConditionalEffectsFromTernary, findUseStateSetters, } from "./conditionalEffectsExtractor.js";
9
+ import { detectArrayDerivedPattern } from "./arrayDerivationDetector.js";
10
+ /**
11
+ * Recursively extracts root variable names from an expression AST node.
12
+ * Used to identify which variables flow into JSX expression children,
13
+ * so we can link them to the return value schema.
14
+ *
15
+ * Examples:
16
+ * - `filteredTopPaths.map(...)` → ['filteredTopPaths']
17
+ * - `a && b` → ['a', 'b']
18
+ * - `condition ? x : y` → ['condition', 'x', 'y']
19
+ */
20
+ function extractRootVariableNames(node) {
21
+ const ignoredIdentifiers = new Set([
22
+ 'undefined',
23
+ 'null',
24
+ 'true',
25
+ 'false',
26
+ 'NaN',
27
+ 'Infinity',
28
+ ]);
29
+ if (ts.isIdentifier(node)) {
30
+ const name = node.text;
31
+ return ignoredIdentifiers.has(name) ? [] : [name];
32
+ }
33
+ if (ts.isPropertyAccessExpression(node)) {
34
+ return extractRootVariableNames(node.expression);
35
+ }
36
+ if (ts.isCallExpression(node)) {
37
+ return extractRootVariableNames(node.expression);
38
+ }
39
+ if (ts.isBinaryExpression(node)) {
40
+ return [
41
+ ...extractRootVariableNames(node.left),
42
+ ...extractRootVariableNames(node.right),
43
+ ];
44
+ }
45
+ if (ts.isPrefixUnaryExpression(node)) {
46
+ return extractRootVariableNames(node.operand);
47
+ }
48
+ if (ts.isConditionalExpression(node)) {
49
+ return [
50
+ ...extractRootVariableNames(node.condition),
51
+ ...extractRootVariableNames(node.whenTrue),
52
+ ...extractRootVariableNames(node.whenFalse),
53
+ ];
54
+ }
55
+ if (ts.isParenthesizedExpression(node)) {
56
+ return extractRootVariableNames(node.expression);
57
+ }
58
+ // Stop recursion at JSX elements and other terminal nodes
59
+ if (ts.isJsxElement(node) ||
60
+ ts.isJsxFragment(node) ||
61
+ ts.isJsxSelfClosingElement(node)) {
62
+ return [];
63
+ }
64
+ return [];
65
+ }
66
+ /**
67
+ * Checks if a JSX element has props that reference variables from the parent scope.
68
+ * This is used to detect unconditionally-rendered children that should have their
69
+ * execution flows merged into the parent.
70
+ *
71
+ * We want to track children where the parent controls data that affects the child's
72
+ * conditional rendering. Static props (like title="Dashboard") don't need tracking
73
+ * because they don't create variable execution flows.
74
+ *
75
+ * Examples:
76
+ * - <WorkoutsView workouts={workouts} /> → true (workouts is a variable)
77
+ * - <ItemList items={items} count={count} /> → true (items, count are variables)
78
+ * - <Header title="Dashboard" /> → false (static string)
79
+ * - <Footer /> → false (no props)
80
+ * - <Button onClick={handleClick} /> → false (only callback, no data props)
81
+ *
82
+ * @returns true if the component has at least one prop that references a variable
83
+ * (excluding callbacks which typically start with 'on' or 'handle')
84
+ */
85
+ function hasDataPropsFromParent(node, componentName) {
86
+ const attributes = ts.isJsxElement(node)
87
+ ? node.openingElement.attributes.properties
88
+ : node.attributes.properties;
89
+ const dataProps = [];
90
+ for (const attr of attributes) {
91
+ // Spread attributes always reference parent data: {...props}
92
+ if (ts.isJsxSpreadAttribute(attr)) {
93
+ const spreadText = attr.expression?.getText() || '...spread';
94
+ dataProps.push(`{...${spreadText}}`);
95
+ console.log(`[UnconditionalChild] ${componentName}: Found spread attribute {${spreadText}}`);
96
+ continue;
97
+ }
98
+ if (ts.isJsxAttribute(attr)) {
99
+ const propName = attr.name.getText();
100
+ // Skip callback props - they don't create data-driven execution flows
101
+ // Callbacks typically start with 'on' (onClick, onChange) or 'handle' (handleSubmit)
102
+ if (propName.startsWith('on') ||
103
+ propName.startsWith('handle') ||
104
+ propName === 'ref') {
105
+ console.log(`[UnconditionalChild] ${componentName}: Skipping callback prop '${propName}'`);
106
+ continue;
107
+ }
108
+ // Check if the prop value is a JSX expression (references a variable)
109
+ // vs a string literal which is static
110
+ if (attr.initializer) {
111
+ if (ts.isJsxExpression(attr.initializer)) {
112
+ // JSX expression like prop={value} - this references a variable
113
+ // Could be a simple identifier, property access, or more complex expression
114
+ const expression = attr.initializer.expression;
115
+ if (expression) {
116
+ // Skip if it's just a function/arrow function (callback)
117
+ if (ts.isArrowFunction(expression) ||
118
+ ts.isFunctionExpression(expression)) {
119
+ console.log(`[UnconditionalChild] ${componentName}: Skipping inline callback prop '${propName}'`);
120
+ continue;
121
+ }
122
+ // This is a data prop that references parent state/props
123
+ const exprText = expression.getText();
124
+ dataProps.push(`${propName}={${exprText}}`);
125
+ console.log(`[UnconditionalChild] ${componentName}: Found data prop '${propName}' = {${exprText}}`);
126
+ }
127
+ }
128
+ else {
129
+ // String literals like prop="value" are static
130
+ console.log(`[UnconditionalChild] ${componentName}: Skipping static prop '${propName}'`);
131
+ }
132
+ }
133
+ }
134
+ }
135
+ const hasDataProps = dataProps.length > 0;
136
+ if (hasDataProps) {
137
+ console.log(`[UnconditionalChild] ${componentName}: Has ${dataProps.length} data props: [${dataProps.join(', ')}]`);
138
+ }
139
+ else {
140
+ console.log(`[UnconditionalChild] ${componentName}: No data props found, will NOT track`);
141
+ }
142
+ return { hasDataProps, dataProps };
143
+ }
144
+ /**
145
+ * Extracts the component name from a JSX element.
146
+ * Returns null for intrinsic elements (div, span, etc.) since we only care about
147
+ * custom components for gating condition tracking.
148
+ *
149
+ * Examples:
150
+ * - <ChildViewer /> → "ChildViewer"
151
+ * - <ScenarioViewer scenario={...} /> → "ScenarioViewer"
152
+ * - <div> → null (intrinsic element)
153
+ */
154
+ function getComponentNameFromJsx(node) {
155
+ let tagName;
156
+ if (ts.isJsxElement(node)) {
157
+ tagName = node.openingElement.tagName;
158
+ }
159
+ else {
160
+ tagName = node.tagName;
161
+ }
162
+ // Get the text of the tag name
163
+ const name = tagName.getText();
164
+ // Check if it's a custom component (starts with uppercase) vs intrinsic element
165
+ // Custom components start with uppercase: <MyComponent />
166
+ // Intrinsic elements start with lowercase: <div />
167
+ if (name &&
168
+ name[0] === name[0].toUpperCase() &&
169
+ name[0] !== name[0].toLowerCase()) {
170
+ return name;
171
+ }
172
+ return null;
173
+ }
174
+ /**
175
+ * Extracts condition paths from a logical AND chain expression.
176
+ * Used for creating gating conditions for child components.
177
+ *
178
+ * Example: `hasData && isReady && <Component />` returns ['hasData', 'isReady']
179
+ */
180
+ function extractConditionPathsFromAndChain(expr, sourceFile) {
181
+ const paths = [];
182
+ const unwrapped = unwrapExpression(expr);
183
+ if (ts.isBinaryExpression(unwrapped) &&
184
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken) {
185
+ // Recursively get conditions from left side
186
+ paths.push(...extractConditionPathsFromAndChain(unwrapped.left, sourceFile));
187
+ // Process right side if it's not JSX (JSX is the consequence, not a condition)
188
+ const rightUnwrapped = unwrapExpression(unwrapped.right);
189
+ if (!ts.isJsxElement(rightUnwrapped) &&
190
+ !ts.isJsxSelfClosingElement(rightUnwrapped) &&
191
+ !ts.isJsxFragment(rightUnwrapped)) {
192
+ paths.push(...extractConditionPathsFromAndChain(unwrapped.right, sourceFile));
193
+ }
194
+ }
195
+ else {
196
+ // Base case: extract path from this expression
197
+ const path = StructuredPath.fromNode(unwrapped, sourceFile);
198
+ if (path) {
199
+ paths.push(path.toString());
200
+ }
201
+ }
202
+ return paths;
203
+ }
204
+ /**
205
+ * Finds the rightmost JSX element in an && chain.
206
+ * Example: `a && b && <Component />` returns <Component />
207
+ */
208
+ function findJsxInAndChain(expr) {
209
+ const unwrapped = unwrapExpression(expr);
210
+ if (ts.isJsxElement(unwrapped) || ts.isJsxSelfClosingElement(unwrapped)) {
211
+ return unwrapped;
212
+ }
213
+ if (ts.isBinaryExpression(unwrapped) &&
214
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken) {
215
+ // Check right side first (most common case: condition && <Jsx />)
216
+ const rightResult = findJsxInAndChain(unwrapped.right);
217
+ if (rightResult)
218
+ return rightResult;
219
+ // Also check left side for rare cases
220
+ return findJsxInAndChain(unwrapped.left);
221
+ }
222
+ return null;
223
+ }
224
+ /**
225
+ * Fix 32: Finds a JSX fragment in an && chain.
226
+ * Example: `activeTab && <><ChildA /><ChildB /></>` returns the fragment
227
+ * This is needed to propagate parent conditions through fragments.
228
+ */
229
+ function findJsxFragmentInAndChain(expr) {
230
+ const unwrapped = unwrapExpression(expr);
231
+ if (ts.isJsxFragment(unwrapped)) {
232
+ return unwrapped;
233
+ }
234
+ if (ts.isBinaryExpression(unwrapped) &&
235
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken) {
236
+ // Check right side first (most common case: condition && <></>)
237
+ const rightResult = findJsxFragmentInAndChain(unwrapped.right);
238
+ if (rightResult)
239
+ return rightResult;
240
+ // Also check left side for rare cases
241
+ return findJsxFragmentInAndChain(unwrapped.left);
242
+ }
243
+ return null;
244
+ }
8
245
  /**
9
246
  * Detects if a property access looks like an environment variable store access.
10
247
  * Matches patterns like `env.DATABASE_URL`, `env.IS_FORMBRICKS_CLOUD`, etc.
@@ -171,6 +408,123 @@ function getSourceLocation(node, sourceFile) {
171
408
  : codeSnippet,
172
409
  };
173
410
  }
411
+ /**
412
+ * Extracts the root array path from an expression that ends with .map().
413
+ * Handles chained methods like .filter().map(), .slice().map(), etc.
414
+ *
415
+ * Examples:
416
+ * - items.map(...) → "items"
417
+ * - data.users.map(...) → "data.users"
418
+ * - items.filter(...).map(...) → "items"
419
+ * - items.slice(0, 5).map(...) → "items"
420
+ */
421
+ function extractArrayPathFromMapCall(expr, sourceFile) {
422
+ // Walk up the chain to find the root array
423
+ let current = expr.expression;
424
+ while (ts.isPropertyAccessExpression(current)) {
425
+ const methodName = current.name.getText(sourceFile);
426
+ // Common array methods that return arrays (so we keep going up)
427
+ const arrayReturningMethods = [
428
+ 'map',
429
+ 'filter',
430
+ 'slice',
431
+ 'concat',
432
+ 'flat',
433
+ 'flatMap',
434
+ 'reverse',
435
+ 'sort',
436
+ 'toReversed',
437
+ 'toSorted',
438
+ 'toSpliced',
439
+ ];
440
+ if (arrayReturningMethods.includes(methodName)) {
441
+ const objectExpr = current.expression;
442
+ // If the object is a call expression (chained method), keep going
443
+ if (ts.isCallExpression(objectExpr)) {
444
+ current = objectExpr.expression;
445
+ }
446
+ else {
447
+ // Found the root - it's an identifier or property access
448
+ const path = StructuredPath.fromNode(objectExpr, sourceFile);
449
+ return path ? path.toString() : null;
450
+ }
451
+ }
452
+ else {
453
+ // Not an array method we recognize
454
+ break;
455
+ }
456
+ }
457
+ return null;
458
+ }
459
+ /**
460
+ * Extracts JSX rendering usages from a JSX expression.
461
+ * Detects:
462
+ * - array.map() calls → 'array-map' type
463
+ * - string interpolations (identifiers/property access) → 'text-interpolation' type
464
+ *
465
+ * Recursively searches inside && chains and ternary expressions.
466
+ *
467
+ * @param expr The expression inside {expr}
468
+ * @param context The analysis context
469
+ */
470
+ function extractJsxRenderingUsage(expr, context) {
471
+ const unwrapped = unwrapExpression(expr);
472
+ const sourceLocation = getSourceLocation(expr, context.sourceFile);
473
+ // Detect array.map() calls
474
+ if (ts.isCallExpression(unwrapped)) {
475
+ const calleeExpr = unwrapped.expression;
476
+ if (ts.isPropertyAccessExpression(calleeExpr)) {
477
+ const methodName = calleeExpr.name.getText(context.sourceFile);
478
+ if (methodName === 'map') {
479
+ const arrayPath = extractArrayPathFromMapCall(unwrapped, context.sourceFile);
480
+ if (arrayPath) {
481
+ context.addJsxRenderingUsage({
482
+ path: arrayPath,
483
+ renderingType: 'array-map',
484
+ valueType: 'array',
485
+ sourceLocation,
486
+ });
487
+ }
488
+ }
489
+ }
490
+ }
491
+ // Detect simple string interpolations: {title} or {user.name}
492
+ else if (ts.isIdentifier(unwrapped) ||
493
+ ts.isPropertyAccessExpression(unwrapped)) {
494
+ const path = StructuredPath.fromNode(unwrapped, context.sourceFile);
495
+ if (path) {
496
+ const pathStr = path.toString();
497
+ const typeInfo = context.getTypeInfo(path);
498
+ // Only track as text interpolation if it's a string type
499
+ // Check for 'string' type, or types that contain 'string' (but not 'string[]')
500
+ if (typeInfo === 'string' ||
501
+ (typeInfo &&
502
+ typeInfo.includes('string') &&
503
+ !typeInfo.includes('string[]'))) {
504
+ context.addJsxRenderingUsage({
505
+ path: pathStr,
506
+ renderingType: 'text-interpolation',
507
+ valueType: 'string',
508
+ sourceLocation,
509
+ });
510
+ }
511
+ }
512
+ }
513
+ // Recursively search inside && chains: {showList && items.map(...)}
514
+ else if (ts.isBinaryExpression(unwrapped) &&
515
+ unwrapped.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken) {
516
+ // Check the right side of the && chain (where .map() typically appears)
517
+ const rightSide = unwrapExpression(unwrapped.right);
518
+ extractJsxRenderingUsage(rightSide, context);
519
+ // Also check nested && chains on the left
520
+ extractJsxRenderingUsage(unwrapped.left, context);
521
+ }
522
+ // Recursively search inside ternaries: {isEmpty ? null : items.map(...)}
523
+ else if (ts.isConditionalExpression(unwrapped)) {
524
+ extractJsxRenderingUsage(unwrapped.whenTrue, context);
525
+ extractJsxRenderingUsage(unwrapped.whenFalse, context);
526
+ }
527
+ }
174
528
  /**
175
529
  * Counts the number of conditions in an && chain (excluding JSX consequence)
176
530
  */
@@ -191,6 +545,368 @@ function countConditionsInAndChain(expr) {
191
545
  // Single condition (not an && chain)
192
546
  return 1;
193
547
  }
548
+ /**
549
+ * Extracts conditionals from JSX elements by recursively traversing children.
550
+ *
551
+ * This is CRITICAL for extracting compound conditionals from JSX expressions
552
+ * like `{hasNewerVersion && !isActive && <Banner />}`.
553
+ *
554
+ * This function is called BEFORE the child boundary check in processExpression
555
+ * because JSX elements are NOT scopes - their expressions use variables from
556
+ * the parent scope and should have their conditionals extracted regardless of
557
+ * whether the JSX is within a child boundary.
558
+ *
559
+ * Fix 32: Added parentConditions parameter to track gating conditions from
560
+ * parent && chains. When we find a component nested inside multiple conditionals
561
+ * like `{activeTab && <>{ternary ? ... : <Component />}</>}`, ALL parent
562
+ * conditions should be added as gating conditions for the component.
563
+ *
564
+ * @param node The JSX element, self-closing element, or fragment to traverse
565
+ * @param context The analysis context
566
+ * @param parentConditions Accumulated gating conditions from parent && chains
567
+ */
568
+ function extractConditionalsFromJsx(node, context, parentConditions = []) {
569
+ // Get children to process
570
+ let children;
571
+ if (ts.isJsxElement(node)) {
572
+ children = node.children;
573
+ }
574
+ else if (ts.isJsxFragment(node)) {
575
+ children = node.children;
576
+ }
577
+ // JsxSelfClosingElement has no children
578
+ if (!children) {
579
+ return;
580
+ }
581
+ for (const child of children) {
582
+ // Process JSX expressions: {expr}
583
+ if (ts.isJsxExpression(child) && child.expression) {
584
+ const expr = unwrapExpression(child.expression);
585
+ // Extract JSX rendering usages (array.map, text interpolation)
586
+ // This handles direct usages like {items.map(...)} or {user.name}
587
+ extractJsxRenderingUsage(expr, context);
588
+ // If the expression is an && chain, extract its conditional usages
589
+ if (ts.isBinaryExpression(expr) &&
590
+ expr.operatorToken.kind === ts.SyntaxKind.AmpersandAmpersandToken) {
591
+ // Mark nullable variables
592
+ markConditionVariablesAsNullable(expr, context);
593
+ // Extract conditional usage (this handles compound conditionals)
594
+ // Pass controlsJsxRendering: true since this conditional controls JSX rendering
595
+ extractConditionalUsage(expr, context, 'logical-and', {
596
+ controlsJsxRendering: true,
597
+ });
598
+ // Extract all condition paths from the && chain for gating tracking
599
+ const conditionPaths = extractConditionPathsFromAndChain(expr, context.sourceFile);
600
+ const sourceLocation = getSourceLocation(expr, context.sourceFile);
601
+ // Fix 32: Build accumulated conditions including parent conditions
602
+ const accumulatedConditions = [
603
+ ...parentConditions,
604
+ ...conditionPaths.map((path) => ({
605
+ path,
606
+ sourceLocation,
607
+ isNegated: false,
608
+ })),
609
+ ];
610
+ // Track gating conditions for child components
611
+ // Example: {hasAnalysis && <ScenarioViewer />}
612
+ const jsxElement = findJsxInAndChain(expr);
613
+ if (jsxElement) {
614
+ const componentName = getComponentNameFromJsx(jsxElement);
615
+ if (componentName) {
616
+ // Fix 32: Add ALL accumulated conditions (parent + current) as gating conditions
617
+ for (const condition of accumulatedConditions) {
618
+ context.addChildBoundaryGatingCondition(componentName, {
619
+ path: condition.path,
620
+ conditionType: 'truthiness',
621
+ location: 'logical-and',
622
+ sourceLocation: condition.sourceLocation,
623
+ controlsJsxRendering: true,
624
+ isNegated: condition.isNegated,
625
+ });
626
+ }
627
+ }
628
+ // Fix 32: Recursively process nested JSX with accumulated conditions
629
+ if (ts.isJsxElement(jsxElement) ||
630
+ ts.isJsxSelfClosingElement(jsxElement)) {
631
+ extractConditionalsFromJsx(jsxElement, context, accumulatedConditions);
632
+ }
633
+ }
634
+ // Fix 32: Also check for nested JSX fragments
635
+ const jsxFragment = findJsxFragmentInAndChain(expr);
636
+ if (jsxFragment) {
637
+ extractConditionalsFromJsx(jsxFragment, context, accumulatedConditions);
638
+ }
639
+ }
640
+ // If the expression is a ternary, extract its conditional
641
+ else if (ts.isConditionalExpression(expr)) {
642
+ // Pass controlsJsxRendering: true since this conditional controls JSX rendering
643
+ extractConditionalUsage(expr.condition, context, 'ternary', {
644
+ controlsJsxRendering: true,
645
+ });
646
+ // Track gating conditions for components in both branches of the ternary
647
+ // Example: {isError ? <ErrorView /> : <SuccessView />}
648
+ const conditionPath = StructuredPath.fromNode(unwrapExpression(expr.condition), context.sourceFile);
649
+ const sourceLocation = getSourceLocation(expr, context.sourceFile);
650
+ // Recursively process the whenTrue and whenFalse branches for JSX
651
+ const whenTrue = unwrapExpression(expr.whenTrue);
652
+ const whenFalse = unwrapExpression(expr.whenFalse);
653
+ // Fix 32: Build conditions for whenTrue branch (parent conditions + ternary condition truthy)
654
+ const whenTrueConditions = [
655
+ ...parentConditions,
656
+ ...(conditionPath
657
+ ? [
658
+ {
659
+ path: conditionPath.toString(),
660
+ sourceLocation,
661
+ isNegated: false,
662
+ },
663
+ ]
664
+ : []),
665
+ ];
666
+ // Fix 32: Build conditions for whenFalse branch (parent conditions + ternary condition falsy)
667
+ const whenFalseConditions = [
668
+ ...parentConditions,
669
+ ...(conditionPath
670
+ ? [
671
+ {
672
+ path: conditionPath.toString(),
673
+ sourceLocation,
674
+ isNegated: true,
675
+ },
676
+ ]
677
+ : []),
678
+ ];
679
+ // Handle whenTrue branch (condition is truthy)
680
+ if (ts.isJsxElement(whenTrue) || ts.isJsxSelfClosingElement(whenTrue)) {
681
+ const componentName = getComponentNameFromJsx(whenTrue);
682
+ if (componentName) {
683
+ // Fix 32: Add ALL conditions (parent + ternary) as gating conditions
684
+ for (const condition of whenTrueConditions) {
685
+ context.addChildBoundaryGatingCondition(componentName, {
686
+ path: condition.path,
687
+ conditionType: 'truthiness',
688
+ location: 'ternary',
689
+ sourceLocation: condition.sourceLocation,
690
+ controlsJsxRendering: true,
691
+ isNegated: condition.isNegated,
692
+ });
693
+ }
694
+ }
695
+ }
696
+ if (ts.isJsxElement(whenTrue) ||
697
+ ts.isJsxSelfClosingElement(whenTrue) ||
698
+ ts.isJsxFragment(whenTrue)) {
699
+ extractConditionalsFromJsx(whenTrue, context, whenTrueConditions);
700
+ }
701
+ // Handle whenFalse branch (condition is falsy/negated)
702
+ if (ts.isJsxElement(whenFalse) ||
703
+ ts.isJsxSelfClosingElement(whenFalse)) {
704
+ const componentName = getComponentNameFromJsx(whenFalse);
705
+ if (componentName) {
706
+ // Fix 32: Add ALL conditions (parent + ternary) as gating conditions
707
+ for (const condition of whenFalseConditions) {
708
+ context.addChildBoundaryGatingCondition(componentName, {
709
+ path: condition.path,
710
+ conditionType: 'truthiness',
711
+ location: 'ternary',
712
+ sourceLocation: condition.sourceLocation,
713
+ controlsJsxRendering: true,
714
+ isNegated: condition.isNegated,
715
+ });
716
+ }
717
+ }
718
+ }
719
+ if (ts.isJsxElement(whenFalse) ||
720
+ ts.isJsxSelfClosingElement(whenFalse) ||
721
+ ts.isJsxFragment(whenFalse)) {
722
+ extractConditionalsFromJsx(whenFalse, context, whenFalseConditions);
723
+ }
724
+ // Handle chained ternaries: a ? <A/> : b ? <B/> : <C/>
725
+ // When whenFalse is another ConditionalExpression, recursively process it
726
+ else if (ts.isConditionalExpression(whenFalse)) {
727
+ // Extract conditional usage for the nested ternary's condition
728
+ extractConditionalUsage(whenFalse.condition, context, 'ternary', {
729
+ controlsJsxRendering: true,
730
+ });
731
+ // Get the nested condition path
732
+ const nestedConditionPath = StructuredPath.fromNode(unwrapExpression(whenFalse.condition), context.sourceFile);
733
+ const nestedSourceLocation = getSourceLocation(whenFalse, context.sourceFile);
734
+ const nestedWhenTrue = unwrapExpression(whenFalse.whenTrue);
735
+ const nestedWhenFalse = unwrapExpression(whenFalse.whenFalse);
736
+ // Fix 32: Build conditions for nested whenTrue (parent falsy + nested truthy)
737
+ const nestedWhenTrueConditions = [
738
+ ...whenFalseConditions, // Parent ternary was falsy to get here
739
+ ...(nestedConditionPath
740
+ ? [
741
+ {
742
+ path: nestedConditionPath.toString(),
743
+ sourceLocation: nestedSourceLocation,
744
+ isNegated: false,
745
+ },
746
+ ]
747
+ : []),
748
+ ];
749
+ // Fix 32: Build conditions for nested whenFalse (parent falsy + nested falsy)
750
+ const nestedWhenFalseConditions = [
751
+ ...whenFalseConditions, // Parent ternary was falsy to get here
752
+ ...(nestedConditionPath
753
+ ? [
754
+ {
755
+ path: nestedConditionPath.toString(),
756
+ sourceLocation: nestedSourceLocation,
757
+ isNegated: true,
758
+ },
759
+ ]
760
+ : []),
761
+ ];
762
+ // Handle nested whenTrue branch
763
+ if (ts.isJsxElement(nestedWhenTrue) ||
764
+ ts.isJsxSelfClosingElement(nestedWhenTrue)) {
765
+ const componentName = getComponentNameFromJsx(nestedWhenTrue);
766
+ if (componentName) {
767
+ // Fix 32: Add ALL accumulated conditions
768
+ for (const condition of nestedWhenTrueConditions) {
769
+ context.addChildBoundaryGatingCondition(componentName, {
770
+ path: condition.path,
771
+ conditionType: 'truthiness',
772
+ location: 'ternary',
773
+ sourceLocation: condition.sourceLocation,
774
+ controlsJsxRendering: true,
775
+ isNegated: condition.isNegated,
776
+ });
777
+ }
778
+ }
779
+ }
780
+ if (ts.isJsxElement(nestedWhenTrue) ||
781
+ ts.isJsxSelfClosingElement(nestedWhenTrue) ||
782
+ ts.isJsxFragment(nestedWhenTrue)) {
783
+ extractConditionalsFromJsx(nestedWhenTrue, context, nestedWhenTrueConditions);
784
+ }
785
+ // Handle nested whenFalse branch (this could be another chained ternary or JSX)
786
+ if (ts.isJsxElement(nestedWhenFalse) ||
787
+ ts.isJsxSelfClosingElement(nestedWhenFalse)) {
788
+ const componentName = getComponentNameFromJsx(nestedWhenFalse);
789
+ if (componentName) {
790
+ // Fix 32: Add ALL accumulated conditions
791
+ for (const condition of nestedWhenFalseConditions) {
792
+ context.addChildBoundaryGatingCondition(componentName, {
793
+ path: condition.path,
794
+ conditionType: 'truthiness',
795
+ location: 'ternary',
796
+ sourceLocation: condition.sourceLocation,
797
+ controlsJsxRendering: true,
798
+ isNegated: condition.isNegated,
799
+ });
800
+ }
801
+ }
802
+ }
803
+ if (ts.isJsxElement(nestedWhenFalse) ||
804
+ ts.isJsxSelfClosingElement(nestedWhenFalse) ||
805
+ ts.isJsxFragment(nestedWhenFalse)) {
806
+ extractConditionalsFromJsx(nestedWhenFalse, context, nestedWhenFalseConditions);
807
+ }
808
+ // If nestedWhenFalse is yet another ConditionalExpression, the recursion
809
+ // will handle it on the next iteration when this function processes it
810
+ else if (ts.isConditionalExpression(nestedWhenFalse)) {
811
+ // Recursively handle deeper nesting by wrapping in a synthetic process
812
+ // We create a fake JsxExpression context to reuse the same logic
813
+ const syntheticChild = {
814
+ kind: ts.SyntaxKind.JsxExpression,
815
+ expression: nestedWhenFalse,
816
+ };
817
+ // Process via the main JSX expression handler by recursing
818
+ // For now, just extract conditionals directly
819
+ extractConditionalUsage(nestedWhenFalse.condition, context, 'ternary', { controlsJsxRendering: true });
820
+ }
821
+ }
822
+ }
823
+ }
824
+ // Recursively process nested JSX elements - Fix 32: pass parent conditions
825
+ else if (ts.isJsxElement(child)) {
826
+ // Check if this is a user-defined component (vs intrinsic element like div)
827
+ const componentName = getComponentNameFromJsx(child);
828
+ if (componentName) {
829
+ if (parentConditions.length > 0) {
830
+ // If there are parent conditions, record them as gating conditions
831
+ console.log(`[ChildBoundary] ${componentName}: Conditionally rendered with ${parentConditions.length} gating conditions`);
832
+ for (const condition of parentConditions) {
833
+ console.log(`[ChildBoundary] ${componentName}: Adding gating condition path='${condition.path}' isNegated=${condition.isNegated}`);
834
+ context.addChildBoundaryGatingCondition(componentName, {
835
+ path: condition.path,
836
+ conditionType: 'truthiness',
837
+ location: 'ternary',
838
+ sourceLocation: condition.sourceLocation,
839
+ controlsJsxRendering: true,
840
+ isNegated: condition.isNegated,
841
+ });
842
+ }
843
+ }
844
+ else {
845
+ // No parent conditions - check if it has data props for unconditional tracking
846
+ console.log(`[ChildBoundary] ${componentName}: Checking for unconditional rendering with data props...`);
847
+ const { hasDataProps, dataProps } = hasDataPropsFromParent(child, componentName);
848
+ if (hasDataProps) {
849
+ // Fix: Track unconditionally-rendered children that receive data props
850
+ // These need to be tracked for flow merging even without gating conditions
851
+ // Example: <WorkoutsView workouts={workouts} /> - parent controls workouts data
852
+ console.log(`[ChildBoundary] ${componentName}: TRACKING as unconditionally-rendered with data props: [${dataProps.join(', ')}]`);
853
+ context.addChildBoundaryGatingCondition(componentName, {
854
+ path: '__unconditional__',
855
+ conditionType: 'truthiness',
856
+ location: 'unconditional',
857
+ controlsJsxRendering: true,
858
+ isNegated: false,
859
+ });
860
+ }
861
+ }
862
+ }
863
+ extractConditionalsFromJsx(child, context, parentConditions);
864
+ }
865
+ // Handle self-closing JSX elements (e.g., <ScenarioViewer />)
866
+ else if (ts.isJsxSelfClosingElement(child)) {
867
+ // Check if this is a user-defined component (vs intrinsic element like div)
868
+ const componentName = getComponentNameFromJsx(child);
869
+ if (componentName) {
870
+ if (parentConditions.length > 0) {
871
+ // If there are parent conditions, record them as gating conditions
872
+ console.log(`[ChildBoundary] ${componentName}: Conditionally rendered (self-closing) with ${parentConditions.length} gating conditions`);
873
+ for (const condition of parentConditions) {
874
+ console.log(`[ChildBoundary] ${componentName}: Adding gating condition path='${condition.path}' isNegated=${condition.isNegated}`);
875
+ context.addChildBoundaryGatingCondition(componentName, {
876
+ path: condition.path,
877
+ conditionType: 'truthiness',
878
+ location: 'ternary',
879
+ sourceLocation: condition.sourceLocation,
880
+ controlsJsxRendering: true,
881
+ isNegated: condition.isNegated,
882
+ });
883
+ }
884
+ }
885
+ else {
886
+ // No parent conditions - check if it has data props for unconditional tracking
887
+ console.log(`[ChildBoundary] ${componentName}: Checking for unconditional rendering (self-closing) with data props...`);
888
+ const { hasDataProps, dataProps } = hasDataPropsFromParent(child, componentName);
889
+ if (hasDataProps) {
890
+ // Fix: Track unconditionally-rendered children that receive data props
891
+ console.log(`[ChildBoundary] ${componentName}: TRACKING as unconditionally-rendered (self-closing) with data props: [${dataProps.join(', ')}]`);
892
+ context.addChildBoundaryGatingCondition(componentName, {
893
+ path: '__unconditional__',
894
+ conditionType: 'truthiness',
895
+ location: 'unconditional',
896
+ controlsJsxRendering: true,
897
+ isNegated: false,
898
+ });
899
+ }
900
+ }
901
+ }
902
+ // Self-closing elements have no children, so no recursion needed
903
+ }
904
+ // Recursively process nested JSX fragments - Fix 32: pass parent conditions
905
+ else if (ts.isJsxFragment(child)) {
906
+ extractConditionalsFromJsx(child, context, parentConditions);
907
+ }
908
+ }
909
+ }
194
910
  /**
195
911
  * Extracts conditional usages from a condition expression for key attribute detection.
196
912
  * This function identifies which attributes are used in conditionals and how they're used.
@@ -199,8 +915,10 @@ function countConditionsInAndChain(expr) {
199
915
  * @param condition The condition expression to analyze
200
916
  * @param context The analysis context
201
917
  * @param location Where this condition appears (if, ternary, logical-and, switch)
918
+ * @param options Additional options including controlsJsxRendering flag
202
919
  */
203
- export function extractConditionalUsage(condition, context, location) {
920
+ export function extractConditionalUsage(condition, context, location, options = {}) {
921
+ const { controlsJsxRendering } = options;
204
922
  // Internal recursive function with chain tracking
205
923
  function extractWithChainTracking(expr, chainInfo, isNegated) {
206
924
  const unwrapped = unwrapExpression(expr);
@@ -225,6 +943,7 @@ export function extractConditionalUsage(condition, context, location) {
225
943
  conditions: [],
226
944
  location,
227
945
  sourceLocation: getSourceLocation(unwrapped, context.sourceFile),
946
+ controlsJsxRendering,
228
947
  };
229
948
  chainInfo = {
230
949
  chainId,
@@ -252,12 +971,33 @@ export function extractConditionalUsage(condition, context, location) {
252
971
  return;
253
972
  }
254
973
  // Handle binary expressions with || (logical OR)
255
- // OR breaks the chain - each side is independent
974
+ // When OR is inside an && chain, we need to continue chain tracking
975
+ // and mark conditions as OR alternatives
256
976
  if (ts.isBinaryExpression(unwrapped) &&
257
977
  unwrapped.operatorToken.kind === ts.SyntaxKind.BarBarToken) {
258
- // Both sides of || are independent conditional checks (no chain tracking)
259
- extractWithChainTracking(unwrapped.left, null, false);
260
- extractWithChainTracking(unwrapped.right, null, false);
978
+ if (chainInfo) {
979
+ // We're inside an && chain - continue tracking but mark as OR alternatives
980
+ // Generate an orGroupId so conditions from both sides can be grouped
981
+ const orGroupId = chainInfo.currentOrGroupId ?? `or_${crypto.randomUUID().slice(0, 8)}`;
982
+ // Process left side with OR group tracking
983
+ const leftChainInfo = {
984
+ ...chainInfo,
985
+ currentOrGroupId: orGroupId,
986
+ };
987
+ extractWithChainTracking(unwrapped.left, leftChainInfo, false);
988
+ // Process right side with same OR group
989
+ // Note: we use leftChainInfo's currentPosition which may have been updated
990
+ const rightChainInfo = {
991
+ ...leftChainInfo,
992
+ currentPosition: chainInfo.currentPosition,
993
+ };
994
+ extractWithChainTracking(unwrapped.right, rightChainInfo, false);
995
+ }
996
+ else {
997
+ // Not inside a chain - OR breaks into independent conditional checks
998
+ extractWithChainTracking(unwrapped.left, null, false);
999
+ extractWithChainTracking(unwrapped.right, null, false);
1000
+ }
261
1001
  return;
262
1002
  }
263
1003
  // Handle comparison operators (===, !==, <, >, <=, >=)
@@ -282,8 +1022,10 @@ export function extractConditionalUsage(condition, context, location) {
282
1022
  }
283
1023
  return literalValue;
284
1024
  };
1025
+ // Get the comparison operator string for the compound condition
1026
+ const comparisonOperator = getComparisonOperatorString(unwrapped.operatorToken.kind);
285
1027
  // Helper to add a condition
286
- const addCondition = (path, conditionType, comparedValues, requiredValue) => {
1028
+ const addCondition = (path, conditionType, comparedValues, requiredValue, sourceExpr) => {
287
1029
  const usage = {
288
1030
  path,
289
1031
  conditionType,
@@ -291,7 +1033,18 @@ export function extractConditionalUsage(condition, context, location) {
291
1033
  location,
292
1034
  sourceLocation: getSourceLocation(unwrapped, context.sourceFile),
293
1035
  isNegated,
1036
+ controlsJsxRendering,
294
1037
  };
1038
+ // Check for inline array-derived patterns (.length) on the source expression
1039
+ if (sourceExpr) {
1040
+ const arrayDerived = detectArrayDerivedPattern(sourceExpr);
1041
+ if (arrayDerived) {
1042
+ usage.derivedFrom = {
1043
+ operation: arrayDerived.operation,
1044
+ sourcePath: arrayDerived.sourcePath,
1045
+ };
1046
+ }
1047
+ }
295
1048
  // Add chain info if part of a compound conditional
296
1049
  if (chainInfo) {
297
1050
  usage.chainId = chainInfo.chainId;
@@ -306,6 +1059,10 @@ export function extractConditionalUsage(condition, context, location) {
306
1059
  comparedValues,
307
1060
  isNegated,
308
1061
  requiredValue,
1062
+ ...(comparisonOperator && { comparisonOperator }),
1063
+ ...(chainInfo.currentOrGroupId && {
1064
+ orGroupId: chainInfo.currentOrGroupId,
1065
+ }),
309
1066
  });
310
1067
  }
311
1068
  context.addConditionalUsage(usage);
@@ -313,21 +1070,21 @@ export function extractConditionalUsage(condition, context, location) {
313
1070
  // Check if left is a variable and right is a literal
314
1071
  if (leftPath && isLiteralExpression(unwrapped.right)) {
315
1072
  const literalValue = getLiteralValue(unwrapped.right, context);
316
- addCondition(leftPath.toLeftHandSideString(), 'comparison', literalValue !== undefined ? [literalValue] : undefined, getRequiredValue(literalValue, isNegated));
1073
+ addCondition(leftPath.toLeftHandSideString(), 'comparison', literalValue !== undefined ? [literalValue] : undefined, getRequiredValue(literalValue, isNegated), unwrapped.left);
317
1074
  return;
318
1075
  }
319
1076
  // Check if right is a variable and left is a literal
320
1077
  if (rightPath && isLiteralExpression(unwrapped.left)) {
321
1078
  const literalValue = getLiteralValue(unwrapped.left, context);
322
- addCondition(rightPath.toLeftHandSideString(), 'comparison', literalValue !== undefined ? [literalValue] : undefined, getRequiredValue(literalValue, isNegated));
1079
+ addCondition(rightPath.toLeftHandSideString(), 'comparison', literalValue !== undefined ? [literalValue] : undefined, getRequiredValue(literalValue, isNegated), unwrapped.right);
323
1080
  return;
324
1081
  }
325
1082
  // Both sides are variables - record both as comparisons without specific values
326
1083
  if (leftPath) {
327
- addCondition(leftPath.toLeftHandSideString(), 'comparison');
1084
+ addCondition(leftPath.toLeftHandSideString(), 'comparison', undefined, undefined, unwrapped.left);
328
1085
  }
329
1086
  if (rightPath) {
330
- addCondition(rightPath.toLeftHandSideString(), 'comparison');
1087
+ addCondition(rightPath.toLeftHandSideString(), 'comparison', undefined, undefined, unwrapped.right);
331
1088
  }
332
1089
  return;
333
1090
  }
@@ -349,7 +1106,17 @@ export function extractConditionalUsage(condition, context, location) {
349
1106
  location,
350
1107
  sourceLocation: getSourceLocation(unwrapped, context.sourceFile),
351
1108
  isNegated,
1109
+ controlsJsxRendering,
352
1110
  };
1111
+ // Check for inline array-derived patterns (.some(), .every(), .includes(), .length)
1112
+ // This populates derivedFrom so downstream code can resolve to the base array path
1113
+ const arrayDerived = detectArrayDerivedPattern(unwrapped);
1114
+ if (arrayDerived) {
1115
+ usage.derivedFrom = {
1116
+ operation: arrayDerived.operation,
1117
+ sourcePath: arrayDerived.sourcePath,
1118
+ };
1119
+ }
353
1120
  // Add chain info if part of a compound conditional
354
1121
  if (chainInfo) {
355
1122
  usage.chainId = chainInfo.chainId;
@@ -364,6 +1131,9 @@ export function extractConditionalUsage(condition, context, location) {
364
1131
  conditionType: 'truthiness',
365
1132
  isNegated,
366
1133
  requiredValue: !isNegated,
1134
+ ...(chainInfo.currentOrGroupId && {
1135
+ orGroupId: chainInfo.currentOrGroupId,
1136
+ }),
367
1137
  });
368
1138
  }
369
1139
  context.addConditionalUsage(usage);
@@ -458,6 +1228,15 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
458
1228
  extractConditionalUsage(unwrappedNode, context, 'logical-and');
459
1229
  }
460
1230
  }
1231
+ // CRITICAL: Extract conditionals from JSX BEFORE checking child boundaries
1232
+ // JSX elements are NOT scopes - their expressions use variables from the parent scope.
1233
+ // Even if the JSX element is within a child boundary (e.g., because it contains callbacks),
1234
+ // we must still extract conditionals from JSX expression children like {x && <div>...</div>}
1235
+ if (ts.isJsxElement(unwrappedNode) ||
1236
+ ts.isJsxSelfClosingElement(unwrappedNode) ||
1237
+ ts.isJsxFragment(unwrappedNode)) {
1238
+ extractConditionalsFromJsx(unwrappedNode, context);
1239
+ }
461
1240
  // If the node falls within an excluded child scope, stop processing it.
462
1241
  if (context.isChildBoundary(node)) {
463
1242
  return true;
@@ -486,15 +1265,21 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
486
1265
  const equivalentVariables = context.getEquivalentVariables();
487
1266
  const structure = context.getStructure();
488
1267
  // Propagate existing equivalencies for sub-properties
489
- for (const [key, value] of Object.entries(equivalentVariables)) {
1268
+ for (const [key, rawValue] of Object.entries(equivalentVariables)) {
490
1269
  // Check if this equivalency is for a sub-property of the identifier
491
1270
  // e.g., completeDataStructure['Function Arguments'] or completeDataStructure.foo
492
1271
  if (key.startsWith(nodePathStr + '.') ||
493
1272
  key.startsWith(nodePathStr + '[')) {
494
1273
  const subPath = key.substring(nodePathStr.length);
495
1274
  const newTargetPath = StructuredPath.fromBase(targetPath.toString() + subPath);
496
- const valuePath = StructuredPath.fromBase(value);
497
- context.addEquivalence(newTargetPath, valuePath);
1275
+ // Handle both string and string[] values
1276
+ const values = Array.isArray(rawValue) ? rawValue : [rawValue];
1277
+ for (const value of values) {
1278
+ if (typeof value === 'string') {
1279
+ const valuePath = StructuredPath.fromBase(value);
1280
+ context.addEquivalence(newTargetPath, valuePath);
1281
+ }
1282
+ }
498
1283
  }
499
1284
  }
500
1285
  // Propagate existing structure entries for sub-properties
@@ -813,6 +1598,13 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
813
1598
  // e.g., `const tab = segments[0] || 'default'` should trace tab back to segments[0]
814
1599
  if (operatorKind === ts.SyntaxKind.QuestionQuestionToken) {
815
1600
  // specifically for ?? we create an equivalence to the left side
1601
+ // IMPORTANT: Also process the left side recursively to apply method semantics
1602
+ // (e.g., for `const segments = splat?.split('/') ?? []`, we need split semantics)
1603
+ processExpression({
1604
+ node: unwrappedNode.left,
1605
+ context,
1606
+ // Don't pass targetPath here - we'll establish equivalence separately below
1607
+ });
816
1608
  if (targetPath) {
817
1609
  resultPath = StructuredPath.fromNode(unwrappedNode.left, context.sourceFile);
818
1610
  }
@@ -823,12 +1615,46 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
823
1615
  }
824
1616
  }
825
1617
  else if (operatorKind === ts.SyntaxKind.BarBarToken) {
826
- // For ||, also create an equivalence to the left side
1618
+ // For ||, create equivalences to BOTH sides
827
1619
  // This enables data flow tracing through fallback expressions
1620
+ // e.g., `const item = items.find(...) || null` should trace to both:
1621
+ // - items[] (from the find result)
1622
+ // - null (from the fallback)
828
1623
  if (targetPath) {
829
- resultPath = StructuredPath.fromNode(unwrappedNode.left, context.sourceFile);
1624
+ // Get paths for both sides
1625
+ const leftPath = StructuredPath.fromNode(unwrappedNode.left, context.sourceFile);
1626
+ const rightPath = StructuredPath.fromNode(unwrappedNode.right, context.sourceFile);
1627
+ // Collect all valid paths
1628
+ const allPaths = [];
1629
+ if (leftPath)
1630
+ allPaths.push(leftPath);
1631
+ if (rightPath)
1632
+ allPaths.push(rightPath);
1633
+ // Add multiple equivalencies to track both sources
1634
+ if (allPaths.length > 0) {
1635
+ context.addMultipleEquivalencies(targetPath, allPaths);
1636
+ }
1637
+ // Process both sides to capture their internal structures
1638
+ processExpression({
1639
+ node: unwrappedNode.left,
1640
+ context,
1641
+ });
1642
+ processExpression({
1643
+ node: unwrappedNode.right,
1644
+ context,
1645
+ });
1646
+ // Register the type for the target path
1647
+ const leftType = context.inferTypeFromNode(unwrappedNode.left);
1648
+ const rightType = context.inferTypeFromNode(unwrappedNode.right);
1649
+ const orResultType = isDefinedType(leftType)
1650
+ ? leftType
1651
+ : rightType || 'unknown';
1652
+ context.addType(targetPath, orResultType);
1653
+ // Return early - we've already handled equivalencies with addMultipleEquivalencies
1654
+ // Don't fall through to the generic addEquivalence call below
1655
+ return true;
830
1656
  }
831
- // Note: Unlike ??, we don't set targetPath when there's no target
1657
+ // Note: When there's no targetPath, we don't recursively process
832
1658
  // because || is often used in boolean contexts where the full expression matters
833
1659
  }
834
1660
  }
@@ -906,18 +1732,44 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
906
1732
  const semantics = semanticsList[0];
907
1733
  // Get the source expression path (e.g., the object for obj.method())
908
1734
  const sourceExpr = unwrappedNode.expression.expression;
909
- const sourcePath = StructuredPath.fromNode(sourceExpr, context.sourceFile);
910
- if (sourcePath) {
911
- // For array-specific semantics (like push), verify the source is actually an array
912
- // This prevents router.push() from being mistakenly treated as Array.push()
913
- const isArraySemantics = semantics instanceof ArrayPushSemantics;
914
- const shouldApply = !isArraySemantics ||
915
- isLikelyArrayType(sourceExpr, context.typeChecker);
916
- if (shouldApply) {
917
- // Apply method semantics
918
- semantics.addEquivalences(callPath, sourcePath, context);
919
- returnType = semantics.getReturnType();
920
- handledBySemantics = true;
1735
+ const unwrappedSourceExpr = unwrapExpression(sourceExpr);
1736
+ // When the source is a ternary expression like (cond ? arr : arr.slice()),
1737
+ // apply method semantics to BOTH branches directly. The ternary itself isn't
1738
+ // a variable - it's just a choice between two paths that both flow to the result.
1739
+ if (ts.isConditionalExpression(unwrappedSourceExpr)) {
1740
+ const branches = [
1741
+ unwrappedSourceExpr.whenTrue,
1742
+ unwrappedSourceExpr.whenFalse,
1743
+ ];
1744
+ for (const branch of branches) {
1745
+ const branchPath = StructuredPath.fromNode(branch, context.sourceFile);
1746
+ if (branchPath) {
1747
+ const isArraySemantics = semantics instanceof ArrayPushSemantics;
1748
+ const shouldApply = !isArraySemantics ||
1749
+ isLikelyArrayType(branch, context.typeChecker);
1750
+ if (shouldApply) {
1751
+ semantics.addEquivalences(callPath, branchPath, context);
1752
+ returnType = semantics.getReturnType();
1753
+ handledBySemantics = true;
1754
+ }
1755
+ }
1756
+ }
1757
+ }
1758
+ else {
1759
+ // Regular (non-ternary) source expression
1760
+ const sourcePath = StructuredPath.fromNode(sourceExpr, context.sourceFile);
1761
+ if (sourcePath) {
1762
+ // For array-specific semantics (like push), verify the source is actually an array
1763
+ // This prevents router.push() from being mistakenly treated as Array.push()
1764
+ const isArraySemantics = semantics instanceof ArrayPushSemantics;
1765
+ const shouldApply = !isArraySemantics ||
1766
+ isLikelyArrayType(sourceExpr, context.typeChecker);
1767
+ if (shouldApply) {
1768
+ // Apply method semantics
1769
+ semantics.addEquivalences(callPath, sourcePath, context);
1770
+ returnType = semantics.getReturnType();
1771
+ handledBySemantics = true;
1772
+ }
921
1773
  }
922
1774
  }
923
1775
  }
@@ -1242,6 +2094,12 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
1242
2094
  markConditionVariablesAsNullable(unwrappedNode.condition, context);
1243
2095
  // Extract conditional usages for key attribute detection
1244
2096
  extractConditionalUsage(unwrappedNode.condition, context, 'ternary');
2097
+ // Extract conditional effects (setter calls in ternary branches)
2098
+ const knownSetters = findUseStateSetters(context.sourceFile);
2099
+ const effects = extractConditionalEffectsFromTernary(unwrappedNode, context, knownSetters);
2100
+ for (const effect of effects) {
2101
+ context.addConditionalEffect(effect);
2102
+ }
1245
2103
  // Process all parts recursively
1246
2104
  processExpression({
1247
2105
  node: unwrappedNode.condition,
@@ -1340,6 +2198,32 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
1340
2198
  }
1341
2199
  // Handle Arrow Functions: (p) => p.prop, (a, b) => { ... }
1342
2200
  if (ts.isArrowFunction(unwrappedNode)) {
2201
+ // If this arrow function is a child boundary (e.g., a .map() callback),
2202
+ // don't process its parameters here - they will be processed when the
2203
+ // child scope is analyzed separately. This prevents parameter variables
2204
+ // from leaking into the parent scope's equivalencies.
2205
+ // Check if this arrow function is a child boundary (i.e., should be processed
2206
+ // as a separate child scope, not here in the parent scope).
2207
+ //
2208
+ // We use two checks because childBoundary positions can be unreliable:
2209
+ // 1. Position-based check (standard isChildBoundary)
2210
+ // 2. Text-based check: if the arrow function text doesn't appear in the
2211
+ // statement text, it was replaced with a cyScope placeholder
2212
+ const isChildBoundary = context.isChildBoundary(unwrappedNode);
2213
+ // Text-based child scope detection for when positions are unreliable
2214
+ const arrowFnText = unwrappedNode.getText(context.sourceFile);
2215
+ const firstLine = arrowFnText.split('\n')[0].trim();
2216
+ const searchText = firstLine.substring(0, Math.min(20, firstLine.length));
2217
+ const isInStatementText = context.statementInfo.text.includes(searchText);
2218
+ const isChildScope = !isInStatementText && arrowFnText.length > 10;
2219
+ if (isChildBoundary || isChildScope) {
2220
+ // The method semantics (e.g., ArrayMapSemantics) have already established
2221
+ // the necessary equivalences between the child scope placeholder and array elements
2222
+ if (targetPath) {
2223
+ context.addType(targetPath, 'function');
2224
+ }
2225
+ return true;
2226
+ }
1343
2227
  // Create a path for the function
1344
2228
  const functionPath = StructuredPath.empty();
1345
2229
  // Process parameters
@@ -1631,6 +2515,15 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
1631
2515
  for (const child of unwrappedNode.children) {
1632
2516
  // Process expressions in JSX children: <div>{expr}</div>
1633
2517
  if (ts.isJsxExpression(child) && child.expression) {
2518
+ // When processing return value JSX, link root variables to return value schema
2519
+ if (targetPath && targetPath.base !== '') {
2520
+ const varNames = [
2521
+ ...new Set(extractRootVariableNames(child.expression)),
2522
+ ];
2523
+ for (const varName of varNames) {
2524
+ context.addEquivalence(targetPath.withProperty(varName), StructuredPath.fromBase(varName));
2525
+ }
2526
+ }
1634
2527
  // Process the expression with StructuredPath.empty() as targetPath
1635
2528
  // to trigger type registration without imposing prefix
1636
2529
  processExpression({
@@ -1661,6 +2554,15 @@ export function processExpression({ node, context, targetPath, typeHint, }) {
1661
2554
  for (const child of unwrappedNode.children) {
1662
2555
  // Process expressions in JSX children: <>{expr}</>
1663
2556
  if (ts.isJsxExpression(child) && child.expression) {
2557
+ // When processing return value JSX, link root variables to return value schema
2558
+ if (targetPath && targetPath.base !== '') {
2559
+ const varNames = [
2560
+ ...new Set(extractRootVariableNames(child.expression)),
2561
+ ];
2562
+ for (const varName of varNames) {
2563
+ context.addEquivalence(targetPath.withProperty(varName), StructuredPath.fromBase(varName));
2564
+ }
2565
+ }
1664
2566
  // Process the expression to extract structure
1665
2567
  processExpression({
1666
2568
  node: child.expression,