@codeyam/codeyam-cli 0.1.8 → 0.1.9

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 (335) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +4 -4
  4. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +0 -33
  5. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +13 -7
  6. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  7. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  8. package/analyzer-template/packages/aws/package.json +1 -1
  9. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +31 -0
  10. package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
  11. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +0 -65
  12. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +5 -0
  13. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -1
  14. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +31 -0
  15. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -1
  16. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  17. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
  18. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  19. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  20. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +0 -25
  21. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  22. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  23. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  24. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  25. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  26. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  27. package/analyzer-template/packages/ui-components/package.json +1 -1
  28. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  29. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  30. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  31. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  32. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  33. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  34. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  35. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  36. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  37. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  38. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +45 -0
  39. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  40. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  41. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  42. package/codeyam-cli/src/commands/default.js +3 -46
  43. package/codeyam-cli/src/commands/default.js.map +1 -1
  44. package/codeyam-cli/src/commands/editor.js +1619 -243
  45. package/codeyam-cli/src/commands/editor.js.map +1 -1
  46. package/codeyam-cli/src/commands/init.js +67 -34
  47. package/codeyam-cli/src/commands/init.js.map +1 -1
  48. package/codeyam-cli/src/data/techStacks.js +77 -0
  49. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  50. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +144 -0
  51. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  52. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  53. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  54. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  55. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  56. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +127 -0
  57. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  58. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +610 -1
  59. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -1
  60. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  61. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  62. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +181 -3
  63. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -1
  64. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +121 -0
  65. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  66. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  67. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  68. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +249 -2
  69. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -1
  70. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +520 -0
  71. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  72. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +118 -1
  73. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -1
  74. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +195 -3
  75. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -1
  76. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  77. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  78. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  79. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  80. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  81. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  82. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +781 -2
  83. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -1
  84. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +213 -0
  85. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  86. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1742 -0
  87. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  88. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  89. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  90. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +101 -0
  91. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  92. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +227 -0
  93. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  94. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +300 -0
  95. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  96. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +25 -5
  97. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  98. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  99. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  100. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  101. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  102. package/codeyam-cli/src/utils/analyzer.js +9 -0
  103. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  104. package/codeyam-cli/src/utils/analyzerFinalization.js +96 -0
  105. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  106. package/codeyam-cli/src/utils/backgroundServer.js +94 -18
  107. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  108. package/codeyam-cli/src/utils/database.js +37 -2
  109. package/codeyam-cli/src/utils/database.js.map +1 -1
  110. package/codeyam-cli/src/utils/devServerState.js +71 -0
  111. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  112. package/codeyam-cli/src/utils/editorApi.js +73 -0
  113. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  114. package/codeyam-cli/src/utils/editorAudit.js +101 -7
  115. package/codeyam-cli/src/utils/editorAudit.js.map +1 -1
  116. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  117. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  118. package/codeyam-cli/src/utils/editorDevServer.js +100 -1
  119. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -1
  120. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +44 -0
  121. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  122. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  123. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  124. package/codeyam-cli/src/utils/editorJournal.js +92 -4
  125. package/codeyam-cli/src/utils/editorJournal.js.map +1 -1
  126. package/codeyam-cli/src/utils/editorLoaderHelpers.js +113 -0
  127. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  128. package/codeyam-cli/src/utils/editorMockState.js +1 -1
  129. package/codeyam-cli/src/utils/editorPreloadHelpers.js +72 -1
  130. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -1
  131. package/codeyam-cli/src/utils/editorPreview.js +67 -1
  132. package/codeyam-cli/src/utils/editorPreview.js.map +1 -1
  133. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  134. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  135. package/codeyam-cli/src/utils/editorScenarios.js +276 -0
  136. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -1
  137. package/codeyam-cli/src/utils/editorSeedAdapter.js +173 -0
  138. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  139. package/codeyam-cli/src/utils/entityChangeStatus.js +349 -0
  140. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  141. package/codeyam-cli/src/utils/entityChangeStatus.server.js +158 -0
  142. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  143. package/codeyam-cli/src/utils/install-skills.js +1 -1
  144. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  145. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  146. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  147. package/codeyam-cli/src/utils/scenarioCoverage.js +75 -0
  148. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  149. package/codeyam-cli/src/utils/scenariosManifest.js +159 -0
  150. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  151. package/codeyam-cli/src/utils/serverState.js +30 -0
  152. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  153. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +46 -16
  154. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  155. package/codeyam-cli/src/utils/simulationGateMiddleware.js +8 -1
  156. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -1
  157. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  158. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  159. package/codeyam-cli/src/utils/syncMocksMiddleware.js +2 -2
  160. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  161. package/codeyam-cli/src/utils/webappDetection.js +21 -0
  162. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  163. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +40 -0
  164. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  165. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +567 -0
  166. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  167. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +65 -0
  168. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  169. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  170. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  171. package/codeyam-cli/src/webserver/build/client/assets/{CopyButton-DmJveP3T.js → CopyButton-BPXZwM4t.js} +1 -1
  172. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-C76mRRiF.js → EntityItem-BcgbViKV.js} +3 -3
  173. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-CobE682z.js → EntityTypeIcon-CQIG2qda.js} +9 -9
  174. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-djPLI-WV.js → ReportIssueModal-BzHcG7SE.js} +3 -3
  175. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-B76aig_2.js → ScenarioViewer-Bd-hxofb.js} +3 -3
  176. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-oAf2Kqsf.js +1 -0
  177. package/codeyam-cli/src/webserver/build/client/assets/{_index-C96V0n15.js → _index-DLxKhri3.js} +3 -3
  178. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-BpKzcsJz.js → activity.(_tab)-BcY3q6nt.js} +6 -6
  179. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  180. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  181. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  182. package/codeyam-cli/src/webserver/build/client/assets/{agent-transcripts-D9hemwl6.js → agent-transcripts-Bni3iiUj.js} +5 -5
  183. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  184. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  185. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  186. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  187. package/codeyam-cli/src/webserver/build/client/assets/{book-open-D_nMCFmP.js → book-open-BYOypzCa.js} +2 -2
  188. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-BH2h1Ea2.js → chevron-down-C_Pmso5S.js} +2 -2
  189. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-DyIKORY6.js → circle-check-BVMi9VA5.js} +2 -2
  190. package/codeyam-cli/src/webserver/build/client/assets/{copy-NDbZjXao.js → copy-n2FB0_Sw.js} +3 -3
  191. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CC6AbExI.js +41 -0
  192. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BsDh6TSF.js +1 -0
  193. package/codeyam-cli/src/webserver/build/client/assets/editor-PBc_6L9R.js +10 -0
  194. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-4FzHlcNn.js +41 -0
  195. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-CrjR3zZW.js → entity._sha._-BsDXNp45.js} +3 -3
  196. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-BgAqUtTZ.js +6 -0
  197. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-Bmshgrij.js +6 -0
  198. package/codeyam-cli/src/webserver/build/client/assets/{files-DO4CZ16O.js → files-BZrlFE1F.js} +1 -1
  199. package/codeyam-cli/src/webserver/build/client/assets/git-DdZcvjGh.js +1 -0
  200. package/codeyam-cli/src/webserver/build/client/assets/globals-B8vTTNy2.css +1 -0
  201. package/codeyam-cli/src/webserver/build/client/assets/index-yHOVb4rc.js +15 -0
  202. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-BAXYRVEO.js → loader-circle-DaAZ_H2w.js} +2 -2
  203. package/codeyam-cli/src/webserver/build/client/assets/manifest-65850841.js +1 -0
  204. package/codeyam-cli/src/webserver/build/client/assets/memory-9gnxSZlb.js +101 -0
  205. package/codeyam-cli/src/webserver/build/client/assets/{pause-DTAcYxBt.js → pause-f5-1lKBt.js} +3 -3
  206. package/codeyam-cli/src/webserver/build/client/assets/root-BwX8YgFb.js +67 -0
  207. package/codeyam-cli/src/webserver/build/client/assets/{search-fKo7v0Zo.js → search-Di64LWVb.js} +2 -2
  208. package/codeyam-cli/src/webserver/build/client/assets/{settings-DfuTtcJP.js → settings-0OrEMU6J.js} +1 -1
  209. package/codeyam-cli/src/webserver/build/client/assets/{simulations-B3aOzpCZ.js → simulations-DWT-CvLy.js} +1 -1
  210. package/codeyam-cli/src/webserver/build/client/assets/{terminal-BG4heKCG.js → terminal-Br7MOqts.js} +3 -3
  211. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-DtSmdtM4.js → triangle-alert-BLdiCuG-.js} +2 -2
  212. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BE43Hjti.js +1 -0
  213. package/codeyam-cli/src/webserver/build/server/assets/index-DEEQf4pi.js +1 -0
  214. package/codeyam-cli/src/webserver/build/server/assets/init-CkWmyFY2.js +10 -0
  215. package/codeyam-cli/src/webserver/build/server/assets/server-build-BHi-9O8W.js +439 -0
  216. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  217. package/codeyam-cli/src/webserver/build-info.json +5 -5
  218. package/codeyam-cli/src/webserver/editorProxy.js +487 -50
  219. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -1
  220. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +242 -3
  221. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +94 -4
  222. package/codeyam-cli/src/webserver/server.js +46 -14
  223. package/codeyam-cli/src/webserver/server.js.map +1 -1
  224. package/codeyam-cli/src/webserver/terminalServer.js +39 -11
  225. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -1
  226. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  227. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  228. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  229. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  230. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  231. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  232. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  233. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  234. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  235. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  236. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  237. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  238. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  239. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  240. package/codeyam-cli/templates/codeyam-editor-claude.md +84 -5
  241. package/codeyam-cli/templates/editor-step-hook.py +97 -8
  242. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  243. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  244. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  245. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  246. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  247. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  248. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  249. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  250. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  251. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  252. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  253. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  254. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  255. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  256. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  257. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  258. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  259. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  260. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  261. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  262. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  263. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  264. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +9 -4
  265. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  266. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +21 -0
  267. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +5 -1
  268. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +4 -1
  269. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +92 -0
  270. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  271. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  272. package/codeyam-cli/templates/{nextjs-prisma-sqlite/PRISMA_SETUP.md → nextjs-prisma-supabase/SUPABASE_SETUP.md} +37 -17
  273. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  274. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  275. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  276. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  277. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  278. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  279. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  280. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  281. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  282. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  283. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  284. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  285. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  286. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  287. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  288. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  289. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +2 -2
  290. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +96 -17
  291. package/codeyam-cli/templates/skills/codeyam-memory/SKILL.md +10 -10
  292. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  293. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  294. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  295. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  296. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  297. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  298. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  299. package/package.json +14 -9
  300. package/packages/ai/src/lib/generateExecutionFlows.js +0 -11
  301. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  302. package/packages/analyze/src/lib/ProjectAnalyzer.js +10 -4
  303. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  304. package/packages/analyze/src/lib/asts/index.js +4 -2
  305. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  306. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  307. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  308. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +31 -0
  309. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -1
  310. package/packages/database/src/lib/loadEntities.js +0 -6
  311. package/packages/database/src/lib/loadEntities.js.map +1 -1
  312. package/packages/database/src/lib/updateCommitMetadata.js +0 -25
  313. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  314. package/packages/types/src/enums/ProjectFramework.js +2 -0
  315. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  316. package/codeyam-cli/src/webserver/build/client/assets/Terminal-Dnj5CY9R.js +0 -41
  317. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-CUXOrorO.js +0 -1
  318. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-CMT1jU2q.js +0 -21
  319. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BiM6z3Do.js +0 -1
  320. package/codeyam-cli/src/webserver/build/client/assets/editor-D1DAKXtT.js +0 -8
  321. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-DkzqFzFj.js +0 -6
  322. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-C28BiQzt.js +0 -6
  323. package/codeyam-cli/src/webserver/build/client/assets/git-CFCTYk9I.js +0 -15
  324. package/codeyam-cli/src/webserver/build/client/assets/globals-B17TBSS6.css +0 -1
  325. package/codeyam-cli/src/webserver/build/client/assets/manifest-a632de18.js +0 -1
  326. package/codeyam-cli/src/webserver/build/client/assets/memory-Dg0mvYrI.js +0 -96
  327. package/codeyam-cli/src/webserver/build/client/assets/root-DUKqhFlb.js +0 -67
  328. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-ByhSyh0W.js +0 -1
  329. package/codeyam-cli/src/webserver/build/server/assets/index-HfLydfDq.js +0 -1
  330. package/codeyam-cli/src/webserver/build/server/assets/server-build-CUu_F-oo.js +0 -366
  331. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.sh +0 -108
  332. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.sh +0 -69
  333. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.sh +0 -12
  334. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter.jq +0 -45
  335. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.sh +0 -139
