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,978 @@
1
+ // CLI Status Component
2
+ // Displays CLI tool availability status and allows setting default tool
3
+
4
+ // ========== CLI State ==========
5
+ let cliToolStatus = { gemini: {}, qwen: {}, codex: {}, claude: {} };
6
+ let codexLensStatus = { ready: false };
7
+ let semanticStatus = { available: false };
8
+ let defaultCliTool = 'gemini';
9
+ let promptConcatFormat = localStorage.getItem('ccw-prompt-format') || 'plain'; // plain, yaml, json
10
+
11
+ // Smart Context settings
12
+ let smartContextEnabled = localStorage.getItem('ccw-smart-context') === 'true';
13
+ let smartContextMaxFiles = parseInt(localStorage.getItem('ccw-smart-context-max-files') || '10', 10);
14
+
15
+ // Native Resume settings
16
+ let nativeResumeEnabled = localStorage.getItem('ccw-native-resume') !== 'false'; // default true
17
+
18
+ // Recursive Query settings (for hierarchical storage aggregation)
19
+ let recursiveQueryEnabled = localStorage.getItem('ccw-recursive-query') !== 'false'; // default true
20
+
21
+ // ========== Initialization ==========
22
+ function initCliStatus() {
23
+ // Load all statuses in one call using aggregated endpoint
24
+ loadAllStatuses();
25
+ }
26
+
27
+ // ========== Data Loading ==========
28
+ /**
29
+ * Load all statuses using aggregated endpoint (single API call)
30
+ */
31
+ async function loadAllStatuses() {
32
+ try {
33
+ const response = await fetch('/api/status/all');
34
+ if (!response.ok) throw new Error('Failed to load status');
35
+ const data = await response.json();
36
+
37
+ // Update all status data
38
+ cliToolStatus = data.cli || { gemini: {}, qwen: {}, codex: {}, claude: {} };
39
+ codexLensStatus = data.codexLens || { ready: false };
40
+ semanticStatus = data.semantic || { available: false };
41
+
42
+ // Update badges
43
+ updateCliBadge();
44
+ updateCodexLensBadge();
45
+
46
+ return data;
47
+ } catch (err) {
48
+ console.error('Failed to load aggregated status:', err);
49
+ // Fallback to individual calls if aggregated endpoint fails
50
+ return await loadAllStatusesFallback();
51
+ }
52
+ }
53
+
54
+ /**
55
+ * Fallback: Load statuses individually if aggregated endpoint fails
56
+ */
57
+ async function loadAllStatusesFallback() {
58
+ console.warn('[CLI Status] Using fallback individual API calls');
59
+ await Promise.all([
60
+ loadCliToolStatus(),
61
+ loadCodexLensStatus()
62
+ ]);
63
+ }
64
+
65
+ /**
66
+ * Legacy: Load CLI tool status individually
67
+ */
68
+ async function loadCliToolStatus() {
69
+ try {
70
+ const response = await fetch('/api/cli/status');
71
+ if (!response.ok) throw new Error('Failed to load CLI status');
72
+ const data = await response.json();
73
+ cliToolStatus = data;
74
+
75
+ // Update badge
76
+ updateCliBadge();
77
+
78
+ return data;
79
+ } catch (err) {
80
+ console.error('Failed to load CLI status:', err);
81
+ return null;
82
+ }
83
+ }
84
+
85
+ /**
86
+ * Legacy: Load CodexLens status individually
87
+ */
88
+ async function loadCodexLensStatus() {
89
+ try {
90
+ const response = await fetch('/api/codexlens/status');
91
+ if (!response.ok) throw new Error('Failed to load CodexLens status');
92
+ const data = await response.json();
93
+ codexLensStatus = data;
94
+
95
+ // Expose to window for other modules (e.g., codexlens-manager.js)
96
+ if (!window.cliToolsStatus) {
97
+ window.cliToolsStatus = {};
98
+ }
99
+ window.cliToolsStatus.codexlens = {
100
+ installed: data.ready || false,
101
+ version: data.version || null
102
+ };
103
+
104
+ // Update CodexLens badge
105
+ updateCodexLensBadge();
106
+
107
+ // If CodexLens is ready, also check semantic status
108
+ if (data.ready) {
109
+ await loadSemanticStatus();
110
+ }
111
+
112
+ return data;
113
+ } catch (err) {
114
+ console.error('Failed to load CodexLens status:', err);
115
+ return null;
116
+ }
117
+ }
118
+
119
+ /**
120
+ * Legacy: Load semantic status individually
121
+ */
122
+ async function loadSemanticStatus() {
123
+ try {
124
+ const response = await fetch('/api/codexlens/semantic/status');
125
+ if (!response.ok) throw new Error('Failed to load semantic status');
126
+ const data = await response.json();
127
+ semanticStatus = data;
128
+ return data;
129
+ } catch (err) {
130
+ console.error('Failed to load semantic status:', err);
131
+ return null;
132
+ }
133
+ }
134
+
135
+ // ========== Badge Update ==========
136
+ function updateCliBadge() {
137
+ const badge = document.getElementById('badgeCliTools');
138
+ if (badge) {
139
+ const available = Object.values(cliToolStatus).filter(t => t.available).length;
140
+ const total = Object.keys(cliToolStatus).length;
141
+ badge.textContent = `${available}/${total}`;
142
+ badge.classList.toggle('text-success', available === total);
143
+ badge.classList.toggle('text-warning', available > 0 && available < total);
144
+ badge.classList.toggle('text-destructive', available === 0);
145
+ }
146
+ }
147
+
148
+ function updateCodexLensBadge() {
149
+ const badge = document.getElementById('badgeCodexLens');
150
+ if (badge) {
151
+ badge.textContent = codexLensStatus.ready ? 'Ready' : 'Not Installed';
152
+ badge.classList.toggle('text-success', codexLensStatus.ready);
153
+ badge.classList.toggle('text-muted-foreground', !codexLensStatus.ready);
154
+ }
155
+ }
156
+
157
+ // ========== Rendering ==========
158
+ function renderCliStatus() {
159
+ const container = document.getElementById('cli-status-panel');
160
+ if (!container) return;
161
+
162
+ const toolDescriptions = {
163
+ gemini: 'Google AI for code analysis',
164
+ qwen: 'Alibaba AI assistant',
165
+ codex: 'OpenAI code generation',
166
+ claude: 'Anthropic AI assistant'
167
+ };
168
+
169
+ const toolIcons = {
170
+ gemini: 'sparkle',
171
+ qwen: 'bot',
172
+ codex: 'code-2',
173
+ claude: 'brain'
174
+ };
175
+
176
+ const tools = ['gemini', 'qwen', 'codex', 'claude'];
177
+
178
+ const toolsHtml = tools.map(tool => {
179
+ const status = cliToolStatus[tool] || {};
180
+ const isAvailable = status.available;
181
+ const isDefault = defaultCliTool === tool;
182
+
183
+ return `
184
+ <div class="cli-tool-card tool-${tool} ${isAvailable ? 'available' : 'unavailable'}">
185
+ <div class="cli-tool-header">
186
+ <span class="cli-tool-status ${isAvailable ? 'status-available' : 'status-unavailable'}"></span>
187
+ <span class="cli-tool-name">${tool.charAt(0).toUpperCase() + tool.slice(1)}</span>
188
+ ${isDefault ? '<span class="cli-tool-badge">Default</span>' : ''}
189
+ </div>
190
+ <div class="cli-tool-desc text-xs text-muted-foreground mt-1">
191
+ ${toolDescriptions[tool]}
192
+ </div>
193
+ <div class="cli-tool-info mt-2">
194
+ ${isAvailable
195
+ ? `<span class="text-success flex items-center gap-1"><i data-lucide="check-circle" class="w-3 h-3"></i> Ready</span>`
196
+ : `<span class="text-muted-foreground flex items-center gap-1"><i data-lucide="circle-dashed" class="w-3 h-3"></i> Not Installed</span>`
197
+ }
198
+ </div>
199
+ <div class="cli-tool-actions mt-3">
200
+ ${isAvailable && !isDefault
201
+ ? `<button class="btn-sm btn-outline flex items-center gap-1" onclick="setDefaultCliTool('${tool}')">
202
+ <i data-lucide="star" class="w-3 h-3"></i> Set Default
203
+ </button>`
204
+ : ''
205
+ }
206
+ </div>
207
+ </div>
208
+ `;
209
+ }).join('');
210
+
211
+ // CodexLens card with semantic search info
212
+ const codexLensHtml = `
213
+ <div class="cli-tool-card tool-codexlens ${codexLensStatus.ready ? 'available' : 'unavailable'}">
214
+ <div class="cli-tool-header">
215
+ <span class="cli-tool-status ${codexLensStatus.ready ? 'status-available' : 'status-unavailable'}"></span>
216
+ <span class="cli-tool-name">CodexLens</span>
217
+ <span class="badge px-1.5 py-0.5 text-xs rounded bg-muted text-muted-foreground">Index</span>
218
+ </div>
219
+ <div class="cli-tool-desc text-xs text-muted-foreground mt-1">
220
+ ${codexLensStatus.ready ? 'Code indexing & FTS search' : 'Full-text code search engine'}
221
+ </div>
222
+ <div class="cli-tool-info mt-2">
223
+ ${codexLensStatus.ready
224
+ ? `<span class="text-success flex items-center gap-1"><i data-lucide="check-circle" class="w-3 h-3"></i> v${codexLensStatus.version || 'installed'}</span>`
225
+ : `<span class="text-muted-foreground flex items-center gap-1"><i data-lucide="circle-dashed" class="w-3 h-3"></i> Not Installed</span>`
226
+ }
227
+ </div>
228
+ <div class="cli-tool-actions flex gap-2 mt-3">
229
+ ${!codexLensStatus.ready
230
+ ? `<button class="btn-sm btn-primary flex items-center gap-1" onclick="installCodexLens()">
231
+ <i data-lucide="download" class="w-3 h-3"></i> Install
232
+ </button>`
233
+ : `<button class="btn-sm btn-outline flex items-center gap-1" onclick="initCodexLensIndex()">
234
+ <i data-lucide="database" class="w-3 h-3"></i> Init Index
235
+ </button>
236
+ <button class="btn-sm btn-outline flex items-center gap-1" onclick="uninstallCodexLens()">
237
+ <i data-lucide="trash-2" class="w-3 h-3"></i> Uninstall
238
+ </button>`
239
+ }
240
+ </div>
241
+ </div>
242
+ `;
243
+
244
+ // Semantic Search card (only show if CodexLens is installed)
245
+ const semanticHtml = codexLensStatus.ready ? `
246
+ <div class="cli-tool-card tool-semantic ${semanticStatus.available ? 'available' : 'unavailable'}">
247
+ <div class="cli-tool-header">
248
+ <span class="cli-tool-status ${semanticStatus.available ? 'status-available' : 'status-unavailable'}"></span>
249
+ <span class="cli-tool-name">Semantic Search</span>
250
+ <span class="badge px-1.5 py-0.5 text-xs rounded ${semanticStatus.available ? 'bg-primary/20 text-primary' : 'bg-muted text-muted-foreground'}">AI</span>
251
+ </div>
252
+ <div class="cli-tool-desc text-xs text-muted-foreground mt-1">
253
+ ${semanticStatus.available ? 'AI-powered code understanding' : 'Natural language code search'}
254
+ </div>
255
+ <div class="cli-tool-info mt-2">
256
+ ${semanticStatus.available
257
+ ? `<span class="text-success flex items-center gap-1"><i data-lucide="sparkles" class="w-3 h-3"></i> ${semanticStatus.backend || 'Ready'}</span>`
258
+ : `<span class="text-muted-foreground flex items-center gap-1"><i data-lucide="circle-dashed" class="w-3 h-3"></i> Not Installed</span>`
259
+ }
260
+ </div>
261
+ <div class="cli-tool-actions flex flex-col gap-2 mt-3">
262
+ ${!semanticStatus.available ? `
263
+ <button class="btn-sm btn-primary w-full flex items-center justify-center gap-1" onclick="openSemanticInstallWizard()">
264
+ <i data-lucide="brain" class="w-3 h-3"></i> Install AI Model
265
+ </button>
266
+ <div class="flex items-center gap-1 text-xs text-muted-foreground mt-1">
267
+ <i data-lucide="hard-drive" class="w-3 h-3"></i>
268
+ <span>~130MB</span>
269
+ </div>
270
+ ` : `
271
+ <div class="flex items-center gap-1 text-xs text-muted-foreground">
272
+ <i data-lucide="cpu" class="w-3 h-3"></i>
273
+ <span>bge-small-en-v1.5</span>
274
+ </div>
275
+ `}
276
+ </div>
277
+ </div>
278
+ ` : '';
279
+
280
+ // CLI Settings section
281
+ const settingsHtml = `
282
+ <div class="cli-settings-section">
283
+ <div class="cli-settings-header">
284
+ <h4><i data-lucide="settings" class="w-3.5 h-3.5"></i> Settings</h4>
285
+ </div>
286
+ <div class="cli-settings-grid">
287
+ <div class="cli-setting-item">
288
+ <label class="cli-setting-label">
289
+ <i data-lucide="layers" class="w-3 h-3"></i>
290
+ Prompt Format
291
+ </label>
292
+ <div class="cli-setting-control">
293
+ <select class="cli-setting-select" onchange="setPromptFormat(this.value)">
294
+ <option value="plain" ${promptConcatFormat === 'plain' ? 'selected' : ''}>Plain Text</option>
295
+ <option value="yaml" ${promptConcatFormat === 'yaml' ? 'selected' : ''}>YAML</option>
296
+ <option value="json" ${promptConcatFormat === 'json' ? 'selected' : ''}>JSON</option>
297
+ </select>
298
+ </div>
299
+ <p class="cli-setting-desc">Format for multi-turn conversation concatenation</p>
300
+ </div>
301
+ <div class="cli-setting-item">
302
+ <label class="cli-setting-label">
303
+ <i data-lucide="database" class="w-3 h-3"></i>
304
+ Storage Backend
305
+ </label>
306
+ <div class="cli-setting-control">
307
+ <span class="cli-setting-value">SQLite</span>
308
+ </div>
309
+ <p class="cli-setting-desc">CLI history stored in SQLite with FTS search</p>
310
+ </div>
311
+ <div class="cli-setting-item">
312
+ <label class="cli-setting-label">
313
+ <i data-lucide="sparkles" class="w-3 h-3"></i>
314
+ Smart Context
315
+ </label>
316
+ <div class="cli-setting-control">
317
+ <label class="cli-toggle">
318
+ <input type="checkbox" ${smartContextEnabled ? 'checked' : ''} onchange="setSmartContextEnabled(this.checked)">
319
+ <span class="cli-toggle-slider"></span>
320
+ </label>
321
+ </div>
322
+ <p class="cli-setting-desc">Auto-analyze prompt and add relevant file paths</p>
323
+ </div>
324
+ <div class="cli-setting-item">
325
+ <label class="cli-setting-label">
326
+ <i data-lucide="refresh-cw" class="w-3 h-3"></i>
327
+ Native Resume
328
+ </label>
329
+ <div class="cli-setting-control">
330
+ <label class="cli-toggle">
331
+ <input type="checkbox" ${nativeResumeEnabled ? 'checked' : ''} onchange="setNativeResumeEnabled(this.checked)">
332
+ <span class="cli-toggle-slider"></span>
333
+ </label>
334
+ </div>
335
+ <p class="cli-setting-desc">Use native tool resume (gemini -r, qwen --resume, codex resume, claude --resume)</p>
336
+ </div>
337
+ <div class="cli-setting-item ${!smartContextEnabled ? 'disabled' : ''}">
338
+ <label class="cli-setting-label">
339
+ <i data-lucide="files" class="w-3 h-3"></i>
340
+ Max Context Files
341
+ </label>
342
+ <div class="cli-setting-control">
343
+ <select class="cli-setting-select" onchange="setSmartContextMaxFiles(this.value)" ${!smartContextEnabled ? 'disabled' : ''}>
344
+ <option value="5" ${smartContextMaxFiles === 5 ? 'selected' : ''}>5 files</option>
345
+ <option value="10" ${smartContextMaxFiles === 10 ? 'selected' : ''}>10 files</option>
346
+ <option value="20" ${smartContextMaxFiles === 20 ? 'selected' : ''}>20 files</option>
347
+ </select>
348
+ </div>
349
+ <p class="cli-setting-desc">Maximum files to include in smart context</p>
350
+ </div>
351
+ </div>
352
+ </div>
353
+ `;
354
+
355
+ container.innerHTML = `
356
+ <div class="cli-status-header">
357
+ <h3><i data-lucide="terminal" class="w-4 h-4"></i> CLI Tools</h3>
358
+ <button class="btn-icon" onclick="refreshAllCliStatus()" title="Refresh">
359
+ <i data-lucide="refresh-cw" class="w-4 h-4"></i>
360
+ </button>
361
+ </div>
362
+ <div class="cli-tools-grid">
363
+ ${toolsHtml}
364
+ ${codexLensHtml}
365
+ ${semanticHtml}
366
+ </div>
367
+ ${settingsHtml}
368
+ `;
369
+
370
+ // Initialize Lucide icons
371
+ if (window.lucide) {
372
+ lucide.createIcons();
373
+ }
374
+ }
375
+
376
+ // ========== Actions ==========
377
+ function setDefaultCliTool(tool) {
378
+ defaultCliTool = tool;
379
+ renderCliStatus();
380
+ showRefreshToast(`Default CLI tool set to ${tool}`, 'success');
381
+ }
382
+
383
+ function setPromptFormat(format) {
384
+ promptConcatFormat = format;
385
+ localStorage.setItem('ccw-prompt-format', format);
386
+ showRefreshToast(`Prompt format set to ${format.toUpperCase()}`, 'success');
387
+ }
388
+
389
+ function setSmartContextEnabled(enabled) {
390
+ smartContextEnabled = enabled;
391
+ localStorage.setItem('ccw-smart-context', enabled.toString());
392
+ // Re-render the appropriate settings panel
393
+ if (typeof renderCliSettingsSection === 'function') {
394
+ renderCliSettingsSection();
395
+ } else {
396
+ renderCliStatus();
397
+ }
398
+ showRefreshToast(`Smart Context ${enabled ? 'enabled' : 'disabled'}`, 'success');
399
+ }
400
+
401
+ function setSmartContextMaxFiles(max) {
402
+ smartContextMaxFiles = parseInt(max, 10);
403
+ localStorage.setItem('ccw-smart-context-max-files', max);
404
+ showRefreshToast(`Smart Context max files set to ${max}`, 'success');
405
+ }
406
+
407
+ function setNativeResumeEnabled(enabled) {
408
+ nativeResumeEnabled = enabled;
409
+ localStorage.setItem('ccw-native-resume', enabled.toString());
410
+ showRefreshToast(`Native Resume ${enabled ? 'enabled' : 'disabled'}`, 'success');
411
+ }
412
+
413
+ function setRecursiveQueryEnabled(enabled) {
414
+ recursiveQueryEnabled = enabled;
415
+ localStorage.setItem('ccw-recursive-query', enabled.toString());
416
+ showRefreshToast(`Recursive Query ${enabled ? 'enabled' : 'disabled'}`, 'success');
417
+ }
418
+
419
+ async function refreshAllCliStatus() {
420
+ await loadAllStatuses();
421
+ renderCliStatus();
422
+ }
423
+
424
+ function installCodexLens() {
425
+ openCodexLensInstallWizard();
426
+ }
427
+
428
+ function openCodexLensInstallWizard() {
429
+ const modal = document.createElement('div');
430
+ modal.id = 'codexlensInstallModal';
431
+ modal.className = 'fixed inset-0 bg-black/50 flex items-center justify-center z-50';
432
+ modal.innerHTML = `
433
+ <div class="bg-card rounded-lg shadow-xl w-full max-w-md mx-4 overflow-hidden">
434
+ <div class="p-6">
435
+ <div class="flex items-center gap-3 mb-4">
436
+ <div class="w-10 h-10 rounded-full bg-primary/10 flex items-center justify-center">
437
+ <i data-lucide="database" class="w-5 h-5 text-primary"></i>
438
+ </div>
439
+ <div>
440
+ <h3 class="text-lg font-semibold">Install CodexLens</h3>
441
+ <p class="text-sm text-muted-foreground">Python-based code indexing engine</p>
442
+ </div>
443
+ </div>
444
+
445
+ <div class="space-y-4">
446
+ <div class="bg-muted/50 rounded-lg p-4">
447
+ <h4 class="font-medium mb-2">What will be installed:</h4>
448
+ <ul class="text-sm space-y-2 text-muted-foreground">
449
+ <li class="flex items-start gap-2">
450
+ <i data-lucide="check" class="w-4 h-4 text-success mt-0.5"></i>
451
+ <span><strong>Python virtual environment</strong> - Isolated Python environment</span>
452
+ </li>
453
+ <li class="flex items-start gap-2">
454
+ <i data-lucide="check" class="w-4 h-4 text-success mt-0.5"></i>
455
+ <span><strong>CodexLens package</strong> - Code indexing and search engine</span>
456
+ </li>
457
+ <li class="flex items-start gap-2">
458
+ <i data-lucide="check" class="w-4 h-4 text-success mt-0.5"></i>
459
+ <span><strong>SQLite FTS5</strong> - Full-text search database</span>
460
+ </li>
461
+ </ul>
462
+ </div>
463
+
464
+ <div class="bg-primary/5 border border-primary/20 rounded-lg p-3">
465
+ <div class="flex items-start gap-2">
466
+ <i data-lucide="info" class="w-4 h-4 text-primary mt-0.5"></i>
467
+ <div class="text-sm text-muted-foreground">
468
+ <p class="font-medium text-foreground">Installation Location</p>
469
+ <p class="mt-1"><code class="bg-muted px-1 rounded">~/.codexlens/venv</code></p>
470
+ <p class="mt-1">First installation may take 2-3 minutes to download and setup Python packages.</p>
471
+ </div>
472
+ </div>
473
+ </div>
474
+
475
+ <div id="codexlensInstallProgress" class="hidden">
476
+ <div class="flex items-center gap-3">
477
+ <div class="animate-spin w-5 h-5 border-2 border-primary border-t-transparent rounded-full"></div>
478
+ <span class="text-sm" id="codexlensInstallStatus">Starting installation...</span>
479
+ </div>
480
+ <div class="mt-2 h-2 bg-muted rounded-full overflow-hidden">
481
+ <div id="codexlensProgressBar" class="h-full bg-primary transition-all duration-300" style="width: 0%"></div>
482
+ </div>
483
+ </div>
484
+ </div>
485
+ </div>
486
+
487
+ <div class="border-t border-border p-4 flex justify-end gap-3 bg-muted/30">
488
+ <button class="btn-outline px-4 py-2" onclick="closeCodexLensInstallWizard()">Cancel</button>
489
+ <button id="codexlensInstallBtn" class="btn-primary px-4 py-2" onclick="startCodexLensInstall()">
490
+ <i data-lucide="download" class="w-4 h-4 mr-2"></i>
491
+ Install Now
492
+ </button>
493
+ </div>
494
+ </div>
495
+ `;
496
+
497
+ document.body.appendChild(modal);
498
+
499
+ if (window.lucide) {
500
+ lucide.createIcons();
501
+ }
502
+ }
503
+
504
+ function closeCodexLensInstallWizard() {
505
+ const modal = document.getElementById('codexlensInstallModal');
506
+ if (modal) {
507
+ modal.remove();
508
+ }
509
+ }
510
+
511
+ async function startCodexLensInstall() {
512
+ const progressDiv = document.getElementById('codexlensInstallProgress');
513
+ const installBtn = document.getElementById('codexlensInstallBtn');
514
+ const statusText = document.getElementById('codexlensInstallStatus');
515
+ const progressBar = document.getElementById('codexlensProgressBar');
516
+
517
+ // Show progress, disable button
518
+ progressDiv.classList.remove('hidden');
519
+ installBtn.disabled = true;
520
+ installBtn.innerHTML = '<span class="animate-pulse">Installing...</span>';
521
+
522
+ // Simulate progress stages
523
+ const stages = [
524
+ { progress: 10, text: 'Creating virtual environment...' },
525
+ { progress: 30, text: 'Installing pip packages...' },
526
+ { progress: 50, text: 'Installing CodexLens package...' },
527
+ { progress: 70, text: 'Setting up Python dependencies...' },
528
+ { progress: 90, text: 'Finalizing installation...' }
529
+ ];
530
+
531
+ let currentStage = 0;
532
+ const progressInterval = setInterval(() => {
533
+ if (currentStage < stages.length) {
534
+ statusText.textContent = stages[currentStage].text;
535
+ progressBar.style.width = `${stages[currentStage].progress}%`;
536
+ currentStage++;
537
+ }
538
+ }, 1500);
539
+
540
+ try {
541
+ const response = await fetch('/api/codexlens/bootstrap', {
542
+ method: 'POST',
543
+ headers: { 'Content-Type': 'application/json' },
544
+ body: JSON.stringify({})
545
+ });
546
+
547
+ clearInterval(progressInterval);
548
+ const result = await response.json();
549
+
550
+ if (result.success) {
551
+ progressBar.style.width = '100%';
552
+ statusText.textContent = 'Installation complete!';
553
+
554
+ setTimeout(() => {
555
+ closeCodexLensInstallWizard();
556
+ showRefreshToast('CodexLens installed successfully!', 'success');
557
+ loadCodexLensStatus().then(() => renderCliStatus());
558
+ }, 1000);
559
+ } else {
560
+ statusText.textContent = `Error: ${result.error}`;
561
+ progressBar.classList.add('bg-destructive');
562
+ installBtn.disabled = false;
563
+ installBtn.innerHTML = '<i data-lucide="refresh-cw" class="w-4 h-4 mr-2"></i> Retry';
564
+ if (window.lucide) lucide.createIcons();
565
+ }
566
+ } catch (err) {
567
+ clearInterval(progressInterval);
568
+ statusText.textContent = `Error: ${err.message}`;
569
+ progressBar.classList.add('bg-destructive');
570
+ installBtn.disabled = false;
571
+ installBtn.innerHTML = '<i data-lucide="refresh-cw" class="w-4 h-4 mr-2"></i> Retry';
572
+ if (window.lucide) lucide.createIcons();
573
+ }
574
+ }
575
+
576
+ function uninstallCodexLens() {
577
+ openCodexLensUninstallWizard();
578
+ }
579
+
580
+ function openCodexLensUninstallWizard() {
581
+ const modal = document.createElement('div');
582
+ modal.id = 'codexlensUninstallModal';
583
+ modal.className = 'fixed inset-0 bg-black/50 flex items-center justify-center z-50';
584
+ modal.innerHTML = `
585
+ <div class="bg-card rounded-lg shadow-xl w-full max-w-md mx-4 overflow-hidden">
586
+ <div class="p-6">
587
+ <div class="flex items-center gap-3 mb-4">
588
+ <div class="w-10 h-10 rounded-full bg-destructive/10 flex items-center justify-center">
589
+ <i data-lucide="trash-2" class="w-5 h-5 text-destructive"></i>
590
+ </div>
591
+ <div>
592
+ <h3 class="text-lg font-semibold">Uninstall CodexLens</h3>
593
+ <p class="text-sm text-muted-foreground">Remove CodexLens and all data</p>
594
+ </div>
595
+ </div>
596
+
597
+ <div class="space-y-4">
598
+ <div class="bg-destructive/5 border border-destructive/20 rounded-lg p-4">
599
+ <h4 class="font-medium text-destructive mb-2">What will be removed:</h4>
600
+ <ul class="text-sm space-y-2 text-muted-foreground">
601
+ <li class="flex items-start gap-2">
602
+ <i data-lucide="x" class="w-4 h-4 text-destructive mt-0.5"></i>
603
+ <span>Virtual environment at <code class="bg-muted px-1 rounded">~/.codexlens/venv</code></span>
604
+ </li>
605
+ <li class="flex items-start gap-2">
606
+ <i data-lucide="x" class="w-4 h-4 text-destructive mt-0.5"></i>
607
+ <span>All CodexLens indexed data and databases</span>
608
+ </li>
609
+ <li class="flex items-start gap-2">
610
+ <i data-lucide="x" class="w-4 h-4 text-destructive mt-0.5"></i>
611
+ <span>Configuration and semantic search models</span>
612
+ </li>
613
+ </ul>
614
+ </div>
615
+
616
+ <div class="bg-warning/10 border border-warning/20 rounded-lg p-3">
617
+ <div class="flex items-start gap-2">
618
+ <i data-lucide="alert-triangle" class="w-4 h-4 text-warning mt-0.5"></i>
619
+ <div class="text-sm">
620
+ <p class="font-medium text-warning">Warning</p>
621
+ <p class="text-muted-foreground">This action cannot be undone. All indexed code data will be permanently deleted.</p>
622
+ </div>
623
+ </div>
624
+ </div>
625
+
626
+ <div id="codexlensUninstallProgress" class="hidden">
627
+ <div class="flex items-center gap-3">
628
+ <div class="animate-spin w-5 h-5 border-2 border-destructive border-t-transparent rounded-full"></div>
629
+ <span class="text-sm" id="codexlensUninstallStatus">Removing files...</span>
630
+ </div>
631
+ <div class="mt-2 h-2 bg-muted rounded-full overflow-hidden">
632
+ <div id="codexlensUninstallProgressBar" class="h-full bg-destructive transition-all duration-300" style="width: 0%"></div>
633
+ </div>
634
+ </div>
635
+ </div>
636
+ </div>
637
+
638
+ <div class="border-t border-border p-4 flex justify-end gap-3 bg-muted/30">
639
+ <button class="btn-outline px-4 py-2" onclick="closeCodexLensUninstallWizard()">Cancel</button>
640
+ <button id="codexlensUninstallBtn" class="btn-destructive px-4 py-2" onclick="startCodexLensUninstall()">
641
+ <i data-lucide="trash-2" class="w-4 h-4 mr-2"></i>
642
+ Uninstall
643
+ </button>
644
+ </div>
645
+ </div>
646
+ `;
647
+
648
+ document.body.appendChild(modal);
649
+
650
+ if (window.lucide) {
651
+ lucide.createIcons();
652
+ }
653
+ }
654
+
655
+ function closeCodexLensUninstallWizard() {
656
+ const modal = document.getElementById('codexlensUninstallModal');
657
+ if (modal) {
658
+ modal.remove();
659
+ }
660
+ }
661
+
662
+ async function startCodexLensUninstall() {
663
+ const progressDiv = document.getElementById('codexlensUninstallProgress');
664
+ const uninstallBtn = document.getElementById('codexlensUninstallBtn');
665
+ const statusText = document.getElementById('codexlensUninstallStatus');
666
+ const progressBar = document.getElementById('codexlensUninstallProgressBar');
667
+
668
+ // Show progress, disable button
669
+ progressDiv.classList.remove('hidden');
670
+ uninstallBtn.disabled = true;
671
+ uninstallBtn.innerHTML = '<span class="animate-pulse">Uninstalling...</span>';
672
+
673
+ // Simulate progress stages
674
+ const stages = [
675
+ { progress: 25, text: 'Removing virtual environment...' },
676
+ { progress: 50, text: 'Deleting indexed data...' },
677
+ { progress: 75, text: 'Cleaning up configuration...' },
678
+ { progress: 90, text: 'Finalizing removal...' }
679
+ ];
680
+
681
+ let currentStage = 0;
682
+ const progressInterval = setInterval(() => {
683
+ if (currentStage < stages.length) {
684
+ statusText.textContent = stages[currentStage].text;
685
+ progressBar.style.width = `${stages[currentStage].progress}%`;
686
+ currentStage++;
687
+ }
688
+ }, 500);
689
+
690
+ try {
691
+ const response = await fetch('/api/codexlens/uninstall', {
692
+ method: 'POST',
693
+ headers: { 'Content-Type': 'application/json' },
694
+ body: JSON.stringify({})
695
+ });
696
+
697
+ clearInterval(progressInterval);
698
+ const result = await response.json();
699
+
700
+ if (result.success) {
701
+ progressBar.style.width = '100%';
702
+ statusText.textContent = 'Uninstallation complete!';
703
+
704
+ setTimeout(() => {
705
+ closeCodexLensUninstallWizard();
706
+ showRefreshToast('CodexLens uninstalled successfully!', 'success');
707
+ loadCodexLensStatus().then(() => renderCliStatus());
708
+ }, 1000);
709
+ } else {
710
+ statusText.textContent = `Error: ${result.error}`;
711
+ progressBar.classList.remove('bg-destructive');
712
+ progressBar.classList.add('bg-destructive');
713
+ uninstallBtn.disabled = false;
714
+ uninstallBtn.innerHTML = '<i data-lucide="refresh-cw" class="w-4 h-4 mr-2"></i> Retry';
715
+ if (window.lucide) lucide.createIcons();
716
+ }
717
+ } catch (err) {
718
+ clearInterval(progressInterval);
719
+ statusText.textContent = `Error: ${err.message}`;
720
+ progressBar.classList.remove('bg-destructive');
721
+ progressBar.classList.add('bg-destructive');
722
+ uninstallBtn.disabled = false;
723
+ uninstallBtn.innerHTML = '<i data-lucide="refresh-cw" class="w-4 h-4 mr-2"></i> Retry';
724
+ if (window.lucide) lucide.createIcons();
725
+ }
726
+ }
727
+
728
+ async function initCodexLensIndex() {
729
+ // Get current workspace path from multiple sources
730
+ let targetPath = null;
731
+
732
+ // Helper function to check if path is valid
733
+ const isValidPath = (path) => {
734
+ return path && typeof path === 'string' && path.length > 0 &&
735
+ (path.includes('/') || path.includes('\\')) &&
736
+ !path.startsWith('{{') && !path.endsWith('}}');
737
+ };
738
+
739
+ console.log('[CodexLens] Attempting to get project path...');
740
+
741
+ // Try 1: Global projectPath variable
742
+ if (isValidPath(projectPath)) {
743
+ targetPath = projectPath;
744
+ console.log('[CodexLens] ✓ Using global projectPath:', targetPath);
745
+ }
746
+
747
+ // Try 2: Get from workflowData
748
+ if (!targetPath && typeof workflowData !== 'undefined' && workflowData && isValidPath(workflowData.projectPath)) {
749
+ targetPath = workflowData.projectPath;
750
+ console.log('[CodexLens] ✓ Using workflowData.projectPath:', targetPath);
751
+ }
752
+
753
+ // Try 3: Get from current path display element
754
+ if (!targetPath) {
755
+ const currentPathEl = document.getElementById('currentPath');
756
+ if (currentPathEl && currentPathEl.textContent) {
757
+ const pathText = currentPathEl.textContent.trim();
758
+ if (isValidPath(pathText)) {
759
+ targetPath = pathText;
760
+ console.log('[CodexLens] ✓ Using currentPath element text:', targetPath);
761
+ }
762
+ }
763
+ }
764
+
765
+ // Final validation
766
+ if (!targetPath) {
767
+ showRefreshToast('Error: No workspace loaded. Please open a workspace first.', 'error');
768
+ console.error('[CodexLens] No valid project path available');
769
+ console.error('[CodexLens] Attempted sources: projectPath:', projectPath, 'workflowData:', workflowData);
770
+ return;
771
+ }
772
+
773
+ showRefreshToast('Initializing CodexLens index...', 'info');
774
+ console.log('[CodexLens] Initializing index for path:', targetPath);
775
+
776
+ try {
777
+ const response = await fetch('/api/codexlens/init', {
778
+ method: 'POST',
779
+ headers: { 'Content-Type': 'application/json' },
780
+ body: JSON.stringify({ path: targetPath })
781
+ });
782
+
783
+ const result = await response.json();
784
+ console.log('[CodexLens] Init result:', result);
785
+
786
+ if (result.success) {
787
+ let data = null;
788
+
789
+ // Try to parse nested JSON in output field
790
+ if (result.output && typeof result.output === 'string') {
791
+ try {
792
+ // Extract JSON from output (it may contain other text before the JSON)
793
+ const jsonMatch = result.output.match(/\{[\s\S]*\}/);
794
+ if (jsonMatch) {
795
+ const parsed = JSON.parse(jsonMatch[0]);
796
+ data = parsed.result || parsed;
797
+ console.log('[CodexLens] Parsed from output:', data);
798
+ }
799
+ } catch (e) {
800
+ console.warn('[CodexLens] Failed to parse output as JSON:', e);
801
+ }
802
+ }
803
+
804
+ // Fallback to direct result field
805
+ if (!data) {
806
+ data = result.result?.result || result.result || result;
807
+ }
808
+
809
+ const files = data.files_indexed || 0;
810
+ const dirs = data.dirs_indexed || 0;
811
+ const symbols = data.symbols_indexed || 0;
812
+
813
+ console.log('[CodexLens] Parsed data:', { files, dirs, symbols });
814
+
815
+ if (files === 0 && dirs === 0) {
816
+ showRefreshToast(`Warning: No files indexed. Path: ${targetPath}`, 'warning');
817
+ console.warn('[CodexLens] No files indexed. Full data:', data);
818
+ } else {
819
+ showRefreshToast(`Index created: ${files} files, ${dirs} directories`, 'success');
820
+ console.log('[CodexLens] Index created successfully');
821
+
822
+ // Reload CodexLens status and refresh the view
823
+ loadCodexLensStatus().then(() => renderCliStatus());
824
+ }
825
+ } else {
826
+ showRefreshToast(`Init failed: ${result.error}`, 'error');
827
+ console.error('[CodexLens] Init error:', result.error);
828
+ }
829
+ } catch (err) {
830
+ showRefreshToast(`Init error: ${err.message}`, 'error');
831
+ console.error('[CodexLens] Exception:', err);
832
+ }
833
+ }
834
+
835
+ // ========== Semantic Search Installation Wizard ==========
836
+ function openSemanticInstallWizard() {
837
+ const modal = document.createElement('div');
838
+ modal.id = 'semanticInstallModal';
839
+ modal.className = 'fixed inset-0 bg-black/50 flex items-center justify-center z-50';
840
+ modal.innerHTML = `
841
+ <div class="bg-card rounded-lg shadow-xl w-full max-w-md mx-4 overflow-hidden">
842
+ <div class="p-6">
843
+ <div class="flex items-center gap-3 mb-4">
844
+ <div class="w-10 h-10 rounded-full bg-primary/10 flex items-center justify-center">
845
+ <i data-lucide="brain" class="w-5 h-5 text-primary"></i>
846
+ </div>
847
+ <div>
848
+ <h3 class="text-lg font-semibold">Install Semantic Search</h3>
849
+ <p class="text-sm text-muted-foreground">AI-powered code understanding</p>
850
+ </div>
851
+ </div>
852
+
853
+ <div class="space-y-4">
854
+ <div class="bg-muted/50 rounded-lg p-4">
855
+ <h4 class="font-medium mb-2">What will be installed:</h4>
856
+ <ul class="text-sm space-y-2 text-muted-foreground">
857
+ <li class="flex items-start gap-2">
858
+ <i data-lucide="check" class="w-4 h-4 text-success mt-0.5"></i>
859
+ <span><strong>sentence-transformers</strong> - ML framework</span>
860
+ </li>
861
+ <li class="flex items-start gap-2">
862
+ <i data-lucide="check" class="w-4 h-4 text-success mt-0.5"></i>
863
+ <span><strong>bge-small-en-v1.5</strong> - Embedding model (~130MB)</span>
864
+ </li>
865
+ </ul>
866
+ </div>
867
+
868
+ <div class="bg-primary/10 border border-primary/20 rounded-lg p-3">
869
+ <div class="flex items-start gap-2">
870
+ <i data-lucide="info" class="w-4 h-4 text-primary mt-0.5"></i>
871
+ <div class="text-sm">
872
+ <p class="font-medium text-primary">Download Size</p>
873
+ <p class="text-muted-foreground">Total size: ~130MB. First-time model loading may take a few minutes.</p>
874
+ </div>
875
+ </div>
876
+ </div>
877
+
878
+ <div id="semanticInstallProgress" class="hidden">
879
+ <div class="flex items-center gap-3">
880
+ <div class="animate-spin w-5 h-5 border-2 border-primary border-t-transparent rounded-full"></div>
881
+ <span class="text-sm" id="semanticInstallStatus">Installing dependencies...</span>
882
+ </div>
883
+ <div class="mt-2 h-2 bg-muted rounded-full overflow-hidden">
884
+ <div id="semanticProgressBar" class="h-full bg-primary transition-all duration-300" style="width: 0%"></div>
885
+ </div>
886
+ </div>
887
+ </div>
888
+ </div>
889
+
890
+ <div class="border-t border-border p-4 flex justify-end gap-3 bg-muted/30">
891
+ <button class="btn-outline px-4 py-2" onclick="closeSemanticInstallWizard()">Cancel</button>
892
+ <button id="semanticInstallBtn" class="btn-primary px-4 py-2" onclick="startSemanticInstall()">
893
+ <i data-lucide="download" class="w-4 h-4 mr-2"></i>
894
+ Install Now
895
+ </button>
896
+ </div>
897
+ </div>
898
+ `;
899
+
900
+ document.body.appendChild(modal);
901
+
902
+ // Initialize Lucide icons in modal
903
+ if (window.lucide) {
904
+ lucide.createIcons();
905
+ }
906
+ }
907
+
908
+ function closeSemanticInstallWizard() {
909
+ const modal = document.getElementById('semanticInstallModal');
910
+ if (modal) {
911
+ modal.remove();
912
+ }
913
+ }
914
+
915
+ async function startSemanticInstall() {
916
+ const progressDiv = document.getElementById('semanticInstallProgress');
917
+ const installBtn = document.getElementById('semanticInstallBtn');
918
+ const statusText = document.getElementById('semanticInstallStatus');
919
+ const progressBar = document.getElementById('semanticProgressBar');
920
+
921
+ // Show progress, disable button
922
+ progressDiv.classList.remove('hidden');
923
+ installBtn.disabled = true;
924
+ installBtn.innerHTML = '<span class="animate-pulse">Installing...</span>';
925
+
926
+ // Simulate progress stages
927
+ const stages = [
928
+ { progress: 20, text: 'Installing sentence-transformers...' },
929
+ { progress: 50, text: 'Downloading embedding model...' },
930
+ { progress: 80, text: 'Setting up model cache...' },
931
+ { progress: 95, text: 'Finalizing installation...' }
932
+ ];
933
+
934
+ let currentStage = 0;
935
+ const progressInterval = setInterval(() => {
936
+ if (currentStage < stages.length) {
937
+ statusText.textContent = stages[currentStage].text;
938
+ progressBar.style.width = `${stages[currentStage].progress}%`;
939
+ currentStage++;
940
+ }
941
+ }, 2000);
942
+
943
+ try {
944
+ const response = await fetch('/api/codexlens/semantic/install', {
945
+ method: 'POST',
946
+ headers: { 'Content-Type': 'application/json' },
947
+ body: JSON.stringify({})
948
+ });
949
+
950
+ clearInterval(progressInterval);
951
+ const result = await response.json();
952
+
953
+ if (result.success) {
954
+ progressBar.style.width = '100%';
955
+ statusText.textContent = 'Installation complete!';
956
+
957
+ setTimeout(() => {
958
+ closeSemanticInstallWizard();
959
+ showRefreshToast('Semantic search installed successfully!', 'success');
960
+ loadSemanticStatus().then(() => renderCliStatus());
961
+ }, 1000);
962
+ } else {
963
+ statusText.textContent = `Error: ${result.error}`;
964
+ progressBar.classList.add('bg-destructive');
965
+ installBtn.disabled = false;
966
+ installBtn.innerHTML = '<i data-lucide="refresh-cw" class="w-4 h-4 mr-2"></i> Retry';
967
+ if (window.lucide) lucide.createIcons();
968
+ }
969
+ } catch (err) {
970
+ clearInterval(progressInterval);
971
+ statusText.textContent = `Error: ${err.message}`;
972
+ progressBar.classList.add('bg-destructive');
973
+ installBtn.disabled = false;
974
+ installBtn.innerHTML = '<i data-lucide="refresh-cw" class="w-4 h-4 mr-2"></i> Retry';
975
+ if (window.lucide) lucide.createIcons();
976
+ }
977
+ }
978
+