@macpaw/cctk 1.0.0-beta.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 (415) hide show
  1. package/License +21 -0
  2. package/README.md +142 -0
  3. package/bin/index.js +5 -0
  4. package/dist/index.js +1 -0
  5. package/package.json +65 -0
  6. package/templates/claude/agents/brainstormer.md +113 -0
  7. package/templates/claude/agents/code-reviewer.md +157 -0
  8. package/templates/claude/agents/copywriter.md +110 -0
  9. package/templates/claude/agents/database-admin.md +92 -0
  10. package/templates/claude/agents/debugger.md +137 -0
  11. package/templates/claude/agents/docs-manager.md +208 -0
  12. package/templates/claude/agents/fullstack-developer.md +95 -0
  13. package/templates/claude/agents/git-manager.md +394 -0
  14. package/templates/claude/agents/journal-writer.md +113 -0
  15. package/templates/claude/agents/mcp-manager.md +89 -0
  16. package/templates/claude/agents/planner.md +108 -0
  17. package/templates/claude/agents/project-manager.md +125 -0
  18. package/templates/claude/agents/registry.json +304 -0
  19. package/templates/claude/agents/researcher.md +37 -0
  20. package/templates/claude/agents/scout-external.md +140 -0
  21. package/templates/claude/agents/scout.md +106 -0
  22. package/templates/claude/agents/tester.md +105 -0
  23. package/templates/claude/agents/ui-ux-designer.md +208 -0
  24. package/templates/claude/commands/ask.md +56 -0
  25. package/templates/claude/commands/bootstrap/auto/fast.md +106 -0
  26. package/templates/claude/commands/bootstrap/auto/parallel.md +64 -0
  27. package/templates/claude/commands/bootstrap/auto.md +110 -0
  28. package/templates/claude/commands/bootstrap.md +130 -0
  29. package/templates/claude/commands/brainstorm.md +75 -0
  30. package/templates/claude/commands/code/auto.md +198 -0
  31. package/templates/claude/commands/code/no-test.md +172 -0
  32. package/templates/claude/commands/code/parallel.md +100 -0
  33. package/templates/claude/commands/code.md +197 -0
  34. package/templates/claude/commands/coding-level.md +37 -0
  35. package/templates/claude/commands/content/cro.md +41 -0
  36. package/templates/claude/commands/content/enhance.md +12 -0
  37. package/templates/claude/commands/content/fast.md +11 -0
  38. package/templates/claude/commands/content/good.md +14 -0
  39. package/templates/claude/commands/cook/auto/fast.md +26 -0
  40. package/templates/claude/commands/cook/auto/parallel.md +49 -0
  41. package/templates/claude/commands/cook/auto.md +15 -0
  42. package/templates/claude/commands/cook.md +101 -0
  43. package/templates/claude/commands/debug.md +13 -0
  44. package/templates/claude/commands/docs/init.md +37 -0
  45. package/templates/claude/commands/docs/summarize.md +22 -0
  46. package/templates/claude/commands/docs/update.md +78 -0
  47. package/templates/claude/commands/fix/ci.md +17 -0
  48. package/templates/claude/commands/fix/fast.md +18 -0
  49. package/templates/claude/commands/fix/hard.md +35 -0
  50. package/templates/claude/commands/fix/logs.md +26 -0
  51. package/templates/claude/commands/fix/parallel.md +54 -0
  52. package/templates/claude/commands/fix/test.md +20 -0
  53. package/templates/claude/commands/fix/types.md +9 -0
  54. package/templates/claude/commands/fix/ui.md +33 -0
  55. package/templates/claude/commands/fix.md +43 -0
  56. package/templates/claude/commands/git/cm.md +5 -0
  57. package/templates/claude/commands/git/cp.md +4 -0
  58. package/templates/claude/commands/git/merge.md +40 -0
  59. package/templates/claude/commands/git/pr.md +50 -0
  60. package/templates/claude/commands/journal.md +7 -0
  61. package/templates/claude/commands/kanban.md +99 -0
  62. package/templates/claude/commands/plan/archive.md +57 -0
  63. package/templates/claude/commands/plan/ci.md +33 -0
  64. package/templates/claude/commands/plan/cro.md +67 -0
  65. package/templates/claude/commands/plan/fast.md +66 -0
  66. package/templates/claude/commands/plan/hard.md +92 -0
  67. package/templates/claude/commands/plan/parallel.md +129 -0
  68. package/templates/claude/commands/plan/two.md +45 -0
  69. package/templates/claude/commands/plan/validate.md +117 -0
  70. package/templates/claude/commands/plan.md +30 -0
  71. package/templates/claude/commands/preview.md +87 -0
  72. package/templates/claude/commands/registry.json +313 -0
  73. package/templates/claude/commands/review/codebase/parallel.md +122 -0
  74. package/templates/claude/commands/review/codebase.md +47 -0
  75. package/templates/claude/commands/scout/ext.md +35 -0
  76. package/templates/claude/commands/scout.md +28 -0
  77. package/templates/claude/commands/skill/add.md +36 -0
  78. package/templates/claude/commands/skill/create.md +29 -0
  79. package/templates/claude/commands/skill/fix-logs.md +22 -0
  80. package/templates/claude/commands/skill/optimize/auto.md +25 -0
  81. package/templates/claude/commands/skill/optimize.md +34 -0
  82. package/templates/claude/commands/skill/plan.md +45 -0
  83. package/templates/claude/commands/test/ui.md +91 -0
  84. package/templates/claude/commands/test.md +8 -0
  85. package/templates/claude/commands/use-mcp.md +34 -0
  86. package/templates/claude/commands/watzup.md +8 -0
  87. package/templates/claude/commands/worktree.md +126 -0
  88. package/templates/claude/hooks/dev-rules-reminder.cjs +258 -0
  89. package/templates/claude/hooks/docs/README.md +42 -0
  90. package/templates/claude/hooks/lib/cctk-config-utils.cjs +751 -0
  91. package/templates/claude/hooks/lib/cctk-paths.cjs +106 -0
  92. package/templates/claude/hooks/lib/context-tracker.cjs +346 -0
  93. package/templates/claude/hooks/privacy-block.cjs +289 -0
  94. package/templates/claude/hooks/registry.json +77 -0
  95. package/templates/claude/hooks/scout-block/broad-pattern-detector.cjs +293 -0
  96. package/templates/claude/hooks/scout-block/error-formatter.cjs +156 -0
  97. package/templates/claude/hooks/scout-block/path-extractor.cjs +359 -0
  98. package/templates/claude/hooks/scout-block/pattern-matcher.cjs +184 -0
  99. package/templates/claude/hooks/scout-block/vendor/ignore.js +626 -0
  100. package/templates/claude/hooks/scout-block.cjs +167 -0
  101. package/templates/claude/hooks/session-end.cjs +35 -0
  102. package/templates/claude/hooks/session-init.cjs +214 -0
  103. package/templates/claude/hooks/subagent-init.cjs +161 -0
  104. package/templates/claude/hooks/write-compact-marker.cjs +153 -0
  105. package/templates/claude/output-styles/coding-level-1.md +148 -0
  106. package/templates/claude/output-styles/coding-level-2.md +159 -0
  107. package/templates/claude/output-styles/coding-level-3.md +91 -0
  108. package/templates/claude/scripts/README.md +33 -0
  109. package/templates/claude/scripts/generate-catalogs.cjs +318 -0
  110. package/templates/claude/scripts/registry.json +48 -0
  111. package/templates/claude/scripts/set-active-plan.cjs +45 -0
  112. package/templates/claude/scripts/validate-docs.cjs +447 -0
  113. package/templates/claude/scripts/worktree.cjs +658 -0
  114. package/templates/claude/skills/README.md +112 -0
  115. package/templates/claude/skills/ai-artist/SKILL.md +75 -0
  116. package/templates/claude/skills/ai-artist/references/advanced-techniques.md +184 -0
  117. package/templates/claude/skills/ai-artist/references/domain-code.md +66 -0
  118. package/templates/claude/skills/ai-artist/references/domain-data.md +72 -0
  119. package/templates/claude/skills/ai-artist/references/domain-marketing.md +66 -0
  120. package/templates/claude/skills/ai-artist/references/domain-patterns.md +33 -0
  121. package/templates/claude/skills/ai-artist/references/domain-writing.md +68 -0
  122. package/templates/claude/skills/ai-artist/references/image-prompting.md +141 -0
  123. package/templates/claude/skills/ai-artist/references/llm-prompting.md +165 -0
  124. package/templates/claude/skills/ai-artist/references/nano-banana.md +59 -0
  125. package/templates/claude/skills/ai-artist/references/reasoning-techniques.md +201 -0
  126. package/templates/claude/skills/backend-development/SKILL.md +95 -0
  127. package/templates/claude/skills/backend-development/references/backend-api-design.md +495 -0
  128. package/templates/claude/skills/backend-development/references/backend-architecture.md +454 -0
  129. package/templates/claude/skills/backend-development/references/backend-authentication.md +338 -0
  130. package/templates/claude/skills/backend-development/references/backend-code-quality.md +659 -0
  131. package/templates/claude/skills/backend-development/references/backend-debugging.md +904 -0
  132. package/templates/claude/skills/backend-development/references/backend-devops.md +494 -0
  133. package/templates/claude/skills/backend-development/references/backend-mindset.md +387 -0
  134. package/templates/claude/skills/backend-development/references/backend-performance.md +397 -0
  135. package/templates/claude/skills/backend-development/references/backend-security.md +290 -0
  136. package/templates/claude/skills/backend-development/references/backend-technologies.md +256 -0
  137. package/templates/claude/skills/backend-development/references/backend-testing.md +429 -0
  138. package/templates/claude/skills/better-auth/SKILL.md +204 -0
  139. package/templates/claude/skills/better-auth/references/advanced-features.md +553 -0
  140. package/templates/claude/skills/better-auth/references/database-integration.md +577 -0
  141. package/templates/claude/skills/better-auth/references/email-password-auth.md +416 -0
  142. package/templates/claude/skills/better-auth/references/oauth-providers.md +430 -0
  143. package/templates/claude/skills/better-auth/scripts/better_auth_init.py +521 -0
  144. package/templates/claude/skills/chrome-devtools/SKILL.md +473 -0
  145. package/templates/claude/skills/chrome-devtools/references/cdp-domains.md +694 -0
  146. package/templates/claude/skills/chrome-devtools/references/performance-guide.md +940 -0
  147. package/templates/claude/skills/chrome-devtools/references/puppeteer-reference.md +953 -0
  148. package/templates/claude/skills/chrome-devtools/scripts/README.md +288 -0
  149. package/templates/claude/skills/chrome-devtools/scripts/aria-snapshot.js +368 -0
  150. package/templates/claude/skills/chrome-devtools/scripts/click.js +92 -0
  151. package/templates/claude/skills/chrome-devtools/scripts/console.js +85 -0
  152. package/templates/claude/skills/chrome-devtools/scripts/evaluate.js +59 -0
  153. package/templates/claude/skills/chrome-devtools/scripts/fill.js +84 -0
  154. package/templates/claude/skills/chrome-devtools/scripts/inject-auth.js +247 -0
  155. package/templates/claude/skills/chrome-devtools/scripts/install-deps.sh +11 -0
  156. package/templates/claude/skills/chrome-devtools/scripts/install.sh +36 -0
  157. package/templates/claude/skills/chrome-devtools/scripts/lib/browser.js +335 -0
  158. package/templates/claude/skills/chrome-devtools/scripts/lib/selector.js +183 -0
  159. package/templates/claude/skills/chrome-devtools/scripts/navigate.js +60 -0
  160. package/templates/claude/skills/chrome-devtools/scripts/network.js +113 -0
  161. package/templates/claude/skills/chrome-devtools/scripts/package.json +16 -0
  162. package/templates/claude/skills/chrome-devtools/scripts/performance.js +159 -0
  163. package/templates/claude/skills/chrome-devtools/scripts/screenshot.js +212 -0
  164. package/templates/claude/skills/chrome-devtools/scripts/select-ref.js +151 -0
  165. package/templates/claude/skills/chrome-devtools/scripts/snapshot.js +143 -0
  166. package/templates/claude/skills/chrome-devtools/scripts/ws-debug.js +47 -0
  167. package/templates/claude/skills/chrome-devtools/scripts/ws-full-debug.js +115 -0
  168. package/templates/claude/skills/claude-code/references/advanced-features.md +399 -0
  169. package/templates/claude/skills/claude-code/references/agent-skills.md +399 -0
  170. package/templates/claude/skills/claude-code/references/api-reference.md +498 -0
  171. package/templates/claude/skills/claude-code/references/best-practices.md +447 -0
  172. package/templates/claude/skills/claude-code/references/cicd-integration.md +428 -0
  173. package/templates/claude/skills/claude-code/references/common-workflows.md +107 -0
  174. package/templates/claude/skills/claude-code/references/configuration.md +480 -0
  175. package/templates/claude/skills/claude-code/references/enterprise-features.md +472 -0
  176. package/templates/claude/skills/claude-code/references/getting-started.md +244 -0
  177. package/templates/claude/skills/claude-code/references/hooks-and-plugins.md +444 -0
  178. package/templates/claude/skills/claude-code/references/hooks-comprehensive.md +622 -0
  179. package/templates/claude/skills/claude-code/references/ide-integration.md +316 -0
  180. package/templates/claude/skills/claude-code/references/mcp-integration.md +386 -0
  181. package/templates/claude/skills/claude-code/references/slash-commands.md +460 -0
  182. package/templates/claude/skills/claude-code/references/troubleshooting.md +455 -0
  183. package/templates/claude/skills/claude-code/skill.md +60 -0
  184. package/templates/claude/skills/code-review/SKILL.md +143 -0
  185. package/templates/claude/skills/code-review/references/code-review-reception.md +209 -0
  186. package/templates/claude/skills/code-review/references/requesting-code-review.md +105 -0
  187. package/templates/claude/skills/code-review/references/verification-before-completion.md +139 -0
  188. package/templates/claude/skills/context-engineering/SKILL.md +86 -0
  189. package/templates/claude/skills/context-engineering/references/context-compression.md +84 -0
  190. package/templates/claude/skills/context-engineering/references/context-degradation.md +93 -0
  191. package/templates/claude/skills/context-engineering/references/context-fundamentals.md +75 -0
  192. package/templates/claude/skills/context-engineering/references/context-optimization.md +82 -0
  193. package/templates/claude/skills/context-engineering/references/evaluation.md +89 -0
  194. package/templates/claude/skills/context-engineering/references/memory-systems.md +88 -0
  195. package/templates/claude/skills/context-engineering/references/multi-agent-patterns.md +90 -0
  196. package/templates/claude/skills/context-engineering/references/project-development.md +97 -0
  197. package/templates/claude/skills/context-engineering/references/tool-design.md +86 -0
  198. package/templates/claude/skills/context-engineering/scripts/compression_evaluator.py +329 -0
  199. package/templates/claude/skills/context-engineering/scripts/context_analyzer.py +294 -0
  200. package/templates/claude/skills/databases/SKILL.md +232 -0
  201. package/templates/claude/skills/databases/references/mongodb-aggregation.md +447 -0
  202. package/templates/claude/skills/databases/references/mongodb-atlas.md +465 -0
  203. package/templates/claude/skills/databases/references/mongodb-crud.md +408 -0
  204. package/templates/claude/skills/databases/references/mongodb-indexing.md +442 -0
  205. package/templates/claude/skills/databases/references/postgresql-administration.md +594 -0
  206. package/templates/claude/skills/databases/references/postgresql-performance.md +527 -0
  207. package/templates/claude/skills/databases/references/postgresql-psql-cli.md +467 -0
  208. package/templates/claude/skills/databases/references/postgresql-queries.md +475 -0
  209. package/templates/claude/skills/databases/scripts/db_backup.py +502 -0
  210. package/templates/claude/skills/databases/scripts/db_migrate.py +414 -0
  211. package/templates/claude/skills/databases/scripts/db_performance_check.py +445 -0
  212. package/templates/claude/skills/debugging/SKILL.md +84 -0
  213. package/templates/claude/skills/debugging/references/defense-in-depth.md +124 -0
  214. package/templates/claude/skills/debugging/references/root-cause-tracing.md +122 -0
  215. package/templates/claude/skills/debugging/references/systematic-debugging.md +102 -0
  216. package/templates/claude/skills/debugging/references/verification.md +123 -0
  217. package/templates/claude/skills/debugging/scripts/find-polluter.sh +63 -0
  218. package/templates/claude/skills/debugging/scripts/find-polluter.test.md +102 -0
  219. package/templates/claude/skills/devops/SKILL.md +293 -0
  220. package/templates/claude/skills/devops/references/browser-rendering.md +305 -0
  221. package/templates/claude/skills/devops/references/cloudflare-d1-kv.md +123 -0
  222. package/templates/claude/skills/devops/references/cloudflare-platform.md +271 -0
  223. package/templates/claude/skills/devops/references/cloudflare-r2-storage.md +280 -0
  224. package/templates/claude/skills/devops/references/cloudflare-workers-advanced.md +312 -0
  225. package/templates/claude/skills/devops/references/cloudflare-workers-apis.md +309 -0
  226. package/templates/claude/skills/devops/references/cloudflare-workers-basics.md +418 -0
  227. package/templates/claude/skills/devops/references/docker-basics.md +297 -0
  228. package/templates/claude/skills/devops/references/docker-compose.md +292 -0
  229. package/templates/claude/skills/devops/references/gcloud-platform.md +307 -0
  230. package/templates/claude/skills/devops/references/gcloud-services.md +304 -0
  231. package/templates/claude/skills/devops/scripts/cloudflare_deploy.py +269 -0
  232. package/templates/claude/skills/devops/scripts/docker_optimize.py +320 -0
  233. package/templates/claude/skills/docs-seeker/SKILL.md +95 -0
  234. package/templates/claude/skills/docs-seeker/package.json +24 -0
  235. package/templates/claude/skills/docs-seeker/references/advanced.md +78 -0
  236. package/templates/claude/skills/docs-seeker/references/context7-patterns.md +68 -0
  237. package/templates/claude/skills/docs-seeker/references/errors.md +68 -0
  238. package/templates/claude/skills/docs-seeker/scripts/analyze-llms-txt.js +245 -0
  239. package/templates/claude/skills/docs-seeker/scripts/detect-topic.js +172 -0
  240. package/templates/claude/skills/docs-seeker/scripts/fetch-docs.js +212 -0
  241. package/templates/claude/skills/docs-seeker/workflows/library-search.md +87 -0
  242. package/templates/claude/skills/docs-seeker/workflows/repo-analysis.md +91 -0
  243. package/templates/claude/skills/docs-seeker/workflows/topic-search.md +77 -0
  244. package/templates/claude/skills/frontend-design/SKILL.md +85 -0
  245. package/templates/claude/skills/frontend-design/references/analysis-best-practices.md +80 -0
  246. package/templates/claude/skills/frontend-design/references/analysis-prompts.md +141 -0
  247. package/templates/claude/skills/frontend-design/references/analysis-techniques.md +118 -0
  248. package/templates/claude/skills/frontend-design/references/animejs.md +396 -0
  249. package/templates/claude/skills/frontend-design/references/design-extraction-overview.md +71 -0
  250. package/templates/claude/skills/frontend-design/references/extraction-best-practices.md +141 -0
  251. package/templates/claude/skills/frontend-design/references/extraction-output-templates.md +162 -0
  252. package/templates/claude/skills/frontend-design/references/extraction-prompts.md +127 -0
  253. package/templates/claude/skills/frontend-design/references/technical-accessibility.md +119 -0
  254. package/templates/claude/skills/frontend-design/references/technical-best-practices.md +97 -0
  255. package/templates/claude/skills/frontend-design/references/technical-optimization.md +44 -0
  256. package/templates/claude/skills/frontend-design/references/technical-overview.md +90 -0
  257. package/templates/claude/skills/frontend-design/references/technical-workflows.md +150 -0
  258. package/templates/claude/skills/frontend-design/references/visual-analysis-overview.md +95 -0
  259. package/templates/claude/skills/frontend-development/SKILL.md +399 -0
  260. package/templates/claude/skills/frontend-development/resources/common-patterns.md +331 -0
  261. package/templates/claude/skills/frontend-development/resources/complete-examples.md +872 -0
  262. package/templates/claude/skills/frontend-development/resources/component-patterns.md +502 -0
  263. package/templates/claude/skills/frontend-development/resources/data-fetching.md +767 -0
  264. package/templates/claude/skills/frontend-development/resources/file-organization.md +502 -0
  265. package/templates/claude/skills/frontend-development/resources/loading-and-error-states.md +501 -0
  266. package/templates/claude/skills/frontend-development/resources/performance.md +406 -0
  267. package/templates/claude/skills/frontend-development/resources/routing-guide.md +364 -0
  268. package/templates/claude/skills/frontend-development/resources/styling-guide.md +428 -0
  269. package/templates/claude/skills/frontend-development/resources/typescript-standards.md +418 -0
  270. package/templates/claude/skills/markdown-novel-viewer/SKILL.md +272 -0
  271. package/templates/claude/skills/markdown-novel-viewer/assets/directory-browser.css +215 -0
  272. package/templates/claude/skills/markdown-novel-viewer/assets/favicon.png +0 -0
  273. package/templates/claude/skills/markdown-novel-viewer/assets/novel-theme.css +872 -0
  274. package/templates/claude/skills/markdown-novel-viewer/assets/reader.js +378 -0
  275. package/templates/claude/skills/markdown-novel-viewer/assets/template.html +85 -0
  276. package/templates/claude/skills/markdown-novel-viewer/package.json +15 -0
  277. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/http-server.cjs +434 -0
  278. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/markdown-renderer.cjs +335 -0
  279. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/plan-navigator.cjs +509 -0
  280. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/port-finder.cjs +49 -0
  281. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/process-mgr.cjs +150 -0
  282. package/templates/claude/skills/markdown-novel-viewer/scripts/server.cjs +398 -0
  283. package/templates/claude/skills/mcp-builder/SKILL.md +328 -0
  284. package/templates/claude/skills/mcp-builder/reference/evaluation.md +602 -0
  285. package/templates/claude/skills/mcp-builder/reference/mcp_best_practices.md +915 -0
  286. package/templates/claude/skills/mcp-builder/reference/node_mcp_server.md +916 -0
  287. package/templates/claude/skills/mcp-builder/reference/python_mcp_server.md +752 -0
  288. package/templates/claude/skills/mcp-builder/scripts/connections.py +151 -0
  289. package/templates/claude/skills/mcp-builder/scripts/evaluation.py +381 -0
  290. package/templates/claude/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
  291. package/templates/claude/skills/mcp-builder/scripts/requirements.txt +2 -0
  292. package/templates/claude/skills/mcp-management/README.md +219 -0
  293. package/templates/claude/skills/mcp-management/SKILL.md +209 -0
  294. package/templates/claude/skills/mcp-management/assets/tools.json +3146 -0
  295. package/templates/claude/skills/mcp-management/references/configuration.md +114 -0
  296. package/templates/claude/skills/mcp-management/references/gemini-cli-integration.md +209 -0
  297. package/templates/claude/skills/mcp-management/references/mcp-protocol.md +116 -0
  298. package/templates/claude/skills/mcp-management/scripts/.env.example +10 -0
  299. package/templates/claude/skills/mcp-management/scripts/cli.ts +202 -0
  300. package/templates/claude/skills/mcp-management/scripts/mcp-client.ts +247 -0
  301. package/templates/claude/skills/mcp-management/scripts/package.json +20 -0
  302. package/templates/claude/skills/mcp-management/scripts/tsconfig.json +15 -0
  303. package/templates/claude/skills/media-processing/SKILL.md +91 -0
  304. package/templates/claude/skills/media-processing/references/common-workflows.md +132 -0
  305. package/templates/claude/skills/media-processing/references/ffmpeg-encoding.md +358 -0
  306. package/templates/claude/skills/media-processing/references/ffmpeg-filters.md +503 -0
  307. package/templates/claude/skills/media-processing/references/ffmpeg-streaming.md +395 -0
  308. package/templates/claude/skills/media-processing/references/format-compatibility.md +375 -0
  309. package/templates/claude/skills/media-processing/references/imagemagick-batch.md +612 -0
  310. package/templates/claude/skills/media-processing/references/imagemagick-editing.md +623 -0
  311. package/templates/claude/skills/media-processing/references/rmbg-background-removal.md +66 -0
  312. package/templates/claude/skills/media-processing/references/troubleshooting.md +109 -0
  313. package/templates/claude/skills/media-processing/scripts/README.md +102 -0
  314. package/templates/claude/skills/media-processing/scripts/batch-remove-background.sh +124 -0
  315. package/templates/claude/skills/media-processing/scripts/batch_resize.py +342 -0
  316. package/templates/claude/skills/media-processing/scripts/media_convert.py +311 -0
  317. package/templates/claude/skills/media-processing/scripts/remove-background.sh +96 -0
  318. package/templates/claude/skills/media-processing/scripts/remove-bg-node.js +181 -0
  319. package/templates/claude/skills/mermaidjs-v11/SKILL.md +115 -0
  320. package/templates/claude/skills/mermaidjs-v11/references/cli-usage.md +228 -0
  321. package/templates/claude/skills/mermaidjs-v11/references/configuration.md +232 -0
  322. package/templates/claude/skills/mermaidjs-v11/references/diagram-types.md +315 -0
  323. package/templates/claude/skills/mermaidjs-v11/references/examples.md +344 -0
  324. package/templates/claude/skills/mermaidjs-v11/references/integration.md +310 -0
  325. package/templates/claude/skills/planning/SKILL.md +115 -0
  326. package/templates/claude/skills/planning/references/codebase-understanding.md +62 -0
  327. package/templates/claude/skills/planning/references/output-standards.md +127 -0
  328. package/templates/claude/skills/planning/references/plan-organization.md +150 -0
  329. package/templates/claude/skills/planning/references/research-phase.md +49 -0
  330. package/templates/claude/skills/planning/references/solution-design.md +63 -0
  331. package/templates/claude/skills/plans-kanban/SKILL.md +157 -0
  332. package/templates/claude/skills/plans-kanban/assets/dashboard-template.html +119 -0
  333. package/templates/claude/skills/plans-kanban/assets/dashboard.css +1594 -0
  334. package/templates/claude/skills/plans-kanban/assets/dashboard.js +659 -0
  335. package/templates/claude/skills/plans-kanban/assets/favicon.png +0 -0
  336. package/templates/claude/skills/plans-kanban/package.json +13 -0
  337. package/templates/claude/skills/plans-kanban/scripts/lib/dashboard-renderer.cjs +941 -0
  338. package/templates/claude/skills/plans-kanban/scripts/lib/http-server.cjs +310 -0
  339. package/templates/claude/skills/plans-kanban/scripts/lib/plan-metadata-extractor.cjs +489 -0
  340. package/templates/claude/skills/plans-kanban/scripts/lib/plan-parser.cjs +194 -0
  341. package/templates/claude/skills/plans-kanban/scripts/lib/plan-scanner.cjs +277 -0
  342. package/templates/claude/skills/plans-kanban/scripts/lib/port-finder.cjs +49 -0
  343. package/templates/claude/skills/plans-kanban/scripts/lib/process-mgr.cjs +128 -0
  344. package/templates/claude/skills/plans-kanban/scripts/server.cjs +249 -0
  345. package/templates/claude/skills/problem-solving/SKILL.md +96 -0
  346. package/templates/claude/skills/problem-solving/references/attribution.md +69 -0
  347. package/templates/claude/skills/problem-solving/references/collision-zone-thinking.md +79 -0
  348. package/templates/claude/skills/problem-solving/references/inversion-exercise.md +91 -0
  349. package/templates/claude/skills/problem-solving/references/meta-pattern-recognition.md +87 -0
  350. package/templates/claude/skills/problem-solving/references/scale-game.md +95 -0
  351. package/templates/claude/skills/problem-solving/references/simplification-cascades.md +80 -0
  352. package/templates/claude/skills/problem-solving/references/when-stuck.md +72 -0
  353. package/templates/claude/skills/registry.json +258 -0
  354. package/templates/claude/skills/repomix/SKILL.md +247 -0
  355. package/templates/claude/skills/repomix/references/configuration.md +211 -0
  356. package/templates/claude/skills/repomix/references/usage-patterns.md +232 -0
  357. package/templates/claude/skills/repomix/scripts/README.md +179 -0
  358. package/templates/claude/skills/repomix/scripts/repomix_batch.py +455 -0
  359. package/templates/claude/skills/repomix/scripts/repos.example.json +15 -0
  360. package/templates/claude/skills/research/SKILL.md +168 -0
  361. package/templates/claude/skills/sequential-thinking/.env.example +8 -0
  362. package/templates/claude/skills/sequential-thinking/README.md +183 -0
  363. package/templates/claude/skills/sequential-thinking/SKILL.md +94 -0
  364. package/templates/claude/skills/sequential-thinking/package.json +31 -0
  365. package/templates/claude/skills/sequential-thinking/references/advanced-strategies.md +79 -0
  366. package/templates/claude/skills/sequential-thinking/references/advanced-techniques.md +76 -0
  367. package/templates/claude/skills/sequential-thinking/references/core-patterns.md +95 -0
  368. package/templates/claude/skills/sequential-thinking/references/examples-api.md +88 -0
  369. package/templates/claude/skills/sequential-thinking/references/examples-architecture.md +94 -0
  370. package/templates/claude/skills/sequential-thinking/references/examples-debug.md +90 -0
  371. package/templates/claude/skills/sequential-thinking/scripts/format-thought.js +182 -0
  372. package/templates/claude/skills/sequential-thinking/scripts/process-thought.js +252 -0
  373. package/templates/claude/skills/skill-creator/LICENSE.txt +202 -0
  374. package/templates/claude/skills/skill-creator/SKILL.md +266 -0
  375. package/templates/claude/skills/skill-creator/references/agent-skills-spec.md +51 -0
  376. package/templates/claude/skills/skill-creator/scripts/encoding_utils.py +21 -0
  377. package/templates/claude/skills/skill-creator/scripts/init_skill.py +304 -0
  378. package/templates/claude/skills/skill-creator/scripts/package_skill.py +110 -0
  379. package/templates/claude/skills/skill-creator/scripts/quick_validate.py +66 -0
  380. package/templates/claude/skills/template-skill/SKILL.md +6 -0
  381. package/templates/claude/skills/vitest/SKILL.md +595 -0
  382. package/templates/claude/skills/vitest/references/async-patterns.md +82 -0
  383. package/templates/claude/skills/vitest/references/mock-patterns.md +78 -0
  384. package/templates/claude/skills/vitest/references/monorepo-setup.md +185 -0
  385. package/templates/claude/skills/vitest/references/turborepo-setup.md +332 -0
  386. package/templates/claude/skills/web-frameworks/SKILL.md +324 -0
  387. package/templates/claude/skills/web-frameworks/references/nextjs-app-router.md +465 -0
  388. package/templates/claude/skills/web-frameworks/references/nextjs-data-fetching.md +459 -0
  389. package/templates/claude/skills/web-frameworks/references/nextjs-optimization.md +511 -0
  390. package/templates/claude/skills/web-frameworks/references/nextjs-server-components.md +495 -0
  391. package/templates/claude/skills/web-frameworks/references/remix-icon-integration.md +603 -0
  392. package/templates/claude/skills/web-frameworks/references/turborepo-caching.md +551 -0
  393. package/templates/claude/skills/web-frameworks/references/turborepo-pipelines.md +517 -0
  394. package/templates/claude/skills/web-frameworks/references/turborepo-setup.md +542 -0
  395. package/templates/claude/skills/web-frameworks/scripts/nextjs_init.py +547 -0
  396. package/templates/claude/skills/web-frameworks/scripts/turborepo_migrate.py +394 -0
  397. package/templates/claude/workflows/development-rules.md +40 -0
  398. package/templates/claude/workflows/documentation-management.md +121 -0
  399. package/templates/claude/workflows/orchestration-protocol.md +16 -0
  400. package/templates/claude/workflows/primary-workflow.md +45 -0
  401. package/templates/claude/workflows/registry.json +37 -0
  402. package/templates/common/.cct.json +41 -0
  403. package/templates/common/.cctkignore +22 -0
  404. package/templates/common/.env.example +39 -0
  405. package/templates/common/.mcp.json.example +16 -0
  406. package/templates/common/metadata.json +15 -0
  407. package/templates/common/settings.json +79 -0
  408. package/templates/common/statusline.cjs +271 -0
  409. package/templates/config/.repomixignore +22 -0
  410. package/templates/config/AGENTS.md +55 -0
  411. package/templates/config/CLAUDE.md +87 -0
  412. package/templates/plans/bug-fix-template.md +69 -0
  413. package/templates/plans/feature-implementation-template.md +84 -0
  414. package/templates/plans/refactor-template.md +82 -0
  415. package/templates/plans/template-usage-guide.md +58 -0