@@ -0,0 +1,20 @@
1
+ // Prisma 7 requires a driver adapter for database access.
2
+ // This file uses the pg adapter for Supabase PostgreSQL.
3
+ //
4
+ // Usage in API routes and server components:
5
+ // import { prisma } from "@/app/lib/prisma";
6
+ // const items = await prisma.todo.findMany();
7
+
8
+ import { PrismaClient } from '@prisma/client';
9
+ import { PrismaPg } from '@prisma/adapter-pg';
10
+
11
+ const globalForPrisma = globalThis as unknown as { prisma: PrismaClient };
12
+
13
+ const connectionString = process.env.DATABASE_URL!;
14
+ const adapter = new PrismaPg({ connectionString });
15
+
16
+ export const prisma = globalForPrisma.prisma ?? new PrismaClient({ adapter });
17
+
18
+ if (process.env.NODE_ENV !== 'production') globalForPrisma.prisma = prisma;
19
+
20
+ export default prisma;
@@ -0,0 +1,12 @@
1
+ // Supabase client for auth, realtime, and storage.
2
+ // For database queries, use Prisma instead (see prisma.ts).
3
+ //
4
+ // Usage:
5
+ // import { supabase } from "@/app/lib/supabase";
6
+
7
+ import { createClient } from '@supabase/supabase-js';
8
+
9
+ const supabaseUrl = process.env.NEXT_PUBLIC_SUPABASE_URL!;
10
+ const supabaseAnonKey = process.env.NEXT_PUBLIC_SUPABASE_ANON_KEY!;
11
+
12
+ export const supabase = createClient(supabaseUrl, supabaseAnonKey);
@@ -0,0 +1,10 @@
1
+ export default function Home() {
2
+ return (
3
+ <main className="min-h-screen flex items-center justify-center">
4
+ <div className="text-center">
5
+ <h1 className="text-4xl font-bold mb-4">Welcome</h1>
6
+ <p className="text-gray-600">Your app is ready. Start building!</p>
7
+ </div>
8
+ </main>
9
+ );
10
+ }
@@ -0,0 +1,9 @@
1
+ # Supabase project credentials
2
+ # Get these from: https://supabase.com/dashboard → Project Settings → API
3
+ NEXT_PUBLIC_SUPABASE_URL=https://YOUR_PROJECT_ID.supabase.co
4
+ NEXT_PUBLIC_SUPABASE_ANON_KEY=your-anon-key-here
5
+
6
+ # Database connection string (Supabase PostgreSQL)
7
+ # Get this from: Supabase Dashboard → Project Settings → Database → Connection string (URI)
8
+ # Use the "Transaction" connection string for serverless environments (Vercel, etc.)
9
+ DATABASE_URL=postgresql://postgres.YOUR_PROJECT_ID:YOUR_PASSWORD@aws-0-us-east-1.pooler.supabase.com:6543/postgres
@@ -0,0 +1,11 @@
1
+ import { defineConfig, globalIgnores } from "eslint/config";
2
+ import nextVitals from "eslint-config-next/core-web-vitals";
3
+ import nextTs from "eslint-config-next/typescript";
4
+
5
+ const eslintConfig = defineConfig([
6
+ ...nextVitals,
7
+ ...nextTs,
8
+ globalIgnores([".next/**", "out/**", "build/**", "next-env.d.ts"]),
9
+ ]);
10
+
11
+ export default eslintConfig;
@@ -0,0 +1,40 @@
1
+ # dependencies
2
+ /node_modules
3
+ /.pnp
4
+ .pnp.*
5
+ .yarn/*
6
+ !.yarn/patches
7
+ !.yarn/plugins
8
+ !.yarn/releases
9
+ !.yarn/versions
10
+
11
+ # testing
12
+ /coverage
13
+
14
+ # next.js
15
+ /.next/
16
+ /out/
17
+
18
+ # production
19
+ /build
20
+
21
+ # misc
22
+ .DS_Store
23
+ *.pem
24
+
25
+ # debug
26
+ npm-debug.log*
27
+ yarn-debug.log*
28
+ yarn-error.log*
29
+ .pnpm-debug.log*
30
+
31
+ # env files (contains secrets)
32
+ .env
33
+ .env*.local
34
+
35
+ # vercel
36
+ .vercel
37
+
38
+ # typescript
39
+ *.tsbuildinfo
40
+ next-env.d.ts
@@ -0,0 +1,11 @@
1
+ import type { NextConfig } from 'next';
2
+
3
+ const nextConfig: NextConfig = {
4
+ turbopack: {
5
+ // Required: prevents Turbopack from inferring a parent directory as root
6
+ // when .codeyam/ exists above the project (which breaks import resolution)
7
+ root: '.',
8
+ },
9
+ };
10
+
11
+ export default nextConfig;
@@ -0,0 +1,37 @@
1
+ {
2
+ "name": "codeyam-project",
3
+ "version": "0.1.0",
4
+ "private": true,
5
+ "scripts": {
6
+ "setup": "npm install && npm run db:push && npm run db:seed",
7
+ "dev": "next dev --turbopack",
8
+ "build": "next build",
9
+ "start": "next start",
10
+ "lint": "eslint",
11
+ "db:push": "npx prisma db push && npx prisma generate",
12
+ "db:seed": "npx tsx prisma/seed.ts",
13
+ "db:reset": "npx prisma migrate reset --force"
14
+ },
15
+ "dependencies": {
16
+ "@prisma/adapter-pg": "^7.4.1",
17
+ "@prisma/client": "^7.4.1",
18
+ "@supabase/supabase-js": "^2.49.4",
19
+ "next": "^15.3.3",
20
+ "pg": "^8.16.0",
21
+ "prisma": "^7.4.1",
22
+ "react": "^19.1.0",
23
+ "react-dom": "^19.1.0"
24
+ },
25
+ "devDependencies": {
26
+ "@tailwindcss/postcss": "^4",
27
+ "@types/node": "^20",
28
+ "@types/pg": "^8",
29
+ "@types/react": "^19",
30
+ "@types/react-dom": "^19",
31
+ "eslint": "^9",
32
+ "eslint-config-next": "^15.3.3",
33
+ "tailwindcss": "^4",
34
+ "tsx": "^4.19.4",
35
+ "typescript": "^5"
36
+ }
37
+ }
@@ -0,0 +1,7 @@
1
+ const config = {
2
+ plugins: {
3
+ "@tailwindcss/postcss": {},
4
+ },
5
+ };
6
+
7
+ export default config;
@@ -0,0 +1,27 @@
1
+ // Prisma 7 with PostgreSQL via Supabase.
2
+ //
3
+ // IMPORTANT: Use "prisma-client-js" (NOT "prisma-client").
4
+ // The "prisma-client" generator requires a custom output path which
5
+ // breaks Turbopack import resolution and seed script imports.
6
+ // "prisma-client-js" outputs to node_modules/@prisma/client which
7
+ // works everywhere with standard imports.
8
+
9
+ generator client {
10
+ provider = "prisma-client-js"
11
+ }
12
+
13
+ datasource db {
14
+ provider = "postgresql"
15
+ }
16
+
17
+ // ──────────────────────────────────────────────
18
+ // Replace these placeholder models with your own.
19
+ // After editing, run: npm run db:push
20
+ // ──────────────────────────────────────────────
21
+
22
+ model Todo {
23
+ id Int @id @default(autoincrement())
24
+ title String
25
+ completed Boolean @default(false)
26
+ createdAt DateTime @default(now())
27
+ }
@@ -0,0 +1,39 @@
1
+ // Seed script for populating the database with demo data.
2
+ //
3
+ // Run with: npx tsx prisma/seed.ts
4
+ // Or: npm run db:seed
5
+ //
6
+ // IMPORTANT: This file must use the same adapter pattern as app/lib/prisma.ts.
7
+ // Do NOT use `new PrismaClient()` without the adapter — Prisma 7 requires it.
8
+
9
+ import 'dotenv/config';
10
+ import { PrismaClient } from '@prisma/client';
11
+ import { PrismaPg } from '@prisma/adapter-pg';
12
+
13
+ const connectionString = process.env.DATABASE_URL!;
14
+ const adapter = new PrismaPg({ connectionString });
15
+ const prisma = new PrismaClient({ adapter });
16
+
17
+ async function main() {
18
+ // Clear existing data
19
+ await prisma.todo.deleteMany();
20
+
21
+ // Seed with demo data
22
+ await prisma.todo.createMany({
23
+ data: [
24
+ { title: 'Set up the project', completed: true },
25
+ { title: 'Build the first feature' },
26
+ { title: 'Add more scenarios' },
27
+ ],
28
+ });
29
+
30
+ const count = await prisma.todo.count();
31
+ console.log(`Seeded ${count} todos`);
32
+ }
33
+
34
+ main()
35
+ .then(() => prisma.$disconnect())
36
+ .catch((e) => {
37
+ console.error(e);
38
+ process.exit(1);
39
+ });
@@ -0,0 +1,12 @@
1
+ import 'dotenv/config';
2
+ import { defineConfig } from 'prisma/config';
3
+
4
+ export default defineConfig({
5
+ schema: 'prisma/schema.prisma',
6
+ migrations: {
7
+ path: 'prisma/migrations',
8
+ },
9
+ datasource: {
10
+ url: process.env['DATABASE_URL'],
11
+ },
12
+ });
@@ -0,0 +1,34 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2017",
4
+ "lib": ["dom", "dom.iterable", "esnext"],
5
+ "allowJs": true,
6
+ "skipLibCheck": true,
7
+ "strict": true,
8
+ "noEmit": true,
9
+ "esModuleInterop": true,
10
+ "module": "esnext",
11
+ "moduleResolution": "bundler",
12
+ "resolveJsonModule": true,
13
+ "isolatedModules": true,
14
+ "jsx": "react-jsx",
15
+ "incremental": true,
16
+ "plugins": [
17
+ {
18
+ "name": "next"
19
+ }
20
+ ],
21
+ "paths": {
22
+ "@/*": ["./*"]
23
+ }
24
+ },
25
+ "include": [
26
+ "next-env.d.ts",
27
+ "**/*.ts",
28
+ "**/*.tsx",
29
+ ".next/types/**/*.ts",
30
+ ".next/dev/types/**/*.ts",
31
+ "**/*.mts"
32
+ ],
33
+ "exclude": ["node_modules"]
34
+ }
@@ -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
 
