claude-code-workflow 6.2.5 → 6.2.6

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 (964) hide show
  1. package/.claude/CLAUDE.md +10 -0
  2. package/.claude/agents/action-planning-agent.md +857 -0
  3. package/.claude/agents/cli-execution-agent.md +267 -0
  4. package/.claude/agents/cli-explore-agent.md +182 -0
  5. package/.claude/agents/cli-lite-planning-agent.md +446 -0
  6. package/.claude/agents/cli-planning-agent.md +558 -0
  7. package/.claude/agents/code-developer.md +311 -0
  8. package/.claude/agents/conceptual-planning-agent.md +308 -0
  9. package/.claude/agents/context-search-agent.md +581 -0
  10. package/.claude/agents/doc-generator.md +330 -0
  11. package/.claude/agents/memory-bridge.md +94 -0
  12. package/.claude/agents/test-context-search-agent.md +400 -0
  13. package/.claude/agents/test-fix-agent.md +344 -0
  14. package/.claude/agents/ui-design-agent.md +593 -0
  15. package/.claude/agents/universal-executor.md +131 -0
  16. package/.claude/commands/clean.md +516 -0
  17. package/.claude/commands/cli/cli-init.md +440 -0
  18. package/.claude/commands/enhance-prompt.md +93 -0
  19. package/.claude/commands/memory/code-map-memory.md +687 -0
  20. package/.claude/commands/memory/compact.md +383 -0
  21. package/.claude/commands/memory/docs-full-cli.md +471 -0
  22. package/.claude/commands/memory/docs-related-cli.md +386 -0
  23. package/.claude/commands/memory/docs.md +615 -0
  24. package/.claude/commands/memory/load-skill-memory.md +182 -0
  25. package/.claude/commands/memory/load.md +240 -0
  26. package/.claude/commands/memory/skill-memory.md +525 -0
  27. package/.claude/commands/memory/style-skill-memory.md +396 -0
  28. package/.claude/commands/memory/tech-research-rules.md +310 -0
  29. package/.claude/commands/memory/update-full.md +332 -0
  30. package/.claude/commands/memory/update-related.md +332 -0
  31. package/.claude/commands/memory/workflow-skill-memory.md +517 -0
  32. package/.claude/commands/task/breakdown.md +204 -0
  33. package/.claude/commands/task/create.md +152 -0
  34. package/.claude/commands/task/execute.md +270 -0
  35. package/.claude/commands/task/replan.md +437 -0
  36. package/.claude/commands/version.md +254 -0
  37. package/.claude/commands/workflow/action-plan-verify.md +447 -0
  38. package/.claude/commands/workflow/brainstorm/api-designer.md +587 -0
  39. package/.claude/commands/workflow/brainstorm/artifacts.md +453 -0
  40. package/.claude/commands/workflow/brainstorm/auto-parallel.md +443 -0
  41. package/.claude/commands/workflow/brainstorm/data-architect.md +220 -0
  42. package/.claude/commands/workflow/brainstorm/product-manager.md +200 -0
  43. package/.claude/commands/workflow/brainstorm/product-owner.md +200 -0
  44. package/.claude/commands/workflow/brainstorm/scrum-master.md +200 -0
  45. package/.claude/commands/workflow/brainstorm/subject-matter-expert.md +200 -0
  46. package/.claude/commands/workflow/brainstorm/synthesis.md +398 -0
  47. package/.claude/commands/workflow/brainstorm/system-architect.md +389 -0
  48. package/.claude/commands/workflow/brainstorm/ui-designer.md +221 -0
  49. package/.claude/commands/workflow/brainstorm/ux-expert.md +221 -0
  50. package/.claude/commands/workflow/debug.md +321 -0
  51. package/.claude/commands/workflow/execute.md +475 -0
  52. package/.claude/commands/workflow/init.md +165 -0
  53. package/.claude/commands/workflow/lite-execute.md +792 -0
  54. package/.claude/commands/workflow/lite-fix.md +623 -0
  55. package/.claude/commands/workflow/lite-plan.md +610 -0
  56. package/.claude/commands/workflow/plan.md +551 -0
  57. package/.claude/commands/workflow/replan.md +515 -0
  58. package/.claude/commands/workflow/review-fix.md +606 -0
  59. package/.claude/commands/workflow/review-module-cycle.md +767 -0
  60. package/.claude/commands/workflow/review-session-cycle.md +778 -0
  61. package/.claude/commands/workflow/review.md +297 -0
  62. package/.claude/commands/workflow/session/complete.md +153 -0
  63. package/.claude/commands/workflow/session/list.md +96 -0
  64. package/.claude/commands/workflow/session/resume.md +61 -0
  65. package/.claude/commands/workflow/session/start.md +200 -0
  66. package/.claude/commands/workflow/tdd-plan.md +460 -0
  67. package/.claude/commands/workflow/tdd-verify.md +400 -0
  68. package/.claude/commands/workflow/test-cycle-execute.md +500 -0
  69. package/.claude/commands/workflow/test-fix-gen.md +699 -0
  70. package/.claude/commands/workflow/test-gen.md +529 -0
  71. package/.claude/commands/workflow/tools/conflict-resolution.md +766 -0
  72. package/.claude/commands/workflow/tools/context-gather.md +436 -0
  73. package/.claude/commands/workflow/tools/task-generate-agent.md +490 -0
  74. package/.claude/commands/workflow/tools/task-generate-tdd.md +526 -0
  75. package/.claude/commands/workflow/tools/tdd-coverage-analysis.md +309 -0
  76. package/.claude/commands/workflow/tools/test-concept-enhanced.md +164 -0
  77. package/.claude/commands/workflow/tools/test-context-gather.md +236 -0
  78. package/.claude/commands/workflow/tools/test-task-generate.md +257 -0
  79. package/.claude/commands/workflow/ui-design/animation-extract.md +1150 -0
  80. package/.claude/commands/workflow/ui-design/codify-style.md +652 -0
  81. package/.claude/commands/workflow/ui-design/design-sync.md +454 -0
  82. package/.claude/commands/workflow/ui-design/explore-auto.md +678 -0
  83. package/.claude/commands/workflow/ui-design/generate.md +504 -0
  84. package/.claude/commands/workflow/ui-design/imitate-auto.md +745 -0
  85. package/.claude/commands/workflow/ui-design/import-from-code.md +540 -0
  86. package/.claude/commands/workflow/ui-design/layout-extract.md +788 -0
  87. package/.claude/commands/workflow/ui-design/reference-page-generator.md +356 -0
  88. package/.claude/commands/workflow/ui-design/style-extract.md +773 -0
  89. package/.claude/skills/command-guide/SKILL.md +388 -0
  90. package/.claude/skills/command-guide/UPDATE-GUIDELINE.md +592 -0
  91. package/.claude/skills/command-guide/guides/cli-tools-guide.md +410 -0
  92. package/.claude/skills/command-guide/guides/examples.md +537 -0
  93. package/.claude/skills/command-guide/guides/getting-started.md +242 -0
  94. package/.claude/skills/command-guide/guides/implementation-details.md +1010 -0
  95. package/.claude/skills/command-guide/guides/index-structure.md +326 -0
  96. package/.claude/skills/command-guide/guides/troubleshooting.md +92 -0
  97. package/.claude/skills/command-guide/guides/ui-design-workflow-guide.md +316 -0
  98. package/.claude/skills/command-guide/guides/workflow-patterns.md +662 -0
  99. package/.claude/skills/command-guide/index/all-commands.json +772 -0
  100. package/.claude/skills/command-guide/index/by-category.json +800 -0
  101. package/.claude/skills/command-guide/index/by-use-case.json +786 -0
  102. package/.claude/skills/command-guide/index/command-relationships.json +307 -0
  103. package/.claude/skills/command-guide/index/essential-commands.json +112 -0
  104. package/.claude/skills/command-guide/reference/agents/action-planning-agent.md +857 -0
  105. package/.claude/skills/command-guide/reference/agents/cli-execution-agent.md +267 -0
  106. package/.claude/skills/command-guide/reference/agents/cli-explore-agent.md +182 -0
  107. package/.claude/skills/command-guide/reference/agents/cli-lite-planning-agent.md +446 -0
  108. package/.claude/skills/command-guide/reference/agents/cli-planning-agent.md +558 -0
  109. package/.claude/skills/command-guide/reference/agents/code-developer.md +311 -0
  110. package/.claude/skills/command-guide/reference/agents/conceptual-planning-agent.md +308 -0
  111. package/.claude/skills/command-guide/reference/agents/context-search-agent.md +581 -0
  112. package/.claude/skills/command-guide/reference/agents/doc-generator.md +330 -0
  113. package/.claude/skills/command-guide/reference/agents/memory-bridge.md +94 -0
  114. package/.claude/skills/command-guide/reference/agents/test-context-search-agent.md +400 -0
  115. package/.claude/skills/command-guide/reference/agents/test-fix-agent.md +344 -0
  116. package/.claude/skills/command-guide/reference/agents/ui-design-agent.md +593 -0
  117. package/.claude/skills/command-guide/reference/agents/universal-executor.md +131 -0
  118. package/.claude/skills/command-guide/reference/commands/cli/cli-init.md +440 -0
  119. package/.claude/skills/command-guide/reference/commands/enhance-prompt.md +93 -0
  120. package/.claude/skills/command-guide/reference/commands/memory/code-map-memory.md +687 -0
  121. package/.claude/skills/command-guide/reference/commands/memory/docs-full-cli.md +471 -0
  122. package/.claude/skills/command-guide/reference/commands/memory/docs-related-cli.md +386 -0
  123. package/.claude/skills/command-guide/reference/commands/memory/docs.md +616 -0
  124. package/.claude/skills/command-guide/reference/commands/memory/load-skill-memory.md +182 -0
  125. package/.claude/skills/command-guide/reference/commands/memory/load.md +240 -0
  126. package/.claude/skills/command-guide/reference/commands/memory/skill-memory.md +525 -0
  127. package/.claude/skills/command-guide/reference/commands/memory/style-skill-memory.md +396 -0
  128. package/.claude/skills/command-guide/reference/commands/memory/tech-research.md +314 -0
  129. package/.claude/skills/command-guide/reference/commands/memory/update-full.md +332 -0
  130. package/.claude/skills/command-guide/reference/commands/memory/update-related.md +332 -0
  131. package/.claude/skills/command-guide/reference/commands/memory/workflow-skill-memory.md +517 -0
  132. package/.claude/skills/command-guide/reference/commands/task/breakdown.md +204 -0
  133. package/.claude/skills/command-guide/reference/commands/task/create.md +152 -0
  134. package/.claude/skills/command-guide/reference/commands/task/execute.md +270 -0
  135. package/.claude/skills/command-guide/reference/commands/task/replan.md +437 -0
  136. package/.claude/skills/command-guide/reference/commands/version.md +254 -0
  137. package/.claude/skills/command-guide/reference/commands/workflow/action-plan-verify.md +447 -0
  138. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/api-designer.md +585 -0
  139. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/artifacts.md +452 -0
  140. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/auto-parallel.md +443 -0
  141. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/data-architect.md +220 -0
  142. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-manager.md +200 -0
  143. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-owner.md +200 -0
  144. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/scrum-master.md +200 -0
  145. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/subject-matter-expert.md +200 -0
  146. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/synthesis.md +398 -0
  147. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/system-architect.md +387 -0
  148. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ui-designer.md +221 -0
  149. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ux-expert.md +221 -0
  150. package/.claude/skills/command-guide/reference/commands/workflow/execute.md +465 -0
  151. package/.claude/skills/command-guide/reference/commands/workflow/init.md +164 -0
  152. package/.claude/skills/command-guide/reference/commands/workflow/lite-execute.md +748 -0
  153. package/.claude/skills/command-guide/reference/commands/workflow/lite-fix.md +664 -0
  154. package/.claude/skills/command-guide/reference/commands/workflow/lite-plan.md +645 -0
  155. package/.claude/skills/command-guide/reference/commands/workflow/plan.md +551 -0
  156. package/.claude/skills/command-guide/reference/commands/workflow/replan.md +515 -0
  157. package/.claude/skills/command-guide/reference/commands/workflow/review-fix.md +606 -0
  158. package/.claude/skills/command-guide/reference/commands/workflow/review-module-cycle.md +765 -0
  159. package/.claude/skills/command-guide/reference/commands/workflow/review-session-cycle.md +776 -0
  160. package/.claude/skills/command-guide/reference/commands/workflow/review.md +298 -0
  161. package/.claude/skills/command-guide/reference/commands/workflow/session/complete.md +547 -0
  162. package/.claude/skills/command-guide/reference/commands/workflow/session/list.md +114 -0
  163. package/.claude/skills/command-guide/reference/commands/workflow/session/resume.md +77 -0
  164. package/.claude/skills/command-guide/reference/commands/workflow/session/start.md +257 -0
  165. package/.claude/skills/command-guide/reference/commands/workflow/tdd-plan.md +460 -0
  166. package/.claude/skills/command-guide/reference/commands/workflow/tdd-verify.md +400 -0
  167. package/.claude/skills/command-guide/reference/commands/workflow/test-cycle-execute.md +498 -0
  168. package/.claude/skills/command-guide/reference/commands/workflow/test-fix-gen.md +699 -0
  169. package/.claude/skills/command-guide/reference/commands/workflow/test-gen.md +529 -0
  170. package/.claude/skills/command-guide/reference/commands/workflow/tools/conflict-resolution.md +766 -0
  171. package/.claude/skills/command-guide/reference/commands/workflow/tools/context-gather.md +434 -0
  172. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-agent.md +487 -0
  173. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-tdd.md +525 -0
  174. package/.claude/skills/command-guide/reference/commands/workflow/tools/tdd-coverage-analysis.md +309 -0
  175. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-concept-enhanced.md +163 -0
  176. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-context-gather.md +235 -0
  177. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-task-generate.md +256 -0
  178. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/animation-extract.md +1150 -0
  179. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/codify-style.md +652 -0
  180. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/design-sync.md +454 -0
  181. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/explore-auto.md +678 -0
  182. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/generate.md +504 -0
  183. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/imitate-auto.md +745 -0
  184. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/import-from-code.md +537 -0
  185. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/layout-extract.md +788 -0
  186. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/reference-page-generator.md +356 -0
  187. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/style-extract.md +773 -0
  188. package/.claude/skills/command-guide/scripts/analyze_commands.py +502 -0
  189. package/.claude/skills/command-guide/scripts/update-index.sh +130 -0
  190. package/.claude/skills/command-guide/templates/issue-bug.md +104 -0
  191. package/.claude/skills/command-guide/templates/issue-diagnosis.md +275 -0
  192. package/.claude/skills/command-guide/templates/issue-feature.md +97 -0
  193. package/.claude/skills/command-guide/templates/issue-question.md +141 -0
  194. package/.claude/skills/prompt-enhancer/SKILL.md +124 -0
  195. package/.claude/workflows/_template-compare-matrix.html +692 -0
  196. package/.claude/workflows/chinese-response.md +38 -0
  197. package/.claude/workflows/cli-templates/fix-plan-template.json +75 -0
  198. package/.claude/workflows/cli-templates/fix-progress-template.json +48 -0
  199. package/.claude/workflows/cli-templates/memory/style-skill-memory/skill-md-template.md +299 -0
  200. package/.claude/workflows/cli-templates/planning-roles/data-architect.md +120 -0
  201. package/.claude/workflows/cli-templates/planning-roles/product-manager.md +119 -0
  202. package/.claude/workflows/cli-templates/planning-roles/product-owner.md +261 -0
  203. package/.claude/workflows/cli-templates/planning-roles/scrum-master.md +186 -0
  204. package/.claude/workflows/cli-templates/planning-roles/subject-matter-expert.md +281 -0
  205. package/.claude/workflows/cli-templates/planning-roles/synthesis-role.md +414 -0
  206. package/.claude/workflows/cli-templates/planning-roles/system-architect.md +106 -0
  207. package/.claude/workflows/cli-templates/planning-roles/test-strategist.md +124 -0
  208. package/.claude/workflows/cli-templates/planning-roles/ui-designer.md +379 -0
  209. package/.claude/workflows/cli-templates/planning-roles/ux-expert.md +240 -0
  210. package/.claude/workflows/cli-templates/prompts/analysis/01-diagnose-bug-root-cause.txt +127 -0
  211. package/.claude/workflows/cli-templates/prompts/analysis/01-trace-code-execution.txt +115 -0
  212. package/.claude/workflows/cli-templates/prompts/analysis/02-analyze-code-patterns.txt +37 -0
  213. package/.claude/workflows/cli-templates/prompts/analysis/02-analyze-technical-document.txt +33 -0
  214. package/.claude/workflows/cli-templates/prompts/analysis/02-review-architecture.txt +29 -0
  215. package/.claude/workflows/cli-templates/prompts/analysis/02-review-code-quality.txt +28 -0
  216. package/.claude/workflows/cli-templates/prompts/analysis/03-analyze-performance.txt +29 -0
  217. package/.claude/workflows/cli-templates/prompts/analysis/03-assess-security-risks.txt +29 -0
  218. package/.claude/workflows/cli-templates/prompts/analysis/03-review-quality-standards.txt +29 -0
  219. package/.claude/workflows/cli-templates/prompts/development/02-generate-tests.txt +70 -0
  220. package/.claude/workflows/cli-templates/prompts/development/02-implement-component-ui.txt +55 -0
  221. package/.claude/workflows/cli-templates/prompts/development/02-implement-feature.txt +58 -0
  222. package/.claude/workflows/cli-templates/prompts/development/02-refactor-codebase.txt +55 -0
  223. package/.claude/workflows/cli-templates/prompts/development/03-debug-runtime-issues.txt +55 -0
  224. package/.claude/workflows/cli-templates/prompts/documentation/api.txt +15 -0
  225. package/.claude/workflows/cli-templates/prompts/documentation/folder-navigation.txt +27 -0
  226. package/.claude/workflows/cli-templates/prompts/documentation/module-readme.txt +49 -0
  227. package/.claude/workflows/cli-templates/prompts/documentation/project-architecture.txt +41 -0
  228. package/.claude/workflows/cli-templates/prompts/documentation/project-examples.txt +35 -0
  229. package/.claude/workflows/cli-templates/prompts/documentation/project-readme.txt +35 -0
  230. package/.claude/workflows/cli-templates/prompts/memory/02-document-module-structure.txt +165 -0
  231. package/.claude/workflows/cli-templates/prompts/planning/01-plan-architecture-design.txt +109 -0
  232. package/.claude/workflows/cli-templates/prompts/planning/02-breakdown-task-steps.txt +30 -0
  233. package/.claude/workflows/cli-templates/prompts/planning/02-design-component-spec.txt +28 -0
  234. package/.claude/workflows/cli-templates/prompts/planning/03-evaluate-concept-feasibility.txt +127 -0
  235. package/.claude/workflows/cli-templates/prompts/planning/03-plan-migration-strategy.txt +30 -0
  236. package/.claude/workflows/cli-templates/prompts/rules/rule-api.txt +122 -0
  237. package/.claude/workflows/cli-templates/prompts/rules/rule-components.txt +122 -0
  238. package/.claude/workflows/cli-templates/prompts/rules/rule-config.txt +89 -0
  239. package/.claude/workflows/cli-templates/prompts/rules/rule-core.txt +60 -0
  240. package/.claude/workflows/cli-templates/prompts/rules/rule-patterns.txt +70 -0
  241. package/.claude/workflows/cli-templates/prompts/rules/rule-testing.txt +81 -0
  242. package/.claude/workflows/cli-templates/prompts/rules/tech-rules-agent-prompt.txt +89 -0
  243. package/.claude/workflows/cli-templates/prompts/tech/tech-module-format.txt +359 -0
  244. package/.claude/workflows/cli-templates/prompts/tech/tech-skill-index.txt +185 -0
  245. package/.claude/workflows/cli-templates/prompts/test/test-concept-analysis.txt +179 -0
  246. package/.claude/workflows/cli-templates/prompts/universal/00-universal-creative-style.txt +95 -0
  247. package/.claude/workflows/cli-templates/prompts/universal/00-universal-rigorous-style.txt +92 -0
  248. package/.claude/workflows/cli-templates/prompts/verification/codex-technical.txt +28 -0
  249. package/.claude/workflows/cli-templates/prompts/verification/cross-validation.txt +28 -0
  250. package/.claude/workflows/cli-templates/prompts/verification/gemini-strategic.txt +27 -0
  251. package/.claude/workflows/cli-templates/prompts/workflow/analysis-results-structure.txt +224 -0
  252. package/.claude/workflows/cli-templates/prompts/workflow/codex-feasibility-validation.txt +176 -0
  253. package/.claude/workflows/cli-templates/prompts/workflow/gemini-solution-design.txt +131 -0
  254. package/.claude/workflows/cli-templates/prompts/workflow/impl-plan-template.txt +286 -0
  255. package/.claude/workflows/cli-templates/prompts/workflow/skill-aggregation.txt +172 -0
  256. package/.claude/workflows/cli-templates/prompts/workflow/skill-conflict-patterns.txt +94 -0
  257. package/.claude/workflows/cli-templates/prompts/workflow/skill-index.txt +224 -0
  258. package/.claude/workflows/cli-templates/prompts/workflow/skill-lessons-learned.txt +94 -0
  259. package/.claude/workflows/cli-templates/prompts/workflow/skill-sessions-timeline.txt +53 -0
  260. package/.claude/workflows/cli-templates/prompts/workflow/task-json-agent-mode.txt +123 -0
  261. package/.claude/workflows/cli-templates/prompts/workflow/task-json-cli-mode.txt +182 -0
  262. package/.claude/workflows/cli-templates/protocols/analysis-protocol.md +112 -0
  263. package/.claude/workflows/cli-templates/protocols/write-protocol.md +201 -0
  264. package/.claude/workflows/cli-templates/schemas/conflict-resolution-schema.json +137 -0
  265. package/.claude/workflows/cli-templates/schemas/debug-log-json-schema.json +127 -0
  266. package/.claude/workflows/cli-templates/schemas/diagnosis-json-schema.json +234 -0
  267. package/.claude/workflows/cli-templates/schemas/explore-json-schema.json +124 -0
  268. package/.claude/workflows/cli-templates/schemas/fix-plan-json-schema.json +298 -0
  269. package/.claude/workflows/cli-templates/schemas/plan-json-schema.json +244 -0
  270. package/.claude/workflows/cli-templates/schemas/project-json-schema.json +221 -0
  271. package/.claude/workflows/cli-templates/schemas/review-deep-dive-results-schema.json +82 -0
  272. package/.claude/workflows/cli-templates/schemas/review-dimension-results-schema.json +51 -0
  273. package/.claude/workflows/cli-templates/tech-stacks/go-dev.md +91 -0
  274. package/.claude/workflows/cli-templates/tech-stacks/java-dev.md +107 -0
  275. package/.claude/workflows/cli-templates/tech-stacks/javascript-dev.md +58 -0
  276. package/.claude/workflows/cli-templates/tech-stacks/python-dev.md +79 -0
  277. package/.claude/workflows/cli-templates/tech-stacks/react-dev.md +103 -0
  278. package/.claude/workflows/cli-templates/tech-stacks/typescript-dev.md +83 -0
  279. package/.claude/workflows/cli-templates/ui-design/systems/animation-tokens.json +247 -0
  280. package/.claude/workflows/cli-templates/ui-design/systems/design-tokens.json +342 -0
  281. package/.claude/workflows/cli-templates/ui-design/systems/layout-templates.json +145 -0
  282. package/.claude/workflows/cli-tools-usage.md +526 -0
  283. package/.claude/workflows/coding-philosophy.md +70 -0
  284. package/.claude/workflows/context-tools.md +84 -0
  285. package/.claude/workflows/file-modification.md +64 -0
  286. package/.claude/workflows/review-directory-specification.md +336 -0
  287. package/.claude/workflows/task-core.md +214 -0
  288. package/.claude/workflows/tool-strategy.md +216 -0
  289. package/.claude/workflows/windows-platform.md +16 -0
  290. package/.claude/workflows/workflow-architecture.md +942 -0
  291. package/.codex/AGENTS.md +63 -0
  292. package/.codex/prompts/debug.md +318 -0
  293. package/.codex/prompts/execute.md +273 -0
  294. package/.codex/prompts/lite-execute.md +164 -0
  295. package/.codex/prompts/lite-plan.md +469 -0
  296. package/.codex/prompts.zip +0 -0
  297. package/.gemini/GEMINI.md +25 -0
  298. package/.qwen/QWEN.md +25 -0
  299. package/LICENSE +21 -0
  300. package/README.md +294 -145
  301. package/ccw/README.md +145 -0
  302. package/ccw/dist/core/lite-scanner-complete.d.ts.map +1 -0
  303. package/ccw/dist/core/lite-scanner-complete.js +371 -0
  304. package/ccw/dist/core/lite-scanner-complete.js.map +1 -0
  305. package/ccw/dist/core/lite-scanner.d.ts.map +1 -0
  306. package/ccw/dist/core/lite-scanner.js +371 -0
  307. package/ccw/dist/core/lite-scanner.js.map +1 -0
  308. package/ccw/dist/core/routes/claude-routes.d.ts.map +1 -0
  309. package/ccw/dist/core/routes/claude-routes.js +1015 -0
  310. package/ccw/dist/core/routes/claude-routes.js.map +1 -0
  311. package/ccw/dist/core/routes/cli-routes.d.ts.map +1 -0
  312. package/ccw/dist/core/routes/cli-routes.js +469 -0
  313. package/ccw/dist/core/routes/cli-routes.js.map +1 -0
  314. package/ccw/dist/core/routes/rules-routes.d.ts.map +1 -0
  315. package/ccw/dist/core/routes/rules-routes.js +443 -0
  316. package/ccw/dist/core/routes/rules-routes.js.map +1 -0
  317. package/ccw/dist/core/routes/skills-routes.d.ts.map +1 -0
  318. package/ccw/dist/core/routes/skills-routes.js +651 -0
  319. package/ccw/dist/core/routes/skills-routes.js.map +1 -0
  320. package/ccw/dist/tools/cli-executor.d.ts +376 -0
  321. package/ccw/dist/tools/cli-executor.d.ts.map +1 -0
  322. package/ccw/dist/tools/cli-executor.js +1677 -0
  323. package/ccw/dist/tools/cli-executor.js.map +1 -0
  324. package/ccw/package.json +65 -0
  325. package/ccw/src/core/lite-scanner-complete.ts +473 -0
  326. package/ccw/src/core/lite-scanner.ts +473 -0
  327. package/ccw/src/core/routes/claude-routes.ts +1181 -0
  328. package/ccw/src/core/routes/cli-routes.ts +562 -0
  329. package/ccw/src/core/routes/rules-routes.ts +527 -0
  330. package/ccw/src/core/routes/skills-routes.ts +737 -0
  331. package/ccw/src/templates/dashboard-js/i18n.js +2969 -0
  332. package/ccw/src/templates/dashboard-js/views/claude-manager.js +926 -0
  333. package/ccw/src/templates/dashboard-js/views/cli-manager.js +2274 -0
  334. package/ccw/src/templates/dashboard-js/views/rules-manager.js +857 -0
  335. package/ccw/src/templates/dashboard-js/views/skills-manager.js +1183 -0
  336. package/ccw/src/tools/cli-executor.ts +2082 -0
  337. package/codex-lens/pyproject.toml +66 -0
  338. package/codex-lens/src/codexlens/.workflow/.cli-history/history.db +0 -0
  339. package/codex-lens/src/codexlens/__init__.py +28 -0
  340. package/codex-lens/src/codexlens/__main__.py +14 -0
  341. package/codex-lens/src/codexlens/__pycache__/__init__.cpython-313.pyc +0 -0
  342. package/codex-lens/src/codexlens/__pycache__/__main__.cpython-313.pyc +0 -0
  343. package/codex-lens/src/codexlens/__pycache__/config.cpython-313.pyc +0 -0
  344. package/codex-lens/src/codexlens/__pycache__/entities.cpython-313.pyc +0 -0
  345. package/codex-lens/src/codexlens/__pycache__/errors.cpython-313.pyc +0 -0
  346. package/codex-lens/src/codexlens/cli/__init__.py +27 -0
  347. package/codex-lens/src/codexlens/cli/__pycache__/__init__.cpython-313.pyc +0 -0
  348. package/codex-lens/src/codexlens/cli/__pycache__/commands.cpython-313.pyc +0 -0
  349. package/codex-lens/src/codexlens/cli/__pycache__/embedding_manager.cpython-313.pyc +0 -0
  350. package/codex-lens/src/codexlens/cli/__pycache__/model_manager.cpython-313.pyc +0 -0
  351. package/codex-lens/src/codexlens/cli/__pycache__/output.cpython-313.pyc +0 -0
  352. package/codex-lens/src/codexlens/cli/commands.py +1931 -0
  353. package/codex-lens/src/codexlens/cli/embedding_manager.py +620 -0
  354. package/codex-lens/src/codexlens/cli/model_manager.py +311 -0
  355. package/codex-lens/src/codexlens/cli/output.py +124 -0
  356. package/codex-lens/src/codexlens/config.py +201 -0
  357. package/codex-lens/src/codexlens/entities.py +121 -0
  358. package/codex-lens/src/codexlens/errors.py +55 -0
  359. package/codex-lens/src/codexlens/indexing/README.md +77 -0
  360. package/codex-lens/src/codexlens/indexing/__init__.py +4 -0
  361. package/codex-lens/src/codexlens/indexing/__pycache__/__init__.cpython-313.pyc +0 -0
  362. package/codex-lens/src/codexlens/indexing/__pycache__/symbol_extractor.cpython-313.pyc +0 -0
  363. package/codex-lens/src/codexlens/indexing/symbol_extractor.py +243 -0
  364. package/codex-lens/src/codexlens/parsers/__init__.py +8 -0
  365. package/codex-lens/src/codexlens/parsers/__pycache__/__init__.cpython-313.pyc +0 -0
  366. package/codex-lens/src/codexlens/parsers/__pycache__/encoding.cpython-313.pyc +0 -0
  367. package/codex-lens/src/codexlens/parsers/__pycache__/factory.cpython-313.pyc +0 -0
  368. package/codex-lens/src/codexlens/parsers/__pycache__/tokenizer.cpython-313.pyc +0 -0
  369. package/codex-lens/src/codexlens/parsers/__pycache__/treesitter_parser.cpython-313.pyc +0 -0
  370. package/codex-lens/src/codexlens/parsers/encoding.py +202 -0
  371. package/codex-lens/src/codexlens/parsers/factory.py +256 -0
  372. package/codex-lens/src/codexlens/parsers/tokenizer.py +98 -0
  373. package/codex-lens/src/codexlens/parsers/treesitter_parser.py +335 -0
  374. package/codex-lens/src/codexlens/search/__init__.py +15 -0
  375. package/codex-lens/src/codexlens/search/__pycache__/__init__.cpython-313.pyc +0 -0
  376. package/codex-lens/src/codexlens/search/__pycache__/chain_search.cpython-313.pyc +0 -0
  377. package/codex-lens/src/codexlens/search/__pycache__/enrichment.cpython-313.pyc +0 -0
  378. package/codex-lens/src/codexlens/search/__pycache__/hybrid_search.cpython-313.pyc +0 -0
  379. package/codex-lens/src/codexlens/search/__pycache__/query_parser.cpython-313.pyc +0 -0
  380. package/codex-lens/src/codexlens/search/__pycache__/ranking.cpython-313.pyc +0 -0
  381. package/codex-lens/src/codexlens/search/chain_search.py +647 -0
  382. package/codex-lens/src/codexlens/search/enrichment.py +150 -0
  383. package/codex-lens/src/codexlens/search/hybrid_search.py +313 -0
  384. package/codex-lens/src/codexlens/search/query_parser.py +242 -0
  385. package/codex-lens/src/codexlens/search/ranking.py +274 -0
  386. package/codex-lens/src/codexlens/semantic/__init__.py +76 -0
  387. package/codex-lens/src/codexlens/semantic/__pycache__/__init__.cpython-313.pyc +0 -0
  388. package/codex-lens/src/codexlens/semantic/__pycache__/ann_index.cpython-313.pyc +0 -0
  389. package/codex-lens/src/codexlens/semantic/__pycache__/chunker.cpython-313.pyc +0 -0
  390. package/codex-lens/src/codexlens/semantic/__pycache__/code_extractor.cpython-313.pyc +0 -0
  391. package/codex-lens/src/codexlens/semantic/__pycache__/embedder.cpython-313.pyc +0 -0
  392. package/codex-lens/src/codexlens/semantic/__pycache__/gpu_support.cpython-313.pyc +0 -0
  393. package/codex-lens/src/codexlens/semantic/__pycache__/graph_analyzer.cpython-313.pyc +0 -0
  394. package/codex-lens/src/codexlens/semantic/__pycache__/llm_enhancer.cpython-313.pyc +0 -0
  395. package/codex-lens/src/codexlens/semantic/__pycache__/ollama_backend.cpython-313.pyc +0 -0
  396. package/codex-lens/src/codexlens/semantic/__pycache__/vector_store.cpython-313.pyc +0 -0
  397. package/codex-lens/src/codexlens/semantic/ann_index.py +414 -0
  398. package/codex-lens/src/codexlens/semantic/chunker.py +448 -0
  399. package/codex-lens/src/codexlens/semantic/code_extractor.py +274 -0
  400. package/codex-lens/src/codexlens/semantic/embedder.py +244 -0
  401. package/codex-lens/src/codexlens/semantic/gpu_support.py +192 -0
  402. package/codex-lens/src/codexlens/semantic/vector_store.py +955 -0
  403. package/codex-lens/src/codexlens/storage/__init__.py +29 -0
  404. package/codex-lens/src/codexlens/storage/__pycache__/__init__.cpython-313.pyc +0 -0
  405. package/codex-lens/src/codexlens/storage/__pycache__/dir_index.cpython-313.pyc +0 -0
  406. package/codex-lens/src/codexlens/storage/__pycache__/file_cache.cpython-313.pyc +0 -0
  407. package/codex-lens/src/codexlens/storage/__pycache__/index_tree.cpython-313.pyc +0 -0
  408. package/codex-lens/src/codexlens/storage/__pycache__/migration_manager.cpython-313.pyc +0 -0
  409. package/codex-lens/src/codexlens/storage/__pycache__/path_mapper.cpython-313.pyc +0 -0
  410. package/codex-lens/src/codexlens/storage/__pycache__/registry.cpython-313.pyc +0 -0
  411. package/codex-lens/src/codexlens/storage/__pycache__/sqlite_store.cpython-313.pyc +0 -0
  412. package/codex-lens/src/codexlens/storage/__pycache__/sqlite_utils.cpython-313.pyc +0 -0
  413. package/codex-lens/src/codexlens/storage/dir_index.py +1850 -0
  414. package/codex-lens/src/codexlens/storage/file_cache.py +32 -0
  415. package/codex-lens/src/codexlens/storage/index_tree.py +776 -0
  416. package/codex-lens/src/codexlens/storage/migration_manager.py +154 -0
  417. package/codex-lens/src/codexlens/storage/migrations/__init__.py +1 -0
  418. package/codex-lens/src/codexlens/storage/migrations/__pycache__/__init__.cpython-313.pyc +0 -0
  419. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_001_normalize_keywords.cpython-313.pyc +0 -0
  420. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_002_add_token_metadata.cpython-313.pyc +0 -0
  421. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_003_code_relationships.cpython-313.pyc +0 -0
  422. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_004_dual_fts.cpython-313.pyc +0 -0
  423. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_005_cleanup_unused_fields.cpython-313.pyc +0 -0
  424. package/codex-lens/src/codexlens/storage/migrations/migration_001_normalize_keywords.py +123 -0
  425. package/codex-lens/src/codexlens/storage/migrations/migration_002_add_token_metadata.py +48 -0
  426. package/codex-lens/src/codexlens/storage/migrations/migration_004_dual_fts.py +232 -0
  427. package/codex-lens/src/codexlens/storage/migrations/migration_005_cleanup_unused_fields.py +196 -0
  428. package/codex-lens/src/codexlens/storage/path_mapper.py +274 -0
  429. package/codex-lens/src/codexlens/storage/registry.py +670 -0
  430. package/codex-lens/src/codexlens/storage/sqlite_store.py +576 -0
  431. package/codex-lens/src/codexlens/storage/sqlite_utils.py +64 -0
  432. package/package.json +36 -28
  433. package/dist/core/lite-scanner-complete.d.ts.map +0 -1
  434. package/dist/core/lite-scanner-complete.js +0 -368
  435. package/dist/core/lite-scanner-complete.js.map +0 -1
  436. package/dist/core/lite-scanner.d.ts.map +0 -1
  437. package/dist/core/lite-scanner.js +0 -368
  438. package/dist/core/lite-scanner.js.map +0 -1
  439. package/dist/core/routes/claude-routes.d.ts.map +0 -1
  440. package/dist/core/routes/claude-routes.js +0 -1017
  441. package/dist/core/routes/claude-routes.js.map +0 -1
  442. package/dist/core/routes/cli-routes.d.ts.map +0 -1
  443. package/dist/core/routes/cli-routes.js +0 -468
  444. package/dist/core/routes/cli-routes.js.map +0 -1
  445. package/dist/core/routes/rules-routes.d.ts.map +0 -1
  446. package/dist/core/routes/rules-routes.js +0 -442
  447. package/dist/core/routes/rules-routes.js.map +0 -1
  448. package/dist/core/routes/skills-routes.d.ts.map +0 -1
  449. package/dist/core/routes/skills-routes.js +0 -533
  450. package/dist/core/routes/skills-routes.js.map +0 -1
  451. package/dist/tools/cli-executor.d.ts +0 -373
  452. package/dist/tools/cli-executor.d.ts.map +0 -1
  453. package/dist/tools/cli-executor.js +0 -1625
  454. package/dist/tools/cli-executor.js.map +0 -1
  455. package/src/core/lite-scanner-complete.ts +0 -469
  456. package/src/core/lite-scanner.ts +0 -469
  457. package/src/core/routes/claude-routes.ts +0 -1183
  458. package/src/core/routes/cli-routes.ts +0 -561
  459. package/src/core/routes/rules-routes.ts +0 -526
  460. package/src/core/routes/skills-routes.ts +0 -599
  461. package/src/templates/dashboard-js/i18n.js +0 -2963
  462. package/src/templates/dashboard-js/views/claude-manager.js +0 -912
  463. package/src/templates/dashboard-js/views/cli-manager.js +0 -2272
  464. package/src/templates/dashboard-js/views/rules-manager.js +0 -828
  465. package/src/templates/dashboard-js/views/skills-manager.js +0 -819
  466. package/src/tools/cli-executor.ts +0 -2014
  467. /package/{bin → ccw/bin}/ccw-mcp.js +0 -0
  468. /package/{bin → ccw/bin}/ccw.js +0 -0
  469. /package/{dist → ccw/dist}/cli.d.ts +0 -0
  470. /package/{dist → ccw/dist}/cli.d.ts.map +0 -0
  471. /package/{dist → ccw/dist}/cli.js +0 -0
  472. /package/{dist → ccw/dist}/cli.js.map +0 -0
  473. /package/{dist → ccw/dist}/commands/cli.d.ts +0 -0
  474. /package/{dist → ccw/dist}/commands/cli.d.ts.map +0 -0
  475. /package/{dist → ccw/dist}/commands/cli.js +0 -0
  476. /package/{dist → ccw/dist}/commands/cli.js.map +0 -0
  477. /package/{dist → ccw/dist}/commands/core-memory.d.ts +0 -0
  478. /package/{dist → ccw/dist}/commands/core-memory.d.ts.map +0 -0
  479. /package/{dist → ccw/dist}/commands/core-memory.js +0 -0
  480. /package/{dist → ccw/dist}/commands/core-memory.js.map +0 -0
  481. /package/{dist → ccw/dist}/commands/hook.d.ts +0 -0
  482. /package/{dist → ccw/dist}/commands/hook.d.ts.map +0 -0
  483. /package/{dist → ccw/dist}/commands/hook.js +0 -0
  484. /package/{dist → ccw/dist}/commands/hook.js.map +0 -0
  485. /package/{dist → ccw/dist}/commands/install.d.ts +0 -0
  486. /package/{dist → ccw/dist}/commands/install.d.ts.map +0 -0
  487. /package/{dist → ccw/dist}/commands/install.js +0 -0
  488. /package/{dist → ccw/dist}/commands/install.js.map +0 -0
  489. /package/{dist → ccw/dist}/commands/list.d.ts +0 -0
  490. /package/{dist → ccw/dist}/commands/list.d.ts.map +0 -0
  491. /package/{dist → ccw/dist}/commands/list.js +0 -0
  492. /package/{dist → ccw/dist}/commands/list.js.map +0 -0
  493. /package/{dist → ccw/dist}/commands/memory.d.ts +0 -0
  494. /package/{dist → ccw/dist}/commands/memory.d.ts.map +0 -0
  495. /package/{dist → ccw/dist}/commands/memory.js +0 -0
  496. /package/{dist → ccw/dist}/commands/memory.js.map +0 -0
  497. /package/{dist → ccw/dist}/commands/serve.d.ts +0 -0
  498. /package/{dist → ccw/dist}/commands/serve.d.ts.map +0 -0
  499. /package/{dist → ccw/dist}/commands/serve.js +0 -0
  500. /package/{dist → ccw/dist}/commands/serve.js.map +0 -0
  501. /package/{dist → ccw/dist}/commands/session-path-resolver.d.ts +0 -0
  502. /package/{dist → ccw/dist}/commands/session-path-resolver.d.ts.map +0 -0
  503. /package/{dist → ccw/dist}/commands/session-path-resolver.js +0 -0
  504. /package/{dist → ccw/dist}/commands/session-path-resolver.js.map +0 -0
  505. /package/{dist → ccw/dist}/commands/session.d.ts +0 -0
  506. /package/{dist → ccw/dist}/commands/session.d.ts.map +0 -0
  507. /package/{dist → ccw/dist}/commands/session.js +0 -0
  508. /package/{dist → ccw/dist}/commands/session.js.map +0 -0
  509. /package/{dist → ccw/dist}/commands/stop.d.ts +0 -0
  510. /package/{dist → ccw/dist}/commands/stop.d.ts.map +0 -0
  511. /package/{dist → ccw/dist}/commands/stop.js +0 -0
  512. /package/{dist → ccw/dist}/commands/stop.js.map +0 -0
  513. /package/{dist → ccw/dist}/commands/tool.d.ts +0 -0
  514. /package/{dist → ccw/dist}/commands/tool.d.ts.map +0 -0
  515. /package/{dist → ccw/dist}/commands/tool.js +0 -0
  516. /package/{dist → ccw/dist}/commands/tool.js.map +0 -0
  517. /package/{dist → ccw/dist}/commands/uninstall.d.ts +0 -0
  518. /package/{dist → ccw/dist}/commands/uninstall.d.ts.map +0 -0
  519. /package/{dist → ccw/dist}/commands/uninstall.js +0 -0
  520. /package/{dist → ccw/dist}/commands/uninstall.js.map +0 -0
  521. /package/{dist → ccw/dist}/commands/upgrade.d.ts +0 -0
  522. /package/{dist → ccw/dist}/commands/upgrade.d.ts.map +0 -0
  523. /package/{dist → ccw/dist}/commands/upgrade.js +0 -0
  524. /package/{dist → ccw/dist}/commands/upgrade.js.map +0 -0
  525. /package/{dist → ccw/dist}/commands/view.d.ts +0 -0
  526. /package/{dist → ccw/dist}/commands/view.d.ts.map +0 -0
  527. /package/{dist → ccw/dist}/commands/view.js +0 -0
  528. /package/{dist → ccw/dist}/commands/view.js.map +0 -0
  529. /package/{dist → ccw/dist}/config/storage-paths.d.ts +0 -0
  530. /package/{dist → ccw/dist}/config/storage-paths.d.ts.map +0 -0
  531. /package/{dist → ccw/dist}/config/storage-paths.js +0 -0
  532. /package/{dist → ccw/dist}/config/storage-paths.js.map +0 -0
  533. /package/{dist → ccw/dist}/core/cache-manager.d.ts +0 -0
  534. /package/{dist → ccw/dist}/core/cache-manager.d.ts.map +0 -0
  535. /package/{dist → ccw/dist}/core/cache-manager.js +0 -0
  536. /package/{dist → ccw/dist}/core/cache-manager.js.map +0 -0
  537. /package/{dist → ccw/dist}/core/claude-freshness.d.ts +0 -0
  538. /package/{dist → ccw/dist}/core/claude-freshness.d.ts.map +0 -0
  539. /package/{dist → ccw/dist}/core/claude-freshness.js +0 -0
  540. /package/{dist → ccw/dist}/core/claude-freshness.js.map +0 -0
  541. /package/{dist → ccw/dist}/core/core-memory-store.d.ts +0 -0
  542. /package/{dist → ccw/dist}/core/core-memory-store.d.ts.map +0 -0
  543. /package/{dist → ccw/dist}/core/core-memory-store.js +0 -0
  544. /package/{dist → ccw/dist}/core/core-memory-store.js.map +0 -0
  545. /package/{dist → ccw/dist}/core/dashboard-generator-patch.d.ts +0 -0
  546. /package/{dist → ccw/dist}/core/dashboard-generator-patch.d.ts.map +0 -0
  547. /package/{dist → ccw/dist}/core/dashboard-generator-patch.js +0 -0
  548. /package/{dist → ccw/dist}/core/dashboard-generator-patch.js.map +0 -0
  549. /package/{dist → ccw/dist}/core/dashboard-generator.d.ts +0 -0
  550. /package/{dist → ccw/dist}/core/dashboard-generator.d.ts.map +0 -0
  551. /package/{dist → ccw/dist}/core/dashboard-generator.js +0 -0
  552. /package/{dist → ccw/dist}/core/dashboard-generator.js.map +0 -0
  553. /package/{dist → ccw/dist}/core/data-aggregator.d.ts +0 -0
  554. /package/{dist → ccw/dist}/core/data-aggregator.d.ts.map +0 -0
  555. /package/{dist → ccw/dist}/core/data-aggregator.js +0 -0
  556. /package/{dist → ccw/dist}/core/data-aggregator.js.map +0 -0
  557. /package/{dist → ccw/dist}/core/history-importer.d.ts +0 -0
  558. /package/{dist → ccw/dist}/core/history-importer.d.ts.map +0 -0
  559. /package/{dist → ccw/dist}/core/history-importer.js +0 -0
  560. /package/{dist → ccw/dist}/core/history-importer.js.map +0 -0
  561. /package/{dist → ccw/dist}/core/lite-scanner-complete.d.ts +0 -0
  562. /package/{dist → ccw/dist}/core/lite-scanner.d.ts +0 -0
  563. /package/{dist → ccw/dist}/core/manifest.d.ts +0 -0
  564. /package/{dist → ccw/dist}/core/manifest.d.ts.map +0 -0
  565. /package/{dist → ccw/dist}/core/manifest.js +0 -0
  566. /package/{dist → ccw/dist}/core/manifest.js.map +0 -0
  567. /package/{dist → ccw/dist}/core/memory-embedder-bridge.d.ts +0 -0
  568. /package/{dist → ccw/dist}/core/memory-embedder-bridge.d.ts.map +0 -0
  569. /package/{dist → ccw/dist}/core/memory-embedder-bridge.js +0 -0
  570. /package/{dist → ccw/dist}/core/memory-embedder-bridge.js.map +0 -0
  571. /package/{dist → ccw/dist}/core/memory-store.d.ts +0 -0
  572. /package/{dist → ccw/dist}/core/memory-store.d.ts.map +0 -0
  573. /package/{dist → ccw/dist}/core/memory-store.js +0 -0
  574. /package/{dist → ccw/dist}/core/memory-store.js.map +0 -0
  575. /package/{dist → ccw/dist}/core/routes/ccw-routes.d.ts +0 -0
  576. /package/{dist → ccw/dist}/core/routes/ccw-routes.d.ts.map +0 -0
  577. /package/{dist → ccw/dist}/core/routes/ccw-routes.js +0 -0
  578. /package/{dist → ccw/dist}/core/routes/ccw-routes.js.map +0 -0
  579. /package/{dist → ccw/dist}/core/routes/claude-routes.d.ts +0 -0
  580. /package/{dist → ccw/dist}/core/routes/cli-routes.d.ts +0 -0
  581. /package/{dist → ccw/dist}/core/routes/codexlens-routes.d.ts +0 -0
  582. /package/{dist → ccw/dist}/core/routes/codexlens-routes.d.ts.map +0 -0
  583. /package/{dist → ccw/dist}/core/routes/codexlens-routes.js +0 -0
  584. /package/{dist → ccw/dist}/core/routes/codexlens-routes.js.map +0 -0
  585. /package/{dist → ccw/dist}/core/routes/core-memory-routes.d.ts +0 -0
  586. /package/{dist → ccw/dist}/core/routes/core-memory-routes.d.ts.map +0 -0
  587. /package/{dist → ccw/dist}/core/routes/core-memory-routes.js +0 -0
  588. /package/{dist → ccw/dist}/core/routes/core-memory-routes.js.map +0 -0
  589. /package/{dist → ccw/dist}/core/routes/files-routes.d.ts +0 -0
  590. /package/{dist → ccw/dist}/core/routes/files-routes.d.ts.map +0 -0
  591. /package/{dist → ccw/dist}/core/routes/files-routes.js +0 -0
  592. /package/{dist → ccw/dist}/core/routes/files-routes.js.map +0 -0
  593. /package/{dist → ccw/dist}/core/routes/graph-routes.d.ts +0 -0
  594. /package/{dist → ccw/dist}/core/routes/graph-routes.d.ts.map +0 -0
  595. /package/{dist → ccw/dist}/core/routes/graph-routes.js +0 -0
  596. /package/{dist → ccw/dist}/core/routes/graph-routes.js.map +0 -0
  597. /package/{dist → ccw/dist}/core/routes/help-routes.d.ts +0 -0
  598. /package/{dist → ccw/dist}/core/routes/help-routes.d.ts.map +0 -0
  599. /package/{dist → ccw/dist}/core/routes/help-routes.js +0 -0
  600. /package/{dist → ccw/dist}/core/routes/help-routes.js.map +0 -0
  601. /package/{dist → ccw/dist}/core/routes/hooks-routes.d.ts +0 -0
  602. /package/{dist → ccw/dist}/core/routes/hooks-routes.d.ts.map +0 -0
  603. /package/{dist → ccw/dist}/core/routes/hooks-routes.js +0 -0
  604. /package/{dist → ccw/dist}/core/routes/hooks-routes.js.map +0 -0
  605. /package/{dist → ccw/dist}/core/routes/mcp-routes.d.ts +0 -0
  606. /package/{dist → ccw/dist}/core/routes/mcp-routes.d.ts.map +0 -0
  607. /package/{dist → ccw/dist}/core/routes/mcp-routes.js +0 -0
  608. /package/{dist → ccw/dist}/core/routes/mcp-routes.js.map +0 -0
  609. /package/{dist → ccw/dist}/core/routes/mcp-templates-db.d.ts +0 -0
  610. /package/{dist → ccw/dist}/core/routes/mcp-templates-db.d.ts.map +0 -0
  611. /package/{dist → ccw/dist}/core/routes/mcp-templates-db.js +0 -0
  612. /package/{dist → ccw/dist}/core/routes/mcp-templates-db.js.map +0 -0
  613. /package/{dist → ccw/dist}/core/routes/memory-routes.d.ts +0 -0
  614. /package/{dist → ccw/dist}/core/routes/memory-routes.d.ts.map +0 -0
  615. /package/{dist → ccw/dist}/core/routes/memory-routes.js +0 -0
  616. /package/{dist → ccw/dist}/core/routes/memory-routes.js.map +0 -0
  617. /package/{dist → ccw/dist}/core/routes/rules-routes.d.ts +0 -0
  618. /package/{dist → ccw/dist}/core/routes/session-routes.d.ts +0 -0
  619. /package/{dist → ccw/dist}/core/routes/session-routes.d.ts.map +0 -0
  620. /package/{dist → ccw/dist}/core/routes/session-routes.js +0 -0
  621. /package/{dist → ccw/dist}/core/routes/session-routes.js.map +0 -0
  622. /package/{dist → ccw/dist}/core/routes/skills-routes.d.ts +0 -0
  623. /package/{dist → ccw/dist}/core/routes/status-routes.d.ts +0 -0
  624. /package/{dist → ccw/dist}/core/routes/status-routes.d.ts.map +0 -0
  625. /package/{dist → ccw/dist}/core/routes/status-routes.js +0 -0
  626. /package/{dist → ccw/dist}/core/routes/status-routes.js.map +0 -0
  627. /package/{dist → ccw/dist}/core/routes/system-routes.d.ts +0 -0
  628. /package/{dist → ccw/dist}/core/routes/system-routes.d.ts.map +0 -0
  629. /package/{dist → ccw/dist}/core/routes/system-routes.js +0 -0
  630. /package/{dist → ccw/dist}/core/routes/system-routes.js.map +0 -0
  631. /package/{dist → ccw/dist}/core/server.d.ts +0 -0
  632. /package/{dist → ccw/dist}/core/server.d.ts.map +0 -0
  633. /package/{dist → ccw/dist}/core/server.js +0 -0
  634. /package/{dist → ccw/dist}/core/server.js.map +0 -0
  635. /package/{dist → ccw/dist}/core/session-clustering-service.d.ts +0 -0
  636. /package/{dist → ccw/dist}/core/session-clustering-service.d.ts.map +0 -0
  637. /package/{dist → ccw/dist}/core/session-clustering-service.js +0 -0
  638. /package/{dist → ccw/dist}/core/session-clustering-service.js.map +0 -0
  639. /package/{dist → ccw/dist}/core/session-scanner.d.ts +0 -0
  640. /package/{dist → ccw/dist}/core/session-scanner.d.ts.map +0 -0
  641. /package/{dist → ccw/dist}/core/session-scanner.js +0 -0
  642. /package/{dist → ccw/dist}/core/session-scanner.js.map +0 -0
  643. /package/{dist → ccw/dist}/core/websocket.d.ts +0 -0
  644. /package/{dist → ccw/dist}/core/websocket.d.ts.map +0 -0
  645. /package/{dist → ccw/dist}/core/websocket.js +0 -0
  646. /package/{dist → ccw/dist}/core/websocket.js.map +0 -0
  647. /package/{dist → ccw/dist}/index.d.ts +0 -0
  648. /package/{dist → ccw/dist}/index.d.ts.map +0 -0
  649. /package/{dist → ccw/dist}/index.js +0 -0
  650. /package/{dist → ccw/dist}/index.js.map +0 -0
  651. /package/{dist → ccw/dist}/mcp-server/index.d.ts +0 -0
  652. /package/{dist → ccw/dist}/mcp-server/index.d.ts.map +0 -0
  653. /package/{dist → ccw/dist}/mcp-server/index.js +0 -0
  654. /package/{dist → ccw/dist}/mcp-server/index.js.map +0 -0
  655. /package/{dist → ccw/dist}/tools/classify-folders.d.ts +0 -0
  656. /package/{dist → ccw/dist}/tools/classify-folders.d.ts.map +0 -0
  657. /package/{dist → ccw/dist}/tools/classify-folders.js +0 -0
  658. /package/{dist → ccw/dist}/tools/classify-folders.js.map +0 -0
  659. /package/{dist → ccw/dist}/tools/cli-config-manager.d.ts +0 -0
  660. /package/{dist → ccw/dist}/tools/cli-config-manager.d.ts.map +0 -0
  661. /package/{dist → ccw/dist}/tools/cli-config-manager.js +0 -0
  662. /package/{dist → ccw/dist}/tools/cli-config-manager.js.map +0 -0
  663. /package/{dist → ccw/dist}/tools/cli-history-store.d.ts +0 -0
  664. /package/{dist → ccw/dist}/tools/cli-history-store.d.ts.map +0 -0
  665. /package/{dist → ccw/dist}/tools/cli-history-store.js +0 -0
  666. /package/{dist → ccw/dist}/tools/cli-history-store.js.map +0 -0
  667. /package/{dist → ccw/dist}/tools/codex-lens.d.ts +0 -0
  668. /package/{dist → ccw/dist}/tools/codex-lens.d.ts.map +0 -0
  669. /package/{dist → ccw/dist}/tools/codex-lens.js +0 -0
  670. /package/{dist → ccw/dist}/tools/codex-lens.js.map +0 -0
  671. /package/{dist → ccw/dist}/tools/convert-tokens-to-css.d.ts +0 -0
  672. /package/{dist → ccw/dist}/tools/convert-tokens-to-css.d.ts.map +0 -0
  673. /package/{dist → ccw/dist}/tools/convert-tokens-to-css.js +0 -0
  674. /package/{dist → ccw/dist}/tools/convert-tokens-to-css.js.map +0 -0
  675. /package/{dist → ccw/dist}/tools/core-memory.d.ts +0 -0
  676. /package/{dist → ccw/dist}/tools/core-memory.d.ts.map +0 -0
  677. /package/{dist → ccw/dist}/tools/core-memory.js +0 -0
  678. /package/{dist → ccw/dist}/tools/core-memory.js.map +0 -0
  679. /package/{dist → ccw/dist}/tools/detect-changed-modules.d.ts +0 -0
  680. /package/{dist → ccw/dist}/tools/detect-changed-modules.d.ts.map +0 -0
  681. /package/{dist → ccw/dist}/tools/detect-changed-modules.js +0 -0
  682. /package/{dist → ccw/dist}/tools/detect-changed-modules.js.map +0 -0
  683. /package/{dist → ccw/dist}/tools/discover-design-files.d.ts +0 -0
  684. /package/{dist → ccw/dist}/tools/discover-design-files.d.ts.map +0 -0
  685. /package/{dist → ccw/dist}/tools/discover-design-files.js +0 -0
  686. /package/{dist → ccw/dist}/tools/discover-design-files.js.map +0 -0
  687. /package/{dist → ccw/dist}/tools/edit-file.d.ts +0 -0
  688. /package/{dist → ccw/dist}/tools/edit-file.d.ts.map +0 -0
  689. /package/{dist → ccw/dist}/tools/edit-file.js +0 -0
  690. /package/{dist → ccw/dist}/tools/edit-file.js.map +0 -0
  691. /package/{dist → ccw/dist}/tools/generate-module-docs.d.ts +0 -0
  692. /package/{dist → ccw/dist}/tools/generate-module-docs.d.ts.map +0 -0
  693. /package/{dist → ccw/dist}/tools/generate-module-docs.js +0 -0
  694. /package/{dist → ccw/dist}/tools/generate-module-docs.js.map +0 -0
  695. /package/{dist → ccw/dist}/tools/get-modules-by-depth.d.ts +0 -0
  696. /package/{dist → ccw/dist}/tools/get-modules-by-depth.d.ts.map +0 -0
  697. /package/{dist → ccw/dist}/tools/get-modules-by-depth.js +0 -0
  698. /package/{dist → ccw/dist}/tools/get-modules-by-depth.js.map +0 -0
  699. /package/{dist → ccw/dist}/tools/index.d.ts +0 -0
  700. /package/{dist → ccw/dist}/tools/index.d.ts.map +0 -0
  701. /package/{dist → ccw/dist}/tools/index.js +0 -0
  702. /package/{dist → ccw/dist}/tools/index.js.map +0 -0
  703. /package/{dist → ccw/dist}/tools/native-session-discovery.d.ts +0 -0
  704. /package/{dist → ccw/dist}/tools/native-session-discovery.d.ts.map +0 -0
  705. /package/{dist → ccw/dist}/tools/native-session-discovery.js +0 -0
  706. /package/{dist → ccw/dist}/tools/native-session-discovery.js.map +0 -0
  707. /package/{dist → ccw/dist}/tools/notifier.d.ts +0 -0
  708. /package/{dist → ccw/dist}/tools/notifier.d.ts.map +0 -0
  709. /package/{dist → ccw/dist}/tools/notifier.js +0 -0
  710. /package/{dist → ccw/dist}/tools/notifier.js.map +0 -0
  711. /package/{dist → ccw/dist}/tools/read-file.d.ts +0 -0
  712. /package/{dist → ccw/dist}/tools/read-file.d.ts.map +0 -0
  713. /package/{dist → ccw/dist}/tools/read-file.js +0 -0
  714. /package/{dist → ccw/dist}/tools/read-file.js.map +0 -0
  715. /package/{dist → ccw/dist}/tools/resume-strategy.d.ts +0 -0
  716. /package/{dist → ccw/dist}/tools/resume-strategy.d.ts.map +0 -0
  717. /package/{dist → ccw/dist}/tools/resume-strategy.js +0 -0
  718. /package/{dist → ccw/dist}/tools/resume-strategy.js.map +0 -0
  719. /package/{dist → ccw/dist}/tools/session-content-parser.d.ts +0 -0
  720. /package/{dist → ccw/dist}/tools/session-content-parser.d.ts.map +0 -0
  721. /package/{dist → ccw/dist}/tools/session-content-parser.js +0 -0
  722. /package/{dist → ccw/dist}/tools/session-content-parser.js.map +0 -0
  723. /package/{dist → ccw/dist}/tools/session-manager.d.ts +0 -0
  724. /package/{dist → ccw/dist}/tools/session-manager.d.ts.map +0 -0
  725. /package/{dist → ccw/dist}/tools/session-manager.js +0 -0
  726. /package/{dist → ccw/dist}/tools/session-manager.js.map +0 -0
  727. /package/{dist → ccw/dist}/tools/smart-context.d.ts +0 -0
  728. /package/{dist → ccw/dist}/tools/smart-context.d.ts.map +0 -0
  729. /package/{dist → ccw/dist}/tools/smart-context.js +0 -0
  730. /package/{dist → ccw/dist}/tools/smart-context.js.map +0 -0
  731. /package/{dist → ccw/dist}/tools/smart-search.d.ts +0 -0
  732. /package/{dist → ccw/dist}/tools/smart-search.d.ts.map +0 -0
  733. /package/{dist → ccw/dist}/tools/smart-search.js +0 -0
  734. /package/{dist → ccw/dist}/tools/smart-search.js.map +0 -0
  735. /package/{dist → ccw/dist}/tools/storage-manager.d.ts +0 -0
  736. /package/{dist → ccw/dist}/tools/storage-manager.d.ts.map +0 -0
  737. /package/{dist → ccw/dist}/tools/storage-manager.js +0 -0
  738. /package/{dist → ccw/dist}/tools/storage-manager.js.map +0 -0
  739. /package/{dist → ccw/dist}/tools/ui-generate-preview.d.ts +0 -0
  740. /package/{dist → ccw/dist}/tools/ui-generate-preview.d.ts.map +0 -0
  741. /package/{dist → ccw/dist}/tools/ui-generate-preview.js +0 -0
  742. /package/{dist → ccw/dist}/tools/ui-generate-preview.js.map +0 -0
  743. /package/{dist → ccw/dist}/tools/ui-instantiate-prototypes.d.ts +0 -0
  744. /package/{dist → ccw/dist}/tools/ui-instantiate-prototypes.d.ts.map +0 -0
  745. /package/{dist → ccw/dist}/tools/ui-instantiate-prototypes.js +0 -0
  746. /package/{dist → ccw/dist}/tools/ui-instantiate-prototypes.js.map +0 -0
  747. /package/{dist → ccw/dist}/tools/update-module-claude.d.ts +0 -0
  748. /package/{dist → ccw/dist}/tools/update-module-claude.d.ts.map +0 -0
  749. /package/{dist → ccw/dist}/tools/update-module-claude.js +0 -0
  750. /package/{dist → ccw/dist}/tools/update-module-claude.js.map +0 -0
  751. /package/{dist → ccw/dist}/tools/write-file.d.ts +0 -0
  752. /package/{dist → ccw/dist}/tools/write-file.d.ts.map +0 -0
  753. /package/{dist → ccw/dist}/tools/write-file.js +0 -0
  754. /package/{dist → ccw/dist}/tools/write-file.js.map +0 -0
  755. /package/{dist → ccw/dist}/types/config.d.ts +0 -0
  756. /package/{dist → ccw/dist}/types/config.d.ts.map +0 -0
  757. /package/{dist → ccw/dist}/types/config.js +0 -0
  758. /package/{dist → ccw/dist}/types/config.js.map +0 -0
  759. /package/{dist → ccw/dist}/types/index.d.ts +0 -0
  760. /package/{dist → ccw/dist}/types/index.d.ts.map +0 -0
  761. /package/{dist → ccw/dist}/types/index.js +0 -0
  762. /package/{dist → ccw/dist}/types/index.js.map +0 -0
  763. /package/{dist → ccw/dist}/types/session.d.ts +0 -0
  764. /package/{dist → ccw/dist}/types/session.d.ts.map +0 -0
  765. /package/{dist → ccw/dist}/types/session.js +0 -0
  766. /package/{dist → ccw/dist}/types/session.js.map +0 -0
  767. /package/{dist → ccw/dist}/types/tool.d.ts +0 -0
  768. /package/{dist → ccw/dist}/types/tool.d.ts.map +0 -0
  769. /package/{dist → ccw/dist}/types/tool.js +0 -0
  770. /package/{dist → ccw/dist}/types/tool.js.map +0 -0
  771. /package/{dist → ccw/dist}/utils/browser-launcher.d.ts +0 -0
  772. /package/{dist → ccw/dist}/utils/browser-launcher.d.ts.map +0 -0
  773. /package/{dist → ccw/dist}/utils/browser-launcher.js +0 -0
  774. /package/{dist → ccw/dist}/utils/browser-launcher.js.map +0 -0
  775. /package/{dist → ccw/dist}/utils/file-utils.d.ts +0 -0
  776. /package/{dist → ccw/dist}/utils/file-utils.d.ts.map +0 -0
  777. /package/{dist → ccw/dist}/utils/file-utils.js +0 -0
  778. /package/{dist → ccw/dist}/utils/file-utils.js.map +0 -0
  779. /package/{dist → ccw/dist}/utils/path-resolver.d.ts +0 -0
  780. /package/{dist → ccw/dist}/utils/path-resolver.d.ts.map +0 -0
  781. /package/{dist → ccw/dist}/utils/path-resolver.js +0 -0
  782. /package/{dist → ccw/dist}/utils/path-resolver.js.map +0 -0
  783. /package/{dist → ccw/dist}/utils/path-validator.d.ts +0 -0
  784. /package/{dist → ccw/dist}/utils/path-validator.d.ts.map +0 -0
  785. /package/{dist → ccw/dist}/utils/path-validator.js +0 -0
  786. /package/{dist → ccw/dist}/utils/path-validator.js.map +0 -0
  787. /package/{dist → ccw/dist}/utils/ui.d.ts +0 -0
  788. /package/{dist → ccw/dist}/utils/ui.d.ts.map +0 -0
  789. /package/{dist → ccw/dist}/utils/ui.js +0 -0
  790. /package/{dist → ccw/dist}/utils/ui.js.map +0 -0
  791. /package/{src → ccw/src}/.workflow/.cli-history/history.db +0 -0
  792. /package/{src → ccw/src}/.workflow/.cli-history/history.db-shm +0 -0
  793. /package/{src → ccw/src}/.workflow/.cli-history/history.db-wal +0 -0
  794. /package/{src → ccw/src}/cli.ts +0 -0
  795. /package/{src → ccw/src}/commands/cli.ts +0 -0
  796. /package/{src → ccw/src}/commands/core-memory.ts +0 -0
  797. /package/{src → ccw/src}/commands/hook.ts +0 -0
  798. /package/{src → ccw/src}/commands/install.ts +0 -0
  799. /package/{src → ccw/src}/commands/list.ts +0 -0
  800. /package/{src → ccw/src}/commands/memory.ts +0 -0
  801. /package/{src → ccw/src}/commands/serve.ts +0 -0
  802. /package/{src → ccw/src}/commands/session-path-resolver.ts +0 -0
  803. /package/{src → ccw/src}/commands/session.ts +0 -0
  804. /package/{src → ccw/src}/commands/stop.ts +0 -0
  805. /package/{src → ccw/src}/commands/tool.ts +0 -0
  806. /package/{src → ccw/src}/commands/uninstall.ts +0 -0
  807. /package/{src → ccw/src}/commands/upgrade.ts +0 -0
  808. /package/{src → ccw/src}/commands/view.ts +0 -0
  809. /package/{src → ccw/src}/config/storage-paths.ts +0 -0
  810. /package/{src → ccw/src}/core/cache-manager.ts +0 -0
  811. /package/{src → ccw/src}/core/claude-freshness.ts +0 -0
  812. /package/{src → ccw/src}/core/core-memory-store.ts +0 -0
  813. /package/{src → ccw/src}/core/dashboard-generator-patch.ts +0 -0
  814. /package/{src → ccw/src}/core/dashboard-generator.ts +0 -0
  815. /package/{src → ccw/src}/core/data-aggregator.ts +0 -0
  816. /package/{src → ccw/src}/core/history-importer.ts +0 -0
  817. /package/{src → ccw/src}/core/manifest.ts +0 -0
  818. /package/{src → ccw/src}/core/memory-embedder-bridge.ts +0 -0
  819. /package/{src → ccw/src}/core/memory-store.ts +0 -0
  820. /package/{src → ccw/src}/core/routes/ccw-routes.ts +0 -0
  821. /package/{src → ccw/src}/core/routes/codexlens-routes.ts +0 -0
  822. /package/{src → ccw/src}/core/routes/core-memory-routes.ts +0 -0
  823. /package/{src → ccw/src}/core/routes/files-routes.ts +0 -0
  824. /package/{src → ccw/src}/core/routes/graph-routes.md +0 -0
  825. /package/{src → ccw/src}/core/routes/graph-routes.ts +0 -0
  826. /package/{src → ccw/src}/core/routes/help-routes.ts +0 -0
  827. /package/{src → ccw/src}/core/routes/hooks-routes.ts +0 -0
  828. /package/{src → ccw/src}/core/routes/mcp-routes.ts +0 -0
  829. /package/{src → ccw/src}/core/routes/mcp-routes.ts.backup +0 -0
  830. /package/{src → ccw/src}/core/routes/mcp-templates-db.ts +0 -0
  831. /package/{src → ccw/src}/core/routes/memory-routes.ts +0 -0
  832. /package/{src → ccw/src}/core/routes/session-routes.ts +0 -0
  833. /package/{src → ccw/src}/core/routes/status-routes.ts +0 -0
  834. /package/{src → ccw/src}/core/routes/system-routes.ts +0 -0
  835. /package/{src → ccw/src}/core/server.ts +0 -0
  836. /package/{src → ccw/src}/core/session-clustering-service.ts +0 -0
  837. /package/{src → ccw/src}/core/session-scanner.ts +0 -0
  838. /package/{src → ccw/src}/core/websocket.ts +0 -0
  839. /package/{src → ccw/src}/index.ts +0 -0
  840. /package/{src → ccw/src}/mcp-server/index.ts +0 -0
  841. /package/{src → ccw/src}/templates/assets/css/github-dark.min.css +0 -0
  842. /package/{src → ccw/src}/templates/assets/css/github.min.css +0 -0
  843. /package/{src → ccw/src}/templates/assets/js/cytoscape.min.js +0 -0
  844. /package/{src → ccw/src}/templates/assets/js/d3.min.js +0 -0
  845. /package/{src → ccw/src}/templates/assets/js/highlight.min.js +0 -0
  846. /package/{src → ccw/src}/templates/assets/js/lucide.min.js +0 -0
  847. /package/{src → ccw/src}/templates/assets/js/marked.min.js +0 -0
  848. /package/{src → ccw/src}/templates/assets/js/tailwind.js +0 -0
  849. /package/{src → ccw/src}/templates/dashboard-css/01-base.css +0 -0
  850. /package/{src → ccw/src}/templates/dashboard-css/02-session.css +0 -0
  851. /package/{src → ccw/src}/templates/dashboard-css/03-tasks.css +0 -0
  852. /package/{src → ccw/src}/templates/dashboard-css/04-lite-tasks.css +0 -0
  853. /package/{src → ccw/src}/templates/dashboard-css/05-context.css +0 -0
  854. /package/{src → ccw/src}/templates/dashboard-css/06-cards.css +0 -0
  855. /package/{src → ccw/src}/templates/dashboard-css/07-managers.css +0 -0
  856. /package/{src → ccw/src}/templates/dashboard-css/08-review.css +0 -0
  857. /package/{src → ccw/src}/templates/dashboard-css/09-explorer.css +0 -0
  858. /package/{src → ccw/src}/templates/dashboard-css/10-cli-status.css +0 -0
  859. /package/{src → ccw/src}/templates/dashboard-css/11-cli-history.css +0 -0
  860. /package/{src → ccw/src}/templates/dashboard-css/12-cli-legacy.css +0 -0
  861. /package/{src → ccw/src}/templates/dashboard-css/13-cli-ccw.css +0 -0
  862. /package/{src → ccw/src}/templates/dashboard-css/14-cli-modals.css +0 -0
  863. /package/{src → ccw/src}/templates/dashboard-css/15-cli-endpoints.css +0 -0
  864. /package/{src → ccw/src}/templates/dashboard-css/16-cli-session.css +0 -0
  865. /package/{src → ccw/src}/templates/dashboard-css/17-cli-conversation.css +0 -0
  866. /package/{src → ccw/src}/templates/dashboard-css/18-cli-settings.css +0 -0
  867. /package/{src → ccw/src}/templates/dashboard-css/19-cli-native-session.css +0 -0
  868. /package/{src → ccw/src}/templates/dashboard-css/20-cli-taskqueue.css +0 -0
  869. /package/{src → ccw/src}/templates/dashboard-css/21-cli-toolmgmt.css +0 -0
  870. /package/{src → ccw/src}/templates/dashboard-css/22-cli-semantic.css +0 -0
  871. /package/{src → ccw/src}/templates/dashboard-css/23-memory.css +0 -0
  872. /package/{src → ccw/src}/templates/dashboard-css/24-prompt-history.css +0 -0
  873. /package/{src → ccw/src}/templates/dashboard-css/25-skills-rules.css +0 -0
  874. /package/{src → ccw/src}/templates/dashboard-css/26-claude-manager.css +0 -0
  875. /package/{src → ccw/src}/templates/dashboard-css/27-graph-explorer.css +0 -0
  876. /package/{src → ccw/src}/templates/dashboard-css/28-mcp-manager.css +0 -0
  877. /package/{src → ccw/src}/templates/dashboard-css/29-help.css +0 -0
  878. /package/{src → ccw/src}/templates/dashboard-css/30-core-memory.css +0 -0
  879. /package/{src → ccw/src}/templates/dashboard-js/api.js +0 -0
  880. /package/{src → ccw/src}/templates/dashboard-js/components/_conflict_tab.js +0 -0
  881. /package/{src → ccw/src}/templates/dashboard-js/components/_exp_helpers.js +0 -0
  882. /package/{src → ccw/src}/templates/dashboard-js/components/_review_tab.js +0 -0
  883. /package/{src → ccw/src}/templates/dashboard-js/components/carousel.js +0 -0
  884. /package/{src → ccw/src}/templates/dashboard-js/components/cli-history.js +0 -0
  885. /package/{src → ccw/src}/templates/dashboard-js/components/cli-status.js +0 -0
  886. /package/{src → ccw/src}/templates/dashboard-js/components/flowchart.js +0 -0
  887. /package/{src → ccw/src}/templates/dashboard-js/components/global-notifications.js +0 -0
  888. /package/{src → ccw/src}/templates/dashboard-js/components/hook-manager.js +0 -0
  889. /package/{src → ccw/src}/templates/dashboard-js/components/index-manager.js +0 -0
  890. /package/{src → ccw/src}/templates/dashboard-js/components/mcp-manager.js +0 -0
  891. /package/{src → ccw/src}/templates/dashboard-js/components/modals.js +0 -0
  892. /package/{src → ccw/src}/templates/dashboard-js/components/navigation.js +0 -0
  893. /package/{src → ccw/src}/templates/dashboard-js/components/notifications.js +0 -0
  894. /package/{src → ccw/src}/templates/dashboard-js/components/sidebar.js +0 -0
  895. /package/{src → ccw/src}/templates/dashboard-js/components/storage-manager.js +0 -0
  896. /package/{src → ccw/src}/templates/dashboard-js/components/tabs-context.js +0 -0
  897. /package/{src → ccw/src}/templates/dashboard-js/components/tabs-other.js +0 -0
  898. /package/{src → ccw/src}/templates/dashboard-js/components/task-drawer-core.js +0 -0
  899. /package/{src → ccw/src}/templates/dashboard-js/components/task-drawer-renderers.js +0 -0
  900. /package/{src → ccw/src}/templates/dashboard-js/components/task-queue-sidebar.js +0 -0
  901. /package/{src → ccw/src}/templates/dashboard-js/components/theme.js +0 -0
  902. /package/{src → ccw/src}/templates/dashboard-js/components/version-check.js +0 -0
  903. /package/{src → ccw/src}/templates/dashboard-js/help-i18n.js +0 -0
  904. /package/{src → ccw/src}/templates/dashboard-js/main.js +0 -0
  905. /package/{src → ccw/src}/templates/dashboard-js/state.js +0 -0
  906. /package/{src → ccw/src}/templates/dashboard-js/utils.js +0 -0
  907. /package/{src → ccw/src}/templates/dashboard-js/views/codexlens-manager.js +0 -0
  908. /package/{src → ccw/src}/templates/dashboard-js/views/core-memory-clusters.js +0 -0
  909. /package/{src → ccw/src}/templates/dashboard-js/views/core-memory.js +0 -0
  910. /package/{src → ccw/src}/templates/dashboard-js/views/explorer.js +0 -0
  911. /package/{src → ccw/src}/templates/dashboard-js/views/fix-session.js +0 -0
  912. /package/{src → ccw/src}/templates/dashboard-js/views/graph-explorer.js +0 -0
  913. /package/{src → ccw/src}/templates/dashboard-js/views/help.js +0 -0
  914. /package/{src → ccw/src}/templates/dashboard-js/views/history.js +0 -0
  915. /package/{src → ccw/src}/templates/dashboard-js/views/home.js +0 -0
  916. /package/{src → ccw/src}/templates/dashboard-js/views/hook-manager.js +0 -0
  917. /package/{src → ccw/src}/templates/dashboard-js/views/lite-tasks.js +0 -0
  918. /package/{src → ccw/src}/templates/dashboard-js/views/mcp-manager.js +0 -0
  919. /package/{src → ccw/src}/templates/dashboard-js/views/mcp-manager.js.backup +0 -0
  920. /package/{src → ccw/src}/templates/dashboard-js/views/mcp-manager.js.new +0 -0
  921. /package/{src → ccw/src}/templates/dashboard-js/views/memory.js +0 -0
  922. /package/{src → ccw/src}/templates/dashboard-js/views/project-overview.js +0 -0
  923. /package/{src → ccw/src}/templates/dashboard-js/views/prompt-history.js +0 -0
  924. /package/{src → ccw/src}/templates/dashboard-js/views/review-session.js +0 -0
  925. /package/{src → ccw/src}/templates/dashboard-js/views/session-detail.js +0 -0
  926. /package/{src → ccw/src}/templates/dashboard.html +0 -0
  927. /package/{src → ccw/src}/templates/hooks-config-example.json +0 -0
  928. /package/{src → ccw/src}/templates/review-cycle-dashboard.html +0 -0
  929. /package/{src → ccw/src}/templates/workflow-dashboard.html +0 -0
  930. /package/{src → ccw/src}/tools/classify-folders.ts +0 -0
  931. /package/{src → ccw/src}/tools/cli-config-manager.ts +0 -0
  932. /package/{src → ccw/src}/tools/cli-history-store.ts +0 -0
  933. /package/{src → ccw/src}/tools/codex-lens.ts +0 -0
  934. /package/{src → ccw/src}/tools/convert-tokens-to-css.ts +0 -0
  935. /package/{src → ccw/src}/tools/core-memory.ts +0 -0
  936. /package/{src → ccw/src}/tools/detect-changed-modules.ts +0 -0
  937. /package/{src → ccw/src}/tools/discover-design-files.ts +0 -0
  938. /package/{src → ccw/src}/tools/edit-file.ts +0 -0
  939. /package/{src → ccw/src}/tools/generate-module-docs.ts +0 -0
  940. /package/{src → ccw/src}/tools/get-modules-by-depth.ts +0 -0
  941. /package/{src → ccw/src}/tools/index.ts +0 -0
  942. /package/{src → ccw/src}/tools/native-session-discovery.ts +0 -0
  943. /package/{src → ccw/src}/tools/notifier.ts +0 -0
  944. /package/{src → ccw/src}/tools/read-file.ts +0 -0
  945. /package/{src → ccw/src}/tools/resume-strategy.ts +0 -0
  946. /package/{src → ccw/src}/tools/session-content-parser.ts +0 -0
  947. /package/{src → ccw/src}/tools/session-manager.ts +0 -0
  948. /package/{src → ccw/src}/tools/smart-context.ts +0 -0
  949. /package/{src → ccw/src}/tools/smart-search.ts +0 -0
  950. /package/{src → ccw/src}/tools/smart-search.ts.backup +0 -0
  951. /package/{src → ccw/src}/tools/storage-manager.ts +0 -0
  952. /package/{src → ccw/src}/tools/ui-generate-preview.js +0 -0
  953. /package/{src → ccw/src}/tools/ui-instantiate-prototypes.js +0 -0
  954. /package/{src → ccw/src}/tools/update-module-claude.js +0 -0
  955. /package/{src → ccw/src}/tools/write-file.ts +0 -0
  956. /package/{src → ccw/src}/types/config.ts +0 -0
  957. /package/{src → ccw/src}/types/index.ts +0 -0
  958. /package/{src → ccw/src}/types/session.ts +0 -0
  959. /package/{src → ccw/src}/types/tool.ts +0 -0
  960. /package/{src → ccw/src}/utils/browser-launcher.ts +0 -0
  961. /package/{src → ccw/src}/utils/file-utils.ts +0 -0
  962. /package/{src → ccw/src}/utils/path-resolver.ts +0 -0
  963. /package/{src → ccw/src}/utils/path-validator.ts +0 -0
  964. /package/{src → ccw/src}/utils/ui.ts +0 -0
