@codeyam/codeyam-cli 0.1.0-staging.ad88eeb → 0.1.0-staging.b6c4c78

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 (279) 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 +2 -2
  4. package/analyzer-template/packages/ai/package.json +1 -1
  5. package/analyzer-template/packages/aws/package.json +1 -1
  6. package/analyzer-template/packages/database/package.json +1 -1
  7. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +72 -0
  8. package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
  9. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +0 -65
  10. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +6 -0
  11. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -1
  12. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +72 -0
  13. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -1
  14. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  15. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
  16. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  17. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  18. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +0 -25
  19. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  20. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +45 -0
  21. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  22. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  23. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  24. package/codeyam-cli/src/commands/editor.js +1810 -386
  25. package/codeyam-cli/src/commands/editor.js.map +1 -1
  26. package/codeyam-cli/src/commands/init.js +68 -34
  27. package/codeyam-cli/src/commands/init.js.map +1 -1
  28. package/codeyam-cli/src/data/techStacks.js +2 -7
  29. package/codeyam-cli/src/data/techStacks.js.map +1 -1
  30. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  31. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  32. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  33. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  34. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +18 -8
  35. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -1
  36. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +353 -1
  37. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -1
  38. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js +76 -0
  39. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js.map +1 -0
  40. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +27 -2
  41. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -1
  42. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +6 -3
  43. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -1
  44. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js +223 -0
  45. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js.map +1 -0
  46. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +163 -1
  47. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -1
  48. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js +430 -0
  49. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js.map +1 -0
  50. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +88 -1
  51. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -1
  52. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +47 -1
  53. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -1
  54. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +968 -1
  55. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -1
  56. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +67 -0
  57. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -1
  58. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js +66 -0
  59. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js.map +1 -0
  60. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js +53 -0
  61. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js.map +1 -0
  62. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +102 -10
  63. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -1
  64. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +30 -2
  65. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -1
  66. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js +118 -0
  67. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js.map +1 -0
  68. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  69. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  70. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +426 -218
  71. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -1
  72. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +1 -0
  73. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  74. package/codeyam-cli/src/utils/analysisRunner.js +3 -1
  75. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  76. package/codeyam-cli/src/utils/analyzer.js +9 -0
  77. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  78. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  79. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  80. package/codeyam-cli/src/utils/backgroundServer.js +92 -16
  81. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  82. package/codeyam-cli/src/utils/database.js +37 -2
  83. package/codeyam-cli/src/utils/database.js.map +1 -1
  84. package/codeyam-cli/src/utils/editorApi.js +11 -5
  85. package/codeyam-cli/src/utils/editorApi.js.map +1 -1
  86. package/codeyam-cli/src/utils/editorAudit.js +51 -0
  87. package/codeyam-cli/src/utils/editorAudit.js.map +1 -1
  88. package/codeyam-cli/src/utils/editorBroadcastViewport.js +26 -0
  89. package/codeyam-cli/src/utils/editorBroadcastViewport.js.map +1 -0
  90. package/codeyam-cli/src/utils/editorDevServer.js +5 -1
  91. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -1
  92. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +1 -1
  93. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -1
  94. package/codeyam-cli/src/utils/editorEntityHelpers.js +129 -0
  95. package/codeyam-cli/src/utils/editorEntityHelpers.js.map +1 -0
  96. package/codeyam-cli/src/utils/editorLoaderHelpers.js +60 -1
  97. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -1
  98. package/codeyam-cli/src/utils/editorMigration.js +224 -0
  99. package/codeyam-cli/src/utils/editorMigration.js.map +1 -0
  100. package/codeyam-cli/src/utils/editorPreview.js +31 -0
  101. package/codeyam-cli/src/utils/editorPreview.js.map +1 -1
  102. package/codeyam-cli/src/utils/editorScenarios.js +309 -0
  103. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -1
  104. package/codeyam-cli/src/utils/editorSeedAdapter.js +183 -4
  105. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -1
  106. package/codeyam-cli/src/utils/editorShouldRevalidate.js +21 -0
  107. package/codeyam-cli/src/utils/editorShouldRevalidate.js.map +1 -0
  108. package/codeyam-cli/src/utils/entityChangeStatus.js +16 -3
  109. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -1
  110. package/codeyam-cli/src/utils/entityChangeStatus.server.js +41 -3
  111. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -1
  112. package/codeyam-cli/src/utils/install-skills.js +9 -0
  113. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  114. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -1
  115. package/codeyam-cli/src/utils/progress.js +2 -2
  116. package/codeyam-cli/src/utils/progress.js.map +1 -1
  117. package/codeyam-cli/src/utils/routePatternMatching.js +129 -0
  118. package/codeyam-cli/src/utils/routePatternMatching.js.map +1 -0
  119. package/codeyam-cli/src/utils/scenarioCoverage.js +74 -0
  120. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  121. package/codeyam-cli/src/utils/scenariosManifest.js +207 -75
  122. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -1
  123. package/codeyam-cli/src/utils/serverState.js +30 -0
  124. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  125. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +1 -0
  126. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  127. package/codeyam-cli/src/utils/simulationGateMiddleware.js +8 -1
  128. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -1
  129. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  130. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  131. package/codeyam-cli/src/utils/syncMocksMiddleware.js +2 -2
  132. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  133. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +40 -0
  134. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  135. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +389 -0
  136. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -1
  137. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +146 -0
  138. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  139. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  140. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  141. package/codeyam-cli/src/webserver/app/lib/git.js +3 -2
  142. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -1
  143. package/codeyam-cli/src/webserver/app/types/editor.js +8 -0
  144. package/codeyam-cli/src/webserver/app/types/editor.js.map +1 -0
  145. package/codeyam-cli/src/webserver/backgroundServer.js +18 -4
  146. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  147. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CzTDWkF2.js +1 -0
  148. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-BcgbViKV.js → EntityItem-BFbq6iFk.js} +3 -3
  149. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CQgyEGV-.js +1 -0
  150. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-CQIG2qda.js → EntityTypeIcon-B6OMi58N.js} +1 -1
  151. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-DuYodzo1.js +1 -0
  152. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-CXo9EeCl.js +25 -0
  153. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-DYCNb2It.js +3 -0
  154. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-BU_OAEMP.js → LoadingDots-By5zI316.js} +1 -1
  155. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-ceAyBX-H.js → LogViewer-CZgY3sxX.js} +3 -3
  156. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-BzHcG7SE.js → ReportIssueModal-CnYYwRDw.js} +2 -2
  157. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-CDoF7ZpU.js +1 -0
  158. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-0DY_NKil.js → ScenarioViewer-DrnfvaLL.js} +3 -3
  159. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Df3UCi8k.js +34 -0
  160. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CK7-NaPZ.js +1 -0
  161. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-DRKR9T0U.js +1 -0
  162. package/codeyam-cli/src/webserver/build/client/assets/{_index-DLxKhri3.js → _index-ClR-g3tY.js} +2 -2
  163. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BcY3q6nt.js → activity.(_tab)-DTH6ydEA.js} +3 -3
  164. package/codeyam-cli/src/webserver/build/client/assets/{addon-web-links-Duc5hnl7.js → addon-web-links-74hnHF59.js} +1 -1
  165. package/codeyam-cli/src/webserver/build/client/assets/{agent-transcripts-Bni3iiUj.js → agent-transcripts-B8CYhCO9.js} +3 -3
  166. package/codeyam-cli/src/webserver/build/client/assets/api.editor-rename-scenario-l0sNRNKZ.js +1 -0
  167. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-seed-state-l0sNRNKZ.js +1 -0
  168. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  169. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-prompt-l0sNRNKZ.js +1 -0
  170. package/codeyam-cli/src/webserver/build/client/assets/api.editor-session-l0sNRNKZ.js +1 -0
  171. package/codeyam-cli/src/webserver/build/client/assets/{book-open-BYOypzCa.js → book-open-CLaoh4ac.js} +1 -1
  172. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-C_Pmso5S.js → chevron-down-BZ2DZxbW.js} +1 -1
  173. package/codeyam-cli/src/webserver/build/client/assets/{chunk-JZWAC4HX-C4pqxYJB.js → chunk-JZWAC4HX-BBXArFPl.js} +13 -21
  174. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-BVMi9VA5.js → circle-check-CT4unAk-.js} +1 -1
  175. package/codeyam-cli/src/webserver/build/client/assets/{copy-n2FB0_Sw.js → copy-zK0B6Nu-.js} +1 -1
  176. package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-CC6AbExI.js → createLucideIcon-DJB0YQJL.js} +1 -1
  177. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-CkXFP_i-.js +1 -0
  178. package/codeyam-cli/src/webserver/build/client/assets/editor._tab-DPw7NZHc.js +1 -0
  179. package/codeyam-cli/src/webserver/build/client/assets/editor.entity.(_sha)-y_5LB2iU.js +58 -0
  180. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-DBa7T2FK.js +41 -0
  181. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-BF4oLwaE.js → entity._sha._-BqAN7hyG.js} +2 -2
  182. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-BOi8kpwd.js +6 -0
  183. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-Dg1NhIms.js +6 -0
  184. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-CJX6kkkV.js +6 -0
  185. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-BMvVHNXU.js → entity._sha_.edit._scenarioId-BhVjZhKg.js} +2 -2
  186. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-DTvKq3TY.js → entry.client-_gzKltPN.js} +6 -6
  187. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-Daa96Fr1.js +1 -0
  188. package/codeyam-cli/src/webserver/build/client/assets/files-CV_17tZS.js +1 -0
  189. package/codeyam-cli/src/webserver/build/client/assets/git-D-YXmMbR.js +1 -0
  190. package/codeyam-cli/src/webserver/build/client/assets/globals-BCTpZEY8.css +1 -0
  191. package/codeyam-cli/src/webserver/build/client/assets/{index-yHOVb4rc.js → index-Blo6EK8G.js} +1 -1
  192. package/codeyam-cli/src/webserver/build/client/assets/{index-10oVnAAH.js → index-BsX0F-9C.js} +1 -1
  193. package/codeyam-cli/src/webserver/build/client/assets/{index-BcvgDzbZ.js → index-CCrgCshv.js} +1 -1
  194. package/codeyam-cli/src/webserver/build/client/assets/jsx-runtime-D_zvdyIk.js +9 -0
  195. package/codeyam-cli/src/webserver/build/client/assets/labs-Byazq8Pv.js +1 -0
  196. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-DaAZ_H2w.js → loader-circle-DVQ0oHR7.js} +1 -1
  197. package/codeyam-cli/src/webserver/build/client/assets/manifest-5f1c29f5.js +1 -0
  198. package/codeyam-cli/src/webserver/build/client/assets/memory-b-VmA2Vj.js +101 -0
  199. package/codeyam-cli/src/webserver/build/client/assets/{pause-f5-1lKBt.js → pause-DGcndCAa.js} +1 -1
  200. package/codeyam-cli/src/webserver/build/client/assets/root-BBCQJ_ZM.js +67 -0
  201. package/codeyam-cli/src/webserver/build/client/assets/{search-Di64LWVb.js → search-C0Uw0bcK.js} +1 -1
  202. package/codeyam-cli/src/webserver/build/client/assets/settings-OoNgHIfW.js +1 -0
  203. package/codeyam-cli/src/webserver/build/client/assets/simulations-Bcemfu8a.js +1 -0
  204. package/codeyam-cli/src/webserver/build/client/assets/{terminal-Br7MOqts.js → terminal-BgMmG7R9.js} +1 -1
  205. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-BLdiCuG-.js → triangle-alert-Cs87hJYK.js} +1 -1
  206. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BR3Rs7JY.js +1 -0
  207. package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-C14nCb1q.js → useLastLogLine-BxxP_XF9.js} +1 -1
  208. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-BermyNU5.js +1 -0
  209. package/codeyam-cli/src/webserver/build/client/assets/useToast-a_QN_W9_.js +1 -0
  210. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  211. package/codeyam-cli/src/webserver/build/server/assets/index-BLKsJR3o.js +1 -0
  212. package/codeyam-cli/src/webserver/build/server/assets/init-C2iMAqYu.js +10 -0
  213. package/codeyam-cli/src/webserver/build/server/assets/server-build-DR42Xd5a.js +489 -0
  214. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  215. package/codeyam-cli/src/webserver/build-info.json +5 -5
  216. package/codeyam-cli/src/webserver/editorProxy.js +309 -13
  217. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -1
  218. package/codeyam-cli/src/webserver/idleDetector.js +73 -0
  219. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  220. package/codeyam-cli/src/webserver/mockStateEvents.js +28 -0
  221. package/codeyam-cli/src/webserver/mockStateEvents.js.map +1 -0
  222. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  223. package/codeyam-cli/src/webserver/server.js +55 -4
  224. package/codeyam-cli/src/webserver/server.js.map +1 -1
  225. package/codeyam-cli/src/webserver/terminalServer.js +153 -33
  226. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -1
  227. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  228. package/codeyam-cli/templates/chrome-extension-react/package.json +1 -0
  229. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +6 -0
  230. package/codeyam-cli/templates/codeyam-editor-claude.md +84 -5
  231. package/codeyam-cli/templates/editor-step-hook.py +107 -24
  232. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  233. package/codeyam-cli/templates/expo-react-native/package.json +1 -0
  234. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +14 -0
  235. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  236. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +1 -0
  237. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +42 -7
  238. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  239. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +1 -0
  240. package/codeyam-cli/templates/seed-adapters/supabase.ts +282 -0
  241. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +1 -1
  242. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +76 -10
  243. package/package.json +1 -1
  244. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +72 -0
  245. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -1
  246. package/packages/database/src/lib/loadEntities.js +0 -6
  247. package/packages/database/src/lib/loadEntities.js.map +1 -1
  248. package/packages/database/src/lib/updateCommitMetadata.js +0 -25
  249. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  250. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-BPXZwM4t.js +0 -1
  251. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-g3saevPb.js +0 -1
  252. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-Bu6c6aDe.js +0 -1
  253. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-DYFW3lDD.js +0 -25
  254. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-DLeucoVX.js +0 -3
  255. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-BED4B6sP.js +0 -1
  256. package/codeyam-cli/src/webserver/build/client/assets/Spinner-Bb5uFQ5V.js +0 -34
  257. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-C8OKAR5x.js +0 -1
  258. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +0 -1
  259. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Csi0_PMl.js +0 -1
  260. package/codeyam-cli/src/webserver/build/client/assets/editor-BuT_Huj0.js +0 -10
  261. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-B7ztwLut.js +0 -41
  262. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-D5rYBT5x.js +0 -6
  263. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-CF164ouH.js +0 -6
  264. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-p9hhkjJM.js +0 -6
  265. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-cPo8LiG3.js +0 -1
  266. package/codeyam-cli/src/webserver/build/client/assets/files-BZrlFE1F.js +0 -1
  267. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +0 -1
  268. package/codeyam-cli/src/webserver/build/client/assets/globals-BkWJ_UNc.css +0 -1
  269. package/codeyam-cli/src/webserver/build/client/assets/labs-Zk7ryIM1.js +0 -1
  270. package/codeyam-cli/src/webserver/build/client/assets/manifest-b0f1372e.js +0 -1
  271. package/codeyam-cli/src/webserver/build/client/assets/memory-Bl2rpw8u.js +0 -96
  272. package/codeyam-cli/src/webserver/build/client/assets/root-B_X8HS1x.js +0 -67
  273. package/codeyam-cli/src/webserver/build/client/assets/settings-0OrEMU6J.js +0 -1
  274. package/codeyam-cli/src/webserver/build/client/assets/simulations-DWT-CvLy.js +0 -1
  275. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-CrAK28Bc.js +0 -1
  276. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-O-jkvSPx.js +0 -1
  277. package/codeyam-cli/src/webserver/build/client/assets/useToast-9FIWuYfK.js +0 -1
  278. package/codeyam-cli/src/webserver/build/server/assets/index-CbF6h3dj.js +0 -1
  279. package/codeyam-cli/src/webserver/build/server/assets/server-build-DRFwTJqO.js +0 -367