@@ -229,7 +229,7 @@ tail -50 <server log path from context file>
229
229
  ## Tips
230
230
 
231
231
  - **NEVER modify shimmed component files** (`*_Scenario.tsx`) to change rendering behavior — only edit `MockData_*.tsx` files to change what the component displays. Shimmed components are auto-generated; functional changes to them won't persist and can't be saved as scenarios.
232
- - Keep edits small and incremental so the user can see changes in the preview as you go
232
+ - **Refresh the preview frequently** the user is watching the preview panel as you work. Make small changes, then refresh so they see visual progress. Don't batch multiple edits into one big refresh at the end. Aim for a refresh after every meaningful edit (new data values, layout changes, style tweaks).
233
233
  - **Always add `[CY-DEBUG]` logging before refreshing** — never refresh without a way to verify the result
234
234
  - Mock data files are TypeScript (`.tsx`) — they export scenario-specific props/data
235
235
  - The database at `.codeyam/db.sqlite3` has entity and scenario metadata if you need deeper investigation
@@ -12,16 +12,16 @@ You are in **Editor Mode**. The user sees a split-screen: this terminal on the l
12
12
 
13
13
  You MUST follow a step-by-step workflow driven by `codeyam editor` commands. Each command tells you exactly what to do next. **You do NOT have all the instructions upfront** — the commands provide them incrementally.