@@ -0,0 +1,2274 @@
1
+ // CLI Manager View
2
+ // Main view combining CLI status and CCW installations panels (two-column layout)
3
+
4
+ // ========== CLI Manager State ==========
5
+ var currentCliExecution = null;
6
+ var cliExecutionOutput = '';
7
+ var ccwInstallations = [];
8
+ var ccwEndpointTools = [];
9
+ var cliToolConfig = null; // Store loaded CLI config
10
+ var predefinedModels = {}; // Store predefined models per tool
11
+
12
+ // ========== CCW Installations ==========
13
+ async function loadCcwInstallations() {
14
+ try {
15
+ var response = await fetch('/api/ccw/installations');
16
+ if (!response.ok) throw new Error('Failed to load CCW installations');
17
+ var data = await response.json();
18
+ ccwInstallations = data.installations || [];
19
+ return ccwInstallations;
20
+ } catch (err) {
21
+ console.error('Failed to load CCW installations:', err);
22
+ ccwInstallations = [];
23
+ return [];
24
+ }
25
+ }
26
+
27
+ // ========== CCW Endpoint Tools ==========
28
+ async function loadCcwEndpointTools() {
29
+ try {
30
+ var response = await fetch('/api/ccw/tools');
31
+ if (!response.ok) throw new Error('Failed to load CCW endpoint tools');
32
+ var data = await response.json();
33
+ ccwEndpointTools = data.tools || [];
34
+ return ccwEndpointTools;
35
+ } catch (err) {
36
+ console.error('Failed to load CCW endpoint tools:', err);
37
+ ccwEndpointTools = [];
38
+ return [];
39
+ }
40
+ }
41
+
42
+ // ========== CLI Tool Configuration ==========
43
+ async function loadCliToolConfig() {
44
+ try {
45
+ var response = await fetch('/api/cli/config');
46
+ if (!response.ok) throw new Error('Failed to load CLI config');
47
+ var data = await response.json();
48
+ cliToolConfig = data.config || null;
49
+ predefinedModels = data.predefinedModels || {};
50
+ return data;
51
+ } catch (err) {
52
+ console.error('Failed to load CLI config:', err);
53
+ cliToolConfig = null;
54
+ predefinedModels = {};
55
+ return null;
56
+ }
57
+ }
58
+
59
+ async function updateCliToolConfig(tool, updates) {
60
+ try {
61
+ var response = await fetch('/api/cli/config/' + tool, {
62
+ method: 'PUT',
63
+ headers: { 'Content-Type': 'application/json' },
64
+ body: JSON.stringify(updates)
65
+ });
66
+ if (!response.ok) throw new Error('Failed to update CLI config');
67
+ var data = await response.json();
68
+ if (data.success && cliToolConfig && cliToolConfig.tools) {
69
+ cliToolConfig.tools[tool] = data.config;
70
+ }
71
+ return data;
72
+ } catch (err) {
73
+ console.error('Failed to update CLI config:', err);
74
+ throw err;
75
+ }
76
+ }
77
+
78
+ // ========== Tool Configuration Modal ==========
79
+ async function showToolConfigModal(toolName) {
80
+ // Load config if not already loaded
81
+ if (!cliToolConfig) {
82
+ await loadCliToolConfig();
83
+ }
84
+
85
+ var toolConfig = cliToolConfig && cliToolConfig.tools ? cliToolConfig.tools[toolName] : null;
86
+ var models = predefinedModels[toolName] || [];
87
+ var status = cliToolStatus[toolName] || {};
88
+
89
+ if (!toolConfig) {
90
+ toolConfig = { enabled: true, primaryModel: '', secondaryModel: '' };
91
+ }
92
+
93
+ var content = buildToolConfigModalContent(toolName, toolConfig, models, status);
94
+ showModal('Configure ' + toolName.charAt(0).toUpperCase() + toolName.slice(1), content, { size: 'md' });
95
+
96
+ // Initialize event handlers after modal is shown
97
+ setTimeout(function() {
98
+ initToolConfigModalEvents(toolName, toolConfig, models);
99
+ }, 100);
100
+ }
101
+
102
+ function buildToolConfigModalContent(tool, config, models, status) {
103
+ var isAvailable = status.available;
104
+ var isEnabled = config.enabled;
105
+
106
+ // Check if model is custom (not in predefined list or empty)
107
+ var isPrimaryCustom = !config.primaryModel || models.indexOf(config.primaryModel) === -1;
108
+ var isSecondaryCustom = !config.secondaryModel || models.indexOf(config.secondaryModel) === -1;
109
+
110
+ var modelsOptionsHtml = function(selected, isCustom) {
111
+ var html = '';
112
+ for (var i = 0; i < models.length; i++) {
113
+ var m = models[i];
114
+ html += '<option value="' + escapeHtml(m) + '"' + (m === selected && !isCustom ? ' selected' : '') + '>' + escapeHtml(m) + '</option>';
115
+ }
116
+ html += '<option value="__custom__"' + (isCustom ? ' selected' : '') + '>Custom...</option>';
117
+ return html;
118
+ };
119
+
120
+ return '<div class="tool-config-modal">' +
121
+ // Status Section
122
+ '<div class="tool-config-section">' +
123
+ '<h4>Status</h4>' +
124
+ '<div class="tool-config-badges">' +
125
+ '<span class="badge ' + (isAvailable ? 'badge-success' : 'badge-muted') + '">' +
126
+ '<i data-lucide="' + (isAvailable ? 'check-circle' : 'circle-dashed') + '" class="w-3 h-3"></i> ' +
127
+ (isAvailable ? 'Installed' : 'Not Installed') +
128
+ '</span>' +
129
+ '<span class="badge ' + (isEnabled ? 'badge-primary' : 'badge-muted') + '">' +
130
+ '<i data-lucide="' + (isEnabled ? 'toggle-right' : 'toggle-left') + '" class="w-3 h-3"></i> ' +
131
+ (isEnabled ? 'Enabled' : 'Disabled') +
132
+ '</span>' +
133
+ '</div>' +
134
+ '</div>' +
135
+
136
+ // Actions Section
137
+ '<div class="tool-config-section">' +
138
+ '<h4>Actions</h4>' +
139
+ '<div class="tool-config-actions">' +
140
+ '<button class="btn-sm ' + (isEnabled ? 'btn-outline' : 'btn-primary') + '" id="toggleEnableBtn" ' + (!isAvailable ? 'disabled' : '') + '>' +
141
+ '<i data-lucide="' + (isEnabled ? 'toggle-left' : 'toggle-right') + '" class="w-3 h-3"></i> ' +
142
+ (isEnabled ? 'Disable' : 'Enable') +
143
+ '</button>' +
144
+ '<button class="btn-sm ' + (isAvailable ? 'btn-outline btn-danger-outline' : 'btn-primary') + '" id="installBtn">' +
145
+ '<i data-lucide="' + (isAvailable ? 'trash-2' : 'download') + '" class="w-3 h-3"></i> ' +
146
+ (isAvailable ? 'Uninstall' : 'Install') +
147
+ '</button>' +
148
+ '</div>' +
149
+ '</div>' +
150
+
151
+ // Primary Model Section
152
+ '<div class="tool-config-section">' +
153
+ '<h4>Primary Model <span class="text-muted">(CLI endpoint calls)</span></h4>' +
154
+ '<div class="model-select-group">' +
155
+ '<select id="primaryModelSelect" class="tool-config-select">' +
156
+ modelsOptionsHtml(config.primaryModel, isPrimaryCustom) +
157
+ '</select>' +
158
+ '<input type="text" id="primaryModelCustom" class="tool-config-input" ' +
159
+ 'style="display: ' + (isPrimaryCustom ? 'block' : 'none') + ';" ' +
160
+ 'placeholder="Enter model name (e.g., gemini-2.5-pro)" ' +
161
+ 'value="' + (isPrimaryCustom && config.primaryModel ? escapeHtml(config.primaryModel) : '') + '" />' +
162
+ '</div>' +
163
+ '</div>' +
164
+
165
+ // Secondary Model Section
166
+ '<div class="tool-config-section">' +
167
+ '<h4>Secondary Model <span class="text-muted">(internal tools)</span></h4>' +
168
+ '<div class="model-select-group">' +
169
+ '<select id="secondaryModelSelect" class="tool-config-select">' +
170
+ modelsOptionsHtml(config.secondaryModel, isSecondaryCustom) +
171
+ '</select>' +
172
+ '<input type="text" id="secondaryModelCustom" class="tool-config-input" ' +
173
+ 'style="display: ' + (isSecondaryCustom ? 'block' : 'none') + ';" ' +
174
+ 'placeholder="Enter model name (e.g., gemini-2.5-flash)" ' +
175
+ 'value="' + (isSecondaryCustom && config.secondaryModel ? escapeHtml(config.secondaryModel) : '') + '" />' +
176
+ '</div>' +
177
+ '</div>' +
178
+
179
+ // Footer
180
+ '<div class="tool-config-footer">' +
181
+ '<button class="btn btn-outline" onclick="closeModal()">' + t('common.cancel') + '</button>' +
182
+ '<button class="btn btn-primary" id="saveConfigBtn">' +
183
+ '<i data-lucide="save" class="w-3.5 h-3.5"></i> ' + t('common.save') +
184
+ '</button>' +
185
+ '</div>' +
186
+ '</div>';
187
+ }
188
+
189
+ function initToolConfigModalEvents(tool, currentConfig, models) {
190
+ // Toggle Enable/Disable
191
+ var toggleBtn = document.getElementById('toggleEnableBtn');
192
+ if (toggleBtn) {
193
+ toggleBtn.onclick = async function() {
194
+ var newEnabled = !currentConfig.enabled;
195
+ try {
196
+ await updateCliToolConfig(tool, { enabled: newEnabled });
197
+ showRefreshToast(tool + ' ' + (newEnabled ? 'enabled' : 'disabled'), 'success');
198
+ closeModal();
199
+ renderToolsSection();
200
+ if (window.lucide) lucide.createIcons();
201
+ } catch (err) {
202
+ showRefreshToast('Failed to update: ' + err.message, 'error');
203
+ }
204
+ };
205
+ }
206
+
207
+ // Install/Uninstall
208
+ var installBtn = document.getElementById('installBtn');
209
+ if (installBtn) {
210
+ installBtn.onclick = function() {
211
+ var status = cliToolStatus[tool] || {};
212
+ closeModal();
213
+
214
+ if (status.available) {
215
+ openCliUninstallWizard(tool);
216
+ } else {
217
+ openCliInstallWizard(tool);
218
+ }
219
+ };
220
+ }
221
+
222
+ // Model select handlers
223
+ var primarySelect = document.getElementById('primaryModelSelect');
224
+ var primaryCustom = document.getElementById('primaryModelCustom');
225
+ var secondarySelect = document.getElementById('secondaryModelSelect');
226
+ var secondaryCustom = document.getElementById('secondaryModelCustom');
227
+
228
+ if (primarySelect && primaryCustom) {
229
+ primarySelect.onchange = function() {
230
+ if (this.value === '__custom__') {
231
+ primaryCustom.style.display = 'block';
232
+ primaryCustom.focus();
233
+ } else {
234
+ primaryCustom.style.display = 'none';
235
+ primaryCustom.value = '';
236
+ }
237
+ };
238
+ }
239
+
240
+ if (secondarySelect && secondaryCustom) {
241
+ secondarySelect.onchange = function() {
242
+ if (this.value === '__custom__') {
243
+ secondaryCustom.style.display = 'block';
244
+ secondaryCustom.focus();
245
+ } else {
246
+ secondaryCustom.style.display = 'none';
247
+ secondaryCustom.value = '';
248
+ }
249
+ };
250
+ }
251
+
252
+ // Save button
253
+ var saveBtn = document.getElementById('saveConfigBtn');
254
+ if (saveBtn) {
255
+ saveBtn.onclick = async function() {
256
+ var primaryModel = primarySelect.value === '__custom__'
257
+ ? primaryCustom.value.trim()
258
+ : primarySelect.value;
259
+ var secondaryModel = secondarySelect.value === '__custom__'
260
+ ? secondaryCustom.value.trim()
261
+ : secondarySelect.value;
262
+
263
+ if (!primaryModel) {
264
+ showRefreshToast('Primary model is required', 'error');
265
+ return;
266
+ }
267
+ if (!secondaryModel) {
268
+ showRefreshToast('Secondary model is required', 'error');
269
+ return;
270
+ }
271
+
272
+ try {
273
+ await updateCliToolConfig(tool, {
274
+ primaryModel: primaryModel,
275
+ secondaryModel: secondaryModel
276
+ });
277
+ showRefreshToast('Configuration saved', 'success');
278
+ closeModal();
279
+ } catch (err) {
280
+ showRefreshToast('Failed to save: ' + err.message, 'error');
281
+ }
282
+ };
283
+ }
284
+
285
+ // Initialize lucide icons in modal
286
+ if (window.lucide) lucide.createIcons();
287
+ }
288
+
289
+ // ========== Rendering ==========
290
+ async function renderCliManager() {
291
+ var container = document.getElementById('mainContent');
292
+ if (!container) return;
293
+
294
+ // Hide stats grid and search for CLI view
295
+ var statsGrid = document.getElementById('statsGrid');
296
+ var searchInput = document.getElementById('searchInput');
297
+ if (statsGrid) statsGrid.style.display = 'none';
298
+ if (searchInput) searchInput.parentElement.style.display = 'none';
299
+
300
+ // Load data (including CodexLens status for tools section)
301
+ await Promise.all([
302
+ loadCliToolStatus(),
303
+ loadCodexLensStatus(),
304
+ loadCcwInstallations(),
305
+ loadCcwEndpointTools()
306
+ ]);
307
+
308
+ container.innerHTML = '<div class="status-manager">' +
309
+ '<div class="status-two-column">' +
310
+ '<div class="cli-section" id="tools-section"></div>' +
311
+ '<div class="cli-section" id="ccw-section"></div>' +
312
+ '</div>' +
313
+ '<div class="cli-section" id="language-settings-section" style="margin-top: 1.5rem;"></div>' +
314
+ '<div class="cli-settings-section" id="cli-settings-section" style="margin-top: 1.5rem;"></div>' +
315
+ '<div class="cli-section" id="ccw-endpoint-tools-section" style="margin-top: 1.5rem;"></div>' +
316
+ '</div>' +
317
+ '<section id="storageCard" class="mb-6"></section>' +
318
+ '<section id="indexCard" class="mb-6"></section>';
319
+
320
+ // Render sub-panels
321
+ renderToolsSection();
322
+ renderCcwSection();
323
+ renderLanguageSettingsSection();
324
+ renderCliSettingsSection();
325
+ renderCcwEndpointToolsSection();
326
+
327
+ // Initialize storage manager card
328
+ if (typeof initStorageManager === 'function') {
329
+ initStorageManager();
330
+ }
331
+
332
+ // Initialize index manager card
333
+ if (typeof initIndexManager === 'function') {
334
+ initIndexManager();
335
+ }
336
+
337
+ // Initialize Lucide icons
338
+ if (window.lucide) lucide.createIcons();
339
+ }
340
+
341
+ // ========== Helper Functions ==========
342
+
343
+ /**
344
+ * Get selected embedding model from dropdown
345
+ * @returns {string} Selected model profile (code, fast, multilingual, balanced)
346
+ */
347
+ function getSelectedModel() {
348
+ var select = document.getElementById('codexlensModelSelect');
349
+ return select ? select.value : 'code';
350
+ }
351
+
352
+ // ========== Tools Section (Left Column) ==========
353
+ function renderToolsSection() {
354
+ var container = document.getElementById('tools-section');
355
+ if (!container) return;
356
+
357
+ var toolDescriptions = {
358
+ gemini: t('cli.geminiDesc'),
359
+ qwen: t('cli.qwenDesc'),
360
+ codex: t('cli.codexDesc')
361
+ };
362
+
363
+ var tools = ['gemini', 'qwen', 'codex'];
364
+ var available = Object.values(cliToolStatus).filter(function(t) { return t.available; }).length;
365
+
366
+ var toolsHtml = tools.map(function(tool) {
367
+ var status = cliToolStatus[tool] || {};
368
+ var isAvailable = status.available;
369
+ var isDefault = defaultCliTool === tool;
370
+
371
+ return '<div class="tool-item clickable ' + (isAvailable ? 'available' : 'unavailable') + '" onclick="showToolConfigModal(\'' + tool + '\')">' +
372
+ '<div class="tool-item-left">' +
373
+ '<span class="tool-status-dot ' + (isAvailable ? 'status-available' : 'status-unavailable') + '"></span>' +
374
+ '<div class="tool-item-info">' +
375
+ '<div class="tool-item-name">' + tool.charAt(0).toUpperCase() + tool.slice(1) +
376
+ (isDefault ? '<span class="tool-default-badge">' + t('cli.default') + '</span>' : '') +
377
+ '<i data-lucide="settings" class="w-3 h-3 tool-config-icon"></i>' +
378
+ '</div>' +
379
+ '<div class="tool-item-desc">' + toolDescriptions[tool] + '</div>' +
380
+ '</div>' +
381
+ '</div>' +
382
+ '<div class="tool-item-right">' +
383
+ (isAvailable
384
+ ? '<span class="tool-status-text success"><i data-lucide="check-circle" class="w-3.5 h-3.5"></i> ' + t('cli.ready') + '</span>'
385
+ : '<span class="tool-status-text muted"><i data-lucide="circle-dashed" class="w-3.5 h-3.5"></i> ' + t('cli.notInstalled') + '</span>') +
386
+ (isAvailable && !isDefault
387
+ ? '<button class="btn-sm btn-outline" onclick="event.stopPropagation(); setDefaultCliTool(\'' + tool + '\')"><i data-lucide="star" class="w-3 h-3"></i> ' + t('cli.setDefault') + '</button>'
388
+ : '') +
389
+ '</div>' +
390
+ '</div>';
391
+ }).join('');
392
+
393
+ // CodexLens item
394
+ var codexLensHtml = '<div class="tool-item clickable ' + (codexLensStatus.ready ? 'available' : 'unavailable') + '" onclick="showCodexLensConfigModal()">' +
395
+ '<div class="tool-item-left">' +
396
+ '<span class="tool-status-dot ' + (codexLensStatus.ready ? 'status-available' : 'status-unavailable') + '"></span>' +
397
+ '<div class="tool-item-info">' +
398
+ '<div class="tool-item-name">CodexLens <span class="tool-type-badge">Index</span>' +
399
+ '<i data-lucide="settings" class="w-3 h-3 tool-config-icon"></i></div>' +
400
+ '<div class="tool-item-desc">' + (codexLensStatus.ready ? t('cli.codexLensDesc') : t('cli.codexLensDescFull')) + '</div>' +
401
+ '</div>' +
402
+ '</div>' +
403
+ '<div class="tool-item-right">' +
404
+ (codexLensStatus.ready
405
+ ? '<span class="tool-status-text success"><i data-lucide="check-circle" class="w-3.5 h-3.5"></i> v' + (codexLensStatus.version || 'installed') + '</span>' +
406
+ '<select id="codexlensModelSelect" class="btn-sm bg-muted border border-border rounded text-xs" onclick="event.stopPropagation()" title="' + (t('index.selectModel') || 'Select embedding model') + '">' +
407
+ '<option value="code">' + (t('index.modelCode') || 'Code (768d)') + ' ⭐</option>' +
408
+ '<option value="base">' + (t('index.modelBase') || 'Base (768d)') + '</option>' +
409
+ '<option value="fast">' + (t('index.modelFast') || 'Fast (384d)') + '</option>' +
410
+ '<option value="minilm">' + (t('index.modelMinilm') || 'MiniLM (384d)') + '</option>' +
411
+ '<option value="multilingual" style="color: var(--muted-foreground)">' + (t('index.modelMultilingual') || 'Multilingual (1024d)') + ' ⚠️</option>' +
412
+ '<option value="balanced" style="color: var(--muted-foreground)">' + (t('index.modelBalanced') || 'Balanced (1024d)') + ' ⚠️</option>' +
413
+ '</select>' +
414
+ '<button class="btn-sm btn-primary" onclick="event.stopPropagation(); initCodexLensIndex(\'full\', getSelectedModel())" title="' + (t('index.fullDesc') || 'FTS + Semantic search (recommended)') + '"><i data-lucide="layers" class="w-3 h-3"></i> ' + (t('index.fullIndex') || '全部索引') + '</button>' +
415
+ '<button class="btn-sm btn-outline" onclick="event.stopPropagation(); initCodexLensIndex(\'vector\', getSelectedModel())" title="' + (t('index.vectorDesc') || 'Semantic search with embeddings') + '"><i data-lucide="sparkles" class="w-3 h-3"></i> ' + (t('index.vectorIndex') || '向量索引') + '</button>' +
416
+ '<button class="btn-sm btn-outline" onclick="event.stopPropagation(); initCodexLensIndex(\'normal\')" title="' + (t('index.normalDesc') || 'Fast full-text search only') + '"><i data-lucide="file-text" class="w-3 h-3"></i> ' + (t('index.normalIndex') || 'FTS索引') + '</button>' +
417
+ '<button class="btn-sm btn-outline btn-danger" onclick="event.stopPropagation(); uninstallCodexLens()"><i data-lucide="trash-2" class="w-3 h-3"></i> ' + t('cli.uninstall') + '</button>'
418
+ : '<span class="tool-status-text muted"><i data-lucide="circle-dashed" class="w-3.5 h-3.5"></i> ' + t('cli.notInstalled') + '</span>' +
419
+ '<button class="btn-sm btn-primary" onclick="event.stopPropagation(); installCodexLens()"><i data-lucide="download" class="w-3 h-3"></i> ' + t('cli.install') + '</button>') +
420
+ '</div>' +
421
+ '</div>';
422
+
423
+ // Semantic Search item (only show if CodexLens is installed)
424
+ var semanticHtml = '';
425
+ if (codexLensStatus.ready) {
426
+ semanticHtml = '<div class="tool-item ' + (semanticStatus.available ? 'available' : 'unavailable') + '">' +
427
+ '<div class="tool-item-left">' +
428
+ '<span class="tool-status-dot ' + (semanticStatus.available ? 'status-available' : 'status-unavailable') + '"></span>' +
429
+ '<div class="tool-item-info">' +
430
+ '<div class="tool-item-name">Semantic Search <span class="tool-type-badge ai">AI</span></div>' +
431
+ '<div class="tool-item-desc">' + (semanticStatus.available ? 'AI-powered code understanding' : 'Natural language code search') + '</div>' +
432
+ '</div>' +
433
+ '</div>' +
434
+ '<div class="tool-item-right">' +
435
+ (semanticStatus.available
436
+ ? '<span class="tool-status-text success"><i data-lucide="sparkles" class="w-3.5 h-3.5"></i> ' + (semanticStatus.backend || 'Ready') + '</span>'
437
+ : '<span class="tool-status-text muted"><i data-lucide="circle-dashed" class="w-3.5 h-3.5"></i> Not Installed</span>' +
438
+ '<button class="btn-sm btn-primary" onclick="event.stopPropagation(); openSemanticInstallWizard()"><i data-lucide="brain" class="w-3 h-3"></i> Install</button>') +
439
+ '</div>' +
440
+ '</div>';
441
+ }
442
+
443
+ container.innerHTML = '<div class="section-header">' +
444
+ '<div class="section-header-left">' +
445
+ '<h3><i data-lucide="terminal" class="w-4 h-4"></i> ' + t('cli.tools') + '</h3>' +
446
+ '<span class="section-count">' + available + '/' + tools.length + ' ' + t('cli.available') + '</span>' +
447
+ '</div>' +
448
+ '<button class="btn-icon" onclick="refreshAllCliStatus()" title="' + t('cli.refreshStatus') + '">' +
449
+ '<i data-lucide="refresh-cw" class="w-4 h-4"></i>' +
450
+ '</button>' +
451
+ '</div>' +
452
+ '<div class="tools-list">' +
453
+ toolsHtml +
454
+ codexLensHtml +
455
+ semanticHtml +
456
+ '</div>';
457
+
458
+ if (window.lucide) lucide.createIcons();
459
+ }
460
+
461
+ // ========== CCW Section (Right Column) ==========
462
+ function renderCcwSection() {
463
+ var container = document.getElementById('ccw-section');
464
+ if (!container) return;
465
+
466
+ var installationsHtml = '';
467
+
468
+ if (ccwInstallations.length === 0) {
469
+ installationsHtml = '<div class="ccw-empty-state">' +
470
+ '<i data-lucide="package-x" class="w-8 h-8"></i>' +
471
+ '<p>' + t('ccw.noInstallations') + '</p>' +
472
+ '<button class="btn btn-sm btn-primary" onclick="showCcwInstallModal()">' +
473
+ '<i data-lucide="download" class="w-3 h-3"></i> ' + t('ccw.installCcw') + '</button>' +
474
+ '</div>';
475
+ } else {
476
+ installationsHtml = '<div class="ccw-list">';
477
+ for (var i = 0; i < ccwInstallations.length; i++) {
478
+ var inst = ccwInstallations[i];
479
+ var isGlobal = inst.installation_mode === 'Global';
480
+ var modeIcon = isGlobal ? 'home' : 'folder';
481
+ var version = inst.application_version || 'unknown';
482
+ var installDate = new Date(inst.installation_date).toLocaleDateString();
483
+
484
+ installationsHtml += '<div class="ccw-item">' +
485
+ '<div class="ccw-item-left">' +
486
+ '<div class="ccw-item-mode ' + (isGlobal ? 'global' : 'path') + '">' +
487
+ '<i data-lucide="' + modeIcon + '" class="w-4 h-4"></i>' +
488
+ '</div>' +
489
+ '<div class="ccw-item-info">' +
490
+ '<div class="ccw-item-header">' +
491
+ '<span class="ccw-item-name">' + inst.installation_mode + '</span>' +
492
+ '<span class="ccw-version-tag">v' + version + '</span>' +
493
+ '</div>' +
494
+ '<div class="ccw-item-path" title="' + inst.installation_path + '">' + escapeHtml(inst.installation_path) + '</div>' +
495
+ '<div class="ccw-item-meta">' +
496
+ '<span><i data-lucide="calendar" class="w-3 h-3"></i> ' + installDate + '</span>' +
497
+ '<span><i data-lucide="file" class="w-3 h-3"></i> ' + (inst.files_count || 0) + ' files</span>' +
498
+ '</div>' +
499
+ '</div>' +
500
+ '</div>' +
501
+ '<div class="ccw-item-actions">' +
502
+ '<button class="btn-icon btn-icon-sm" onclick="runCcwUpgrade()" title="Upgrade">' +
503
+ '<i data-lucide="arrow-up-circle" class="w-4 h-4"></i>' +
504
+ '</button>' +
505
+ '<button class="btn-icon btn-icon-sm btn-danger" onclick="confirmCcwUninstall(\'' + escapeHtml(inst.installation_path) + '\')" title="Uninstall">' +
506
+ '<i data-lucide="trash-2" class="w-4 h-4"></i>' +
507
+ '</button>' +
508
+ '</div>' +
509
+ '</div>';
510
+ }
511
+ installationsHtml += '</div>';
512
+ }
513
+
514
+ container.innerHTML = '<div class="section-header">' +
515
+ '<div class="section-header-left">' +
516
+ '<h3><i data-lucide="package" class="w-4 h-4"></i> ' + t('ccw.install') + '</h3>' +
517
+ '<span class="section-count">' + ccwInstallations.length + ' ' + (ccwInstallations.length !== 1 ? t('ccw.installationsPlural') : t('ccw.installations')) + '</span>' +
518
+ '</div>' +
519
+ '<div class="section-header-actions">' +
520
+ '<button class="btn-icon" onclick="showCcwInstallModal()" title="Add Installation">' +
521
+ '<i data-lucide="plus" class="w-4 h-4"></i>' +
522
+ '</button>' +
523
+ '<button class="btn-icon" onclick="loadCcwInstallations().then(function() { renderCcwSection(); if (window.lucide) lucide.createIcons(); })" title="Refresh">' +
524
+ '<i data-lucide="refresh-cw" class="w-4 h-4"></i>' +
525
+ '</button>' +
526
+ '</div>' +
527
+ '</div>' +
528
+ installationsHtml;
529
+
530
+ if (window.lucide) lucide.createIcons();
531
+ }
532
+
533
+ // ========== Language Settings State ==========
534
+ var chineseResponseEnabled = false;
535
+ var chineseResponseLoading = false;
536
+ var windowsPlatformEnabled = false;
537
+ var windowsPlatformLoading = false;
538
+
539
+ // ========== Language Settings Section ==========
540
+ async function loadLanguageSettings() {
541
+ try {
542
+ var response = await fetch('/api/language/chinese-response');
543
+ if (!response.ok) throw new Error('Failed to load language settings');
544
+ var data = await response.json();
545
+ chineseResponseEnabled = data.enabled || false;
546
+ return data;
547
+ } catch (err) {
548
+ console.error('Failed to load language settings:', err);
549
+ chineseResponseEnabled = false;
550
+ return { enabled: false, guidelinesExists: false };
551
+ }
552
+ }
553
+
554
+ async function loadWindowsPlatformSettings() {
555
+ try {
556
+ var response = await fetch('/api/language/windows-platform');
557
+ if (!response.ok) throw new Error('Failed to load Windows platform settings');
558
+ var data = await response.json();
559
+ windowsPlatformEnabled = data.enabled || false;
560
+ return data;
561
+ } catch (err) {
562
+ console.error('Failed to load Windows platform settings:', err);
563
+ windowsPlatformEnabled = false;
564
+ return { enabled: false, guidelinesExists: false };
565
+ }
566
+ }
567
+
568
+ async function toggleChineseResponse(enabled) {
569
+ if (chineseResponseLoading) return;
570
+ chineseResponseLoading = true;
571
+
572
+ try {
573
+ var response = await fetch('/api/language/chinese-response', {
574
+ method: 'POST',
575
+ headers: { 'Content-Type': 'application/json' },
576
+ body: JSON.stringify({ enabled: enabled })
577
+ });
578
+
579
+ if (!response.ok) {
580
+ var errData = await response.json();
581
+ throw new Error(errData.error || 'Failed to update setting');
582
+ }
583
+
584
+ var data = await response.json();
585
+ chineseResponseEnabled = data.enabled;
586
+
587
+ // Update UI
588
+ renderLanguageSettingsSection();
589
+
590
+ // Show toast
591
+ showRefreshToast(enabled ? t('lang.enableSuccess') : t('lang.disableSuccess'), 'success');
592
+ } catch (err) {
593
+ console.error('Failed to toggle Chinese response:', err);
594
+ showRefreshToast(enabled ? t('lang.enableFailed') : t('lang.disableFailed'), 'error');
595
+ } finally {
596
+ chineseResponseLoading = false;
597
+ }
598
+ }
599
+
600
+ async function toggleWindowsPlatform(enabled) {
601
+ if (windowsPlatformLoading) return;
602
+ windowsPlatformLoading = true;
603
+
604
+ try {
605
+ var response = await fetch('/api/language/windows-platform', {
606
+ method: 'POST',
607
+ headers: { 'Content-Type': 'application/json' },
608
+ body: JSON.stringify({ enabled: enabled })
609
+ });
610
+
611
+ if (!response.ok) {
612
+ var errData = await response.json();
613
+ throw new Error(errData.error || 'Failed to update setting');
614
+ }
615
+
616
+ var data = await response.json();
617
+ windowsPlatformEnabled = data.enabled;
618
+
619
+ // Update UI
620
+ renderLanguageSettingsSection();
621
+
622
+ // Show toast
623
+ showRefreshToast(enabled ? t('lang.windowsEnableSuccess') : t('lang.windowsDisableSuccess'), 'success');
624
+ } catch (err) {
625
+ console.error('Failed to toggle Windows platform:', err);
626
+ showRefreshToast(enabled ? t('lang.windowsEnableFailed') : t('lang.windowsDisableFailed'), 'error');
627
+ } finally {
628
+ windowsPlatformLoading = false;
629
+ }
630
+ }
631
+
632
+ async function renderLanguageSettingsSection() {
633
+ var container = document.getElementById('language-settings-section');
634
+ if (!container) return;
635
+
636
+ // Load current state if not loaded
637
+ if (!chineseResponseEnabled && !chineseResponseLoading) {
638
+ await loadLanguageSettings();
639
+ }
640
+ if (!windowsPlatformEnabled && !windowsPlatformLoading) {
641
+ await loadWindowsPlatformSettings();
642
+ }
643
+
644
+ var settingsHtml = '<div class="section-header">' +
645
+ '<div class="section-header-left">' +
646
+ '<h3><i data-lucide="languages" class="w-4 h-4"></i> ' + t('lang.settings') + '</h3>' +
647
+ '</div>' +
648
+ '</div>' +
649
+ '<div class="cli-settings-grid" style="grid-template-columns: 1fr 1fr;">' +
650
+ '<div class="cli-setting-item">' +
651
+ '<label class="cli-setting-label">' +
652
+ '<i data-lucide="message-square-text" class="w-3 h-3"></i>' +
653
+ t('lang.chinese') +
654
+ '</label>' +
655
+ '<div class="cli-setting-control">' +
656
+ '<label class="cli-toggle">' +
657
+ '<input type="checkbox"' + (chineseResponseEnabled ? ' checked' : '') + ' onchange="toggleChineseResponse(this.checked)"' + (chineseResponseLoading ? ' disabled' : '') + '>' +
658
+ '<span class="cli-toggle-slider"></span>' +
659
+ '</label>' +
660
+ '<span class="cli-setting-status ' + (chineseResponseEnabled ? 'enabled' : 'disabled') + '">' +
661
+ (chineseResponseEnabled ? t('lang.enabled') : t('lang.disabled')) +
662
+ '</span>' +
663
+ '</div>' +
664
+ '<p class="cli-setting-desc">' + t('lang.chineseDesc') + '</p>' +
665
+ '</div>' +
666
+ '<div class="cli-setting-item">' +
667
+ '<label class="cli-setting-label">' +
668
+ '<i data-lucide="monitor" class="w-3 h-3"></i>' +
669
+ t('lang.windows') +
670
+ '</label>' +
671
+ '<div class="cli-setting-control">' +
672
+ '<label class="cli-toggle">' +
673
+ '<input type="checkbox"' + (windowsPlatformEnabled ? ' checked' : '') + ' onchange="toggleWindowsPlatform(this.checked)"' + (windowsPlatformLoading ? ' disabled' : '') + '>' +
674
+ '<span class="cli-toggle-slider"></span>' +
675
+ '</label>' +
676
+ '<span class="cli-setting-status ' + (windowsPlatformEnabled ? 'enabled' : 'disabled') + '">' +
677
+ (windowsPlatformEnabled ? t('lang.enabled') : t('lang.disabled')) +
678
+ '</span>' +
679
+ '</div>' +
680
+ '<p class="cli-setting-desc">' + t('lang.windowsDesc') + '</p>' +
681
+ '</div>' +
682
+ '</div>';
683
+
684
+ container.innerHTML = settingsHtml;
685
+ if (window.lucide) lucide.createIcons();
686
+ }
687
+
688
+ // ========== CLI Settings Section (Full Width) ==========
689
+ function renderCliSettingsSection() {
690
+ var container = document.getElementById('cli-settings-section');
691
+ if (!container) return;
692
+
693
+ var settingsHtml = '<div class="section-header">' +
694
+ '<div class="section-header-left">' +
695
+ '<h3><i data-lucide="settings" class="w-4 h-4"></i> ' + t('cli.settings') + '</h3>' +
696
+ '</div>' +
697
+ '</div>' +
698
+ '<div class="cli-settings-grid">' +
699
+ '<div class="cli-setting-item">' +
700
+ '<label class="cli-setting-label">' +
701
+ '<i data-lucide="layers" class="w-3 h-3"></i>' +
702
+ t('cli.promptFormat') +
703
+ '</label>' +
704
+ '<div class="cli-setting-control">' +
705
+ '<select class="cli-setting-select" onchange="setPromptFormat(this.value)">' +
706
+ '<option value="plain"' + (promptConcatFormat === 'plain' ? ' selected' : '') + '>Plain Text</option>' +
707
+ '<option value="yaml"' + (promptConcatFormat === 'yaml' ? ' selected' : '') + '>YAML</option>' +
708
+ '<option value="json"' + (promptConcatFormat === 'json' ? ' selected' : '') + '>JSON</option>' +
709
+ '</select>' +
710
+ '</div>' +
711
+ '<p class="cli-setting-desc">' + t('cli.promptFormatDesc') + '</p>' +
712
+ '</div>' +
713
+ '<div class="cli-setting-item">' +
714
+ '<label class="cli-setting-label">' +
715
+ '<i data-lucide="database" class="w-3 h-3"></i>' +
716
+ t('cli.storageBackend') +
717
+ '</label>' +
718
+ '<div class="cli-setting-control">' +
719
+ '<span class="cli-setting-value">SQLite</span>' +
720
+ '</div>' +
721
+ '<p class="cli-setting-desc">' + t('cli.storageBackendDesc') + '</p>' +
722
+ '</div>' +
723
+ '<div class="cli-setting-item">' +
724
+ '<label class="cli-setting-label">' +
725
+ '<i data-lucide="sparkles" class="w-3 h-3"></i>' +
726
+ t('cli.smartContext') +
727
+ '</label>' +
728
+ '<div class="cli-setting-control">' +
729
+ '<label class="cli-toggle">' +
730
+ '<input type="checkbox"' + (smartContextEnabled ? ' checked' : '') + ' onchange="setSmartContextEnabled(this.checked)">' +
731
+ '<span class="cli-toggle-slider"></span>' +
732
+ '</label>' +
733
+ '</div>' +
734
+ '<p class="cli-setting-desc">' + t('cli.smartContextDesc') + '</p>' +
735
+ '</div>' +
736
+ '<div class="cli-setting-item">' +
737
+ '<label class="cli-setting-label">' +
738
+ '<i data-lucide="refresh-cw" class="w-3 h-3"></i>' +
739
+ t('cli.nativeResume') +
740
+ '</label>' +
741
+ '<div class="cli-setting-control">' +
742
+ '<label class="cli-toggle">' +
743
+ '<input type="checkbox"' + (nativeResumeEnabled ? ' checked' : '') + ' onchange="setNativeResumeEnabled(this.checked)">' +
744
+ '<span class="cli-toggle-slider"></span>' +
745
+ '</label>' +
746
+ '</div>' +
747
+ '<p class="cli-setting-desc">' + t('cli.nativeResumeDesc') + '</p>' +
748
+ '</div>' +
749
+ '<div class="cli-setting-item">' +
750
+ '<label class="cli-setting-label">' +
751
+ '<i data-lucide="git-branch" class="w-3 h-3"></i>' +
752
+ t('cli.recursiveQuery') +
753
+ '</label>' +
754
+ '<div class="cli-setting-control">' +
755
+ '<label class="cli-toggle">' +
756
+ '<input type="checkbox"' + (recursiveQueryEnabled ? ' checked' : '') + ' onchange="setRecursiveQueryEnabled(this.checked)">' +
757
+ '<span class="cli-toggle-slider"></span>' +
758
+ '</label>' +
759
+ '</div>' +
760
+ '<p class="cli-setting-desc">' + t('cli.recursiveQueryDesc') + '</p>' +
761
+ '</div>' +
762
+ '<div class="cli-setting-item' + (!smartContextEnabled ? ' disabled' : '') + '">' +
763
+ '<label class="cli-setting-label">' +
764
+ '<i data-lucide="files" class="w-3 h-3"></i>' +
765
+ t('cli.maxContextFiles') +
766
+ '</label>' +
767
+ '<div class="cli-setting-control">' +
768
+ '<select class="cli-setting-select" onchange="setSmartContextMaxFiles(this.value)"' + (!smartContextEnabled ? ' disabled' : '') + '>' +
769
+ '<option value="5"' + (smartContextMaxFiles === 5 ? ' selected' : '') + '>5 files</option>' +
770
+ '<option value="10"' + (smartContextMaxFiles === 10 ? ' selected' : '') + '>10 files</option>' +
771
+ '<option value="20"' + (smartContextMaxFiles === 20 ? ' selected' : '') + '>20 files</option>' +
772
+ '</select>' +
773
+ '</div>' +
774
+ '<p class="cli-setting-desc">' + t('cli.maxContextFilesDesc') + '</p>' +
775
+ '</div>' +
776
+ '</div>';
777
+
778
+ container.innerHTML = settingsHtml;
779
+ if (window.lucide) lucide.createIcons();
780
+ }
781
+
782
+ // ========== CCW Endpoint Tools Section (Full Width) ==========
783
+ function renderCcwEndpointToolsSection() {
784
+ var container = document.getElementById('ccw-endpoint-tools-section');
785
+ if (!container) return;
786
+
787
+ var count = (ccwEndpointTools || []).length;
788
+ var toolsHtml = '';
789
+
790
+ if (!ccwEndpointTools || ccwEndpointTools.length === 0) {
791
+ toolsHtml = '<div class="ccw-empty-state">' +
792
+ '<i data-lucide="wrench" class="w-8 h-8"></i>' +
793
+ '<p>' + t('ccw.noEndpointTools') + '</p>' +
794
+ '<button class="btn btn-sm btn-primary" onclick="loadCcwEndpointTools().then(function() { renderCcwEndpointToolsSection(); if (window.lucide) lucide.createIcons(); })">' +
795
+ '<i data-lucide="refresh-cw" class="w-3 h-3"></i> ' + t('common.refresh') + '</button>' +
796
+ '</div>';
797
+ } else {
798
+ toolsHtml = '<div class="endpoint-tools-grid">' +
799
+ ccwEndpointTools.map(function(t, idx) {
800
+ var name = t && t.name ? String(t.name) : 'unknown';
801
+ var desc = t && t.description ? String(t.description) : '';
802
+ var requiredCount = (t && t.parameters && Array.isArray(t.parameters.required)) ? t.parameters.required.length : 0;
803
+ var propsCount = (t && t.parameters && t.parameters.properties) ? Object.keys(t.parameters.properties).length : 0;
804
+ var shortDesc = desc.length > 60 ? desc.substring(0, 60) + '...' : desc;
805
+
806
+ return '<div class="endpoint-tool-card" onclick="showEndpointToolDetail(' + idx + ')">' +
807
+ '<div class="endpoint-tool-header">' +
808
+ '<span class="endpoint-tool-dot"></span>' +
809
+ '<span class="endpoint-tool-name">' + escapeHtml(name) + '</span>' +
810
+ '</div>' +
811
+ '<div class="endpoint-tool-desc">' + escapeHtml(shortDesc || 'No description') + '</div>' +
812
+ '<div class="endpoint-tool-meta">' +
813
+ '<span class="endpoint-tool-params">' +
814
+ '<i data-lucide="braces" class="w-3 h-3"></i> ' + propsCount +
815
+ '</span>' +
816
+ (requiredCount > 0 ? '<span class="endpoint-tool-required">' + requiredCount + ' required</span>' : '') +
817
+ '</div>' +
818
+ '</div>';
819
+ }).join('') +
820
+ '</div>';
821
+ }
822
+
823
+ container.innerHTML = '<div class="section-header">' +
824
+ '<div class="section-header-left">' +
825
+ '<h3><i data-lucide="server" class="w-4 h-4"></i> ' + t('ccw.endpointTools') + '</h3>' +
826
+ '<span class="section-count">' + count + ' ' + (count !== 1 ? t('ccw.tools') : t('ccw.tool')) + '</span>' +
827
+ '</div>' +
828
+ '<button class="btn-icon" onclick="loadCcwEndpointTools().then(function() { renderCcwEndpointToolsSection(); if (window.lucide) lucide.createIcons(); })" title="Refresh">' +
829
+ '<i data-lucide="refresh-cw" class="w-4 h-4"></i>' +
830
+ '</button>' +
831
+ '</div>' +
832
+ toolsHtml;
833
+
834
+ if (window.lucide) lucide.createIcons();
835
+ }
836
+
837
+ // ========== Endpoint Tool Detail Modal ==========
838
+ function showEndpointToolDetail(toolIndex) {
839
+ var tool = ccwEndpointTools[toolIndex];
840
+ if (!tool) return;
841
+
842
+ var name = tool.name || 'unknown';
843
+ var desc = tool.description || 'No description available';
844
+ var params = tool.parameters || {};
845
+ var properties = params.properties || {};
846
+ var required = params.required || [];
847
+
848
+ // Build parameters table
849
+ var paramsHtml = '';
850
+ var propKeys = Object.keys(properties);
851
+
852
+ if (propKeys.length > 0) {
853
+ paramsHtml = '<div class="tool-detail-params">' +
854
+ '<h4><i data-lucide="settings-2" class="w-4 h-4"></i> Parameters</h4>' +
855
+ '<div class="tool-params-list">';
856
+
857
+ for (var i = 0; i < propKeys.length; i++) {
858
+ var key = propKeys[i];
859
+ var prop = properties[key];
860
+ var isRequired = required.indexOf(key) !== -1;
861
+ var propType = prop.type || 'any';
862
+ var propDesc = prop.description || '';
863
+ var propDefault = prop.default !== undefined ? JSON.stringify(prop.default) : null;
864
+ var propEnum = prop.enum ? prop.enum.join(', ') : null;
865
+
866
+ paramsHtml += '<div class="tool-param-item">' +
867
+ '<div class="tool-param-header">' +
868
+ '<code class="tool-param-name">' + escapeHtml(key) + '</code>' +
869
+ '<span class="tool-param-type">' + escapeHtml(propType) + '</span>' +
870
+ (isRequired ? '<span class="tool-param-required">required</span>' : '<span class="tool-param-optional">optional</span>') +
871
+ '</div>' +
872
+ (propDesc ? '<div class="tool-param-desc">' + escapeHtml(propDesc) + '</div>' : '') +
873
+ (propDefault ? '<div class="tool-param-default">Default: <code>' + escapeHtml(propDefault) + '</code></div>' : '') +
874
+ (propEnum ? '<div class="tool-param-enum">Options: <code>' + escapeHtml(propEnum) + '</code></div>' : '') +
875
+ '</div>';
876
+ }
877
+
878
+ paramsHtml += '</div></div>';
879
+ } else {
880
+ paramsHtml = '<div class="tool-detail-no-params">' +
881
+ '<i data-lucide="info" class="w-4 h-4"></i>' +
882
+ '<span>This tool has no parameters</span>' +
883
+ '</div>';
884
+ }
885
+
886
+ // Usage example
887
+ var usageExample = 'ccw tool exec ' + name;
888
+ if (propKeys.length > 0) {
889
+ var exampleParams = {};
890
+ for (var j = 0; j < Math.min(propKeys.length, 2); j++) {
891
+ var k = propKeys[j];
892
+ var p = properties[k];
893
+ if (p.type === 'string') exampleParams[k] = '<value>';
894
+ else if (p.type === 'boolean') exampleParams[k] = true;
895
+ else if (p.type === 'number') exampleParams[k] = 0;
896
+ else exampleParams[k] = '<value>';
897
+ }
898
+ usageExample += " '" + JSON.stringify(exampleParams) + "'";
899
+ }
900
+
901
+ var modalContent = '<div class="tool-detail-modal">' +
902
+ '<div class="tool-detail-header">' +
903
+ '<div class="tool-detail-icon"><i data-lucide="terminal" class="w-6 h-6"></i></div>' +
904
+ '<div class="tool-detail-title">' +
905
+ '<h3>' + escapeHtml(name) + '</h3>' +
906
+ '<span class="tool-detail-badge">endpoint tool</span>' +
907
+ '</div>' +
908
+ '</div>' +
909
+ '<div class="tool-detail-desc">' + escapeHtml(desc) + '</div>' +
910
+ paramsHtml +
911
+ '<div class="tool-detail-usage">' +
912
+ '<h4><i data-lucide="terminal-square" class="w-4 h-4"></i> Usage Example</h4>' +
913
+ '<div class="tool-usage-code">' +
914
+ '<code>' + escapeHtml(usageExample) + '</code>' +
915
+ '<button class="tool-copy-btn" onclick="copyToolUsage(this, \'' + escapeHtml(usageExample.replace(/'/g, "\\'")) + '\')" title="Copy">' +
916
+ '<i data-lucide="copy" class="w-3.5 h-3.5"></i>' +
917
+ '</button>' +
918
+ '</div>' +
919
+ '</div>' +
920
+ '</div>';
921
+
922
+ showModal(name, modalContent, { size: 'lg' });
923
+ }
924
+
925
+ function copyToolUsage(btn, text) {
926
+ navigator.clipboard.writeText(text).then(function() {
927
+ var icon = btn.querySelector('i');
928
+ if (icon) {
929
+ icon.setAttribute('data-lucide', 'check');
930
+ if (window.lucide) lucide.createIcons();
931
+ setTimeout(function() {
932
+ icon.setAttribute('data-lucide', 'copy');
933
+ if (window.lucide) lucide.createIcons();
934
+ }, 2000);
935
+ }
936
+ });
937
+ }
938
+
939
+ // CCW Install Carousel State
940
+ var ccwCarouselIndex = 0;
941
+
942
+ function renderCcwInstallPanel() {
943
+ var container = document.getElementById('ccw-install-panel');
944
+ if (!container) return;
945
+
946
+ var html = '<div class="cli-status-header"><h3><i data-lucide="package" class="w-4 h-4"></i> CCW Installations</h3>' +
947
+ '<div class="ccw-header-actions">' +
948
+ '<button class="btn-icon" onclick="showCcwInstallModal()" title="Add Installation">' +
949
+ '<i data-lucide="plus" class="w-4 h-4"></i></button>' +
950
+ '<button class="btn-icon" onclick="loadCcwInstallations().then(function() { renderCcwInstallPanel(); })" title="Refresh">' +
951
+ '<i data-lucide="refresh-cw" class="w-4 h-4"></i></button>' +
952
+ '</div></div>' +
953
+ '<div class="ccw-install-content">';
954
+
955
+ if (ccwInstallations.length === 0) {
956
+ html += '<div class="ccw-empty-state">' +
957
+ '<i data-lucide="package-x" class="w-8 h-8"></i>' +
958
+ '<p>No installations found</p>' +
959
+ '<button class="btn btn-sm btn-primary" onclick="showCcwInstallModal()">' +
960
+ '<i data-lucide="download" class="w-3 h-3"></i> Install CCW</button></div>';
961
+ } else {
962
+ // Carousel container
963
+ html += '<div class="ccw-carousel-wrapper">';
964
+
965
+ // Left arrow (show only if more than 1 installation)
966
+ if (ccwInstallations.length > 1) {
967
+ html += '<button class="ccw-carousel-btn ccw-carousel-prev" onclick="ccwCarouselPrev()" title="Previous">' +
968
+ '<i data-lucide="chevron-left" class="w-4 h-4"></i></button>';
969
+ }
970
+
971
+ html += '<div class="ccw-carousel-track" id="ccwCarouselTrack">';
972
+
973
+ for (var i = 0; i < ccwInstallations.length; i++) {
974
+ var inst = ccwInstallations[i];
975
+ var isGlobal = inst.installation_mode === 'Global';
976
+ var modeIcon = isGlobal ? 'home' : 'folder';
977
+ var version = inst.application_version || 'unknown';
978
+ var installDate = new Date(inst.installation_date).toLocaleDateString();
979
+ var activeClass = i === ccwCarouselIndex ? 'active' : '';
980
+
981
+ html += '<div class="ccw-carousel-card ' + activeClass + '" data-index="' + i + '">' +
982
+ '<div class="ccw-card-header">' +
983
+ '<div class="ccw-card-mode ' + (isGlobal ? 'global' : 'path') + '">' +
984
+ '<i data-lucide="' + modeIcon + '" class="w-4 h-4"></i>' +
985
+ '<span>' + inst.installation_mode + '</span>' +
986
+ '</div>' +
987
+ '<div class="ccw-card-header-right">' +
988
+ '<span class="ccw-version-tag">v' + version + '</span>' +
989
+ '<button class="btn-icon btn-icon-sm" onclick="runCcwUpgrade()" title="Upgrade">' +
990
+ '<i data-lucide="arrow-up-circle" class="w-3.5 h-3.5"></i></button>' +
991
+ '<button class="btn-icon btn-icon-sm btn-danger" onclick="confirmCcwUninstall(\'' + escapeHtml(inst.installation_path) + '\')" title="Uninstall">' +
992
+ '<i data-lucide="trash-2" class="w-3.5 h-3.5"></i></button>' +
993
+ '</div>' +
994
+ '</div>' +
995
+ '<div class="ccw-card-path" title="' + inst.installation_path + '">' + escapeHtml(inst.installation_path) + '</div>' +
996
+ '<div class="ccw-card-meta">' +
997
+ '<span><i data-lucide="calendar" class="w-3 h-3"></i> ' + installDate + '</span>' +
998
+ '<span><i data-lucide="file" class="w-3 h-3"></i> ' + (inst.files_count || 0) + ' files</span>' +
999
+ '</div>' +
1000
+ '</div>';
1001
+ }
1002
+
1003
+ html += '</div>';
1004
+
1005
+ // Right arrow (show only if more than 1 installation)
1006
+ if (ccwInstallations.length > 1) {
1007
+ html += '<button class="ccw-carousel-btn ccw-carousel-next" onclick="ccwCarouselNext()" title="Next">' +
1008
+ '<i data-lucide="chevron-right" class="w-4 h-4"></i></button>';
1009
+ }
1010
+
1011
+ html += '</div>';
1012
+
1013
+ // Dots indicator (show only if more than 1 installation)
1014
+ if (ccwInstallations.length > 1) {
1015
+ html += '<div class="ccw-carousel-dots">';
1016
+ for (var j = 0; j < ccwInstallations.length; j++) {
1017
+ var dotActive = j === ccwCarouselIndex ? 'active' : '';
1018
+ html += '<button class="ccw-carousel-dot ' + dotActive + '" onclick="ccwCarouselGoTo(' + j + ')"></button>';
1019
+ }
1020
+ html += '</div>';
1021
+ }
1022
+ }
1023
+
1024
+ html += '</div>';
1025
+ container.innerHTML = html;
1026
+ if (window.lucide) lucide.createIcons();
1027
+
1028
+ // Update carousel position
1029
+ updateCcwCarouselPosition();
1030
+ }
1031
+
1032
+ function ccwCarouselPrev() {
1033
+ if (ccwCarouselIndex > 0) {
1034
+ ccwCarouselIndex--;
1035
+ updateCcwCarouselPosition();
1036
+ updateCcwCarouselDots();
1037
+ }
1038
+ }
1039
+
1040
+ function ccwCarouselNext() {
1041
+ if (ccwCarouselIndex < ccwInstallations.length - 1) {
1042
+ ccwCarouselIndex++;
1043
+ updateCcwCarouselPosition();
1044
+ updateCcwCarouselDots();
1045
+ }
1046
+ }
1047
+
1048
+ function ccwCarouselGoTo(index) {
1049
+ ccwCarouselIndex = index;
1050
+ updateCcwCarouselPosition();
1051
+ updateCcwCarouselDots();
1052
+ }
1053
+
1054
+ function updateCcwCarouselPosition() {
1055
+ var track = document.getElementById('ccwCarouselTrack');
1056
+ if (track) {
1057
+ track.style.transform = 'translateX(-' + (ccwCarouselIndex * 100) + '%)';
1058
+ }
1059
+
1060
+ // Update card active states
1061
+ var cards = document.querySelectorAll('.ccw-carousel-card');
1062
+ cards.forEach(function(card, idx) {
1063
+ card.classList.toggle('active', idx === ccwCarouselIndex);
1064
+ });
1065
+ }
1066
+
1067
+ function updateCcwCarouselDots() {
1068
+ var dots = document.querySelectorAll('.ccw-carousel-dot');
1069
+ dots.forEach(function(dot, idx) {
1070
+ dot.classList.toggle('active', idx === ccwCarouselIndex);
1071
+ });
1072
+ }
1073
+
1074
+ // CCW Install Modal
1075
+ function showCcwInstallModal() {
1076
+ var modalContent = '<div class="ccw-install-modal">' +
1077
+ '<div class="ccw-install-options">' +
1078
+ '<div class="ccw-install-option" onclick="selectCcwInstallMode(\'Global\')">' +
1079
+ '<div class="ccw-option-icon global"><i data-lucide="home" class="w-6 h-6"></i></div>' +
1080
+ '<div class="ccw-option-info">' +
1081
+ '<div class="ccw-option-title">Global Installation</div>' +
1082
+ '<div class="ccw-option-desc">Install to user home directory (~/.claude)</div>' +
1083
+ '</div>' +
1084
+ '<i data-lucide="chevron-right" class="w-4 h-4 text-muted-foreground"></i>' +
1085
+ '</div>' +
1086
+ '<div class="ccw-install-option" onclick="toggleCcwPathInput()">' +
1087
+ '<div class="ccw-option-icon path"><i data-lucide="folder" class="w-6 h-6"></i></div>' +
1088
+ '<div class="ccw-option-info">' +
1089
+ '<div class="ccw-option-title">Path Installation</div>' +
1090
+ '<div class="ccw-option-desc">Install to a specific project folder</div>' +
1091
+ '</div>' +
1092
+ '<i data-lucide="chevron-right" class="w-4 h-4 text-muted-foreground"></i>' +
1093
+ '</div>' +
1094
+ '</div>' +
1095
+ '<div class="ccw-path-input-section hidden" id="ccwPathInputSection">' +
1096
+ '<div class="ccw-path-input-group">' +
1097
+ '<label>Installation Path</label>' +
1098
+ '<input type="text" id="ccwInstallPath" class="cli-textarea" placeholder="D:/projects/my-project" value="' + (projectPath || '') + '">' +
1099
+ '</div>' +
1100
+ '<div class="ccw-install-action">' +
1101
+ '<button class="btn btn-primary" onclick="executeCcwInstall()">' +
1102
+ '<i data-lucide="download" class="w-4 h-4"></i> Install to Path</button>' +
1103
+ '</div>' +
1104
+ '</div>' +
1105
+ '</div>';
1106
+
1107
+ showModal('Install CCW', modalContent);
1108
+ }
1109
+
1110
+ function selectCcwInstallMode(mode) {
1111
+ if (mode === 'Global') {
1112
+ closeModal();
1113
+ runCcwInstall('Global');
1114
+ }
1115
+ }
1116
+
1117
+ function toggleCcwPathInput() {
1118
+ var section = document.getElementById('ccwPathInputSection');
1119
+ if (section) {
1120
+ section.classList.toggle('hidden');
1121
+ if (!section.classList.contains('hidden')) {
1122
+ var input = document.getElementById('ccwInstallPath');
1123
+ if (input) input.focus();
1124
+ }
1125
+ }
1126
+ }
1127
+
1128
+ function executeCcwInstall() {
1129
+ var input = document.getElementById('ccwInstallPath');
1130
+ var path = input ? input.value.trim() : '';
1131
+
1132
+ if (!path) {
1133
+ showRefreshToast('Please enter a path', 'error');
1134
+ return;
1135
+ }
1136
+
1137
+ closeModal();
1138
+ runCcwInstall('Path', path);
1139
+ }
1140
+
1141
+ function truncatePath(path) {
1142
+ if (!path) return '';
1143
+ var maxLen = 35;
1144
+ if (path.length <= maxLen) return path;
1145
+ return '...' + path.slice(-maxLen + 3);
1146
+ }
1147
+
1148
+ function renderCliExecutePanel() {
1149
+ var container = document.getElementById('cli-execute-panel');
1150
+ if (!container) return;
1151
+
1152
+ var tools = ['gemini', 'qwen', 'codex'];
1153
+ var modes = ['analysis', 'write', 'auto'];
1154
+
1155
+ var html = '<div class="cli-execute-header"><h3>Quick Execute</h3></div>' +
1156
+ '<div class="cli-execute-form"><div class="cli-execute-row">' +
1157
+ '<div class="cli-form-group"><label for="cli-exec-tool">Tool</label>' +
1158
+ '<select id="cli-exec-tool" class="cli-select">';
1159
+ for (var i = 0; i < tools.length; i++) {
1160
+ var tool = tools[i];
1161
+ var selected = tool === defaultCliTool ? 'selected' : '';
1162
+ html += '<option value="' + tool + '" ' + selected + '>' + tool.charAt(0).toUpperCase() + tool.slice(1) + '</option>';
1163
+ }
1164
+ html += '</select></div>' +
1165
+ '<div class="cli-form-group"><label for="cli-exec-mode">Mode</label>' +
1166
+ '<select id="cli-exec-mode" class="cli-select">';
1167
+ for (var j = 0; j < modes.length; j++) {
1168
+ var mode = modes[j];
1169
+ var sel = mode === 'analysis' ? 'selected' : '';
1170
+ html += '<option value="' + mode + '" ' + sel + '>' + mode.charAt(0).toUpperCase() + mode.slice(1) + '</option>';
1171
+ }
1172
+ html += '</select></div></div>' +
1173
+ '<div class="cli-form-group"><label for="cli-exec-prompt">Prompt</label>' +
1174
+ '<textarea id="cli-exec-prompt" class="cli-textarea" placeholder="Enter your prompt..."></textarea></div>' +
1175
+ '<div class="cli-execute-actions">' +
1176
+ '<button class="btn btn-primary" onclick="executeCliFromDashboard()" ' + (currentCliExecution ? 'disabled' : '') + '>' +
1177
+ '<i data-lucide="play" class="w-4 h-4"></i> Execute</button></div></div>';
1178
+ container.innerHTML = html;
1179
+ if (window.lucide) lucide.createIcons();
1180
+ }
1181
+
1182
+ // ========== CCW Actions ==========
1183
+ function runCcwInstall(mode, customPath) {
1184
+ var command;
1185
+ if (mode === 'Global') {
1186
+ command = 'ccw install --mode Global';
1187
+ } else {
1188
+ var installPath = customPath || projectPath;
1189
+ command = 'ccw install --mode Path --path "' + installPath + '"';
1190
+ }
1191
+
1192
+ // Copy command to clipboard
1193
+ if (navigator.clipboard) {
1194
+ navigator.clipboard.writeText(command).then(function() {
1195
+ showRefreshToast('Command copied: ' + command, 'success');
1196
+ }).catch(function() {
1197
+ showRefreshToast('Run: ' + command, 'info');
1198
+ });
1199
+ } else {
1200
+ showRefreshToast('Run: ' + command, 'info');
1201
+ }
1202
+ }
1203
+
1204
+ async function runCcwUpgrade() {
1205
+ showRefreshToast(t('ccw.upgradeStarting'), 'info');
1206
+
1207
+ try {
1208
+ var response = await fetch('/api/ccw/upgrade', {
1209
+ method: 'POST',
1210
+ headers: { 'Content-Type': 'application/json' },
1211
+ body: JSON.stringify({})
1212
+ });
1213
+
1214
+ var result = await response.json();
1215
+
1216
+ if (result.success) {
1217
+ showRefreshToast(t('ccw.upgradeCompleted'), 'success');
1218
+ // Reload installations after upgrade
1219
+ setTimeout(function() {
1220
+ loadCcwInstallations().then(function() {
1221
+ renderCcwInstallPanel();
1222
+ });
1223
+ }, 1000);
1224
+ } else {
1225
+ showRefreshToast(t('ccw.upgradeFailed', { error: result.error || 'Unknown error' }), 'error');
1226
+ }
1227
+ } catch (err) {
1228
+ showRefreshToast(t('ccw.upgradeFailed', { error: err.message }), 'error');
1229
+ }
1230
+ }
1231
+
1232
+ function confirmCcwUninstall(installPath) {
1233
+ if (confirm(t('ccw.uninstallConfirm') + '\n' + (installPath || 'Current installation'))) {
1234
+ var command = installPath
1235
+ ? 'ccw uninstall --path "' + installPath + '"'
1236
+ : 'ccw uninstall';
1237
+
1238
+ if (navigator.clipboard) {
1239
+ navigator.clipboard.writeText(command).then(function() {
1240
+ showRefreshToast('Command copied: ' + command, 'success');
1241
+ }).catch(function() {
1242
+ showRefreshToast('Run: ' + command, 'info');
1243
+ });
1244
+ } else {
1245
+ showRefreshToast('Run: ' + command, 'info');
1246
+ }
1247
+ }
1248
+ }
1249
+
1250
+ // ========== Execution ==========
1251
+ async function executeCliFromDashboard() {
1252
+ var toolEl = document.getElementById('cli-exec-tool');
1253
+ var modeEl = document.getElementById('cli-exec-mode');
1254
+ var promptEl = document.getElementById('cli-exec-prompt');
1255
+
1256
+ var tool = toolEl ? toolEl.value : 'gemini';
1257
+ var mode = modeEl ? modeEl.value : 'analysis';
1258
+ var prompt = promptEl ? promptEl.value.trim() : '';
1259
+
1260
+ if (!prompt) {
1261
+ showRefreshToast(t('toast.enterPrompt'), 'error');
1262
+ return;
1263
+ }
1264
+
1265
+ currentCliExecution = { tool: tool, mode: mode, prompt: prompt, startTime: Date.now() };
1266
+ cliExecutionOutput = '';
1267
+
1268
+ var outputPanel = document.getElementById('cli-output-panel');
1269
+ var outputContent = document.getElementById('cli-output-content');
1270
+ var statusIndicator = document.getElementById('cli-output-status-indicator');
1271
+ var statusText = document.getElementById('cli-output-status-text');
1272
+
1273
+ if (outputPanel) outputPanel.classList.remove('hidden');
1274
+ if (outputContent) outputContent.textContent = '';
1275
+ if (statusIndicator) statusIndicator.className = 'status-indicator running';
1276
+ if (statusText) statusText.textContent = 'Running...';
1277
+
1278
+ var execBtn = document.querySelector('.cli-execute-actions .btn-primary');
1279
+ if (execBtn) execBtn.disabled = true;
1280
+
1281
+ try {
1282
+ var response = await fetch('/api/cli/execute', {
1283
+ method: 'POST',
1284
+ headers: { 'Content-Type': 'application/json' },
1285
+ body: JSON.stringify({
1286
+ tool: tool,
1287
+ mode: mode,
1288
+ prompt: prompt,
1289
+ dir: projectPath,
1290
+ format: promptConcatFormat,
1291
+ smartContext: {
1292
+ enabled: smartContextEnabled,
1293
+ maxFiles: smartContextMaxFiles
1294
+ }
1295
+ })
1296
+ });
1297
+ var result = await response.json();
1298
+
1299
+ if (statusIndicator) statusIndicator.className = 'status-indicator ' + (result.success ? 'success' : 'error');
1300
+ if (statusText) {
1301
+ var duration = formatDuration(result.execution ? result.execution.duration_ms : (Date.now() - currentCliExecution.startTime));
1302
+ statusText.textContent = result.success ? 'Completed in ' + duration : 'Failed: ' + (result.error || 'Unknown');
1303
+ }
1304
+
1305
+ await loadCliHistory();
1306
+ renderCliHistory();
1307
+ showRefreshToast(result.success ? t('toast.completed') : (result.error || t('toast.failed')), result.success ? 'success' : 'error');
1308
+ } catch (error) {
1309
+ if (statusIndicator) statusIndicator.className = 'status-indicator error';
1310
+ if (statusText) statusText.textContent = 'Error: ' + error.message;
1311
+ showRefreshToast(t('toast.error', { error: error.message }), 'error');
1312
+ }
1313
+
1314
+ currentCliExecution = null;
1315
+ if (execBtn) execBtn.disabled = false;
1316
+ }
1317
+
1318
+ // ========== WebSocket Event Handlers ==========
1319
+ function handleCliExecutionStarted(payload) {
1320
+ currentCliExecution = {
1321
+ executionId: payload.executionId,
1322
+ tool: payload.tool,
1323
+ mode: payload.mode,
1324
+ startTime: new Date(payload.timestamp).getTime()
1325
+ };
1326
+ cliExecutionOutput = '';
1327
+
1328
+ // Show toast notification
1329
+ if (typeof addGlobalNotification === 'function') {
1330
+ addGlobalNotification('info', 'CLI ' + payload.tool + ' started', payload.mode + ' mode', 'CLI');
1331
+ }
1332
+
1333
+ if (currentView === 'cli-manager') {
1334
+ var outputPanel = document.getElementById('cli-output-panel');
1335
+ var outputContent = document.getElementById('cli-output-content');
1336
+ var statusIndicator = document.getElementById('cli-output-status-indicator');
1337
+ var statusText = document.getElementById('cli-output-status-text');
1338
+
1339
+ if (outputPanel) outputPanel.classList.remove('hidden');
1340
+ if (outputContent) outputContent.textContent = '';
1341
+ if (statusIndicator) statusIndicator.className = 'status-indicator running';
1342
+ if (statusText) statusText.textContent = 'Running ' + payload.tool + ' (' + payload.mode + ')...';
1343
+ }
1344
+ }
1345
+
1346
+ function handleCliOutput(payload) {
1347
+ cliExecutionOutput += payload.data;
1348
+ var outputContent = document.getElementById('cli-output-content');
1349
+ if (outputContent) {
1350
+ outputContent.textContent = cliExecutionOutput;
1351
+ outputContent.scrollTop = outputContent.scrollHeight;
1352
+ }
1353
+ }
1354
+
1355
+ function handleCliExecutionCompleted(payload) {
1356
+ var statusIndicator = document.getElementById('cli-output-status-indicator');
1357
+ var statusText = document.getElementById('cli-output-status-text');
1358
+
1359
+ if (statusIndicator) statusIndicator.className = 'status-indicator ' + (payload.success ? 'success' : 'error');
1360
+ if (statusText) statusText.textContent = payload.success ? 'Completed in ' + formatDuration(payload.duration_ms) : 'Failed: ' + payload.status;
1361
+
1362
+ // Show toast notification
1363
+ if (typeof addGlobalNotification === 'function') {
1364
+ if (payload.success) {
1365
+ addGlobalNotification('success', 'CLI execution completed', formatDuration(payload.duration_ms), 'CLI');
1366
+ } else {
1367
+ addGlobalNotification('error', 'CLI execution failed', payload.status, 'CLI');
1368
+ }
1369
+ }
1370
+
1371
+ currentCliExecution = null;
1372
+ if (currentView === 'cli-manager') {
1373
+ loadCliHistory().then(function() { renderCliHistory(); });
1374
+ }
1375
+ }
1376
+
1377
+ function handleCliExecutionError(payload) {
1378
+ var statusIndicator = document.getElementById('cli-output-status-indicator');
1379
+ var statusText = document.getElementById('cli-output-status-text');
1380
+
1381
+ if (statusIndicator) statusIndicator.className = 'status-indicator error';
1382
+ if (statusText) statusText.textContent = 'Error: ' + payload.error;
1383
+
1384
+ // Show toast notification
1385
+ if (typeof addGlobalNotification === 'function') {
1386
+ addGlobalNotification('error', 'CLI execution error', payload.error, 'CLI');
1387
+ }
1388
+
1389
+ currentCliExecution = null;
1390
+ }
1391
+
1392
+ // ========== CLI Tool Install/Uninstall Wizards ==========
1393
+ function openCliInstallWizard(toolName) {
1394
+ var toolDescriptions = {
1395
+ gemini: 'Google AI for code analysis and generation',
1396
+ qwen: 'Alibaba AI assistant for coding',
1397
+ codex: 'OpenAI code generation and understanding',
1398
+ claude: 'Anthropic AI assistant'
1399
+ };
1400
+
1401
+ var toolPackages = {
1402
+ gemini: '@google/gemini-cli',
1403
+ qwen: '@qwen-code/qwen-code',
1404
+ codex: '@openai/codex',
1405
+ claude: '@anthropic-ai/claude-code'
1406
+ };
1407
+
1408
+ var modal = document.createElement('div');
1409
+ modal.id = 'cliInstallModal';
1410
+ modal.className = 'fixed inset-0 bg-black/50 flex items-center justify-center z-50';
1411
+ modal.innerHTML =
1412
+ '<div class="bg-card rounded-lg shadow-xl w-full max-w-md mx-4 overflow-hidden">' +
1413
+ '<div class="p-6">' +
1414
+ '<div class="flex items-center gap-3 mb-4">' +
1415
+ '<div class="w-10 h-10 rounded-full bg-primary/10 flex items-center justify-center">' +
1416
+ '<i data-lucide="download" class="w-5 h-5 text-primary"></i>' +
1417
+ '</div>' +
1418
+ '<div>' +
1419
+ '<h3 class="text-lg font-semibold">Install ' + toolName.charAt(0).toUpperCase() + toolName.slice(1) + '</h3>' +
1420
+ '<p class="text-sm text-muted-foreground">' + (toolDescriptions[toolName] || 'CLI tool') + '</p>' +
1421
+ '</div>' +
1422
+ '</div>' +
1423
+ '<div class="space-y-4">' +
1424
+ '<div class="bg-muted/50 rounded-lg p-4">' +
1425
+ '<h4 class="font-medium mb-2">What will be installed:</h4>' +
1426
+ '<ul class="text-sm space-y-2 text-muted-foreground">' +
1427
+ '<li class="flex items-start gap-2">' +
1428
+ '<i data-lucide="check" class="w-4 h-4 text-success mt-0.5"></i>' +
1429
+ '<span><strong>NPM Package:</strong> <code class="bg-muted px-1 rounded">' + (toolPackages[toolName] || toolName) + '</code></span>' +
1430
+ '</li>' +
1431
+ '<li class="flex items-start gap-2">' +
1432
+ '<i data-lucide="check" class="w-4 h-4 text-success mt-0.5"></i>' +
1433
+ '<span><strong>Global installation</strong> - Available system-wide</span>' +
1434
+ '</li>' +
1435
+ '<li class="flex items-start gap-2">' +
1436
+ '<i data-lucide="check" class="w-4 h-4 text-success mt-0.5"></i>' +
1437
+ '<span><strong>CLI commands</strong> - Accessible from terminal</span>' +
1438
+ '</li>' +
1439
+ '</ul>' +
1440
+ '</div>' +
1441
+ '<div class="bg-primary/5 border border-primary/20 rounded-lg p-3">' +
1442
+ '<div class="flex items-start gap-2">' +
1443
+ '<i data-lucide="info" class="w-4 h-4 text-primary mt-0.5"></i>' +
1444
+ '<div class="text-sm text-muted-foreground">' +
1445
+ '<p class="font-medium text-foreground">Installation Method</p>' +
1446
+ '<p class="mt-1">Uses <code class="bg-muted px-1 rounded">npm install -g</code></p>' +
1447
+ '<p class="mt-1">First installation may take 1-2 minutes depending on network speed.</p>' +
1448
+ '</div>' +
1449
+ '</div>' +
1450
+ '</div>' +
1451
+ '<div id="cliInstallProgress" class="hidden">' +
1452
+ '<div class="flex items-center gap-3">' +
1453
+ '<div class="animate-spin w-5 h-5 border-2 border-primary border-t-transparent rounded-full"></div>' +
1454
+ '<span class="text-sm" id="cliInstallStatus">Starting installation...</span>' +
1455
+ '</div>' +
1456
+ '<div class="mt-2 h-2 bg-muted rounded-full overflow-hidden">' +
1457
+ '<div id="cliInstallProgressBar" class="h-full bg-primary transition-all duration-300" style="width: 0%"></div>' +
1458
+ '</div>' +
1459
+ '</div>' +
1460
+ '</div>' +
1461
+ '</div>' +
1462
+ '<div class="border-t border-border p-4 flex justify-end gap-3 bg-muted/30">' +
1463
+ '<button class="btn-outline px-4 py-2" onclick="closeCliInstallWizard()">Cancel</button>' +
1464
+ '<button id="cliInstallBtn" class="btn-primary px-4 py-2" onclick="startCliInstall(\'' + toolName + '\')">' +
1465
+ '<i data-lucide="download" class="w-4 h-4 mr-2"></i>' +
1466
+ 'Install Now' +
1467
+ '</button>' +
1468
+ '</div>' +
1469
+ '</div>';
1470
+
1471
+ document.body.appendChild(modal);
1472
+
1473
+ if (window.lucide) {
1474
+ lucide.createIcons();
1475
+ }
1476
+ }
1477
+
1478
+ function closeCliInstallWizard() {
1479
+ var modal = document.getElementById('cliInstallModal');
1480
+ if (modal) {
1481
+ modal.remove();
1482
+ }
1483
+ }
1484
+
1485
+ async function startCliInstall(toolName) {
1486
+ var progressDiv = document.getElementById('cliInstallProgress');
1487
+ var installBtn = document.getElementById('cliInstallBtn');
1488
+ var statusText = document.getElementById('cliInstallStatus');
1489
+ var progressBar = document.getElementById('cliInstallProgressBar');
1490
+
1491
+ progressDiv.classList.remove('hidden');
1492
+ installBtn.disabled = true;
1493
+ installBtn.innerHTML = '<span class="animate-pulse">Installing...</span>';
1494
+
1495
+ var stages = [
1496
+ { progress: 20, text: 'Connecting to NPM registry...' },
1497
+ { progress: 40, text: 'Downloading package...' },
1498
+ { progress: 60, text: 'Installing dependencies...' },
1499
+ { progress: 80, text: 'Setting up CLI commands...' },
1500
+ { progress: 95, text: 'Finalizing installation...' }
1501
+ ];
1502
+
1503
+ var currentStage = 0;
1504
+ var progressInterval = setInterval(function() {
1505
+ if (currentStage < stages.length) {
1506
+ statusText.textContent = stages[currentStage].text;
1507
+ progressBar.style.width = stages[currentStage].progress + '%';
1508
+ currentStage++;
1509
+ }
1510
+ }, 1000);
1511
+
1512
+ try {
1513
+ var response = await fetch('/api/cli/install', {
1514
+ method: 'POST',
1515
+ headers: { 'Content-Type': 'application/json' },
1516
+ body: JSON.stringify({ tool: toolName })
1517
+ });
1518
+
1519
+ clearInterval(progressInterval);
1520
+ var result = await response.json();
1521
+
1522
+ if (result.success) {
1523
+ progressBar.style.width = '100%';
1524
+ statusText.textContent = 'Installation complete!';
1525
+
1526
+ setTimeout(function() {
1527
+ closeCliInstallWizard();
1528
+ showRefreshToast(toolName + ' installed successfully!', 'success');
1529
+ loadCliToolStatus().then(function() {
1530
+ renderToolsSection();
1531
+ if (window.lucide) lucide.createIcons();
1532
+ });
1533
+ }, 1000);
1534
+ } else {
1535
+ statusText.textContent = 'Error: ' + result.error;
1536
+ progressBar.classList.add('bg-destructive');
1537
+ installBtn.disabled = false;
1538
+ installBtn.innerHTML = '<i data-lucide="refresh-cw" class="w-4 h-4 mr-2"></i> Retry';
1539
+ if (window.lucide) lucide.createIcons();
1540
+ }
1541
+ } catch (err) {
1542
+ clearInterval(progressInterval);
1543
+ statusText.textContent = 'Error: ' + err.message;
1544
+ progressBar.classList.add('bg-destructive');
1545
+ installBtn.disabled = false;
1546
+ installBtn.innerHTML = '<i data-lucide="refresh-cw" class="w-4 h-4 mr-2"></i> Retry';
1547
+ if (window.lucide) lucide.createIcons();
1548
+ }
1549
+ }
1550
+
1551
+ function openCliUninstallWizard(toolName) {
1552
+ var modal = document.createElement('div');
1553
+ modal.id = 'cliUninstallModal';
1554
+ modal.className = 'fixed inset-0 bg-black/50 flex items-center justify-center z-50';
1555
+ modal.innerHTML =
1556
+ '<div class="bg-card rounded-lg shadow-xl w-full max-w-md mx-4 overflow-hidden">' +
1557
+ '<div class="p-6">' +
1558
+ '<div class="flex items-center gap-3 mb-4">' +
1559
+ '<div class="w-10 h-10 rounded-full bg-destructive/10 flex items-center justify-center">' +
1560
+ '<i data-lucide="trash-2" class="w-5 h-5 text-destructive"></i>' +
1561
+ '</div>' +
1562
+ '<div>' +
1563
+ '<h3 class="text-lg font-semibold">Uninstall ' + toolName.charAt(0).toUpperCase() + toolName.slice(1) + '</h3>' +
1564
+ '<p class="text-sm text-muted-foreground">Remove CLI tool from system</p>' +
1565
+ '</div>' +
1566
+ '</div>' +
1567
+ '<div class="space-y-4">' +
1568
+ '<div class="bg-destructive/5 border border-destructive/20 rounded-lg p-4">' +
1569
+ '<h4 class="font-medium text-destructive mb-2">What will be removed:</h4>' +
1570
+ '<ul class="text-sm space-y-2 text-muted-foreground">' +
1571
+ '<li class="flex items-start gap-2">' +
1572
+ '<i data-lucide="x" class="w-4 h-4 text-destructive mt-0.5"></i>' +
1573
+ '<span>Global NPM package</span>' +
1574
+ '</li>' +
1575
+ '<li class="flex items-start gap-2">' +
1576
+ '<i data-lucide="x" class="w-4 h-4 text-destructive mt-0.5"></i>' +
1577
+ '<span>CLI commands and executables</span>' +
1578
+ '</li>' +
1579
+ '<li class="flex items-start gap-2">' +
1580
+ '<i data-lucide="x" class="w-4 h-4 text-destructive mt-0.5"></i>' +
1581
+ '<span>Tool configuration (if any)</span>' +
1582
+ '</li>' +
1583
+ '</ul>' +
1584
+ '</div>' +
1585
+ '<div class="bg-warning/10 border border-warning/20 rounded-lg p-3">' +
1586
+ '<div class="flex items-start gap-2">' +
1587
+ '<i data-lucide="alert-triangle" class="w-4 h-4 text-warning mt-0.5"></i>' +
1588
+ '<div class="text-sm">' +
1589
+ '<p class="font-medium text-warning">Note</p>' +
1590
+ '<p class="text-muted-foreground">You can reinstall this tool anytime from the CLI Manager.</p>' +
1591
+ '</div>' +
1592
+ '</div>' +
1593
+ '</div>' +
1594
+ '<div id="cliUninstallProgress" class="hidden">' +
1595
+ '<div class="flex items-center gap-3">' +
1596
+ '<div class="animate-spin w-5 h-5 border-2 border-destructive border-t-transparent rounded-full"></div>' +
1597
+ '<span class="text-sm" id="cliUninstallStatus">Removing package...</span>' +
1598
+ '</div>' +
1599
+ '<div class="mt-2 h-2 bg-muted rounded-full overflow-hidden">' +
1600
+ '<div id="cliUninstallProgressBar" class="h-full bg-destructive transition-all duration-300" style="width: 0%"></div>' +
1601
+ '</div>' +
1602
+ '</div>' +
1603
+ '</div>' +
1604
+ '</div>' +
1605
+ '<div class="border-t border-border p-4 flex justify-end gap-3 bg-muted/30">' +
1606
+ '<button class="btn-outline px-4 py-2" onclick="closeCliUninstallWizard()">Cancel</button>' +
1607
+ '<button id="cliUninstallBtn" class="btn-destructive px-4 py-2" onclick="startCliUninstall(\'' + toolName + '\')">' +
1608
+ '<i data-lucide="trash-2" class="w-4 h-4 mr-2"></i>' +
1609
+ 'Uninstall' +
1610
+ '</button>' +
1611
+ '</div>' +
1612
+ '</div>';
1613
+
1614
+ document.body.appendChild(modal);
1615
+
1616
+ if (window.lucide) {
1617
+ lucide.createIcons();
1618
+ }
1619
+ }
1620
+
1621
+ function closeCliUninstallWizard() {
1622
+ var modal = document.getElementById('cliUninstallModal');
1623
+ if (modal) {
1624
+ modal.remove();
1625
+ }
1626
+ }
1627
+
1628
+ async function startCliUninstall(toolName) {
1629
+ var progressDiv = document.getElementById('cliUninstallProgress');
1630
+ var uninstallBtn = document.getElementById('cliUninstallBtn');
1631
+ var statusText = document.getElementById('cliUninstallStatus');
1632
+ var progressBar = document.getElementById('cliUninstallProgressBar');
1633
+
1634
+ progressDiv.classList.remove('hidden');
1635
+ uninstallBtn.disabled = true;
1636
+ uninstallBtn.innerHTML = '<span class="animate-pulse">Uninstalling...</span>';
1637
+
1638
+ var stages = [
1639
+ { progress: 33, text: 'Removing package files...' },
1640
+ { progress: 66, text: 'Cleaning up dependencies...' },
1641
+ { progress: 90, text: 'Finalizing removal...' }
1642
+ ];
1643
+
1644
+ var currentStage = 0;
1645
+ var progressInterval = setInterval(function() {
1646
+ if (currentStage < stages.length) {
1647
+ statusText.textContent = stages[currentStage].text;
1648
+ progressBar.style.width = stages[currentStage].progress + '%';
1649
+ currentStage++;
1650
+ }
1651
+ }, 500);
1652
+
1653
+ try {
1654
+ var response = await fetch('/api/cli/uninstall', {
1655
+ method: 'POST',
1656
+ headers: { 'Content-Type': 'application/json' },
1657
+ body: JSON.stringify({ tool: toolName })
1658
+ });
1659
+
1660
+ clearInterval(progressInterval);
1661
+ var result = await response.json();
1662
+
1663
+ if (result.success) {
1664
+ progressBar.style.width = '100%';
1665
+ statusText.textContent = 'Uninstallation complete!';
1666
+
1667
+ setTimeout(function() {
1668
+ closeCliUninstallWizard();
1669
+ showRefreshToast(toolName + ' uninstalled successfully!', 'success');
1670
+ loadCliToolStatus().then(function() {
1671
+ renderToolsSection();
1672
+ if (window.lucide) lucide.createIcons();
1673
+ });
1674
+ }, 1000);
1675
+ } else {
1676
+ statusText.textContent = 'Error: ' + result.error;
1677
+ progressBar.classList.remove('bg-destructive');
1678
+ progressBar.classList.add('bg-destructive');
1679
+ uninstallBtn.disabled = false;
1680
+ uninstallBtn.innerHTML = '<i data-lucide="refresh-cw" class="w-4 h-4 mr-2"></i> Retry';
1681
+ if (window.lucide) lucide.createIcons();
1682
+ }
1683
+ } catch (err) {
1684
+ clearInterval(progressInterval);
1685
+ statusText.textContent = 'Error: ' + err.message;
1686
+ progressBar.classList.remove('bg-destructive');
1687
+ progressBar.classList.add('bg-destructive');
1688
+ uninstallBtn.disabled = false;
1689
+ uninstallBtn.innerHTML = '<i data-lucide="refresh-cw" class="w-4 h-4 mr-2"></i> Retry';
1690
+ if (window.lucide) lucide.createIcons();
1691
+ }
1692
+ }
1693
+
1694
+ // ========== CodexLens Configuration Modal ==========
1695
+ async function showCodexLensConfigModal() {
1696
+ var loadingContent = '<div class="text-center py-8">' +
1697
+ '<div class="animate-spin w-8 h-8 border-2 border-primary border-t-transparent rounded-full mx-auto mb-4"></div>' +
1698
+ '<p class="text-muted-foreground">' + t('codexlens.loadingConfig') + '</p>' +
1699
+ '</div>';
1700
+
1701
+ showModal(t('codexlens.config'), loadingContent, { size: 'md' });
1702
+
1703
+ try {
1704
+ // Fetch current configuration
1705
+ var response = await fetch('/api/codexlens/config');
1706
+ var config = await response.json();
1707
+
1708
+ var content = buildCodexLensConfigContent(config);
1709
+ showModal('CodexLens Configuration', content, { size: 'md' });
1710
+
1711
+ setTimeout(function() {
1712
+ initCodexLensConfigEvents(config);
1713
+ if (window.lucide) lucide.createIcons();
1714
+ }, 100);
1715
+ } catch (err) {
1716
+ var errorContent = '<div class="bg-destructive/10 border border-destructive/20 rounded-lg p-4">' +
1717
+ '<div class="flex items-start gap-2">' +
1718
+ '<i data-lucide="alert-circle" class="w-5 h-5 text-destructive mt-0.5"></i>' +
1719
+ '<div>' +
1720
+ '<p class="font-medium text-destructive">Failed to load configuration</p>' +
1721
+ '<p class="text-sm text-muted-foreground mt-1">' + err.message + '</p>' +
1722
+ '</div>' +
1723
+ '</div>' +
1724
+ '</div>';
1725
+ showModal('CodexLens Configuration', errorContent, { size: 'md' });
1726
+ }
1727
+ }
1728
+
1729
+ function buildCodexLensConfigContent(config) {
1730
+ var status = codexLensStatus || {};
1731
+ var isInstalled = status.ready;
1732
+ var indexDir = config.index_dir || '~/.codexlens/indexes';
1733
+ var currentWorkspace = config.current_workspace || 'None';
1734
+ var indexCount = config.index_count || 0;
1735
+
1736
+ return '<div class="tool-config-modal">' +
1737
+ // Status Section
1738
+ '<div class="tool-config-section">' +
1739
+ '<h4>' + t('codexlens.status') + '</h4>' +
1740
+ '<div class="tool-config-badges">' +
1741
+ '<span class="badge ' + (isInstalled ? 'badge-success' : 'badge-muted') + '">' +
1742
+ '<i data-lucide="' + (isInstalled ? 'check-circle' : 'circle-dashed') + '" class="w-3 h-3"></i> ' +
1743
+ (isInstalled ? t('codexlens.installed') : t('codexlens.notInstalled')) +
1744
+ '</span>' +
1745
+ '<span class="badge badge-primary">' +
1746
+ '<i data-lucide="database" class="w-3 h-3"></i> ' + indexCount + ' ' + t('codexlens.indexes') +
1747
+ '</span>' +
1748
+ '</div>' +
1749
+ (currentWorkspace !== 'None'
1750
+ ? '<div class="mt-3 p-3 bg-muted/30 rounded-lg">' +
1751
+ '<p class="text-sm text-muted-foreground mb-1">' + t('codexlens.currentWorkspace') + ':</p>' +
1752
+ '<p class="text-sm font-mono break-all">' + escapeHtml(currentWorkspace) + '</p>' +
1753
+ '</div>'
1754
+ : '') +
1755
+ '</div>' +
1756
+
1757
+ // Index Storage Path Section
1758
+ '<div class="tool-config-section">' +
1759
+ '<h4>' + t('codexlens.indexStoragePath') + ' <span class="text-muted">(' + t('codexlens.whereIndexesStored') + ')</span></h4>' +
1760
+ '<div class="space-y-3">' +
1761
+ '<div class="bg-muted/30 rounded-lg p-3">' +
1762
+ '<p class="text-sm text-muted-foreground mb-2">' + t('codexlens.currentPath') + ':</p>' +
1763
+ '<p class="text-sm font-mono break-all bg-background px-2 py-1 rounded border border-border">' +
1764
+ escapeHtml(indexDir) +
1765
+ '</p>' +
1766
+ '</div>' +
1767
+ '<div>' +
1768
+ '<label class="text-sm font-medium mb-2 block">' + t('codexlens.newStoragePath') + ':</label>' +
1769
+ '<input type="text" id="indexDirInput" class="tool-config-input w-full" ' +
1770
+ 'placeholder="' + t('codexlens.pathPlaceholder') + '" ' +
1771
+ 'value="' + escapeHtml(indexDir) + '" />' +
1772
+ '<p class="text-xs text-muted-foreground mt-2">' +
1773
+ '<i data-lucide="info" class="w-3 h-3 inline"></i> ' +
1774
+ t('codexlens.pathInfo') +
1775
+ '</p>' +
1776
+ '</div>' +
1777
+ '<div class="bg-warning/10 border border-warning/20 rounded-lg p-3">' +
1778
+ '<div class="flex items-start gap-2">' +
1779
+ '<i data-lucide="alert-triangle" class="w-4 h-4 text-warning mt-0.5"></i>' +
1780
+ '<div class="text-sm">' +
1781
+ '<p class="font-medium text-warning">' + t('codexlens.migrationRequired') + '</p>' +
1782
+ '<p class="text-muted-foreground mt-1">' + t('codexlens.migrationWarning') + '</p>' +
1783
+ '</div>' +
1784
+ '</div>' +
1785
+ '</div>' +
1786
+ '</div>' +
1787
+ '</div>' +
1788
+
1789
+ // Actions Section
1790
+ '<div class="tool-config-section">' +
1791
+ '<h4>' + t('codexlens.actions') + '</h4>' +
1792
+ '<div class="tool-config-actions">' +
1793
+ (isInstalled
1794
+ ? '<button class="btn-sm btn-outline" onclick="event.stopPropagation(); initCodexLensIndex()">' +
1795
+ '<i data-lucide="database" class="w-3 h-3"></i> ' + t('codexlens.initializeIndex') +
1796
+ '</button>' +
1797
+ '<button class="btn-sm btn-outline" onclick="event.stopPropagation(); cleanCurrentWorkspaceIndex()">' +
1798
+ '<i data-lucide="folder-x" class="w-3 h-3"></i> ' + t('codexlens.cleanCurrentWorkspace') +
1799
+ '</button>' +
1800
+ '<button class="btn-sm btn-outline" onclick="event.stopPropagation(); cleanCodexLensIndexes()">' +
1801
+ '<i data-lucide="trash" class="w-3 h-3"></i> ' + t('codexlens.cleanAllIndexes') +
1802
+ '</button>' +
1803
+ '<button class="btn-sm btn-outline btn-danger" onclick="event.stopPropagation(); uninstallCodexLens()">' +
1804
+ '<i data-lucide="trash-2" class="w-3 h-3"></i> ' + t('cli.uninstall') +
1805
+ '</button>'
1806
+ : '<button class="btn-sm btn-primary" onclick="event.stopPropagation(); installCodexLens()">' +
1807
+ '<i data-lucide="download" class="w-3 h-3"></i> ' + t('codexlens.installCodexLens') +
1808
+ '</button>') +
1809
+ '</div>' +
1810
+ '</div>' +
1811
+
1812
+ // Semantic Dependencies Section
1813
+ (isInstalled
1814
+ ? '<div class="tool-config-section">' +
1815
+ '<h4>' + t('codexlens.semanticDeps') + '</h4>' +
1816
+ '<div id="semanticDepsStatus" class="space-y-2">' +
1817
+ '<div class="text-sm text-muted-foreground">' + t('codexlens.checkingDeps') + '</div>' +
1818
+ '</div>' +
1819
+ '</div>'
1820
+ : '') +
1821
+
1822
+ // Model Management Section
1823
+ (isInstalled
1824
+ ? '<div class="tool-config-section">' +
1825
+ '<h4>' + t('codexlens.modelManagement') + '</h4>' +
1826
+ '<div id="modelListContainer" class="space-y-2">' +
1827
+ '<div class="text-sm text-muted-foreground">' + t('codexlens.loadingModels') + '</div>' +
1828
+ '</div>' +
1829
+ '</div>'
1830
+ : '') +
1831
+
1832
+ // Test Search Section
1833
+ (isInstalled
1834
+ ? '<div class="tool-config-section">' +
1835
+ '<h4>' + t('codexlens.testSearch') + ' <span class="text-muted">(' + t('codexlens.testFunctionality') + ')</span></h4>' +
1836
+ '<div class="space-y-3">' +
1837
+ '<div class="flex gap-2">' +
1838
+ '<select id="searchTypeSelect" class="tool-config-select flex-1">' +
1839
+ '<option value="search">' + t('codexlens.textSearch') + '</option>' +
1840
+ '<option value="search_files">' + t('codexlens.fileSearch') + '</option>' +
1841
+ '<option value="symbol">' + t('codexlens.symbolSearch') + '</option>' +
1842
+ '</select>' +
1843
+ '<select id="searchModeSelect" class="tool-config-select flex-1">' +
1844
+ '<option value="exact">' + t('codexlens.exactMode') + '</option>' +
1845
+ '<option value="fuzzy">' + t('codexlens.fuzzyMode') + '</option>' +
1846
+ '<option value="hybrid">' + t('codexlens.hybridMode') + '</option>' +
1847
+ '<option value="vector">' + t('codexlens.vectorMode') + '</option>' +
1848
+ '</select>' +
1849
+ '</div>' +
1850
+ '<div>' +
1851
+ '<input type="text" id="searchQueryInput" class="tool-config-input w-full" ' +
1852
+ 'placeholder="' + t('codexlens.searchPlaceholder') + '" />' +
1853
+ '</div>' +
1854
+ '<div>' +
1855
+ '<button class="btn-sm btn-primary w-full" id="runSearchBtn">' +
1856
+ '<i data-lucide="search" class="w-3 h-3"></i> ' + t('codexlens.runSearch') +
1857
+ '</button>' +
1858
+ '</div>' +
1859
+ '<div id="searchResults" class="hidden">' +
1860
+ '<div class="bg-muted/30 rounded-lg p-3 max-h-64 overflow-y-auto">' +
1861
+ '<div class="flex items-center justify-between mb-2">' +
1862
+ '<p class="text-sm font-medium">' + t('codexlens.results') + ':</p>' +
1863
+ '<span id="searchResultCount" class="text-xs text-muted-foreground"></span>' +
1864
+ '</div>' +
1865
+ '<pre id="searchResultContent" class="text-xs font-mono whitespace-pre-wrap break-all"></pre>' +
1866
+ '</div>' +
1867
+ '</div>' +
1868
+ '</div>' +
1869
+ '</div>'
1870
+ : '') +
1871
+
1872
+ // Footer
1873
+ '<div class="tool-config-footer">' +
1874
+ '<button class="btn btn-outline" onclick="closeModal()">' + t('common.cancel') + '</button>' +
1875
+ '<button class="btn btn-primary" id="saveCodexLensConfigBtn">' +
1876
+ '<i data-lucide="save" class="w-3.5 h-3.5"></i> ' + t('codexlens.saveConfig') +
1877
+ '</button>' +
1878
+ '</div>' +
1879
+ '</div>';
1880
+ }
1881
+
1882
+ function initCodexLensConfigEvents(currentConfig) {
1883
+ var saveBtn = document.getElementById('saveCodexLensConfigBtn');
1884
+ if (saveBtn) {
1885
+ saveBtn.onclick = async function() {
1886
+ var indexDirInput = document.getElementById('indexDirInput');
1887
+ var newIndexDir = indexDirInput ? indexDirInput.value.trim() : '';
1888
+
1889
+ if (!newIndexDir) {
1890
+ showRefreshToast(t('codexlens.pathEmpty'), 'error');
1891
+ return;
1892
+ }
1893
+
1894
+ if (newIndexDir === currentConfig.index_dir) {
1895
+ closeModal();
1896
+ return;
1897
+ }
1898
+
1899
+ saveBtn.disabled = true;
1900
+ saveBtn.innerHTML = '<span class="animate-pulse">' + t('common.saving') + '</span>';
1901
+
1902
+ try {
1903
+ var response = await fetch('/api/codexlens/config', {
1904
+ method: 'POST',
1905
+ headers: { 'Content-Type': 'application/json' },
1906
+ body: JSON.stringify({ index_dir: newIndexDir })
1907
+ });
1908
+
1909
+ var result = await response.json();
1910
+
1911
+ if (result.success) {
1912
+ showRefreshToast(t('codexlens.configSaved'), 'success');
1913
+ closeModal();
1914
+
1915
+ // Refresh CodexLens status
1916
+ if (typeof loadCodexLensStatus === 'function') {
1917
+ await loadCodexLensStatus();
1918
+ renderToolsSection();
1919
+ if (window.lucide) lucide.createIcons();
1920
+ }
1921
+ } else {
1922
+ showRefreshToast(t('common.saveFailed') + ': ' + result.error, 'error');
1923
+ saveBtn.disabled = false;
1924
+ saveBtn.innerHTML = '<i data-lucide="save" class="w-3.5 h-3.5"></i> ' + t('codexlens.saveConfig');
1925
+ if (window.lucide) lucide.createIcons();
1926
+ }
1927
+ } catch (err) {
1928
+ showRefreshToast(t('common.error') + ': ' + err.message, 'error');
1929
+ saveBtn.disabled = false;
1930
+ saveBtn.innerHTML = '<i data-lucide="save" class="w-3.5 h-3.5"></i> ' + t('codexlens.saveConfig');
1931
+ if (window.lucide) lucide.createIcons();
1932
+ }
1933
+ };
1934
+ }
1935
+
1936
+ // Test Search Button
1937
+ var runSearchBtn = document.getElementById('runSearchBtn');
1938
+ if (runSearchBtn) {
1939
+ runSearchBtn.onclick = async function() {
1940
+ var searchType = document.getElementById('searchTypeSelect').value;
1941
+ var searchMode = document.getElementById('searchModeSelect').value;
1942
+ var query = document.getElementById('searchQueryInput').value.trim();
1943
+ var resultsDiv = document.getElementById('searchResults');
1944
+ var resultCount = document.getElementById('searchResultCount');
1945
+ var resultContent = document.getElementById('searchResultContent');
1946
+
1947
+ if (!query) {
1948
+ showRefreshToast(t('codexlens.enterQuery'), 'warning');
1949
+ return;
1950
+ }
1951
+
1952
+ runSearchBtn.disabled = true;
1953
+ runSearchBtn.innerHTML = '<span class="animate-pulse">' + t('codexlens.searching') + '</span>';
1954
+ resultsDiv.classList.add('hidden');
1955
+
1956
+ try {
1957
+ var endpoint = '/api/codexlens/' + searchType;
1958
+ var params = new URLSearchParams({ query: query, limit: '20' });
1959
+ // Add mode parameter for search and search_files (not for symbol search)
1960
+ if (searchType === 'search' || searchType === 'search_files') {
1961
+ params.append('mode', searchMode);
1962
+ }
1963
+
1964
+ var response = await fetch(endpoint + '?' + params.toString());
1965
+ var result = await response.json();
1966
+
1967
+ console.log('[CodexLens Test] Search result:', result);
1968
+
1969
+ if (result.success) {
1970
+ var results = result.results || result.files || [];
1971
+ resultCount.textContent = results.length + ' ' + t('codexlens.resultsCount');
1972
+ resultContent.textContent = JSON.stringify(results, null, 2);
1973
+ resultsDiv.classList.remove('hidden');
1974
+ showRefreshToast(t('codexlens.searchCompleted') + ': ' + results.length + ' ' + t('codexlens.resultsCount'), 'success');
1975
+ } else {
1976
+ resultContent.textContent = t('common.error') + ': ' + (result.error || t('common.unknownError'));
1977
+ resultsDiv.classList.remove('hidden');
1978
+ showRefreshToast(t('codexlens.searchFailed') + ': ' + result.error, 'error');
1979
+ }
1980
+
1981
+ runSearchBtn.disabled = false;
1982
+ runSearchBtn.innerHTML = '<i data-lucide="search" class="w-3 h-3"></i> ' + t('codexlens.runSearch');
1983
+ if (window.lucide) lucide.createIcons();
1984
+ } catch (err) {
1985
+ console.error('[CodexLens Test] Error:', err);
1986
+ resultContent.textContent = t('common.exception') + ': ' + err.message;
1987
+ resultsDiv.classList.remove('hidden');
1988
+ showRefreshToast(t('common.error') + ': ' + err.message, 'error');
1989
+ runSearchBtn.disabled = false;
1990
+ runSearchBtn.innerHTML = '<i data-lucide="search" class="w-3 h-3"></i> ' + t('codexlens.runSearch');
1991
+ if (window.lucide) lucide.createIcons();
1992
+ }
1993
+ };
1994
+ }
1995
+
1996
+ // Load semantic dependencies status
1997
+ loadSemanticDepsStatus();
1998
+
1999
+ // Load model list
2000
+ loadModelList();
2001
+ }
2002
+
2003
+ // Load semantic dependencies status
2004
+ async function loadSemanticDepsStatus() {
2005
+ var container = document.getElementById('semanticDepsStatus');
2006
+ if (!container) return;
2007
+
2008
+ try {
2009
+ var response = await fetch('/api/codexlens/semantic/status');
2010
+ var result = await response.json();
2011
+
2012
+ if (result.available) {
2013
+ container.innerHTML =
2014
+ '<div class="flex items-center gap-2 text-sm">' +
2015
+ '<i data-lucide="check-circle" class="w-4 h-4 text-success"></i>' +
2016
+ '<span>' + t('codexlens.semanticInstalled') + '</span>' +
2017
+ '<span class="text-muted-foreground">(' + (result.backend || 'fastembed') + ')</span>' +
2018
+ '</div>';
2019
+ } else {
2020
+ container.innerHTML =
2021
+ '<div class="space-y-2">' +
2022
+ '<div class="flex items-center gap-2 text-sm text-muted-foreground">' +
2023
+ '<i data-lucide="alert-circle" class="w-4 h-4"></i>' +
2024
+ '<span>' + t('codexlens.semanticNotInstalled') + '</span>' +
2025
+ '</div>' +
2026
+ '<button class="btn-sm btn-outline" onclick="installSemanticDeps()">' +
2027
+ '<i data-lucide="download" class="w-3 h-3"></i> ' + t('codexlens.installDeps') +
2028
+ '</button>' +
2029
+ '</div>';
2030
+ }
2031
+ if (window.lucide) lucide.createIcons();
2032
+ } catch (err) {
2033
+ container.innerHTML =
2034
+ '<div class="text-sm text-error">' + t('common.error') + ': ' + err.message + '</div>';
2035
+ }
2036
+ }
2037
+
2038
+ // Install semantic dependencies
2039
+ async function installSemanticDeps() {
2040
+ var container = document.getElementById('semanticDepsStatus');
2041
+ if (!container) return;
2042
+
2043
+ container.innerHTML =
2044
+ '<div class="text-sm text-muted-foreground animate-pulse">' + t('codexlens.installingDeps') + '</div>';
2045
+
2046
+ try {
2047
+ var response = await fetch('/api/codexlens/semantic/install', { method: 'POST' });
2048
+ var result = await response.json();
2049
+
2050
+ if (result.success) {
2051
+ showRefreshToast(t('codexlens.depsInstalled'), 'success');
2052
+ await loadSemanticDepsStatus();
2053
+ await loadModelList();
2054
+ } else {
2055
+ showRefreshToast(t('codexlens.depsInstallFailed') + ': ' + result.error, 'error');
2056
+ await loadSemanticDepsStatus();
2057
+ }
2058
+ } catch (err) {
2059
+ showRefreshToast(t('common.error') + ': ' + err.message, 'error');
2060
+ await loadSemanticDepsStatus();
2061
+ }
2062
+ }
2063
+
2064
+ // Load model list
2065
+ async function loadModelList() {
2066
+ var container = document.getElementById('modelListContainer');
2067
+ if (!container) return;
2068
+
2069
+ try {
2070
+ var response = await fetch('/api/codexlens/models');
2071
+ var result = await response.json();
2072
+
2073
+ if (!result.success || !result.result || !result.result.models) {
2074
+ container.innerHTML =
2075
+ '<div class="text-sm text-muted-foreground">' + t('codexlens.semanticNotInstalled') + '</div>';
2076
+ return;
2077
+ }
2078
+
2079
+ var models = result.result.models;
2080
+ var html = '<div class="space-y-2">';
2081
+
2082
+ models.forEach(function(model) {
2083
+ var statusIcon = model.installed
2084
+ ? '<i data-lucide="check-circle" class="w-4 h-4 text-success"></i>'
2085
+ : '<i data-lucide="circle" class="w-4 h-4 text-muted"></i>';
2086
+
2087
+ var sizeText = model.installed
2088
+ ? model.actual_size_mb.toFixed(1) + ' MB'
2089
+ : '~' + model.estimated_size_mb + ' MB';
2090
+
2091
+ var actionBtn = model.installed
2092
+ ? '<button class="btn-sm btn-outline btn-danger" onclick="deleteModel(\'' + model.profile + '\')">' +
2093
+ '<i data-lucide="trash-2" class="w-3 h-3"></i> ' + t('codexlens.deleteModel') +
2094
+ '</button>'
2095
+ : '<button class="btn-sm btn-outline" onclick="downloadModel(\'' + model.profile + '\')">' +
2096
+ '<i data-lucide="download" class="w-3 h-3"></i> ' + t('codexlens.downloadModel') +
2097
+ '</button>';
2098
+
2099
+ html +=
2100
+ '<div class="border rounded-lg p-3 space-y-2" id="model-' + model.profile + '">' +
2101
+ '<div class="flex items-start justify-between">' +
2102
+ '<div class="flex-1">' +
2103
+ '<div class="flex items-center gap-2 mb-1">' +
2104
+ statusIcon +
2105
+ '<span class="font-medium">' + model.profile + '</span>' +
2106
+ '<span class="text-xs text-muted-foreground">(' + model.dimensions + ' dims)</span>' +
2107
+ '</div>' +
2108
+ '<div class="text-xs text-muted-foreground mb-1">' + model.model_name + '</div>' +
2109
+ '<div class="text-xs text-muted-foreground">' + model.use_case + '</div>' +
2110
+ '</div>' +
2111
+ '<div class="text-right">' +
2112
+ '<div class="text-xs text-muted-foreground mb-2">' + sizeText + '</div>' +
2113
+ actionBtn +
2114
+ '</div>' +
2115
+ '</div>' +
2116
+ '</div>';
2117
+ });
2118
+
2119
+ html += '</div>';
2120
+ container.innerHTML = html;
2121
+ if (window.lucide) lucide.createIcons();
2122
+ } catch (err) {
2123
+ container.innerHTML =
2124
+ '<div class="text-sm text-error">' + t('common.error') + ': ' + err.message + '</div>';
2125
+ }
2126
+ }
2127
+
2128
+ // Download model
2129
+ async function downloadModel(profile) {
2130
+ var modelCard = document.getElementById('model-' + profile);
2131
+ if (!modelCard) return;
2132
+
2133
+ var originalHTML = modelCard.innerHTML;
2134
+ modelCard.innerHTML =
2135
+ '<div class="flex items-center justify-center p-3">' +
2136
+ '<span class="text-sm text-muted-foreground animate-pulse">' + t('codexlens.downloading') + '</span>' +
2137
+ '</div>';
2138
+
2139
+ try {
2140
+ var response = await fetch('/api/codexlens/models/download', {
2141
+ method: 'POST',
2142
+ headers: { 'Content-Type': 'application/json' },
2143
+ body: JSON.stringify({ profile: profile })
2144
+ });
2145
+
2146
+ var result = await response.json();
2147
+
2148
+ if (result.success) {
2149
+ showRefreshToast(t('codexlens.modelDownloaded') + ': ' + profile, 'success');
2150
+ await loadModelList();
2151
+ } else {
2152
+ showRefreshToast(t('codexlens.modelDownloadFailed') + ': ' + result.error, 'error');
2153
+ modelCard.innerHTML = originalHTML;
2154
+ if (window.lucide) lucide.createIcons();
2155
+ }
2156
+ } catch (err) {
2157
+ showRefreshToast(t('common.error') + ': ' + err.message, 'error');
2158
+ modelCard.innerHTML = originalHTML;
2159
+ if (window.lucide) lucide.createIcons();
2160
+ }
2161
+ }
2162
+
2163
+ // Delete model
2164
+ async function deleteModel(profile) {
2165
+ if (!confirm(t('codexlens.deleteModelConfirm') + ' ' + profile + '?')) {
2166
+ return;
2167
+ }
2168
+
2169
+ var modelCard = document.getElementById('model-' + profile);
2170
+ if (!modelCard) return;
2171
+
2172
+ var originalHTML = modelCard.innerHTML;
2173
+ modelCard.innerHTML =
2174
+ '<div class="flex items-center justify-center p-3">' +
2175
+ '<span class="text-sm text-muted-foreground animate-pulse">' + t('codexlens.deleting') + '</span>' +
2176
+ '</div>';
2177
+
2178
+ try {
2179
+ var response = await fetch('/api/codexlens/models/delete', {
2180
+ method: 'POST',
2181
+ headers: { 'Content-Type': 'application/json' },
2182
+ body: JSON.stringify({ profile: profile })
2183
+ });
2184
+
2185
+ var result = await response.json();
2186
+
2187
+ if (result.success) {
2188
+ showRefreshToast(t('codexlens.modelDeleted') + ': ' + profile, 'success');
2189
+ await loadModelList();
2190
+ } else {
2191
+ showRefreshToast(t('codexlens.modelDeleteFailed') + ': ' + result.error, 'error');
2192
+ modelCard.innerHTML = originalHTML;
2193
+ if (window.lucide) lucide.createIcons();
2194
+ }
2195
+ } catch (err) {
2196
+ showRefreshToast(t('common.error') + ': ' + err.message, 'error');
2197
+ modelCard.innerHTML = originalHTML;
2198
+ if (window.lucide) lucide.createIcons();
2199
+ }
2200
+ }
2201
+ /**
2202
+ * Clean current workspace index
2203
+ */
2204
+ async function cleanCurrentWorkspaceIndex() {
2205
+ if (!confirm(t('codexlens.cleanCurrentWorkspaceConfirm'))) {
2206
+ return;
2207
+ }
2208
+
2209
+ try {
2210
+ showRefreshToast(t('codexlens.cleaning'), 'info');
2211
+
2212
+ // Get current workspace path (projectPath is a global variable from state.js)
2213
+ var workspacePath = projectPath;
2214
+
2215
+ var response = await fetch('/api/codexlens/clean', {
2216
+ method: 'POST',
2217
+ headers: { 'Content-Type': 'application/json' },
2218
+ body: JSON.stringify({ path: workspacePath })
2219
+ });
2220
+
2221
+ var result = await response.json();
2222
+
2223
+ if (result.success) {
2224
+ showRefreshToast(t('codexlens.cleanCurrentWorkspaceSuccess'), 'success');
2225
+
2226
+ // Refresh status
2227
+ if (typeof loadCodexLensStatus === 'function') {
2228
+ await loadCodexLensStatus();
2229
+ renderToolsSection();
2230
+ if (window.lucide) lucide.createIcons();
2231
+ }
2232
+ } else {
2233
+ showRefreshToast(t('codexlens.cleanFailed') + ': ' + result.error, 'error');
2234
+ }
2235
+ } catch (err) {
2236
+ showRefreshToast(t('common.error') + ': ' + err.message, 'error');
2237
+ }
2238
+ }
2239
+
2240
+ /**
2241
+ * Clean all CodexLens indexes
2242
+ */
2243
+ async function cleanCodexLensIndexes() {
2244
+ if (!confirm(t('codexlens.cleanConfirm'))) {
2245
+ return;
2246
+ }
2247
+
2248
+ try {
2249
+ showRefreshToast(t('codexlens.cleaning'), 'info');
2250
+
2251
+ var response = await fetch('/api/codexlens/clean', {
2252
+ method: 'POST',
2253
+ headers: { 'Content-Type': 'application/json' },
2254
+ body: JSON.stringify({ all: true })
2255
+ });
2256
+
2257
+ var result = await response.json();
2258
+
2259
+ if (result.success) {
2260
+ showRefreshToast(t('codexlens.cleanSuccess'), 'success');
2261
+
2262
+ // Refresh status
2263
+ if (typeof loadCodexLensStatus === 'function') {
2264
+ await loadCodexLensStatus();
2265
+ renderToolsSection();
2266
+ if (window.lucide) lucide.createIcons();
2267
+ }
2268
+ } else {
2269
+ showRefreshToast(t('codexlens.cleanFailed') + ': ' + result.error, 'error');
2270
+ }
2271
+ } catch (err) {
2272
+ showRefreshToast(t('common.error') + ': ' + err.message, 'error');
2273
+ }
2274
+ }