claude-code-workflow 6.1.4 → 6.2.1

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 (879) hide show
  1. package/README.md +145 -274
  2. package/bin/ccw-mcp.js +7 -0
  3. package/bin/ccw.js +10 -0
  4. package/dist/cli.d.ts +2 -0
  5. package/dist/cli.d.ts.map +1 -0
  6. package/dist/cli.js +219 -0
  7. package/dist/cli.js.map +1 -0
  8. package/dist/commands/cli.d.ts +32 -0
  9. package/dist/commands/cli.d.ts.map +1 -0
  10. package/dist/commands/cli.js +619 -0
  11. package/dist/commands/cli.js.map +1 -0
  12. package/dist/commands/core-memory.d.ts +32 -0
  13. package/dist/commands/core-memory.d.ts.map +1 -0
  14. package/dist/commands/core-memory.js +640 -0
  15. package/dist/commands/core-memory.js.map +1 -0
  16. package/dist/commands/hook.d.ts +16 -0
  17. package/dist/commands/hook.d.ts.map +1 -0
  18. package/dist/commands/hook.js +276 -0
  19. package/dist/commands/hook.js.map +1 -0
  20. package/dist/commands/install.d.ts +12 -0
  21. package/dist/commands/install.d.ts.map +1 -0
  22. package/dist/commands/install.js +443 -0
  23. package/dist/commands/install.js.map +1 -0
  24. package/dist/commands/list.d.ts +5 -0
  25. package/dist/commands/list.d.ts.map +1 -0
  26. package/dist/commands/list.js +32 -0
  27. package/dist/commands/list.js.map +1 -0
  28. package/dist/commands/memory.d.ts +57 -0
  29. package/dist/commands/memory.d.ts.map +1 -0
  30. package/dist/commands/memory.js +890 -0
  31. package/dist/commands/memory.js.map +1 -0
  32. package/dist/commands/serve.d.ts +12 -0
  33. package/dist/commands/serve.d.ts.map +1 -0
  34. package/dist/commands/serve.js +63 -0
  35. package/dist/commands/serve.js.map +1 -0
  36. package/dist/commands/session-path-resolver.d.ts +45 -0
  37. package/dist/commands/session-path-resolver.d.ts.map +1 -0
  38. package/dist/commands/session-path-resolver.js +302 -0
  39. package/dist/commands/session-path-resolver.js.map +1 -0
  40. package/dist/commands/session.d.ts +12 -0
  41. package/dist/commands/session.d.ts.map +1 -0
  42. package/dist/commands/session.js +954 -0
  43. package/dist/commands/session.js.map +1 -0
  44. package/dist/commands/stop.d.ts +11 -0
  45. package/dist/commands/stop.d.ts.map +1 -0
  46. package/dist/commands/stop.js +96 -0
  47. package/dist/commands/stop.js.map +1 -0
  48. package/dist/commands/tool.d.ts +29 -0
  49. package/dist/commands/tool.d.ts.map +1 -0
  50. package/dist/commands/tool.js +173 -0
  51. package/dist/commands/tool.js.map +1 -0
  52. package/dist/commands/uninstall.d.ts +9 -0
  53. package/dist/commands/uninstall.d.ts.map +1 -0
  54. package/dist/commands/uninstall.js +239 -0
  55. package/dist/commands/uninstall.js.map +1 -0
  56. package/dist/commands/upgrade.d.ts +10 -0
  57. package/dist/commands/upgrade.d.ts.map +1 -0
  58. package/dist/commands/upgrade.js +288 -0
  59. package/dist/commands/upgrade.js.map +1 -0
  60. package/dist/commands/view.d.ts +14 -0
  61. package/dist/commands/view.d.ts.map +1 -0
  62. package/dist/commands/view.js +100 -0
  63. package/dist/commands/view.js.map +1 -0
  64. package/dist/config/storage-paths.d.ts +184 -0
  65. package/dist/config/storage-paths.d.ts.map +1 -0
  66. package/dist/config/storage-paths.js +536 -0
  67. package/dist/config/storage-paths.js.map +1 -0
  68. package/dist/core/cache-manager.d.ts +80 -0
  69. package/dist/core/cache-manager.d.ts.map +1 -0
  70. package/dist/core/cache-manager.js +260 -0
  71. package/dist/core/cache-manager.js.map +1 -0
  72. package/dist/core/claude-freshness.d.ts +53 -0
  73. package/dist/core/claude-freshness.d.ts.map +1 -0
  74. package/dist/core/claude-freshness.js +232 -0
  75. package/dist/core/claude-freshness.js.map +1 -0
  76. package/dist/core/core-memory-store.d.ts +320 -0
  77. package/dist/core/core-memory-store.d.ts.map +1 -0
  78. package/dist/core/core-memory-store.js +1177 -0
  79. package/dist/core/core-memory-store.js.map +1 -0
  80. package/dist/core/dashboard-generator-patch.d.ts +2 -0
  81. package/dist/core/dashboard-generator-patch.d.ts.map +1 -0
  82. package/dist/core/dashboard-generator-patch.js +48 -0
  83. package/dist/core/dashboard-generator-patch.js.map +1 -0
  84. package/dist/core/dashboard-generator.d.ts +8 -0
  85. package/dist/core/dashboard-generator.d.ts.map +1 -0
  86. package/dist/core/dashboard-generator.js +695 -0
  87. package/dist/core/dashboard-generator.js.map +1 -0
  88. package/dist/core/data-aggregator.d.ts +145 -0
  89. package/dist/core/data-aggregator.d.ts.map +1 -0
  90. package/dist/core/data-aggregator.js +416 -0
  91. package/dist/core/data-aggregator.js.map +1 -0
  92. package/dist/core/history-importer.d.ts +102 -0
  93. package/dist/core/history-importer.d.ts.map +1 -0
  94. package/dist/core/history-importer.js +493 -0
  95. package/dist/core/history-importer.js.map +1 -0
  96. package/dist/core/lite-scanner-complete.d.ts +81 -0
  97. package/dist/core/lite-scanner-complete.d.ts.map +1 -0
  98. package/dist/core/lite-scanner-complete.js +368 -0
  99. package/dist/core/lite-scanner-complete.js.map +1 -0
  100. package/dist/core/lite-scanner.d.ts +81 -0
  101. package/dist/core/lite-scanner.d.ts.map +1 -0
  102. package/dist/core/lite-scanner.js +368 -0
  103. package/dist/core/lite-scanner.js.map +1 -0
  104. package/dist/core/manifest.d.ts +88 -0
  105. package/dist/core/manifest.d.ts.map +1 -0
  106. package/dist/core/manifest.js +214 -0
  107. package/dist/core/manifest.js.map +1 -0
  108. package/dist/core/memory-embedder-bridge.d.ts +83 -0
  109. package/dist/core/memory-embedder-bridge.d.ts.map +1 -0
  110. package/dist/core/memory-embedder-bridge.js +181 -0
  111. package/dist/core/memory-embedder-bridge.js.map +1 -0
  112. package/dist/core/memory-store.d.ts +249 -0
  113. package/dist/core/memory-store.d.ts.map +1 -0
  114. package/dist/core/memory-store.js +781 -0
  115. package/dist/core/memory-store.js.map +1 -0
  116. package/dist/core/routes/ccw-routes.d.ts +20 -0
  117. package/dist/core/routes/ccw-routes.d.ts.map +1 -0
  118. package/dist/core/routes/ccw-routes.js +70 -0
  119. package/dist/core/routes/ccw-routes.js.map +1 -0
  120. package/dist/core/routes/claude-routes.d.ts +19 -0
  121. package/dist/core/routes/claude-routes.d.ts.map +1 -0
  122. package/dist/core/routes/claude-routes.js +1017 -0
  123. package/dist/core/routes/claude-routes.js.map +1 -0
  124. package/dist/core/routes/cli-routes.d.ts +20 -0
  125. package/dist/core/routes/cli-routes.d.ts.map +1 -0
  126. package/dist/core/routes/cli-routes.js +468 -0
  127. package/dist/core/routes/cli-routes.js.map +1 -0
  128. package/dist/core/routes/codexlens-routes.d.ts +20 -0
  129. package/dist/core/routes/codexlens-routes.d.ts.map +1 -0
  130. package/dist/core/routes/codexlens-routes.js +754 -0
  131. package/dist/core/routes/codexlens-routes.js.map +1 -0
  132. package/dist/core/routes/core-memory-routes.d.ts +21 -0
  133. package/dist/core/routes/core-memory-routes.d.ts.map +1 -0
  134. package/dist/core/routes/core-memory-routes.js +520 -0
  135. package/dist/core/routes/core-memory-routes.js.map +1 -0
  136. package/dist/core/routes/files-routes.d.ts +20 -0
  137. package/dist/core/routes/files-routes.d.ts.map +1 -0
  138. package/dist/core/routes/files-routes.js +374 -0
  139. package/dist/core/routes/files-routes.js.map +1 -0
  140. package/dist/core/routes/graph-routes.d.ts +20 -0
  141. package/dist/core/routes/graph-routes.d.ts.map +1 -0
  142. package/dist/core/routes/graph-routes.js +517 -0
  143. package/dist/core/routes/graph-routes.js.map +1 -0
  144. package/dist/core/routes/help-routes.d.ts +20 -0
  145. package/dist/core/routes/help-routes.d.ts.map +1 -0
  146. package/dist/core/routes/help-routes.js +250 -0
  147. package/dist/core/routes/help-routes.js.map +1 -0
  148. package/dist/core/routes/hooks-routes.d.ts +21 -0
  149. package/dist/core/routes/hooks-routes.d.ts.map +1 -0
  150. package/dist/core/routes/hooks-routes.js +346 -0
  151. package/dist/core/routes/hooks-routes.js.map +1 -0
  152. package/dist/core/routes/mcp-routes.d.ts +20 -0
  153. package/dist/core/routes/mcp-routes.d.ts.map +1 -0
  154. package/dist/core/routes/mcp-routes.js +1129 -0
  155. package/dist/core/routes/mcp-routes.js.map +1 -0
  156. package/dist/core/routes/mcp-templates-db.d.ts +54 -0
  157. package/dist/core/routes/mcp-templates-db.d.ts.map +1 -0
  158. package/dist/core/routes/mcp-templates-db.js +226 -0
  159. package/dist/core/routes/mcp-templates-db.js.map +1 -0
  160. package/dist/core/routes/memory-routes.d.ts +21 -0
  161. package/dist/core/routes/memory-routes.d.ts.map +1 -0
  162. package/dist/core/routes/memory-routes.js +1095 -0
  163. package/dist/core/routes/memory-routes.js.map +1 -0
  164. package/dist/core/routes/rules-routes.d.ts +20 -0
  165. package/dist/core/routes/rules-routes.d.ts.map +1 -0
  166. package/dist/core/routes/rules-routes.js +442 -0
  167. package/dist/core/routes/rules-routes.js.map +1 -0
  168. package/dist/core/routes/session-routes.d.ts +20 -0
  169. package/dist/core/routes/session-routes.d.ts.map +1 -0
  170. package/dist/core/routes/session-routes.js +423 -0
  171. package/dist/core/routes/session-routes.js.map +1 -0
  172. package/dist/core/routes/skills-routes.d.ts +20 -0
  173. package/dist/core/routes/skills-routes.d.ts.map +1 -0
  174. package/dist/core/routes/skills-routes.js +533 -0
  175. package/dist/core/routes/skills-routes.js.map +1 -0
  176. package/dist/core/routes/status-routes.d.ts +20 -0
  177. package/dist/core/routes/status-routes.d.ts.map +1 -0
  178. package/dist/core/routes/status-routes.js +38 -0
  179. package/dist/core/routes/status-routes.js.map +1 -0
  180. package/dist/core/routes/system-routes.d.ts +22 -0
  181. package/dist/core/routes/system-routes.d.ts.map +1 -0
  182. package/dist/core/routes/system-routes.js +354 -0
  183. package/dist/core/routes/system-routes.js.map +1 -0
  184. package/dist/core/server.d.ts +17 -0
  185. package/dist/core/server.d.ts.map +1 -0
  186. package/dist/core/server.js +386 -0
  187. package/dist/core/server.js.map +1 -0
  188. package/dist/core/session-clustering-service.d.ts +153 -0
  189. package/dist/core/session-clustering-service.d.ts.map +1 -0
  190. package/dist/core/session-clustering-service.js +1065 -0
  191. package/dist/core/session-clustering-service.js.map +1 -0
  192. package/dist/core/session-scanner.d.ts +32 -0
  193. package/dist/core/session-scanner.d.ts.map +1 -0
  194. package/dist/core/session-scanner.js +253 -0
  195. package/dist/core/session-scanner.js.map +1 -0
  196. package/dist/core/websocket.d.ts +23 -0
  197. package/dist/core/websocket.d.ts.map +1 -0
  198. package/dist/core/websocket.js +168 -0
  199. package/dist/core/websocket.js.map +1 -0
  200. package/dist/index.d.ts +10 -0
  201. package/dist/index.d.ts.map +1 -0
  202. package/dist/index.js +10 -0
  203. package/dist/index.js.map +1 -0
  204. package/dist/mcp-server/index.d.ts +7 -0
  205. package/dist/mcp-server/index.d.ts.map +1 -0
  206. package/dist/mcp-server/index.js +157 -0
  207. package/dist/mcp-server/index.js.map +1 -0
  208. package/dist/tools/classify-folders.d.ts +26 -0
  209. package/dist/tools/classify-folders.d.ts.map +1 -0
  210. package/dist/tools/classify-folders.js +201 -0
  211. package/dist/tools/classify-folders.js.map +1 -0
  212. package/dist/tools/cli-config-manager.d.ts +62 -0
  213. package/dist/tools/cli-config-manager.d.ts.map +1 -0
  214. package/dist/tools/cli-config-manager.js +221 -0
  215. package/dist/tools/cli-config-manager.js.map +1 -0
  216. package/dist/tools/cli-executor.d.ts +373 -0
  217. package/dist/tools/cli-executor.d.ts.map +1 -0
  218. package/dist/tools/cli-executor.js +1625 -0
  219. package/dist/tools/cli-executor.js.map +1 -0
  220. package/dist/tools/cli-history-store.d.ts +330 -0
  221. package/dist/tools/cli-history-store.d.ts.map +1 -0
  222. package/dist/tools/cli-history-store.js +916 -0
  223. package/dist/tools/cli-history-store.js.map +1 -0
  224. package/dist/tools/codex-lens.d.ts +118 -0
  225. package/dist/tools/codex-lens.d.ts.map +1 -0
  226. package/dist/tools/codex-lens.js +962 -0
  227. package/dist/tools/codex-lens.js.map +1 -0
  228. package/dist/tools/convert-tokens-to-css.d.ts +14 -0
  229. package/dist/tools/convert-tokens-to-css.d.ts.map +1 -0
  230. package/dist/tools/convert-tokens-to-css.js +244 -0
  231. package/dist/tools/convert-tokens-to-css.js.map +1 -0
  232. package/dist/tools/core-memory.d.ts +66 -0
  233. package/dist/tools/core-memory.d.ts.map +1 -0
  234. package/dist/tools/core-memory.js +324 -0
  235. package/dist/tools/core-memory.js.map +1 -0
  236. package/dist/tools/detect-changed-modules.d.ts +24 -0
  237. package/dist/tools/detect-changed-modules.d.ts.map +1 -0
  238. package/dist/tools/detect-changed-modules.js +277 -0
  239. package/dist/tools/detect-changed-modules.js.map +1 -0
  240. package/dist/tools/discover-design-files.d.ts +36 -0
  241. package/dist/tools/discover-design-files.d.ts.map +1 -0
  242. package/dist/tools/discover-design-files.js +147 -0
  243. package/dist/tools/discover-design-files.js.map +1 -0
  244. package/dist/tools/edit-file.d.ts +28 -0
  245. package/dist/tools/edit-file.d.ts.map +1 -0
  246. package/dist/tools/edit-file.js +479 -0
  247. package/dist/tools/edit-file.js.map +1 -0
  248. package/dist/tools/generate-module-docs.d.ts +22 -0
  249. package/dist/tools/generate-module-docs.d.ts.map +1 -0
  250. package/dist/tools/generate-module-docs.js +379 -0
  251. package/dist/tools/generate-module-docs.js.map +1 -0
  252. package/dist/tools/get-modules-by-depth.d.ts +15 -0
  253. package/dist/tools/get-modules-by-depth.d.ts.map +1 -0
  254. package/dist/tools/get-modules-by-depth.js +296 -0
  255. package/dist/tools/get-modules-by-depth.js.map +1 -0
  256. package/dist/tools/index.d.ts +55 -0
  257. package/dist/tools/index.d.ts.map +1 -0
  258. package/dist/tools/index.js +304 -0
  259. package/dist/tools/index.js.map +1 -0
  260. package/dist/tools/native-session-discovery.d.ts +97 -0
  261. package/dist/tools/native-session-discovery.d.ts.map +1 -0
  262. package/dist/tools/native-session-discovery.js +700 -0
  263. package/dist/tools/native-session-discovery.js.map +1 -0
  264. package/dist/tools/notifier.d.ts +50 -0
  265. package/dist/tools/notifier.d.ts.map +1 -0
  266. package/dist/tools/notifier.js +90 -0
  267. package/dist/tools/notifier.js.map +1 -0
  268. package/dist/tools/read-file.d.ts +32 -0
  269. package/dist/tools/read-file.d.ts.map +1 -0
  270. package/dist/tools/read-file.js +329 -0
  271. package/dist/tools/read-file.js.map +1 -0
  272. package/dist/tools/resume-strategy.d.ts +48 -0
  273. package/dist/tools/resume-strategy.d.ts.map +1 -0
  274. package/dist/tools/resume-strategy.js +248 -0
  275. package/dist/tools/resume-strategy.js.map +1 -0
  276. package/dist/tools/session-content-parser.d.ts +58 -0
  277. package/dist/tools/session-content-parser.d.ts.map +1 -0
  278. package/dist/tools/session-content-parser.js +420 -0
  279. package/dist/tools/session-content-parser.js.map +1 -0
  280. package/dist/tools/session-manager.d.ts +9 -0
  281. package/dist/tools/session-manager.d.ts.map +1 -0
  282. package/dist/tools/session-manager.js +834 -0
  283. package/dist/tools/session-manager.js.map +1 -0
  284. package/dist/tools/smart-context.d.ts +35 -0
  285. package/dist/tools/smart-context.d.ts.map +1 -0
  286. package/dist/tools/smart-context.js +182 -0
  287. package/dist/tools/smart-context.js.map +1 -0
  288. package/dist/tools/smart-search.d.ts +105 -0
  289. package/dist/tools/smart-search.d.ts.map +1 -0
  290. package/dist/tools/smart-search.js +1753 -0
  291. package/dist/tools/smart-search.js.map +1 -0
  292. package/dist/tools/storage-manager.d.ts +114 -0
  293. package/dist/tools/storage-manager.d.ts.map +1 -0
  294. package/dist/tools/storage-manager.js +392 -0
  295. package/dist/tools/storage-manager.js.map +1 -0
  296. package/dist/tools/ui-generate-preview.d.ts +39 -0
  297. package/dist/tools/ui-generate-preview.d.ts.map +1 -0
  298. package/dist/tools/ui-generate-preview.js +300 -0
  299. package/dist/tools/ui-generate-preview.js.map +1 -0
  300. package/dist/tools/ui-instantiate-prototypes.d.ts +75 -0
  301. package/dist/tools/ui-instantiate-prototypes.d.ts.map +1 -0
  302. package/dist/tools/ui-instantiate-prototypes.js +256 -0
  303. package/dist/tools/ui-instantiate-prototypes.js.map +1 -0
  304. package/dist/tools/update-module-claude.d.ts +80 -0
  305. package/dist/tools/update-module-claude.d.ts.map +1 -0
  306. package/dist/tools/update-module-claude.js +351 -0
  307. package/dist/tools/update-module-claude.js.map +1 -0
  308. package/dist/tools/write-file.d.ts +19 -0
  309. package/dist/tools/write-file.d.ts.map +1 -0
  310. package/dist/tools/write-file.js +193 -0
  311. package/dist/tools/write-file.js.map +1 -0
  312. package/dist/types/config.d.ts +11 -0
  313. package/dist/types/config.d.ts.map +1 -0
  314. package/dist/types/config.js +2 -0
  315. package/dist/types/config.js.map +1 -0
  316. package/dist/types/index.d.ts +4 -0
  317. package/dist/types/index.d.ts.map +1 -0
  318. package/dist/types/index.js +4 -0
  319. package/dist/types/index.js.map +1 -0
  320. package/dist/types/session.d.ts +20 -0
  321. package/dist/types/session.d.ts.map +1 -0
  322. package/dist/types/session.js +2 -0
  323. package/dist/types/session.js.map +1 -0
  324. package/dist/types/tool.d.ts +36 -0
  325. package/dist/types/tool.d.ts.map +1 -0
  326. package/dist/types/tool.js +11 -0
  327. package/dist/types/tool.js.map +1 -0
  328. package/dist/utils/browser-launcher.d.ts +13 -0
  329. package/dist/utils/browser-launcher.d.ts.map +1 -0
  330. package/dist/utils/browser-launcher.js +60 -0
  331. package/dist/utils/browser-launcher.js.map +1 -0
  332. package/dist/utils/file-utils.d.ts +25 -0
  333. package/dist/utils/file-utils.d.ts.map +1 -0
  334. package/dist/utils/file-utils.js +48 -0
  335. package/dist/utils/file-utils.js.map +1 -0
  336. package/dist/utils/path-resolver.d.ts +80 -0
  337. package/dist/utils/path-resolver.d.ts.map +1 -0
  338. package/dist/utils/path-resolver.js +260 -0
  339. package/dist/utils/path-resolver.js.map +1 -0
  340. package/dist/utils/path-validator.d.ts +49 -0
  341. package/dist/utils/path-validator.d.ts.map +1 -0
  342. package/dist/utils/path-validator.js +123 -0
  343. package/dist/utils/path-validator.js.map +1 -0
  344. package/dist/utils/ui.d.ts +62 -0
  345. package/dist/utils/ui.d.ts.map +1 -0
  346. package/dist/utils/ui.js +129 -0
  347. package/dist/utils/ui.js.map +1 -0
  348. package/package.json +32 -34
  349. package/src/.workflow/.cli-history/history.db +0 -0
  350. package/src/.workflow/.cli-history/history.db-shm +0 -0
  351. package/src/.workflow/.cli-history/history.db-wal +0 -0
  352. package/src/cli.ts +244 -0
  353. package/src/commands/cli.ts +740 -0
  354. package/src/commands/core-memory.ts +770 -0
  355. package/src/commands/hook.ts +315 -0
  356. package/src/commands/install.ts +519 -0
  357. package/src/commands/list.ts +37 -0
  358. package/src/commands/memory.ts +1090 -0
  359. package/src/commands/serve.ts +76 -0
  360. package/src/commands/session-path-resolver.ts +372 -0
  361. package/src/commands/session.ts +1141 -0
  362. package/src/commands/stop.ts +111 -0
  363. package/src/commands/tool.ts +201 -0
  364. package/src/commands/uninstall.ts +287 -0
  365. package/src/commands/upgrade.ts +352 -0
  366. package/src/commands/view.ts +119 -0
  367. package/src/config/storage-paths.ts +670 -0
  368. package/src/core/cache-manager.ts +294 -0
  369. package/src/core/claude-freshness.ts +319 -0
  370. package/src/core/core-memory-store.ts +1528 -0
  371. package/src/core/dashboard-generator-patch.ts +47 -0
  372. package/src/core/dashboard-generator.ts +739 -0
  373. package/src/core/data-aggregator.ts +584 -0
  374. package/src/core/history-importer.ts +625 -0
  375. package/src/core/lite-scanner-complete.ts +469 -0
  376. package/src/core/lite-scanner.ts +469 -0
  377. package/src/core/manifest.ts +271 -0
  378. package/src/core/memory-embedder-bridge.ts +262 -0
  379. package/src/core/memory-store.ts +978 -0
  380. package/src/core/routes/ccw-routes.ts +96 -0
  381. package/src/core/routes/claude-routes.ts +1183 -0
  382. package/src/core/routes/cli-routes.ts +561 -0
  383. package/src/core/routes/codexlens-routes.ts +806 -0
  384. package/src/core/routes/core-memory-routes.ts +605 -0
  385. package/src/core/routes/files-routes.ts +428 -0
  386. package/src/core/routes/graph-routes.md +164 -0
  387. package/src/core/routes/graph-routes.ts +626 -0
  388. package/src/core/routes/help-routes.ts +308 -0
  389. package/src/core/routes/hooks-routes.ts +405 -0
  390. package/src/core/routes/mcp-routes.ts +1271 -0
  391. package/src/core/routes/mcp-routes.ts.backup +550 -0
  392. package/src/core/routes/mcp-templates-db.ts +268 -0
  393. package/src/core/routes/memory-routes.ts +1206 -0
  394. package/src/core/routes/rules-routes.ts +526 -0
  395. package/src/core/routes/session-routes.ts +467 -0
  396. package/src/core/routes/skills-routes.ts +599 -0
  397. package/src/core/routes/status-routes.ts +57 -0
  398. package/src/core/routes/system-routes.ts +427 -0
  399. package/src/core/server.ts +431 -0
  400. package/src/core/session-clustering-service.ts +1258 -0
  401. package/src/core/session-scanner.ts +283 -0
  402. package/src/core/websocket.ts +190 -0
  403. package/src/index.ts +10 -0
  404. package/src/mcp-server/index.ts +186 -0
  405. package/src/templates/assets/css/github-dark.min.css +10 -0
  406. package/src/templates/assets/css/github.min.css +10 -0
  407. package/src/templates/assets/js/cytoscape.min.js +32 -0
  408. package/src/templates/assets/js/d3.min.js +2 -0
  409. package/src/templates/assets/js/highlight.min.js +1244 -0
  410. package/src/templates/assets/js/lucide.min.js +12 -0
  411. package/src/templates/assets/js/marked.min.js +69 -0
  412. package/src/templates/assets/js/tailwind.js +83 -0
  413. package/src/templates/dashboard-css/01-base.css +302 -0
  414. package/src/templates/dashboard-css/02-session.css +748 -0
  415. package/src/templates/dashboard-css/04-lite-tasks.css +1181 -0
  416. package/src/templates/dashboard-css/06-cards.css +1576 -0
  417. package/src/templates/dashboard-css/07-managers.css +2107 -0
  418. package/src/templates/dashboard-css/09-explorer.css +1408 -0
  419. package/src/templates/dashboard-css/10-cli-status.css +337 -0
  420. package/src/templates/dashboard-css/11-cli-history.css +271 -0
  421. package/src/templates/dashboard-css/12-cli-legacy.css +796 -0
  422. package/src/templates/dashboard-css/13-cli-ccw.css +199 -0
  423. package/src/templates/dashboard-css/14-cli-modals.css +258 -0
  424. package/src/templates/dashboard-css/15-cli-endpoints.css +305 -0
  425. package/src/templates/dashboard-css/16-cli-session.css +241 -0
  426. package/src/templates/dashboard-css/17-cli-conversation.css +283 -0
  427. package/src/templates/dashboard-css/18-cli-settings.css +160 -0
  428. package/src/templates/dashboard-css/19-cli-native-session.css +496 -0
  429. package/src/templates/dashboard-css/20-cli-taskqueue.css +188 -0
  430. package/src/templates/dashboard-css/21-cli-toolmgmt.css +310 -0
  431. package/src/templates/dashboard-css/22-cli-semantic.css +240 -0
  432. package/src/templates/dashboard-css/23-memory.css +2390 -0
  433. package/src/templates/dashboard-css/24-prompt-history.css +1089 -0
  434. package/src/templates/dashboard-css/25-skills-rules.css +326 -0
  435. package/src/templates/dashboard-css/26-claude-manager.css +908 -0
  436. package/src/templates/dashboard-css/27-graph-explorer.css +1678 -0
  437. package/src/templates/dashboard-css/28-mcp-manager.css +748 -0
  438. package/src/templates/dashboard-css/29-help.css +264 -0
  439. package/src/templates/dashboard-css/30-core-memory.css +1700 -0
  440. package/src/templates/dashboard-js/api.js +220 -0
  441. package/src/templates/dashboard-js/components/carousel.js +398 -0
  442. package/src/templates/dashboard-js/components/cli-history.js +876 -0
  443. package/src/templates/dashboard-js/components/cli-status.js +978 -0
  444. package/src/templates/dashboard-js/components/global-notifications.js +508 -0
  445. package/src/templates/dashboard-js/components/hook-manager.js +1278 -0
  446. package/src/templates/dashboard-js/components/index-manager.js +302 -0
  447. package/src/templates/dashboard-js/components/mcp-manager.js +1219 -0
  448. package/src/templates/dashboard-js/components/modals.js +326 -0
  449. package/src/templates/dashboard-js/components/navigation.js +313 -0
  450. package/src/templates/dashboard-js/components/notifications.js +758 -0
  451. package/src/templates/dashboard-js/components/storage-manager.js +478 -0
  452. package/src/templates/dashboard-js/components/tabs-other.js +424 -0
  453. package/src/templates/dashboard-js/components/task-queue-sidebar.js +716 -0
  454. package/src/templates/dashboard-js/help-i18n.js +272 -0
  455. package/src/templates/dashboard-js/i18n.js +2807 -0
  456. package/src/templates/dashboard-js/main.js +87 -0
  457. package/src/templates/dashboard-js/state.js +243 -0
  458. package/src/templates/dashboard-js/utils.js +199 -0
  459. package/src/templates/dashboard-js/views/claude-manager.js +912 -0
  460. package/src/templates/dashboard-js/views/cli-manager.js +2272 -0
  461. package/src/templates/dashboard-js/views/codexlens-manager.js +964 -0
  462. package/src/templates/dashboard-js/views/core-memory-clusters.js +503 -0
  463. package/src/templates/dashboard-js/views/core-memory.js +782 -0
  464. package/src/templates/dashboard-js/views/explorer.js +888 -0
  465. package/src/templates/dashboard-js/views/graph-explorer.js +1157 -0
  466. package/src/templates/dashboard-js/views/help.js +856 -0
  467. package/src/templates/dashboard-js/views/history.js +337 -0
  468. package/src/templates/dashboard-js/views/home.js +243 -0
  469. package/src/templates/dashboard-js/views/hook-manager.js +660 -0
  470. package/src/templates/dashboard-js/views/lite-tasks.js +861 -0
  471. package/src/templates/dashboard-js/views/mcp-manager.js +2187 -0
  472. package/src/templates/dashboard-js/views/mcp-manager.js.backup +1729 -0
  473. package/src/templates/dashboard-js/views/mcp-manager.js.new +928 -0
  474. package/src/templates/dashboard-js/views/memory.js +1221 -0
  475. package/src/templates/dashboard-js/views/prompt-history.js +713 -0
  476. package/src/templates/dashboard-js/views/rules-manager.js +828 -0
  477. package/src/templates/dashboard-js/views/session-detail.js +781 -0
  478. package/src/templates/dashboard-js/views/skills-manager.js +819 -0
  479. package/src/templates/dashboard.html +831 -0
  480. package/src/templates/hooks-config-example.json +60 -0
  481. package/src/tools/classify-folders.ts +245 -0
  482. package/src/tools/cli-config-manager.ts +268 -0
  483. package/src/tools/cli-executor.ts +2014 -0
  484. package/src/tools/cli-history-store.ts +1195 -0
  485. package/src/tools/codex-lens.ts +1141 -0
  486. package/src/tools/convert-tokens-to-css.ts +300 -0
  487. package/src/tools/core-memory.ts +444 -0
  488. package/src/tools/detect-changed-modules.ts +325 -0
  489. package/src/tools/discover-design-files.ts +184 -0
  490. package/src/tools/edit-file.ts +568 -0
  491. package/src/tools/generate-module-docs.ts +438 -0
  492. package/src/tools/get-modules-by-depth.ts +349 -0
  493. package/src/tools/index.ts +370 -0
  494. package/src/tools/native-session-discovery.ts +795 -0
  495. package/src/tools/notifier.ts +129 -0
  496. package/src/tools/read-file.ts +410 -0
  497. package/src/tools/resume-strategy.ts +345 -0
  498. package/src/tools/session-content-parser.ts +619 -0
  499. package/src/tools/session-manager.ts +1026 -0
  500. package/src/tools/smart-context.ts +228 -0
  501. package/src/tools/smart-search.ts +2065 -0
  502. package/src/tools/smart-search.ts.backup +1233 -0
  503. package/src/tools/storage-manager.ts +455 -0
  504. package/src/tools/write-file.ts +222 -0
  505. package/src/types/config.ts +11 -0
  506. package/src/types/index.ts +3 -0
  507. package/src/types/session.ts +25 -0
  508. package/src/types/tool.ts +41 -0
  509. package/src/utils/browser-launcher.ts +62 -0
  510. package/src/utils/file-utils.ts +48 -0
  511. package/src/utils/path-resolver.ts +315 -0
  512. package/src/utils/path-validator.ts +153 -0
  513. package/src/utils/ui.ts +155 -0
  514. package/.claude/agents/action-planning-agent.md +0 -778
  515. package/.claude/agents/cli-execution-agent.md +0 -270
  516. package/.claude/agents/cli-explore-agent.md +0 -182
  517. package/.claude/agents/cli-lite-planning-agent.md +0 -396
  518. package/.claude/agents/cli-planning-agent.md +0 -558
  519. package/.claude/agents/code-developer.md +0 -310
  520. package/.claude/agents/conceptual-planning-agent.md +0 -308
  521. package/.claude/agents/context-search-agent.md +0 -582
  522. package/.claude/agents/doc-generator.md +0 -330
  523. package/.claude/agents/memory-bridge.md +0 -94
  524. package/.claude/agents/test-context-search-agent.md +0 -399
  525. package/.claude/agents/test-fix-agent.md +0 -343
  526. package/.claude/agents/ui-design-agent.md +0 -593
  527. package/.claude/agents/universal-executor.md +0 -131
  528. package/.claude/commands/cli/cli-init.md +0 -440
  529. package/.claude/commands/enhance-prompt.md +0 -93
  530. package/.claude/commands/memory/code-map-memory.md +0 -687
  531. package/.claude/commands/memory/docs-full-cli.md +0 -471
  532. package/.claude/commands/memory/docs-related-cli.md +0 -386
  533. package/.claude/commands/memory/docs.md +0 -615
  534. package/.claude/commands/memory/load-skill-memory.md +0 -182
  535. package/.claude/commands/memory/load.md +0 -240
  536. package/.claude/commands/memory/skill-memory.md +0 -525
  537. package/.claude/commands/memory/style-skill-memory.md +0 -396
  538. package/.claude/commands/memory/tech-research.md +0 -477
  539. package/.claude/commands/memory/update-full.md +0 -332
  540. package/.claude/commands/memory/update-related.md +0 -332
  541. package/.claude/commands/memory/workflow-skill-memory.md +0 -517
  542. package/.claude/commands/task/breakdown.md +0 -204
  543. package/.claude/commands/task/create.md +0 -152
  544. package/.claude/commands/task/execute.md +0 -270
  545. package/.claude/commands/task/replan.md +0 -437
  546. package/.claude/commands/version.md +0 -254
  547. package/.claude/commands/workflow/action-plan-verify.md +0 -447
  548. package/.claude/commands/workflow/brainstorm/api-designer.md +0 -585
  549. package/.claude/commands/workflow/brainstorm/artifacts.md +0 -452
  550. package/.claude/commands/workflow/brainstorm/auto-parallel.md +0 -443
  551. package/.claude/commands/workflow/brainstorm/data-architect.md +0 -220
  552. package/.claude/commands/workflow/brainstorm/product-manager.md +0 -200
  553. package/.claude/commands/workflow/brainstorm/product-owner.md +0 -200
  554. package/.claude/commands/workflow/brainstorm/scrum-master.md +0 -200
  555. package/.claude/commands/workflow/brainstorm/subject-matter-expert.md +0 -200
  556. package/.claude/commands/workflow/brainstorm/synthesis.md +0 -398
  557. package/.claude/commands/workflow/brainstorm/system-architect.md +0 -387
  558. package/.claude/commands/workflow/brainstorm/ui-designer.md +0 -221
  559. package/.claude/commands/workflow/brainstorm/ux-expert.md +0 -221
  560. package/.claude/commands/workflow/execute.md +0 -462
  561. package/.claude/commands/workflow/init.md +0 -164
  562. package/.claude/commands/workflow/lite-execute.md +0 -686
  563. package/.claude/commands/workflow/lite-fix.md +0 -621
  564. package/.claude/commands/workflow/lite-plan.md +0 -592
  565. package/.claude/commands/workflow/plan.md +0 -551
  566. package/.claude/commands/workflow/replan.md +0 -515
  567. package/.claude/commands/workflow/review-fix.md +0 -606
  568. package/.claude/commands/workflow/review-module-cycle.md +0 -765
  569. package/.claude/commands/workflow/review-session-cycle.md +0 -776
  570. package/.claude/commands/workflow/review.md +0 -291
  571. package/.claude/commands/workflow/session/complete.md +0 -500
  572. package/.claude/commands/workflow/session/list.md +0 -96
  573. package/.claude/commands/workflow/session/resume.md +0 -61
  574. package/.claude/commands/workflow/session/start.md +0 -200
  575. package/.claude/commands/workflow/tdd-plan.md +0 -460
  576. package/.claude/commands/workflow/tdd-verify.md +0 -386
  577. package/.claude/commands/workflow/test-cycle-execute.md +0 -498
  578. package/.claude/commands/workflow/test-fix-gen.md +0 -699
  579. package/.claude/commands/workflow/test-gen.md +0 -529
  580. package/.claude/commands/workflow/tools/conflict-resolution.md +0 -680
  581. package/.claude/commands/workflow/tools/context-gather.md +0 -434
  582. package/.claude/commands/workflow/tools/task-generate-agent.md +0 -291
  583. package/.claude/commands/workflow/tools/task-generate-tdd.md +0 -518
  584. package/.claude/commands/workflow/tools/tdd-coverage-analysis.md +0 -309
  585. package/.claude/commands/workflow/tools/test-concept-enhanced.md +0 -163
  586. package/.claude/commands/workflow/tools/test-context-gather.md +0 -235
  587. package/.claude/commands/workflow/tools/test-task-generate.md +0 -256
  588. package/.claude/commands/workflow/ui-design/animation-extract.md +0 -1150
  589. package/.claude/commands/workflow/ui-design/codify-style.md +0 -652
  590. package/.claude/commands/workflow/ui-design/design-sync.md +0 -454
  591. package/.claude/commands/workflow/ui-design/explore-auto.md +0 -678
  592. package/.claude/commands/workflow/ui-design/generate.md +0 -504
  593. package/.claude/commands/workflow/ui-design/imitate-auto.md +0 -745
  594. package/.claude/commands/workflow/ui-design/import-from-code.md +0 -537
  595. package/.claude/commands/workflow/ui-design/layout-extract.md +0 -788
  596. package/.claude/commands/workflow/ui-design/reference-page-generator.md +0 -356
  597. package/.claude/commands/workflow/ui-design/style-extract.md +0 -773
  598. package/.claude/scripts/classify-folders.sh +0 -39
  599. package/.claude/scripts/convert_tokens_to_css.sh +0 -229
  600. package/.claude/scripts/detect_changed_modules.sh +0 -161
  601. package/.claude/scripts/discover-design-files.sh +0 -87
  602. package/.claude/scripts/extract-animations.js +0 -243
  603. package/.claude/scripts/extract-computed-styles.js +0 -118
  604. package/.claude/scripts/extract-layout-structure.js +0 -411
  605. package/.claude/scripts/generate_module_docs.sh +0 -717
  606. package/.claude/scripts/get_modules_by_depth.sh +0 -170
  607. package/.claude/scripts/ui-generate-preview.sh +0 -395
  608. package/.claude/scripts/ui-instantiate-prototypes.sh +0 -815
  609. package/.claude/scripts/update_module_claude.sh +0 -337
  610. package/.claude/skills/command-guide/SKILL.md +0 -388
  611. package/.claude/skills/command-guide/UPDATE-GUIDELINE.md +0 -592
  612. package/.claude/skills/command-guide/guides/cli-tools-guide.md +0 -410
  613. package/.claude/skills/command-guide/guides/examples.md +0 -537
  614. package/.claude/skills/command-guide/guides/getting-started.md +0 -242
  615. package/.claude/skills/command-guide/guides/implementation-details.md +0 -1010
  616. package/.claude/skills/command-guide/guides/index-structure.md +0 -326
  617. package/.claude/skills/command-guide/guides/troubleshooting.md +0 -92
  618. package/.claude/skills/command-guide/guides/ui-design-workflow-guide.md +0 -316
  619. package/.claude/skills/command-guide/guides/workflow-patterns.md +0 -662
  620. package/.claude/skills/command-guide/index/all-commands.json +0 -772
  621. package/.claude/skills/command-guide/index/by-category.json +0 -800
  622. package/.claude/skills/command-guide/index/by-use-case.json +0 -786
  623. package/.claude/skills/command-guide/index/command-relationships.json +0 -307
  624. package/.claude/skills/command-guide/index/essential-commands.json +0 -112
  625. package/.claude/skills/command-guide/reference/agents/action-planning-agent.md +0 -778
  626. package/.claude/skills/command-guide/reference/agents/cli-execution-agent.md +0 -270
  627. package/.claude/skills/command-guide/reference/agents/cli-explore-agent.md +0 -182
  628. package/.claude/skills/command-guide/reference/agents/cli-lite-planning-agent.md +0 -396
  629. package/.claude/skills/command-guide/reference/agents/cli-planning-agent.md +0 -558
  630. package/.claude/skills/command-guide/reference/agents/code-developer.md +0 -310
  631. package/.claude/skills/command-guide/reference/agents/conceptual-planning-agent.md +0 -308
  632. package/.claude/skills/command-guide/reference/agents/context-search-agent.md +0 -582
  633. package/.claude/skills/command-guide/reference/agents/doc-generator.md +0 -330
  634. package/.claude/skills/command-guide/reference/agents/memory-bridge.md +0 -94
  635. package/.claude/skills/command-guide/reference/agents/test-context-search-agent.md +0 -399
  636. package/.claude/skills/command-guide/reference/agents/test-fix-agent.md +0 -343
  637. package/.claude/skills/command-guide/reference/agents/ui-design-agent.md +0 -593
  638. package/.claude/skills/command-guide/reference/agents/universal-executor.md +0 -131
  639. package/.claude/skills/command-guide/reference/commands/cli/cli-init.md +0 -440
  640. package/.claude/skills/command-guide/reference/commands/enhance-prompt.md +0 -93
  641. package/.claude/skills/command-guide/reference/commands/memory/code-map-memory.md +0 -687
  642. package/.claude/skills/command-guide/reference/commands/memory/docs-full-cli.md +0 -471
  643. package/.claude/skills/command-guide/reference/commands/memory/docs-related-cli.md +0 -386
  644. package/.claude/skills/command-guide/reference/commands/memory/docs.md +0 -615
  645. package/.claude/skills/command-guide/reference/commands/memory/load-skill-memory.md +0 -182
  646. package/.claude/skills/command-guide/reference/commands/memory/load.md +0 -240
  647. package/.claude/skills/command-guide/reference/commands/memory/skill-memory.md +0 -525
  648. package/.claude/skills/command-guide/reference/commands/memory/style-skill-memory.md +0 -396
  649. package/.claude/skills/command-guide/reference/commands/memory/tech-research.md +0 -477
  650. package/.claude/skills/command-guide/reference/commands/memory/update-full.md +0 -332
  651. package/.claude/skills/command-guide/reference/commands/memory/update-related.md +0 -332
  652. package/.claude/skills/command-guide/reference/commands/memory/workflow-skill-memory.md +0 -517
  653. package/.claude/skills/command-guide/reference/commands/task/breakdown.md +0 -204
  654. package/.claude/skills/command-guide/reference/commands/task/create.md +0 -152
  655. package/.claude/skills/command-guide/reference/commands/task/execute.md +0 -270
  656. package/.claude/skills/command-guide/reference/commands/task/replan.md +0 -437
  657. package/.claude/skills/command-guide/reference/commands/version.md +0 -254
  658. package/.claude/skills/command-guide/reference/commands/workflow/action-plan-verify.md +0 -447
  659. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/api-designer.md +0 -585
  660. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/artifacts.md +0 -452
  661. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/auto-parallel.md +0 -443
  662. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/data-architect.md +0 -220
  663. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-manager.md +0 -200
  664. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-owner.md +0 -200
  665. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/scrum-master.md +0 -200
  666. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/subject-matter-expert.md +0 -200
  667. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/synthesis.md +0 -398
  668. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/system-architect.md +0 -387
  669. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ui-designer.md +0 -221
  670. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ux-expert.md +0 -221
  671. package/.claude/skills/command-guide/reference/commands/workflow/execute.md +0 -460
  672. package/.claude/skills/command-guide/reference/commands/workflow/init.md +0 -164
  673. package/.claude/skills/command-guide/reference/commands/workflow/lite-execute.md +0 -686
  674. package/.claude/skills/command-guide/reference/commands/workflow/lite-fix.md +0 -621
  675. package/.claude/skills/command-guide/reference/commands/workflow/lite-plan.md +0 -592
  676. package/.claude/skills/command-guide/reference/commands/workflow/plan.md +0 -551
  677. package/.claude/skills/command-guide/reference/commands/workflow/replan.md +0 -515
  678. package/.claude/skills/command-guide/reference/commands/workflow/review-fix.md +0 -606
  679. package/.claude/skills/command-guide/reference/commands/workflow/review-module-cycle.md +0 -765
  680. package/.claude/skills/command-guide/reference/commands/workflow/review-session-cycle.md +0 -776
  681. package/.claude/skills/command-guide/reference/commands/workflow/review.md +0 -291
  682. package/.claude/skills/command-guide/reference/commands/workflow/session/complete.md +0 -500
  683. package/.claude/skills/command-guide/reference/commands/workflow/session/list.md +0 -96
  684. package/.claude/skills/command-guide/reference/commands/workflow/session/resume.md +0 -61
  685. package/.claude/skills/command-guide/reference/commands/workflow/session/start.md +0 -200
  686. package/.claude/skills/command-guide/reference/commands/workflow/tdd-plan.md +0 -460
  687. package/.claude/skills/command-guide/reference/commands/workflow/tdd-verify.md +0 -386
  688. package/.claude/skills/command-guide/reference/commands/workflow/test-cycle-execute.md +0 -498
  689. package/.claude/skills/command-guide/reference/commands/workflow/test-fix-gen.md +0 -699
  690. package/.claude/skills/command-guide/reference/commands/workflow/test-gen.md +0 -529
  691. package/.claude/skills/command-guide/reference/commands/workflow/tools/conflict-resolution.md +0 -680
  692. package/.claude/skills/command-guide/reference/commands/workflow/tools/context-gather.md +0 -434
  693. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-agent.md +0 -291
  694. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-tdd.md +0 -518
  695. package/.claude/skills/command-guide/reference/commands/workflow/tools/tdd-coverage-analysis.md +0 -309
  696. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-concept-enhanced.md +0 -163
  697. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-context-gather.md +0 -235
  698. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-task-generate.md +0 -256
  699. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/animation-extract.md +0 -1150
  700. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/codify-style.md +0 -652
  701. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/design-sync.md +0 -454
  702. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/explore-auto.md +0 -678
  703. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/generate.md +0 -504
  704. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/imitate-auto.md +0 -745
  705. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/import-from-code.md +0 -537
  706. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/layout-extract.md +0 -788
  707. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/reference-page-generator.md +0 -356
  708. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/style-extract.md +0 -773
  709. package/.claude/skills/command-guide/scripts/analyze_commands.py +0 -502
  710. package/.claude/skills/command-guide/scripts/update-index.sh +0 -130
  711. package/.claude/skills/command-guide/templates/issue-bug.md +0 -104
  712. package/.claude/skills/command-guide/templates/issue-diagnosis.md +0 -275
  713. package/.claude/skills/command-guide/templates/issue-feature.md +0 -97
  714. package/.claude/skills/command-guide/templates/issue-question.md +0 -141
  715. package/.claude/skills/prompt-enhancer/SKILL.md +0 -124
  716. package/.claude/workflows/_template-compare-matrix.html +0 -692
  717. package/.claude/workflows/cli-templates/fix-plan-template.json +0 -75
  718. package/.claude/workflows/cli-templates/fix-progress-template.json +0 -48
  719. package/.claude/workflows/cli-templates/memory/style-skill-memory/skill-md-template.md +0 -299
  720. package/.claude/workflows/cli-templates/planning-roles/data-architect.md +0 -120
  721. package/.claude/workflows/cli-templates/planning-roles/product-manager.md +0 -119
  722. package/.claude/workflows/cli-templates/planning-roles/product-owner.md +0 -261
  723. package/.claude/workflows/cli-templates/planning-roles/scrum-master.md +0 -186
  724. package/.claude/workflows/cli-templates/planning-roles/subject-matter-expert.md +0 -281
  725. package/.claude/workflows/cli-templates/planning-roles/synthesis-role.md +0 -414
  726. package/.claude/workflows/cli-templates/planning-roles/system-architect.md +0 -106
  727. package/.claude/workflows/cli-templates/planning-roles/test-strategist.md +0 -124
  728. package/.claude/workflows/cli-templates/planning-roles/ui-designer.md +0 -379
  729. package/.claude/workflows/cli-templates/planning-roles/ux-expert.md +0 -240
  730. package/.claude/workflows/cli-templates/prompts/analysis/01-diagnose-bug-root-cause.txt +0 -127
  731. package/.claude/workflows/cli-templates/prompts/analysis/01-trace-code-execution.txt +0 -115
  732. package/.claude/workflows/cli-templates/prompts/analysis/02-analyze-code-patterns.txt +0 -37
  733. package/.claude/workflows/cli-templates/prompts/analysis/02-analyze-technical-document.txt +0 -33
  734. package/.claude/workflows/cli-templates/prompts/analysis/02-review-architecture.txt +0 -29
  735. package/.claude/workflows/cli-templates/prompts/analysis/02-review-code-quality.txt +0 -28
  736. package/.claude/workflows/cli-templates/prompts/analysis/03-analyze-performance.txt +0 -29
  737. package/.claude/workflows/cli-templates/prompts/analysis/03-assess-security-risks.txt +0 -29
  738. package/.claude/workflows/cli-templates/prompts/analysis/03-review-quality-standards.txt +0 -29
  739. package/.claude/workflows/cli-templates/prompts/development/02-generate-tests.txt +0 -70
  740. package/.claude/workflows/cli-templates/prompts/development/02-implement-component-ui.txt +0 -55
  741. package/.claude/workflows/cli-templates/prompts/development/02-implement-feature.txt +0 -58
  742. package/.claude/workflows/cli-templates/prompts/development/02-refactor-codebase.txt +0 -55
  743. package/.claude/workflows/cli-templates/prompts/development/03-debug-runtime-issues.txt +0 -55
  744. package/.claude/workflows/cli-templates/prompts/documentation/api.txt +0 -15
  745. package/.claude/workflows/cli-templates/prompts/documentation/folder-navigation.txt +0 -27
  746. package/.claude/workflows/cli-templates/prompts/documentation/module-readme.txt +0 -49
  747. package/.claude/workflows/cli-templates/prompts/documentation/project-architecture.txt +0 -41
  748. package/.claude/workflows/cli-templates/prompts/documentation/project-examples.txt +0 -35
  749. package/.claude/workflows/cli-templates/prompts/documentation/project-readme.txt +0 -35
  750. package/.claude/workflows/cli-templates/prompts/memory/02-document-module-structure.txt +0 -165
  751. package/.claude/workflows/cli-templates/prompts/planning/01-plan-architecture-design.txt +0 -109
  752. package/.claude/workflows/cli-templates/prompts/planning/02-breakdown-task-steps.txt +0 -30
  753. package/.claude/workflows/cli-templates/prompts/planning/02-design-component-spec.txt +0 -28
  754. package/.claude/workflows/cli-templates/prompts/planning/03-evaluate-concept-feasibility.txt +0 -127
  755. package/.claude/workflows/cli-templates/prompts/planning/03-plan-migration-strategy.txt +0 -30
  756. package/.claude/workflows/cli-templates/prompts/tech/tech-module-format.txt +0 -359
  757. package/.claude/workflows/cli-templates/prompts/tech/tech-skill-index.txt +0 -185
  758. package/.claude/workflows/cli-templates/prompts/test/test-concept-analysis.txt +0 -179
  759. package/.claude/workflows/cli-templates/prompts/universal/00-universal-creative-style.txt +0 -95
  760. package/.claude/workflows/cli-templates/prompts/universal/00-universal-rigorous-style.txt +0 -92
  761. package/.claude/workflows/cli-templates/prompts/verification/codex-technical.txt +0 -28
  762. package/.claude/workflows/cli-templates/prompts/verification/cross-validation.txt +0 -28
  763. package/.claude/workflows/cli-templates/prompts/verification/gemini-strategic.txt +0 -27
  764. package/.claude/workflows/cli-templates/prompts/workflow/analysis-results-structure.txt +0 -224
  765. package/.claude/workflows/cli-templates/prompts/workflow/codex-feasibility-validation.txt +0 -176
  766. package/.claude/workflows/cli-templates/prompts/workflow/gemini-solution-design.txt +0 -131
  767. package/.claude/workflows/cli-templates/prompts/workflow/impl-plan-template.txt +0 -286
  768. package/.claude/workflows/cli-templates/prompts/workflow/skill-aggregation.txt +0 -172
  769. package/.claude/workflows/cli-templates/prompts/workflow/skill-conflict-patterns.txt +0 -98
  770. package/.claude/workflows/cli-templates/prompts/workflow/skill-index.txt +0 -224
  771. package/.claude/workflows/cli-templates/prompts/workflow/skill-lessons-learned.txt +0 -98
  772. package/.claude/workflows/cli-templates/prompts/workflow/skill-sessions-timeline.txt +0 -53
  773. package/.claude/workflows/cli-templates/prompts/workflow/task-json-agent-mode.txt +0 -123
  774. package/.claude/workflows/cli-templates/prompts/workflow/task-json-cli-mode.txt +0 -182
  775. package/.claude/workflows/cli-templates/schemas/diagnosis-json-schema.json +0 -234
  776. package/.claude/workflows/cli-templates/schemas/explore-json-schema.json +0 -124
  777. package/.claude/workflows/cli-templates/schemas/fix-plan-json-schema.json +0 -273
  778. package/.claude/workflows/cli-templates/schemas/plan-json-schema.json +0 -219
  779. package/.claude/workflows/cli-templates/schemas/project-json-schema.json +0 -221
  780. package/.claude/workflows/cli-templates/schemas/review-deep-dive-results-schema.json +0 -82
  781. package/.claude/workflows/cli-templates/schemas/review-dimension-results-schema.json +0 -51
  782. package/.claude/workflows/cli-templates/tech-stacks/go-dev.md +0 -91
  783. package/.claude/workflows/cli-templates/tech-stacks/java-dev.md +0 -107
  784. package/.claude/workflows/cli-templates/tech-stacks/javascript-dev.md +0 -58
  785. package/.claude/workflows/cli-templates/tech-stacks/python-dev.md +0 -79
  786. package/.claude/workflows/cli-templates/tech-stacks/react-dev.md +0 -103
  787. package/.claude/workflows/cli-templates/tech-stacks/typescript-dev.md +0 -83
  788. package/.claude/workflows/cli-templates/ui-design/systems/animation-tokens.json +0 -247
  789. package/.claude/workflows/cli-templates/ui-design/systems/design-tokens.json +0 -342
  790. package/.claude/workflows/cli-templates/ui-design/systems/layout-templates.json +0 -145
  791. package/.claude/workflows/context-search-strategy.md +0 -77
  792. package/.claude/workflows/intelligent-tools-strategy.md +0 -662
  793. package/.claude/workflows/review-directory-specification.md +0 -336
  794. package/.claude/workflows/task-core.md +0 -214
  795. package/.claude/workflows/tool-strategy.md +0 -79
  796. package/.claude/workflows/workflow-architecture.md +0 -942
  797. package/.codex/AGENTS.md +0 -330
  798. package/.gemini/GEMINI.md +0 -164
  799. package/.qwen/QWEN.md +0 -164
  800. package/CLAUDE.md +0 -91
  801. package/LICENSE +0 -21
  802. package/ccw/README.md +0 -121
  803. package/ccw/bin/ccw.js +0 -10
  804. package/ccw/package.json +0 -47
  805. package/ccw/src/cli.js +0 -119
  806. package/ccw/src/commands/install.js +0 -324
  807. package/ccw/src/commands/list.js +0 -37
  808. package/ccw/src/commands/serve.js +0 -67
  809. package/ccw/src/commands/stop.js +0 -101
  810. package/ccw/src/commands/tool.js +0 -138
  811. package/ccw/src/commands/uninstall.js +0 -238
  812. package/ccw/src/commands/upgrade.js +0 -307
  813. package/ccw/src/commands/view.js +0 -105
  814. package/ccw/src/core/dashboard-generator-patch.js +0 -29
  815. package/ccw/src/core/dashboard-generator.js +0 -682
  816. package/ccw/src/core/data-aggregator.js +0 -409
  817. package/ccw/src/core/lite-scanner.js +0 -373
  818. package/ccw/src/core/manifest.js +0 -201
  819. package/ccw/src/core/server.js +0 -2063
  820. package/ccw/src/core/session-scanner.js +0 -235
  821. package/ccw/src/index.js +0 -9
  822. package/ccw/src/templates/dashboard-css/01-base.css +0 -291
  823. package/ccw/src/templates/dashboard-css/02-session.css +0 -726
  824. package/ccw/src/templates/dashboard-css/04-lite-tasks.css +0 -1171
  825. package/ccw/src/templates/dashboard-css/06-cards.css +0 -1570
  826. package/ccw/src/templates/dashboard-css/07-managers.css +0 -936
  827. package/ccw/src/templates/dashboard-css/09-explorer.css +0 -1397
  828. package/ccw/src/templates/dashboard-js/api.js +0 -200
  829. package/ccw/src/templates/dashboard-js/components/carousel.js +0 -398
  830. package/ccw/src/templates/dashboard-js/components/global-notifications.js +0 -219
  831. package/ccw/src/templates/dashboard-js/components/hook-manager.js +0 -283
  832. package/ccw/src/templates/dashboard-js/components/mcp-manager.js +0 -528
  833. package/ccw/src/templates/dashboard-js/components/modals.js +0 -260
  834. package/ccw/src/templates/dashboard-js/components/navigation.js +0 -245
  835. package/ccw/src/templates/dashboard-js/components/notifications.js +0 -194
  836. package/ccw/src/templates/dashboard-js/components/tabs-other.js +0 -273
  837. package/ccw/src/templates/dashboard-js/main.js +0 -72
  838. package/ccw/src/templates/dashboard-js/state.js +0 -42
  839. package/ccw/src/templates/dashboard-js/utils.js +0 -153
  840. package/ccw/src/templates/dashboard-js/views/explorer.js +0 -852
  841. package/ccw/src/templates/dashboard-js/views/home.js +0 -197
  842. package/ccw/src/templates/dashboard-js/views/hook-manager.js +0 -392
  843. package/ccw/src/templates/dashboard-js/views/lite-tasks.js +0 -685
  844. package/ccw/src/templates/dashboard-js/views/mcp-manager.js +0 -411
  845. package/ccw/src/templates/dashboard-js/views/session-detail.js +0 -780
  846. package/ccw/src/templates/dashboard.html +0 -731
  847. package/ccw/src/tools/classify-folders.js +0 -204
  848. package/ccw/src/tools/convert-tokens-to-css.js +0 -250
  849. package/ccw/src/tools/detect-changed-modules.js +0 -288
  850. package/ccw/src/tools/discover-design-files.js +0 -134
  851. package/ccw/src/tools/edit-file.js +0 -266
  852. package/ccw/src/tools/generate-module-docs.js +0 -416
  853. package/ccw/src/tools/get-modules-by-depth.js +0 -308
  854. package/ccw/src/tools/index.js +0 -176
  855. package/ccw/src/utils/browser-launcher.js +0 -60
  856. package/ccw/src/utils/file-utils.js +0 -48
  857. package/ccw/src/utils/path-resolver.js +0 -279
  858. package/ccw/src/utils/ui.js +0 -148
  859. /package/{ccw/src → src}/templates/dashboard-css/03-tasks.css +0 -0
  860. /package/{ccw/src → src}/templates/dashboard-css/05-context.css +0 -0
  861. /package/{ccw/src → src}/templates/dashboard-css/08-review.css +0 -0
  862. /package/{ccw/src → src}/templates/dashboard-js/components/_conflict_tab.js +0 -0
  863. /package/{ccw/src → src}/templates/dashboard-js/components/_exp_helpers.js +0 -0
  864. /package/{ccw/src → src}/templates/dashboard-js/components/_review_tab.js +0 -0
  865. /package/{ccw/src → src}/templates/dashboard-js/components/flowchart.js +0 -0
  866. /package/{ccw/src → src}/templates/dashboard-js/components/sidebar.js +0 -0
  867. /package/{ccw/src → src}/templates/dashboard-js/components/tabs-context.js +0 -0
  868. /package/{ccw/src → src}/templates/dashboard-js/components/task-drawer-core.js +0 -0
  869. /package/{ccw/src → src}/templates/dashboard-js/components/task-drawer-renderers.js +0 -0
  870. /package/{ccw/src → src}/templates/dashboard-js/components/theme.js +0 -0
  871. /package/{ccw/src → src}/templates/dashboard-js/components/version-check.js +0 -0
  872. /package/{ccw/src → src}/templates/dashboard-js/views/fix-session.js +0 -0
  873. /package/{ccw/src → src}/templates/dashboard-js/views/project-overview.js +0 -0
  874. /package/{ccw/src → src}/templates/dashboard-js/views/review-session.js +0 -0
  875. /package/{ccw/src → src}/templates/review-cycle-dashboard.html +0 -0
  876. /package/{ccw/src → src}/templates/workflow-dashboard.html +0 -0
  877. /package/{ccw/src → src}/tools/ui-generate-preview.js +0 -0
  878. /package/{ccw/src → src}/tools/ui-instantiate-prototypes.js +0 -0
  879. /package/{ccw/src → src}/tools/update-module-claude.js +0 -0