14
14
 
15
- **Your first action:** Run `codeyam editor`.
15
+ **Your first action:** Run `codeyam editor steps`.
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
19
  ## The Cycle
20
20
 
21
- Every feature follows 12 gated steps:
21
+ Every feature follows 13 gated steps:
22
22
 
23
23
  ```
24
- codeyam editor → Setup (if new) or cycle overview
24
+ codeyam editor steps → Setup (if new) or cycle overview
25
25
  codeyam editor 1 → Plan the feature (confirm with user)
26
26
  codeyam editor 2 → Build a working prototype fast
27
27
  codeyam editor 3 → Confirm prototype with user
@@ -33,10 +33,24 @@ codeyam editor 8 → Create app-level scenarios
33
33
  codeyam editor 9 → Create user-persona scenarios
34
34
  codeyam editor 10 → Verify screenshots and check for errors
35
35
  codeyam editor 11 → Create/update journal entry
36
- codeyam editor 12 → Present summary, get final approval
36
+ codeyam editor 12 → Verify screenshots and audit
37
+ codeyam editor 13 → Present summary, get final approval
37
38
  ```
38
39
 
39
- **You MUST run each command and follow its checklist before moving to the next.** Steps 1, 3, and 12 require user confirmation. After step 12, loop back to step 1.
40
+ **You MUST run each command and follow its checklist before moving to the next.** Steps 1, 3, and 13 require user confirmation. After step 13, loop back to step 1.
41
+
42
+ ## Handling User Feedback / Changes
43
+
44
+ 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
+
46
+ - Code changes (components, routes, lib functions, styles)
47
+ - Scenario data updates (seed data, localStorage data, mock data)
48
+ - Style adjustments (CSS, Tailwind classes, layout tweaks)
49
+ - Even small fixes (typos, color tweaks, spacing)
50
+
51
+ This command gives you the post-change checklist (re-register scenarios, re-run tests, update journal, etc.). Never make changes without running the change workflow first.
52
+
53
+ **CRITICAL:** The change workflow MUST end with `codeyam editor 13`, which shows Working Session Results to the user. Skipping this step is a broken experience — the user will not see what changed and cannot approve or request further changes. Every change, no matter how small, must conclude with results being shown.
40
54
 
