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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (822) hide show
  1. package/analyzer-template/.build-info.json +7 -7
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +24 -24
  4. package/analyzer-template/packages/ai/index.ts +1 -0
  5. package/analyzer-template/packages/ai/package.json +3 -3
  6. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +23 -1
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
  8. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  9. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +101 -0
  10. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  11. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +6 -0
  12. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +588 -13
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +5 -1
  15. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +11 -2
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +2 -2
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +140 -14
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +20 -1
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +84 -19
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  23. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +40 -13
  24. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +58 -3
  25. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +124 -7
  26. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +101 -2
  27. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +359 -142
  28. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +51 -3
  29. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  30. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  31. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +24 -4
  32. package/analyzer-template/packages/analyze/index.ts +2 -0
  33. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +19 -7
  34. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  35. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  36. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +69 -3
  37. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +13 -0
  38. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  39. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  40. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1352 -0
  41. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +4 -0
  42. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +59 -26
  43. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +277 -15
  44. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  45. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +395 -61
  46. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  47. package/analyzer-template/packages/aws/package.json +10 -10
  48. package/analyzer-template/packages/database/index.ts +1 -0
  49. package/analyzer-template/packages/database/package.json +4 -4
  50. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  51. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  52. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  53. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  54. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  55. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  56. package/analyzer-template/packages/database/src/lib/kysely/db.ts +14 -0
  57. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +1 -1
  58. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +82 -0
  59. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  60. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  61. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  62. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  63. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  64. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  65. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +151 -135
  66. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  67. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  68. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  69. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  70. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  71. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  72. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  73. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  74. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  75. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  76. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  77. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  78. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  79. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  80. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  81. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  82. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  83. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  85. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  86. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  87. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -0
  88. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  89. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +8 -0
  90. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  91. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +1 -1
  92. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +24 -0
  93. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  94. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
  95. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  96. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  97. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  98. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  99. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  100. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  101. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  102. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  103. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  104. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  105. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  106. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  107. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  108. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  109. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  110. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  111. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  112. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  113. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  114. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  115. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +100 -89
  116. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  117. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  118. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  119. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  120. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  121. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  122. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  123. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  124. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  125. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  126. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  127. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  128. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  129. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  130. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  131. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  132. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  133. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  134. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  135. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  136. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  137. package/analyzer-template/packages/github/package.json +1 -1
  138. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  139. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +8 -0
  140. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  141. package/analyzer-template/packages/ui-components/package.json +1 -1
  142. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  143. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  144. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  145. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  146. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +8 -0
  147. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  148. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  149. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  150. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  151. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +98 -3
  152. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  153. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +121 -3
  154. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  155. package/analyzer-template/project/constructMockCode.ts +206 -51
  156. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  157. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  158. package/analyzer-template/project/start.ts +3 -0
  159. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  160. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  161. package/analyzer-template/project/writeMockDataTsx.ts +136 -17
  162. package/analyzer-template/project/writeScenarioComponents.ts +170 -29
  163. package/analyzer-template/project/writeSimpleRoot.ts +21 -11
  164. package/analyzer-template/tsconfig.json +13 -1
  165. package/background/src/lib/local/createLocalAnalyzer.js +1 -1
  166. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  167. package/background/src/lib/virtualized/project/constructMockCode.js +175 -42
  168. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  169. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  170. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  171. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  172. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  173. package/background/src/lib/virtualized/project/start.js +2 -0
  174. package/background/src/lib/virtualized/project/start.js.map +1 -1
  175. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  176. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  177. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  178. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  179. package/background/src/lib/virtualized/project/writeMockDataTsx.js +114 -13
  180. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  181. package/background/src/lib/virtualized/project/writeScenarioComponents.js +143 -27
  182. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  183. package/background/src/lib/virtualized/project/writeSimpleRoot.js +21 -11
  184. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  185. package/codeyam-cli/scripts/apply-setup.js +252 -21
  186. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  187. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  188. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  189. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  190. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  191. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  192. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  193. package/codeyam-cli/src/cli.js +33 -24
  194. package/codeyam-cli/src/cli.js.map +1 -1
  195. package/codeyam-cli/src/codeyam-cli.js +18 -2
  196. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  197. package/codeyam-cli/src/commands/analyze.js +21 -9
  198. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  199. package/codeyam-cli/src/commands/baseline.js +2 -0
  200. package/codeyam-cli/src/commands/baseline.js.map +1 -1
  201. package/codeyam-cli/src/commands/debug.js +2 -0
  202. package/codeyam-cli/src/commands/debug.js.map +1 -1
  203. package/codeyam-cli/src/commands/default.js +44 -21
  204. package/codeyam-cli/src/commands/default.js.map +1 -1
  205. package/codeyam-cli/src/commands/editor.js +2868 -0
  206. package/codeyam-cli/src/commands/editor.js.map +1 -0
  207. package/codeyam-cli/src/commands/init.js +81 -260
  208. package/codeyam-cli/src/commands/init.js.map +1 -1
  209. package/codeyam-cli/src/commands/memory.js +97 -92
  210. package/codeyam-cli/src/commands/memory.js.map +1 -1
  211. package/codeyam-cli/src/commands/recapture.js +2 -0
  212. package/codeyam-cli/src/commands/recapture.js.map +1 -1
  213. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  214. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  215. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  216. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  217. package/codeyam-cli/src/commands/test-startup.js +2 -0
  218. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  219. package/codeyam-cli/src/commands/verify.js +14 -2
  220. package/codeyam-cli/src/commands/verify.js.map +1 -1
  221. package/codeyam-cli/src/data/techStacks.js +77 -0
  222. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  223. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  224. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  225. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  226. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  227. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
  228. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  229. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +635 -0
  230. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  231. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  232. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  233. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  234. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  235. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  236. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  237. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  238. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  239. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  240. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  241. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  242. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  243. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  244. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  245. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  246. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  247. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +266 -0
  248. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  249. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  250. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  251. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  252. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  253. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  254. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  255. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +275 -0
  256. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  257. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  258. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  259. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  260. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  261. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  262. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  263. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  264. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  265. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +185 -0
  266. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  267. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +101 -0
  268. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  269. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  270. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  271. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  272. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  273. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  274. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  275. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  276. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  277. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +246 -0
  278. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  279. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +174 -86
  280. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  281. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  282. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  283. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  284. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  285. package/codeyam-cli/src/utils/analyzer.js +7 -0
  286. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  287. package/codeyam-cli/src/utils/backgroundServer.js +198 -29
  288. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  289. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  290. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  291. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  292. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  293. package/codeyam-cli/src/utils/devServerState.js +71 -0
  294. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  295. package/codeyam-cli/src/utils/editorApi.js +73 -0
  296. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  297. package/codeyam-cli/src/utils/editorAudit.js +159 -0
  298. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  299. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  300. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  301. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  302. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  303. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  304. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  305. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  306. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  307. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  308. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  309. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  310. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  311. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  312. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  313. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  314. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  315. package/codeyam-cli/src/utils/editorPreview.js +106 -0
  316. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  317. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  318. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  319. package/codeyam-cli/src/utils/editorScenarios.js +126 -0
  320. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  321. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  322. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  323. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  324. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  325. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  326. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  327. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  328. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  329. package/codeyam-cli/src/utils/fileWatcher.js +25 -9
  330. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  331. package/codeyam-cli/src/utils/generateReport.js +2 -2
  332. package/codeyam-cli/src/utils/git.js +103 -0
  333. package/codeyam-cli/src/utils/git.js.map +1 -1
  334. package/codeyam-cli/src/utils/install-skills.js +101 -56
  335. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  336. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  337. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  338. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  339. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  340. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  341. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  342. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  343. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  344. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  345. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  346. package/codeyam-cli/src/utils/progress.js +7 -0
  347. package/codeyam-cli/src/utils/progress.js.map +1 -1
  348. package/codeyam-cli/src/utils/project.js +15 -5
  349. package/codeyam-cli/src/utils/project.js.map +1 -1
  350. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  351. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  352. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  353. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  354. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  355. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  356. package/codeyam-cli/src/utils/queue/job.js +74 -1
  357. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  358. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  359. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  360. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  361. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  362. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  363. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  364. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +229 -0
  365. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  366. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  367. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  368. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  369. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  370. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  371. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  372. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  373. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  374. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +74 -0
  375. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  376. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +376 -0
  377. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  378. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +113 -0
  379. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  380. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  381. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  382. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  383. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  384. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  385. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  386. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  387. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  388. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  389. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  390. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  391. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  392. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  393. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  394. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  395. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  396. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  397. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  398. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  399. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  400. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  401. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  402. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  403. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  404. package/codeyam-cli/src/utils/rules/index.js +2 -0
  405. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  406. package/codeyam-cli/src/utils/rules/parser.js +16 -29
  407. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  408. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  409. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  410. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  411. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  412. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  413. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  414. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  415. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  416. package/codeyam-cli/src/utils/rules/staleness.js +16 -11
  417. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -1
  418. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  419. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  420. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  421. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  422. package/codeyam-cli/src/utils/scenariosManifest.js +112 -0
  423. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  424. package/codeyam-cli/src/utils/serverState.js +94 -12
  425. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  426. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +95 -47
  427. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  428. package/codeyam-cli/src/utils/simulationGateMiddleware.js +159 -0
  429. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  430. package/codeyam-cli/src/utils/syncMocksMiddleware.js +5 -24
  431. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  432. package/codeyam-cli/src/utils/testRunner.js +158 -0
  433. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  434. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  435. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  436. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  437. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  438. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  439. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  440. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +31 -0
  441. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  442. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  443. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  444. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +487 -0
  445. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  446. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  447. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  448. package/codeyam-cli/src/webserver/app/lib/database.js +56 -30
  449. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  450. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  451. package/codeyam-cli/src/webserver/app/lib/git.js +396 -0
  452. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  453. package/codeyam-cli/src/webserver/backgroundServer.js +166 -16
  454. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  455. package/codeyam-cli/src/webserver/bootstrap.js +11 -0
  456. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  457. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-BPXZwM4t.js +1 -0
  458. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-DsN1wKrm.js → EntityItem-BcgbViKV.js} +3 -3
  459. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-DLqD3qNt.js → EntityTypeBadge-g3saevPb.js} +1 -1
  460. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-Ba2JVPzP.js → EntityTypeIcon-CQIG2qda.js} +9 -9
  461. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +1 -0
  462. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-aht4aafF.js → InteractivePreview-DYFW3lDD.js} +3 -3
  463. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-CVtiBnY5.js → LibraryFunctionPreview-DLeucoVX.js} +1 -1
  464. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-B0GLXMsr.js → LoadingDots-BU_OAEMP.js} +1 -1
  465. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-xgeCVgSM.js → LogViewer-ceAyBX-H.js} +1 -1
  466. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-OApQuNyq.js → ReportIssueModal-BzHcG7SE.js} +5 -10
  467. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-DuDvi0jm.js → SafeScreenshot-BED4B6sP.js} +1 -1
  468. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-DzccYyI8.js → ScenarioViewer-0DY_NKil.js} +3 -3
  469. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +34 -0
  470. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-DyFZkK0l.js → TruncatedFilePath-C8OKAR5x.js} +1 -1
  471. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  472. package/codeyam-cli/src/webserver/build/client/assets/{_index-BwqWJOgH.js → _index-DLxKhri3.js} +3 -3
  473. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BwavGCpm.js → activity.(_tab)-BcY3q6nt.js} +10 -15
  474. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  475. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  476. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-Duc5hnl7.js +1 -0
  477. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  478. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bni3iiUj.js +22 -0
  479. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  480. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  481. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  482. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  483. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  484. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  485. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  486. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  487. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  488. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  489. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  490. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  491. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  492. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  493. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  494. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  495. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  496. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  497. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  498. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  499. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  500. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  501. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  502. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  503. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  504. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  505. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  506. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  507. package/codeyam-cli/src/webserver/build/client/assets/book-open-BYOypzCa.js +6 -0
  508. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-Cx24_aWc.js → chevron-down-C_Pmso5S.js} +2 -2
  509. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-CXRTFQ3F.js → chunk-JZWAC4HX-C4pqxYJB.js} +12 -12
  510. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BOARzkeR.js → circle-check-BVMi9VA5.js} +2 -2
  511. package/codeyam-cli/src/webserver/build/client/assets/copy-n2FB0_Sw.js +11 -0
  512. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  513. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Csi0_PMl.js +1 -0
  514. package/codeyam-cli/src/webserver/build/client/assets/editor-vgc8jrQL.js +10 -0
  515. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-BLQMSKZa.js +41 -0
  516. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BJUiQqZF.js → entity._sha._-BF4oLwaE.js} +12 -12
  517. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-C7YX6r3H.js +6 -0
  518. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CF164ouH.js +6 -0
  519. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +6 -0
  520. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-CTBG2mmz.js → entity._sha_.edit._scenarioId-BMvVHNXU.js} +2 -2
  521. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-CS2cb_eZ.js → entry.client-DTvKq3TY.js} +1 -1
  522. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DMJ7zii9.js → fileTableUtils-cPo8LiG3.js} +1 -1
  523. package/codeyam-cli/src/webserver/build/client/assets/{files-CJ6lTdTA.js → files-BZrlFE1F.js} +1 -1
  524. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  525. package/codeyam-cli/src/webserver/build/client/assets/globals-BkWJ_UNc.css +1 -0
  526. package/codeyam-cli/src/webserver/build/client/assets/{index-B1h680n5.js → index-10oVnAAH.js} +1 -1
  527. package/codeyam-cli/src/webserver/build/client/assets/{index-lzqtyFU8.js → index-BcvgDzbZ.js} +1 -1
  528. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  529. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +1 -0
  530. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-B7B9V-bu.js → loader-circle-DaAZ_H2w.js} +2 -2
  531. package/codeyam-cli/src/webserver/build/client/assets/manifest-05e71e0b.js +1 -0
  532. package/codeyam-cli/src/webserver/build/client/assets/memory-Bl2rpw8u.js +96 -0
  533. package/codeyam-cli/src/webserver/build/client/assets/pause-f5-1lKBt.js +11 -0
  534. package/codeyam-cli/src/webserver/build/client/assets/root-ClvYBUSA.js +67 -0
  535. package/codeyam-cli/src/webserver/build/client/assets/{search-CxXUmBSd.js → search-Di64LWVb.js} +2 -2
  536. package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +1 -0
  537. package/codeyam-cli/src/webserver/build/client/assets/{simulations-DwFIBT09.js → simulations-DWT-CvLy.js} +1 -1
  538. package/codeyam-cli/src/webserver/build/client/assets/terminal-Br7MOqts.js +11 -0
  539. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-B6LgvRJg.js → triangle-alert-BLdiCuG-.js} +2 -2
  540. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-CrAK28Bc.js +1 -0
  541. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-C14nCb1q.js +2 -0
  542. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-DYxHZQuP.js → useReportContext-O-jkvSPx.js} +1 -1
  543. package/codeyam-cli/src/webserver/build/client/assets/{useToast-mBRpZPiu.js → useToast-9FIWuYfK.js} +1 -1
  544. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  545. package/codeyam-cli/src/webserver/build/server/assets/index-B4lc-hKc.js +1 -0
  546. package/codeyam-cli/src/webserver/build/server/assets/server-build-BbkD6mNV.js +426 -0
  547. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  548. package/codeyam-cli/src/webserver/build-info.json +5 -5
  549. package/codeyam-cli/src/webserver/devServer.js +39 -5
  550. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  551. package/codeyam-cli/src/webserver/editorProxy.js +846 -0
  552. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  553. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  554. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +230 -0
  555. package/codeyam-cli/src/webserver/server.js +258 -1
  556. package/codeyam-cli/src/webserver/server.js.map +1 -1
  557. package/codeyam-cli/src/webserver/terminalServer.js +726 -0
  558. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  559. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  560. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  561. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  562. package/codeyam-cli/templates/chrome-extension-react/package.json +26 -0
  563. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  564. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  565. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  566. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  567. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  568. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  569. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  570. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  571. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  572. package/codeyam-cli/templates/codeyam-editor-claude.md +68 -0
  573. package/codeyam-cli/templates/codeyam-memory-hook.sh +19 -20
  574. package/codeyam-cli/templates/commands/codeyam-diagnose.md +481 -0
  575. package/codeyam-cli/templates/editor-step-hook.py +231 -0
  576. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  577. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  578. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  579. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  580. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  581. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  582. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  583. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  584. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  585. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  586. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  587. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  588. package/codeyam-cli/templates/expo-react-native/package.json +37 -0
  589. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  590. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  591. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  592. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  593. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  594. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  595. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  596. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  597. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  598. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  599. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  600. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  601. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  602. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  603. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  604. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  605. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  606. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  607. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  608. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  609. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  610. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  611. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  612. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +38 -0
  613. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  614. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  615. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  616. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  617. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  618. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  619. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  620. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  621. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  622. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  623. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  624. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  625. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  626. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  627. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  628. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  629. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  630. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  631. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +36 -0
  632. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  633. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  634. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  635. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  636. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  637. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  638. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  639. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  640. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  641. package/codeyam-cli/templates/rule-notification-hook.py +83 -0
  642. package/codeyam-cli/templates/rule-reflection-hook.py +574 -88
  643. package/codeyam-cli/templates/rules-instructions.md +45 -93
  644. package/codeyam-cli/templates/{codeyam:debug.md → skills/codeyam-debug/SKILL.md} +1 -1
  645. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  646. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +148 -0
  647. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +611 -0
  648. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  649. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  650. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  651. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  652. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  653. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  654. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  655. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  656. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  657. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  658. package/codeyam-cli/templates/skills/codeyam-new-rule/SKILL.md +11 -0
  659. package/codeyam-cli/templates/{codeyam:setup.md → skills/codeyam-setup/SKILL.md} +13 -1
  660. package/codeyam-cli/templates/{codeyam:sim.md → skills/codeyam-sim/SKILL.md} +1 -1
  661. package/codeyam-cli/templates/{codeyam:test.md → skills/codeyam-test/SKILL.md} +1 -1
  662. package/codeyam-cli/templates/{codeyam:verify.md → skills/codeyam-verify/SKILL.md} +1 -1
  663. package/package.json +28 -21
  664. package/packages/ai/index.js +1 -1
  665. package/packages/ai/index.js.map +1 -1
  666. package/packages/ai/src/lib/analyzeScope.js +21 -1
  667. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  668. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  669. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  670. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  671. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  672. package/packages/ai/src/lib/astScopes/processExpression.js +78 -1
  673. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  674. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  675. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  676. package/packages/ai/src/lib/completionCall.js +10 -7
  677. package/packages/ai/src/lib/completionCall.js.map +1 -1
  678. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +495 -10
  679. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  680. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +5 -1
  681. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  682. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +11 -2
  683. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  684. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +2 -2
  685. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  686. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  687. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  688. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  689. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  690. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +122 -12
  691. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  692. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +15 -1
  693. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -1
  694. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +78 -17
  695. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  696. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  697. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  698. package/packages/ai/src/lib/dataStructureChunking.js +30 -11
  699. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -1
  700. package/packages/ai/src/lib/generateEntityDataStructure.js +46 -2
  701. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  702. package/packages/ai/src/lib/generateEntityScenarioData.js +89 -5
  703. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  704. package/packages/ai/src/lib/generateExecutionFlows.js +86 -2
  705. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  706. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +242 -81
  707. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  708. package/packages/ai/src/lib/isolateScopes.js +39 -3
  709. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  710. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  711. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  712. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  713. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  714. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +17 -2
  715. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  716. package/packages/analyze/index.js +1 -0
  717. package/packages/analyze/index.js.map +1 -1
  718. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  719. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  720. package/packages/analyze/src/lib/asts/index.js +4 -2
  721. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  722. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  723. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  724. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +52 -2
  725. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  726. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +10 -0
  727. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  728. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  729. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  730. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  731. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  732. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +907 -0
  733. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  734. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +5 -1
  735. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  736. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +51 -14
  737. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  738. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +181 -13
  739. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  740. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  741. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  742. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +328 -49
  743. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  744. package/packages/analyze/src/lib/index.js +1 -0
  745. package/packages/analyze/src/lib/index.js.map +1 -1
  746. package/packages/database/index.js +1 -0
  747. package/packages/database/index.js.map +1 -1
  748. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  749. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  750. package/packages/database/src/lib/analysisToDb.js +1 -1
  751. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  752. package/packages/database/src/lib/branchToDb.js +1 -1
  753. package/packages/database/src/lib/branchToDb.js.map +1 -1
  754. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  755. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  756. package/packages/database/src/lib/commitToDb.js +1 -1
  757. package/packages/database/src/lib/commitToDb.js.map +1 -1
  758. package/packages/database/src/lib/fileToDb.js +1 -1
  759. package/packages/database/src/lib/fileToDb.js.map +1 -1
  760. package/packages/database/src/lib/kysely/db.js +8 -0
  761. package/packages/database/src/lib/kysely/db.js.map +1 -1
  762. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +65 -0
  763. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  764. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  765. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  766. package/packages/database/src/lib/loadCommits.js +23 -13
  767. package/packages/database/src/lib/loadCommits.js.map +1 -1
  768. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  769. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  770. package/packages/database/src/lib/projectToDb.js +1 -1
  771. package/packages/database/src/lib/projectToDb.js.map +1 -1
  772. package/packages/database/src/lib/saveFiles.js +1 -1
  773. package/packages/database/src/lib/saveFiles.js.map +1 -1
  774. package/packages/database/src/lib/scenarioToDb.js +1 -1
  775. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  776. package/packages/database/src/lib/updateCommitMetadata.js +100 -89
  777. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  778. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  779. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  780. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  781. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  782. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  783. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  784. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  785. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  786. package/packages/types/src/enums/ProjectFramework.js +2 -0
  787. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  788. package/packages/utils/src/lib/fs/rsyncCopy.js +98 -3
  789. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  790. package/scripts/npm-post-install.cjs +34 -0
  791. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -118
  792. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  793. package/codeyam-cli/src/commands/list.js +0 -31
  794. package/codeyam-cli/src/commands/list.js.map +0 -1
  795. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  796. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  797. package/codeyam-cli/src/utils/reviewedRules.js +0 -92
  798. package/codeyam-cli/src/utils/reviewedRules.js.map +0 -1
  799. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  800. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  801. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-C8lyxW9k.js +0 -34
  802. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +0 -6
  803. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BdhJEx6B.js +0 -21
  804. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +0 -1
  805. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js +0 -6
  806. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-D1T4TGjf.js +0 -6
  807. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +0 -6
  808. package/codeyam-cli/src/webserver/build/client/assets/git-CPTZZ-JZ.js +0 -15
  809. package/codeyam-cli/src/webserver/build/client/assets/globals-CX9f-5xM.css +0 -1
  810. package/codeyam-cli/src/webserver/build/client/assets/manifest-bba56ec1.js +0 -1
  811. package/codeyam-cli/src/webserver/build/client/assets/memory-DuTFSyJ2.js +0 -92
  812. package/codeyam-cli/src/webserver/build/client/assets/root-DTfSQARG.js +0 -62
  813. package/codeyam-cli/src/webserver/build/client/assets/settings-CS5f3WzT.js +0 -1
  814. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-C1v1PQzo.js +0 -1
  815. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-aSv48UbS.js +0 -2
  816. package/codeyam-cli/src/webserver/build/server/assets/index-TD1f-DHV.js +0 -1
  817. package/codeyam-cli/src/webserver/build/server/assets/server-build-BQ-1XyEa.js +0 -258
  818. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  819. package/codeyam-cli/templates/codeyam:diagnose.md +0 -803
  820. package/codeyam-cli/templates/codeyam:memory.md +0 -403
  821. package/codeyam-cli/templates/codeyam:new-rule.md +0 -52
  822. package/scripts/finalize-analyzer.cjs +0 -81
