claude-code-workflow 6.1.4 → 6.2.2

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 (437) hide show
  1. package/.claude/CLAUDE.md +10 -0
  2. package/.claude/agents/action-planning-agent.md +857 -778
  3. package/.claude/agents/cli-execution-agent.md +266 -269
  4. package/.claude/agents/cli-explore-agent.md +2 -2
  5. package/.claude/agents/cli-lite-planning-agent.md +142 -92
  6. package/.claude/agents/cli-planning-agent.md +4 -4
  7. package/.claude/agents/code-developer.md +7 -6
  8. package/.claude/agents/conceptual-planning-agent.md +2 -2
  9. package/.claude/agents/context-search-agent.md +31 -32
  10. package/.claude/agents/doc-generator.md +4 -4
  11. package/.claude/agents/memory-bridge.md +93 -93
  12. package/.claude/agents/test-context-search-agent.md +8 -7
  13. package/.claude/agents/test-fix-agent.md +7 -6
  14. package/.claude/commands/clean.md +516 -0
  15. package/.claude/commands/memory/compact.md +383 -0
  16. package/.claude/commands/memory/docs-full-cli.md +471 -471
  17. package/.claude/commands/memory/docs-related-cli.md +386 -386
  18. package/.claude/commands/memory/docs.md +615 -615
  19. package/.claude/commands/memory/load.md +5 -5
  20. package/.claude/commands/memory/tech-research-rules.md +310 -0
  21. package/.claude/commands/memory/update-full.md +332 -332
  22. package/.claude/commands/memory/workflow-skill-memory.md +4 -4
  23. package/.claude/commands/task/create.md +151 -151
  24. package/.claude/commands/version.md +254 -254
  25. package/.claude/commands/workflow/brainstorm/api-designer.md +587 -585
  26. package/.claude/commands/workflow/brainstorm/artifacts.md +1 -0
  27. package/.claude/commands/workflow/brainstorm/auto-parallel.md +443 -443
  28. package/.claude/commands/workflow/brainstorm/data-architect.md +220 -220
  29. package/.claude/commands/workflow/brainstorm/product-manager.md +200 -200
  30. package/.claude/commands/workflow/brainstorm/product-owner.md +200 -200
  31. package/.claude/commands/workflow/brainstorm/scrum-master.md +200 -200
  32. package/.claude/commands/workflow/brainstorm/subject-matter-expert.md +200 -200
  33. package/.claude/commands/workflow/brainstorm/system-architect.md +389 -387
  34. package/.claude/commands/workflow/brainstorm/ui-designer.md +221 -221
  35. package/.claude/commands/workflow/brainstorm/ux-expert.md +221 -221
  36. package/.claude/commands/workflow/debug.md +321 -0
  37. package/.claude/commands/workflow/execute.md +13 -0
  38. package/.claude/commands/workflow/init.md +165 -164
  39. package/.claude/commands/workflow/lite-execute.md +119 -13
  40. package/.claude/commands/workflow/lite-fix.md +623 -621
  41. package/.claude/commands/workflow/lite-plan.md +610 -592
  42. package/.claude/commands/workflow/plan.md +5 -5
  43. package/.claude/commands/workflow/review-module-cycle.md +2 -0
  44. package/.claude/commands/workflow/review-session-cycle.md +2 -0
  45. package/.claude/commands/workflow/review.md +297 -291
  46. package/.claude/commands/workflow/session/complete.md +153 -500
  47. package/.claude/commands/workflow/session/list.md +95 -95
  48. package/.claude/commands/workflow/session/resume.md +60 -60
  49. package/.claude/commands/workflow/session/start.md +199 -199
  50. package/.claude/commands/workflow/tdd-plan.md +3 -3
  51. package/.claude/commands/workflow/tdd-verify.md +23 -9
  52. package/.claude/commands/workflow/test-cycle-execute.md +2 -0
  53. package/.claude/commands/workflow/test-fix-gen.md +699 -699
  54. package/.claude/commands/workflow/tools/conflict-resolution.md +104 -18
  55. package/.claude/commands/workflow/tools/context-gather.md +436 -434
  56. package/.claude/commands/workflow/tools/task-generate-agent.md +490 -291
  57. package/.claude/commands/workflow/tools/task-generate-tdd.md +18 -10
  58. package/.claude/commands/workflow/tools/test-concept-enhanced.md +2 -1
  59. package/.claude/commands/workflow/tools/test-context-gather.md +1 -0
  60. package/.claude/commands/workflow/tools/test-task-generate.md +1 -0
  61. package/.claude/commands/workflow/ui-design/import-from-code.md +9 -6
  62. package/.claude/skills/command-guide/SKILL.md +5 -5
  63. package/.claude/skills/command-guide/index/all-commands.json +1 -1
  64. package/.claude/skills/command-guide/index/by-category.json +1 -1
  65. package/.claude/skills/command-guide/index/by-use-case.json +1 -1
  66. package/.claude/skills/command-guide/reference/agents/action-planning-agent.md +857 -778
  67. package/.claude/skills/command-guide/reference/agents/cli-execution-agent.md +266 -269
  68. package/.claude/skills/command-guide/reference/agents/cli-explore-agent.md +2 -2
  69. package/.claude/skills/command-guide/reference/agents/cli-lite-planning-agent.md +142 -92
  70. package/.claude/skills/command-guide/reference/agents/cli-planning-agent.md +4 -4
  71. package/.claude/skills/command-guide/reference/agents/code-developer.md +7 -6
  72. package/.claude/skills/command-guide/reference/agents/conceptual-planning-agent.md +2 -2
  73. package/.claude/skills/command-guide/reference/agents/context-search-agent.md +31 -32
  74. package/.claude/skills/command-guide/reference/agents/doc-generator.md +4 -4
  75. package/.claude/skills/command-guide/reference/agents/memory-bridge.md +93 -93
  76. package/.claude/skills/command-guide/reference/agents/test-context-search-agent.md +8 -7
  77. package/.claude/skills/command-guide/reference/agents/test-fix-agent.md +7 -6
  78. package/.claude/skills/command-guide/reference/commands/memory/docs-full-cli.md +471 -471
  79. package/.claude/skills/command-guide/reference/commands/memory/docs-related-cli.md +386 -386
  80. package/.claude/skills/command-guide/reference/commands/memory/docs.md +17 -16
  81. package/.claude/skills/command-guide/reference/commands/memory/load.md +5 -5
  82. package/.claude/skills/command-guide/reference/commands/memory/tech-research.md +194 -357
  83. package/.claude/skills/command-guide/reference/commands/memory/update-full.md +332 -332
  84. package/.claude/skills/command-guide/reference/commands/memory/workflow-skill-memory.md +4 -4
  85. package/.claude/skills/command-guide/reference/commands/task/create.md +151 -151
  86. package/.claude/skills/command-guide/reference/commands/version.md +254 -254
  87. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/api-designer.md +585 -585
  88. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/auto-parallel.md +443 -443
  89. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/data-architect.md +220 -220
  90. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-manager.md +200 -200
  91. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-owner.md +200 -200
  92. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/scrum-master.md +200 -200
  93. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/subject-matter-expert.md +200 -200
  94. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/system-architect.md +387 -387
  95. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ui-designer.md +221 -221
  96. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ux-expert.md +221 -221
  97. package/.claude/skills/command-guide/reference/commands/workflow/execute.md +25 -20
  98. package/.claude/skills/command-guide/reference/commands/workflow/init.md +164 -164
  99. package/.claude/skills/command-guide/reference/commands/workflow/lite-execute.md +748 -686
  100. package/.claude/skills/command-guide/reference/commands/workflow/lite-fix.md +664 -621
  101. package/.claude/skills/command-guide/reference/commands/workflow/lite-plan.md +645 -592
  102. package/.claude/skills/command-guide/reference/commands/workflow/plan.md +5 -5
  103. package/.claude/skills/command-guide/reference/commands/workflow/review.md +25 -18
  104. package/.claude/skills/command-guide/reference/commands/workflow/session/complete.md +547 -500
  105. package/.claude/skills/command-guide/reference/commands/workflow/session/list.md +45 -27
  106. package/.claude/skills/command-guide/reference/commands/workflow/session/resume.md +35 -19
  107. package/.claude/skills/command-guide/reference/commands/workflow/session/start.md +90 -33
  108. package/.claude/skills/command-guide/reference/commands/workflow/tdd-plan.md +3 -3
  109. package/.claude/skills/command-guide/reference/commands/workflow/tdd-verify.md +23 -9
  110. package/.claude/skills/command-guide/reference/commands/workflow/test-fix-gen.md +699 -699
  111. package/.claude/skills/command-guide/reference/commands/workflow/tools/conflict-resolution.md +103 -17
  112. package/.claude/skills/command-guide/reference/commands/workflow/tools/context-gather.md +434 -434
  113. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-agent.md +487 -291
  114. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-tdd.md +17 -10
  115. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-concept-enhanced.md +1 -1
  116. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/import-from-code.md +6 -6
  117. package/.claude/workflows/chinese-response.md +38 -0
  118. package/.claude/workflows/cli-templates/prompts/rules/rule-api.txt +122 -0
  119. package/.claude/workflows/cli-templates/prompts/rules/rule-components.txt +122 -0
  120. package/.claude/workflows/cli-templates/prompts/rules/rule-config.txt +89 -0
  121. package/.claude/workflows/cli-templates/prompts/rules/rule-core.txt +60 -0
  122. package/.claude/workflows/cli-templates/prompts/rules/rule-patterns.txt +70 -0
  123. package/.claude/workflows/cli-templates/prompts/rules/rule-testing.txt +81 -0
  124. package/.claude/workflows/cli-templates/prompts/rules/tech-rules-agent-prompt.txt +89 -0
  125. package/.claude/workflows/cli-templates/prompts/workflow/gemini-solution-design.txt +131 -131
  126. package/.claude/workflows/cli-templates/prompts/workflow/skill-conflict-patterns.txt +5 -9
  127. package/.claude/workflows/cli-templates/prompts/workflow/skill-lessons-learned.txt +5 -9
  128. package/.claude/workflows/cli-templates/protocols/analysis-protocol.md +112 -0
  129. package/.claude/workflows/cli-templates/protocols/write-protocol.md +201 -0
  130. package/.claude/workflows/cli-templates/schemas/conflict-resolution-schema.json +137 -0
  131. package/.claude/workflows/cli-templates/schemas/debug-log-json-schema.json +127 -0
  132. package/.claude/workflows/cli-templates/schemas/fix-plan-json-schema.json +25 -0
  133. package/.claude/workflows/cli-templates/schemas/plan-json-schema.json +25 -0
  134. package/.claude/workflows/cli-tools-usage.md +526 -0
  135. package/{CLAUDE.md → .claude/workflows/coding-philosophy.md} +24 -45
  136. package/.claude/workflows/context-tools.md +84 -0
  137. package/.claude/workflows/file-modification.md +64 -0
  138. package/.claude/workflows/tool-strategy.md +216 -79
  139. package/.claude/workflows/windows-platform.md +16 -0
  140. package/.claude/workflows/workflow-architecture.md +942 -942
  141. package/.codex/AGENTS.md +63 -330
  142. package/.codex/prompts/debug.md +318 -0
  143. package/.codex/prompts/execute.md +273 -0
  144. package/.codex/prompts/lite-execute.md +164 -0
  145. package/.codex/prompts/lite-plan.md +469 -0
  146. package/.codex/prompts.zip +0 -0
  147. package/.gemini/GEMINI.md +25 -164
  148. package/.qwen/QWEN.md +0 -139
  149. package/README.md +29 -9
  150. package/ccw/README.md +30 -6
  151. package/ccw/bin/ccw-mcp.js +7 -0
  152. package/ccw/bin/ccw.js +9 -9
  153. package/ccw/package.json +65 -47
  154. package/ccw/src/.workflow/.cli-history/history.db +0 -0
  155. package/ccw/src/.workflow/.cli-history/history.db-shm +0 -0
  156. package/ccw/src/.workflow/.cli-history/history.db-wal +0 -0
  157. package/ccw/src/cli.ts +244 -0
  158. package/ccw/src/commands/cli.ts +740 -0
  159. package/ccw/src/commands/core-memory.ts +770 -0
  160. package/ccw/src/commands/hook.ts +315 -0
  161. package/ccw/src/commands/install.ts +519 -0
  162. package/ccw/src/commands/{list.js → list.ts} +1 -1
  163. package/ccw/src/commands/memory.ts +1090 -0
  164. package/ccw/src/commands/{serve.js → serve.ts} +14 -5
  165. package/ccw/src/commands/session-path-resolver.ts +372 -0
  166. package/ccw/src/commands/session.ts +1141 -0
  167. package/ccw/src/commands/{stop.js → stop.ts} +16 -6
  168. package/ccw/src/commands/tool.ts +201 -0
  169. package/ccw/src/commands/{uninstall.js → uninstall.ts} +89 -40
  170. package/ccw/src/commands/{upgrade.js → upgrade.ts} +68 -23
  171. package/ccw/src/commands/{view.js → view.ts} +22 -8
  172. package/ccw/src/config/storage-paths.ts +670 -0
  173. package/ccw/src/core/cache-manager.ts +294 -0
  174. package/ccw/src/core/claude-freshness.ts +319 -0
  175. package/ccw/src/core/core-memory-store.ts +1528 -0
  176. package/ccw/src/core/{dashboard-generator-patch.js → dashboard-generator-patch.ts} +18 -0
  177. package/ccw/src/core/{dashboard-generator.js → dashboard-generator.ts} +69 -12
  178. package/ccw/src/core/data-aggregator.ts +584 -0
  179. package/ccw/src/core/history-importer.ts +625 -0
  180. package/ccw/src/core/{lite-scanner.js → lite-scanner-complete.ts} +162 -66
  181. package/ccw/src/core/lite-scanner.ts +469 -0
  182. package/ccw/src/core/{manifest.js → manifest.ts} +104 -34
  183. package/ccw/src/core/memory-embedder-bridge.ts +262 -0
  184. package/ccw/src/core/memory-store.ts +978 -0
  185. package/ccw/src/core/routes/ccw-routes.ts +96 -0
  186. package/ccw/src/core/routes/claude-routes.ts +1183 -0
  187. package/ccw/src/core/routes/cli-routes.ts +561 -0
  188. package/ccw/src/core/routes/codexlens-routes.ts +806 -0
  189. package/ccw/src/core/routes/core-memory-routes.ts +605 -0
  190. package/ccw/src/core/routes/files-routes.ts +428 -0
  191. package/ccw/src/core/routes/graph-routes.md +164 -0
  192. package/ccw/src/core/routes/graph-routes.ts +626 -0
  193. package/ccw/src/core/routes/help-routes.ts +308 -0
  194. package/ccw/src/core/routes/hooks-routes.ts +405 -0
  195. package/ccw/src/core/routes/mcp-routes.ts +1271 -0
  196. package/ccw/src/core/routes/mcp-routes.ts.backup +550 -0
  197. package/ccw/src/core/routes/mcp-templates-db.ts +268 -0
  198. package/ccw/src/core/routes/memory-routes.ts +1206 -0
  199. package/ccw/src/core/routes/rules-routes.ts +526 -0
  200. package/ccw/src/core/routes/session-routes.ts +467 -0
  201. package/ccw/src/core/routes/skills-routes.ts +599 -0
  202. package/ccw/src/core/routes/status-routes.ts +57 -0
  203. package/ccw/src/core/routes/system-routes.ts +427 -0
  204. package/ccw/src/core/server.ts +431 -0
  205. package/ccw/src/core/session-clustering-service.ts +1258 -0
  206. package/ccw/src/core/session-scanner.ts +283 -0
  207. package/ccw/src/core/websocket.ts +190 -0
  208. package/ccw/src/{index.js → index.ts} +1 -0
  209. package/ccw/src/mcp-server/index.ts +186 -0
  210. package/ccw/src/templates/assets/css/github-dark.min.css +10 -0
  211. package/ccw/src/templates/assets/css/github.min.css +10 -0
  212. package/ccw/src/templates/assets/js/cytoscape.min.js +32 -0
  213. package/ccw/src/templates/assets/js/d3.min.js +2 -0
  214. package/ccw/src/templates/assets/js/highlight.min.js +1244 -0
  215. package/ccw/src/templates/assets/js/lucide.min.js +12 -0
  216. package/ccw/src/templates/assets/js/marked.min.js +69 -0
  217. package/ccw/src/templates/assets/js/tailwind.js +83 -0
  218. package/ccw/src/templates/dashboard-css/01-base.css +11 -0
  219. package/ccw/src/templates/dashboard-css/02-session.css +22 -0
  220. package/ccw/src/templates/dashboard-css/04-lite-tasks.css +10 -0
  221. package/ccw/src/templates/dashboard-css/06-cards.css +10 -4
  222. package/ccw/src/templates/dashboard-css/07-managers.css +1178 -7
  223. package/ccw/src/templates/dashboard-css/09-explorer.css +23 -12
  224. package/ccw/src/templates/dashboard-css/10-cli-status.css +337 -0
  225. package/ccw/src/templates/dashboard-css/11-cli-history.css +271 -0
  226. package/ccw/src/templates/dashboard-css/12-cli-legacy.css +796 -0
  227. package/ccw/src/templates/dashboard-css/13-cli-ccw.css +199 -0
  228. package/ccw/src/templates/dashboard-css/14-cli-modals.css +258 -0
  229. package/ccw/src/templates/dashboard-css/15-cli-endpoints.css +305 -0
  230. package/ccw/src/templates/dashboard-css/16-cli-session.css +241 -0
  231. package/ccw/src/templates/dashboard-css/17-cli-conversation.css +283 -0
  232. package/ccw/src/templates/dashboard-css/18-cli-settings.css +160 -0
  233. package/ccw/src/templates/dashboard-css/19-cli-native-session.css +496 -0
  234. package/ccw/src/templates/dashboard-css/20-cli-taskqueue.css +188 -0
  235. package/ccw/src/templates/dashboard-css/21-cli-toolmgmt.css +310 -0
  236. package/ccw/src/templates/dashboard-css/22-cli-semantic.css +240 -0
  237. package/ccw/src/templates/dashboard-css/23-memory.css +2390 -0
  238. package/ccw/src/templates/dashboard-css/24-prompt-history.css +1089 -0
  239. package/ccw/src/templates/dashboard-css/25-skills-rules.css +326 -0
  240. package/ccw/src/templates/dashboard-css/26-claude-manager.css +908 -0
  241. package/ccw/src/templates/dashboard-css/27-graph-explorer.css +1678 -0
  242. package/ccw/src/templates/dashboard-css/28-mcp-manager.css +748 -0
  243. package/ccw/src/templates/dashboard-css/29-help.css +264 -0
  244. package/ccw/src/templates/dashboard-css/30-core-memory.css +1700 -0
  245. package/ccw/src/templates/dashboard-js/api.js +162 -142
  246. package/ccw/src/templates/dashboard-js/components/carousel.js +4 -4
  247. package/ccw/src/templates/dashboard-js/components/cli-history.js +876 -0
  248. package/ccw/src/templates/dashboard-js/components/cli-status.js +978 -0
  249. package/ccw/src/templates/dashboard-js/components/global-notifications.js +508 -219
  250. package/ccw/src/templates/dashboard-js/components/hook-manager.js +1277 -282
  251. package/ccw/src/templates/dashboard-js/components/index-manager.js +302 -0
  252. package/ccw/src/templates/dashboard-js/components/mcp-manager.js +718 -27
  253. package/ccw/src/templates/dashboard-js/components/modals.js +66 -0
  254. package/ccw/src/templates/dashboard-js/components/navigation.js +80 -12
  255. package/ccw/src/templates/dashboard-js/components/notifications.js +758 -194
  256. package/ccw/src/templates/dashboard-js/components/storage-manager.js +478 -0
  257. package/ccw/src/templates/dashboard-js/components/tabs-other.js +157 -6
  258. package/ccw/src/templates/dashboard-js/components/task-queue-sidebar.js +716 -0
  259. package/ccw/src/templates/dashboard-js/help-i18n.js +272 -0
  260. package/ccw/src/templates/dashboard-js/i18n.js +2807 -0
  261. package/ccw/src/templates/dashboard-js/main.js +15 -0
  262. package/ccw/src/templates/dashboard-js/state.js +243 -42
  263. package/ccw/src/templates/dashboard-js/utils.js +47 -1
  264. package/ccw/src/templates/dashboard-js/views/claude-manager.js +912 -0
  265. package/ccw/src/templates/dashboard-js/views/cli-manager.js +2272 -0
  266. package/ccw/src/templates/dashboard-js/views/codexlens-manager.js +964 -0
  267. package/ccw/src/templates/dashboard-js/views/core-memory-clusters.js +503 -0
  268. package/ccw/src/templates/dashboard-js/views/core-memory.js +782 -0
  269. package/ccw/src/templates/dashboard-js/views/explorer.js +888 -852
  270. package/ccw/src/templates/dashboard-js/views/graph-explorer.js +1157 -0
  271. package/ccw/src/templates/dashboard-js/views/help.js +856 -0
  272. package/ccw/src/templates/dashboard-js/views/history.js +337 -0
  273. package/ccw/src/templates/dashboard-js/views/home.js +61 -15
  274. package/ccw/src/templates/dashboard-js/views/hook-manager.js +311 -43
  275. package/ccw/src/templates/dashboard-js/views/lite-tasks.js +204 -28
  276. package/ccw/src/templates/dashboard-js/views/mcp-manager.js +2187 -411
  277. package/ccw/src/templates/dashboard-js/views/mcp-manager.js.backup +1729 -0
  278. package/ccw/src/templates/dashboard-js/views/mcp-manager.js.new +928 -0
  279. package/ccw/src/templates/dashboard-js/views/memory.js +1221 -0
  280. package/ccw/src/templates/dashboard-js/views/prompt-history.js +713 -0
  281. package/ccw/src/templates/dashboard-js/views/rules-manager.js +828 -0
  282. package/ccw/src/templates/dashboard-js/views/session-detail.js +54 -53
  283. package/ccw/src/templates/dashboard-js/views/skills-manager.js +819 -0
  284. package/ccw/src/templates/dashboard.html +185 -85
  285. package/ccw/src/templates/hooks-config-example.json +60 -0
  286. package/ccw/src/tools/classify-folders.ts +245 -0
  287. package/ccw/src/tools/cli-config-manager.ts +268 -0
  288. package/ccw/src/tools/cli-executor.ts +2014 -0
  289. package/ccw/src/tools/cli-history-store.ts +1195 -0
  290. package/ccw/src/tools/codex-lens.ts +1141 -0
  291. package/ccw/src/tools/{convert-tokens-to-css.js → convert-tokens-to-css.ts} +73 -23
  292. package/ccw/src/tools/core-memory.ts +444 -0
  293. package/ccw/src/tools/detect-changed-modules.ts +325 -0
  294. package/ccw/src/tools/{discover-design-files.js → discover-design-files.ts} +74 -24
  295. package/ccw/src/tools/edit-file.ts +568 -0
  296. package/ccw/src/tools/{generate-module-docs.js → generate-module-docs.ts} +207 -185
  297. package/ccw/src/tools/{get-modules-by-depth.js → get-modules-by-depth.ts} +120 -79
  298. package/ccw/src/tools/index.ts +370 -0
  299. package/ccw/src/tools/native-session-discovery.ts +795 -0
  300. package/ccw/src/tools/notifier.ts +129 -0
  301. package/ccw/src/tools/read-file.ts +410 -0
  302. package/ccw/src/tools/resume-strategy.ts +345 -0
  303. package/ccw/src/tools/session-content-parser.ts +619 -0
  304. package/ccw/src/tools/session-manager.ts +1026 -0
  305. package/ccw/src/tools/smart-context.ts +228 -0
  306. package/ccw/src/tools/smart-search.ts +2065 -0
  307. package/ccw/src/tools/smart-search.ts.backup +1233 -0
  308. package/ccw/src/tools/storage-manager.ts +455 -0
  309. package/ccw/src/tools/write-file.ts +222 -0
  310. package/ccw/src/types/config.ts +11 -0
  311. package/ccw/src/types/index.ts +3 -0
  312. package/ccw/src/types/session.ts +25 -0
  313. package/ccw/src/types/tool.ts +41 -0
  314. package/ccw/src/utils/{browser-launcher.js → browser-launcher.ts} +10 -8
  315. package/ccw/src/utils/file-utils.ts +48 -0
  316. package/ccw/src/utils/{path-resolver.js → path-resolver.ts} +114 -78
  317. package/ccw/src/utils/path-validator.ts +153 -0
  318. package/ccw/src/utils/{ui.js → ui.ts} +32 -25
  319. package/codex-lens/pyproject.toml +48 -0
  320. package/codex-lens/src/codexlens/.workflow/.cli-history/history.db +0 -0
  321. package/codex-lens/src/codexlens/__init__.py +28 -0
  322. package/codex-lens/src/codexlens/__main__.py +14 -0
  323. package/codex-lens/src/codexlens/__pycache__/__init__.cpython-313.pyc +0 -0
  324. package/codex-lens/src/codexlens/__pycache__/__main__.cpython-313.pyc +0 -0
  325. package/codex-lens/src/codexlens/__pycache__/config.cpython-313.pyc +0 -0
  326. package/codex-lens/src/codexlens/__pycache__/entities.cpython-313.pyc +0 -0
  327. package/codex-lens/src/codexlens/__pycache__/errors.cpython-313.pyc +0 -0
  328. package/codex-lens/src/codexlens/cli/__init__.py +27 -0
  329. package/codex-lens/src/codexlens/cli/__pycache__/__init__.cpython-313.pyc +0 -0
  330. package/codex-lens/src/codexlens/cli/__pycache__/commands.cpython-313.pyc +0 -0
  331. package/codex-lens/src/codexlens/cli/__pycache__/embedding_manager.cpython-313.pyc +0 -0
  332. package/codex-lens/src/codexlens/cli/__pycache__/model_manager.cpython-313.pyc +0 -0
  333. package/codex-lens/src/codexlens/cli/__pycache__/output.cpython-313.pyc +0 -0
  334. package/codex-lens/src/codexlens/cli/commands.py +1931 -0
  335. package/codex-lens/src/codexlens/cli/embedding_manager.py +620 -0
  336. package/codex-lens/src/codexlens/cli/model_manager.py +289 -0
  337. package/codex-lens/src/codexlens/cli/output.py +124 -0
  338. package/codex-lens/src/codexlens/config.py +201 -0
  339. package/codex-lens/src/codexlens/entities.py +121 -0
  340. package/codex-lens/src/codexlens/errors.py +55 -0
  341. package/codex-lens/src/codexlens/indexing/README.md +77 -0
  342. package/codex-lens/src/codexlens/indexing/__init__.py +4 -0
  343. package/codex-lens/src/codexlens/indexing/__pycache__/__init__.cpython-313.pyc +0 -0
  344. package/codex-lens/src/codexlens/indexing/__pycache__/symbol_extractor.cpython-313.pyc +0 -0
  345. package/codex-lens/src/codexlens/indexing/symbol_extractor.py +243 -0
  346. package/codex-lens/src/codexlens/parsers/__init__.py +8 -0
  347. package/codex-lens/src/codexlens/parsers/__pycache__/__init__.cpython-313.pyc +0 -0
  348. package/codex-lens/src/codexlens/parsers/__pycache__/encoding.cpython-313.pyc +0 -0
  349. package/codex-lens/src/codexlens/parsers/__pycache__/factory.cpython-313.pyc +0 -0
  350. package/codex-lens/src/codexlens/parsers/__pycache__/tokenizer.cpython-313.pyc +0 -0
  351. package/codex-lens/src/codexlens/parsers/__pycache__/treesitter_parser.cpython-313.pyc +0 -0
  352. package/codex-lens/src/codexlens/parsers/encoding.py +202 -0
  353. package/codex-lens/src/codexlens/parsers/factory.py +256 -0
  354. package/codex-lens/src/codexlens/parsers/tokenizer.py +98 -0
  355. package/codex-lens/src/codexlens/parsers/treesitter_parser.py +335 -0
  356. package/codex-lens/src/codexlens/search/__init__.py +15 -0
  357. package/codex-lens/src/codexlens/search/__pycache__/__init__.cpython-313.pyc +0 -0
  358. package/codex-lens/src/codexlens/search/__pycache__/chain_search.cpython-313.pyc +0 -0
  359. package/codex-lens/src/codexlens/search/__pycache__/enrichment.cpython-313.pyc +0 -0
  360. package/codex-lens/src/codexlens/search/__pycache__/hybrid_search.cpython-313.pyc +0 -0
  361. package/codex-lens/src/codexlens/search/__pycache__/query_parser.cpython-313.pyc +0 -0
  362. package/codex-lens/src/codexlens/search/__pycache__/ranking.cpython-313.pyc +0 -0
  363. package/codex-lens/src/codexlens/search/chain_search.py +647 -0
  364. package/codex-lens/src/codexlens/search/enrichment.py +150 -0
  365. package/codex-lens/src/codexlens/search/hybrid_search.py +313 -0
  366. package/codex-lens/src/codexlens/search/query_parser.py +242 -0
  367. package/codex-lens/src/codexlens/search/ranking.py +274 -0
  368. package/codex-lens/src/codexlens/semantic/__init__.py +39 -0
  369. package/codex-lens/src/codexlens/semantic/__pycache__/__init__.cpython-313.pyc +0 -0
  370. package/codex-lens/src/codexlens/semantic/__pycache__/ann_index.cpython-313.pyc +0 -0
  371. package/codex-lens/src/codexlens/semantic/__pycache__/chunker.cpython-313.pyc +0 -0
  372. package/codex-lens/src/codexlens/semantic/__pycache__/code_extractor.cpython-313.pyc +0 -0
  373. package/codex-lens/src/codexlens/semantic/__pycache__/embedder.cpython-313.pyc +0 -0
  374. package/codex-lens/src/codexlens/semantic/__pycache__/graph_analyzer.cpython-313.pyc +0 -0
  375. package/codex-lens/src/codexlens/semantic/__pycache__/llm_enhancer.cpython-313.pyc +0 -0
  376. package/codex-lens/src/codexlens/semantic/__pycache__/vector_store.cpython-313.pyc +0 -0
  377. package/codex-lens/src/codexlens/semantic/ann_index.py +414 -0
  378. package/codex-lens/src/codexlens/semantic/chunker.py +448 -0
  379. package/codex-lens/src/codexlens/semantic/code_extractor.py +274 -0
  380. package/codex-lens/src/codexlens/semantic/embedder.py +185 -0
  381. package/codex-lens/src/codexlens/semantic/vector_store.py +955 -0
  382. package/codex-lens/src/codexlens/storage/__init__.py +29 -0
  383. package/codex-lens/src/codexlens/storage/__pycache__/__init__.cpython-313.pyc +0 -0
  384. package/codex-lens/src/codexlens/storage/__pycache__/dir_index.cpython-313.pyc +0 -0
  385. package/codex-lens/src/codexlens/storage/__pycache__/file_cache.cpython-313.pyc +0 -0
  386. package/codex-lens/src/codexlens/storage/__pycache__/index_tree.cpython-313.pyc +0 -0
  387. package/codex-lens/src/codexlens/storage/__pycache__/migration_manager.cpython-313.pyc +0 -0
  388. package/codex-lens/src/codexlens/storage/__pycache__/path_mapper.cpython-313.pyc +0 -0
  389. package/codex-lens/src/codexlens/storage/__pycache__/registry.cpython-313.pyc +0 -0
  390. package/codex-lens/src/codexlens/storage/__pycache__/sqlite_store.cpython-313.pyc +0 -0
  391. package/codex-lens/src/codexlens/storage/__pycache__/sqlite_utils.cpython-313.pyc +0 -0
  392. package/codex-lens/src/codexlens/storage/dir_index.py +1850 -0
  393. package/codex-lens/src/codexlens/storage/file_cache.py +32 -0
  394. package/codex-lens/src/codexlens/storage/index_tree.py +776 -0
  395. package/codex-lens/src/codexlens/storage/migration_manager.py +154 -0
  396. package/codex-lens/src/codexlens/storage/migrations/__init__.py +1 -0
  397. package/codex-lens/src/codexlens/storage/migrations/__pycache__/__init__.cpython-313.pyc +0 -0
  398. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_001_normalize_keywords.cpython-313.pyc +0 -0
  399. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_002_add_token_metadata.cpython-313.pyc +0 -0
  400. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_003_code_relationships.cpython-313.pyc +0 -0
  401. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_004_dual_fts.cpython-313.pyc +0 -0
  402. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_005_cleanup_unused_fields.cpython-313.pyc +0 -0
  403. package/codex-lens/src/codexlens/storage/migrations/migration_001_normalize_keywords.py +123 -0
  404. package/codex-lens/src/codexlens/storage/migrations/migration_002_add_token_metadata.py +48 -0
  405. package/codex-lens/src/codexlens/storage/migrations/migration_004_dual_fts.py +232 -0
  406. package/codex-lens/src/codexlens/storage/migrations/migration_005_cleanup_unused_fields.py +196 -0
  407. package/codex-lens/src/codexlens/storage/path_mapper.py +274 -0
  408. package/codex-lens/src/codexlens/storage/registry.py +670 -0
  409. package/codex-lens/src/codexlens/storage/sqlite_store.py +576 -0
  410. package/codex-lens/src/codexlens/storage/sqlite_utils.py +64 -0
  411. package/package.json +4 -1
  412. package/.claude/commands/memory/tech-research.md +0 -477
  413. package/.claude/scripts/classify-folders.sh +0 -39
  414. package/.claude/scripts/convert_tokens_to_css.sh +0 -229
  415. package/.claude/scripts/detect_changed_modules.sh +0 -161
  416. package/.claude/scripts/discover-design-files.sh +0 -87
  417. package/.claude/scripts/extract-animations.js +0 -243
  418. package/.claude/scripts/extract-computed-styles.js +0 -118
  419. package/.claude/scripts/extract-layout-structure.js +0 -411
  420. package/.claude/scripts/generate_module_docs.sh +0 -717
  421. package/.claude/scripts/get_modules_by_depth.sh +0 -170
  422. package/.claude/scripts/ui-generate-preview.sh +0 -395
  423. package/.claude/scripts/ui-instantiate-prototypes.sh +0 -815
  424. package/.claude/scripts/update_module_claude.sh +0 -337
  425. package/.claude/workflows/context-search-strategy.md +0 -77
  426. package/.claude/workflows/intelligent-tools-strategy.md +0 -662
  427. package/ccw/src/cli.js +0 -119
  428. package/ccw/src/commands/install.js +0 -324
  429. package/ccw/src/commands/tool.js +0 -138
  430. package/ccw/src/core/data-aggregator.js +0 -409
  431. package/ccw/src/core/server.js +0 -2063
  432. package/ccw/src/core/session-scanner.js +0 -235
  433. package/ccw/src/tools/classify-folders.js +0 -204
  434. package/ccw/src/tools/detect-changed-modules.js +0 -288
  435. package/ccw/src/tools/edit-file.js +0 -266
  436. package/ccw/src/tools/index.js +0 -176
  437. package/ccw/src/utils/file-utils.js +0 -48