41
55
  ## Key Rules
42
56
 
@@ -45,25 +59,90 @@ codeyam editor 12 → Present summary, get final approval
45
59
  - **Always scaffold with a database** (Prisma + SQLite)
46
60
  - **Build real API routes** — the proxy handles scenario data transparently
47
61
  - **Start the dev server via the CodeYam API** — it handles proxy setup automatically
48
- - **Verify the preview after changes** — check the dev server URL, not the proxy
62
+ - **Keep the preview moving** — the user watches the preview panel as you work. Refresh it frequently so they see progress, not a static screen. See below.
63
+
64
+ ## Keep the Preview Moving
65
+
66
+ The user is watching the live preview panel while you work. A static preview makes it feel like nothing is happening. **Refresh the preview after every meaningful change** — not just at the end of a step.
67
+
68
+ **During prototyping (step 2):**
69
+
70
+ - Refresh after creating the first visible page, even if it's bare
71
+ - Refresh after adding each major UI section (header, list, form, etc.)
72
+ - Refresh after seeding data so the user sees real content appear
73
+ - Refresh after styling changes so the user sees the visual progress
74
+
75
+ **During extraction (step 5):**
76
+
77
+ - Refresh after extracting each batch of components to confirm nothing broke
78
+
79
+ **During changes:**
80
+
81
+ - Refresh after each individual change, not after all changes are done
82
+
83
+ **How to refresh:**
84
+
85
+ ```
86
+ codeyam editor preview
87
+ ```
88
+
89
+ Navigate to a specific path or switch scenario:
90
+
91
+ ```
92
+ codeyam editor preview '{"path":"/drinks/1"}'
93
+ codeyam editor preview '{"scenarioId":"abc-123"}'
94
+ ```
95
+
96
+ The goal: the user should see the preview update 4-8+ times during a typical building session, not just once at the end.
97
+
98
+ ## Collaboration
99
+
100
+ Isolation routes are committed to git (not gitignored). They are protected by a layout guard at `app/isolated-components/layout.tsx` that returns `notFound()` in production, so they are safe to commit. Scenarios, screenshots, journal entries, and the glossary are also committed. Only the local database and secrets are gitignored.
101
+
102
+ When a collaborator clones the repo and runs `codeyam editor`, scenarios are auto-imported from `scenarios-manifest.json`. Run `codeyam editor sync` to manually re-sync after pulling new changes.
49
103
 
