claude-code-workflow 6.1.4 → 6.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (437) hide show
  1. package/.claude/CLAUDE.md +10 -0
  2. package/.claude/agents/action-planning-agent.md +857 -778
  3. package/.claude/agents/cli-execution-agent.md +266 -269
  4. package/.claude/agents/cli-explore-agent.md +2 -2
  5. package/.claude/agents/cli-lite-planning-agent.md +142 -92
  6. package/.claude/agents/cli-planning-agent.md +4 -4
  7. package/.claude/agents/code-developer.md +7 -6
  8. package/.claude/agents/conceptual-planning-agent.md +2 -2
  9. package/.claude/agents/context-search-agent.md +31 -32
  10. package/.claude/agents/doc-generator.md +4 -4
  11. package/.claude/agents/memory-bridge.md +93 -93
  12. package/.claude/agents/test-context-search-agent.md +8 -7
  13. package/.claude/agents/test-fix-agent.md +7 -6
  14. package/.claude/commands/clean.md +516 -0
  15. package/.claude/commands/memory/compact.md +383 -0
  16. package/.claude/commands/memory/docs-full-cli.md +471 -471
  17. package/.claude/commands/memory/docs-related-cli.md +386 -386
  18. package/.claude/commands/memory/docs.md +615 -615
  19. package/.claude/commands/memory/load.md +5 -5
  20. package/.claude/commands/memory/tech-research-rules.md +310 -0
  21. package/.claude/commands/memory/update-full.md +332 -332
  22. package/.claude/commands/memory/workflow-skill-memory.md +4 -4
  23. package/.claude/commands/task/create.md +151 -151
  24. package/.claude/commands/version.md +254 -254
  25. package/.claude/commands/workflow/brainstorm/api-designer.md +587 -585
  26. package/.claude/commands/workflow/brainstorm/artifacts.md +1 -0
  27. package/.claude/commands/workflow/brainstorm/auto-parallel.md +443 -443
  28. package/.claude/commands/workflow/brainstorm/data-architect.md +220 -220
  29. package/.claude/commands/workflow/brainstorm/product-manager.md +200 -200
  30. package/.claude/commands/workflow/brainstorm/product-owner.md +200 -200
  31. package/.claude/commands/workflow/brainstorm/scrum-master.md +200 -200
  32. package/.claude/commands/workflow/brainstorm/subject-matter-expert.md +200 -200
  33. package/.claude/commands/workflow/brainstorm/system-architect.md +389 -387
  34. package/.claude/commands/workflow/brainstorm/ui-designer.md +221 -221
  35. package/.claude/commands/workflow/brainstorm/ux-expert.md +221 -221
  36. package/.claude/commands/workflow/debug.md +321 -0
  37. package/.claude/commands/workflow/execute.md +13 -0
  38. package/.claude/commands/workflow/init.md +165 -164
  39. package/.claude/commands/workflow/lite-execute.md +119 -13
  40. package/.claude/commands/workflow/lite-fix.md +623 -621
  41. package/.claude/commands/workflow/lite-plan.md +610 -592
  42. package/.claude/commands/workflow/plan.md +5 -5
  43. package/.claude/commands/workflow/review-module-cycle.md +2 -0
  44. package/.claude/commands/workflow/review-session-cycle.md +2 -0
  45. package/.claude/commands/workflow/review.md +297 -291
  46. package/.claude/commands/workflow/session/complete.md +153 -500
  47. package/.claude/commands/workflow/session/list.md +95 -95
  48. package/.claude/commands/workflow/session/resume.md +60 -60
  49. package/.claude/commands/workflow/session/start.md +199 -199
  50. package/.claude/commands/workflow/tdd-plan.md +3 -3
  51. package/.claude/commands/workflow/tdd-verify.md +23 -9
  52. package/.claude/commands/workflow/test-cycle-execute.md +2 -0
  53. package/.claude/commands/workflow/test-fix-gen.md +699 -699
  54. package/.claude/commands/workflow/tools/conflict-resolution.md +104 -18
  55. package/.claude/commands/workflow/tools/context-gather.md +436 -434
  56. package/.claude/commands/workflow/tools/task-generate-agent.md +490 -291
  57. package/.claude/commands/workflow/tools/task-generate-tdd.md +18 -10
  58. package/.claude/commands/workflow/tools/test-concept-enhanced.md +2 -1
  59. package/.claude/commands/workflow/tools/test-context-gather.md +1 -0
  60. package/.claude/commands/workflow/tools/test-task-generate.md +1 -0
  61. package/.claude/commands/workflow/ui-design/import-from-code.md +9 -6
  62. package/.claude/skills/command-guide/SKILL.md +5 -5
  63. package/.claude/skills/command-guide/index/all-commands.json +1 -1
  64. package/.claude/skills/command-guide/index/by-category.json +1 -1
  65. package/.claude/skills/command-guide/index/by-use-case.json +1 -1
  66. package/.claude/skills/command-guide/reference/agents/action-planning-agent.md +857 -778
  67. package/.claude/skills/command-guide/reference/agents/cli-execution-agent.md +266 -269
  68. package/.claude/skills/command-guide/reference/agents/cli-explore-agent.md +2 -2
  69. package/.claude/skills/command-guide/reference/agents/cli-lite-planning-agent.md +142 -92
  70. package/.claude/skills/command-guide/reference/agents/cli-planning-agent.md +4 -4
  71. package/.claude/skills/command-guide/reference/agents/code-developer.md +7 -6
  72. package/.claude/skills/command-guide/reference/agents/conceptual-planning-agent.md +2 -2
  73. package/.claude/skills/command-guide/reference/agents/context-search-agent.md +31 -32
  74. package/.claude/skills/command-guide/reference/agents/doc-generator.md +4 -4
  75. package/.claude/skills/command-guide/reference/agents/memory-bridge.md +93 -93
  76. package/.claude/skills/command-guide/reference/agents/test-context-search-agent.md +8 -7
  77. package/.claude/skills/command-guide/reference/agents/test-fix-agent.md +7 -6
  78. package/.claude/skills/command-guide/reference/commands/memory/docs-full-cli.md +471 -471
  79. package/.claude/skills/command-guide/reference/commands/memory/docs-related-cli.md +386 -386
  80. package/.claude/skills/command-guide/reference/commands/memory/docs.md +17 -16
  81. package/.claude/skills/command-guide/reference/commands/memory/load.md +5 -5
  82. package/.claude/skills/command-guide/reference/commands/memory/tech-research.md +194 -357
  83. package/.claude/skills/command-guide/reference/commands/memory/update-full.md +332 -332
  84. package/.claude/skills/command-guide/reference/commands/memory/workflow-skill-memory.md +4 -4
  85. package/.claude/skills/command-guide/reference/commands/task/create.md +151 -151
  86. package/.claude/skills/command-guide/reference/commands/version.md +254 -254
  87. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/api-designer.md +585 -585
  88. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/auto-parallel.md +443 -443
  89. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/data-architect.md +220 -220
  90. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-manager.md +200 -200
  91. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-owner.md +200 -200
  92. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/scrum-master.md +200 -200
  93. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/subject-matter-expert.md +200 -200
  94. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/system-architect.md +387 -387
  95. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ui-designer.md +221 -221
  96. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ux-expert.md +221 -221
  97. package/.claude/skills/command-guide/reference/commands/workflow/execute.md +25 -20
  98. package/.claude/skills/command-guide/reference/commands/workflow/init.md +164 -164
  99. package/.claude/skills/command-guide/reference/commands/workflow/lite-execute.md +748 -686
  100. package/.claude/skills/command-guide/reference/commands/workflow/lite-fix.md +664 -621
  101. package/.claude/skills/command-guide/reference/commands/workflow/lite-plan.md +645 -592
  102. package/.claude/skills/command-guide/reference/commands/workflow/plan.md +5 -5
  103. package/.claude/skills/command-guide/reference/commands/workflow/review.md +25 -18
  104. package/.claude/skills/command-guide/reference/commands/workflow/session/complete.md +547 -500
  105. package/.claude/skills/command-guide/reference/commands/workflow/session/list.md +45 -27
  106. package/.claude/skills/command-guide/reference/commands/workflow/session/resume.md +35 -19
  107. package/.claude/skills/command-guide/reference/commands/workflow/session/start.md +90 -33
  108. package/.claude/skills/command-guide/reference/commands/workflow/tdd-plan.md +3 -3
  109. package/.claude/skills/command-guide/reference/commands/workflow/tdd-verify.md +23 -9
  110. package/.claude/skills/command-guide/reference/commands/workflow/test-fix-gen.md +699 -699
  111. package/.claude/skills/command-guide/reference/commands/workflow/tools/conflict-resolution.md +103 -17
  112. package/.claude/skills/command-guide/reference/commands/workflow/tools/context-gather.md +434 -434
  113. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-agent.md +487 -291
  114. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-tdd.md +17 -10
  115. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-concept-enhanced.md +1 -1
  116. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/import-from-code.md +6 -6
  117. package/.claude/workflows/chinese-response.md +38 -0
  118. package/.claude/workflows/cli-templates/prompts/rules/rule-api.txt +122 -0
  119. package/.claude/workflows/cli-templates/prompts/rules/rule-components.txt +122 -0
  120. package/.claude/workflows/cli-templates/prompts/rules/rule-config.txt +89 -0
  121. package/.claude/workflows/cli-templates/prompts/rules/rule-core.txt +60 -0
  122. package/.claude/workflows/cli-templates/prompts/rules/rule-patterns.txt +70 -0
  123. package/.claude/workflows/cli-templates/prompts/rules/rule-testing.txt +81 -0
  124. package/.claude/workflows/cli-templates/prompts/rules/tech-rules-agent-prompt.txt +89 -0
  125. package/.claude/workflows/cli-templates/prompts/workflow/gemini-solution-design.txt +131 -131
  126. package/.claude/workflows/cli-templates/prompts/workflow/skill-conflict-patterns.txt +5 -9
  127. package/.claude/workflows/cli-templates/prompts/workflow/skill-lessons-learned.txt +5 -9
  128. package/.claude/workflows/cli-templates/protocols/analysis-protocol.md +112 -0
  129. package/.claude/workflows/cli-templates/protocols/write-protocol.md +201 -0
  130. package/.claude/workflows/cli-templates/schemas/conflict-resolution-schema.json +137 -0
  131. package/.claude/workflows/cli-templates/schemas/debug-log-json-schema.json +127 -0
  132. package/.claude/workflows/cli-templates/schemas/fix-plan-json-schema.json +25 -0
  133. package/.claude/workflows/cli-templates/schemas/plan-json-schema.json +25 -0
  134. package/.claude/workflows/cli-tools-usage.md +526 -0
  135. package/{CLAUDE.md → .claude/workflows/coding-philosophy.md} +24 -45
  136. package/.claude/workflows/context-tools.md +84 -0
  137. package/.claude/workflows/file-modification.md +64 -0
  138. package/.claude/workflows/tool-strategy.md +216 -79
  139. package/.claude/workflows/windows-platform.md +16 -0
  140. package/.claude/workflows/workflow-architecture.md +942 -942
  141. package/.codex/AGENTS.md +63 -330
  142. package/.codex/prompts/debug.md +318 -0
  143. package/.codex/prompts/execute.md +273 -0
  144. package/.codex/prompts/lite-execute.md +164 -0
  145. package/.codex/prompts/lite-plan.md +469 -0
  146. package/.codex/prompts.zip +0 -0
  147. package/.gemini/GEMINI.md +25 -164
  148. package/.qwen/QWEN.md +0 -139
  149. package/README.md +29 -9
  150. package/ccw/README.md +30 -6
  151. package/ccw/bin/ccw-mcp.js +7 -0
  152. package/ccw/bin/ccw.js +9 -9
  153. package/ccw/package.json +65 -47
  154. package/ccw/src/.workflow/.cli-history/history.db +0 -0
  155. package/ccw/src/.workflow/.cli-history/history.db-shm +0 -0
  156. package/ccw/src/.workflow/.cli-history/history.db-wal +0 -0
  157. package/ccw/src/cli.ts +244 -0
  158. package/ccw/src/commands/cli.ts +740 -0
  159. package/ccw/src/commands/core-memory.ts +770 -0
  160. package/ccw/src/commands/hook.ts +315 -0
  161. package/ccw/src/commands/install.ts +519 -0
  162. package/ccw/src/commands/{list.js → list.ts} +1 -1
  163. package/ccw/src/commands/memory.ts +1090 -0
  164. package/ccw/src/commands/{serve.js → serve.ts} +14 -5
  165. package/ccw/src/commands/session-path-resolver.ts +372 -0
  166. package/ccw/src/commands/session.ts +1141 -0
  167. package/ccw/src/commands/{stop.js → stop.ts} +16 -6
  168. package/ccw/src/commands/tool.ts +201 -0
  169. package/ccw/src/commands/{uninstall.js → uninstall.ts} +89 -40
  170. package/ccw/src/commands/{upgrade.js → upgrade.ts} +68 -23
  171. package/ccw/src/commands/{view.js → view.ts} +22 -8
  172. package/ccw/src/config/storage-paths.ts +670 -0
  173. package/ccw/src/core/cache-manager.ts +294 -0
  174. package/ccw/src/core/claude-freshness.ts +319 -0
  175. package/ccw/src/core/core-memory-store.ts +1528 -0
  176. package/ccw/src/core/{dashboard-generator-patch.js → dashboard-generator-patch.ts} +18 -0
  177. package/ccw/src/core/{dashboard-generator.js → dashboard-generator.ts} +69 -12
  178. package/ccw/src/core/data-aggregator.ts +584 -0
  179. package/ccw/src/core/history-importer.ts +625 -0
  180. package/ccw/src/core/{lite-scanner.js → lite-scanner-complete.ts} +162 -66
  181. package/ccw/src/core/lite-scanner.ts +469 -0
  182. package/ccw/src/core/{manifest.js → manifest.ts} +104 -34
  183. package/ccw/src/core/memory-embedder-bridge.ts +262 -0
  184. package/ccw/src/core/memory-store.ts +978 -0
  185. package/ccw/src/core/routes/ccw-routes.ts +96 -0
  186. package/ccw/src/core/routes/claude-routes.ts +1183 -0
  187. package/ccw/src/core/routes/cli-routes.ts +561 -0
  188. package/ccw/src/core/routes/codexlens-routes.ts +806 -0
  189. package/ccw/src/core/routes/core-memory-routes.ts +605 -0
  190. package/ccw/src/core/routes/files-routes.ts +428 -0
  191. package/ccw/src/core/routes/graph-routes.md +164 -0
  192. package/ccw/src/core/routes/graph-routes.ts +626 -0
  193. package/ccw/src/core/routes/help-routes.ts +308 -0
  194. package/ccw/src/core/routes/hooks-routes.ts +405 -0
  195. package/ccw/src/core/routes/mcp-routes.ts +1271 -0
  196. package/ccw/src/core/routes/mcp-routes.ts.backup +550 -0
  197. package/ccw/src/core/routes/mcp-templates-db.ts +268 -0
  198. package/ccw/src/core/routes/memory-routes.ts +1206 -0
  199. package/ccw/src/core/routes/rules-routes.ts +526 -0
  200. package/ccw/src/core/routes/session-routes.ts +467 -0
  201. package/ccw/src/core/routes/skills-routes.ts +599 -0
  202. package/ccw/src/core/routes/status-routes.ts +57 -0
  203. package/ccw/src/core/routes/system-routes.ts +427 -0
  204. package/ccw/src/core/server.ts +431 -0
  205. package/ccw/src/core/session-clustering-service.ts +1258 -0
  206. package/ccw/src/core/session-scanner.ts +283 -0
  207. package/ccw/src/core/websocket.ts +190 -0
  208. package/ccw/src/{index.js → index.ts} +1 -0
  209. package/ccw/src/mcp-server/index.ts +186 -0
  210. package/ccw/src/templates/assets/css/github-dark.min.css +10 -0
  211. package/ccw/src/templates/assets/css/github.min.css +10 -0
  212. package/ccw/src/templates/assets/js/cytoscape.min.js +32 -0
  213. package/ccw/src/templates/assets/js/d3.min.js +2 -0
  214. package/ccw/src/templates/assets/js/highlight.min.js +1244 -0
  215. package/ccw/src/templates/assets/js/lucide.min.js +12 -0
  216. package/ccw/src/templates/assets/js/marked.min.js +69 -0
  217. package/ccw/src/templates/assets/js/tailwind.js +83 -0
  218. package/ccw/src/templates/dashboard-css/01-base.css +11 -0
  219. package/ccw/src/templates/dashboard-css/02-session.css +22 -0
  220. package/ccw/src/templates/dashboard-css/04-lite-tasks.css +10 -0
  221. package/ccw/src/templates/dashboard-css/06-cards.css +10 -4
  222. package/ccw/src/templates/dashboard-css/07-managers.css +1178 -7
  223. package/ccw/src/templates/dashboard-css/09-explorer.css +23 -12
  224. package/ccw/src/templates/dashboard-css/10-cli-status.css +337 -0
  225. package/ccw/src/templates/dashboard-css/11-cli-history.css +271 -0
  226. package/ccw/src/templates/dashboard-css/12-cli-legacy.css +796 -0
  227. package/ccw/src/templates/dashboard-css/13-cli-ccw.css +199 -0
  228. package/ccw/src/templates/dashboard-css/14-cli-modals.css +258 -0
  229. package/ccw/src/templates/dashboard-css/15-cli-endpoints.css +305 -0
  230. package/ccw/src/templates/dashboard-css/16-cli-session.css +241 -0
  231. package/ccw/src/templates/dashboard-css/17-cli-conversation.css +283 -0
  232. package/ccw/src/templates/dashboard-css/18-cli-settings.css +160 -0
  233. package/ccw/src/templates/dashboard-css/19-cli-native-session.css +496 -0
  234. package/ccw/src/templates/dashboard-css/20-cli-taskqueue.css +188 -0
  235. package/ccw/src/templates/dashboard-css/21-cli-toolmgmt.css +310 -0
  236. package/ccw/src/templates/dashboard-css/22-cli-semantic.css +240 -0
  237. package/ccw/src/templates/dashboard-css/23-memory.css +2390 -0
  238. package/ccw/src/templates/dashboard-css/24-prompt-history.css +1089 -0
  239. package/ccw/src/templates/dashboard-css/25-skills-rules.css +326 -0
  240. package/ccw/src/templates/dashboard-css/26-claude-manager.css +908 -0
  241. package/ccw/src/templates/dashboard-css/27-graph-explorer.css +1678 -0
  242. package/ccw/src/templates/dashboard-css/28-mcp-manager.css +748 -0
  243. package/ccw/src/templates/dashboard-css/29-help.css +264 -0
  244. package/ccw/src/templates/dashboard-css/30-core-memory.css +1700 -0
  245. package/ccw/src/templates/dashboard-js/api.js +162 -142
  246. package/ccw/src/templates/dashboard-js/components/carousel.js +4 -4
  247. package/ccw/src/templates/dashboard-js/components/cli-history.js +876 -0
  248. package/ccw/src/templates/dashboard-js/components/cli-status.js +978 -0
  249. package/ccw/src/templates/dashboard-js/components/global-notifications.js +508 -219
  250. package/ccw/src/templates/dashboard-js/components/hook-manager.js +1277 -282
  251. package/ccw/src/templates/dashboard-js/components/index-manager.js +302 -0
  252. package/ccw/src/templates/dashboard-js/components/mcp-manager.js +718 -27
  253. package/ccw/src/templates/dashboard-js/components/modals.js +66 -0
  254. package/ccw/src/templates/dashboard-js/components/navigation.js +80 -12
  255. package/ccw/src/templates/dashboard-js/components/notifications.js +758 -194
  256. package/ccw/src/templates/dashboard-js/components/storage-manager.js +478 -0
  257. package/ccw/src/templates/dashboard-js/components/tabs-other.js +157 -6
  258. package/ccw/src/templates/dashboard-js/components/task-queue-sidebar.js +716 -0
  259. package/ccw/src/templates/dashboard-js/help-i18n.js +272 -0
  260. package/ccw/src/templates/dashboard-js/i18n.js +2807 -0
  261. package/ccw/src/templates/dashboard-js/main.js +15 -0
  262. package/ccw/src/templates/dashboard-js/state.js +243 -42
  263. package/ccw/src/templates/dashboard-js/utils.js +47 -1
  264. package/ccw/src/templates/dashboard-js/views/claude-manager.js +912 -0
  265. package/ccw/src/templates/dashboard-js/views/cli-manager.js +2272 -0
  266. package/ccw/src/templates/dashboard-js/views/codexlens-manager.js +964 -0
  267. package/ccw/src/templates/dashboard-js/views/core-memory-clusters.js +503 -0
  268. package/ccw/src/templates/dashboard-js/views/core-memory.js +782 -0
  269. package/ccw/src/templates/dashboard-js/views/explorer.js +888 -852
  270. package/ccw/src/templates/dashboard-js/views/graph-explorer.js +1157 -0
  271. package/ccw/src/templates/dashboard-js/views/help.js +856 -0
  272. package/ccw/src/templates/dashboard-js/views/history.js +337 -0
  273. package/ccw/src/templates/dashboard-js/views/home.js +61 -15
  274. package/ccw/src/templates/dashboard-js/views/hook-manager.js +311 -43
  275. package/ccw/src/templates/dashboard-js/views/lite-tasks.js +204 -28
  276. package/ccw/src/templates/dashboard-js/views/mcp-manager.js +2187 -411
  277. package/ccw/src/templates/dashboard-js/views/mcp-manager.js.backup +1729 -0
  278. package/ccw/src/templates/dashboard-js/views/mcp-manager.js.new +928 -0
  279. package/ccw/src/templates/dashboard-js/views/memory.js +1221 -0
  280. package/ccw/src/templates/dashboard-js/views/prompt-history.js +713 -0
  281. package/ccw/src/templates/dashboard-js/views/rules-manager.js +828 -0
  282. package/ccw/src/templates/dashboard-js/views/session-detail.js +54 -53
  283. package/ccw/src/templates/dashboard-js/views/skills-manager.js +819 -0
  284. package/ccw/src/templates/dashboard.html +185 -85
  285. package/ccw/src/templates/hooks-config-example.json +60 -0
  286. package/ccw/src/tools/classify-folders.ts +245 -0
  287. package/ccw/src/tools/cli-config-manager.ts +268 -0
  288. package/ccw/src/tools/cli-executor.ts +2014 -0
  289. package/ccw/src/tools/cli-history-store.ts +1195 -0
  290. package/ccw/src/tools/codex-lens.ts +1141 -0
  291. package/ccw/src/tools/{convert-tokens-to-css.js → convert-tokens-to-css.ts} +73 -23
  292. package/ccw/src/tools/core-memory.ts +444 -0
  293. package/ccw/src/tools/detect-changed-modules.ts +325 -0
  294. package/ccw/src/tools/{discover-design-files.js → discover-design-files.ts} +74 -24
  295. package/ccw/src/tools/edit-file.ts +568 -0
  296. package/ccw/src/tools/{generate-module-docs.js → generate-module-docs.ts} +207 -185
  297. package/ccw/src/tools/{get-modules-by-depth.js → get-modules-by-depth.ts} +120 -79
  298. package/ccw/src/tools/index.ts +370 -0
  299. package/ccw/src/tools/native-session-discovery.ts +795 -0
  300. package/ccw/src/tools/notifier.ts +129 -0
  301. package/ccw/src/tools/read-file.ts +410 -0
  302. package/ccw/src/tools/resume-strategy.ts +345 -0
  303. package/ccw/src/tools/session-content-parser.ts +619 -0
  304. package/ccw/src/tools/session-manager.ts +1026 -0
  305. package/ccw/src/tools/smart-context.ts +228 -0
  306. package/ccw/src/tools/smart-search.ts +2065 -0
  307. package/ccw/src/tools/smart-search.ts.backup +1233 -0
  308. package/ccw/src/tools/storage-manager.ts +455 -0
  309. package/ccw/src/tools/write-file.ts +222 -0
  310. package/ccw/src/types/config.ts +11 -0
  311. package/ccw/src/types/index.ts +3 -0
  312. package/ccw/src/types/session.ts +25 -0
  313. package/ccw/src/types/tool.ts +41 -0
  314. package/ccw/src/utils/{browser-launcher.js → browser-launcher.ts} +10 -8
  315. package/ccw/src/utils/file-utils.ts +48 -0
  316. package/ccw/src/utils/{path-resolver.js → path-resolver.ts} +114 -78
  317. package/ccw/src/utils/path-validator.ts +153 -0
  318. package/ccw/src/utils/{ui.js → ui.ts} +32 -25
  319. package/codex-lens/pyproject.toml +48 -0
  320. package/codex-lens/src/codexlens/.workflow/.cli-history/history.db +0 -0
  321. package/codex-lens/src/codexlens/__init__.py +28 -0
  322. package/codex-lens/src/codexlens/__main__.py +14 -0
  323. package/codex-lens/src/codexlens/__pycache__/__init__.cpython-313.pyc +0 -0
  324. package/codex-lens/src/codexlens/__pycache__/__main__.cpython-313.pyc +0 -0
  325. package/codex-lens/src/codexlens/__pycache__/config.cpython-313.pyc +0 -0
  326. package/codex-lens/src/codexlens/__pycache__/entities.cpython-313.pyc +0 -0
  327. package/codex-lens/src/codexlens/__pycache__/errors.cpython-313.pyc +0 -0
  328. package/codex-lens/src/codexlens/cli/__init__.py +27 -0
  329. package/codex-lens/src/codexlens/cli/__pycache__/__init__.cpython-313.pyc +0 -0
  330. package/codex-lens/src/codexlens/cli/__pycache__/commands.cpython-313.pyc +0 -0
  331. package/codex-lens/src/codexlens/cli/__pycache__/embedding_manager.cpython-313.pyc +0 -0
  332. package/codex-lens/src/codexlens/cli/__pycache__/model_manager.cpython-313.pyc +0 -0
  333. package/codex-lens/src/codexlens/cli/__pycache__/output.cpython-313.pyc +0 -0
  334. package/codex-lens/src/codexlens/cli/commands.py +1931 -0
  335. package/codex-lens/src/codexlens/cli/embedding_manager.py +620 -0
  336. package/codex-lens/src/codexlens/cli/model_manager.py +289 -0
  337. package/codex-lens/src/codexlens/cli/output.py +124 -0
  338. package/codex-lens/src/codexlens/config.py +201 -0
  339. package/codex-lens/src/codexlens/entities.py +121 -0
  340. package/codex-lens/src/codexlens/errors.py +55 -0
  341. package/codex-lens/src/codexlens/indexing/README.md +77 -0
  342. package/codex-lens/src/codexlens/indexing/__init__.py +4 -0
  343. package/codex-lens/src/codexlens/indexing/__pycache__/__init__.cpython-313.pyc +0 -0
  344. package/codex-lens/src/codexlens/indexing/__pycache__/symbol_extractor.cpython-313.pyc +0 -0
  345. package/codex-lens/src/codexlens/indexing/symbol_extractor.py +243 -0
  346. package/codex-lens/src/codexlens/parsers/__init__.py +8 -0
  347. package/codex-lens/src/codexlens/parsers/__pycache__/__init__.cpython-313.pyc +0 -0
  348. package/codex-lens/src/codexlens/parsers/__pycache__/encoding.cpython-313.pyc +0 -0
  349. package/codex-lens/src/codexlens/parsers/__pycache__/factory.cpython-313.pyc +0 -0
  350. package/codex-lens/src/codexlens/parsers/__pycache__/tokenizer.cpython-313.pyc +0 -0
  351. package/codex-lens/src/codexlens/parsers/__pycache__/treesitter_parser.cpython-313.pyc +0 -0
  352. package/codex-lens/src/codexlens/parsers/encoding.py +202 -0
  353. package/codex-lens/src/codexlens/parsers/factory.py +256 -0
  354. package/codex-lens/src/codexlens/parsers/tokenizer.py +98 -0
  355. package/codex-lens/src/codexlens/parsers/treesitter_parser.py +335 -0
  356. package/codex-lens/src/codexlens/search/__init__.py +15 -0
  357. package/codex-lens/src/codexlens/search/__pycache__/__init__.cpython-313.pyc +0 -0
  358. package/codex-lens/src/codexlens/search/__pycache__/chain_search.cpython-313.pyc +0 -0
  359. package/codex-lens/src/codexlens/search/__pycache__/enrichment.cpython-313.pyc +0 -0
  360. package/codex-lens/src/codexlens/search/__pycache__/hybrid_search.cpython-313.pyc +0 -0
  361. package/codex-lens/src/codexlens/search/__pycache__/query_parser.cpython-313.pyc +0 -0
  362. package/codex-lens/src/codexlens/search/__pycache__/ranking.cpython-313.pyc +0 -0
  363. package/codex-lens/src/codexlens/search/chain_search.py +647 -0
  364. package/codex-lens/src/codexlens/search/enrichment.py +150 -0
  365. package/codex-lens/src/codexlens/search/hybrid_search.py +313 -0
  366. package/codex-lens/src/codexlens/search/query_parser.py +242 -0
  367. package/codex-lens/src/codexlens/search/ranking.py +274 -0
  368. package/codex-lens/src/codexlens/semantic/__init__.py +39 -0
  369. package/codex-lens/src/codexlens/semantic/__pycache__/__init__.cpython-313.pyc +0 -0
  370. package/codex-lens/src/codexlens/semantic/__pycache__/ann_index.cpython-313.pyc +0 -0
  371. package/codex-lens/src/codexlens/semantic/__pycache__/chunker.cpython-313.pyc +0 -0
  372. package/codex-lens/src/codexlens/semantic/__pycache__/code_extractor.cpython-313.pyc +0 -0
  373. package/codex-lens/src/codexlens/semantic/__pycache__/embedder.cpython-313.pyc +0 -0
  374. package/codex-lens/src/codexlens/semantic/__pycache__/graph_analyzer.cpython-313.pyc +0 -0
  375. package/codex-lens/src/codexlens/semantic/__pycache__/llm_enhancer.cpython-313.pyc +0 -0
  376. package/codex-lens/src/codexlens/semantic/__pycache__/vector_store.cpython-313.pyc +0 -0
  377. package/codex-lens/src/codexlens/semantic/ann_index.py +414 -0
  378. package/codex-lens/src/codexlens/semantic/chunker.py +448 -0
  379. package/codex-lens/src/codexlens/semantic/code_extractor.py +274 -0
  380. package/codex-lens/src/codexlens/semantic/embedder.py +185 -0
  381. package/codex-lens/src/codexlens/semantic/vector_store.py +955 -0
  382. package/codex-lens/src/codexlens/storage/__init__.py +29 -0
  383. package/codex-lens/src/codexlens/storage/__pycache__/__init__.cpython-313.pyc +0 -0
  384. package/codex-lens/src/codexlens/storage/__pycache__/dir_index.cpython-313.pyc +0 -0
  385. package/codex-lens/src/codexlens/storage/__pycache__/file_cache.cpython-313.pyc +0 -0
  386. package/codex-lens/src/codexlens/storage/__pycache__/index_tree.cpython-313.pyc +0 -0
  387. package/codex-lens/src/codexlens/storage/__pycache__/migration_manager.cpython-313.pyc +0 -0
  388. package/codex-lens/src/codexlens/storage/__pycache__/path_mapper.cpython-313.pyc +0 -0
  389. package/codex-lens/src/codexlens/storage/__pycache__/registry.cpython-313.pyc +0 -0
  390. package/codex-lens/src/codexlens/storage/__pycache__/sqlite_store.cpython-313.pyc +0 -0
  391. package/codex-lens/src/codexlens/storage/__pycache__/sqlite_utils.cpython-313.pyc +0 -0
  392. package/codex-lens/src/codexlens/storage/dir_index.py +1850 -0
  393. package/codex-lens/src/codexlens/storage/file_cache.py +32 -0
  394. package/codex-lens/src/codexlens/storage/index_tree.py +776 -0
  395. package/codex-lens/src/codexlens/storage/migration_manager.py +154 -0
  396. package/codex-lens/src/codexlens/storage/migrations/__init__.py +1 -0
  397. package/codex-lens/src/codexlens/storage/migrations/__pycache__/__init__.cpython-313.pyc +0 -0
  398. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_001_normalize_keywords.cpython-313.pyc +0 -0
  399. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_002_add_token_metadata.cpython-313.pyc +0 -0
  400. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_003_code_relationships.cpython-313.pyc +0 -0
  401. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_004_dual_fts.cpython-313.pyc +0 -0
  402. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_005_cleanup_unused_fields.cpython-313.pyc +0 -0
  403. package/codex-lens/src/codexlens/storage/migrations/migration_001_normalize_keywords.py +123 -0
  404. package/codex-lens/src/codexlens/storage/migrations/migration_002_add_token_metadata.py +48 -0
  405. package/codex-lens/src/codexlens/storage/migrations/migration_004_dual_fts.py +232 -0
  406. package/codex-lens/src/codexlens/storage/migrations/migration_005_cleanup_unused_fields.py +196 -0
  407. package/codex-lens/src/codexlens/storage/path_mapper.py +274 -0
  408. package/codex-lens/src/codexlens/storage/registry.py +670 -0
  409. package/codex-lens/src/codexlens/storage/sqlite_store.py +576 -0
  410. package/codex-lens/src/codexlens/storage/sqlite_utils.py +64 -0
  411. package/package.json +4 -1
  412. package/.claude/commands/memory/tech-research.md +0 -477
  413. package/.claude/scripts/classify-folders.sh +0 -39
  414. package/.claude/scripts/convert_tokens_to_css.sh +0 -229
  415. package/.claude/scripts/detect_changed_modules.sh +0 -161
  416. package/.claude/scripts/discover-design-files.sh +0 -87
  417. package/.claude/scripts/extract-animations.js +0 -243
  418. package/.claude/scripts/extract-computed-styles.js +0 -118
  419. package/.claude/scripts/extract-layout-structure.js +0 -411
  420. package/.claude/scripts/generate_module_docs.sh +0 -717
  421. package/.claude/scripts/get_modules_by_depth.sh +0 -170
  422. package/.claude/scripts/ui-generate-preview.sh +0 -395
  423. package/.claude/scripts/ui-instantiate-prototypes.sh +0 -815
  424. package/.claude/scripts/update_module_claude.sh +0 -337
  425. package/.claude/workflows/context-search-strategy.md +0 -77
  426. package/.claude/workflows/intelligent-tools-strategy.md +0 -662
  427. package/ccw/src/cli.js +0 -119
  428. package/ccw/src/commands/install.js +0 -324
  429. package/ccw/src/commands/tool.js +0 -138
  430. package/ccw/src/core/data-aggregator.js +0 -409
  431. package/ccw/src/core/server.js +0 -2063
  432. package/ccw/src/core/session-scanner.js +0 -235
  433. package/ccw/src/tools/classify-folders.js +0 -204
  434. package/ccw/src/tools/detect-changed-modules.js +0 -288
  435. package/ccw/src/tools/edit-file.js +0 -266
  436. package/ccw/src/tools/index.js +0 -176
  437. package/ccw/src/utils/file-utils.js +0 -48