@@ -1,146 +0,0 @@
1
- import * as path from 'path';
2
- import * as fs from 'fs';
3
- import { error, header, info, success } from "../utils/progress.js";
4
- import { getProjectRoot } from "../state.js";
5
- import { initializeEnvironment, requireBranchAndProject, } from "../utils/database.js";
6
- import { getDatabase, loadAnalysis } from "../../../packages/database/index.js";
7
- import { getWebappInfo } from "../../../packages/utils/index.js";
8
- /**
9
- * Detect the type of identifier provided:
10
- * - UUID format: could be scenario ID, analysis ID, or entity SHA
11
- * - Path format: file path (contains / or ends with .ts/.tsx/.js/.jsx)
12
- */
13
- function isFilePath(identifier) {
14
- return (identifier.includes('/') ||
15
- identifier.endsWith('.ts') ||
16
- identifier.endsWith('.tsx') ||
17
- identifier.endsWith('.js') ||
18
- identifier.endsWith('.jsx'));
19
- }
20
- const webappInfoCommand = {
21
- command: 'webapp-info <identifier>',
22
- describe: 'Show webapp info and start command for a scenario, analysis, entity SHA, or file path',
23
- builder: {
24
- identifier: {
25
- type: 'string',
26
- describe: 'Scenario ID, analysis ID, entity SHA, or file path',
27
- demandOption: true,
28
- },
29
- },
30
- handler: async (argv) => {
31
- header('Webapp Information');
32
- const { identifier } = argv;
33
- const projectRoot = getProjectRoot();
34
- if (!projectRoot) {
35
- error('Not in a CodeYam project. Run: codeyam init');
36
- return;
37
- }
38
- try {
39
- await initializeEnvironment();
40
- // Get project configuration
41
- const configPath = path.join(projectRoot, '.codeyam', 'config.json');
42
- const config = JSON.parse(fs.readFileSync(configPath, 'utf8'));
43
- const { projectSlug } = config;
44
- if (!projectSlug) {
45
- error('Project slug not found in config');
46
- return;
47
- }
48
- const { project } = await requireBranchAndProject(projectSlug);
49
- const webapps = project.metadata?.webapps || [];
50
- if (webapps.length === 0) {
51
- error('No webapps configured in project metadata');
52
- return;
53
- }
54
- const packageManager = project.metadata?.packageManager || 'npm';
55
- const environmentVariables = config.environmentVariables || [];
56
- const port = 3112;
57
- let filePath;
58
- let entityName;
59
- if (isFilePath(identifier)) {
60
- // Identifier is a file path
61
- filePath = identifier;
62
- info(`Using file path: ${filePath}`);
63
- }
64
- else {
65
- // Identifier is an ID - try to resolve it
66
- const db = getDatabase();
67
- // First try as scenario ID
68
- const scenarioRow = await db
69
- .selectFrom('scenarios')
70
- .select(['id', 'analysis_id'])
71
- .where('id', '=', identifier)
72
- .executeTakeFirst();
73
- if (scenarioRow) {
74
- info(`Found scenario, loading analysis ${scenarioRow.analysis_id}`);
75
- const analysis = await loadAnalysis({ id: scenarioRow.analysis_id });
76
- if (!analysis) {
77
- error(`Analysis ${scenarioRow.analysis_id} not found`);
78
- return;
79
- }
80
- filePath = analysis.filePath;
81
- entityName = analysis.entityName;
82
- }
83
- else {
84
- // Try as analysis ID
85
- const analysisRow = await db
86
- .selectFrom('analyses')
87
- .select(['id', 'file_path', 'entity_name'])
88
- .where('id', '=', identifier)
89
- .executeTakeFirst();
90
- if (analysisRow) {
91
- info(`Found analysis ${identifier}`);
92
- filePath = analysisRow.file_path;
93
- entityName = analysisRow.entity_name;
94
- }
95
- else {
96
- // Try as entity SHA
97
- const entityRow = await db
98
- .selectFrom('entities')
99
- .select(['sha', 'file_path', 'name'])
100
- .where('sha', '=', identifier)
101
- .executeTakeFirst();
102
- if (entityRow) {
103
- info(`Found entity ${entityRow.name}`);
104
- filePath = entityRow.file_path;
105
- entityName = entityRow.name;
106
- }
107
- else {
108
- error(`Identifier "${identifier}" not found as scenario, analysis, entity, or file path`);
109
- return;
110
- }
111
- }
112
- }
113
- }
114
- // Get webapp info
115
- const webappInfo = getWebappInfo({
116
- filePath,
117
- webapps,
118
- environmentVariables,
119
- port,
120
- packageManager,
121
- });
122
- // Output results
123
- info('');
124
- if (entityName) {
125
- info(`Entity: ${entityName}`);
126
- }
127
- info(`File: ${filePath}`);
128
- info('');
129
- success('Webapp Details:');
130
- info(` Path: ${webappInfo.webappPath}`);
131
- info(` Framework: ${webappInfo.framework}`);
132
- info(` Package Manager: ${webappInfo.packageManager}`);
133
- info('');
134
- success('Start Command:');
135
- info(` ${webappInfo.startCommand}`);
136
- info('');
137
- success('URL:');
138
- info(` ${webappInfo.url}`);
139
- }
140
- catch (err) {
141
- error(`Failed to get webapp info: ${err.message}`);
142
- }
143
- },
144
- };
145
- export default webappInfoCommand;
146
- //# sourceMappingURL=webapp-info.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"webapp-info.js","sourceRoot":"","sources":["../../../../src/commands/webapp-info.ts"],"names":[],"mappings":"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"}
@@ -1,92 +0,0 @@
1
- // Utility functions for managing reviewed rules state
2
- import path from 'path';
3
- import fs from 'fs/promises';
4
- const REVIEWED_RULES_FILE = 'reviewed-rules.json';
5
- const CURRENT_VERSION = 1;
6
- /**
7
- * Get the path to the reviewed-rules.json file
8
- */
9
- function getReviewedRulesPath(projectRoot) {
10
- return path.join(projectRoot, '.codeyam', REVIEWED_RULES_FILE);
11
- }
12
- /**
13
- * Load reviewed rules from .codeyam/reviewed-rules.json
14
- */
15
- export async function loadReviewedRules(projectRoot) {
16
- const filePath = getReviewedRulesPath(projectRoot);
17
- try {
18
- const content = await fs.readFile(filePath, 'utf-8');
19
- const data = JSON.parse(content);
20
- // Validate version
21
- if (data.version !== CURRENT_VERSION) {
22
- console.warn(`[reviewedRules] Unknown version ${data.version}, using empty state`);
23
- return { version: CURRENT_VERSION, rules: {} };
24
- }
25
- return data;
26
- }
27
- catch (error) {
28
- // File doesn't exist or is invalid - return empty state
29
- return { version: CURRENT_VERSION, rules: {} };
30
- }
31
- }
32
- /**
33
- * Save reviewed rules to .codeyam/reviewed-rules.json
34
- */
35
- export async function saveReviewedRules(projectRoot, data) {
36
- const filePath = getReviewedRulesPath(projectRoot);
37
- // Ensure .codeyam directory exists
38
- const codeyamDir = path.dirname(filePath);
39
- await fs.mkdir(codeyamDir, { recursive: true });
40
- await fs.writeFile(filePath, JSON.stringify(data, null, 2), 'utf-8');
41
- }
42
- /**
43
- * Check if a rule is reviewed based on its entry and current lastModified
44
- *
45
- * A rule is considered unreviewed if:
46
- * - It's not in the reviewed rules file, OR
47
- * - Its current lastModified is newer than lastModifiedWhenReviewed
48
- */
49
- export function isRuleReviewed(entry, currentLastModified) {
50
- if (!entry) {
51
- return false;
52
- }
53
- const reviewedAt = new Date(entry.lastModifiedWhenReviewed).getTime();
54
- const current = new Date(currentLastModified).getTime();
55
- // If the rule was modified after it was reviewed, it's unreviewed
56
- return current <= reviewedAt;
57
- }
58
- /**
59
- * Mark a rule as reviewed
60
- */
61
- export async function markRuleReviewed(projectRoot, rulePath, currentLastModified) {
62
- const data = await loadReviewedRules(projectRoot);
63
- data.rules[rulePath] = {
64
- reviewedAt: new Date().toISOString(),
65
- lastModifiedWhenReviewed: currentLastModified,
66
- };
67
- await saveReviewedRules(projectRoot, data);
68
- }
69
- /**
70
- * Mark a rule as unreviewed (remove from reviewed list)
71
- */
72
- export async function markRuleUnreviewed(projectRoot, rulePath) {
73
- const data = await loadReviewedRules(projectRoot);
74
- delete data.rules[rulePath];
75
- await saveReviewedRules(projectRoot, data);
76
- }
77
- /**
78
- * Compute reviewed status for a collection of rules
79
- *
80
- * @param rules - Array of rules with filePath and lastModified
81
- * @param reviewedData - The loaded reviewed rules data
82
- * @returns Record mapping filePath to boolean (true = reviewed)
83
- */
84
- export function computeReviewedStatus(rules, reviewedData) {
85
- const status = {};
86
- for (const rule of rules) {
87
- const entry = reviewedData.rules[rule.filePath];
88
- status[rule.filePath] = isRuleReviewed(entry, rule.lastModified);
89
- }
90
- return status;
91
- }
92
- //# sourceMappingURL=reviewedRules.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"reviewedRules.js","sourceRoot":"","sources":["../../../../src/utils/reviewedRules.ts"],"names":[],"mappings":"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"}
@@ -1,152 +0,0 @@
1
- import { runClaudeCode } from "./claude-code.js";
2
- export async function detectUniversalMocks(existingMocks = [], progressCallback) {
3
- const claudeResult = await runClaudeCode({
4
- prompt: getPrompt(existingMocks),
5
- allowedTools: ['Bash(jq:*)'],
6
- progressCallback,
7
- });
8
- if (!claudeResult) {
9
- // Claude Code package failed to load, return empty mocks
10
- return {
11
- universalMocks: existingMocks,
12
- duration_ms: 0,
13
- total_cost_usd: 0,
14
- };
15
- }
16
- let resultString = claudeResult.result;
17
- // use regexp to extract ths ```json\n...\n``` block
18
- const jsonMatch = resultString.match(/```json\n([\s\S]*?)\n```/);
19
- if (jsonMatch && jsonMatch.length > 1) {
20
- resultString = jsonMatch[1].trim();
21
- }
22
- else {
23
- console.warn(`CodeYam Warning: Claude Code did not return markdown-wrapped JSON`);
24
- // fall back to the entire result if no JSON block is found
25
- }
26
- const result = JSON.parse(resultString);
27
- const universalMocks = result && result.universalMocks && Array.isArray(result.universalMocks)
28
- ? result.universalMocks
29
- .map((mock) => {
30
- if (mock.content &&
31
- typeof mock.content === 'string' &&
32
- mock.filePath &&
33
- typeof mock.filePath === 'string' &&
34
- mock.entityName &&
35
- typeof mock.entityName === 'string') {
36
- return {
37
- content: mock.content,
38
- filePath: mock.filePath,
39
- entityName: mock.entityName,
40
- };
41
- }
42
- console.warn(`CodeYam Warning: Invalid universal mock format`, mock);
43
- return null;
44
- })
45
- .filter((mock) => mock !== null)
46
- : [];
47
- return {
48
- universalMocks,
49
- duration_ms: claudeResult.duration_ms,
50
- total_cost_usd: claudeResult.total_cost_usd,
51
- };
52
- }
53
- function getPrompt(existingMocks) {
54
- const mocksString = JSON.stringify(existingMocks);
55
- return `
56
- Hi Claude! You should find in this directory a primarily TypeScript-based web application. If that doesn't seem to be the case, return an error object:
57
- \`\`\`
58
- {
59
- "error": "<reason for failure>"
60
- }
61
- \`\`\`
62
-
63
- Now, your job is to explore the codebase and read enough source modules to determine if any of them rely on environment variables or external services in a way which **prevents startup**. You will MODIFY NO FILES. You are only gathering data, and you will finish by outputting a JSON object of these 'universal mocks'.
64
-
65
- **CRITICAL: Mocks should be MINIMAL** - just enough to prevent startup crashes, not comprehensive implementations.
66
-
67
- We will illustrate with examples:
68
-
69
- **Example 1: Class that's initialized on load**
70
- File: \`lib/dbNotifier.ts\`
71
- \`\`\`
72
- export class DbNotifier extends EventEmitter {
73
- constructor() {
74
- super();
75
- this.db = connectToDatabase(process.env.DATABASE_URL!); // ❌ Crashes on load
76
- }
77
- async start() { /* ... */ }
78
- }
79
- \`\`\`
80
-
81
- **Minimal mock** (just enough to start):
82
- \`\`\`
83
- class DbNotifier extends EventEmitter { async start() {} }
84
- \`\`\`
85
-
86
- **Example 2: Client initialized on load**
87
- File: \`lib/supabase.ts\`
88
- \`\`\`
89
- import { createClient } from "@supabase/supabase-js"
90
- export const supabase = createClient(
91
- process.env.NEXT_PUBLIC_SUPABASE_URL!, // ❌ Crashes on load
92
- process.env.NEXT_PUBLIC_SUPABASE_ANON_KEY!
93
- )
94
- \`\`\`
95
-
96
- **Minimal mock**:
97
- \`\`\`
98
- export const supabase = {
99
- auth: {
100
- getSession: async () => ({ data: { session: null } }),
101
- onAuthStateChange: () => ({ data: { subscription: { unsubscribe: () => {} } } })
102
- }
103
- };
104
- \`\`\`
105
-
106
- **Example 3: NO MOCK NEEDED**
107
- File: \`lib/client.ts\`
108
- \`\`\`
109
- export function getClient() {
110
- return createClient(process.env.API_URL!); // ✅ OK - not called on load
111
- }
112
- \`\`\`
113
- No mock needed - lazy initialization won't crash on startup.
114
-
115
- **Key principles:**
116
- 1. Only mock things that are **executed during module load**
117
- 2. Mocks should be **minimal** - empty methods/properties are fine
118
- 3. We need the app to **compile and start**, not work correctly
119
- 4. Return types should match what TypeScript expects (but values can be empty/null) When you've determined that a file requires a universal mock, you will include it in your output, which might look something like this:
120
- \`\`\`json
121
- {
122
- "universalMocks": [
123
- {
124
- "entityName": "DbNotifier",
125
- "filePath": "lib/dbNotifier.ts",
126
- "content": "class DbNotifier extends EventEmitter { async start() {} }"
127
- },
128
- {
129
- "entityName": "supabase",
130
- "filePath": "lib/supabase.ts",
131
- "content": "export const supabase = { auth: { getSession: async () => ({ data: { session: null } }) } };"
132
- }
133
- ]
134
- }
135
- \`\`\`
136
-
137
- Note: You MUST wrap the result JSON in \`\`\`json\n...\n\`\`\` so that it can later be extracted programmatically.
138
-
139
- So a "universal mock" object contains of a file path (\`/example/lib/supabase.ts\` in our case), an entity name (\`supabase\`), and the full text of the TypeScript with which to replace that entity in the mocked-up module.
140
- - There can be multiple mocks in the same file, for different entities. An entity is e.g. a function, a type, a variable, a React component, etc.
141
- - Each universal mock should contain ONLY the replacement content for a single entity. If a file exports multiple entities that need mocking, create separate mock objects for each entity.
142
- - Remember that the JSON string must be escaped.
143
-
144
- The current \`universalMocks\` array, which you should merge into / append to, is as follows:
145
- \`\`\`
146
- ${mocksString}
147
- \`\`\`
148
-
149
- Now put on your best sleuthing cap and figure out how to scan this repository for likely signs of external dependencies that may need mocking, compile a list of universal mocks, and return it as JSON on the format shown above.
150
- `;
151
- }
152
- //# sourceMappingURL=universal-mocks.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"universal-mocks.js","sourceRoot":"","sources":["../../../../src/utils/universal-mocks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAI9C,MAAM,CAAC,KAAK,UAAU,oBAAoB,CACxC,gBAAmD,EAAE,EACrD,gBAAiD;IAMjD,MAAM,YAAY,GAAG,MAAM,aAAa,CAAC;QACvC,MAAM,EAAE,SAAS,CAAC,aAAa,CAAC;QAChC,YAAY,EAAE,CAAC,YAAY,CAAC;QAC5B,gBAAgB;KACjB,CAAC,CAAC;IAEH,IAAI,CAAC,YAAY,EAAE,CAAC;QAClB,yDAAyD;QACzD,OAAO;YACL,cAAc,EAAE,aAAa;YAC7B,WAAW,EAAE,CAAC;YACd,cAAc,EAAE,CAAC;SAClB,CAAC;IACJ,CAAC;IAED,IAAI,YAAY,GAAG,YAAY,CAAC,MAAM,CAAC;IAEvC,oDAAoD;IACpD,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;IACjE,IAAI,SAAS,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACtC,YAAY,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;IACrC,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,IAAI,CACV,mEAAmE,CACpE,CAAC;QACF,2DAA2D;IAC7D,CAAC;IAED,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IACxC,MAAM,cAAc,GAClB,MAAM,IAAI,MAAM,CAAC,cAAc,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,cAAc,CAAC;QACrE,CAAC,CAAC,MAAM,CAAC,cAAc;aAClB,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE;YACjB,IACE,IAAI,CAAC,OAAO;gBACZ,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ;gBAChC,IAAI,CAAC,QAAQ;gBACb,OAAO,IAAI,CAAC,QAAQ,KAAK,QAAQ;gBACjC,IAAI,CAAC,UAAU;gBACf,OAAO,IAAI,CAAC,UAAU,KAAK,QAAQ,EACnC,CAAC;gBACD,OAAO;oBACL,OAAO,EAAE,IAAI,CAAC,OAAO;oBACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,UAAU,EAAE,IAAI,CAAC,UAAU;iBAC5B,CAAC;YACJ,CAAC;YACD,OAAO,CAAC,IAAI,CACV,gDAAgD,EAChD,IAAI,CACL,CAAC;YACF,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;aACD,MAAM,CAAC,CAAC,IAAiB,EAAE,EAAE,CAAC,IAAI,KAAK,IAAI,CAAC;QACjD,CAAC,CAAC,EAAE,CAAC;IAET,OAAO;QACL,cAAc;QACd,WAAW,EAAE,YAAY,CAAC,WAAW;QACrC,cAAc,EAAE,YAAY,CAAC,cAAc;KAC5C,CAAC;AACJ,CAAC;AAED,SAAS,SAAS,CAAC,aAAqB;IACtC,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;IAElD,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA2FP,WAAW;;;;GAIV,CAAC;AACJ,CAAC"}
@@ -1,34 +0,0 @@
1
- import{c as _,r as e,j as h}from"./chunk-EPOLDU6W-CXRTFQ3F.js";import{u as K}from"./useLastLogLine-aSv48UbS.js";function U(s){const r=s.replace(/[^a-zA-Z0-9_]+/g,"_");return r.slice(0,1).toUpperCase()+r.slice(1)}function V({analysisId:s,scenarioId:r,scenarioName:a,projectSlug:i,enabled:g=!0,refreshTrigger:f=0}){const k=_(),[S,w]=e.useState(null),[A,E]=e.useState(!1),[B,c]=e.useState(!1),[q,l]=e.useState(!1),d=e.useRef(!1),x=e.useRef(null),I=e.useRef(null),[M,m]=e.useState(0),[z,R]=e.useState(0),n=e.useRef(null),u=e.useRef(!1),{interactiveUrl:b,resetLogs:L}=K(i,g),y=e.useRef(r),F=e.useRef(f);e.useEffect(()=>{F.current!==f&&(F.current=f,S&&(console.log("[useInteractiveMode] Manual refresh triggered"),c(!0),l(!1),m(0),R(t=>t+1),u.current=!1,n.current&&(clearTimeout(n.current),n.current=null)))},[f,S]),e.useEffect(()=>{if(y.current!==r&&(y.current=r,x.current&&I.current&&a)){const t=U(I.current),o=U(a),p=x.current.replace(t,o);w(p),c(!0),l(!1),m(0),R(v=>v+1),u.current=!1,n.current&&(clearTimeout(n.current),n.current=null);return}},[r,a]),e.useEffect(()=>{if(b){const t=b+"?width=600px";x.current=t,a&&(I.current=a),w(t),E(!1),c(!0)}},[b]),e.useEffect(()=>{const t=o=>{o.data.type==="codeyam-resize"&&(u.current||(u.current=!0,n.current&&(clearTimeout(n.current),n.current=null),m(0),l(!0),requestAnimationFrame(()=>{requestAnimationFrame(()=>{c(!1)})})))};return window.addEventListener("message",t),()=>window.removeEventListener("message",t)},[]);const j=()=>{u.current=!1,n.current&&clearTimeout(n.current);const t=500*Math.pow(2,M);n.current=setTimeout(()=>{u.current||(M<2?(m(o=>o+1),R(o=>o+1),c(!0)):(console.error("[useInteractiveMode] Interactive mode failed to load after 3 attempts - showing iframe anyway"),l(!0),c(!1)))},t)};return e.useEffect(()=>{g&&!d.current&&r&&s&&(d.current=!0,E(!0),l(!1),w(null),(async()=>{if(i)try{await fetch(`/api/logs/${i}`,{method:"DELETE"})}catch(o){console.error("[useInteractiveMode] Failed to clear log file:",o)}L(),k.submit({action:"start",analysisId:s,scenarioId:r},{method:"post",action:"/api/interactive-mode"})})())},[g,r,s,L,i]),e.useEffect(()=>{const t=s,o=()=>{if(d.current&&t){const v=new URLSearchParams({action:"stop",analysisId:t});console.log("[useInteractiveMode] Sending stop request via sendBeacon");const T=navigator.sendBeacon("/api/interactive-mode",v);console.log("[useInteractiveMode] sendBeacon result:",T),T||(console.log("[useInteractiveMode] sendBeacon failed, using fetch fallback"),fetch("/api/interactive-mode",{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:v,keepalive:!0}).catch(D=>console.error("Failed to stop interactive mode:",D)))}},p=()=>{o()};return window.addEventListener("beforeunload",p),()=>{window.removeEventListener("beforeunload",p),console.log("[useInteractiveMode] Cleanup running:",{hasStarted:d.current,analysisId:t}),o()}},[s]),{interactiveServerUrl:S,isStarting:A,isLoading:B,showIframe:q,iframeKey:z,onIframeLoad:j}}function Z(){return h.jsxs("div",{className:"spinner-container",children:[h.jsx("span",{className:"loader"}),h.jsx("style",{children:`
2
- .loader {
3
- width: 48px;
4
- height: 48px;
5
- border: 3px solid rgba(0, 92, 117, 0.2);
6
- border-radius: 50%;
7
- display: inline-block;
8
- position: relative;
9
- box-sizing: border-box;
10
- animation: rotation 1s linear infinite;
11
- }
12
- .loader::after {
13
- content: '';
14
- box-sizing: border-box;
15
- position: absolute;
16
- left: 50%;
17
- top: 50%;
18
- transform: translate(-50%, -50%);
19
- width: 56px;
20
- height: 56px;
21
- border-radius: 50%;
22
- border: 3px solid;
23
- border-color: #005c75 transparent;
24
- }
25
-
26
- @keyframes rotation {
27
- 0% {
28
- transform: rotate(0deg);
29
- }
30
- 100% {
31
- transform: rotate(360deg);
32
- }
33
- }
34
- `})]})}const C=["⣾","⣽","⣻","⢿","⡿","⣟","⣯","⣷"],N=80;function $(){const[s,r]=e.useState(0);return e.useEffect(()=>{const a=setInterval(()=>{r(i=>(i+1)%C.length)},N);return()=>clearInterval(a)},[]),h.jsx("span",{className:"inline-block mr-2",children:C[s]})}export{$ as I,Z as S,V as u};
@@ -1,6 +0,0 @@
1
- import{c}from"./createLucideIcon-BdhJEx6B.js";/**
2
- * @license lucide-react v0.556.0 - ISC
3
- *
4
- * This source code is licensed under the ISC license.
5
- * See the LICENSE file in the root directory of this source tree.
6
- */const e=[["rect",{width:"14",height:"14",x:"8",y:"8",rx:"2",ry:"2",key:"17jyea"}],["path",{d:"M4 16c-1.1 0-2-.9-2-2V4c0-1.1.9-2 2-2h10c1.1 0 2 .9 2 2",key:"zix9uf"}]],t=c("copy",e);export{t as C};
@@ -1,21 +0,0 @@
1
- import{r as s}from"./chunk-EPOLDU6W-CXRTFQ3F.js";/**
2
- * @license lucide-react v0.556.0 - ISC
3
- *
4
- * This source code is licensed under the ISC license.
5
- * See the LICENSE file in the root directory of this source tree.
6
- */const C=t=>t.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase(),w=t=>t.replace(/^([A-Z])|[\s-_]+(\w)/g,(e,r,o)=>o?o.toUpperCase():r.toLowerCase()),i=t=>{const e=w(t);return e.charAt(0).toUpperCase()+e.slice(1)},l=(...t)=>t.filter((e,r,o)=>!!e&&e.trim()!==""&&o.indexOf(e)===r).join(" ").trim(),f=t=>{for(const e in t)if(e.startsWith("aria-")||e==="role"||e==="title")return!0};/**
7
- * @license lucide-react v0.556.0 - ISC
8
- *
9
- * This source code is licensed under the ISC license.
10
- * See the LICENSE file in the root directory of this source tree.
11
- */var h={xmlns:"http://www.w3.org/2000/svg",width:24,height:24,viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round",strokeLinejoin:"round"};/**
12
- * @license lucide-react v0.556.0 - ISC
13
- *
14
- * This source code is licensed under the ISC license.
15
- * See the LICENSE file in the root directory of this source tree.
16
- */const g=s.forwardRef(({color:t="currentColor",size:e=24,strokeWidth:r=2,absoluteStrokeWidth:o,className:n="",children:a,iconNode:u,...c},p)=>s.createElement("svg",{ref:p,...h,width:e,height:e,stroke:t,strokeWidth:o?Number(r)*24/Number(e):r,className:l("lucide",n),...!a&&!f(c)&&{"aria-hidden":"true"},...c},[...u.map(([m,d])=>s.createElement(m,d)),...Array.isArray(a)?a:[a]]));/**
17
- * @license lucide-react v0.556.0 - ISC
18
- *
19
- * This source code is licensed under the ISC license.
20
- * See the LICENSE file in the root directory of this source tree.
21
- */const b=(t,e)=>{const r=s.forwardRef(({className:o,...n},a)=>s.createElement(g,{ref:a,iconNode:e,className:l(`lucide-${C(i(t))}`,`lucide-${t}`,o),...n}));return r.displayName=i(t),r};export{b as c};
@@ -1 +0,0 @@
1
- import{w as t,c as r,j as e}from"./chunk-EPOLDU6W-CXRTFQ3F.js";import{S as i}from"./ScenarioViewer-DzccYyI8.js";import{W as n}from"./InteractivePreview-aht4aafF.js";import"./useCustomSizes-C1v1PQzo.js";import"./LogViewer-xgeCVgSM.js";import"./SafeScreenshot-DuDvi0jm.js";import"./useLastLogLine-aSv48UbS.js";import"./InlineSpinner-C8lyxW9k.js";import"./preload-helper-ckwbz45p.js";import"./ReportIssueModal-OApQuNyq.js";import"./createLucideIcon-BdhJEx6B.js";import"./circle-check-BOARzkeR.js";import"./triangle-alert-B6LgvRJg.js";import"./copy-Bb-80kDT.js";import"./scenarioStatus-B_8jpV3e.js";const y=()=>[{title:"Empty State - CodeYam"},{name:"description",content:"Simulations empty state development view"}],w=t(function(){r();const s={sha:"mock-sha",name:"Dashboard",filePath:"codeyam-cli/src/webserver/app/routes/_index.tsx",entityType:"visual"};return e.jsx(n,{children:e.jsxs("div",{className:"h-screen bg-[#F8F7F6] flex flex-col overflow-hidden",children:[e.jsx("header",{className:"bg-white border-b border-gray-200 shrink-0 relative h-[54px]",children:e.jsxs("div",{className:"flex items-center h-full px-6 gap-6",children:[e.jsxs("div",{className:"flex items-center gap-3 min-w-0",children:[e.jsx("svg",{width:"17",height:"17",viewBox:"0 0 17 17",fill:"none",className:"shrink-0",children:e.jsx("path",{d:"M13 8.5H4M4 8.5L8.5 4M4 8.5L8.5 13",stroke:"#005c75",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})}),e.jsx("h1",{className:"text-lg font-semibold text-black m-0 leading-[26px] shrink-0",children:"Dashboard"}),e.jsx("span",{className:"text-xs text-[#626262] font-mono whitespace-nowrap overflow-hidden text-ellipsis min-w-0",children:"codeyam-cli/src/webserver/app/routes/_index.tsx"})]}),e.jsxs("div",{className:"flex items-center gap-3 shrink-0",children:[e.jsxs("div",{className:"flex items-center gap-2 px-[15px] py-0 h-[26px] bg-[#efefef] border border-[#e1e1e1] rounded",children:[e.jsx("div",{className:"w-2 h-2 rounded-full bg-[#626262]"}),e.jsx("span",{className:"text-xs font-semibold text-[#626262]",children:"Not analyzed"})]}),e.jsx("button",{className:"px-[15px] py-0 h-[26px] bg-[#005c75] text-white rounded text-xs font-semibold border-none cursor-pointer hover:bg-[#004a5e] transition-colors",children:"Analyze"})]}),e.jsxs("div",{className:"flex items-center gap-1 text-[10px] text-[#626262] ml-auto",children:[e.jsx("span",{className:"leading-[22px]",children:"Next Entity"}),e.jsx("svg",{width:"17",height:"17",viewBox:"0 0 17 17",fill:"none",className:"shrink-0",children:e.jsx("path",{d:"M4 8.5H13M13 8.5L8.5 4M13 8.5L8.5 13",stroke:"#005c75",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]})]})}),e.jsx("div",{className:"bg-[#efefef] border-b border-[#efefef] shrink-0",children:e.jsxs("div",{className:"flex items-center gap-3 h-11 px-[15px]",children:[e.jsxs("div",{className:"px-4 flex items-center justify-center gap-3 shrink-0 text-sm rounded bg-[#343434] text-[#efefef] font-semibold h-8",children:["Scenarios",e.jsx("span",{className:"px-2 py-0.5 rounded-[9px] text-xs font-semibold bg-[#cbf3fa] text-[#005c75] min-w-[25px] text-center",children:"0"})]}),e.jsxs("div",{className:"px-4 flex items-center justify-center gap-3 shrink-0 text-sm rounded-[9px] text-[#3e3e3e] font-normal",children:["Related Entities",e.jsx("span",{className:"px-2 py-0.5 rounded-[9px] text-xs font-semibold bg-[#e1e1e1] text-[#3e3e3e] min-w-[25px] text-center",children:"5"})]}),e.jsx("div",{className:"px-4 shrink-0 text-sm text-[#3e3e3e] font-normal",children:"Code"}),e.jsx("div",{className:"px-4 shrink-0 text-sm text-[#3e3e3e] font-normal",children:"Data Structure"}),e.jsx("div",{className:"px-4 shrink-0 text-sm text-[#3e3e3e] font-normal",children:"History"})]})}),e.jsxs("div",{className:"flex flex-1 gap-0 min-h-0",children:[e.jsx("div",{className:"w-[165px] bg-[#e1e1e1] border-r border-[#c7c7c7] flex items-center justify-center shrink-0",children:e.jsx("span",{className:"text-xs font-medium text-[#8e8e8e] leading-5",children:"No Scenarios"})}),e.jsx(i,{selectedScenario:null,analysis:void 0,entity:s,viewMode:"screenshot",cacheBuster:Date.now(),hasScenarios:!1,isAnalyzing:!1,projectSlug:null,hasAnApiKey:!0})]})]})})});export{w as default,y as meta};
@@ -1,6 +0,0 @@
1
- import{w as Y,u as q,a as G,b as J,r as l,j as e}from"./chunk-EPOLDU6W-CXRTFQ3F.js";import{u as O,S as P,I as $}from"./InlineSpinner-C8lyxW9k.js";import{u as Q}from"./useLastLogLine-aSv48UbS.js";import{u as X,V as Z,S as ee}from"./useCustomSizes-C1v1PQzo.js";import{c as te}from"./cy-logo-cli-DcX-ZS3p.js";const b=[{name:"Mobile",width:375,height:667},{name:"Tablet",width:768,height:1024},{name:"Laptop",width:1024,height:768},{name:"Desktop",width:1440,height:900}],de=Y(function(){const{entity:i,scenario:s,analysis:r,projectSlug:m}=q(),u=G();J();const[ne,w]=l.useState(null),[_,N]=l.useState(1440),[a,g]=l.useState({name:"Desktop",width:1440,height:900}),[z,p]=l.useState(!1),[f,B]=l.useState(null),{customSizes:S,addCustomSize:D}=X(m),x=l.useMemo(()=>[...b,...S],[S]),{interactiveServerUrl:y,isStarting:k,isLoading:C,showIframe:I,iframeKey:W,onIframeLoad:E}=O({analysisId:r==null?void 0:r.id,scenarioId:s==null?void 0:s.id,scenarioName:s==null?void 0:s.name,projectSlug:m,enabled:!0}),{lastLine:h}=Q(m,k||C),U=()=>{u(`/entity/${i.sha}`)},V=(t,n)=>{N(t);const o=x.find(M=>M.width===t&&M.height===n);w(o||null),g({name:(o==null?void 0:o.name)||"Custom",width:t,height:n})},L=t=>{w(t),N(t.width),g({name:t.name,width:t.width,height:t.height})},R=t=>{D(t,a.width,a.height??900),p(!1),g(n=>({...n,name:t}))},c=((r==null?void 0:r.scenarios)||[]).filter(t=>{var n;return!((n=t.metadata)!=null&&n.sameAsDefault)}),d=c.findIndex(t=>t.id===(s==null?void 0:s.id)),H=d+1,T=c.length,v=d>0,j=d<c.length-1,A=()=>{if(v){const t=c[d-1],n=encodeURIComponent(`/entity/${i.sha}/scenarios/${t.id}/fullscreen`);u(`/entity/${i.sha}/scenarios/${t.id}/fullscreen?from=${n}`)}},F=()=>{if(j){const t=c[d+1],n=encodeURIComponent(`/entity/${i.sha}/scenarios/${t.id}/fullscreen`);u(`/entity/${i.sha}/scenarios/${t.id}/fullscreen?from=${n}`)}},K=k||C||!I;return e.jsxs("div",{className:"fixed inset-0 bg-[#2d2d2d] flex flex-col",children:[e.jsxs("div",{className:"bg-[#3d3d3d] h-12 flex items-center px-4 gap-4 shrink-0 z-20",children:[e.jsxs("div",{className:"flex items-center gap-3 flex-1 min-w-0",children:[e.jsx("img",{src:te,alt:"CodeYam",className:"h-6 brightness-0 invert"}),e.jsx("span",{className:"text-white font-medium text-sm whitespace-nowrap",children:i.name}),e.jsxs("div",{className:"flex items-center gap-2 shrink-0",children:[e.jsx("button",{onClick:A,disabled:!v,className:`${v?"text-white hover:text-gray-300":"text-gray-600 cursor-not-allowed"} transition-colors`,"aria-label":"Previous scenario",children:e.jsx("svg",{width:"20",height:"20",viewBox:"0 0 20 20",fill:"none",children:e.jsx("path",{d:"M12.5 15L7.5 10L12.5 5",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})}),e.jsxs("span",{className:"text-gray-400 text-sm",children:[H,"/",T]}),e.jsx("button",{onClick:F,disabled:!j,className:`${j?"text-white hover:text-gray-300":"text-gray-600 cursor-not-allowed"} transition-colors`,"aria-label":"Next scenario",children:e.jsx("svg",{width:"20",height:"20",viewBox:"0 0 20 20",fill:"none",children:e.jsx("path",{d:"M7.5 15L12.5 10L7.5 5",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})})]}),e.jsxs("div",{className:"flex items-center gap-2 ml-2 min-w-0",children:[e.jsx("span",{className:"text-white font-semibold text-xs whitespace-nowrap shrink-0",children:s==null?void 0:s.name}),(s==null?void 0:s.description)&&e.jsxs("div",{className:"relative group min-w-0",children:[e.jsx("span",{className:"text-gray-400 text-xs truncate block",children:s.description}),e.jsx("div",{className:"absolute left-0 top-full mt-1 hidden group-hover:block z-50 bg-black text-white text-xs px-3 py-2 rounded shadow-lg max-w-md",children:s.description})]})]})]}),e.jsx("button",{onClick:U,className:"text-white hover:text-gray-300 transition-colors ml-4","aria-label":"Close fullscreen",children:e.jsx("svg",{width:"20",height:"20",viewBox:"0 0 20 20",fill:"none",children:e.jsx("path",{d:"M15 5L5 15M5 5L15 15",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round"})})})]}),e.jsxs("div",{className:"bg-[#e5e7eb] border-b border-[rgba(0,0,0,0.1)] shrink-0 z-10 h-6 flex items-center justify-center relative",children:[e.jsx("div",{className:"absolute inset-0 flex justify-center",children:e.jsx("div",{style:{maxWidth:`${b[b.length-1].width}px`,width:"100%"},children:e.jsx(Z,{currentViewportWidth:_,currentPresetName:a.name,onDevicePresetClick:L,devicePresets:x,hideLabel:!0,onHoverChange:B,lightMode:!0})})}),e.jsxs("div",{className:"relative z-10 flex items-center gap-2",children:[e.jsxs("div",{className:"relative w-28 h-5",children:[e.jsxs("div",{className:"absolute inset-0 bg-white text-gray-900 text-xs px-2 rounded flex items-center justify-between pointer-events-none border border-gray-300",children:[e.jsx("span",{className:"leading-none",children:(f==null?void 0:f.name)||a.name}),e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 12 12",fill:"none",className:"shrink-0",children:e.jsx("path",{d:"M3 4.5L6 7.5L9 4.5",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]}),e.jsxs("select",{value:a.name,onChange:t=>{const n=x.find(o=>o.name===t.target.value);n&&L(n)},className:"relative w-full h-full opacity-0 cursor-pointer",children:[x.map(t=>e.jsx("option",{value:t.name,children:t.name},t.name)),a.name==="Custom"&&e.jsx("option",{value:"Custom",children:"Custom"})]})]}),e.jsx("input",{type:"number",value:a.width,onChange:t=>{const n=parseInt(t.target.value,10);!isNaN(n)&&n>0&&V(n,a.height??900)},className:"bg-white text-gray-900 text-xs px-1 rounded border border-gray-300 outline-none w-16 text-center h-5 leading-none",min:"200",max:"3840"}),e.jsx("span",{className:"text-gray-400 text-xs h-5 flex items-center leading-none",children:"×"}),e.jsx("span",{className:"bg-gray-100 text-gray-600 text-xs px-1 rounded w-14 text-center h-5 flex items-center justify-center leading-none",children:a.height??900}),a.name==="Custom"&&e.jsx("button",{onClick:()=>p(!0),className:"bg-white text-gray-900 text-xs px-2 rounded h-5 flex items-center leading-none border border-gray-300 hover:bg-gray-50 transition-colors",children:"Save"})]})]}),e.jsx("div",{className:"flex-1 flex items-center justify-center overflow-auto p-8",style:{backgroundImage:`
2
- linear-gradient(45deg, #ebebeb 25%, transparent 25%),
3
- linear-gradient(-45deg, #ebebeb 25%, transparent 25%),
4
- linear-gradient(45deg, transparent 75%, #ebebeb 75%),
5
- linear-gradient(-45deg, transparent 75%, #ebebeb 75%)
6
- `,backgroundSize:"16px 16px",backgroundPosition:"0 0, 0 8px, 8px -8px, -8px 0px",backgroundColor:"#fafafa"},children:y?e.jsxs("div",{className:"relative bg-white w-full h-full",style:{maxWidth:`${a.width}px`,maxHeight:`${a.height}px`},children:[K&&e.jsx("div",{className:"absolute inset-0 flex items-center justify-center z-10",children:e.jsxs("div",{className:"flex flex-col items-center justify-center gap-6 bg-white rounded-lg p-8 shadow-sm w-[500px] h-[300px]",children:[e.jsx("div",{className:"mb-4",children:e.jsx(P,{})}),e.jsxs("div",{className:"flex flex-col gap-3 text-center",children:[e.jsx("h2",{className:"text-xl font-medium text-black leading-[28px] m-0 font-['IBM_Plex_Sans']",children:"Starting Interactive Mode"}),e.jsx("p",{className:"text-sm text-[#666] leading-5 m-0 font-['IBM_Plex_Sans']",children:"Setting up a sandboxed environment for your component"}),h&&e.jsxs("p",{className:"text-xs font-mono text-[#005c75] text-center leading-5 m-0 mt-3 font-['IBM_Plex_Mono'] uppercase",children:[e.jsx($,{}),h]})]})]})}),e.jsx("iframe",{src:y,className:"w-full h-full border-none",title:`Interactive preview: ${s==null?void 0:s.name}`,onLoad:E,style:{opacity:I?1:0}},W)]}):e.jsxs("div",{className:"flex flex-col items-center justify-center gap-6 w-[500px] h-[300px] bg-white rounded-lg p-8 shadow-sm",children:[e.jsx("div",{className:"mb-4",children:e.jsx(P,{})}),e.jsxs("div",{className:"flex flex-col gap-3 text-center",children:[e.jsx("h2",{className:"text-xl font-medium text-black leading-[28px] m-0 font-['IBM_Plex_Sans']",children:"Starting Interactive Mode"}),e.jsx("p",{className:"text-sm text-[#666] leading-5 m-0 font-['IBM_Plex_Sans']",children:"Setting up a sandboxed environment for your component"}),h&&e.jsxs("p",{className:"text-xs font-mono text-[#005c75] text-center leading-5 m-0 mt-3 font-['IBM_Plex_Mono'] uppercase",children:[e.jsx($,{}),h]})]})]})}),z&&e.jsx(ee,{width:a.width,height:a.height??900,onSave:R,onCancel:()=>p(!1)})]})});export{de as default};
@@ -1,6 +0,0 @@
1
- import{r as a,j as e,w as Z,u as ee,a as te,L as v}from"./chunk-EPOLDU6W-CXRTFQ3F.js";import{W as se,u as re,I as ae}from"./InteractivePreview-aht4aafF.js";import{u as ne}from"./InlineSpinner-C8lyxW9k.js";import{c as oe}from"./executionFlowCoverage-BWhdfn70.js";import"./preload-helper-ckwbz45p.js";import"./useLastLogLine-aSv48UbS.js";function ie({executionFlows:t,selections:r,onChange:n,disabled:i=!1}){const x=a.useCallback(s=>r.some(o=>o.flowId===s),[r]),p=a.useCallback(s=>{x(s.id)?n(r.filter(o=>o.flowId!==s.id)):n([...r,{flowId:s.id,flowName:s.name}])},[r,n,x]);return t.length===0?e.jsx("div",{className:"text-sm text-gray-500 py-2",children:"No execution flows found."}):e.jsx("div",{className:"space-y-3",children:t.map(s=>{const o=x(s.id),I=s.usedInScenarios.length>0;return e.jsxs("div",{className:"border-b border-gray-100 pb-3 last:border-0 last:pb-0",children:[e.jsxs("label",{className:"flex items-start gap-2 cursor-pointer",children:[e.jsx("input",{type:"checkbox",checked:o,onChange:()=>p(s),disabled:i,className:"mt-0.5 h-4 w-4 rounded border-gray-300 text-blue-600 focus:ring-blue-500"}),e.jsxs("div",{className:"flex-1 min-w-0",children:[e.jsxs("div",{className:"flex items-center gap-2 flex-wrap",children:[e.jsx("span",{className:"font-mono text-sm font-medium text-gray-900",children:s.name}),!I&&e.jsx("span",{className:"text-xs px-1.5 py-0.5 bg-amber-100 text-amber-700 rounded",children:"uncovered"}),s.blocksOtherFlows&&e.jsx("span",{className:"text-xs px-1.5 py-0.5 bg-purple-100 text-purple-700 rounded",children:"blocking"}),s.impact==="high"&&e.jsx("span",{className:"text-xs px-1.5 py-0.5 bg-red-100 text-red-700 rounded",children:"high impact"})]}),s.description&&e.jsx("p",{className:"text-xs text-gray-500 mt-0.5 m-0",children:s.description})]})]}),o&&s.requiredValues.length>0&&e.jsxs("div",{className:"ml-6 mt-2 p-2 bg-gray-50 rounded text-xs",children:[e.jsx("span",{className:"text-gray-700 font-medium",children:"Required values:"}),e.jsx("ul",{className:"m-0 mt-1 pl-4 space-y-0.5",children:s.requiredValues.map((h,E)=>e.jsxs("li",{className:"text-gray-600",children:[e.jsx("code",{className:"bg-gray-100 px-1 rounded",children:h.attributePath})," ",e.jsx("span",{className:"text-gray-400",children:h.comparison})," ",e.jsx("code",{className:"bg-gray-100 px-1 rounded",children:h.value})]},E))})]})]},s.id)})})}const he=({data:t})=>[{title:t!=null&&t.entity?`Create Scenario - ${t.entity.name} - CodeYam`:"Create Scenario - CodeYam"},{name:"description",content:"Create a new scenario"}];function ce(){var W;const{analysis:t,defaultScenario:r,entity:n,entitySha:i,projectSlug:x}=ee(),p=te(),{iframeRef:s}=re(),[o,I]=a.useState(""),[h,E]=a.useState(400),[b,P]=a.useState(!1),[U,R]=a.useState(!1),[G,$]=a.useState(!1),[M,L]=a.useState(null),[F,l]=a.useState(null),[d,H]=a.useState([]),D=a.useMemo(()=>{var c;return!((c=t==null?void 0:t.metadata)!=null&&c.executionFlows)||!(t!=null&&t.scenarios)?[]:oe(t.metadata.executionFlows,t.scenarios).executionFlows},[t]),{interactiveServerUrl:y,isStarting:J,isLoading:_,showIframe:q,iframeKey:B,onIframeLoad:V}=ne({analysisId:t==null?void 0:t.id,scenarioId:r==null?void 0:r.id,scenarioName:r==null?void 0:r.name,projectSlug:x,enabled:!0}),Y=a.useCallback(async()=>{var m,c,T,z;if(!o.trim()&&d.length===0){L("Please describe how you want to change the scenario or select execution flows");return}R(!0),L(null),l("Generating scenario with AI...");try{const u=await fetch("/api/generate-scenario-data",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({description:o,existingScenarios:t.scenarios,scenariosDataStructure:(m=t.metadata)==null?void 0:m.scenariosDataStructure,flowSelections:d.length>0?d:void 0})}),N=await u.json();if(!u.ok||!N.success)throw new Error(N.error||"Failed to generate scenario data");console.log("[CreateScenario] AI generated scenario:",N.data);const g=N.data;if(!g.name||!g.data)throw new Error("AI response missing required fields (name or data)");l("Saving new scenario..."),$(!0);const X={name:g.name,description:g.description||o,metadata:{data:g.data,interactiveExamplePath:(c=r.metadata)==null?void 0:c.interactiveExamplePath}},Q=[...t.scenarios||[],X],O=await fetch("/api/save-scenarios",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({analysis:t,scenarios:Q})}),C=await O.json();if(!O.ok||!C.success)throw new Error(C.error||"Failed to save scenario");console.log("[CreateScenario] Scenario saved:",C);const f=(z=(T=C.analysis)==null?void 0:T.scenarios)==null?void 0:z.find(k=>k.name===g.name);if(!(f!=null&&f.id)){console.warn("[CreateScenario] Could not find saved scenario ID, navigating to entity page"),l("Scenario created! Redirecting..."),setTimeout(()=>void p(`/entity/${i}`),1e3);return}if(y){l("Capturing screenshot...");const k=await fetch("/api/capture-screenshot",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({serverUrl:y,scenarioId:f.id,projectId:t.projectId,viewportWidth:1440})}),A=await k.json();!k.ok||!A.success?(console.error("[CreateScenario] Capture failed:",A),l("Scenario created! (Screenshot capture failed)")):l("Scenario created and captured!")}else l("Scenario created!");setTimeout(()=>{p(`/entity/${i}/scenarios/${f.id}`)},1e3)}catch(u){console.error("[CreateScenario] Error:",u),L(u instanceof Error?u.message:String(u)),l(null)}finally{R(!1),$(!1)}},[o,d,t,r,i,y,p]),j=U||G,K=a.useCallback(()=>{P(!0)},[]),w=a.useCallback(m=>{if(!b)return;const c=m.clientX;c>=250&&c<=600&&E(c)},[b]),S=a.useCallback(()=>{P(!1)},[]);return a.useEffect(()=>(b?(document.addEventListener("mousemove",w),document.addEventListener("mouseup",S)):(document.removeEventListener("mousemove",w),document.removeEventListener("mouseup",S)),()=>{document.removeEventListener("mousemove",w),document.removeEventListener("mouseup",S)}),[b,w,S]),e.jsxs("div",{className:"h-screen bg-white flex flex-col overflow-hidden",children:[e.jsx("header",{className:"bg-white border-b border-gray-200 shrink-0 relative h-[54px]",children:e.jsxs("div",{className:"flex items-end h-full px-6 gap-6",children:[e.jsxs("div",{className:"flex items-center gap-3 min-w-0 flex-1 pb-[14px]",children:[e.jsx("button",{onClick:()=>void p(`/entity/${i}`),className:"no-underline shrink-0 bg-transparent border-none cursor-pointer p-0 flex items-center",title:"Back",children:e.jsx("svg",{width:"17",height:"17",viewBox:"0 0 17 17",fill:"none",children:e.jsx("path",{d:"M13 8.5H4M4 8.5L8.5 4M4 8.5L8.5 13",stroke:"#005c75",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})}),e.jsx("h1",{className:"text-base font-semibold text-black m-0 leading-[20px] shrink-0",children:n==null?void 0:n.name}),e.jsx("span",{className:"text-xs text-[#9e9e9e] font-mono font-normal whitespace-nowrap overflow-hidden text-ellipsis min-w-0",title:n==null?void 0:n.filePath,children:n==null?void 0:n.filePath})]}),e.jsxs("div",{className:"flex items-end gap-8 shrink-0",children:[e.jsx(v,{to:`/entity/${i}/scenarios`,className:"relative pb-[17px] px-2 text-sm transition-colors cursor-pointer no-underline font-medium border-b-2",style:{color:"#005C75",borderColor:"#005C75"},children:e.jsxs("span",{className:"flex items-center gap-2",children:["Scenarios",e.jsx("span",{className:"inline-flex items-center justify-center px-2 py-0.5 text-xs font-semibold rounded-full bg-[#cbf3fa] text-[#005c75]",children:((W=t==null?void 0:t.scenarios)==null?void 0:W.length)||0})]})}),e.jsx(v,{to:`/entity/${i}/related`,className:"relative pb-[17px] px-2 text-sm transition-colors cursor-pointer no-underline font-normal hover:text-gray-700",style:{color:"#9ca3af"},children:"Related Entities"}),e.jsx(v,{to:`/entity/${i}/code`,className:"relative pb-[17px] px-2 text-sm transition-colors cursor-pointer no-underline font-normal hover:text-gray-700",style:{color:"#9ca3af"},children:"Code"}),e.jsx(v,{to:`/entity/${i}/data`,className:"relative pb-[17px] px-2 text-sm transition-colors cursor-pointer no-underline font-normal hover:text-gray-700",style:{color:"#9ca3af"},children:"Data Structure"}),e.jsx(v,{to:`/entity/${i}/history`,className:"relative pb-[17px] px-2 text-sm transition-colors cursor-pointer no-underline font-normal hover:text-gray-700",style:{color:"#9ca3af"},children:"History"})]})]})}),e.jsxs("div",{className:"flex flex-1 gap-0 min-h-0 relative",children:[e.jsxs("aside",{className:"bg-white border-r border-gray-200 overflow-y-auto shrink-0 p-6 flex flex-col",style:{width:`${h}px`},children:[e.jsxs("div",{className:"mb-6",children:[e.jsx("h2",{className:"text-lg font-semibold text-gray-900 mb-2",children:"Default Scenario Preview"}),e.jsx("p",{className:"text-sm text-gray-600 leading-relaxed",children:"The preview on the right shows the Default Scenario. Select execution flows and/or describe how you'd like to change it."})]}),D.length>0&&e.jsxs("details",{className:"mb-4 border border-gray-200 rounded-lg",children:[e.jsxs("summary",{className:"px-3 py-2 text-sm font-medium text-gray-700 cursor-pointer hover:bg-gray-50 rounded-lg",children:["Select Execution Flows"," ",d.length>0&&e.jsxs("span",{className:"text-blue-600",children:["(",d.length," selected)"]})]}),e.jsx("div",{className:"px-3 pb-3 pt-1 border-t border-gray-100",children:e.jsx(ie,{executionFlows:D,selections:d,onChange:H,disabled:j})})]}),e.jsxs("div",{className:"mb-4",children:[e.jsx("label",{htmlFor:"prompt",className:"block text-sm font-medium text-gray-700 mb-2",children:"Describe your scenario"}),e.jsx("textarea",{id:"prompt",value:o,onChange:m=>I(m.target.value),placeholder:"e.g., Show an empty state with no items...",className:"w-full h-32 px-3 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-1 focus:ring-blue-500 focus:border-blue-500 text-sm resize-none",disabled:j})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx("button",{onClick:()=>void Y(),disabled:j||!o.trim()&&d.length===0,className:"w-full px-4 py-2 bg-blue-600 text-white rounded-lg text-sm font-medium cursor-pointer transition-colors hover:bg-blue-700 disabled:bg-gray-400 disabled:cursor-not-allowed",children:j?"Creating...":"Create Scenario"}),F&&e.jsx("div",{className:"text-xs text-blue-600 bg-blue-50 px-2 py-1.5 rounded",children:F}),M&&e.jsx("div",{className:"text-xs text-red-600 bg-red-50 px-2 py-1.5 rounded",children:M})]})]}),e.jsxs("div",{onMouseDown:K,style:{width:"20px",position:"absolute",top:0,left:`${h-10}px`,bottom:0,cursor:"col-resize",touchAction:"none",userSelect:"none",zIndex:100,pointerEvents:"auto"},children:[e.jsx("div",{style:{position:"absolute",left:"10px",top:0,bottom:0,width:"1px",background:b?"#005c75":"rgba(0,0,0,0.1)",transition:"background 0.15s ease"}}),e.jsx("div",{style:{position:"absolute",top:"50%",left:"10px",transform:"translate(-50%, -50%)",width:"8px",height:"40px",background:"#fff",border:"1px solid rgba(0,0,0,0.15)",borderRadius:"4px",cursor:"col-resize"}})]}),e.jsx("main",{className:"flex-1 overflow-auto flex items-center justify-center min-w-0",style:{backgroundImage:`
2
- linear-gradient(45deg, #ebebeb 25%, transparent 25%),
3
- linear-gradient(-45deg, #ebebeb 25%, transparent 25%),
4
- linear-gradient(45deg, transparent 75%, #ebebeb 75%),
5
- linear-gradient(-45deg, transparent 75%, #ebebeb 75%)
6
- `,backgroundSize:"16px 16px",backgroundPosition:"0 0, 0 8px, 8px -8px, -8px 0px",backgroundColor:"#fafafa"},children:e.jsx(ae,{scenarioId:r.id||r.name,scenarioName:r.name,iframeUrl:y,isStarting:J,isLoading:_,showIframe:q,iframeKey:B,onIframeLoad:V,projectSlug:x,defaultWidth:1440,defaultHeight:900})})]})]})}const ge=Z(function(){return e.jsx(se,{children:e.jsx(ce,{})})});export{ge as default,he as meta};
@@ -1,6 +0,0 @@
1
- import{c as e}from"./createLucideIcon-BdhJEx6B.js";/**
2
- * @license lucide-react v0.556.0 - ISC
3
- *
4
- * This source code is licensed under the ISC license.
5
- * See the LICENSE file in the root directory of this source tree.
6
- */const a=[["path",{d:"M6 22a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h8a2.4 2.4 0 0 1 1.704.706l3.588 3.588A2.4 2.4 0 0 1 20 8v12a2 2 0 0 1-2 2z",key:"1oefj6"}],["path",{d:"M14 2v5a1 1 0 0 0 1 1h5",key:"wfsgrz"}],["path",{d:"M10 12.5 8 15l2 2.5",key:"1tg20x"}],["path",{d:"m14 12.5 2 2.5-2 2.5",key:"yinavb"}]],t=e("file-code",a);export{t as F};