50
104
  ## Quick Reference
51
105
 
52
106
  ```bash
53
- # Register scenario (auto-captures screenshot)
54
- curl -s -X POST http://localhost:${CODEYAM_PORT:-3111}/api/editor-register-scenario \
55
- -H 'Content-Type: application/json' \
56
- -d '{"name":"...","description":"...","mockData":{"routes":{"/api/...":{"body":[...]}}}}'
107
+ # 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":[...]}}}}'
109
+
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":[...]}}'
112
+
113
+ # Register app scenario with localStorage (for apps using client-side storage instead of a database)
114
+ codeyam editor register '{"name":"Full Library","type":"application","url":"/","localStorage":{"articles":[...],"collections":[...]}}'
115
+
116
+ # For large seed/localStorage data, write JSON to a temp file and use @ prefix:
117
+ codeyam editor register @/tmp/scenario-data.json
57
118
 
58
119
  # Journal entry (one per feature, references scenario names)
59
- curl -s -X POST http://localhost:${CODEYAM_PORT:-3111}/api/editor-journal-entry \
60
- -H 'Content-Type: application/json' \
61
- -d '{"title":"...","type":"feature","description":"...","scenarios":["..."]}'
120
+ codeyam editor journal '{"title":"...","type":"feature","description":"..."}'
121
+
122
+ # Update journal with commit info
123
+ codeyam editor journal-update '{"time":"...","commitSha":"...","commitMessage":"..."}'
124
+
125
+ # Refresh preview / navigate / switch scenario
126
+ codeyam editor preview
127
+ codeyam editor preview '{"path":"/drinks/1"}'
128
+ codeyam editor preview '{"scenarioId":"abc-123"}'
62
129
 
63
- # Refresh preview
64
- curl -s -X POST http://localhost:${CODEYAM_PORT:-3111}/api/dev-mode-preview
130
+ # Show/hide results panel
131
+ codeyam editor show-results
132
+ codeyam editor hide-results
133
+
134
+ # Commit feature
135
+ codeyam editor commit '{"message":"feat: Add drinks page"}'
65
136
 
66
137
  # Restart dev server (only for config/dependency changes)
67
- curl -s -X POST http://localhost:${CODEYAM_PORT:-3111}/api/editor-dev-server \
68
- -H 'Content-Type: application/json' -d '{"action":"restart"}'
138
+ codeyam editor dev-server '{"action":"restart"}'
139
+
140
+ # Check for client-side errors
141
+ codeyam editor client-errors
142
+
143
+ # Verify all images load (extracts URLs from pages, HTTP-checks each one)
144
+ codeyam editor verify-images '{"paths":["/","/drinks/1"]}'
145
+
146
+ # Sync scenarios from manifest (after pulling collaborator changes)
147
+ codeyam editor sync
69
148
  ```