@@ -0,0 +1,856 @@
1
+ // ==========================================
2
+ // HELP VIEW
3
+ // Command guide with categories, workflow diagrams, and CodexLens quick-start
4
+ // ==========================================
5
+
6
+ // State variables
7
+ var helpData = {
8
+ commands: [],
9
+ grouped: {},
10
+ workflows: {},
11
+ codexlens: {}
12
+ };
13
+ var activeHelpTab = 'cli';
14
+ var helpSearchQuery = '';
15
+ var helpSearchTimeout = null;
16
+ var cytoscapeInstance = null;
17
+ var activeWorkflowDiagram = 'decision';
18
+
19
+ // ========== Main Render Function ==========
20
+ async function renderHelpView() {
21
+ // Debug: Check if ht function is available
22
+ console.log('[Help View] ht function available:', typeof ht, typeof window.ht);
23
+
24
+ hideStatsAndCarousel();
25
+
26
+ var container = document.getElementById('mainContent');
27
+ if (!container) return;
28
+
29
+ // Show loading state
30
+ container.innerHTML = '<div class="flex items-center justify-center py-16"><i data-lucide="loader-2" class="w-8 h-8 animate-spin"></i></div>';
31
+ if (typeof lucide !== 'undefined') lucide.createIcons();
32
+
33
+ // Load help data
34
+ await loadHelpData();
35
+
36
+ // Render layout
37
+ container.innerHTML = renderHelpLayout();
38
+
39
+ // Initialize event handlers
40
+ initializeHelpEventHandlers();
41
+
42
+ // Render initial tab
43
+ renderCommandsTab(activeHelpTab);
44
+
45
+ if (typeof lucide !== 'undefined') lucide.createIcons();
46
+ }
47
+
48
+ // ========== Data Loading ==========
49
+ async function loadHelpData() {
50
+ try {
51
+ // Load all commands with grouping
52
+ var commandsResp = await fetch('/api/help/commands');
53
+ if (commandsResp.ok) {
54
+ var data = await commandsResp.json();
55
+ helpData.commands = data.commands || [];
56
+ helpData.grouped = data.grouped || {};
57
+ }
58
+
59
+ // Load workflow relationships
60
+ var workflowsResp = await fetch('/api/help/workflows');
61
+ if (workflowsResp.ok) {
62
+ helpData.workflows = await workflowsResp.json();
63
+ }
64
+
65
+ // Load CodexLens data
66
+ var codexResp = await fetch('/api/help/codexlens');
67
+ if (codexResp.ok) {
68
+ helpData.codexlens = await codexResp.json();
69
+ }
70
+ } catch (err) {
71
+ console.error('Failed to load help data:', err);
72
+ }
73
+ }
74
+
75
+ // ========== Layout Rendering ==========
76
+ function renderHelpLayout() {
77
+ return `
78
+ <div class="help-view-container">
79
+ <!-- Page Header -->
80
+ <div class="bg-card border border-border rounded-lg p-6 mb-6">
81
+ <h2 class="text-2xl font-bold text-foreground mb-2 flex items-center gap-2">
82
+ <i data-lucide="help-circle" class="w-6 h-6"></i>
83
+ ${ht('help.title')}
84
+ </h2>
85
+ <p class="text-muted-foreground">
86
+ ${ht('help.subtitle')}
87
+ </p>
88
+ </div>
89
+
90
+ <!-- Search Bar -->
91
+ <div class="bg-card border border-border rounded-lg p-4 mb-6">
92
+ <div class="relative">
93
+ <i data-lucide="search" class="absolute left-3 top-1/2 transform -translate-y-1/2 w-4 h-4 text-muted-foreground"></i>
94
+ <input
95
+ type="text"
96
+ id="helpSearchInput"
97
+ class="w-full pl-10 pr-4 py-2 bg-background border border-border rounded-lg text-foreground focus:outline-none focus:ring-2 focus:ring-primary"
98
+ placeholder="${ht('help.search.placeholder')}"
99
+ value="${escapeHtml(helpSearchQuery)}"
100
+ />
101
+ </div>
102
+ </div>
103
+
104
+ <!-- Main Tab Navigation -->
105
+ <div class="bg-card border border-border rounded-lg overflow-hidden">
106
+ <div class="flex border-b border-border">
107
+ <button class="help-main-tab flex-1 px-6 py-3 text-sm font-medium transition-colors" data-tab="cli">
108
+ ${ht('help.tab.cli')}
109
+ </button>
110
+ <button class="help-main-tab flex-1 px-6 py-3 text-sm font-medium transition-colors" data-tab="memory">
111
+ ${ht('help.tab.memory')}
112
+ </button>
113
+ <button class="help-main-tab flex-1 px-6 py-3 text-sm font-medium transition-colors" data-tab="workflow">
114
+ ${ht('help.tab.workflow')}
115
+ </button>
116
+ <button class="help-main-tab flex-1 px-6 py-3 text-sm font-medium transition-colors" data-tab="task">
117
+ ${ht('help.tab.task')}
118
+ </button>
119
+ <button class="help-main-tab flex-1 px-6 py-3 text-sm font-medium transition-colors" data-tab="diagrams">
120
+ <i data-lucide="git-branch" class="w-4 h-4 inline-block mr-1"></i>
121
+ ${ht('help.tab.diagrams')}
122
+ </button>
123
+ <button class="help-main-tab flex-1 px-6 py-3 text-sm font-medium transition-colors" data-tab="codexlens">
124
+ <i data-lucide="zap" class="w-4 h-4 inline-block mr-1"></i>
125
+ ${ht('help.tab.codexlens')}
126
+ </button>
127
+ </div>
128
+
129
+ <!-- Tab Content Container -->
130
+ <div id="helpTabContent" class="p-6">
131
+ <!-- Content will be dynamically rendered -->
132
+ </div>
133
+ </div>
134
+ </div>
135
+ `;
136
+ }
137
+
138
+ // ========== Event Handlers ==========
139
+ function initializeHelpEventHandlers() {
140
+ // Tab switching
141
+ var tabs = document.querySelectorAll('.help-main-tab');
142
+ tabs.forEach(function(tab) {
143
+ tab.addEventListener('click', function() {
144
+ var tabName = this.dataset.tab;
145
+ switchHelpTab(tabName);
146
+ });
147
+ });
148
+
149
+ // Update active tab styles
150
+ updateActiveTab(activeHelpTab);
151
+
152
+ // Search input with debounce
153
+ var searchInput = document.getElementById('helpSearchInput');
154
+ if (searchInput) {
155
+ searchInput.addEventListener('input', function(e) {
156
+ clearTimeout(helpSearchTimeout);
157
+ helpSearchTimeout = setTimeout(function() {
158
+ helpSearchQuery = e.target.value;
159
+ performHelpSearch();
160
+ }, 300);
161
+ });
162
+ }
163
+ }
164
+
165
+ function switchHelpTab(tabName) {
166
+ activeHelpTab = tabName;
167
+ updateActiveTab(tabName);
168
+
169
+ if (tabName === 'diagrams') {
170
+ renderWorkflowDiagrams();
171
+ } else if (tabName === 'codexlens') {
172
+ renderCodexLensQuickStart();
173
+ } else {
174
+ renderCommandsTab(tabName);
175
+ }
176
+ }
177
+
178
+ function updateActiveTab(activeTab) {
179
+ var tabs = document.querySelectorAll('.help-main-tab');
180
+ tabs.forEach(function(tab) {
181
+ if (tab.dataset.tab === activeTab) {
182
+ tab.classList.add('bg-primary', 'text-primary-foreground');
183
+ tab.classList.remove('bg-transparent', 'text-muted-foreground', 'hover:bg-muted');
184
+ } else {
185
+ tab.classList.remove('bg-primary', 'text-primary-foreground');
186
+ tab.classList.add('bg-transparent', 'text-muted-foreground', 'hover:bg-muted');
187
+ }
188
+ });
189
+ }
190
+
191
+ // ========== Command Rendering ==========
192
+ function renderCommandsTab(category) {
193
+ var container = document.getElementById('helpTabContent');
194
+ if (!container) return;
195
+
196
+ var categoryData = helpData.grouped[category];
197
+
198
+ if (!categoryData) {
199
+ container.innerHTML = `
200
+ <div class="text-center py-8 text-muted-foreground">
201
+ <i data-lucide="inbox" class="w-12 h-12 mx-auto mb-2"></i>
202
+ <p>No commands found for this category</p>
203
+ </div>
204
+ `;
205
+ if (typeof lucide !== 'undefined') lucide.createIcons();
206
+ return;
207
+ }
208
+
209
+ var filteredCommands = helpSearchQuery
210
+ ? filterCommandsBySearch(categoryData.commands, helpSearchQuery)
211
+ : categoryData.commands;
212
+
213
+ var html = '';
214
+
215
+ // Show search results count
216
+ if (helpSearchQuery) {
217
+ html += `
218
+ <div class="mb-4 p-3 bg-muted rounded-lg text-sm text-muted-foreground">
219
+ Found ${filteredCommands.length} commands matching "${escapeHtml(helpSearchQuery)}"
220
+ </div>
221
+ `;
222
+ }
223
+
224
+ // Render direct commands
225
+ if (filteredCommands.length > 0) {
226
+ html += '<div class="space-y-3">';
227
+ filteredCommands.forEach(function(cmd) {
228
+ html += renderCommandCard(cmd);
229
+ });
230
+ html += '</div>';
231
+ }
232
+
233
+ // Render subcategories as accordions
234
+ var subcategories = categoryData.subcategories || {};
235
+ var subcategoryKeys = Object.keys(subcategories);
236
+
237
+ if (subcategoryKeys.length > 0) {
238
+ html += '<div class="mt-6 space-y-3">';
239
+ subcategoryKeys.forEach(function(subcat) {
240
+ var subcatCommands = helpSearchQuery
241
+ ? filterCommandsBySearch(subcategories[subcat], helpSearchQuery)
242
+ : subcategories[subcat];
243
+
244
+ if (subcatCommands.length > 0) {
245
+ html += renderSubcategoryAccordion(subcat, subcatCommands);
246
+ }
247
+ });
248
+ html += '</div>';
249
+ }
250
+
251
+ if (filteredCommands.length === 0 && subcategoryKeys.length === 0) {
252
+ html = `
253
+ <div class="text-center py-8 text-muted-foreground">
254
+ <i data-lucide="search-x" class="w-12 h-12 mx-auto mb-2"></i>
255
+ <p>No commands found matching your search</p>
256
+ </div>
257
+ `;
258
+ }
259
+
260
+ container.innerHTML = html;
261
+ if (typeof lucide !== 'undefined') lucide.createIcons();
262
+
263
+ // Initialize accordion handlers
264
+ initializeAccordions();
265
+ }
266
+
267
+ function renderCommandCard(cmd) {
268
+ var difficultyColor = {
269
+ 'Beginner': 'bg-success-light text-success',
270
+ 'Intermediate': 'bg-warning-light text-warning',
271
+ 'Advanced': 'bg-error-light text-error'
272
+ }[cmd.difficulty] || 'bg-muted text-muted-foreground';
273
+
274
+ return `
275
+ <div class="bg-background border border-border rounded-lg p-4 hover:border-primary transition-colors">
276
+ <div class="flex items-start justify-between mb-2">
277
+ <div class="flex-1">
278
+ <div class="flex items-center gap-2 mb-1">
279
+ <code class="text-sm font-mono text-primary font-semibold">${escapeHtml(cmd.command)}</code>
280
+ <span class="text-xs px-2 py-0.5 rounded ${difficultyColor}">${escapeHtml(cmd.difficulty)}</span>
281
+ </div>
282
+ <p class="text-sm text-muted-foreground">${escapeHtml(cmd.description)}</p>
283
+ </div>
284
+ </div>
285
+ ${cmd.arguments ? `
286
+ <div class="mt-2 text-xs">
287
+ <span class="text-muted-foreground">Arguments:</span>
288
+ <code class="ml-2 text-foreground">${escapeHtml(cmd.arguments)}</code>
289
+ </div>
290
+ ` : ''}
291
+ </div>
292
+ `;
293
+ }
294
+
295
+ function renderSubcategoryAccordion(subcatName, commands) {
296
+ var accordionId = 'accordion-' + subcatName.replace(/\s+/g, '-').toLowerCase();
297
+
298
+ return `
299
+ <div class="border border-border rounded-lg overflow-hidden">
300
+ <button
301
+ class="accordion-header w-full px-4 py-3 bg-muted hover:bg-muted/80 text-left flex items-center justify-between transition-colors"
302
+ data-accordion="${accordionId}"
303
+ >
304
+ <div class="flex items-center gap-2">
305
+ <i data-lucide="chevron-right" class="accordion-icon w-4 h-4 transition-transform"></i>
306
+ <span class="font-medium text-foreground">${escapeHtml(subcatName)}</span>
307
+ <span class="text-xs text-muted-foreground ml-2">(${commands.length} commands)</span>
308
+ </div>
309
+ </button>
310
+ <div class="accordion-content hidden">
311
+ <div class="p-4 space-y-3 bg-card">
312
+ ${commands.map(cmd => renderCommandCard(cmd)).join('')}
313
+ </div>
314
+ </div>
315
+ </div>
316
+ `;
317
+ }
318
+
319
+ function initializeAccordions() {
320
+ var headers = document.querySelectorAll('.accordion-header');
321
+ headers.forEach(function(header) {
322
+ header.addEventListener('click', function() {
323
+ var content = this.nextElementSibling;
324
+ var icon = this.querySelector('.accordion-icon');
325
+
326
+ if (content.classList.contains('hidden')) {
327
+ content.classList.remove('hidden');
328
+ icon.style.transform = 'rotate(90deg)';
329
+ } else {
330
+ content.classList.add('hidden');
331
+ icon.style.transform = 'rotate(0deg)';
332
+ }
333
+ });
334
+ });
335
+ }
336
+
337
+ // ========== Search Functions ==========
338
+ function filterCommandsBySearch(commands, query) {
339
+ if (!query) return commands;
340
+
341
+ var lowerQuery = query.toLowerCase();
342
+ return commands.filter(function(cmd) {
343
+ return (cmd.name && cmd.name.toLowerCase().includes(lowerQuery)) ||
344
+ (cmd.command && cmd.command.toLowerCase().includes(lowerQuery)) ||
345
+ (cmd.description && cmd.description.toLowerCase().includes(lowerQuery)) ||
346
+ (cmd.category && cmd.category.toLowerCase().includes(lowerQuery));
347
+ });
348
+ }
349
+
350
+ async function performHelpSearch() {
351
+ // Reload data with search query
352
+ try {
353
+ var url = '/api/help/commands' + (helpSearchQuery ? '?q=' + encodeURIComponent(helpSearchQuery) : '');
354
+ var resp = await fetch(url);
355
+ if (resp.ok) {
356
+ var data = await resp.json();
357
+ helpData.commands = data.commands || [];
358
+ helpData.grouped = data.grouped || {};
359
+ }
360
+ } catch (err) {
361
+ console.error('Search failed:', err);
362
+ }
363
+
364
+ // Re-render current tab
365
+ if (activeHelpTab !== 'diagrams' && activeHelpTab !== 'codexlens') {
366
+ renderCommandsTab(activeHelpTab);
367
+ }
368
+ }
369
+
370
+ // ========== Workflow Diagrams ==========
371
+ function renderWorkflowDiagrams() {
372
+ var container = document.getElementById('helpTabContent');
373
+ if (!container) return;
374
+
375
+ container.innerHTML = `
376
+ <div class="workflow-diagrams-section">
377
+ <div class="mb-4">
378
+ <h3 class="text-lg font-semibold text-foreground mb-3">${ht('help.diagrams.title')}</h3>
379
+ <div class="flex gap-2 flex-wrap">
380
+ <button class="workflow-diagram-btn px-4 py-2 rounded-lg text-sm font-medium transition-colors" data-workflow="decision">
381
+ ${ht('help.diagrams.decision')}
382
+ </button>
383
+ <button class="workflow-diagram-btn px-4 py-2 rounded-lg text-sm font-medium transition-colors" data-workflow="brainstorm">
384
+ ${ht('help.diagrams.brainstorm')}
385
+ </button>
386
+ <button class="workflow-diagram-btn px-4 py-2 rounded-lg text-sm font-medium transition-colors" data-workflow="cli-resume">
387
+ ${ht('help.diagrams.cliResume')}
388
+ </button>
389
+ <button class="workflow-diagram-btn px-4 py-2 rounded-lg text-sm font-medium transition-colors" data-workflow="bug-fix">
390
+ ${ht('help.diagrams.bugFix')}
391
+ </button>
392
+ <button class="workflow-diagram-btn px-4 py-2 rounded-lg text-sm font-medium transition-colors" data-workflow="lite">
393
+ ${ht('help.diagrams.lite')}
394
+ </button>
395
+ <button class="workflow-diagram-btn px-4 py-2 rounded-lg text-sm font-medium transition-colors" data-workflow="plan-full">
396
+ ${ht('help.diagrams.planFull')}
397
+ </button>
398
+ <button class="workflow-diagram-btn px-4 py-2 rounded-lg text-sm font-medium transition-colors" data-workflow="tdd">
399
+ ${ht('help.diagrams.tdd')}
400
+ </button>
401
+ </div>
402
+ </div>
403
+
404
+ <!-- Cytoscape Container -->
405
+ <div id="cytoscapeContainer" class="bg-background border border-border rounded-lg" style="height: 600px; min-height: 500px;"></div>
406
+
407
+ <!-- Diagram Controls -->
408
+ <div class="mt-4 flex gap-2">
409
+ <button id="fitDiagramBtn" class="px-3 py-2 bg-muted hover:bg-muted/80 rounded-lg text-sm flex items-center gap-2">
410
+ <i data-lucide="maximize-2" class="w-4 h-4"></i>
411
+ ${ht('help.diagrams.fit')}
412
+ </button>
413
+ <button id="zoomInBtn" class="px-3 py-2 bg-muted hover:bg-muted/80 rounded-lg text-sm flex items-center gap-2">
414
+ <i data-lucide="zoom-in" class="w-4 h-4"></i>
415
+ ${ht('help.diagrams.zoomIn')}
416
+ </button>
417
+ <button id="zoomOutBtn" class="px-3 py-2 bg-muted hover:bg-muted/80 rounded-lg text-sm flex items-center gap-2">
418
+ <i data-lucide="zoom-out" class="w-4 h-4"></i>
419
+ ${ht('help.diagrams.zoomOut')}
420
+ </button>
421
+ </div>
422
+
423
+ <!-- Legend -->
424
+ <div class="mt-4 p-4 bg-muted rounded-lg">
425
+ <h4 class="text-sm font-semibold text-foreground mb-2">${ht('help.diagrams.legend')}</h4>
426
+ <div class="flex gap-4 flex-wrap text-xs">
427
+ <div class="flex items-center gap-2">
428
+ <div class="w-3 h-3 rounded-full bg-primary"></div>
429
+ <span>${ht('help.diagrams.legend.prerequisites')}</span>
430
+ </div>
431
+ <div class="flex items-center gap-2">
432
+ <div class="w-3 h-3 rounded-full bg-success"></div>
433
+ <span>${ht('help.diagrams.legend.nextSteps')}</span>
434
+ </div>
435
+ <div class="flex items-center gap-2">
436
+ <div class="w-3 h-3 rounded-full bg-warning"></div>
437
+ <span>${ht('help.diagrams.legend.alternatives')}</span>
438
+ </div>
439
+ </div>
440
+ </div>
441
+ </div>
442
+ `;
443
+
444
+ if (typeof lucide !== 'undefined') lucide.createIcons();
445
+
446
+ // Initialize workflow diagram buttons
447
+ var diagramBtns = document.querySelectorAll('.workflow-diagram-btn');
448
+ diagramBtns.forEach(function(btn) {
449
+ btn.addEventListener('click', function() {
450
+ activeWorkflowDiagram = this.dataset.workflow;
451
+ updateActiveWorkflowBtn(activeWorkflowDiagram);
452
+ initializeCytoscapeDiagram(activeWorkflowDiagram);
453
+ });
454
+ });
455
+
456
+ // Initialize control buttons
457
+ var fitBtn = document.getElementById('fitDiagramBtn');
458
+ if (fitBtn) {
459
+ fitBtn.addEventListener('click', function() {
460
+ if (cytoscapeInstance) cytoscapeInstance.fit();
461
+ });
462
+ }
463
+
464
+ var zoomInBtn = document.getElementById('zoomInBtn');
465
+ if (zoomInBtn) {
466
+ zoomInBtn.addEventListener('click', function() {
467
+ if (cytoscapeInstance) cytoscapeInstance.zoom(cytoscapeInstance.zoom() * 1.2);
468
+ });
469
+ }
470
+
471
+ var zoomOutBtn = document.getElementById('zoomOutBtn');
472
+ if (zoomOutBtn) {
473
+ zoomOutBtn.addEventListener('click', function() {
474
+ if (cytoscapeInstance) cytoscapeInstance.zoom(cytoscapeInstance.zoom() * 0.8);
475
+ });
476
+ }
477
+
478
+ // Update active button
479
+ updateActiveWorkflowBtn(activeWorkflowDiagram);
480
+
481
+ // Initialize Cytoscape diagram
482
+ setTimeout(function() {
483
+ initializeCytoscapeDiagram(activeWorkflowDiagram);
484
+ }, 100);
485
+ }
486
+
487
+ function updateActiveWorkflowBtn(workflow) {
488
+ var btns = document.querySelectorAll('.workflow-diagram-btn');
489
+ btns.forEach(function(btn) {
490
+ if (btn.dataset.workflow === workflow) {
491
+ btn.classList.add('bg-primary', 'text-primary-foreground');
492
+ btn.classList.remove('bg-muted', 'text-muted-foreground');
493
+ } else {
494
+ btn.classList.remove('bg-primary', 'text-primary-foreground');
495
+ btn.classList.add('bg-muted', 'text-muted-foreground');
496
+ }
497
+ });
498
+ }
499
+
500
+ function initializeCytoscapeDiagram(workflow) {
501
+ var container = document.getElementById('cytoscapeContainer');
502
+ if (!container) return;
503
+
504
+ // Destroy previous instance
505
+ if (cytoscapeInstance) {
506
+ cytoscapeInstance.destroy();
507
+ cytoscapeInstance = null;
508
+ }
509
+
510
+ // Get workflow data
511
+ var graphData = getWorkflowGraphData(workflow);
512
+
513
+ // Check if cytoscape is available
514
+ if (typeof cytoscape === 'undefined') {
515
+ container.innerHTML = '<div class="flex items-center justify-center h-full text-muted-foreground">' + ht('help.diagrams.notLoaded') + '</div>';
516
+ return;
517
+ }
518
+
519
+ // Get computed CSS variable values
520
+ var rootStyles = getComputedStyle(document.documentElement);
521
+ var primaryColor = rootStyles.getPropertyValue('--primary').trim();
522
+ var foregroundColor = rootStyles.getPropertyValue('--foreground').trim();
523
+ var mutedColor = rootStyles.getPropertyValue('--muted-foreground').trim();
524
+
525
+ // Convert HSL values to usable format
526
+ var primaryHsl = primaryColor ? 'hsl(' + primaryColor + ')' : '#3B82F6';
527
+ var foregroundHsl = foregroundColor ? 'hsl(' + foregroundColor + ')' : '#1F2937';
528
+ var mutedHsl = mutedColor ? 'hsl(' + mutedColor + ')' : '#6B7280';
529
+
530
+ // Initialize Cytoscape
531
+ cytoscapeInstance = cytoscape({
532
+ container: container,
533
+ elements: graphData,
534
+ style: [
535
+ {
536
+ selector: 'node',
537
+ style: {
538
+ 'shape': 'roundrectangle',
539
+ 'background-color': primaryHsl,
540
+ 'background-opacity': 0.9,
541
+ 'border-width': 2,
542
+ 'border-color': primaryHsl,
543
+ 'border-opacity': 1,
544
+ 'label': 'data(label)',
545
+ 'color': '#FFFFFF',
546
+ 'text-valign': 'center',
547
+ 'text-halign': 'center',
548
+ 'font-size': '14px',
549
+ 'font-weight': '600',
550
+ 'width': '140px',
551
+ 'height': '60px',
552
+ 'text-wrap': 'wrap',
553
+ 'text-max-width': '130px',
554
+ 'padding': '8px',
555
+ 'shadow-blur': 10,
556
+ 'shadow-color': '#000000',
557
+ 'shadow-opacity': 0.2,
558
+ 'shadow-offset-x': 0,
559
+ 'shadow-offset-y': 2
560
+ }
561
+ },
562
+ {
563
+ selector: 'edge',
564
+ style: {
565
+ 'width': 3,
566
+ 'line-color': mutedHsl,
567
+ 'target-arrow-color': mutedHsl,
568
+ 'target-arrow-shape': 'triangle',
569
+ 'target-arrow-fill': 'filled',
570
+ 'arrow-scale': 1.5,
571
+ 'curve-style': 'bezier',
572
+ 'label': 'data(label)',
573
+ 'font-size': '12px',
574
+ 'font-weight': '500',
575
+ 'color': foregroundHsl,
576
+ 'text-background-color': '#FFFFFF',
577
+ 'text-background-opacity': 0.9,
578
+ 'text-background-padding': '4px',
579
+ 'text-background-shape': 'roundrectangle',
580
+ 'text-border-width': 1,
581
+ 'text-border-color': mutedHsl,
582
+ 'text-border-opacity': 0.3
583
+ }
584
+ },
585
+ {
586
+ selector: 'edge.prerequisite',
587
+ style: {
588
+ 'line-color': primaryHsl,
589
+ 'target-arrow-color': primaryHsl,
590
+ 'width': 3
591
+ }
592
+ },
593
+ {
594
+ selector: 'edge.next-step',
595
+ style: {
596
+ 'line-color': '#10B981',
597
+ 'target-arrow-color': '#10B981',
598
+ 'width': 3,
599
+ 'line-style': 'solid'
600
+ }
601
+ },
602
+ {
603
+ selector: 'edge.alternative',
604
+ style: {
605
+ 'line-color': '#F59E0B',
606
+ 'target-arrow-color': '#F59E0B',
607
+ 'line-style': 'dashed',
608
+ 'line-dash-pattern': [10, 5],
609
+ 'width': 2.5
610
+ }
611
+ }
612
+ ],
613
+ layout: {
614
+ name: 'breadthfirst',
615
+ directed: true,
616
+ padding: 80,
617
+ spacingFactor: 2,
618
+ avoidOverlap: true,
619
+ nodeDimensionsIncludeLabels: true,
620
+ animate: false
621
+ }
622
+ });
623
+
624
+ // Add click handler for nodes
625
+ cytoscapeInstance.on('tap', 'node', function(evt) {
626
+ var node = evt.target;
627
+ var commandName = node.data('id');
628
+ showCommandTooltip(commandName, node);
629
+ });
630
+
631
+ // Fit to viewport
632
+ cytoscapeInstance.fit();
633
+ }
634
+
635
+ function getWorkflowGraphData(workflow) {
636
+ var workflows = {
637
+ 'decision': {
638
+ nodes: [
639
+ { data: { id: 'start', label: ht('help.workflows.decision.start') } },
640
+ { data: { id: 'cli-analyze', label: ht('help.workflows.decision.cliAnalyze') } },
641
+ { data: { id: 'understand', label: ht('help.workflows.decision.understand') } },
642
+ { data: { id: 'simple', label: ht('help.workflows.decision.simple') } },
643
+ { data: { id: 'medium', label: ht('help.workflows.decision.medium') } },
644
+ { data: { id: 'complex', label: ht('help.workflows.decision.complex') } },
645
+ { data: { id: 'claude-exec', label: ht('help.workflows.decision.claudeExec') } },
646
+ { data: { id: 'cli-exec', label: ht('help.workflows.decision.cliExec') } },
647
+ { data: { id: 'claude-plan', label: ht('help.workflows.decision.claudePlan') } },
648
+ { data: { id: 'lite-plan', label: '/workflow:lite-plan' } },
649
+ { data: { id: 'full-plan', label: '/workflow:plan' } }
650
+ ],
651
+ edges: [
652
+ { data: { source: 'start', target: 'cli-analyze' }, classes: 'next-step' },
653
+ { data: { source: 'cli-analyze', target: 'understand' }, classes: 'next-step' },
654
+ { data: { source: 'understand', target: 'simple' }, classes: 'alternative' },
655
+ { data: { source: 'understand', target: 'medium' }, classes: 'alternative' },
656
+ { data: { source: 'understand', target: 'complex' }, classes: 'alternative' },
657
+ { data: { source: 'simple', target: 'claude-exec', label: '优先' }, classes: 'next-step' },
658
+ { data: { source: 'simple', target: 'cli-exec' }, classes: 'alternative' },
659
+ { data: { source: 'medium', target: 'claude-plan' }, classes: 'next-step' },
660
+ { data: { source: 'medium', target: 'lite-plan' }, classes: 'alternative' },
661
+ { data: { source: 'complex', target: 'full-plan' }, classes: 'next-step' }
662
+ ]
663
+ },
664
+ 'brainstorm': {
665
+ nodes: [
666
+ { data: { id: 'start', label: ht('help.workflows.brainstorm.start') } },
667
+ { data: { id: 'question', label: ht('help.workflows.brainstorm.question') } },
668
+ { data: { id: 'product', label: ht('help.workflows.brainstorm.product') } },
669
+ { data: { id: 'design', label: ht('help.workflows.brainstorm.design') } },
670
+ { data: { id: 'brainstorm-product', label: '/workflow:brainstorm:auto-parallel' } },
671
+ { data: { id: 'brainstorm-design', label: '/workflow:brainstorm:auto-parallel' } },
672
+ { data: { id: 'next', label: ht('help.workflows.brainstorm.next') } }
673
+ ],
674
+ edges: [
675
+ { data: { source: 'start', target: 'question' }, classes: 'next-step' },
676
+ { data: { source: 'question', target: 'product' }, classes: 'alternative' },
677
+ { data: { source: 'question', target: 'design' }, classes: 'alternative' },
678
+ { data: { source: 'product', target: 'brainstorm-product' }, classes: 'next-step' },
679
+ { data: { source: 'design', target: 'brainstorm-design' }, classes: 'next-step' },
680
+ { data: { source: 'brainstorm-product', target: 'next' }, classes: 'next-step' },
681
+ { data: { source: 'brainstorm-design', target: 'next' }, classes: 'next-step' }
682
+ ]
683
+ },
684
+ 'cli-resume': {
685
+ nodes: [
686
+ { data: { id: 'first-exec', label: ht('help.workflows.cliResume.firstExec') } },
687
+ { data: { id: 'save-context', label: ht('help.workflows.cliResume.saveContext') } },
688
+ { data: { id: 'resume-cmd', label: ht('help.workflows.cliResume.resumeCmd') } },
689
+ { data: { id: 'merge', label: ht('help.workflows.cliResume.merge') } },
690
+ { data: { id: 'continue', label: ht('help.workflows.cliResume.continue') } },
691
+ { data: { id: 'split-output', label: ht('help.workflows.cliResume.splitOutput') } },
692
+ { data: { id: 'complete', label: ht('help.workflows.cliResume.complete') } }
693
+ ],
694
+ edges: [
695
+ { data: { source: 'first-exec', target: 'save-context' }, classes: 'next-step' },
696
+ { data: { source: 'save-context', target: 'resume-cmd' }, classes: 'next-step' },
697
+ { data: { source: 'resume-cmd', target: 'merge' }, classes: 'next-step' },
698
+ { data: { source: 'merge', target: 'continue' }, classes: 'next-step' },
699
+ { data: { source: 'continue', target: 'split-output' }, classes: 'next-step' },
700
+ { data: { source: 'split-output', target: 'complete' }, classes: 'next-step' }
701
+ ]
702
+ },
703
+ 'bug-fix': {
704
+ nodes: [
705
+ { data: { id: 'start', label: ht('help.workflows.bugFix.start') } },
706
+ { data: { id: 'cli-analyze', label: ht('help.workflows.bugFix.cliAnalyze') } },
707
+ { data: { id: 'lite-fix', label: '/workflow:lite-fix' } },
708
+ { data: { id: 'diagnosis', label: ht('help.workflows.bugFix.diagnosis') } },
709
+ { data: { id: 'impact', label: ht('help.workflows.bugFix.impact') } },
710
+ { data: { id: 'strategy', label: ht('help.workflows.bugFix.strategy') } },
711
+ { data: { id: 'execute', label: ht('help.workflows.bugFix.execute') } },
712
+ { data: { id: 'complete', label: ht('help.workflows.bugFix.complete') } }
713
+ ],
714
+ edges: [
715
+ { data: { source: 'start', target: 'cli-analyze' }, classes: 'next-step' },
716
+ { data: { source: 'cli-analyze', target: 'lite-fix' }, classes: 'next-step' },
717
+ { data: { source: 'lite-fix', target: 'diagnosis' }, classes: 'next-step' },
718
+ { data: { source: 'diagnosis', target: 'impact' }, classes: 'next-step' },
719
+ { data: { source: 'impact', target: 'strategy' }, classes: 'next-step' },
720
+ { data: { source: 'strategy', target: 'execute' }, classes: 'next-step' },
721
+ { data: { source: 'execute', target: 'complete' }, classes: 'next-step' }
722
+ ]
723
+ },
724
+ 'plan-full': {
725
+ nodes: [
726
+ { data: { id: 'start', label: ht('help.workflows.planFull.start') } },
727
+ { data: { id: 'cli-analyze', label: ht('help.workflows.planFull.cliAnalyze') } },
728
+ { data: { id: 'plan', label: '/workflow:plan' } },
729
+ { data: { id: 'verify', label: '/workflow:action-plan-verify' } },
730
+ { data: { id: 'execute', label: '/workflow:execute' } },
731
+ { data: { id: 'test', label: '/workflow:test-gen' } },
732
+ { data: { id: 'review', label: '/workflow:review' } },
733
+ { data: { id: 'complete', label: '/workflow:session:complete' } }
734
+ ],
735
+ edges: [
736
+ { data: { source: 'start', target: 'cli-analyze' }, classes: 'next-step' },
737
+ { data: { source: 'cli-analyze', target: 'plan' }, classes: 'next-step' },
738
+ { data: { source: 'plan', target: 'verify' }, classes: 'next-step' },
739
+ { data: { source: 'verify', target: 'execute' }, classes: 'next-step' },
740
+ { data: { source: 'execute', target: 'test' }, classes: 'next-step' },
741
+ { data: { source: 'test', target: 'review' }, classes: 'next-step' },
742
+ { data: { source: 'review', target: 'complete' }, classes: 'next-step' }
743
+ ]
744
+ },
745
+ 'lite': {
746
+ nodes: [
747
+ { data: { id: 'start', label: ht('help.workflows.lite.start') } },
748
+ { data: { id: 'lite-plan', label: '/workflow:lite-plan' } },
749
+ { data: { id: 'confirm', label: ht('help.workflows.lite.confirm') } },
750
+ { data: { id: 'lite-execute', label: '/workflow:lite-execute' } },
751
+ { data: { id: 'complete', label: ht('help.workflows.lite.complete') } }
752
+ ],
753
+ edges: [
754
+ { data: { source: 'start', target: 'lite-plan' }, classes: 'next-step' },
755
+ { data: { source: 'lite-plan', target: 'confirm' }, classes: 'next-step' },
756
+ { data: { source: 'confirm', target: 'lite-execute' }, classes: 'next-step' },
757
+ { data: { source: 'lite-execute', target: 'complete' }, classes: 'next-step' }
758
+ ]
759
+ },
760
+ 'tdd': {
761
+ nodes: [
762
+ { data: { id: 'start', label: ht('help.workflows.tdd.start') } },
763
+ { data: { id: 'tdd-plan', label: '/workflow:tdd-plan' } },
764
+ { data: { id: 'red', label: ht('help.workflows.tdd.red') } },
765
+ { data: { id: 'green', label: ht('help.workflows.tdd.green') } },
766
+ { data: { id: 'refactor', label: ht('help.workflows.tdd.refactor') } },
767
+ { data: { id: 'verify', label: '/workflow:tdd-verify' } },
768
+ { data: { id: 'complete', label: ht('help.workflows.tdd.complete') } }
769
+ ],
770
+ edges: [
771
+ { data: { source: 'start', target: 'tdd-plan' }, classes: 'next-step' },
772
+ { data: { source: 'tdd-plan', target: 'red' }, classes: 'next-step' },
773
+ { data: { source: 'red', target: 'green' }, classes: 'next-step' },
774
+ { data: { source: 'green', target: 'refactor' }, classes: 'next-step' },
775
+ { data: { source: 'refactor', target: 'verify' }, classes: 'next-step' },
776
+ { data: { source: 'verify', target: 'complete' }, classes: 'next-step' }
777
+ ]
778
+ }
779
+ };
780
+
781
+ var workflowData = workflows[workflow] || workflows['decision'];
782
+ console.log('Building workflow diagram for:', workflow);
783
+ console.log('Generated graph:', workflowData.nodes.length, 'nodes,', workflowData.edges.length, 'edges');
784
+
785
+ return workflowData.nodes.concat(workflowData.edges);
786
+ }
787
+
788
+ function showCommandTooltip(commandName, node) {
789
+ // Find command in helpData
790
+ var command = helpData.commands.find(function(cmd) {
791
+ return cmd.command === '/' + commandName;
792
+ });
793
+
794
+ if (command) {
795
+ alert(command.command + '\n\n' + command.description);
796
+ }
797
+ }
798
+
799
+ // ========== CodexLens Quick Start ==========
800
+ function renderCodexLensQuickStart() {
801
+ var container = document.getElementById('helpTabContent');
802
+ if (!container) return;
803
+
804
+ var data = helpData.codexlens;
805
+
806
+ var html = `
807
+ <div class="codexlens-quickstart">
808
+ <div class="mb-6">
809
+ <h3 class="text-xl font-bold text-foreground mb-2">${ht('help.codexlens.title')}</h3>
810
+ <p class="text-muted-foreground">${ht('help.codexlens.subtitle')}</p>
811
+ </div>
812
+
813
+ ${data.sections ? data.sections.map(function(section) {
814
+ return `
815
+ <div class="mb-8">
816
+ <h4 class="text-lg font-semibold text-foreground mb-4">${escapeHtml(section.title)}</h4>
817
+ <div class="space-y-4">
818
+ ${section.items.map(function(item) {
819
+ return `
820
+ <div class="bg-background border border-border rounded-lg p-4">
821
+ ${item.name ? `<h5 class="font-medium text-foreground mb-2">${escapeHtml(item.name)}</h5>` : ''}
822
+ <p class="text-sm text-muted-foreground mb-2">${escapeHtml(item.description)}</p>
823
+ ${item.command ? `
824
+ <div class="bg-muted rounded p-3 mt-2">
825
+ <code class="text-xs font-mono text-foreground">${escapeHtml(item.command)}</code>
826
+ </div>
827
+ ` : ''}
828
+ </div>
829
+ `;
830
+ }).join('')}
831
+ </div>
832
+ </div>
833
+ `;
834
+ }).join('') : ''}
835
+
836
+ ${data.links && data.links.length > 0 ? `
837
+ <div class="mt-8 p-4 bg-muted rounded-lg">
838
+ <h4 class="text-sm font-semibold text-foreground mb-3">Additional Resources</h4>
839
+ <div class="space-y-2">
840
+ ${data.links.map(function(link) {
841
+ return `
842
+ <a href="${escapeHtml(link.url)}" class="block text-sm text-primary hover:underline">
843
+ <i data-lucide="external-link" class="w-3 h-3 inline-block mr-1"></i>
844
+ ${escapeHtml(link.text)}
845
+ </a>
846
+ `;
847
+ }).join('')}
848
+ </div>
849
+ </div>
850
+ ` : ''}
851
+ </div>
852
+ `;
853
+
854
+ container.innerHTML = html;
855
+ if (typeof lucide !== 'undefined') lucide.createIcons();
856
+ }