@@ -17,7 +17,7 @@
17
17
  */
18
18
 
19
19
  import 'dotenv/config';
20
- import { PrismaClient } from '@prisma/client';
20
+ import { PrismaClient, Prisma } from '@prisma/client';
21
21
  import { PrismaBetterSqlite3 } from '@prisma/adapter-better-sqlite3';
22
22
  import * as fs from 'fs';
23
23
 
@@ -84,9 +84,44 @@ async function main() {
84
84
  console.log('Seed complete');
85
85
  }
86
86
 
87
- main()
88
- .then(() => prisma.$disconnect())
89
- .catch((e) => {
90
- console.error('Seed adapter error:', e);
91
- process.exit(1);
92
- });
87
+ /**
88
+ * Export mode: dump current database state to a JSON file.
89
+ * Used by CodeYam to save interactive changes back to scenario seed data.
90
+ *
91
+ * Usage: npx tsx .codeyam/seed-adapter.ts --export <output-path.json>
92
+ */
93
+ async function exportData(outputPath: string) {
94
+ const modelNames = Prisma.dmmf.datamodel.models.map((m) => m.name);
95
+
96
+ const seed: Record<string, unknown[]> = {};
97
+ for (const model of modelNames) {
98
+ const camelCase = model.charAt(0).toLowerCase() + model.slice(1);
99
+ try {
100
+ const rows = await (prisma as any)[camelCase].findMany();
101
+ if (rows.length > 0) {
102
+ seed[camelCase] = rows;
103
+ }
104
+ } catch {
105
+ // Skip tables that can't be queried
106
+ }
107
+ }
108
+
109
+ fs.writeFileSync(outputPath, JSON.stringify(seed, null, 2));
110
+ console.log(`Exported ${Object.keys(seed).length} tables`);
111
+ }
112
+
113
+ if (process.argv[2] === '--export') {
114
+ exportData(process.argv[3])
115
+ .then(() => prisma.$disconnect())
116
+ .catch((e) => {
117
+ console.error('Seed adapter export error:', e);
118
+ process.exit(1);
119
+ });
120
+ } else {
121
+ main()
122
+ .then(() => prisma.$disconnect())
123
+ .catch((e) => {
124
+ console.error('Seed adapter error:', e);
125
+ process.exit(1);
126
+ });
127
+ }
@@ -0,0 +1,52 @@
1
+ # Project Name
2
+
3
+ Brief description of what this app does.
4
+
5
+ ## Setup
6
+
7
+ Run the setup script to install dependencies, initialize the database, and seed it with demo data:
8
+
9
+ ```bash
10
+ npm run setup
11
+ ```
12
+
13
+ ## Development
14
+
15
+ Start the dev server:
16
+
17
+ ```bash
18
+ npm run dev
19
+ ```
20
+
21
+ Open [http://localhost:3000](http://localhost:3000) in your browser.
22
+
23
+ ## Using CodeYam Editor
24
+
25
+ This project was built with [CodeYam](https://codeyam.com). To launch the editor:
26
+
27
+ ```bash
28
+ codeyam editor
29
+ ```
30
+
31
+ The editor provides a live preview alongside a Claude Code terminal for iterating on the app.
32
+
33
+ ## Database
34
+
35
+ This project uses Supabase (PostgreSQL) via Prisma. Common commands:
36
+
37
+ ```bash
38
+ npm run db:push # Apply schema changes and generate Prisma client
39
+ npm run db:seed # Seed the database with demo data
40
+ npm run db:reset # Reset database (runs prisma migrate reset)
41
+ ```
42
+
43
+ ## Scripts
44
+
45
+ | Script | Description |
46
+ | ------------------ | -------------------------------------------- |
47
+ | `npm run setup` | One-line project setup (install + db + seed) |
48
+ | `npm run dev` | Start the development server |
49
+ | `npm run build` | Build for production |
50
+ | `npm run db:push` | Apply Prisma schema changes |
51
+ | `npm run db:seed` | Seed the database |
52
+ | `npm run db:reset` | Reset the database |
@@ -3,6 +3,7 @@
3
3
  "version": "0.1.0",
4
4
  "private": true,
5
5
  "scripts": {
6
+ "setup": "npm install && npm run db:push && npm run db:seed",
6
7
  "dev": "next dev --turbopack",
7
8
  "build": "next build",
8
9
  "start": "next start",
@@ -0,0 +1,282 @@
1
+ /**
2
+ * CodeYam Seed Adapter for Supabase.
3
+ *
4
+ * Seeds the database and optionally signs in a user for authenticated scenarios.
5
+ *
6
+ * Usage: npx tsx .codeyam/seed-adapter.ts <path-to-seed-data.json>
7
+ *
8
+ * Input JSON format:
9
+ * {
10
+ * "tableName": [{ "column": "value", ... }, ...],
11
+ * "_auth": { // optional
12
+ * "email": "alice@example.com",
13
+ * "password": "test123"
14
+ * }
15
+ * }
16
+ *
17
+ * When _auth is present, the adapter:
18
+ * 1. Creates the user if they don't exist (auto-confirms email)
19
+ * 2. Signs in with signInWithPassword to get a valid session
20
+ * 3. Writes session cookies to .codeyam/tmp/seed-session.json
21
+ * so the CodeYam proxy can inject them into the browser
22
+ *
23
+ * Requirements:
24
+ * - A Supabase project URL (https://<ref>.supabase.co) in any env var
25
+ * - A secret key (sb_secret_... or legacy eyJ... service_role JWT) in any env var
26
+ *
27
+ * The adapter scans ALL env vars by value pattern — no specific naming required.
28
+ */
29
+
30
+ import { createClient } from '@supabase/supabase-js';
31
+ import * as fs from 'fs';
32
+ import * as path from 'path';
33
+
34
+ /**
35
+ * Scan all env vars for values matching a pattern.
36
+ * Returns ALL unique matches (not just the first) so callers can disambiguate.
37
+ */
38
+ function findAllEnvByPattern(pattern: RegExp): string[] {
39
+ const matches = new Set<string>();
40
+ for (const value of Object.values(process.env)) {
41
+ if (value && pattern.test(value)) matches.add(value);
42
+ }
43
+ return [...matches];
44
+ }
45
+
46
+ /**
47
+ * For legacy Supabase JWTs, decode the payload to check the `role` claim.
48
+ * Returns the role string ("service_role", "anon", etc.) or undefined.
49
+ */
50
+ function getJwtRole(jwt: string): string | undefined {
51
+ try {
52
+ const payload = jwt.split('.')[1];
53
+ const decoded = JSON.parse(Buffer.from(payload, 'base64url').toString());
54
+ return decoded.role;
55
+ } catch {
56
+ return undefined;
57
+ }
58
+ }
59
+
60
+ // Detect Supabase credentials by value pattern, not env var name.
61
+ // This works regardless of what the user named their env vars.
62
+ const supabaseUrl = findAllEnvByPattern(
63
+ /^https:\/\/[a-z0-9]+\.supabase\.co\b/,
64
+ )[0];
65
+
66
+ // New-format keys are unambiguous by prefix
67
+ const newSecretKey = findAllEnvByPattern(/^sb_secret_/)[0];
68
+ const newAnonKey = findAllEnvByPattern(/^sb_publishable_/)[0];
69
+
70
+ // Legacy JWT keys — disambiguate by decoding the role claim
71
+ const legacyJwts = findAllEnvByPattern(
72
+ /^eyJ[A-Za-z0-9_-]+\.[A-Za-z0-9_-]+\.[A-Za-z0-9_-]+$/,
73
+ );
74
+ const legacyServiceRole = legacyJwts.find(
75
+ (jwt) => getJwtRole(jwt) === 'service_role',
76
+ );
77
+ const legacyAnon = legacyJwts.find((jwt) => getJwtRole(jwt) === 'anon');
78
+
79
+ const secretKey = newSecretKey || legacyServiceRole;
80
+ const anonKey = newAnonKey || legacyAnon;
81
+
82
+ if (!supabaseUrl || !secretKey) {
83
+ console.error(
84
+ 'Could not find Supabase credentials in environment variables.',
85
+ );
86
+ console.error(
87
+ 'Looking for: a URL matching https://<ref>.supabase.co and a key starting with sb_secret_ (or a service_role JWT)',
88
+ );
89
+ console.error(
90
+ 'Add them to .env.local — the seed adapter scans all env vars by value pattern.',
91
+ );
92
+ process.exit(1);
93
+ }
94
+
95
+ // Admin client for user management (uses secret key to bypass RLS)
96
+ const supabase = createClient(supabaseUrl, secretKey, {
97
+ auth: { autoRefreshToken: false, persistSession: false },
98
+ });
99
+
100
+ // Derive the project ref from the URL for cookie naming
101
+ // e.g. "https://abcdefgh.supabase.co" → "abcdefgh"
102
+ function getProjectRef(): string {
103
+ try {
104
+ const hostname = new URL(supabaseUrl!).hostname;
105
+ return hostname.split('.')[0];
106
+ } catch {
107
+ return 'unknown';
108
+ }
109
+ }
110
+
111
+ async function seedTables(seed: Record<string, unknown[]>) {
112
+ const tableNames = Object.keys(seed);
113
+ if (tableNames.length === 0) return;
114
+
115
+ console.log(`Seeding tables: ${tableNames.join(', ')}`);
116
+
117
+ // Wipe tables in reverse order (to respect foreign keys)
118
+ for (const table of [...tableNames].reverse()) {
119
+ const { error } = await supabase.from(table).delete().gte('id', 0);
120
+ if (error) {
121
+ const { error: error2 } = await supabase
122
+ .from(table)
123
+ .delete()
124
+ .not('id', 'is', null);
125
+ if (error2) {
126
+ console.warn(` Could not clear ${table}: ${error2.message}`);
127
+ } else {
128
+ console.log(` Cleared ${table}`);
129
+ }
130
+ } else {
131
+ console.log(` Cleared ${table}`);
132
+ }
133
+ }
134
+
135
+ // Insert seed data
136
+ for (const [table, rows] of Object.entries(seed)) {
137
+ if (!Array.isArray(rows) || rows.length === 0) continue;
138
+ const { error } = await supabase.from(table).insert(rows);
139
+ if (error) {
140
+ console.error(` Failed to seed ${table}: ${error.message}`);
141
+ process.exit(1);
142
+ }
143
+ console.log(` Seeded ${rows.length} rows into ${table}`);
144
+ }
145
+ }
146
+
147
+ /**
148
+ * Handle auth: create user, sign in, write session cookies.
149
+ * Returns the user ID so callers can replace __AUTH_USER_ID__ placeholders in seed data.
150
+ */
151
+ async function handleAuth(auth: {
152
+ email: string;
153
+ password: string;
154
+ }): Promise<string> {
155
+ const { email, password } = auth;
156
+
157
+ // Create user if they don't exist (auto-confirm email so sign-in works)
158
+ const { data: createData, error: createError } =
159
+ await supabase.auth.admin.createUser({
160
+ email,
161
+ password,
162
+ email_confirm: true,
163
+ });
164
+
165
+ if (createError) {
166
+ if (createError.message.includes('already been registered')) {
167
+ // User exists — update their password so sign-in works even if the
168
+ // scenario specifies a different password than a previous run.
169
+ const { data: listData } = await supabase.auth.admin.listUsers();
170
+ const existingUser = listData?.users?.find((u) => u.email === email);
171
+ if (existingUser) {
172
+ await supabase.auth.admin.updateUserById(existingUser.id, {
173
+ password,
174
+ });
175
+ console.log(` Updated password for existing user ${email}`);
176
+ }
177
+ } else {
178
+ console.error(` Failed to create auth user: ${createError.message}`);
179
+ process.exit(1);
180
+ }
181
+ }
182
+
183
+ // Sign in to get a valid session
184
+ // Use a separate client with the publishable/anon key for sign-in (if available)
185
+ const signInClient =
186
+ anonKey && anonKey !== secretKey
187
+ ? createClient(supabaseUrl!, anonKey, {
188
+ auth: { autoRefreshToken: false, persistSession: false },
189
+ })
190
+ : supabase;
191
+
192
+ const { data: signInData, error: signInError } =
193
+ await signInClient.auth.signInWithPassword({ email, password });
194
+
195
+ if (signInError || !signInData.session) {
196
+ console.error(
197
+ ` Failed to sign in as ${email}: ${signInError?.message || 'no session returned'}`,
198
+ );
199
+ process.exit(1);
200
+ }
201
+
202
+ const userId = signInData.user.id;
203
+ console.log(` Signed in as ${email} (user: ${userId})`);
204
+
205
+ // Write session cookies for the proxy to inject
206
+ const projectRef = getProjectRef();
207
+ const sessionOutput = {
208
+ cookies: [
209
+ {
210
+ name: `sb-${projectRef}-auth-token`,
211
+ value: JSON.stringify({
212
+ access_token: signInData.session.access_token,
213
+ refresh_token: signInData.session.refresh_token,
214
+ token_type: 'bearer',
215
+ expires_in: signInData.session.expires_in,
216
+ expires_at: signInData.session.expires_at,
217
+ }),
218
+ path: '/',
219
+ sameSite: 'Lax' as const,
220
+ },
221
+ ],
222
+ };
223
+
224
+ const outputDir = path.join(process.cwd(), '.codeyam', 'tmp');
225
+ fs.mkdirSync(outputDir, { recursive: true });
226
+ const outputPath = path.join(outputDir, 'seed-session.json');
227
+ fs.writeFileSync(outputPath, JSON.stringify(sessionOutput, null, 2));
228
+ console.log(` Session cookies written to ${outputPath}`);
229
+
230
+ return userId;
231
+ }
232
+
233
+ /**
234
+ * Replace __AUTH_USER_ID__ placeholders in seed data with the actual Supabase user ID.
235
+ * This lets scenarios reference the authenticated user in foreign key columns (e.g. user_id)
236
+ * without knowing the UUID ahead of time.
237
+ */
238
+ function replaceAuthPlaceholders(
239
+ seed: Record<string, unknown[]>,
240
+ userId: string,
241
+ ): Record<string, unknown[]> {
242
+ const json = JSON.stringify(seed);
243
+ const replaced = json.replace(/__AUTH_USER_ID__/g, userId);
244
+ return JSON.parse(replaced);
245
+ }
246
+
247
+ async function main() {
248
+ const seedDataPath = process.argv[2];
249
+ if (!seedDataPath) {
250
+ console.error('Usage: npx tsx .codeyam/seed-adapter.ts <seed-data.json>');
251
+ process.exit(1);
252
+ }
253
+
254
+ const raw = fs.readFileSync(seedDataPath, 'utf-8');
255
+ const data = JSON.parse(raw);
256
+
257
+ // Separate auth config from table data
258
+ const auth = data._auth;
259
+ let seed: Record<string, unknown[]> = {};
260
+ for (const [key, value] of Object.entries(data)) {
261
+ if (key === '_auth') continue;
262
+ seed[key] = value as unknown[];
263
+ }
264
+
265
+ // Auth first: we need the user ID to replace __AUTH_USER_ID__ placeholders
266
+ // in seed data (e.g. for user_id foreign key columns with Supabase RLS)
267
+ if (auth) {
268
+ const userId = await handleAuth(
269
+ auth as { email: string; password: string },
270
+ );
271
+ seed = replaceAuthPlaceholders(seed, userId);
272
+ }
273
+
274
+ await seedTables(seed);
275
+
276
+ console.log('Seed complete');
277
+ }
278
+
279
+ main().catch((e) => {
280
+ console.error('Seed adapter error:', e);
281
+ process.exit(1);
282
+ });
@@ -53,7 +53,7 @@ Then present a **concise** overview to the user:
53
53
 
54
54
  1. **Component Summary** — 2-3 sentences on what the component does and the current scenario being previewed.
55
55
 
56
- 2. **Suggested Tests** — Compare the component's code paths (conditionals, edge cases, visual states) against the existing scenarios from the database. Recommend 2-4 specific ways to test the component that are **not yet covered** by saved scenarios. Focus on interesting visual states — e.g. "What does this look like with a very long title?", "What happens when the list is empty?", "How does the error state render?". Be specific to this component, not generic.
56
+ 2. **Suggested Tests** — Compare the component's code paths (conditionals, edge cases, visual states) against the existing scenarios from the database. Recommend 2-4 specific ways to test the component that are **not yet covered** by saved scenarios. Focus on interesting visual states — e.g. "What does this look like with a very long title?", "What happens when the list is empty?", "How does the error state render?". Also suggest ways to enrich the _existing_ scenario's data to better exercise the component (more realistic content, populated optional fields, diverse values). Be specific to this component, not generic.
57
57
 
58
58
  Keep it brief — no tables, no exhaustive attribute lists. The user can see the preview and wants actionable suggestions, not a data dump.
59
59
 
@@ -16,6 +16,68 @@ You MUST follow a step-by-step workflow driven by `codeyam editor` commands. Eac
16
16
 
17
17
  **The rule:** After completing what a command tells you to do, run the NEXT command it specifies. The commands are your instructions — follow them one at a time.
18
18
 
19
+ ## Migration Mode
20
+
21
+ When `codeyam editor steps` shows **"Project Migration"** instead of "Feature Cycle", the project is being migrated from an existing codebase. Follow the `codeyam editor migrate` commands instead of the normal 13-step cycle.
22
+
23
+ Migration uses a different command set:
24
+
25
+ ```
26
+ codeyam editor migrate → Survey the project (explore pages, confirm order)
27
+ codeyam editor migrate 1-8 → Run migration step N for the current page
28
+ codeyam editor migrate next → Advance to the next page
29
+ codeyam editor migrate status → Show migration progress
30
+ ```
31
+
32
+ **The same rule applies:** run the command shown in the output, follow its checklist, then run the next command it specifies. Migration steps are 1-8 per page: Capture → Preview → Discuss → Decompose → Extract → Recapture → Journal → Present. Steps 4-6 (Decompose/Extract/Recapture) are optional — the user decides at step 3 whether to decompose or skip to step 7. After all pages are migrated, the project transitions to the normal feature cycle.
33
+
34
+ **IMPORTANT:** When `codeyam editor steps` tells you to run a `codeyam editor migrate` command, run THAT command — do NOT run `codeyam editor 1` or any other normal step command.
35
+
36
+ ### Migration Survey (codeyam editor migrate)
37
+
38
+ When you run `codeyam editor migrate` with no arguments and no existing migration state, follow this survey checklist:
39
+
40
+ 1. Read `package.json` — understand the framework, dependencies, and scripts
41
+ 2. Explore the project structure — find all page/route files
42
+ - Next.js App Router: `app/**/page.tsx` | Pages Router: `pages/**/*.tsx`
43
+ - Check for other patterns: `src/` directory, custom routing, etc.
44
+ 3. Read each page/route to assess complexity and data flow
45
+ 4. Identify how the dev server starts (check `scripts` in package.json)
46
+ 5. Note any environment variables, databases, or external services needed
47
+ 6. Present a numbered list of all pages with:
48
+ - Page name and route
49
+ - File path
50
+ - Complexity assessment (simple / moderate / complex)
51
+ 7. Suggest a migration order — **start with the most complex pages** (dashboards, analytics, etc.) as they best demonstrate CodeYam's value and have rich decomposition opportunities
52
+ 8. Wait for user confirmation of the order
53
+
54
+ **After user confirms**, write `.codeyam/migration-state.json`:
55
+
56
+ ```json
57
+ {
58
+ "status": "surveyed",
59
+ "startedAt": "<ISO>",
60
+ "completedAt": null,
61
+ "pages": [
62
+ {
63
+ "name": "Home",
64
+ "route": "/",
65
+ "filePath": "app/page.tsx",
66
+ "status": "pending",
67
+ "startedAt": null,
68
+ "completedAt": null,
69
+ "extractedComponents": [],
70
+ "extractedFunctions": [],
71
+ "scenarioCount": 0
72
+ }
73
+ ],
74
+ "currentPageIndex": 0,
75
+ "sharedComponents": []
76
+ }
77
+ ```
78
+
79
+ Then run: `codeyam editor migrate 1`
80
+
19
81
  ## The Cycle
20
82
 
21
83
  Every feature follows 13 gated steps:
@@ -44,7 +106,7 @@ codeyam editor 13 → Present summary, get final approval
44
106
  When the user asks for changes — whether through the menu, a direct request, or even a question that implies a change (e.g., "Can the cards have images?") — you MUST run `codeyam editor change` **before** making any modifications. This includes:
45
107
 
46
108
  - Code changes (components, routes, lib functions, styles)
47
- - Scenario data updates (seed data, mock data)
109
+ - Scenario data updates (seed data, localStorage data, mock data)
48
110
  - Style adjustments (CSS, Tailwind classes, layout tweaks)
49
111
  - Even small fixes (typos, color tweaks, spacing)
50
112
 
@@ -83,13 +145,13 @@ The user is watching the live preview panel while you work. A static preview mak
83
145
  **How to refresh:**
84
146
 
85
147
  ```
86
- codeyam editor preview
148
+ codeyam editor preview '{"dimension":"<name from screenSizes>"}'
87
149
  ```
88
150
 
89
151
  Navigate to a specific path or switch scenario:
90
152
 
91
153
  ```
92
- codeyam editor preview '{"path":"/drinks/1"}'
154
+ codeyam editor preview '{"path":"/drinks/1","dimension":"<name from screenSizes>"}'
93
155
  codeyam editor preview '{"scenarioId":"abc-123"}'
94
156
  ```
95
157
 
@@ -105,12 +167,16 @@ When a collaborator clones the repo and runs `codeyam editor`, scenarios are aut
105
167
 
106
168
  ```bash
107
169
  # Register component scenario (auto-captures screenshot)
108
- codeyam editor register '{"name":"DrinkCard - Default","componentName":"DrinkCard","componentPath":"app/components/DrinkCard.tsx","url":"/isolated-components/DrinkCard?s=Default","mockData":{"routes":{"/api/...":{"body":[...]}}}}'
170
+ # ALWAYS include "dimensions" use the project's default screen size name from setup
171
+ codeyam editor register '{"name":"DrinkCard - Default","componentName":"DrinkCard","componentPath":"app/components/DrinkCard.tsx","url":"/isolated-components/DrinkCard?s=Default","dimensions":["<name from screenSizes>"],"mockData":{"routes":{"/api/...":{"body":[...]}}}}'
172
+
173
+ # Register app scenario with seed data (ALWAYS include "url" and "dimensions")
174
+ codeyam editor register '{"name":"Full Catalog","type":"application","url":"/","dimensions":["<name from screenSizes>"],"seed":{"drinks":[...]}}'
109
175
 
110
- # Register app scenario with seed data (ALWAYS include "url" the page to screenshot)
111
- codeyam editor register '{"name":"Full Catalog","type":"application","url":"/","seed":{"drinks":[...]}}'
176
+ # Register app scenario with localStorage (for apps using client-side storage instead of a database)
177
+ codeyam editor register '{"name":"Full Library","type":"application","url":"/","dimensions":["<name from screenSizes>"],"localStorage":{"articles":[...],"collections":[...]}}'
112
178
 
113
- # For large seed data, write JSON to a temp file and use @ prefix:
179
+ # For large seed/localStorage data, write JSON to a temp file and use @ prefix:
114
180
  codeyam editor register @/tmp/scenario-data.json
115
181
 
116
182
  # Journal entry (one per feature, references scenario names)
@@ -119,9 +185,9 @@ codeyam editor journal '{"title":"...","type":"feature","description":"..."}'
119
185
  # Update journal with commit info
120
186
  codeyam editor journal-update '{"time":"...","commitSha":"...","commitMessage":"..."}'
121
187
 
122
- # Refresh preview / navigate / switch scenario
123
- codeyam editor preview
124
- codeyam editor preview '{"path":"/drinks/1"}'
188
+ # Refresh preview / navigate / switch scenario (ALWAYS include "dimension")
189
+ codeyam editor preview '{"dimension":"<name from screenSizes>"}'
190
+ codeyam editor preview '{"path":"/drinks/1","dimension":"<name from screenSizes>"}'
125
191
  codeyam editor preview '{"scenarioId":"abc-123"}'
126
192
 
127
193
  # Show/hide results panel
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@codeyam/codeyam-cli",
3
- "version": "0.1.0-staging.ad88eeb",
3
+ "version": "0.1.0-staging.b6c4c78",
4
4
  "description": "Local development CLI for CodeYam analysis",
5
5
  "type": "module",
6
6
  "bin": {
@@ -11,6 +11,12 @@ const editorScenariosSchema = {
11
11
  screenshot_path: schemaField(),
12
12
  viewport_width: schemaField(),
13
13
  viewport_height: schemaField(),
14
+ dimension: schemaField(),
15
+ dimensions: schemaField(),
16
+ screenshot_paths: schemaField(),
17
+ page_file_path: schemaField(),
18
+ entity_sha: schemaField(),
19
+ display_name: schemaField(),
14
20
  created_at: schemaField(),
15
21
  updated_at: schemaField(),
16
22
  };
@@ -61,5 +67,71 @@ export async function createEditorScenariosTable(db) {
61
67
  // Column already exists — expected for fresh databases
62
68
  }
63
69
  }
70
+ // Named dimension column (e.g. "Mobile", "Desktop")
71
+ try {
72
+ await db.schema
73
+ .alterTable('editor_scenarios')
74
+ .addColumn('dimension', 'varchar')
75
+ .execute();
76
+ }
77
+ catch {
78
+ // Column already exists — expected for fresh databases
79
+ }
80
+ // Multi-dimension support: JSON array of dimension names and map of screenshot paths
81
+ for (const col of ['dimensions', 'screenshot_paths']) {
82
+ try {
83
+ await db.schema
84
+ .alterTable('editor_scenarios')
85
+ .addColumn(col, 'text')
86
+ .execute();
87
+ }
88
+ catch {
89
+ // Column already exists — expected for fresh databases
90
+ }
91
+ }
92
+ // Route tracking: page file path for application scenarios
93
+ // Entity association: SHA links scenario to entity, display_name is the human label
94
+ for (const col of ['page_file_path', 'entity_sha', 'display_name']) {
95
+ try {
96
+ await db.schema
97
+ .alterTable('editor_scenarios')
98
+ .addColumn(col, 'varchar')
99
+ .execute();
100
+ }
101
+ catch {
102
+ // Column already exists — expected for fresh databases
103
+ }
104
+ }
105
+ // Backfill: wrap existing single dimension into dimensions array,
106
+ // and existing screenshot_path into screenshot_paths object
107
+ try {
108
+ const rows = await db
109
+ .selectFrom('editor_scenarios')
110
+ .select(['id', 'dimension', 'screenshot_path'])
111
+ .execute();
112
+ for (const row of rows) {
113
+ const r = row;
114
+ if (r.dimension && !r.dimensions) {
115
+ await db
116
+ .updateTable('editor_scenarios')
117
+ .set({ dimensions: JSON.stringify([r.dimension]) })
118
+ .where('id', '=', r.id)
119
+ .execute();
120
+ }
121
+ if (r.screenshot_path && !r.screenshot_paths) {
122
+ const dimName = r.dimension || 'Default';
123
+ await db
124
+ .updateTable('editor_scenarios')
125
+ .set({
126
+ screenshot_paths: JSON.stringify({ [dimName]: r.screenshot_path }),
127
+ })
128
+ .where('id', '=', r.id)
129
+ .execute();
130
+ }
131
+ }
132
+ }
133
+ catch {
134
+ // Backfill is best-effort — columns may not exist yet on first run
135
+ }
64
136
  }
65
137
  //# sourceMappingURL=editorScenariosTable.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"editorScenariosTable.js","sourceRoot":"","sources":["../../../../../../../../packages/database/src/lib/kysely/tables/editorScenariosTable.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE3D,MAAM,qBAAqB,GAAG;IAC5B,EAAE,EAAE,WAAW,EAAqB;IACpC,UAAU,EAAE,WAAW,EAAU;IACjC,IAAI,EAAE,WAAW,EAAU;IAC3B,WAAW,EAAE,WAAW,EAAiB;IACzC,cAAc,EAAE,WAAW,EAAiB;IAC5C,cAAc,EAAE,WAAW,EAAiB;IAC5C,GAAG,EAAE,WAAW,EAAiB;IACjC,IAAI,EAAE,WAAW,EAAiB;IAClC,eAAe,EAAE,WAAW,EAAiB;IAC7C,cAAc,EAAE,WAAW,EAAiB;IAC5C,eAAe,EAAE,WAAW,EAAiB;IAC7C,UAAU,EAAE,WAAW,EAAqB;IAC5C,UAAU,EAAE,WAAW,EAAqB;CACpC,CAAC;AAMX,MAAM,CAAC,MAAM,2BAA2B,GAAG,MAAM,CAAC,IAAI,CACpD,qBAAqB,CACY,CAAC;AAEpC,MAAM,CAAC,KAAK,UAAU,0BAA0B,CAC9C,EAAe;IAEf,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,kBAAkB,CAAC;SAC/B,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC,GAA4B,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;SAC3E,SAAS,CAAC,YAAY,EAAE,MAAM,EAAE,CAAC,GAA4B,EAAE,EAAE,CAChE,GAAG,CAAC,OAAO,EAAE,CACd;SACA,SAAS,CAAC,MAAM,EAAE,SAAS,EAAE,CAAC,GAA4B,EAAE,EAAE,CAC7D,GAAG,CAAC,OAAO,EAAE,CACd;SACA,SAAS,CAAC,aAAa,EAAE,MAAM,CAAC;SAChC,SAAS,CAAC,gBAAgB,EAAE,SAAS,CAAC;SACtC,SAAS,CAAC,gBAAgB,EAAE,SAAS,CAAC;SACtC,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC;SAC3B,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC;SAC5B,SAAS,CAAC,iBAAiB,EAAE,SAAS,CAAC;SACvC,SAAS,CAAC,YAAY,EAAE,UAAU,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;SACrD,SAAS,CAAC,YAAY,EAAE,UAAU,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;SACrD,WAAW,EAAE;SACb,OAAO,EAAE,CAAC;IAEb,8EAA8E;IAC9E,KAAK,MAAM,GAAG,IAAI;QAChB,gBAAgB;QAChB,gBAAgB;QAChB,KAAK;QACL,MAAM;QACN,iBAAiB;KACT,EAAE,CAAC;QACX,IAAI,CAAC;YACH,MAAM,EAAE,CAAC,MAAM;iBACZ,UAAU,CAAC,kBAAkB,CAAC;iBAC9B,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC;iBACzB,OAAO,EAAE,CAAC;QACf,CAAC;QAAC,MAAM,CAAC;YACP,uDAAuD;QACzD,CAAC;IACH,CAAC;IAED,0CAA0C;IAC1C,KAAK,MAAM,GAAG,IAAI,CAAC,gBAAgB,EAAE,iBAAiB,CAAU,EAAE,CAAC;QACjE,IAAI,CAAC;YACH,MAAM,EAAE,CAAC,MAAM;iBACZ,UAAU,CAAC,kBAAkB,CAAC;iBAC9B,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC;iBACzB,OAAO,EAAE,CAAC;QACf,CAAC;QAAC,MAAM,CAAC;YACP,uDAAuD;QACzD,CAAC;IACH,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"editorScenariosTable.js","sourceRoot":"","sources":["../../../../../../../../packages/database/src/lib/kysely/tables/editorScenariosTable.ts"],"names":[],"mappings":"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"}
@@ -59,12 +59,6 @@ export default async function loadEntities({ projectId, branchId, fileIds, fileP
59
59
  .$if(!!fileIds, (qb) => qb.where('entities.file_id', 'in', fileIds));
60
60
  const entities = await query.execute();
61
61
  if (!entities || entities.length === 0) {
62
- console.log('Load Entities: No entities found', {
63
- projectId,
64
- fileIds,
65
- filePaths,
66
- shas,
67
- });
68
62
  return null;
69
63
  }
70
64
  return entities.map(dbToEntity);