@@ -225,31 +225,31 @@ rm -rf /tmp/codeyam-memory/ /tmp/cc-session-analysis/
225
225
  ```
226
226
 
227
227
  ```bash
228
- bash .claude/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.sh
228
+ node .claude/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs
229
229
  ```
230
230
 
231
231
  ```bash
232
- bash .claude/skills/codeyam-memory/scripts/holistic-analysis/find-exports.sh
232
+ node .claude/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs
233
233
  ```
234
234
 
235
235
  ```bash
236
- bash .claude/skills/codeyam-memory/scripts/session-mining/preprocess.sh 2>/dev/null
236
+ node .claude/skills/codeyam-memory/scripts/session-mining/preprocess.mjs 2>/dev/null
237
237
  ```
238
238
 
239
- Capture the stdout of `preprocess.sh` — each line is a path to a filtered session file.
239
+ Capture the stdout of `preprocess.mjs` — each line is a path to a filtered session file.
240
240
 
241
241
  ### Step 2: Extract sizing metrics
242
242
 
243
- Use quick `jq` one-liners to extract counts — do NOT read the full JSON files into the main context:
243
+ Use quick one-liners to extract counts — do NOT read the full JSON files into the main context:
244
244
 
245
245
  ```bash
246
- jq '.dependencies | length' /tmp/codeyam-memory/deprecated-scan.json
247
- jq '.explicit_markers | length' /tmp/codeyam-memory/deprecated-scan.json
248
- jq '.stats.total_exports' /tmp/codeyam-memory/exports-scan.json
249
- jq '.stats.total_files' /tmp/codeyam-memory/exports-scan.json
246
+ node .claude/skills/codeyam-memory/scripts/lib/read-json-field.mjs /tmp/codeyam-memory/deprecated-scan.json '.dependencies | length'
247
+ node .claude/skills/codeyam-memory/scripts/lib/read-json-field.mjs /tmp/codeyam-memory/deprecated-scan.json '.explicit_markers | length'
248
+ node .claude/skills/codeyam-memory/scripts/lib/read-json-field.mjs /tmp/codeyam-memory/exports-scan.json '.stats.total_exports'
249
+ node .claude/skills/codeyam-memory/scripts/lib/read-json-field.mjs /tmp/codeyam-memory/exports-scan.json '.stats.total_files'
250
250
  ```
251
251
 
252
- The session count is the number of lines from `preprocess.sh` stdout.
252
+ The session count is the number of lines from `preprocess.mjs` stdout.
253
253
 
254
254
  **Time estimate formulas:**
255
255
 
@@ -0,0 +1,139 @@
1
+ #!/usr/bin/env node
2
+ // Gathers deprecation signals from package.json, source markers, and git history.
3
+ // Outputs structured JSON to /tmp/codeyam-memory/deprecated-scan.json
4
+
5
+ import { readdir, readFile, mkdir, writeFile } from 'node:fs/promises';
6
+ import { execFileSync } from 'node:child_process';
7
+ import { join } from 'node:path';
8
+ import { ripgrepSearch } from '../lib/ripgrep-fallback.mjs';
9
+
10
+ const OUTPUT_DIR = '/tmp/codeyam-memory';
11
+ const OUTPUT_FILE = join(OUTPUT_DIR, 'deprecated-scan.json');
12
+ await mkdir(OUTPUT_DIR, { recursive: true });
13
+
14
+ // --- Dependency scan ---
15
+ // Collect all dependency names from package.json files
16
+ const allDeps = new Set();
17
+ const packageFiles = await findFiles('.', 'package.json', ['node_modules', 'dist', '.next']);
18
+
19
+ for (const pkgPath of packageFiles) {
20
+ try {
21
+ const pkg = JSON.parse(await readFile(pkgPath, 'utf-8'));
22
+ for (const key of ['dependencies', 'devDependencies']) {
23
+ if (pkg[key] && typeof pkg[key] === 'object') {
24
+ for (const dep of Object.keys(pkg[key])) allDeps.add(dep);
25
+ }
26
+ }
27
+ } catch {
28
+ // Skip unparseable package.json
29
+ }
30
+ }
31
+
32
+ const dependencies = [...allDeps].sort();
33
+
34
+ // --- Explicit marker scan ---
35
+ let explicitMarkers = [];
36
+
37
+ const markerOutput = await ripgrepSearch(
38
+ '@deprecated|// legacy|// deprecated|// old approach|TODO.*deprecat|FIXME.*deprecat',
39
+ {
40
+ types: ['ts', 'js'],
41
+ globs: ['!node_modules', '!dist', '!build', '!.next'],
42
+ context: 2,
43
+ lineNumbers: true,
44
+ },
45
+ );
46
+
47
+ if (markerOutput.trim()) {
48
+ // Parse ripgrep output into structured entries
49
+ for (const line of markerOutput.split('\n')) {
50
+ // Match "file:line:text" (colons in file path unlikely for these repos)
51
+ const match = line.match(/^([^:]+):(\d+):(.*)$/);
52
+ if (match) {
53
+ explicitMarkers.push({
54
+ file: match[1],
55
+ line: parseInt(match[2], 10),
56
+ text: match[3].trim(),
57
+ });
58
+ }
59
+ }
60
+ }
61
+
62
+ // --- Git recency comparison ---
63
+ const gitRecency = {};
64
+
65
+ if (dependencies.length > 0) {
66
+ const recentImports = gitImports('3 months ago', undefined);
67
+ const oldImports = gitImports('12 months ago', '3 months ago');
68
+
69
+ for (const dep of dependencies) {
70
+ if (dep.length < 3) continue; // Skip short names that match too broadly
71
+
72
+ const pattern = `from ['"]${dep}`;
73
+ const recent = countMatches(recentImports, pattern);
74
+ const old = countMatches(oldImports, pattern);
75
+
76
+ if (recent > 0 || old > 0) {
77
+ gitRecency[dep] = { recent_imports: recent, old_imports: old };
78
+ }
79
+ }
80
+ }
81
+
82
+ // --- Assemble final output ---
83
+ const output = {
84
+ dependencies,
85
+ explicit_markers: explicitMarkers,
86
+ git_recency: gitRecency,
87
+ };
88
+
89
+ await writeFile(OUTPUT_FILE, JSON.stringify(output, null, 2));
90
+
91
+ console.log(`Deprecated pattern scan complete: ${OUTPUT_FILE}`);
92
+ console.log(` Dependencies found: ${dependencies.length}`);
93
+ console.log(` Explicit markers found: ${explicitMarkers.length}`);
94
+ console.log(` Deps with git activity: ${Object.keys(gitRecency).length}`);
95
+
96
+ // --- Helpers ---
97
+
98
+ async function findFiles(dir, filename, ignoreDirs) {
99
+ const results = [];
100
+ const ignoreSet = new Set(ignoreDirs);
101
+
102
+ let entries;
103
+ try {
104
+ entries = await readdir(dir, { recursive: true, withFileTypes: true });
105
+ } catch {
106
+ return results;
107
+ }
108
+
109
+ for (const entry of entries) {
110
+ if (!entry.isFile() || entry.name !== filename) continue;
111
+ const parentPath = entry.parentPath ?? entry.path; // parentPath in Node 22+
112
+ const parts = parentPath.split('/');
113
+ if (parts.some((p) => ignoreSet.has(p))) continue;
114
+ results.push(join(parentPath, entry.name));
115
+ }
116
+ return results;
117
+ }
118
+
119
+ function gitImports(since, until) {
120
+ const args = ['log', `--since=${since}`, '-p', '--', '*.ts', '*.tsx', '*.js', '*.jsx'];
121
+ if (until) args.splice(2, 0, `--until=${until}`);
122
+
123
+ try {
124
+ const output = execFileSync('git', args, {
125
+ maxBuffer: 100 * 1024 * 1024,
126
+ encoding: 'utf-8',
127
+ stdio: ['pipe', 'pipe', 'pipe'],
128
+ });
129
+ return output;
130
+ } catch {
131
+ return '';
132
+ }
133
+ }
134
+
135
+ function countMatches(text, pattern) {
136
+ const regex = new RegExp(pattern, 'g');
137
+ const matches = text.match(regex);
138
+ return matches ? matches.length : 0;
139
+ }