@@ -0,0 +1,503 @@
1
+ // Session Clustering visualization for Core Memory
2
+ // Dependencies: This file requires core-memory.js to be loaded first
3
+ // - Uses: viewMemoryDetail(), fetchMemoryById(), showNotification(), t(), escapeHtml(), projectPath
4
+
5
+ // Global state
6
+ var clusterList = [];
7
+ var selectedCluster = null;
8
+ var embeddingStatus = null;
9
+
10
+ /**
11
+ * Check embedding status for better clustering
12
+ */
13
+ async function checkEmbeddingStatus() {
14
+ try {
15
+ const response = await fetch(`/api/core-memory/embed-status?path=${encodeURIComponent(projectPath)}`);
16
+ if (response.ok) {
17
+ embeddingStatus = await response.json();
18
+ }
19
+ } catch (error) {
20
+ console.log('Embedding status check skipped:', error.message);
21
+ }
22
+ }
23
+
24
+ /**
25
+ * Fetch and render cluster list
26
+ */
27
+ async function loadClusters() {
28
+ try {
29
+ // Check embedding status first
30
+ await checkEmbeddingStatus();
31
+
32
+ const response = await fetch(`/api/core-memory/clusters?path=${encodeURIComponent(projectPath)}`);
33
+ if (!response.ok) throw new Error(`HTTP ${response.status}`);
34
+
35
+ const result = await response.json();
36
+ clusterList = result.clusters || [];
37
+ renderClusterList();
38
+ } catch (error) {
39
+ console.error('Failed to load clusters:', error);
40
+ showNotification(t('coreMemory.clusterLoadError'), 'error');
41
+ }
42
+ }
43
+
44
+ /**
45
+ * Render embedding status hint
46
+ */
47
+ function renderEmbeddingHint() {
48
+ // No status data - API call failed
49
+ if (!embeddingStatus) {
50
+ return '';
51
+ }
52
+
53
+ // Embedder not available - show install hint linking to status page
54
+ if (embeddingStatus.available === false) {
55
+ return `
56
+ <div class="embedding-hint warning">
57
+ <i data-lucide="alert-triangle"></i>
58
+ <span>${t('coreMemory.embeddingNotAvailable')}</span>
59
+ <a href="#" onclick="switchToSemanticStatus(); return false;" class="hint-link">
60
+ ${t('coreMemory.installGuide')}
61
+ </a>
62
+ </div>
63
+ `;
64
+ }
65
+
66
+ // Has pending chunks - show progress
67
+ if (embeddingStatus.pending_chunks > 0) {
68
+ const pct = embeddingStatus.total_chunks > 0
69
+ ? Math.round((embeddingStatus.embedded_chunks / embeddingStatus.total_chunks) * 100)
70
+ : 0;
71
+ return `
72
+ <div class="embedding-hint info">
73
+ <i data-lucide="cpu"></i>
74
+ <span>${t('coreMemory.embeddingProgress', { pct, pending: embeddingStatus.pending_chunks })}</span>
75
+ <button class="btn btn-xs" onclick="triggerEmbedding()">
76
+ ${t('coreMemory.generateEmbeddings')}
77
+ </button>
78
+ </div>
79
+ `;
80
+ }
81
+
82
+ // No chunks yet - show hint to run embed
83
+ if (embeddingStatus.total_chunks === 0) {
84
+ return `
85
+ <div class="embedding-hint info">
86
+ <i data-lucide="info"></i>
87
+ <span>${t('coreMemory.noChunksYet')}</span>
88
+ <button class="btn btn-xs" onclick="triggerEmbedding()">
89
+ ${t('coreMemory.generateEmbeddings')}
90
+ </button>
91
+ </div>
92
+ `;
93
+ }
94
+
95
+ // All embedded - no hint needed
96
+ return '';
97
+ }
98
+
99
+ /**
100
+ * Switch to CLI Manager and show semantic install hint
101
+ */
102
+ function switchToSemanticStatus() {
103
+ // Navigate to CLI Manager view (which contains the Semantic Search section)
104
+ const navItem = document.querySelector('[data-view="cli-manager"]');
105
+ if (navItem) {
106
+ navItem.click();
107
+ // Open CodexLens config modal after navigation
108
+ setTimeout(() => {
109
+ if (typeof openCodexLensConfig === 'function') {
110
+ openCodexLensConfig();
111
+ }
112
+ }, 300);
113
+ } else {
114
+ showNotification(t('coreMemory.goToSemanticStatus'), 'info');
115
+ }
116
+ }
117
+
118
+ /**
119
+ * Trigger embedding generation
120
+ */
121
+ async function triggerEmbedding() {
122
+ try {
123
+ showNotification(t('coreMemory.embeddingInProgress'), 'info');
124
+ const response = await fetch(`/api/core-memory/embed?path=${encodeURIComponent(projectPath)}`, {
125
+ method: 'POST'
126
+ });
127
+ if (!response.ok) throw new Error(`HTTP ${response.status}`);
128
+ const result = await response.json();
129
+ showNotification(t('coreMemory.embeddingComplete', { count: result.chunks_processed }), 'success');
130
+ await loadClusters();
131
+ } catch (error) {
132
+ console.error('Embedding failed:', error);
133
+ showNotification(t('coreMemory.embeddingError'), 'error');
134
+ }
135
+ }
136
+
137
+ /**
138
+ * Render cluster list in sidebar
139
+ */
140
+ function renderClusterList() {
141
+ const container = document.getElementById('clusterListContainer');
142
+ if (!container) return;
143
+
144
+ // Add embedding status hint at top
145
+ const embeddingHint = renderEmbeddingHint();
146
+
147
+ if (clusterList.length === 0) {
148
+ container.innerHTML = `
149
+ ${embeddingHint}
150
+ <div class="empty-state">
151
+ <i data-lucide="folder-tree"></i>
152
+ <p>${t('coreMemory.noClusters')}</p>
153
+ <button class="btn btn-primary btn-sm" onclick="triggerAutoClustering()">
154
+ <i data-lucide="sparkles"></i>
155
+ ${t('coreMemory.autoCluster')}
156
+ </button>
157
+ </div>
158
+ `;
159
+ lucide.createIcons();
160
+ return;
161
+ }
162
+
163
+ container.innerHTML = embeddingHint + clusterList.map(cluster => `
164
+ <div class="cluster-item ${selectedCluster?.id === cluster.id ? 'active' : ''}"
165
+ onclick="selectCluster('${cluster.id}')">
166
+ <div class="cluster-icon">
167
+ <i data-lucide="${cluster.status === 'active' ? 'folder-open' : 'folder'}"></i>
168
+ </div>
169
+ <div class="cluster-info">
170
+ <div class="cluster-name">${escapeHtml(cluster.name)}</div>
171
+ <div class="cluster-meta">
172
+ <span>${cluster.memberCount} sessions</span>
173
+ <span>${formatDate(cluster.updated_at)}</span>
174
+ </div>
175
+ </div>
176
+ <span class="badge badge-${cluster.status}">${cluster.status}</span>
177
+ </div>
178
+ `).join('');
179
+
180
+ lucide.createIcons();
181
+ }
182
+
183
+ /**
184
+ * Select and load cluster details
185
+ */
186
+ async function selectCluster(clusterId) {
187
+ try {
188
+ const response = await fetch(`/api/core-memory/clusters/${clusterId}?path=${encodeURIComponent(projectPath)}`);
189
+ if (!response.ok) throw new Error(`HTTP ${response.status}`);
190
+
191
+ const result = await response.json();
192
+ selectedCluster = result.cluster;
193
+ renderClusterDetail(result.cluster, result.members, result.relations);
194
+
195
+ // Update list to show selection
196
+ renderClusterList();
197
+ } catch (error) {
198
+ console.error('Failed to load cluster:', error);
199
+ showNotification(t('coreMemory.clusterDetailError'), 'error');
200
+ }
201
+ }
202
+
203
+ /**
204
+ * Render cluster detail view
205
+ */
206
+ function renderClusterDetail(cluster, members, relations) {
207
+ const container = document.getElementById('clusterDetailContainer');
208
+ if (!container) return;
209
+
210
+ container.innerHTML = `
211
+ <div class="cluster-detail">
212
+ <div class="cluster-header">
213
+ <h3>${escapeHtml(cluster.name)}</h3>
214
+ <div class="cluster-actions">
215
+ <button class="btn btn-sm" onclick="editCluster('${cluster.id}')" title="${t('common.edit')}">
216
+ <i data-lucide="edit-2"></i>
217
+ </button>
218
+ <button class="btn btn-sm btn-danger" onclick="deleteCluster('${cluster.id}')" title="${t('common.delete')}">
219
+ <i data-lucide="trash-2"></i>
220
+ </button>
221
+ </div>
222
+ </div>
223
+
224
+ ${cluster.description ? `<p class="cluster-description">${escapeHtml(cluster.description)}</p>` : ''}
225
+ ${cluster.intent ? `<div class="cluster-intent"><strong>${t('coreMemory.intent')}:</strong> ${escapeHtml(cluster.intent)}</div>` : ''}
226
+
227
+ <div class="cluster-timeline">
228
+ <h4><i data-lucide="git-branch"></i> ${t('coreMemory.sessionTimeline')}</h4>
229
+ ${renderTimeline(members)}
230
+ </div>
231
+
232
+ ${relations && relations.length > 0 ? `
233
+ <div class="cluster-relations">
234
+ <h4><i data-lucide="link"></i> ${t('coreMemory.relatedClusters')}</h4>
235
+ ${renderRelations(relations)}
236
+ </div>
237
+ ` : ''}
238
+ </div>
239
+ `;
240
+
241
+ lucide.createIcons();
242
+ }
243
+
244
+ /**
245
+ * Render session timeline
246
+ */
247
+ function renderTimeline(members) {
248
+ if (!members || members.length === 0) {
249
+ return `<p class="text-muted">${t('coreMemory.noSessions')}</p>`;
250
+ }
251
+
252
+ // Sort by sequence order
253
+ const sorted = [...members].sort((a, b) => a.sequence_order - b.sequence_order);
254
+
255
+ return `
256
+ <div class="timeline">
257
+ ${sorted.map((member, index) => {
258
+ const meta = member.metadata || {};
259
+ // Get display text - prefer title, fallback to summary
260
+ const displayTitle = meta.title || meta.summary || '';
261
+ // Truncate for display
262
+ const truncatedTitle = displayTitle.length > 120
263
+ ? displayTitle.substring(0, 120) + '...'
264
+ : displayTitle;
265
+
266
+ return `
267
+ <div class="timeline-item">
268
+ <div class="timeline-marker">
269
+ <span class="timeline-number">${index + 1}</span>
270
+ </div>
271
+ <div class="timeline-content clickable" onclick="previewSession('${member.session_id}', '${member.session_type}')">
272
+ <div class="timeline-header">
273
+ <span class="session-id">${escapeHtml(member.session_id)}</span>
274
+ <span class="badge badge-${member.session_type}">${member.session_type}</span>
275
+ </div>
276
+ ${truncatedTitle ? `<div class="session-title">${escapeHtml(truncatedTitle)}</div>` : ''}
277
+ ${meta.token_estimate ? `<div class="session-tokens">~${meta.token_estimate} tokens</div>` : ''}
278
+ <div class="timeline-card-footer">
279
+ <span class="preview-hint"><i data-lucide="eye"></i> ${t('coreMemory.clickToPreview')}</span>
280
+ <button class="btn btn-xs btn-ghost btn-danger" onclick="event.stopPropagation(); removeMember('${selectedCluster.id}', '${member.session_id}')" title="${t('common.delete')}">
281
+ <i data-lucide="trash-2"></i>
282
+ </button>
283
+ </div>
284
+ </div>
285
+ </div>
286
+ `}).join('')}
287
+ </div>
288
+ `;
289
+ }
290
+
291
+ /**
292
+ * Preview session in modal based on type
293
+ */
294
+ async function previewSession(sessionId, sessionType) {
295
+ try {
296
+ if (sessionType === 'cli_history') {
297
+ // Use CLI history preview modal
298
+ if (typeof showExecutionDetail === 'function') {
299
+ await showExecutionDetail(sessionId);
300
+ } else {
301
+ console.error('showExecutionDetail is not available. Make sure cli-history.js is loaded.');
302
+ showNotification(t('coreMemory.previewError'), 'error');
303
+ }
304
+ } else if (sessionType === 'core_memory') {
305
+ // Use memory preview modal
306
+ await viewMemoryContent(sessionId);
307
+ } else if (sessionType === 'workflow') {
308
+ // Navigate to workflow view for now
309
+ window.location.hash = `#workflow/${sessionId}`;
310
+ } else {
311
+ showNotification(t('coreMemory.unknownSessionType'), 'warning');
312
+ }
313
+ } catch (error) {
314
+ console.error('Failed to preview session:', error);
315
+ showNotification(t('coreMemory.previewError'), 'error');
316
+ }
317
+ }
318
+
319
+ /**
320
+ * Render cluster relations
321
+ */
322
+ function renderRelations(relations) {
323
+ return `
324
+ <div class="relations-list">
325
+ ${relations.map(rel => `
326
+ <div class="relation-item">
327
+ <i data-lucide="arrow-right"></i>
328
+ <span class="relation-type">${rel.relation_type}</span>
329
+ <a href="#" onclick="selectCluster('${rel.target_cluster_id}'); return false;">
330
+ ${rel.target_cluster_id}
331
+ </a>
332
+ </div>
333
+ `).join('')}
334
+ </div>
335
+ `;
336
+ }
337
+
338
+ /**
339
+ * Trigger auto-clustering
340
+ */
341
+ async function triggerAutoClustering(scope = 'recent') {
342
+ try {
343
+ showNotification(t('coreMemory.clusteringInProgress'), 'info');
344
+
345
+ const response = await fetch(`/api/core-memory/clusters/auto?path=${encodeURIComponent(projectPath)}`, {
346
+ method: 'POST',
347
+ headers: { 'Content-Type': 'application/json' },
348
+ body: JSON.stringify({ scope })
349
+ });
350
+
351
+ if (!response.ok) throw new Error(`HTTP ${response.status}`);
352
+
353
+ const result = await response.json();
354
+ showNotification(
355
+ t('coreMemory.clusteringComplete', {
356
+ created: result.clustersCreated,
357
+ sessions: result.sessionsClustered
358
+ }),
359
+ 'success'
360
+ );
361
+
362
+ // Reload clusters
363
+ await loadClusters();
364
+ } catch (error) {
365
+ console.error('Auto-clustering failed:', error);
366
+ showNotification(t('coreMemory.clusteringError'), 'error');
367
+ }
368
+ }
369
+
370
+ /**
371
+ * Create new cluster
372
+ */
373
+ async function createCluster() {
374
+ const name = prompt(t('coreMemory.enterClusterName'));
375
+ if (!name) return;
376
+
377
+ try {
378
+ const response = await fetch(`/api/core-memory/clusters?path=${encodeURIComponent(projectPath)}`, {
379
+ method: 'POST',
380
+ headers: { 'Content-Type': 'application/json' },
381
+ body: JSON.stringify({ name })
382
+ });
383
+
384
+ if (!response.ok) throw new Error(`HTTP ${response.status}`);
385
+
386
+ showNotification(t('coreMemory.clusterCreated'), 'success');
387
+ await loadClusters();
388
+ } catch (error) {
389
+ console.error('Failed to create cluster:', error);
390
+ showNotification(t('coreMemory.clusterCreateError'), 'error');
391
+ }
392
+ }
393
+
394
+ /**
395
+ * Edit cluster (placeholder)
396
+ */
397
+ function editCluster(clusterId) {
398
+ const cluster = selectedCluster;
399
+ if (!cluster) return;
400
+
401
+ const newName = prompt(t('coreMemory.enterClusterName'), cluster.name);
402
+ if (!newName || newName === cluster.name) return;
403
+
404
+ updateCluster(clusterId, { name: newName });
405
+ }
406
+
407
+ /**
408
+ * Update cluster
409
+ */
410
+ async function updateCluster(clusterId, updates) {
411
+ try {
412
+ const response = await fetch(`/api/core-memory/clusters/${clusterId}?path=${encodeURIComponent(projectPath)}`, {
413
+ method: 'PATCH',
414
+ headers: { 'Content-Type': 'application/json' },
415
+ body: JSON.stringify(updates)
416
+ });
417
+
418
+ if (!response.ok) throw new Error(`HTTP ${response.status}`);
419
+
420
+ showNotification(t('coreMemory.clusterUpdated'), 'success');
421
+ await loadClusters();
422
+ if (selectedCluster?.id === clusterId) {
423
+ await selectCluster(clusterId);
424
+ }
425
+ } catch (error) {
426
+ console.error('Failed to update cluster:', error);
427
+ showNotification(t('coreMemory.clusterUpdateError'), 'error');
428
+ }
429
+ }
430
+
431
+ /**
432
+ * Delete cluster
433
+ */
434
+ async function deleteCluster(clusterId) {
435
+ if (!confirm(t('coreMemory.confirmDeleteCluster'))) return;
436
+
437
+ try {
438
+ const response = await fetch(`/api/core-memory/clusters/${clusterId}?path=${encodeURIComponent(projectPath)}`, {
439
+ method: 'DELETE'
440
+ });
441
+
442
+ if (!response.ok) throw new Error(`HTTP ${response.status}`);
443
+
444
+ showNotification(t('coreMemory.clusterDeleted'), 'success');
445
+ selectedCluster = null;
446
+ await loadClusters();
447
+
448
+ // Clear detail view
449
+ const container = document.getElementById('clusterDetailContainer');
450
+ if (container) container.innerHTML = '';
451
+ } catch (error) {
452
+ console.error('Failed to delete cluster:', error);
453
+ showNotification(t('coreMemory.clusterDeleteError'), 'error');
454
+ }
455
+ }
456
+
457
+ /**
458
+ * Remove member from cluster
459
+ */
460
+ async function removeMember(clusterId, sessionId) {
461
+ try {
462
+ const response = await fetch(
463
+ `/api/core-memory/clusters/${clusterId}/members/${sessionId}?path=${encodeURIComponent(projectPath)}`,
464
+ { method: 'DELETE' }
465
+ );
466
+
467
+ if (!response.ok) throw new Error(`HTTP ${response.status}`);
468
+
469
+ showNotification(t('coreMemory.memberRemoved'), 'success');
470
+ await selectCluster(clusterId); // Refresh detail
471
+ } catch (error) {
472
+ console.error('Failed to remove member:', error);
473
+ showNotification(t('coreMemory.memberRemoveError'), 'error');
474
+ }
475
+ }
476
+
477
+ /**
478
+ * View memory content in modal
479
+ * Requires: viewMemoryDetail from core-memory.js
480
+ */
481
+ async function viewMemoryContent(memoryId) {
482
+ try {
483
+ // Check if required functions exist (from core-memory.js)
484
+ if (typeof viewMemoryDetail === 'function') {
485
+ await viewMemoryDetail(memoryId);
486
+ } else {
487
+ console.error('viewMemoryDetail is not available. Make sure core-memory.js is loaded.');
488
+ showNotification(t('coreMemory.fetchError'), 'error');
489
+ }
490
+ } catch (error) {
491
+ console.error('Failed to load memory content:', error);
492
+ showNotification(t('coreMemory.fetchError'), 'error');
493
+ }
494
+ }
495
+
496
+ /**
497
+ * Format date for display
498
+ */
499
+ function formatDate(dateStr) {
500
+ if (!dateStr) return '';
501
+ const date = new Date(dateStr);
502
+ return date.toLocaleDateString();
503
+ }