@@ -0,0 +1,1278 @@
1
+ // Hook Manager Component
2
+ // Manages Claude Code hooks configuration from settings.json
3
+
4
+ // ========== Hook State ==========
5
+ let hookConfig = {
6
+ global: { hooks: {} },
7
+ project: { hooks: {} }
8
+ };
9
+
10
+ // ========== Hook Templates ==========
11
+ const HOOK_TEMPLATES = {
12
+ 'ccw-notify': {
13
+ event: 'PostToolUse',
14
+ matcher: 'Write',
15
+ command: 'bash',
16
+ args: ['-c', 'INPUT=$(cat); FILE_PATH=$(echo "$INPUT" | jq -r ".tool_input.file_path // .tool_input.path // empty"); [ -n "$FILE_PATH" ] && curl -s -X POST -H "Content-Type: application/json" -d "{\\"type\\":\\"file_written\\",\\"filePath\\":\\"$FILE_PATH\\"}" http://localhost:3456/api/hook || true'],
17
+ description: 'Notify CCW dashboard when files are written',
18
+ category: 'notification'
19
+ },
20
+ 'log-tool': {
21
+ event: 'PostToolUse',
22
+ matcher: '',
23
+ command: 'bash',
24
+ args: ['-c', 'INPUT=$(cat); TOOL=$(echo "$INPUT" | jq -r ".tool_name // empty"); FILE=$(echo "$INPUT" | jq -r ".tool_input.file_path // .tool_input.path // empty"); echo "[$(date)] Tool: $TOOL, File: $FILE" >> ~/.claude/tool-usage.log'],
25
+ description: 'Log all tool executions to a file',
26
+ category: 'logging'
27
+ },
28
+ 'lint-check': {
29
+ event: 'PostToolUse',
30
+ matcher: 'Write',
31
+ command: 'bash',
32
+ args: ['-c', 'INPUT=$(cat); FILE=$(echo "$INPUT" | jq -r ".tool_input.file_path // empty"); if [[ "$FILE" =~ \\.(js|ts|jsx|tsx)$ ]]; then npx eslint "$FILE" --fix 2>/dev/null || true; fi'],
33
+ description: 'Run ESLint on JavaScript/TypeScript files after write',
34
+ category: 'quality'
35
+ },
36
+ 'git-add': {
37
+ event: 'PostToolUse',
38
+ matcher: 'Write',
39
+ command: 'bash',
40
+ args: ['-c', 'INPUT=$(cat); FILE=$(echo "$INPUT" | jq -r ".tool_input.file_path // empty"); [ -n "$FILE" ] && git add "$FILE" 2>/dev/null || true'],
41
+ description: 'Automatically stage written files to git',
42
+ category: 'git'
43
+ },
44
+ 'codexlens-update': {
45
+ event: 'PostToolUse',
46
+ matcher: 'Write|Edit',
47
+ command: 'bash',
48
+ args: ['-c', 'INPUT=$(cat); FILE=$(echo "$INPUT" | jq -r ".tool_input.file_path // .tool_input.path // empty"); [ -d ".codexlens" ] && [ -n "$FILE" ] && (python -m codexlens update "$FILE" --json 2>/dev/null || ~/.codexlens/venv/bin/python -m codexlens update "$FILE" --json 2>/dev/null || true)'],
49
+ description: 'Auto-update code index when files are written or edited',
50
+ category: 'indexing'
51
+ },
52
+ 'memory-update-related': {
53
+ event: 'Stop',
54
+ matcher: '',
55
+ command: 'bash',
56
+ args: ['-c', 'ccw tool exec update_module_claude \'{"strategy":"related","tool":"gemini"}\''],
57
+ description: 'Update CLAUDE.md for changed modules when session ends',
58
+ category: 'memory',
59
+ configurable: true,
60
+ config: {
61
+ tool: { type: 'select', options: ['gemini', 'qwen', 'codex'], default: 'gemini', label: 'CLI Tool' },
62
+ strategy: { type: 'select', options: ['related', 'single-layer'], default: 'related', label: 'Strategy' }
63
+ }
64
+ },
65
+ 'memory-update-periodic': {
66
+ event: 'PostToolUse',
67
+ matcher: 'Write|Edit',
68
+ command: 'bash',
69
+ args: ['-c', 'INTERVAL=300; LAST_FILE=~/.claude/.last_memory_update; NOW=$(date +%s); LAST=0; [ -f "$LAST_FILE" ] && LAST=$(cat "$LAST_FILE"); if [ $((NOW - LAST)) -ge $INTERVAL ]; then echo $NOW > "$LAST_FILE"; ccw tool exec update_module_claude \'{"strategy":"related","tool":"gemini"}\' & fi'],
70
+ description: 'Periodically update CLAUDE.md (default: 5 min interval)',
71
+ category: 'memory',
72
+ configurable: true,
73
+ config: {
74
+ tool: { type: 'select', options: ['gemini', 'qwen', 'codex'], default: 'gemini', label: 'CLI Tool' },
75
+ interval: { type: 'number', default: 300, min: 60, max: 3600, label: 'Interval (seconds)', step: 60 }
76
+ }
77
+ },
78
+ 'memory-update-count-based': {
79
+ event: 'PostToolUse',
80
+ matcher: 'Write|Edit',
81
+ command: 'bash',
82
+ args: ['-c', 'THRESHOLD=10; COUNT_FILE=~/.claude/.memory_update_count; INPUT=$(cat); FILE_PATH=$(echo "$INPUT" | jq -r ".tool_input.file_path // .tool_input.path // empty"); [ -z "$FILE_PATH" ] && exit 0; COUNT=0; [ -f "$COUNT_FILE" ] && COUNT=$(cat "$COUNT_FILE" 2>/dev/null || echo 0); COUNT=$((COUNT + 1)); echo $COUNT > "$COUNT_FILE"; if [ $COUNT -ge $THRESHOLD ]; then echo 0 > "$COUNT_FILE"; ccw tool exec update_module_claude \'{"strategy":"related","tool":"gemini"}\' & fi'],
83
+ description: 'Update CLAUDE.md when file changes reach threshold (default: 10 files)',
84
+ category: 'memory',
85
+ configurable: true,
86
+ config: {
87
+ tool: { type: 'select', options: ['gemini', 'qwen', 'codex'], default: 'gemini', label: 'CLI Tool' },
88
+ threshold: { type: 'number', default: 10, min: 3, max: 50, label: 'File count threshold', step: 1 }
89
+ }
90
+ },
91
+ // SKILL Context Loader templates
92
+ 'skill-context-keyword': {
93
+ event: 'UserPromptSubmit',
94
+ matcher: '',
95
+ command: 'bash',
96
+ args: ['-c', 'ccw tool exec skill_context_loader --stdin'],
97
+ description: 'Load SKILL context based on keyword matching in user prompt',
98
+ category: 'skill',
99
+ configurable: true,
100
+ config: {
101
+ keywords: { type: 'text', default: '', label: 'Keywords (comma-separated)', placeholder: 'react,workflow,api' },
102
+ skills: { type: 'text', default: '', label: 'SKILL Names (comma-separated)', placeholder: 'prompt-enhancer,command-guide' }
103
+ }
104
+ },
105
+ 'skill-context-auto': {
106
+ event: 'UserPromptSubmit',
107
+ matcher: '',
108
+ command: 'bash',
109
+ args: ['-c', 'ccw tool exec skill_context_loader --stdin --mode auto'],
110
+ description: 'Auto-detect and load SKILL based on skill name in prompt',
111
+ category: 'skill',
112
+ configurable: false
113
+ },
114
+ 'memory-file-read': {
115
+ event: 'PostToolUse',
116
+ matcher: 'Read|mcp__ccw-tools__read_file',
117
+ command: 'ccw',
118
+ args: ['memory', 'track', '--type', 'file', '--action', 'read', '--stdin'],
119
+ description: 'Track file reads to build context heatmap',
120
+ category: 'memory',
121
+ timeout: 5000
122
+ },
123
+ 'memory-file-write': {
124
+ event: 'PostToolUse',
125
+ matcher: 'Write|Edit|mcp__ccw-tools__write_file|mcp__ccw-tools__edit_file',
126
+ command: 'ccw',
127
+ args: ['memory', 'track', '--type', 'file', '--action', 'write', '--stdin'],
128
+ description: 'Track file modifications to identify core modules',
129
+ category: 'memory',
130
+ timeout: 5000
131
+ },
132
+ 'memory-prompt-track': {
133
+ event: 'UserPromptSubmit',
134
+ matcher: '',
135
+ command: 'ccw',
136
+ args: ['memory', 'track', '--type', 'topic', '--action', 'mention', '--stdin'],
137
+ description: 'Record user prompts for pattern analysis',
138
+ category: 'memory',
139
+ timeout: 5000
140
+ },
141
+ // Session Context - Progressive disclosure based on session state
142
+ // First prompt: returns cluster overview, subsequent: intent-matched sessions
143
+ 'session-context': {
144
+ event: 'UserPromptSubmit',
145
+ matcher: '',
146
+ command: 'ccw',
147
+ args: ['hook', 'session-context', '--stdin'],
148
+ description: 'Progressive session context (cluster overview → intent matching)',
149
+ category: 'context',
150
+ timeout: 5000
151
+ }
152
+ };
153
+
154
+ // ========== Wizard Templates (Special Category) ==========
155
+ const WIZARD_TEMPLATES = {
156
+ 'memory-update': {
157
+ name: 'Memory Update Hook',
158
+ description: 'Automatically update CLAUDE.md documentation based on code changes',
159
+ icon: 'brain',
160
+ options: [
161
+ {
162
+ id: 'on-stop',
163
+ name: 'On Session End',
164
+ description: 'Update documentation when Claude session ends',
165
+ templateId: 'memory-update-related'
166
+ },
167
+ {
168
+ id: 'periodic',
169
+ name: 'Periodic Update',
170
+ description: 'Update documentation at regular intervals during session',
171
+ templateId: 'memory-update-periodic'
172
+ },
173
+ {
174
+ id: 'count-based',
175
+ name: 'Count-Based Update',
176
+ description: 'Update documentation when file changes reach threshold',
177
+ templateId: 'memory-update-count-based'
178
+ }
179
+ ],
180
+ configFields: [
181
+ { key: 'tool', type: 'select', label: 'CLI Tool', options: ['gemini', 'qwen', 'codex'], default: 'gemini', description: 'Tool for documentation generation' },
182
+ { key: 'interval', type: 'number', label: 'Interval (seconds)', default: 300, min: 60, max: 3600, step: 60, showFor: ['periodic'], description: 'Time between updates' },
183
+ { key: 'threshold', type: 'number', label: 'File Count Threshold', default: 10, min: 3, max: 50, step: 1, showFor: ['count-based'], description: 'Number of file changes to trigger update' },
184
+ { key: 'strategy', type: 'select', label: 'Update Strategy', options: ['related', 'single-layer'], default: 'related', description: 'Related: changed modules, Single-layer: current directory' }
185
+ ]
186
+ },
187
+ 'skill-context': {
188
+ name: 'SKILL Context Loader',
189
+ description: 'Automatically load SKILL packages based on keywords in user prompts',
190
+ icon: 'sparkles',
191
+ options: [
192
+ {
193
+ id: 'keyword',
194
+ name: 'Keyword Matching',
195
+ description: 'Load specific SKILLs when keywords are detected in prompt',
196
+ templateId: 'skill-context-keyword'
197
+ },
198
+ {
199
+ id: 'auto',
200
+ name: 'Auto Detection',
201
+ description: 'Automatically detect and load SKILLs by name in prompt',
202
+ templateId: 'skill-context-auto'
203
+ }
204
+ ],
205
+ configFields: [],
206
+ requiresSkillDiscovery: true,
207
+ customRenderer: 'renderSkillContextConfig'
208
+ },
209
+ 'memory-setup': {
210
+ name: 'Memory Module Setup',
211
+ description: 'Configure automatic context tracking',
212
+ icon: 'brain',
213
+ options: [
214
+ {
215
+ id: 'file-read',
216
+ name: 'File Read Tracker',
217
+ description: 'Track file reads to build context heatmap',
218
+ templateId: 'memory-file-read'
219
+ },
220
+ {
221
+ id: 'file-write',
222
+ name: 'File Write Tracker',
223
+ description: 'Track file modifications to identify core modules',
224
+ templateId: 'memory-file-write'
225
+ },
226
+ {
227
+ id: 'prompts',
228
+ name: 'Prompt Tracker',
229
+ description: 'Record user prompts for pattern analysis',
230
+ templateId: 'memory-prompt-track'
231
+ }
232
+ ],
233
+ configFields: [],
234
+ multiSelect: true
235
+ }
236
+ };
237
+
238
+ // ========== Initialization ==========
239
+ function initHookManager() {
240
+ // Initialize Hook navigation
241
+ document.querySelectorAll('.nav-item[data-view="hook-manager"]').forEach(item => {
242
+ item.addEventListener('click', () => {
243
+ setActiveNavItem(item);
244
+ currentView = 'hook-manager';
245
+ currentFilter = null;
246
+ currentLiteType = null;
247
+ currentSessionDetailKey = null;
248
+ updateContentTitle();
249
+ renderHookManager();
250
+ });
251
+ });
252
+ }
253
+
254
+ // ========== Data Loading ==========
255
+ async function loadHookConfig() {
256
+ try {
257
+ const response = await fetch(`/api/hooks?path=${encodeURIComponent(projectPath)}`);
258
+ if (!response.ok) throw new Error('Failed to load hook config');
259
+ const data = await response.json();
260
+ hookConfig = data;
261
+ updateHookBadge();
262
+ return data;
263
+ } catch (err) {
264
+ console.error('Failed to load hook config:', err);
265
+ return null;
266
+ }
267
+ }
268
+
269
+ async function loadAvailableSkills() {
270
+ try {
271
+ const response = await fetch('/api/skills?path=' + encodeURIComponent(projectPath));
272
+ if (!response.ok) throw new Error('Failed to load skills');
273
+ const data = await response.json();
274
+
275
+ // Combine project and user skills
276
+ const projectSkills = (data.projectSkills || []).map(s => ({
277
+ name: s.name,
278
+ path: s.path,
279
+ scope: 'project'
280
+ }));
281
+ const userSkills = (data.userSkills || []).map(s => ({
282
+ name: s.name,
283
+ path: s.path,
284
+ scope: 'user'
285
+ }));
286
+
287
+ // Store in window for access by wizard
288
+ window.availableSkills = [...projectSkills, ...userSkills];
289
+
290
+ return window.availableSkills;
291
+ } catch (err) {
292
+ console.error('Failed to load available skills:', err);
293
+ window.availableSkills = [];
294
+ return [];
295
+ }
296
+ }
297
+
298
+ /**
299
+ * Convert internal hook format to Claude Code format
300
+ * Internal: { command, args, matcher, timeout }
301
+ * Claude Code: { matcher, hooks: [{ type: "command", command: "...", timeout }] }
302
+ */
303
+ function convertToClaudeCodeFormat(hookData) {
304
+ // If already in correct format, return as-is
305
+ if (hookData.hooks && Array.isArray(hookData.hooks)) {
306
+ return hookData;
307
+ }
308
+
309
+ // Build command string from command + args
310
+ let commandStr = hookData.command || '';
311
+ if (hookData.args && Array.isArray(hookData.args)) {
312
+ // Join args, properly quoting if needed
313
+ const quotedArgs = hookData.args.map(arg => {
314
+ if (arg.includes(' ') && !arg.startsWith('"') && !arg.startsWith("'")) {
315
+ return `"${arg.replace(/"/g, '\\"')}"`;
316
+ }
317
+ return arg;
318
+ });
319
+ commandStr = `${commandStr} ${quotedArgs.join(' ')}`.trim();
320
+ }
321
+
322
+ const converted = {
323
+ hooks: [{
324
+ type: 'command',
325
+ command: commandStr
326
+ }]
327
+ };
328
+
329
+ // Add matcher if present (not needed for UserPromptSubmit, Stop, etc.)
330
+ if (hookData.matcher) {
331
+ converted.matcher = hookData.matcher;
332
+ }
333
+
334
+ // Add timeout if present (in seconds for Claude Code)
335
+ if (hookData.timeout) {
336
+ converted.hooks[0].timeout = Math.ceil(hookData.timeout / 1000);
337
+ }
338
+
339
+ // Preserve replaceIndex for updates
340
+ if (hookData.replaceIndex !== undefined) {
341
+ converted.replaceIndex = hookData.replaceIndex;
342
+ }
343
+
344
+ return converted;
345
+ }
346
+
347
+ async function saveHook(scope, event, hookData) {
348
+ try {
349
+ // Convert to Claude Code format before saving
350
+ const convertedHookData = convertToClaudeCodeFormat(hookData);
351
+
352
+ const response = await fetch('/api/hooks', {
353
+ method: 'POST',
354
+ headers: { 'Content-Type': 'application/json' },
355
+ body: JSON.stringify({
356
+ projectPath: projectPath,
357
+ scope: scope,
358
+ event: event,
359
+ hookData: convertedHookData
360
+ })
361
+ });
362
+
363
+ if (!response.ok) throw new Error('Failed to save hook');
364
+
365
+ const result = await response.json();
366
+ if (result.success) {
367
+ await loadHookConfig();
368
+ renderHookManager();
369
+ showRefreshToast(`Hook saved successfully`, 'success');
370
+ }
371
+ return result;
372
+ } catch (err) {
373
+ console.error('Failed to save hook:', err);
374
+ showRefreshToast(`Failed to save hook: ${err.message}`, 'error');
375
+ return null;
376
+ }
377
+ }
378
+
379
+ async function removeHook(scope, event, hookIndex) {
380
+ try {
381
+ const response = await fetch('/api/hooks', {
382
+ method: 'DELETE',
383
+ headers: { 'Content-Type': 'application/json' },
384
+ body: JSON.stringify({
385
+ projectPath: projectPath,
386
+ scope: scope,
387
+ event: event,
388
+ hookIndex: hookIndex
389
+ })
390
+ });
391
+
392
+ if (!response.ok) throw new Error('Failed to remove hook');
393
+
394
+ const result = await response.json();
395
+ if (result.success) {
396
+ await loadHookConfig();
397
+ renderHookManager();
398
+ showRefreshToast(`Hook removed successfully`, 'success');
399
+ }
400
+ return result;
401
+ } catch (err) {
402
+ console.error('Failed to remove hook:', err);
403
+ showRefreshToast(`Failed to remove hook: ${err.message}`, 'error');
404
+ return null;
405
+ }
406
+ }
407
+
408
+ // ========== Badge Update ==========
409
+ function updateHookBadge() {
410
+ const badge = document.getElementById('badgeHooks');
411
+ if (badge) {
412
+ let totalHooks = 0;
413
+
414
+ // Count global hooks
415
+ if (hookConfig.global?.hooks) {
416
+ for (const event of Object.keys(hookConfig.global.hooks)) {
417
+ const hooks = hookConfig.global.hooks[event];
418
+ totalHooks += Array.isArray(hooks) ? hooks.length : 1;
419
+ }
420
+ }
421
+
422
+ // Count project hooks
423
+ if (hookConfig.project?.hooks) {
424
+ for (const event of Object.keys(hookConfig.project.hooks)) {
425
+ const hooks = hookConfig.project.hooks[event];
426
+ totalHooks += Array.isArray(hooks) ? hooks.length : 1;
427
+ }
428
+ }
429
+
430
+ badge.textContent = totalHooks;
431
+ }
432
+ }
433
+
434
+ // ========== Hook Modal Functions ==========
435
+ let editingHookData = null;
436
+
437
+ function openHookCreateModal(editData = null) {
438
+ const modal = document.getElementById('hookCreateModal');
439
+ const title = document.getElementById('hookModalTitle');
440
+
441
+ if (modal) {
442
+ modal.classList.remove('hidden');
443
+ editingHookData = editData;
444
+
445
+ // Set title based on mode
446
+ title.textContent = editData ? 'Edit Hook' : 'Create Hook';
447
+
448
+ // Clear or populate form
449
+ if (editData) {
450
+ document.getElementById('hookEvent').value = editData.event || '';
451
+ document.getElementById('hookMatcher').value = editData.matcher || '';
452
+ document.getElementById('hookCommand').value = editData.command || '';
453
+ document.getElementById('hookArgs').value = (editData.args || []).join('\n');
454
+
455
+ // Set scope radio
456
+ const scopeRadio = document.querySelector(`input[name="hookScope"][value="${editData.scope || 'project'}"]`);
457
+ if (scopeRadio) scopeRadio.checked = true;
458
+ } else {
459
+ document.getElementById('hookEvent').value = '';
460
+ document.getElementById('hookMatcher').value = '';
461
+ document.getElementById('hookCommand').value = '';
462
+ document.getElementById('hookArgs').value = '';
463
+ document.querySelector('input[name="hookScope"][value="project"]').checked = true;
464
+ }
465
+
466
+ // Focus on event select
467
+ document.getElementById('hookEvent').focus();
468
+ }
469
+ }
470
+
471
+ function closeHookCreateModal() {
472
+ const modal = document.getElementById('hookCreateModal');
473
+ if (modal) {
474
+ modal.classList.add('hidden');
475
+ editingHookData = null;
476
+ }
477
+ }
478
+
479
+ function applyHookTemplate(templateName) {
480
+ const template = HOOK_TEMPLATES[templateName];
481
+ if (!template) return;
482
+
483
+ document.getElementById('hookEvent').value = template.event;
484
+ document.getElementById('hookMatcher').value = template.matcher;
485
+ document.getElementById('hookCommand').value = template.command;
486
+ document.getElementById('hookArgs').value = template.args.join('\n');
487
+ }
488
+
489
+ async function submitHookCreate() {
490
+ const event = document.getElementById('hookEvent').value;
491
+ const matcher = document.getElementById('hookMatcher').value.trim();
492
+ const command = document.getElementById('hookCommand').value.trim();
493
+ const argsText = document.getElementById('hookArgs').value.trim();
494
+ const scope = document.querySelector('input[name="hookScope"]:checked').value;
495
+
496
+ // Validate required fields
497
+ if (!event) {
498
+ showRefreshToast('Hook event is required', 'error');
499
+ document.getElementById('hookEvent').focus();
500
+ return;
501
+ }
502
+
503
+ if (!command) {
504
+ showRefreshToast('Command is required', 'error');
505
+ document.getElementById('hookCommand').focus();
506
+ return;
507
+ }
508
+
509
+ // Parse args (one per line)
510
+ const args = argsText ? argsText.split('\n').map(a => a.trim()).filter(a => a) : [];
511
+
512
+ // Build hook data
513
+ const hookData = {
514
+ command: command
515
+ };
516
+
517
+ if (args.length > 0) {
518
+ hookData.args = args;
519
+ }
520
+
521
+ if (matcher) {
522
+ hookData.matcher = matcher;
523
+ }
524
+
525
+ // If editing, include original index for replacement
526
+ if (editingHookData && editingHookData.index !== undefined) {
527
+ hookData.replaceIndex = editingHookData.index;
528
+ }
529
+
530
+ // Submit to API
531
+ await saveHook(scope, event, hookData);
532
+ closeHookCreateModal();
533
+ }
534
+
535
+ // ========== Helpers ==========
536
+ function getHookEventDescription(event) {
537
+ const descriptions = {
538
+ 'PreToolUse': 'Runs before a tool is executed',
539
+ 'PostToolUse': 'Runs after a tool completes',
540
+ 'Notification': 'Runs when a notification is triggered',
541
+ 'Stop': 'Runs when the agent stops',
542
+ 'UserPromptSubmit': 'Runs when user submits a prompt'
543
+ };
544
+ return descriptions[event] || event;
545
+ }
546
+
547
+ function getHookEventIcon(event) {
548
+ const icons = {
549
+ 'PreToolUse': '⏳',
550
+ 'PostToolUse': '✅',
551
+ 'Notification': '🔔',
552
+ 'Stop': '🛑',
553
+ 'UserPromptSubmit': '💬'
554
+ };
555
+ return icons[event] || '🪝';
556
+ }
557
+
558
+ function getHookEventIconLucide(event) {
559
+ const icons = {
560
+ 'PreToolUse': '<i data-lucide="clock" class="w-5 h-5"></i>',
561
+ 'PostToolUse': '<i data-lucide="check-circle" class="w-5 h-5"></i>',
562
+ 'Notification': '<i data-lucide="bell" class="w-5 h-5"></i>',
563
+ 'Stop': '<i data-lucide="octagon-x" class="w-5 h-5"></i>',
564
+ 'UserPromptSubmit': '<i data-lucide="message-square" class="w-5 h-5"></i>'
565
+ };
566
+ return icons[event] || '<i data-lucide="webhook" class="w-5 h-5"></i>';
567
+ }
568
+
569
+ // ========== Wizard Modal Functions ==========
570
+ let currentWizardTemplate = null;
571
+ let wizardConfig = {};
572
+
573
+ async function openHookWizardModal(wizardId) {
574
+ const wizard = WIZARD_TEMPLATES[wizardId];
575
+ if (!wizard) {
576
+ showRefreshToast('Wizard template not found', 'error');
577
+ return;
578
+ }
579
+
580
+ currentWizardTemplate = { id: wizardId, ...wizard };
581
+ wizardConfig = {};
582
+
583
+ // Set defaults
584
+ wizard.configFields.forEach(field => {
585
+ wizardConfig[field.key] = field.default;
586
+ });
587
+
588
+ // Initialize selectedOptions for multi-select wizards
589
+ if (wizard.multiSelect) {
590
+ wizardConfig.selectedOptions = [];
591
+ }
592
+
593
+ // Always refresh available skills when opening SKILL context wizard
594
+ if (wizardId === 'skill-context') {
595
+ await loadAvailableSkills();
596
+ }
597
+
598
+ const modal = document.getElementById('hookWizardModal');
599
+ if (modal) {
600
+ renderWizardModalContent();
601
+ modal.classList.remove('hidden');
602
+ }
603
+ }
604
+
605
+ function closeHookWizardModal() {
606
+ const modal = document.getElementById('hookWizardModal');
607
+ if (modal) {
608
+ modal.classList.add('hidden');
609
+ currentWizardTemplate = null;
610
+ wizardConfig = {};
611
+ }
612
+ }
613
+
614
+ function renderWizardModalContent() {
615
+ const container = document.getElementById('wizardModalContent');
616
+ if (!container || !currentWizardTemplate) return;
617
+
618
+ const wizard = currentWizardTemplate;
619
+ const wizardId = wizard.id;
620
+ const selectedOption = wizardConfig.triggerType || wizard.options[0].id;
621
+
622
+ // Get translated wizard name and description
623
+ const wizardName = wizardId === 'memory-update' ? t('hook.wizard.memoryUpdate') :
624
+ wizardId === 'memory-setup' ? t('hook.wizard.memorySetup') :
625
+ wizardId === 'skill-context' ? t('hook.wizard.skillContext') : wizard.name;
626
+ const wizardDesc = wizardId === 'memory-update' ? t('hook.wizard.memoryUpdateDesc') :
627
+ wizardId === 'memory-setup' ? t('hook.wizard.memorySetupDesc') :
628
+ wizardId === 'skill-context' ? t('hook.wizard.skillContextDesc') : wizard.description;
629
+
630
+ // Helper to get translated option names
631
+ const getOptionName = (optId) => {
632
+ if (wizardId === 'memory-update') {
633
+ if (optId === 'on-stop') return t('hook.wizard.onSessionEnd');
634
+ if (optId === 'periodic') return t('hook.wizard.periodicUpdate');
635
+ if (optId === 'count-based') return t('hook.wizard.countBasedUpdate');
636
+ }
637
+ if (wizardId === 'memory-setup') {
638
+ if (optId === 'file-read') return t('hook.wizard.fileReadTracker');
639
+ if (optId === 'file-write') return t('hook.wizard.fileWriteTracker');
640
+ if (optId === 'prompts') return t('hook.wizard.promptTracker');
641
+ }
642
+ if (wizardId === 'skill-context') {
643
+ if (optId === 'keyword') return t('hook.wizard.keywordMatching');
644
+ if (optId === 'auto') return t('hook.wizard.autoDetection');
645
+ }
646
+ return wizard.options.find(o => o.id === optId)?.name || '';
647
+ };
648
+
649
+ const getOptionDesc = (optId) => {
650
+ if (wizardId === 'memory-update') {
651
+ if (optId === 'on-stop') return t('hook.wizard.onSessionEndDesc');
652
+ if (optId === 'periodic') return t('hook.wizard.periodicUpdateDesc');
653
+ if (optId === 'count-based') return t('hook.wizard.countBasedUpdateDesc');
654
+ }
655
+ if (wizardId === 'memory-setup') {
656
+ if (optId === 'file-read') return t('hook.wizard.fileReadTrackerDesc');
657
+ if (optId === 'file-write') return t('hook.wizard.fileWriteTrackerDesc');
658
+ if (optId === 'prompts') return t('hook.wizard.promptTrackerDesc');
659
+ }
660
+ if (wizardId === 'skill-context') {
661
+ if (optId === 'keyword') return t('hook.wizard.keywordMatchingDesc');
662
+ if (optId === 'auto') return t('hook.wizard.autoDetectionDesc');
663
+ }
664
+ return wizard.options.find(o => o.id === optId)?.description || '';
665
+ };
666
+
667
+ // Helper to get translated field labels
668
+ const getFieldLabel = (fieldKey) => {
669
+ const labels = {
670
+ 'tool': t('hook.wizard.cliTool'),
671
+ 'interval': t('hook.wizard.intervalSeconds'),
672
+ 'threshold': t('hook.wizard.fileCountThreshold'),
673
+ 'strategy': t('hook.wizard.updateStrategy')
674
+ };
675
+ return labels[fieldKey] || wizard.configFields.find(f => f.key === fieldKey)?.label || fieldKey;
676
+ };
677
+
678
+ const getFieldDesc = (fieldKey) => {
679
+ const descs = {
680
+ 'tool': t('hook.wizard.toolForDocGen'),
681
+ 'interval': t('hook.wizard.timeBetweenUpdates'),
682
+ 'threshold': t('hook.wizard.fileCountThresholdDesc'),
683
+ 'strategy': t('hook.wizard.relatedStrategy')
684
+ };
685
+ return descs[fieldKey] || wizard.configFields.find(f => f.key === fieldKey)?.description || '';
686
+ };
687
+
688
+ container.innerHTML = `
689
+ <div class="space-y-6">
690
+ <!-- Wizard Header -->
691
+ <div class="flex items-center gap-3 pb-4 border-b border-border">
692
+ <div class="p-2 bg-primary/10 rounded-lg">
693
+ <i data-lucide="${wizard.icon}" class="w-6 h-6 text-primary"></i>
694
+ </div>
695
+ <div>
696
+ <h3 class="text-lg font-semibold text-foreground">${escapeHtml(wizardName)}</h3>
697
+ <p class="text-sm text-muted-foreground">${escapeHtml(wizardDesc)}</p>
698
+ </div>
699
+ </div>
700
+
701
+ <!-- Trigger Type Selection -->
702
+ <div class="space-y-3">
703
+ <label class="block text-sm font-medium text-foreground">${wizard.multiSelect ? t('hook.wizard.selectTrackers') : t('hook.wizard.whenToTrigger')}</label>
704
+ <div class="grid grid-cols-1 gap-3">
705
+ ${wizard.multiSelect ? wizard.options.map(opt => {
706
+ const isSelected = wizardConfig.selectedOptions?.includes(opt.id) || false;
707
+ return `
708
+ <label class="flex items-start gap-3 p-3 border rounded-lg cursor-pointer transition-all ${isSelected ? 'border-primary bg-primary/5' : 'border-border hover:border-muted-foreground'}">
709
+ <input type="checkbox" name="wizardTrigger" value="${opt.id}"
710
+ ${isSelected ? 'checked' : ''}
711
+ onchange="toggleWizardOption('${opt.id}')"
712
+ class="mt-1">
713
+ <div class="flex-1">
714
+ <span class="font-medium text-foreground">${escapeHtml(getOptionName(opt.id))}</span>
715
+ <p class="text-sm text-muted-foreground">${escapeHtml(getOptionDesc(opt.id))}</p>
716
+ </div>
717
+ </label>
718
+ `;
719
+ }).join('') : wizard.options.map(opt => `
720
+ <label class="flex items-start gap-3 p-3 border rounded-lg cursor-pointer transition-all ${selectedOption === opt.id ? 'border-primary bg-primary/5' : 'border-border hover:border-muted-foreground'}">
721
+ <input type="radio" name="wizardTrigger" value="${opt.id}"
722
+ ${selectedOption === opt.id ? 'checked' : ''}
723
+ onchange="updateWizardTrigger('${opt.id}')"
724
+ class="mt-1">
725
+ <div class="flex-1">
726
+ <span class="font-medium text-foreground">${escapeHtml(getOptionName(opt.id))}</span>
727
+ <p class="text-sm text-muted-foreground">${escapeHtml(getOptionDesc(opt.id))}</p>
728
+ </div>
729
+ </label>
730
+ `).join('')}
731
+ </div>
732
+ </div>
733
+
734
+ <!-- Configuration Fields -->
735
+ <div class="space-y-4">
736
+ <label class="block text-sm font-medium text-foreground">${t('hook.wizard.configuration')}</label>
737
+ ${wizard.customRenderer ? window[wizard.customRenderer]() : wizard.configFields.map(field => {
738
+ // Check if field should be shown for current trigger type
739
+ const shouldShow = !field.showFor || field.showFor.includes(selectedOption);
740
+ if (!shouldShow) return '';
741
+
742
+ const value = wizardConfig[field.key] ?? field.default;
743
+ const fieldLabel = getFieldLabel(field.key);
744
+ const fieldDesc = getFieldDesc(field.key);
745
+
746
+ if (field.type === 'select') {
747
+ return `
748
+ <div class="space-y-1">
749
+ <label class="block text-sm text-muted-foreground">${escapeHtml(fieldLabel)}</label>
750
+ <select id="wizard_${field.key}"
751
+ onchange="updateWizardConfig('${field.key}', this.value)"
752
+ class="w-full px-3 py-2 bg-background border border-border rounded-lg text-foreground focus:outline-none focus:ring-2 focus:ring-primary">
753
+ ${field.options.map(opt => `
754
+ <option value="${opt}" ${value === opt ? 'selected' : ''}>${opt}</option>
755
+ `).join('')}
756
+ </select>
757
+ ${fieldDesc ? `<p class="text-xs text-muted-foreground">${escapeHtml(fieldDesc)}</p>` : ''}
758
+ </div>
759
+ `;
760
+ } else if (field.type === 'number') {
761
+ return `
762
+ <div class="space-y-1">
763
+ <label class="block text-sm text-muted-foreground">${escapeHtml(fieldLabel)}</label>
764
+ <div class="flex items-center gap-2">
765
+ <input type="number" id="wizard_${field.key}"
766
+ value="${value}"
767
+ min="${field.min || 0}"
768
+ max="${field.max || 9999}"
769
+ step="${field.step || 1}"
770
+ onchange="updateWizardConfig('${field.key}', parseInt(this.value))"
771
+ class="flex-1 px-3 py-2 bg-background border border-border rounded-lg text-foreground focus:outline-none focus:ring-2 focus:ring-primary">
772
+ <span class="text-sm text-muted-foreground">${formatIntervalDisplay(value)}</span>
773
+ </div>
774
+ ${fieldDesc ? `<p class="text-xs text-muted-foreground">${escapeHtml(fieldDesc)}</p>` : ''}
775
+ </div>
776
+ `;
777
+ }
778
+ return '';
779
+ }).join('')}
780
+ </div>
781
+
782
+ <!-- Preview -->
783
+ <div class="space-y-2">
784
+ <label class="block text-sm font-medium text-foreground">${t('hook.wizard.commandPreview')}</label>
785
+ <div class="bg-muted/50 rounded-lg p-3 font-mono text-xs overflow-x-auto">
786
+ <pre id="wizardCommandPreview" class="whitespace-pre-wrap text-muted-foreground">${escapeHtml(generateWizardCommand())}</pre>
787
+ </div>
788
+ </div>
789
+
790
+ <!-- Scope Selection -->
791
+ <div class="space-y-3">
792
+ <label class="block text-sm font-medium text-foreground">${t('hook.wizard.installTo')}</label>
793
+ <div class="flex gap-4">
794
+ <label class="flex items-center gap-2 cursor-pointer">
795
+ <input type="radio" name="wizardScope" value="project" checked>
796
+ <span class="text-sm text-foreground">${t('hook.scopeProject').split('(')[0]}</span>
797
+ <span class="text-xs text-muted-foreground">(.claude/settings.json)</span>
798
+ </label>
799
+ <label class="flex items-center gap-2 cursor-pointer">
800
+ <input type="radio" name="wizardScope" value="global">
801
+ <span class="text-sm text-foreground">${t('hook.scopeGlobal').split('(')[0]}</span>
802
+ <span class="text-xs text-muted-foreground">(~/.claude/settings.json)</span>
803
+ </label>
804
+ </div>
805
+ </div>
806
+ </div>
807
+ `;
808
+
809
+ // Initialize Lucide icons
810
+ if (typeof lucide !== 'undefined') lucide.createIcons();
811
+ }
812
+
813
+ function updateWizardTrigger(triggerId) {
814
+ wizardConfig.triggerType = triggerId;
815
+ renderWizardModalContent();
816
+ }
817
+
818
+ function toggleWizardOption(optionId) {
819
+ if (!wizardConfig.selectedOptions) {
820
+ wizardConfig.selectedOptions = [];
821
+ }
822
+
823
+ const index = wizardConfig.selectedOptions.indexOf(optionId);
824
+ if (index === -1) {
825
+ wizardConfig.selectedOptions.push(optionId);
826
+ } else {
827
+ wizardConfig.selectedOptions.splice(index, 1);
828
+ }
829
+
830
+ renderWizardModalContent();
831
+ }
832
+
833
+ function updateWizardConfig(key, value) {
834
+ wizardConfig[key] = value;
835
+ // Update command preview
836
+ const preview = document.getElementById('wizardCommandPreview');
837
+ if (preview) {
838
+ preview.textContent = generateWizardCommand();
839
+ }
840
+ // Re-render if interval changed (to update display)
841
+ if (key === 'interval') {
842
+ const displaySpan = document.querySelector(`#wizard_${key}`)?.parentElement?.querySelector('.text-muted-foreground:last-child');
843
+ if (displaySpan) {
844
+ displaySpan.textContent = formatIntervalDisplay(value);
845
+ }
846
+ }
847
+ }
848
+
849
+ function formatIntervalDisplay(seconds) {
850
+ if (seconds < 60) return `${seconds}s`;
851
+ const mins = Math.floor(seconds / 60);
852
+ const secs = seconds % 60;
853
+ if (secs === 0) return `${mins}min`;
854
+ return `${mins}min ${secs}s`;
855
+ }
856
+
857
+ // ========== SKILL Context Wizard Custom Functions ==========
858
+ function renderSkillContextConfig() {
859
+ const selectedOption = wizardConfig.triggerType || 'keyword';
860
+ const skillConfigs = wizardConfig.skillConfigs || [];
861
+ const availableSkills = window.availableSkills || [];
862
+
863
+ if (selectedOption === 'auto') {
864
+ let skillBadges = '';
865
+ let isLoading = typeof window.availableSkills === 'undefined' || window.skillsLoading;
866
+ if (isLoading) {
867
+ // Still loading
868
+ skillBadges = '<span class="px-1.5 py-0.5 bg-muted text-muted-foreground rounded text-xs">' + t('common.loading') + '...</span>';
869
+ } else if (availableSkills.length === 0) {
870
+ // No skills found
871
+ skillBadges = '<span class="px-1.5 py-0.5 bg-warning/10 text-warning rounded text-xs">' + t('hook.wizard.noSkillsFound') + '</span>';
872
+ } else {
873
+ // Skills found
874
+ skillBadges = availableSkills.map(function(s) {
875
+ return '<span class="px-1.5 py-0.5 bg-emerald-500/10 text-emerald-500 rounded text-xs">' + escapeHtml(s.name) + '</span>';
876
+ }).join(' ');
877
+ }
878
+ return '<div class="bg-muted/30 rounded-lg p-4 text-sm text-muted-foreground">' +
879
+ '<div class="flex items-center justify-between mb-2">' +
880
+ '<div class="flex items-center gap-2">' +
881
+ '<i data-lucide="info" class="w-4 h-4"></i>' +
882
+ '<span class="font-medium">' + t('hook.wizard.autoDetectionMode') + '</span>' +
883
+ '</div>' +
884
+ '<button type="button" onclick="refreshAvailableSkills()" ' +
885
+ 'class="p-1.5 text-muted-foreground hover:text-primary hover:bg-primary/10 rounded transition-colors" ' +
886
+ 'title="' + t('common.refresh') + '">' +
887
+ '<i data-lucide="refresh-cw" class="w-4 h-4' + (isLoading ? ' animate-spin' : '') + '"></i>' +
888
+ '</button>' +
889
+ '</div>' +
890
+ '<p>' + t('hook.wizard.autoDetectionInfo') + '</p>' +
891
+ '<div class="mt-2 flex items-center gap-2 flex-wrap">' +
892
+ '<span>' + t('hook.wizard.availableSkills') + '</span>' +
893
+ skillBadges +
894
+ '</div>' +
895
+ '</div>';
896
+ }
897
+
898
+ var configListHtml = '';
899
+ if (skillConfigs.length === 0) {
900
+ configListHtml = '<div class="text-center py-6 text-muted-foreground text-sm border border-dashed border-border rounded-lg">' +
901
+ '<i data-lucide="package" class="w-8 h-8 mx-auto mb-2 opacity-50"></i>' +
902
+ '<p>' + t('hook.wizard.noSkillsConfigured') + '</p>' +
903
+ '<p class="text-xs mt-1">' + t('hook.wizard.clickAddSkill') + '</p>' +
904
+ '</div>';
905
+ } else {
906
+ configListHtml = skillConfigs.map(function(config, idx) {
907
+ var skillOptions = '';
908
+ if (availableSkills.length === 0) {
909
+ skillOptions = '<option value="" disabled>' + t('hook.wizard.noSkillsFound') + '</option>';
910
+ } else {
911
+ skillOptions = availableSkills.map(function(s) {
912
+ var selected = config.skill === s.name ? 'selected' : '';
913
+ return '<option value="' + escapeHtml(s.name) + '" ' + selected + '>' + escapeHtml(s.name) + '</option>';
914
+ }).join('');
915
+ }
916
+ return '<div class="border border-border rounded-lg p-3 bg-card">' +
917
+ '<div class="flex items-center justify-between mb-2">' +
918
+ '<select onchange="updateSkillConfig(' + idx + ', \'skill\', this.value)" ' +
919
+ 'class="px-2 py-1 text-sm bg-background border border-border rounded text-foreground">' +
920
+ '<option value="">' + t('hook.wizard.selectSkill') + '</option>' +
921
+ skillOptions +
922
+ '</select>' +
923
+ '<button onclick="removeSkillConfig(' + idx + ')" ' +
924
+ 'class="p-1 text-muted-foreground hover:text-destructive rounded">' +
925
+ '<i data-lucide="trash-2" class="w-4 h-4"></i>' +
926
+ '</button>' +
927
+ '</div>' +
928
+ '<div class="space-y-1">' +
929
+ '<label class="text-xs text-muted-foreground">' + t('hook.wizard.triggerKeywords') + '</label>' +
930
+ '<input type="text" ' +
931
+ 'value="' + (config.keywords || '') + '" ' +
932
+ 'onchange="updateSkillConfig(' + idx + ', \'keywords\', this.value)" ' +
933
+ 'placeholder="e.g., react, hooks, component" ' +
934
+ 'class="w-full px-2 py-1.5 text-sm bg-background border border-border rounded text-foreground">' +
935
+ '</div>' +
936
+ '</div>';
937
+ }).join('');
938
+ }
939
+
940
+ var isLoading = typeof window.availableSkills === 'undefined' || window.skillsLoading;
941
+ var skillsStatusHtml = '';
942
+ if (isLoading) {
943
+ skillsStatusHtml = '<span class="text-xs text-muted-foreground flex items-center gap-1">' +
944
+ '<i data-lucide="loader-2" class="w-3 h-3 animate-spin"></i>' +
945
+ t('common.loading') +
946
+ '</span>';
947
+ } else if (availableSkills.length === 0) {
948
+ skillsStatusHtml = '<span class="text-xs text-amber-500 flex items-center gap-1">' +
949
+ '<i data-lucide="alert-triangle" class="w-3 h-3"></i>' +
950
+ t('hook.wizard.noSkillsFound') +
951
+ '</span>';
952
+ } else {
953
+ skillsStatusHtml = '<span class="text-xs text-muted-foreground">' +
954
+ availableSkills.length + ' ' + t('skills.skillsCount') +
955
+ '</span>';
956
+ }
957
+
958
+ return '<div class="space-y-4">' +
959
+ '<div class="flex items-center justify-between">' +
960
+ '<div class="flex items-center gap-2">' +
961
+ '<span class="text-sm font-medium text-foreground">' + t('hook.wizard.configureSkills') + '</span>' +
962
+ skillsStatusHtml +
963
+ '<button type="button" onclick="refreshAvailableSkills()" ' +
964
+ 'class="p-1 text-muted-foreground hover:text-primary hover:bg-primary/10 rounded transition-colors" ' +
965
+ 'title="' + t('common.refresh') + '">' +
966
+ '<i data-lucide="refresh-cw" class="w-3 h-3' + (isLoading ? ' animate-spin' : '') + '"></i>' +
967
+ '</button>' +
968
+ '</div>' +
969
+ '<button type="button" onclick="addSkillConfig()" ' +
970
+ 'class="px-3 py-1.5 text-xs bg-primary text-primary-foreground rounded-lg hover:opacity-90 flex items-center gap-1">' +
971
+ '<i data-lucide="plus" class="w-3 h-3"></i> ' + t('hook.wizard.addSkill') +
972
+ '</button>' +
973
+ '</div>' +
974
+ '<div id="skillConfigsList" class="space-y-3">' + configListHtml + '</div>' +
975
+ '</div>';
976
+ }
977
+
978
+ async function refreshAvailableSkills() {
979
+ // Set loading state
980
+ window.skillsLoading = true;
981
+ renderWizardModalContent();
982
+
983
+ try {
984
+ await loadAvailableSkills();
985
+ } finally {
986
+ window.skillsLoading = false;
987
+ renderWizardModalContent();
988
+ // Refresh Lucide icons
989
+ if (typeof lucide !== 'undefined') lucide.createIcons();
990
+ }
991
+ }
992
+
993
+ function addSkillConfig() {
994
+ if (!wizardConfig.skillConfigs) {
995
+ wizardConfig.skillConfigs = [];
996
+ }
997
+ wizardConfig.skillConfigs.push({ skill: '', keywords: '' });
998
+ renderWizardModalContent();
999
+ }
1000
+
1001
+ function removeSkillConfig(index) {
1002
+ if (wizardConfig.skillConfigs) {
1003
+ wizardConfig.skillConfigs.splice(index, 1);
1004
+ renderWizardModalContent();
1005
+ }
1006
+ }
1007
+
1008
+ function updateSkillConfig(index, key, value) {
1009
+ if (wizardConfig.skillConfigs && wizardConfig.skillConfigs[index]) {
1010
+ wizardConfig.skillConfigs[index][key] = value;
1011
+ const preview = document.getElementById('wizardCommandPreview');
1012
+ if (preview) {
1013
+ preview.textContent = generateWizardCommand();
1014
+ }
1015
+ }
1016
+ }
1017
+
1018
+
1019
+
1020
+ function generateWizardCommand() {
1021
+ if (!currentWizardTemplate) return '';
1022
+
1023
+ const wizard = currentWizardTemplate;
1024
+ const wizardId = wizard.id;
1025
+ const triggerType = wizardConfig.triggerType || wizard.options[0].id;
1026
+ const selectedOption = wizard.options.find(o => o.id === triggerType);
1027
+ if (!selectedOption) return '';
1028
+
1029
+ const baseTemplate = HOOK_TEMPLATES[selectedOption.templateId];
1030
+ if (!baseTemplate) return '';
1031
+
1032
+ // Handle skill-context wizard
1033
+ if (wizardId === 'skill-context') {
1034
+ if (triggerType === 'keyword') {
1035
+ const skillConfigs = wizardConfig.skillConfigs || [];
1036
+ const validConfigs = skillConfigs.filter(c => c.skill && c.keywords);
1037
+
1038
+ if (validConfigs.length === 0) {
1039
+ return '# No SKILL configurations yet';
1040
+ }
1041
+
1042
+ const configJson = validConfigs.map(c => ({
1043
+ skill: c.skill,
1044
+ keywords: c.keywords.split(',').map(k => k.trim()).filter(k => k)
1045
+ }));
1046
+
1047
+ const params = JSON.stringify({ configs: configJson, prompt: '$CLAUDE_PROMPT' });
1048
+ return `ccw tool exec skill_context_loader '${params}'`;
1049
+ } else {
1050
+ // auto mode
1051
+ const params = JSON.stringify({ mode: 'auto', prompt: '$CLAUDE_PROMPT' });
1052
+ return `ccw tool exec skill_context_loader '${params}'`;
1053
+ }
1054
+ }
1055
+
1056
+ // Handle memory-update wizard (default)
1057
+ const tool = wizardConfig.tool || 'gemini';
1058
+ const strategy = wizardConfig.strategy || 'related';
1059
+ const interval = wizardConfig.interval || 300;
1060
+ const threshold = wizardConfig.threshold || 10;
1061
+
1062
+ // Build the ccw tool command based on configuration
1063
+ const params = JSON.stringify({ strategy, tool });
1064
+
1065
+ if (triggerType === 'periodic') {
1066
+ return `INTERVAL=${interval}; LAST_FILE=~/.claude/.last_memory_update; NOW=$(date +%s); LAST=0; [ -f "$LAST_FILE" ] && LAST=$(cat "$LAST_FILE"); if [ $((NOW - LAST)) -ge $INTERVAL ]; then echo $NOW > "$LAST_FILE"; ccw tool exec update_module_claude '${params}' & fi`;
1067
+ } else if (triggerType === 'count-based') {
1068
+ return `THRESHOLD=${threshold}; COUNT_FILE=~/.claude/.memory_update_count; INPUT=$(cat); FILE_PATH=$(echo "$INPUT" | jq -r ".tool_input.file_path // .tool_input.path // empty"); [ -z "$FILE_PATH" ] && exit 0; COUNT=0; [ -f "$COUNT_FILE" ] && COUNT=$(cat "$COUNT_FILE" 2>/dev/null || echo 0); COUNT=$((COUNT + 1)); echo $COUNT > "$COUNT_FILE"; if [ $COUNT -ge $THRESHOLD ]; then echo 0 > "$COUNT_FILE"; ccw tool exec update_module_claude '${params}' & fi`;
1069
+ } else {
1070
+ return `ccw tool exec update_module_claude '${params}'`;
1071
+ }
1072
+ }
1073
+
1074
+ async function submitHookWizard() {
1075
+ if (!currentWizardTemplate) return;
1076
+
1077
+ const wizard = currentWizardTemplate;
1078
+ const scope = document.querySelector('input[name="wizardScope"]:checked')?.value || 'project';
1079
+
1080
+ // Handle multi-select wizards
1081
+ if (wizard.multiSelect) {
1082
+ const selectedOptions = wizardConfig.selectedOptions || [];
1083
+ if (selectedOptions.length === 0) {
1084
+ showRefreshToast('Please select at least one option', 'error');
1085
+ return;
1086
+ }
1087
+
1088
+ // Install each selected hook (skip if already exists)
1089
+ let installedCount = 0;
1090
+ let skippedCount = 0;
1091
+
1092
+ for (const optionId of selectedOptions) {
1093
+ const selectedOption = wizard.options.find(o => o.id === optionId);
1094
+ if (!selectedOption) continue;
1095
+
1096
+ const baseTemplate = HOOK_TEMPLATES[selectedOption.templateId];
1097
+ if (!baseTemplate) continue;
1098
+
1099
+ // Check if hook already exists
1100
+ const existingHooks = scope === 'global'
1101
+ ? hookConfig.global?.hooks?.[baseTemplate.event] || []
1102
+ : hookConfig.project?.hooks?.[baseTemplate.event] || [];
1103
+
1104
+ const hookList = Array.isArray(existingHooks) ? existingHooks : [existingHooks];
1105
+ const alreadyExists = hookList.some(h => {
1106
+ // Check by matcher and command
1107
+ const existingMatcher = h.matcher || '';
1108
+ const templateMatcher = baseTemplate.matcher || '';
1109
+ const existingCmd = h.hooks?.[0]?.command || h.command || '';
1110
+ const templateCmd = baseTemplate.command + ' ' + (baseTemplate.args || []).join(' ');
1111
+ return existingMatcher === templateMatcher && existingCmd.includes(baseTemplate.command);
1112
+ });
1113
+
1114
+ if (alreadyExists) {
1115
+ skippedCount++;
1116
+ continue;
1117
+ }
1118
+
1119
+ const hookData = {
1120
+ command: baseTemplate.command,
1121
+ args: baseTemplate.args
1122
+ };
1123
+
1124
+ if (baseTemplate.matcher) {
1125
+ hookData.matcher = baseTemplate.matcher;
1126
+ }
1127
+
1128
+ if (baseTemplate.timeout) {
1129
+ hookData.timeout = baseTemplate.timeout;
1130
+ }
1131
+
1132
+ await saveHook(scope, baseTemplate.event, hookData);
1133
+ installedCount++;
1134
+ }
1135
+
1136
+ closeHookWizardModal();
1137
+
1138
+ if (skippedCount > 0 && installedCount === 0) {
1139
+ showRefreshToast(`All ${skippedCount} hook(s) already installed`, 'info');
1140
+ } else if (skippedCount > 0) {
1141
+ showRefreshToast(`Installed ${installedCount}, skipped ${skippedCount} (already exists)`, 'success');
1142
+ }
1143
+ return;
1144
+ }
1145
+
1146
+ // Handle single-select wizards
1147
+ const triggerType = wizardConfig.triggerType || wizard.options[0].id;
1148
+ const selectedOption = wizard.options.find(o => o.id === triggerType);
1149
+ if (!selectedOption) return;
1150
+
1151
+ const baseTemplate = HOOK_TEMPLATES[selectedOption.templateId];
1152
+ if (!baseTemplate) return;
1153
+
1154
+ const command = generateWizardCommand();
1155
+
1156
+ const hookData = {
1157
+ command: 'bash',
1158
+ args: ['-c', command]
1159
+ };
1160
+
1161
+ if (baseTemplate.matcher) {
1162
+ hookData.matcher = baseTemplate.matcher;
1163
+ }
1164
+
1165
+ await saveHook(scope, baseTemplate.event, hookData);
1166
+ closeHookWizardModal();
1167
+ }
1168
+
1169
+ // ========== Template View/Copy Functions ==========
1170
+ function viewTemplateDetails(templateId) {
1171
+ const template = HOOK_TEMPLATES[templateId];
1172
+ if (!template) return;
1173
+
1174
+ const modal = document.getElementById('templateViewModal');
1175
+ const content = document.getElementById('templateViewContent');
1176
+
1177
+ if (modal && content) {
1178
+ const args = template.args || [];
1179
+ content.innerHTML = `
1180
+ <div class="space-y-4">
1181
+ <div class="flex items-center gap-3 pb-3 border-b border-border">
1182
+ <i data-lucide="webhook" class="w-5 h-5 text-primary"></i>
1183
+ <div>
1184
+ <h4 class="font-semibold text-foreground">${escapeHtml(templateId)}</h4>
1185
+ <p class="text-sm text-muted-foreground">${escapeHtml(template.description || 'No description')}</p>
1186
+ </div>
1187
+ </div>
1188
+
1189
+ <div class="space-y-3 text-sm">
1190
+ <div class="flex items-start gap-2">
1191
+ <span class="font-mono text-xs bg-muted px-1.5 py-0.5 rounded shrink-0 w-16">Event</span>
1192
+ <span class="font-medium text-foreground">${escapeHtml(template.event)}</span>
1193
+ </div>
1194
+ <div class="flex items-start gap-2">
1195
+ <span class="font-mono text-xs bg-muted px-1.5 py-0.5 rounded shrink-0 w-16">Matcher</span>
1196
+ <span class="text-muted-foreground">${escapeHtml(template.matcher || 'All tools')}</span>
1197
+ </div>
1198
+ <div class="flex items-start gap-2">
1199
+ <span class="font-mono text-xs bg-muted px-1.5 py-0.5 rounded shrink-0 w-16">Command</span>
1200
+ <code class="font-mono text-xs text-foreground">${escapeHtml(template.command)}</code>
1201
+ </div>
1202
+ ${args.length > 0 ? `
1203
+ <div class="flex items-start gap-2">
1204
+ <span class="font-mono text-xs bg-muted px-1.5 py-0.5 rounded shrink-0 w-16">Args</span>
1205
+ <div class="flex-1">
1206
+ <pre class="font-mono text-xs text-muted-foreground bg-muted/50 rounded p-2 overflow-x-auto whitespace-pre-wrap">${escapeHtml(args.join('\n'))}</pre>
1207
+ </div>
1208
+ </div>
1209
+ ` : ''}
1210
+ ${template.category ? `
1211
+ <div class="flex items-start gap-2">
1212
+ <span class="font-mono text-xs bg-muted px-1.5 py-0.5 rounded shrink-0 w-16">Category</span>
1213
+ <span class="px-2 py-0.5 text-xs rounded-full bg-primary/10 text-primary">${escapeHtml(template.category)}</span>
1214
+ </div>
1215
+ ` : ''}
1216
+ </div>
1217
+
1218
+ <div class="flex gap-2 pt-3 border-t border-border">
1219
+ <button class="flex-1 px-3 py-2 text-sm bg-primary text-primary-foreground rounded-lg hover:opacity-90 transition-opacity"
1220
+ onclick="copyTemplateToClipboard('${templateId}')">
1221
+ <i data-lucide="copy" class="w-4 h-4 inline mr-1"></i> Copy JSON
1222
+ </button>
1223
+ <button class="flex-1 px-3 py-2 text-sm bg-muted text-foreground rounded-lg hover:bg-hover transition-colors"
1224
+ onclick="editTemplateAsNew('${templateId}')">
1225
+ <i data-lucide="pencil" class="w-4 h-4 inline mr-1"></i> Edit as New
1226
+ </button>
1227
+ </div>
1228
+ </div>
1229
+ `;
1230
+
1231
+ modal.classList.remove('hidden');
1232
+ if (typeof lucide !== 'undefined') lucide.createIcons();
1233
+ }
1234
+ }
1235
+
1236
+ function closeTemplateViewModal() {
1237
+ const modal = document.getElementById('templateViewModal');
1238
+ if (modal) {
1239
+ modal.classList.add('hidden');
1240
+ }
1241
+ }
1242
+
1243
+ function copyTemplateToClipboard(templateId) {
1244
+ const template = HOOK_TEMPLATES[templateId];
1245
+ if (!template) return;
1246
+
1247
+ const hookJson = {
1248
+ matcher: template.matcher || undefined,
1249
+ command: template.command,
1250
+ args: template.args
1251
+ };
1252
+
1253
+ // Clean up undefined values
1254
+ Object.keys(hookJson).forEach(key => {
1255
+ if (hookJson[key] === undefined || hookJson[key] === '') {
1256
+ delete hookJson[key];
1257
+ }
1258
+ });
1259
+
1260
+ navigator.clipboard.writeText(JSON.stringify(hookJson, null, 2))
1261
+ .then(() => showRefreshToast('Template copied to clipboard', 'success'))
1262
+ .catch(() => showRefreshToast('Failed to copy', 'error'));
1263
+ }
1264
+
1265
+ function editTemplateAsNew(templateId) {
1266
+ const template = HOOK_TEMPLATES[templateId];
1267
+ if (!template) return;
1268
+
1269
+ closeTemplateViewModal();
1270
+
1271
+ // Open create modal with template data
1272
+ openHookCreateModal({
1273
+ event: template.event,
1274
+ matcher: template.matcher || '',
1275
+ command: template.command,
1276
+ args: template.args || []
1277
+ });
1278
+ }