@@ -0,0 +1,418 @@
1
+ # TypeScript Standards
2
+
3
+ TypeScript best practices for type safety and maintainability in React frontend code.
4
+
5
+ ---
6
+
7
+ ## Strict Mode
8
+
9
+ ### Configuration
10
+
11
+ TypeScript strict mode is **enabled** in the project:
12
+
13
+ ```json
14
+ // tsconfig.json
15
+ {
16
+ "compilerOptions": {
17
+ "strict": true,
18
+ "noImplicitAny": true,
19
+ "strictNullChecks": true
20
+ }
21
+ }
22
+ ```
23
+
24
+ **This means:**
25
+ - No implicit `any` types
26
+ - Null/undefined must be handled explicitly
27
+ - Type safety enforced
28
+
29
+ ---
30
+
31
+ ## No `any` Type
32
+
33
+ ### The Rule
34
+
35
+ ```typescript
36
+ // ❌ NEVER use any
37
+ function handleData(data: any) {
38
+ return data.something;
39
+ }
40
+
41
+ // ✅ Use specific types
42
+ interface MyData {
43
+ something: string;
44
+ }
45
+
46
+ function handleData(data: MyData) {
47
+ return data.something;
48
+ }
49
+
50
+ // ✅ Or use unknown for truly unknown data
51
+ function handleUnknown(data: unknown) {
52
+ if (typeof data === 'object' && data !== null && 'something' in data) {
53
+ return (data as MyData).something;
54
+ }
55
+ }
56
+ ```
57
+
58
+ **If you truly don't know the type:**
59
+ - Use `unknown` (forces type checking)
60
+ - Use type guards to narrow
61
+ - Document why type is unknown
62
+
63
+ ---
64
+
65
+ ## Explicit Return Types
66
+
67
+ ### Function Return Types
68
+
69
+ ```typescript
70
+ // ✅ CORRECT - Explicit return type
71
+ function getUser(id: number): Promise<User> {
72
+ return apiClient.get(`/users/${id}`);
73
+ }
74
+
75
+ function calculateTotal(items: Item[]): number {
76
+ return items.reduce((sum, item) => sum + item.price, 0);
77
+ }
78
+
79
+ // ❌ AVOID - Implicit return type (less clear)
80
+ function getUser(id: number) {
81
+ return apiClient.get(`/users/${id}`);
82
+ }
83
+ ```
84
+
85
+ ### Component Return Types
86
+
87
+ ```typescript
88
+ // React.FC already provides return type (ReactElement)
89
+ export const MyComponent: React.FC<Props> = ({ prop }) => {
90
+ return <div>{prop}</div>;
91
+ };
92
+
93
+ // For custom hooks
94
+ function useMyData(id: number): { data: Data; isLoading: boolean } {
95
+ const [data, setData] = useState<Data | null>(null);
96
+ const [isLoading, setIsLoading] = useState(true);
97
+
98
+ return { data: data!, isLoading };
99
+ }
100
+ ```
101
+
102
+ ---
103
+
104
+ ## Type Imports
105
+
106
+ ### Use 'type' Keyword
107
+
108
+ ```typescript
109
+ // ✅ CORRECT - Explicitly mark as type import
110
+ import type { User } from '~types/user';
111
+ import type { Post } from '~types/post';
112
+ import type { SxProps, Theme } from '@mui/material';
113
+
114
+ // ❌ AVOID - Mixed value and type imports
115
+ import { User } from '~types/user'; // Unclear if type or value
116
+ ```
117
+
118
+ **Benefits:**
119
+ - Clearly separates types from values
120
+ - Better tree-shaking
121
+ - Prevents circular dependencies
122
+ - TypeScript compiler optimization
123
+
124
+ ---
125
+
126
+ ## Component Prop Interfaces
127
+
128
+ ### Interface Pattern
129
+
130
+ ```typescript
131
+ /**
132
+ * Props for MyComponent
133
+ */
134
+ interface MyComponentProps {
135
+ /** The user ID to display */
136
+ userId: number;
137
+
138
+ /** Optional callback when action completes */
139
+ onComplete?: () => void;
140
+
141
+ /** Display mode for the component */
142
+ mode?: 'view' | 'edit';
143
+
144
+ /** Additional CSS classes */
145
+ className?: string;
146
+ }
147
+
148
+ export const MyComponent: React.FC<MyComponentProps> = ({
149
+ userId,
150
+ onComplete,
151
+ mode = 'view', // Default value
152
+ className,
153
+ }) => {
154
+ return <div>...</div>;
155
+ };
156
+ ```
157
+
158
+ **Key Points:**
159
+ - Separate interface for props
160
+ - JSDoc comments for each prop
161
+ - Optional props use `?`
162
+ - Provide defaults in destructuring
163
+
164
+ ### Props with Children
165
+
166
+ ```typescript
167
+ interface ContainerProps {
168
+ children: React.ReactNode;
169
+ title: string;
170
+ }
171
+
172
+ // React.FC automatically includes children type, but be explicit
173
+ export const Container: React.FC<ContainerProps> = ({ children, title }) => {
174
+ return (
175
+ <div>
176
+ <h2>{title}</h2>
177
+ {children}
178
+ </div>
179
+ );
180
+ };
181
+ ```
182
+
183
+ ---
184
+
185
+ ## Utility Types
186
+
187
+ ### Partial<T>
188
+
189
+ ```typescript
190
+ // Make all properties optional
191
+ type UserUpdate = Partial<User>;
192
+
193
+ function updateUser(id: number, updates: Partial<User>) {
194
+ // updates can have any subset of User properties
195
+ }
196
+ ```
197
+
198
+ ### Pick<T, K>
199
+
200
+ ```typescript
201
+ // Select specific properties
202
+ type UserPreview = Pick<User, 'id' | 'name' | 'email'>;
203
+
204
+ const preview: UserPreview = {
205
+ id: 1,
206
+ name: 'John',
207
+ email: 'john@example.com',
208
+ // Other User properties not allowed
209
+ };
210
+ ```
211
+
212
+ ### Omit<T, K>
213
+
214
+ ```typescript
215
+ // Exclude specific properties
216
+ type UserWithoutPassword = Omit<User, 'password' | 'passwordHash'>;
217
+
218
+ const publicUser: UserWithoutPassword = {
219
+ id: 1,
220
+ name: 'John',
221
+ email: 'john@example.com',
222
+ // password and passwordHash not allowed
223
+ };
224
+ ```
225
+
226
+ ### Required<T>
227
+
228
+ ```typescript
229
+ // Make all properties required
230
+ type RequiredConfig = Required<Config>; // All optional props become required
231
+ ```
232
+
233
+ ### Record<K, V>
234
+
235
+ ```typescript
236
+ // Type-safe object/map
237
+ const userMap: Record<string, User> = {
238
+ 'user1': { id: 1, name: 'John' },
239
+ 'user2': { id: 2, name: 'Jane' },
240
+ };
241
+
242
+ // For styles
243
+ import type { SxProps, Theme } from '@mui/material';
244
+
245
+ const styles: Record<string, SxProps<Theme>> = {
246
+ container: { p: 2 },
247
+ header: { mb: 1 },
248
+ };
249
+ ```
250
+
251
+ ---
252
+
253
+ ## Type Guards
254
+
255
+ ### Basic Type Guards
256
+
257
+ ```typescript
258
+ function isUser(data: unknown): data is User {
259
+ return (
260
+ typeof data === 'object' &&
261
+ data !== null &&
262
+ 'id' in data &&
263
+ 'name' in data
264
+ );
265
+ }
266
+
267
+ // Usage
268
+ if (isUser(response)) {
269
+ console.log(response.name); // TypeScript knows it's User
270
+ }
271
+ ```
272
+
273
+ ### Discriminated Unions
274
+
275
+ ```typescript
276
+ type LoadingState =
277
+ | { status: 'idle' }
278
+ | { status: 'loading' }
279
+ | { status: 'success'; data: Data }
280
+ | { status: 'error'; error: Error };
281
+
282
+ function Component({ state }: { state: LoadingState }) {
283
+ // TypeScript narrows type based on status
284
+ if (state.status === 'success') {
285
+ return <Display data={state.data} />; // data available here
286
+ }
287
+
288
+ if (state.status === 'error') {
289
+ return <Error error={state.error} />; // error available here
290
+ }
291
+
292
+ return <Loading />;
293
+ }
294
+ ```
295
+
296
+ ---
297
+
298
+ ## Generic Types
299
+
300
+ ### Generic Functions
301
+
302
+ ```typescript
303
+ function getById<T>(items: T[], id: number): T | undefined {
304
+ return items.find(item => (item as any).id === id);
305
+ }
306
+
307
+ // Usage with type inference
308
+ const users: User[] = [...];
309
+ const user = getById(users, 123); // Type: User | undefined
310
+ ```
311
+
312
+ ### Generic Components
313
+
314
+ ```typescript
315
+ interface ListProps<T> {
316
+ items: T[];
317
+ renderItem: (item: T) => React.ReactNode;
318
+ }
319
+
320
+ export function List<T>({ items, renderItem }: ListProps<T>): React.ReactElement {
321
+ return (
322
+ <div>
323
+ {items.map((item, index) => (
324
+ <div key={index}>{renderItem(item)}</div>
325
+ ))}
326
+ </div>
327
+ );
328
+ }
329
+
330
+ // Usage
331
+ <List<User>
332
+ items={users}
333
+ renderItem={(user) => <UserCard user={user} />}
334
+ />
335
+ ```
336
+
337
+ ---
338
+
339
+ ## Type Assertions (Use Sparingly)
340
+
341
+ ### When to Use
342
+
343
+ ```typescript
344
+ // ✅ OK - When you know more than TypeScript
345
+ const element = document.getElementById('my-element') as HTMLInputElement;
346
+ const value = element.value;
347
+
348
+ // ✅ OK - API response that you've validated
349
+ const response = await api.getData();
350
+ const user = response.data as User; // You know the shape
351
+ ```
352
+
353
+ ### When NOT to Use
354
+
355
+ ```typescript
356
+ // ❌ AVOID - Circumventing type safety
357
+ const data = getData() as any; // WRONG - defeats TypeScript
358
+
359
+ // ❌ AVOID - Unsafe assertion
360
+ const value = unknownValue as string; // Might not actually be string
361
+ ```
362
+
363
+ ---
364
+
365
+ ## Null/Undefined Handling
366
+
367
+ ### Optional Chaining
368
+
369
+ ```typescript
370
+ // ✅ CORRECT
371
+ const name = user?.profile?.name;
372
+
373
+ // Equivalent to:
374
+ const name = user && user.profile && user.profile.name;
375
+ ```
376
+
377
+ ### Nullish Coalescing
378
+
379
+ ```typescript
380
+ // ✅ CORRECT
381
+ const displayName = user?.name ?? 'Anonymous';
382
+
383
+ // Only uses default if null or undefined
384
+ // (Different from || which triggers on '', 0, false)
385
+ ```
386
+
387
+ ### Non-Null Assertion (Use Carefully)
388
+
389
+ ```typescript
390
+ // ✅ OK - When you're certain value exists
391
+ const data = queryClient.getQueryData<Data>(['data'])!;
392
+
393
+ // ⚠️ CAREFUL - Only use when you KNOW it's not null
394
+ // Better to check explicitly:
395
+ const data = queryClient.getQueryData<Data>(['data']);
396
+ if (data) {
397
+ // Use data
398
+ }
399
+ ```
400
+
401
+ ---
402
+
403
+ ## Summary
404
+
405
+ **TypeScript Checklist:**
406
+ - ✅ Strict mode enabled
407
+ - ✅ No `any` type (use `unknown` if needed)
408
+ - ✅ Explicit return types on functions
409
+ - ✅ Use `import type` for type imports
410
+ - ✅ JSDoc comments on prop interfaces
411
+ - ✅ Utility types (Partial, Pick, Omit, Required, Record)
412
+ - ✅ Type guards for narrowing
413
+ - ✅ Optional chaining and nullish coalescing
414
+ - ❌ Avoid type assertions unless necessary
415
+
416
+ **See Also:**
417
+ - [component-patterns.md](component-patterns.md) - Component typing
418
+ - [data-fetching.md](data-fetching.md) - API typing
@@ -0,0 +1,272 @@
1
+ # markdown-novel-viewer
2
+
3
+ Background HTTP server rendering markdown files with calm, book-like reading experience.
4
+
5
+ ## ⚠️ Installation Required
6
+
7
+ **This skill requires npm dependencies.** Run one of the following:
8
+
9
+ ```bash
10
+ cd .claude/skills/markdown-novel-viewer
11
+ npm install
12
+ ```
13
+
14
+ **Dependencies:** `marked`, `highlight.js`, `gray-matter`
15
+
16
+ Without installation, you'll get **Error 500: Error rendering markdown**.
17
+
18
+ ## Purpose
19
+
20
+ Universal viewer - pass ANY path and view it:
21
+ - **Markdown files** → novel-reader UI with serif fonts, warm theme
22
+ - **Directories** → file listing browser with clickable links
23
+
24
+ ## Quick Start
25
+
26
+ ```bash
27
+ # View a markdown file
28
+ node .claude/skills/markdown-novel-viewer/scripts/server.cjs \
29
+ --file ./plans/my-plan/plan.md \
30
+ --open
31
+
32
+ # Browse a directory
33
+ node .claude/skills/markdown-novel-viewer/scripts/server.cjs \
34
+ --dir ./plans \
35
+ --host 0.0.0.0 \
36
+ --open
37
+
38
+ # Background mode
39
+ node .claude/skills/markdown-novel-viewer/scripts/server.cjs \
40
+ --file ./README.md \
41
+ --background
42
+
43
+ # Stop all running servers
44
+ node $HOME/.claude/skills/markdown-novel-viewer/scripts/server.cjs --stop
45
+ ```
46
+
47
+ ## Slash Command
48
+
49
+ Use `/preview` for quick access:
50
+
51
+ ```bash
52
+ /preview plans/my-plan/plan.md # View markdown file
53
+ /preview plans/ # Browse directory
54
+ /preview --stop # Stop server
55
+ ```
56
+
57
+ ## Features
58
+
59
+ ### Novel Theme
60
+ - Warm cream background (light mode)
61
+ - Dark mode with warm gold accents
62
+ - Libre Baskerville serif headings
63
+ - Inter body text, JetBrains Mono code
64
+ - Maximum 720px content width
65
+
66
+ ### Mermaid.js Diagrams
67
+ - Auto-renders `mermaid` code blocks as diagrams
68
+ - Theme-aware (light/dark mode support)
69
+ - Error display with source preview for debugging
70
+
71
+ ### Directory Browser
72
+ - Clean file listing with emoji icons
73
+ - Markdown files link to viewer
74
+ - Folders link to sub-directories
75
+ - Parent directory navigation (..)
76
+ - Light/dark mode support
77
+
78
+ ### Plan Navigation
79
+ - Auto-detects plan directory structure
80
+ - Sidebar shows all phases with status indicators
81
+ - Previous/Next navigation buttons
82
+ - Keyboard shortcuts: Arrow Left/Right
83
+
84
+ ### Keyboard Shortcuts
85
+ - `T` - Toggle theme
86
+ - `S` - Toggle sidebar
87
+ - `Left/Right` - Navigate phases
88
+ - `Escape` - Close sidebar (mobile)
89
+
90
+ ## CLI Options
91
+
92
+ | Option | Description | Default |
93
+ |--------|-------------|---------|
94
+ | `--file <path>` | Markdown file to view | - |
95
+ | `--dir <path>` | Directory to browse | - |
96
+ | `--port <number>` | Server port | 3456 |
97
+ | `--host <addr>` | Host to bind (`0.0.0.0` for remote) | localhost |
98
+ | `--open` | Auto-open browser | false |
99
+ | `--background` | Run in background | false |
100
+ | `--stop` | Stop all servers | - |
101
+
102
+ ## Architecture
103
+
104
+ ```
105
+ scripts/
106
+ ├── server.cjs # Main entry point
107
+ └── lib/
108
+ ├── port-finder.cjs # Dynamic port allocation
109
+ ├── process-mgr.cjs # PID file management
110
+ ├── http-server.cjs # Core HTTP routing (/view, /browse)
111
+ ├── markdown-renderer.cjs # MD→HTML conversion
112
+ └── plan-navigator.cjs # Plan detection & nav
113
+
114
+ assets/
115
+ ├── template.html # Markdown viewer template
116
+ ├── novel-theme.css # Combined light/dark theme
117
+ ├── reader.js # Client-side interactivity
118
+ ├── directory-browser.css # Directory browser styles
119
+ ```
120
+
121
+ ## HTTP Routes
122
+
123
+ | Route | Description |
124
+ |-------|-------------|
125
+ | `/view?file=<path>` | Markdown file viewer |
126
+ | `/browse?dir=<path>` | Directory browser |
127
+ | `/assets/*` | Static assets |
128
+ | `/file/*` | Local file serving (images) |
129
+
130
+ ## Dependencies
131
+
132
+ - Node.js built-in: `http`, `fs`, `path`, `net`
133
+ - npm: `marked`, `highlight.js`, `gray-matter` (installed via `npm install`)
134
+
135
+ ## Customization
136
+
137
+ ### Theme Colors (CSS Variables)
138
+
139
+ Light mode variables in `assets/novel-theme.css`:
140
+ ```css
141
+ --bg-primary: #faf8f3; /* Warm cream */
142
+ --accent: #8b4513; /* Saddle brown */
143
+ ```
144
+
145
+ Dark mode:
146
+ ```css
147
+ --bg-primary: #1a1a1a; /* Near black */
148
+ --accent: #d4a574; /* Warm gold */
149
+ ```
150
+
151
+ ### Content Width
152
+ ```css
153
+ --content-width: 720px;
154
+ ```
155
+
156
+ ## Remote Access
157
+
158
+ To access from another device on your network:
159
+
160
+ ```bash
161
+ # Start with 0.0.0.0 to bind to all interfaces
162
+ node server.cjs --file ./README.md --host 0.0.0.0 --port 3456
163
+ ```
164
+
165
+ When using `--host 0.0.0.0`, the server auto-detects your local network IP and includes it in the output:
166
+
167
+ ```json
168
+ {
169
+ "success": true,
170
+ "url": "http://localhost:3456/view?file=...",
171
+ "networkUrl": "http://192.168.2.75:3456/view?file=...",
172
+ "port": 3456
173
+ }
174
+ ```
175
+
176
+ Use `networkUrl` to access from other devices on the same network.
177
+
178
+ ## Troubleshooting
179
+
180
+ **Port in use**: Server auto-increments to next available port (3456-3500)
181
+
182
+ **Images not loading**: Ensure image paths are relative to markdown file
183
+
184
+ **Server won't stop**: Check `/tmp/md-novel-viewer-*.pid` for stale PID files
185
+
186
+ **Remote access denied**: Use `--host 0.0.0.0` to bind to all interfaces
187
+
188
+ ## Mermaid.js Diagrams
189
+
190
+ ### Usage
191
+
192
+ Use fenced code blocks with `mermaid` language:
193
+
194
+ ````markdown
195
+ ```mermaid
196
+ pie title Traffic Sources
197
+ "Organic" : 45
198
+ "Direct" : 30
199
+ "Referral" : 25
200
+ ```
201
+ ````
202
+
203
+ ### Supported Diagram Types
204
+
205
+ | Type | Syntax | Use Case |
206
+ |------|--------|----------|
207
+ | Flowchart | `flowchart LR/TB/TD` | Process flows, decision trees |
208
+ | Sequence | `sequenceDiagram` | API interactions, message flows |
209
+ | Pie | `pie title "..."` | Distribution data |
210
+ | Gantt | `gantt` | Project timelines |
211
+ | XY Chart | `xychart-beta` | Bar/line charts |
212
+ | Mindmap | `mindmap` | Idea hierarchies |
213
+ | Quadrant | `quadrantChart` | 2x2 matrices |
214
+
215
+ ### Validating Mermaid Snippets
216
+
217
+ **Quick validation**: Use the [Mermaid Live Editor](https://mermaid.live) to test syntax.
218
+
219
+ **Common errors and fixes**:
220
+
221
+ | Error | Cause | Fix |
222
+ |-------|-------|-----|
223
+ | `Parse error` | Invalid syntax | Check diagram type declaration |
224
+ | `Unknown diagram type` | Typo in declaration | Use exact type: `flowchart`, not `flow` |
225
+ | `Expecting token` | Missing quotes/brackets | Ensure balanced delimiters |
226
+ | `UnknownDiagramError` | Empty or malformed block | Add valid diagram content |
227
+
228
+ ### Fixing Common Issues
229
+
230
+ **1. Flowchart arrows**
231
+ ```mermaid
232
+ %% Wrong: A -> B
233
+ %% Correct:
234
+ flowchart LR
235
+ A --> B
236
+ ```
237
+
238
+ **2. Pie chart values**
239
+ ```mermaid
240
+ %% Wrong: "Label": 50%
241
+ %% Correct:
242
+ pie title Sales
243
+ "Product A" : 50
244
+ "Product B" : 30
245
+ ```
246
+
247
+ **3. XY Chart data format**
248
+ ```mermaid
249
+ xychart-beta
250
+ title "Monthly Sales"
251
+ x-axis [Jan, Feb, Mar]
252
+ y-axis "Revenue" 0 --> 100
253
+ bar [30, 45, 60]
254
+ ```
255
+
256
+ **4. Sequence diagram participants**
257
+ ```mermaid
258
+ sequenceDiagram
259
+ participant A as Client
260
+ participant B as Server
261
+ A->>B: Request
262
+ B-->>A: Response
263
+ ```
264
+
265
+ ### Debug Mode
266
+
267
+ When a diagram fails to render, the viewer shows:
268
+ - Error message
269
+ - Expandable source code preview
270
+ - Line number where parsing failed (when available)
271
+
272
+ Fix the syntax and refresh the page to re-render.