claude-skill-lord 1.5.0

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 (684) hide show
  1. package/.claude-plugin/marketplace.json +19 -0
  2. package/.claude-plugin/plugin.json +54 -0
  3. package/CLAUDE.md +81 -0
  4. package/LICENSE +33 -0
  5. package/LICENSE-ui-ux-pro-max.txt +21 -0
  6. package/README.md +294 -0
  7. package/agents/architect.md +211 -0
  8. package/agents/brainstormer.md +103 -0
  9. package/agents/build-error-resolver.md +114 -0
  10. package/agents/chief-of-staff.md +151 -0
  11. package/agents/code-reviewer.md +285 -0
  12. package/agents/copywriter.md +111 -0
  13. package/agents/database-admin.md +91 -0
  14. package/agents/debugger.md +135 -0
  15. package/agents/docs-manager.md +119 -0
  16. package/agents/e2e-runner.md +107 -0
  17. package/agents/git-manager.md +199 -0
  18. package/agents/harness-optimizer.md +35 -0
  19. package/agents/loop-operator.md +36 -0
  20. package/agents/planner.md +245 -0
  21. package/agents/project-manager.md +117 -0
  22. package/agents/quality-gate.md +173 -0
  23. package/agents/refactor-cleaner.md +85 -0
  24. package/agents/scout.md +105 -0
  25. package/agents/security-reviewer.md +108 -0
  26. package/agents/skill-router.md +112 -0
  27. package/agents/tdd-guide.md +91 -0
  28. package/agents/ui-ux-designer.md +220 -0
  29. package/assets/canvas-fonts/ArsenalSC-OFL.txt +93 -0
  30. package/assets/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  31. package/assets/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  32. package/assets/canvas-fonts/BigShoulders-OFL.txt +93 -0
  33. package/assets/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  34. package/assets/canvas-fonts/Boldonse-OFL.txt +93 -0
  35. package/assets/canvas-fonts/Boldonse-Regular.ttf +0 -0
  36. package/assets/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  37. package/assets/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
  38. package/assets/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  39. package/assets/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  40. package/assets/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  41. package/assets/canvas-fonts/CrimsonPro-OFL.txt +93 -0
  42. package/assets/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  43. package/assets/canvas-fonts/DMMono-OFL.txt +93 -0
  44. package/assets/canvas-fonts/DMMono-Regular.ttf +0 -0
  45. package/assets/canvas-fonts/EricaOne-OFL.txt +94 -0
  46. package/assets/canvas-fonts/EricaOne-Regular.ttf +0 -0
  47. package/assets/canvas-fonts/GeistMono-Bold.ttf +0 -0
  48. package/assets/canvas-fonts/GeistMono-OFL.txt +93 -0
  49. package/assets/canvas-fonts/GeistMono-Regular.ttf +0 -0
  50. package/assets/canvas-fonts/Gloock-OFL.txt +93 -0
  51. package/assets/canvas-fonts/Gloock-Regular.ttf +0 -0
  52. package/assets/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  53. package/assets/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
  54. package/assets/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  55. package/assets/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  56. package/assets/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  57. package/assets/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  58. package/assets/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  59. package/assets/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  60. package/assets/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  61. package/assets/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  62. package/assets/canvas-fonts/InstrumentSans-OFL.txt +93 -0
  63. package/assets/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  64. package/assets/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  65. package/assets/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  66. package/assets/canvas-fonts/Italiana-OFL.txt +93 -0
  67. package/assets/canvas-fonts/Italiana-Regular.ttf +0 -0
  68. package/assets/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  69. package/assets/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
  70. package/assets/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  71. package/assets/canvas-fonts/Jura-Light.ttf +0 -0
  72. package/assets/canvas-fonts/Jura-Medium.ttf +0 -0
  73. package/assets/canvas-fonts/Jura-OFL.txt +93 -0
  74. package/assets/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
  75. package/assets/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  76. package/assets/canvas-fonts/Lora-Bold.ttf +0 -0
  77. package/assets/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  78. package/assets/canvas-fonts/Lora-Italic.ttf +0 -0
  79. package/assets/canvas-fonts/Lora-OFL.txt +93 -0
  80. package/assets/canvas-fonts/Lora-Regular.ttf +0 -0
  81. package/assets/canvas-fonts/NationalPark-Bold.ttf +0 -0
  82. package/assets/canvas-fonts/NationalPark-OFL.txt +93 -0
  83. package/assets/canvas-fonts/NationalPark-Regular.ttf +0 -0
  84. package/assets/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
  85. package/assets/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  86. package/assets/canvas-fonts/Outfit-Bold.ttf +0 -0
  87. package/assets/canvas-fonts/Outfit-OFL.txt +93 -0
  88. package/assets/canvas-fonts/Outfit-Regular.ttf +0 -0
  89. package/assets/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  90. package/assets/canvas-fonts/PixelifySans-OFL.txt +93 -0
  91. package/assets/canvas-fonts/PoiretOne-OFL.txt +93 -0
  92. package/assets/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  93. package/assets/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  94. package/assets/canvas-fonts/RedHatMono-OFL.txt +93 -0
  95. package/assets/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  96. package/assets/canvas-fonts/Silkscreen-OFL.txt +93 -0
  97. package/assets/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  98. package/assets/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  99. package/assets/canvas-fonts/SmoochSans-OFL.txt +93 -0
  100. package/assets/canvas-fonts/Tektur-Medium.ttf +0 -0
  101. package/assets/canvas-fonts/Tektur-OFL.txt +93 -0
  102. package/assets/canvas-fonts/Tektur-Regular.ttf +0 -0
  103. package/assets/canvas-fonts/WorkSans-Bold.ttf +0 -0
  104. package/assets/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  105. package/assets/canvas-fonts/WorkSans-Italic.ttf +0 -0
  106. package/assets/canvas-fonts/WorkSans-OFL.txt +93 -0
  107. package/assets/canvas-fonts/WorkSans-Regular.ttf +0 -0
  108. package/assets/canvas-fonts/YoungSerif-OFL.txt +93 -0
  109. package/assets/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  110. package/commands/ask.md +56 -0
  111. package/commands/audit.md +25 -0
  112. package/commands/bootstrap/auto/fast.md +111 -0
  113. package/commands/bootstrap/auto.md +115 -0
  114. package/commands/bootstrap.md +137 -0
  115. package/commands/brainstorm.md +69 -0
  116. package/commands/build-fix.md +66 -0
  117. package/commands/code-review.md +44 -0
  118. package/commands/code.md +93 -0
  119. package/commands/commit_gen.md +44 -0
  120. package/commands/content/cro.md +43 -0
  121. package/commands/content/enhance.md +14 -0
  122. package/commands/content/fast.md +13 -0
  123. package/commands/content/good.md +16 -0
  124. package/commands/cook/auto/fast.md +26 -0
  125. package/commands/cook/auto.md +15 -0
  126. package/commands/cook.md +105 -0
  127. package/commands/debug.md +13 -0
  128. package/commands/design/3d.md +74 -0
  129. package/commands/design/describe.md +21 -0
  130. package/commands/design/fast.md +22 -0
  131. package/commands/design/good.md +26 -0
  132. package/commands/design/screenshot.md +32 -0
  133. package/commands/design/video.md +32 -0
  134. package/commands/docs/init.md +15 -0
  135. package/commands/docs/summarize.md +22 -0
  136. package/commands/docs/update.md +23 -0
  137. package/commands/e2e.md +365 -0
  138. package/commands/evolve.md +178 -0
  139. package/commands/fix/ci.md +20 -0
  140. package/commands/fix/fast.md +19 -0
  141. package/commands/fix/hard.md +43 -0
  142. package/commands/fix/logs.md +20 -0
  143. package/commands/fix/test.md +20 -0
  144. package/commands/fix/types.md +9 -0
  145. package/commands/fix/ui.md +35 -0
  146. package/commands/fix.md +12 -0
  147. package/commands/git/cm.md +11 -0
  148. package/commands/git/cp.md +9 -0
  149. package/commands/git/pr.md +15 -0
  150. package/commands/integrate/polar.md +28 -0
  151. package/commands/integrate/sepay.md +28 -0
  152. package/commands/journal.md +5 -0
  153. package/commands/learn.md +74 -0
  154. package/commands/loop-start.md +36 -0
  155. package/commands/loop-status.md +28 -0
  156. package/commands/model-route.md +30 -0
  157. package/commands/plan.md +115 -0
  158. package/commands/prompt-optimize.md +38 -0
  159. package/commands/quality-gate.md +33 -0
  160. package/commands/refactor-clean.md +84 -0
  161. package/commands/review/codebase.md +49 -0
  162. package/commands/route.md +28 -0
  163. package/commands/scout/ext.md +35 -0
  164. package/commands/scout.md +28 -0
  165. package/commands/skill/add.md +29 -0
  166. package/commands/skill/create.md +22 -0
  167. package/commands/skill/fix-logs.md +21 -0
  168. package/commands/skill/optimize.md +28 -0
  169. package/commands/skill-create.md +174 -0
  170. package/commands/tdd.md +328 -0
  171. package/commands/test.md +8 -0
  172. package/commands/verify.md +63 -0
  173. package/commands/watzup.md +8 -0
  174. package/hooks/hooks.json +86 -0
  175. package/hooks/scripts/block-no-verify.js +19 -0
  176. package/hooks/scripts/check-console-log.js +71 -0
  177. package/hooks/scripts/check-hook-enabled.js +12 -0
  178. package/hooks/scripts/config-protection.js +125 -0
  179. package/hooks/scripts/post-edit-console-warn.js +54 -0
  180. package/hooks/scripts/post-edit-format.js +109 -0
  181. package/hooks/scripts/post-edit-typecheck.js +96 -0
  182. package/hooks/scripts/quality-gate.js +168 -0
  183. package/hooks/scripts/run-with-flags-shell.sh +32 -0
  184. package/hooks/scripts/run-with-flags.js +120 -0
  185. package/hooks/scripts/session-end.js +301 -0
  186. package/hooks/scripts/session-start.js +98 -0
  187. package/manifests/install-modules.json +96 -0
  188. package/manifests/install-profiles.json +17 -0
  189. package/package.json +52 -0
  190. package/scripts/install.js +144 -0
  191. package/scripts/lib/hook-flags.js +74 -0
  192. package/scripts/lib/profile-utils.js +97 -0
  193. package/scripts/lib/resolve-formatter.js +185 -0
  194. package/scripts/lib/resolve-root.js +89 -0
  195. package/scripts/lib/utils.js +564 -0
  196. package/scripts/sl.js +677 -0
  197. package/skills/manifest.json +493 -0
  198. package/skills/tier-1/api-design/SKILL.md +523 -0
  199. package/skills/tier-1/backend-development/SKILL.md +95 -0
  200. package/skills/tier-1/backend-development/references/backend-api-design.md +495 -0
  201. package/skills/tier-1/backend-development/references/backend-architecture.md +454 -0
  202. package/skills/tier-1/backend-development/references/backend-authentication.md +338 -0
  203. package/skills/tier-1/backend-development/references/backend-code-quality.md +659 -0
  204. package/skills/tier-1/backend-development/references/backend-debugging.md +904 -0
  205. package/skills/tier-1/backend-development/references/backend-devops.md +494 -0
  206. package/skills/tier-1/backend-development/references/backend-mindset.md +387 -0
  207. package/skills/tier-1/backend-development/references/backend-performance.md +397 -0
  208. package/skills/tier-1/backend-development/references/backend-security.md +290 -0
  209. package/skills/tier-1/backend-development/references/backend-technologies.md +256 -0
  210. package/skills/tier-1/backend-development/references/backend-testing.md +429 -0
  211. package/skills/tier-1/code-review/SKILL.md +143 -0
  212. package/skills/tier-1/code-review/references/code-review-reception.md +209 -0
  213. package/skills/tier-1/code-review/references/requesting-code-review.md +105 -0
  214. package/skills/tier-1/code-review/references/verification-before-completion.md +139 -0
  215. package/skills/tier-1/databases/SKILL.md +232 -0
  216. package/skills/tier-1/databases/references/mongodb-aggregation.md +447 -0
  217. package/skills/tier-1/databases/references/mongodb-atlas.md +465 -0
  218. package/skills/tier-1/databases/references/mongodb-crud.md +408 -0
  219. package/skills/tier-1/databases/references/mongodb-indexing.md +442 -0
  220. package/skills/tier-1/databases/references/postgresql-administration.md +594 -0
  221. package/skills/tier-1/databases/references/postgresql-performance.md +527 -0
  222. package/skills/tier-1/databases/references/postgresql-psql-cli.md +467 -0
  223. package/skills/tier-1/databases/references/postgresql-queries.md +475 -0
  224. package/skills/tier-1/databases/scripts/.coverage +0 -0
  225. package/skills/tier-1/databases/scripts/db_backup.py +502 -0
  226. package/skills/tier-1/databases/scripts/db_migrate.py +414 -0
  227. package/skills/tier-1/databases/scripts/db_performance_check.py +444 -0
  228. package/skills/tier-1/databases/scripts/requirements.txt +20 -0
  229. package/skills/tier-1/databases/scripts/tests/coverage-db.json +1 -0
  230. package/skills/tier-1/databases/scripts/tests/requirements.txt +4 -0
  231. package/skills/tier-1/databases/scripts/tests/test_db_backup.py +340 -0
  232. package/skills/tier-1/databases/scripts/tests/test_db_migrate.py +277 -0
  233. package/skills/tier-1/databases/scripts/tests/test_db_performance_check.py +370 -0
  234. package/skills/tier-1/debugging/SKILL.md +84 -0
  235. package/skills/tier-1/debugging/references/defense-in-depth.md +124 -0
  236. package/skills/tier-1/debugging/references/root-cause-tracing.md +122 -0
  237. package/skills/tier-1/debugging/references/systematic-debugging.md +102 -0
  238. package/skills/tier-1/debugging/references/verification.md +123 -0
  239. package/skills/tier-1/debugging/scripts/find-polluter.sh +63 -0
  240. package/skills/tier-1/debugging/scripts/find-polluter.test.md +102 -0
  241. package/skills/tier-1/devops/.env.example +76 -0
  242. package/skills/tier-1/devops/SKILL.md +285 -0
  243. package/skills/tier-1/devops/references/browser-rendering.md +305 -0
  244. package/skills/tier-1/devops/references/cloudflare-d1-kv.md +123 -0
  245. package/skills/tier-1/devops/references/cloudflare-platform.md +271 -0
  246. package/skills/tier-1/devops/references/cloudflare-r2-storage.md +280 -0
  247. package/skills/tier-1/devops/references/cloudflare-workers-advanced.md +312 -0
  248. package/skills/tier-1/devops/references/cloudflare-workers-apis.md +309 -0
  249. package/skills/tier-1/devops/references/cloudflare-workers-basics.md +418 -0
  250. package/skills/tier-1/devops/references/docker-basics.md +297 -0
  251. package/skills/tier-1/devops/references/docker-compose.md +292 -0
  252. package/skills/tier-1/devops/references/gcloud-platform.md +297 -0
  253. package/skills/tier-1/devops/references/gcloud-services.md +304 -0
  254. package/skills/tier-1/devops/scripts/cloudflare_deploy.py +269 -0
  255. package/skills/tier-1/devops/scripts/docker_optimize.py +320 -0
  256. package/skills/tier-1/devops/scripts/requirements.txt +20 -0
  257. package/skills/tier-1/devops/scripts/tests/requirements.txt +3 -0
  258. package/skills/tier-1/devops/scripts/tests/test_cloudflare_deploy.py +285 -0
  259. package/skills/tier-1/devops/scripts/tests/test_docker_optimize.py +436 -0
  260. package/skills/tier-1/frontend-development/SKILL.md +399 -0
  261. package/skills/tier-1/frontend-development/resources/common-patterns.md +331 -0
  262. package/skills/tier-1/frontend-development/resources/complete-examples.md +872 -0
  263. package/skills/tier-1/frontend-development/resources/component-patterns.md +502 -0
  264. package/skills/tier-1/frontend-development/resources/data-fetching.md +767 -0
  265. package/skills/tier-1/frontend-development/resources/file-organization.md +502 -0
  266. package/skills/tier-1/frontend-development/resources/loading-and-error-states.md +501 -0
  267. package/skills/tier-1/frontend-development/resources/performance.md +406 -0
  268. package/skills/tier-1/frontend-development/resources/routing-guide.md +364 -0
  269. package/skills/tier-1/frontend-development/resources/styling-guide.md +428 -0
  270. package/skills/tier-1/frontend-development/resources/typescript-standards.md +418 -0
  271. package/skills/tier-1/react-best-practices/AGENTS.md +2410 -0
  272. package/skills/tier-1/react-best-practices/README.md +123 -0
  273. package/skills/tier-1/react-best-practices/SKILL.md +125 -0
  274. package/skills/tier-1/react-best-practices/metadata.json +15 -0
  275. package/skills/tier-1/react-best-practices/rules/_sections.md +46 -0
  276. package/skills/tier-1/react-best-practices/rules/_template.md +28 -0
  277. package/skills/tier-1/react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  278. package/skills/tier-1/react-best-practices/rules/advanced-use-latest.md +49 -0
  279. package/skills/tier-1/react-best-practices/rules/async-api-routes.md +38 -0
  280. package/skills/tier-1/react-best-practices/rules/async-defer-await.md +80 -0
  281. package/skills/tier-1/react-best-practices/rules/async-dependencies.md +36 -0
  282. package/skills/tier-1/react-best-practices/rules/async-parallel.md +28 -0
  283. package/skills/tier-1/react-best-practices/rules/async-suspense-boundaries.md +99 -0
  284. package/skills/tier-1/react-best-practices/rules/bundle-barrel-imports.md +59 -0
  285. package/skills/tier-1/react-best-practices/rules/bundle-conditional.md +31 -0
  286. package/skills/tier-1/react-best-practices/rules/bundle-defer-third-party.md +49 -0
  287. package/skills/tier-1/react-best-practices/rules/bundle-dynamic-imports.md +35 -0
  288. package/skills/tier-1/react-best-practices/rules/bundle-preload.md +50 -0
  289. package/skills/tier-1/react-best-practices/rules/client-event-listeners.md +74 -0
  290. package/skills/tier-1/react-best-practices/rules/client-localstorage-schema.md +71 -0
  291. package/skills/tier-1/react-best-practices/rules/client-passive-event-listeners.md +48 -0
  292. package/skills/tier-1/react-best-practices/rules/client-swr-dedup.md +56 -0
  293. package/skills/tier-1/react-best-practices/rules/js-batch-dom-css.md +82 -0
  294. package/skills/tier-1/react-best-practices/rules/js-cache-function-results.md +80 -0
  295. package/skills/tier-1/react-best-practices/rules/js-cache-property-access.md +28 -0
  296. package/skills/tier-1/react-best-practices/rules/js-cache-storage.md +70 -0
  297. package/skills/tier-1/react-best-practices/rules/js-combine-iterations.md +32 -0
  298. package/skills/tier-1/react-best-practices/rules/js-early-exit.md +50 -0
  299. package/skills/tier-1/react-best-practices/rules/js-hoist-regexp.md +45 -0
  300. package/skills/tier-1/react-best-practices/rules/js-index-maps.md +37 -0
  301. package/skills/tier-1/react-best-practices/rules/js-length-check-first.md +49 -0
  302. package/skills/tier-1/react-best-practices/rules/js-min-max-loop.md +82 -0
  303. package/skills/tier-1/react-best-practices/rules/js-set-map-lookups.md +24 -0
  304. package/skills/tier-1/react-best-practices/rules/js-tosorted-immutable.md +57 -0
  305. package/skills/tier-1/react-best-practices/rules/rendering-activity.md +26 -0
  306. package/skills/tier-1/react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
  307. package/skills/tier-1/react-best-practices/rules/rendering-conditional-render.md +40 -0
  308. package/skills/tier-1/react-best-practices/rules/rendering-content-visibility.md +38 -0
  309. package/skills/tier-1/react-best-practices/rules/rendering-hoist-jsx.md +46 -0
  310. package/skills/tier-1/react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
  311. package/skills/tier-1/react-best-practices/rules/rendering-svg-precision.md +28 -0
  312. package/skills/tier-1/react-best-practices/rules/rerender-defer-reads.md +39 -0
  313. package/skills/tier-1/react-best-practices/rules/rerender-dependencies.md +45 -0
  314. package/skills/tier-1/react-best-practices/rules/rerender-derived-state.md +29 -0
  315. package/skills/tier-1/react-best-practices/rules/rerender-functional-setstate.md +74 -0
  316. package/skills/tier-1/react-best-practices/rules/rerender-lazy-state-init.md +58 -0
  317. package/skills/tier-1/react-best-practices/rules/rerender-memo.md +44 -0
  318. package/skills/tier-1/react-best-practices/rules/rerender-transitions.md +40 -0
  319. package/skills/tier-1/react-best-practices/rules/server-after-nonblocking.md +73 -0
  320. package/skills/tier-1/react-best-practices/rules/server-cache-lru.md +41 -0
  321. package/skills/tier-1/react-best-practices/rules/server-cache-react.md +76 -0
  322. package/skills/tier-1/react-best-practices/rules/server-parallel-fetching.md +83 -0
  323. package/skills/tier-1/react-best-practices/rules/server-serialization.md +38 -0
  324. package/skills/tier-1/research/SKILL.md +168 -0
  325. package/skills/tier-1/security-review/SKILL.md +495 -0
  326. package/skills/tier-1/security-review/cloud-infrastructure-security.md +361 -0
  327. package/skills/tier-1/sequential-thinking/.env.example +8 -0
  328. package/skills/tier-1/sequential-thinking/README.md +183 -0
  329. package/skills/tier-1/sequential-thinking/SKILL.md +94 -0
  330. package/skills/tier-1/sequential-thinking/package.json +31 -0
  331. package/skills/tier-1/sequential-thinking/references/advanced-strategies.md +79 -0
  332. package/skills/tier-1/sequential-thinking/references/advanced-techniques.md +76 -0
  333. package/skills/tier-1/sequential-thinking/references/core-patterns.md +95 -0
  334. package/skills/tier-1/sequential-thinking/references/examples-api.md +88 -0
  335. package/skills/tier-1/sequential-thinking/references/examples-architecture.md +94 -0
  336. package/skills/tier-1/sequential-thinking/references/examples-debug.md +90 -0
  337. package/skills/tier-1/sequential-thinking/scripts/format-thought.js +159 -0
  338. package/skills/tier-1/sequential-thinking/scripts/process-thought.js +236 -0
  339. package/skills/tier-1/sequential-thinking/tests/format-thought.test.js +133 -0
  340. package/skills/tier-1/sequential-thinking/tests/process-thought.test.js +215 -0
  341. package/skills/tier-1/tdd-workflow/SKILL.md +410 -0
  342. package/skills/tier-1/testing/SKILL.md +56 -0
  343. package/skills/tier-1/ui-styling/LICENSE.txt +202 -0
  344. package/skills/tier-1/ui-styling/SKILL.md +321 -0
  345. package/skills/tier-1/ui-styling/references/canvas-design-system.md +320 -0
  346. package/skills/tier-1/ui-styling/references/shadcn-accessibility.md +471 -0
  347. package/skills/tier-1/ui-styling/references/shadcn-components.md +424 -0
  348. package/skills/tier-1/ui-styling/references/shadcn-theming.md +373 -0
  349. package/skills/tier-1/ui-styling/references/tailwind-customization.md +483 -0
  350. package/skills/tier-1/ui-styling/references/tailwind-responsive.md +382 -0
  351. package/skills/tier-1/ui-styling/references/tailwind-utilities.md +455 -0
  352. package/skills/tier-1/ui-styling/scripts/.coverage +0 -0
  353. package/skills/tier-1/ui-styling/scripts/requirements.txt +17 -0
  354. package/skills/tier-1/ui-styling/scripts/shadcn_add.py +292 -0
  355. package/skills/tier-1/ui-styling/scripts/tailwind_config_gen.py +456 -0
  356. package/skills/tier-1/ui-styling/scripts/tests/coverage-ui.json +1 -0
  357. package/skills/tier-1/ui-styling/scripts/tests/requirements.txt +3 -0
  358. package/skills/tier-1/ui-styling/scripts/tests/test_shadcn_add.py +266 -0
  359. package/skills/tier-1/ui-styling/scripts/tests/test_tailwind_config_gen.py +336 -0
  360. package/skills/tier-1/ui-ux-pro-max/SKILL.md +659 -0
  361. package/skills/tier-1/ui-ux-pro-max/data/_sync_all.py +414 -0
  362. package/skills/tier-1/ui-ux-pro-max/data/app-interface.csv +31 -0
  363. package/skills/tier-1/ui-ux-pro-max/data/charts.csv +26 -0
  364. package/skills/tier-1/ui-ux-pro-max/data/colors.csv +162 -0
  365. package/skills/tier-1/ui-ux-pro-max/data/design.csv +1776 -0
  366. package/skills/tier-1/ui-ux-pro-max/data/draft.csv +1779 -0
  367. package/skills/tier-1/ui-ux-pro-max/data/google-fonts.csv +1924 -0
  368. package/skills/tier-1/ui-ux-pro-max/data/icons.csv +106 -0
  369. package/skills/tier-1/ui-ux-pro-max/data/landing.csv +35 -0
  370. package/skills/tier-1/ui-ux-pro-max/data/products.csv +162 -0
  371. package/skills/tier-1/ui-ux-pro-max/data/react-performance.csv +45 -0
  372. package/skills/tier-1/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  373. package/skills/tier-1/ui-ux-pro-max/data/styles.csv +85 -0
  374. package/skills/tier-1/ui-ux-pro-max/data/typography.csv +74 -0
  375. package/skills/tier-1/ui-ux-pro-max/data/ui-reasoning.csv +162 -0
  376. package/skills/tier-1/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  377. package/skills/tier-1/ui-ux-pro-max/scripts/core.py +247 -0
  378. package/skills/tier-1/ui-ux-pro-max/scripts/design_system.py +1067 -0
  379. package/skills/tier-1/ui-ux-pro-max/scripts/search.py +114 -0
  380. package/skills/tier-1/ui-ux-pro-max/templates/base/quick-reference.md +297 -0
  381. package/skills/tier-1/ui-ux-pro-max/templates/base/skill-content.md +358 -0
  382. package/skills/tier-1/ui-ux-pro-max/templates/platforms/agent.json +21 -0
  383. package/skills/tier-1/ui-ux-pro-max/templates/platforms/claude.json +21 -0
  384. package/skills/tier-1/ui-ux-pro-max/templates/platforms/codebuddy.json +21 -0
  385. package/skills/tier-1/ui-ux-pro-max/templates/platforms/codex.json +21 -0
  386. package/skills/tier-1/ui-ux-pro-max/templates/platforms/continue.json +21 -0
  387. package/skills/tier-1/ui-ux-pro-max/templates/platforms/copilot.json +18 -0
  388. package/skills/tier-1/ui-ux-pro-max/templates/platforms/cursor.json +18 -0
  389. package/skills/tier-1/ui-ux-pro-max/templates/platforms/droid.json +21 -0
  390. package/skills/tier-1/ui-ux-pro-max/templates/platforms/gemini.json +21 -0
  391. package/skills/tier-1/ui-ux-pro-max/templates/platforms/kiro.json +18 -0
  392. package/skills/tier-1/ui-ux-pro-max/templates/platforms/opencode.json +21 -0
  393. package/skills/tier-1/ui-ux-pro-max/templates/platforms/qoder.json +21 -0
  394. package/skills/tier-1/ui-ux-pro-max/templates/platforms/roocode.json +18 -0
  395. package/skills/tier-1/ui-ux-pro-max/templates/platforms/trae.json +21 -0
  396. package/skills/tier-1/ui-ux-pro-max/templates/platforms/windsurf.json +18 -0
  397. package/skills/tier-1/web-frameworks/SKILL.md +324 -0
  398. package/skills/tier-1/web-frameworks/references/nextjs-app-router.md +465 -0
  399. package/skills/tier-1/web-frameworks/references/nextjs-data-fetching.md +459 -0
  400. package/skills/tier-1/web-frameworks/references/nextjs-optimization.md +511 -0
  401. package/skills/tier-1/web-frameworks/references/nextjs-server-components.md +495 -0
  402. package/skills/tier-1/web-frameworks/references/remix-icon-integration.md +603 -0
  403. package/skills/tier-1/web-frameworks/references/turborepo-caching.md +551 -0
  404. package/skills/tier-1/web-frameworks/references/turborepo-pipelines.md +517 -0
  405. package/skills/tier-1/web-frameworks/references/turborepo-setup.md +542 -0
  406. package/skills/tier-1/web-frameworks/scripts/.coverage +0 -0
  407. package/skills/tier-1/web-frameworks/scripts/__init__.py +0 -0
  408. package/skills/tier-1/web-frameworks/scripts/nextjs_init.py +547 -0
  409. package/skills/tier-1/web-frameworks/scripts/requirements.txt +16 -0
  410. package/skills/tier-1/web-frameworks/scripts/tests/coverage-web.json +1 -0
  411. package/skills/tier-1/web-frameworks/scripts/tests/requirements.txt +3 -0
  412. package/skills/tier-1/web-frameworks/scripts/tests/test_nextjs_init.py +319 -0
  413. package/skills/tier-1/web-frameworks/scripts/tests/test_turborepo_migrate.py +374 -0
  414. package/skills/tier-1/web-frameworks/scripts/turborepo_migrate.py +394 -0
  415. package/skills/tier-2/ai-multimodal/.env.example +97 -0
  416. package/skills/tier-2/ai-multimodal/SKILL.md +353 -0
  417. package/skills/tier-2/ai-multimodal/references/audio-processing.md +373 -0
  418. package/skills/tier-2/ai-multimodal/references/image-generation.md +558 -0
  419. package/skills/tier-2/ai-multimodal/references/video-analysis.md +498 -0
  420. package/skills/tier-2/ai-multimodal/references/vision-understanding.md +479 -0
  421. package/skills/tier-2/ai-multimodal/scripts/.coverage +0 -0
  422. package/skills/tier-2/ai-multimodal/scripts/document_converter.py +395 -0
  423. package/skills/tier-2/ai-multimodal/scripts/gemini_batch_process.py +480 -0
  424. package/skills/tier-2/ai-multimodal/scripts/media_optimizer.py +506 -0
  425. package/skills/tier-2/ai-multimodal/scripts/requirements.txt +26 -0
  426. package/skills/tier-2/ai-multimodal/scripts/tests/.coverage +0 -0
  427. package/skills/tier-2/ai-multimodal/scripts/tests/requirements.txt +20 -0
  428. package/skills/tier-2/ai-multimodal/scripts/tests/test_document_converter.py +74 -0
  429. package/skills/tier-2/ai-multimodal/scripts/tests/test_failures.log +258 -0
  430. package/skills/tier-2/ai-multimodal/scripts/tests/test_gemini_batch_process.py +362 -0
  431. package/skills/tier-2/ai-multimodal/scripts/tests/test_media_optimizer.py +373 -0
  432. package/skills/tier-2/autonomous-loops/SKILL.md +610 -0
  433. package/skills/tier-2/backend-patterns/SKILL.md +598 -0
  434. package/skills/tier-2/better-auth/SKILL.md +204 -0
  435. package/skills/tier-2/better-auth/references/advanced-features.md +553 -0
  436. package/skills/tier-2/better-auth/references/database-integration.md +577 -0
  437. package/skills/tier-2/better-auth/references/email-password-auth.md +416 -0
  438. package/skills/tier-2/better-auth/references/oauth-providers.md +430 -0
  439. package/skills/tier-2/better-auth/scripts/.coverage +0 -0
  440. package/skills/tier-2/better-auth/scripts/better_auth_init.py +521 -0
  441. package/skills/tier-2/better-auth/scripts/requirements.txt +15 -0
  442. package/skills/tier-2/better-auth/scripts/tests/.coverage +0 -0
  443. package/skills/tier-2/better-auth/scripts/tests/test_better_auth_init.py +421 -0
  444. package/skills/tier-2/brand/SKILL.md +97 -0
  445. package/skills/tier-2/brand/references/approval-checklist.md +169 -0
  446. package/skills/tier-2/brand/references/asset-organization.md +157 -0
  447. package/skills/tier-2/brand/references/brand-guideline-template.md +140 -0
  448. package/skills/tier-2/brand/references/color-palette-management.md +186 -0
  449. package/skills/tier-2/brand/references/consistency-checklist.md +94 -0
  450. package/skills/tier-2/brand/references/logo-usage-rules.md +185 -0
  451. package/skills/tier-2/brand/references/messaging-framework.md +85 -0
  452. package/skills/tier-2/brand/references/typography-specifications.md +214 -0
  453. package/skills/tier-2/brand/references/update.md +118 -0
  454. package/skills/tier-2/brand/references/visual-identity.md +96 -0
  455. package/skills/tier-2/brand/references/voice-framework.md +88 -0
  456. package/skills/tier-2/brand/scripts/extract-colors.cjs +341 -0
  457. package/skills/tier-2/brand/scripts/inject-brand-context.cjs +349 -0
  458. package/skills/tier-2/brand/scripts/sync-brand-to-tokens.cjs +266 -0
  459. package/skills/tier-2/brand/scripts/validate-asset.cjs +387 -0
  460. package/skills/tier-2/brand/templates/brand-guidelines-starter.md +275 -0
  461. package/skills/tier-2/claude-code/SKILL.md +188 -0
  462. package/skills/tier-2/claude-code/references/advanced-features.md +399 -0
  463. package/skills/tier-2/claude-code/references/agent-skills.md +399 -0
  464. package/skills/tier-2/claude-code/references/api-reference.md +498 -0
  465. package/skills/tier-2/claude-code/references/best-practices.md +447 -0
  466. package/skills/tier-2/claude-code/references/cicd-integration.md +428 -0
  467. package/skills/tier-2/claude-code/references/configuration.md +480 -0
  468. package/skills/tier-2/claude-code/references/enterprise-features.md +472 -0
  469. package/skills/tier-2/claude-code/references/getting-started.md +252 -0
  470. package/skills/tier-2/claude-code/references/hooks-and-plugins.md +441 -0
  471. package/skills/tier-2/claude-code/references/ide-integration.md +316 -0
  472. package/skills/tier-2/claude-code/references/mcp-integration.md +386 -0
  473. package/skills/tier-2/claude-code/references/slash-commands.md +489 -0
  474. package/skills/tier-2/claude-code/references/troubleshooting.md +456 -0
  475. package/skills/tier-2/codebase-onboarding/SKILL.md +233 -0
  476. package/skills/tier-2/coding-standards/SKILL.md +530 -0
  477. package/skills/tier-2/continuous-learning/SKILL.md +365 -0
  478. package/skills/tier-2/continuous-learning/agents/observer-loop.sh +191 -0
  479. package/skills/tier-2/continuous-learning/agents/observer.md +198 -0
  480. package/skills/tier-2/continuous-learning/agents/session-guardian.sh +150 -0
  481. package/skills/tier-2/continuous-learning/agents/start-observer.sh +240 -0
  482. package/skills/tier-2/continuous-learning/config.json +8 -0
  483. package/skills/tier-2/continuous-learning/hooks/observe.sh +412 -0
  484. package/skills/tier-2/continuous-learning/scripts/detect-project.sh +228 -0
  485. package/skills/tier-2/continuous-learning/scripts/instinct-cli.py +1426 -0
  486. package/skills/tier-2/continuous-learning/scripts/test_parse_instinct.py +984 -0
  487. package/skills/tier-2/database-migrations/SKILL.md +429 -0
  488. package/skills/tier-2/deployment-patterns/SKILL.md +427 -0
  489. package/skills/tier-2/design/SKILL.md +302 -0
  490. package/skills/tier-2/design/data/cip/deliverables.csv +51 -0
  491. package/skills/tier-2/design/data/cip/industries.csv +21 -0
  492. package/skills/tier-2/design/data/cip/mockup-contexts.csv +21 -0
  493. package/skills/tier-2/design/data/cip/styles.csv +21 -0
  494. package/skills/tier-2/design/data/icon/styles.csv +16 -0
  495. package/skills/tier-2/design/data/logo/colors.csv +56 -0
  496. package/skills/tier-2/design/data/logo/industries.csv +56 -0
  497. package/skills/tier-2/design/data/logo/styles.csv +56 -0
  498. package/skills/tier-2/design/references/banner-sizes-and-styles.md +118 -0
  499. package/skills/tier-2/design/references/cip-deliverable-guide.md +95 -0
  500. package/skills/tier-2/design/references/cip-design.md +121 -0
  501. package/skills/tier-2/design/references/cip-prompt-engineering.md +84 -0
  502. package/skills/tier-2/design/references/cip-style-guide.md +68 -0
  503. package/skills/tier-2/design/references/design-routing.md +207 -0
  504. package/skills/tier-2/design/references/icon-design.md +122 -0
  505. package/skills/tier-2/design/references/logo-color-psychology.md +101 -0
  506. package/skills/tier-2/design/references/logo-design.md +92 -0
  507. package/skills/tier-2/design/references/logo-prompt-engineering.md +158 -0
  508. package/skills/tier-2/design/references/logo-style-guide.md +109 -0
  509. package/skills/tier-2/design/references/slides-copywriting-formulas.md +84 -0
  510. package/skills/tier-2/design/references/slides-create.md +4 -0
  511. package/skills/tier-2/design/references/slides-html-template.md +295 -0
  512. package/skills/tier-2/design/references/slides-layout-patterns.md +137 -0
  513. package/skills/tier-2/design/references/slides-strategies.md +94 -0
  514. package/skills/tier-2/design/references/slides.md +42 -0
  515. package/skills/tier-2/design/references/social-photos-design.md +329 -0
  516. package/skills/tier-2/design/scripts/cip/core.py +215 -0
  517. package/skills/tier-2/design/scripts/cip/generate.py +484 -0
  518. package/skills/tier-2/design/scripts/cip/render-html.py +424 -0
  519. package/skills/tier-2/design/scripts/cip/search.py +127 -0
  520. package/skills/tier-2/design/scripts/icon/generate.py +487 -0
  521. package/skills/tier-2/design/scripts/logo/core.py +175 -0
  522. package/skills/tier-2/design/scripts/logo/generate.py +362 -0
  523. package/skills/tier-2/design/scripts/logo/search.py +114 -0
  524. package/skills/tier-2/design-system/SKILL.md +244 -0
  525. package/skills/tier-2/design-system/data/slide-backgrounds.csv +11 -0
  526. package/skills/tier-2/design-system/data/slide-charts.csv +26 -0
  527. package/skills/tier-2/design-system/data/slide-color-logic.csv +14 -0
  528. package/skills/tier-2/design-system/data/slide-copy.csv +26 -0
  529. package/skills/tier-2/design-system/data/slide-layout-logic.csv +16 -0
  530. package/skills/tier-2/design-system/data/slide-layouts.csv +26 -0
  531. package/skills/tier-2/design-system/data/slide-strategies.csv +16 -0
  532. package/skills/tier-2/design-system/data/slide-typography.csv +15 -0
  533. package/skills/tier-2/design-system/references/component-specs.md +236 -0
  534. package/skills/tier-2/design-system/references/component-tokens.md +214 -0
  535. package/skills/tier-2/design-system/references/primitive-tokens.md +203 -0
  536. package/skills/tier-2/design-system/references/semantic-tokens.md +215 -0
  537. package/skills/tier-2/design-system/references/states-and-variants.md +241 -0
  538. package/skills/tier-2/design-system/references/tailwind-integration.md +251 -0
  539. package/skills/tier-2/design-system/references/token-architecture.md +224 -0
  540. package/skills/tier-2/design-system/scripts/embed-tokens.cjs +99 -0
  541. package/skills/tier-2/design-system/scripts/fetch-background.py +317 -0
  542. package/skills/tier-2/design-system/scripts/generate-slide.py +753 -0
  543. package/skills/tier-2/design-system/scripts/generate-tokens.cjs +205 -0
  544. package/skills/tier-2/design-system/scripts/html-token-validator.py +327 -0
  545. package/skills/tier-2/design-system/scripts/search-slides.py +218 -0
  546. package/skills/tier-2/design-system/scripts/slide-token-validator.py +35 -0
  547. package/skills/tier-2/design-system/scripts/slide_search_core.py +453 -0
  548. package/skills/tier-2/design-system/scripts/validate-tokens.cjs +251 -0
  549. package/skills/tier-2/design-system/templates/design-tokens-starter.json +143 -0
  550. package/skills/tier-2/docker-patterns/SKILL.md +364 -0
  551. package/skills/tier-2/e2e-testing/SKILL.md +326 -0
  552. package/skills/tier-2/eval-harness/SKILL.md +270 -0
  553. package/skills/tier-2/frontend-patterns/SKILL.md +642 -0
  554. package/skills/tier-2/google-adk-python/SKILL.md +242 -0
  555. package/skills/tier-2/mcp-management/README.md +219 -0
  556. package/skills/tier-2/mcp-management/SKILL.md +209 -0
  557. package/skills/tier-2/mcp-management/assets/tools.json +3146 -0
  558. package/skills/tier-2/mcp-management/references/configuration.md +114 -0
  559. package/skills/tier-2/mcp-management/references/gemini-cli-integration.md +215 -0
  560. package/skills/tier-2/mcp-management/references/mcp-protocol.md +116 -0
  561. package/skills/tier-2/mcp-management/scripts/.env.example +10 -0
  562. package/skills/tier-2/mcp-management/scripts/cli.ts +195 -0
  563. package/skills/tier-2/mcp-management/scripts/dist/analyze-tools.js +70 -0
  564. package/skills/tier-2/mcp-management/scripts/dist/cli.js +127 -0
  565. package/skills/tier-2/mcp-management/scripts/dist/mcp-client.js +115 -0
  566. package/skills/tier-2/mcp-management/scripts/mcp-client.ts +230 -0
  567. package/skills/tier-2/mcp-management/scripts/package.json +20 -0
  568. package/skills/tier-2/mcp-management/scripts/tsconfig.json +15 -0
  569. package/skills/tier-2/mcp-server-patterns/SKILL.md +67 -0
  570. package/skills/tier-2/media-processing/SKILL.md +358 -0
  571. package/skills/tier-2/media-processing/references/ffmpeg-encoding.md +358 -0
  572. package/skills/tier-2/media-processing/references/ffmpeg-filters.md +503 -0
  573. package/skills/tier-2/media-processing/references/ffmpeg-streaming.md +403 -0
  574. package/skills/tier-2/media-processing/references/format-compatibility.md +375 -0
  575. package/skills/tier-2/media-processing/references/imagemagick-batch.md +612 -0
  576. package/skills/tier-2/media-processing/references/imagemagick-editing.md +623 -0
  577. package/skills/tier-2/media-processing/scripts/batch_resize.py +342 -0
  578. package/skills/tier-2/media-processing/scripts/media_convert.py +311 -0
  579. package/skills/tier-2/media-processing/scripts/requirements.txt +24 -0
  580. package/skills/tier-2/media-processing/scripts/tests/.coverage +0 -0
  581. package/skills/tier-2/media-processing/scripts/tests/requirements.txt +2 -0
  582. package/skills/tier-2/media-processing/scripts/tests/test_batch_resize.py +372 -0
  583. package/skills/tier-2/media-processing/scripts/tests/test_media_convert.py +259 -0
  584. package/skills/tier-2/media-processing/scripts/tests/test_video_optimize.py +397 -0
  585. package/skills/tier-2/media-processing/scripts/video_optimize.py +414 -0
  586. package/skills/tier-2/mobile-development/SKILL.md +212 -0
  587. package/skills/tier-2/mobile-development/references/mobile-android.md +604 -0
  588. package/skills/tier-2/mobile-development/references/mobile-best-practices.md +545 -0
  589. package/skills/tier-2/mobile-development/references/mobile-debugging.md +1089 -0
  590. package/skills/tier-2/mobile-development/references/mobile-frameworks.md +465 -0
  591. package/skills/tier-2/mobile-development/references/mobile-ios.md +496 -0
  592. package/skills/tier-2/mobile-development/references/mobile-mindset.md +544 -0
  593. package/skills/tier-2/payment-integration/README.md +185 -0
  594. package/skills/tier-2/payment-integration/SKILL.md +118 -0
  595. package/skills/tier-2/payment-integration/references/polar/benefits.md +396 -0
  596. package/skills/tier-2/payment-integration/references/polar/best-practices.md +482 -0
  597. package/skills/tier-2/payment-integration/references/polar/checkouts.md +266 -0
  598. package/skills/tier-2/payment-integration/references/polar/overview.md +184 -0
  599. package/skills/tier-2/payment-integration/references/polar/products.md +244 -0
  600. package/skills/tier-2/payment-integration/references/polar/sdk.md +436 -0
  601. package/skills/tier-2/payment-integration/references/polar/subscriptions.md +340 -0
  602. package/skills/tier-2/payment-integration/references/polar/webhooks.md +405 -0
  603. package/skills/tier-2/payment-integration/references/sepay/api.md +140 -0
  604. package/skills/tier-2/payment-integration/references/sepay/best-practices.md +337 -0
  605. package/skills/tier-2/payment-integration/references/sepay/overview.md +138 -0
  606. package/skills/tier-2/payment-integration/references/sepay/qr-codes.md +228 -0
  607. package/skills/tier-2/payment-integration/references/sepay/sdk.md +213 -0
  608. package/skills/tier-2/payment-integration/references/sepay/webhooks.md +208 -0
  609. package/skills/tier-2/payment-integration/scripts/.env.example +20 -0
  610. package/skills/tier-2/payment-integration/scripts/checkout-helper.js +244 -0
  611. package/skills/tier-2/payment-integration/scripts/package.json +17 -0
  612. package/skills/tier-2/payment-integration/scripts/polar-webhook-verify.js +202 -0
  613. package/skills/tier-2/payment-integration/scripts/sepay-webhook-verify.js +193 -0
  614. package/skills/tier-2/payment-integration/scripts/test-scripts.js +237 -0
  615. package/skills/tier-2/planning/SKILL.md +88 -0
  616. package/skills/tier-2/planning/references/codebase-understanding.md +62 -0
  617. package/skills/tier-2/planning/references/output-standards.md +87 -0
  618. package/skills/tier-2/planning/references/plan-organization.md +100 -0
  619. package/skills/tier-2/planning/references/research-phase.md +49 -0
  620. package/skills/tier-2/planning/references/solution-design.md +63 -0
  621. package/skills/tier-2/postgres-patterns/SKILL.md +147 -0
  622. package/skills/tier-2/problem-solving/SKILL.md +96 -0
  623. package/skills/tier-2/problem-solving/references/attribution.md +69 -0
  624. package/skills/tier-2/problem-solving/references/collision-zone-thinking.md +79 -0
  625. package/skills/tier-2/problem-solving/references/inversion-exercise.md +91 -0
  626. package/skills/tier-2/problem-solving/references/meta-pattern-recognition.md +87 -0
  627. package/skills/tier-2/problem-solving/references/scale-game.md +95 -0
  628. package/skills/tier-2/problem-solving/references/simplification-cascades.md +80 -0
  629. package/skills/tier-2/problem-solving/references/when-stuck.md +72 -0
  630. package/skills/tier-2/strategic-compact/SKILL.md +131 -0
  631. package/skills/tier-2/strategic-compact/suggest-compact.sh +54 -0
  632. package/skills/tier-2/verification-loop/SKILL.md +126 -0
  633. package/skills/tier-3/agentic-engineering/SKILL.md +63 -0
  634. package/skills/tier-3/banner-design/SKILL.md +192 -0
  635. package/skills/tier-3/banner-design/references/banner-sizes-and-styles.md +118 -0
  636. package/skills/tier-3/cost-aware-llm-pipeline/SKILL.md +183 -0
  637. package/skills/tier-3/django-patterns/SKILL.md +734 -0
  638. package/skills/tier-3/golang-patterns/SKILL.md +674 -0
  639. package/skills/tier-3/kotlin-patterns/SKILL.md +711 -0
  640. package/skills/tier-3/laravel-patterns/SKILL.md +415 -0
  641. package/skills/tier-3/prompt-optimizer/SKILL.md +397 -0
  642. package/skills/tier-3/python-patterns/SKILL.md +750 -0
  643. package/skills/tier-3/pytorch-patterns/SKILL.md +396 -0
  644. package/skills/tier-3/rust-patterns/SKILL.md +499 -0
  645. package/skills/tier-3/shopify/README.md +66 -0
  646. package/skills/tier-3/shopify/SKILL.md +319 -0
  647. package/skills/tier-3/shopify/references/app-development.md +470 -0
  648. package/skills/tier-3/shopify/references/extensions.md +493 -0
  649. package/skills/tier-3/shopify/references/themes.md +498 -0
  650. package/skills/tier-3/shopify/scripts/.coverage +0 -0
  651. package/skills/tier-3/shopify/scripts/requirements.txt +19 -0
  652. package/skills/tier-3/shopify/scripts/shopify_init.py +423 -0
  653. package/skills/tier-3/shopify/scripts/tests/.coverage +0 -0
  654. package/skills/tier-3/shopify/scripts/tests/test_shopify_init.py +385 -0
  655. package/skills/tier-3/slides/SKILL.md +42 -0
  656. package/skills/tier-3/slides/references/copywriting-formulas.md +84 -0
  657. package/skills/tier-3/slides/references/create.md +4 -0
  658. package/skills/tier-3/slides/references/html-template.md +295 -0
  659. package/skills/tier-3/slides/references/layout-patterns.md +137 -0
  660. package/skills/tier-3/slides/references/slide-strategies.md +94 -0
  661. package/skills/tier-3/springboot-patterns/SKILL.md +314 -0
  662. package/skills/tier-3/swiftui-patterns/SKILL.md +259 -0
  663. package/skills/tier-3/threejs/SKILL.md +89 -0
  664. package/skills/tier-3/threejs/references/01-getting-started.md +177 -0
  665. package/skills/tier-3/threejs/references/02-loaders.md +169 -0
  666. package/skills/tier-3/threejs/references/03-textures.md +170 -0
  667. package/skills/tier-3/threejs/references/04-cameras.md +195 -0
  668. package/skills/tier-3/threejs/references/05-lights.md +183 -0
  669. package/skills/tier-3/threejs/references/06-animations.md +214 -0
  670. package/skills/tier-3/threejs/references/07-math.md +260 -0
  671. package/skills/tier-3/threejs/references/08-interaction.md +267 -0
  672. package/skills/tier-3/threejs/references/09-postprocessing.md +240 -0
  673. package/skills/tier-3/threejs/references/10-controls.md +259 -0
  674. package/skills/tier-3/threejs/references/11-materials-advanced.md +270 -0
  675. package/skills/tier-3/threejs/references/12-performance.md +269 -0
  676. package/skills/tier-3/threejs/references/13-node-materials.md +298 -0
  677. package/skills/tier-3/threejs/references/14-physics-vr.md +304 -0
  678. package/skills/tier-3/threejs/references/15-specialized-loaders.md +333 -0
  679. package/skills/tier-3/threejs/references/16-webgpu.md +302 -0
  680. package/skills/tier-3/vercel-deploy/SKILL.md +112 -0
  681. package/skills/tier-3/vercel-deploy/scripts/deploy.sh +249 -0
  682. package/workflows/development-rules.md +49 -0
  683. package/workflows/orchestration-protocol.md +16 -0
  684. package/workflows/primary-workflow.md +52 -0
@@ -0,0 +1,453 @@
1
+ #!/usr/bin/env python3
2
+ # -*- coding: utf-8 -*-
3
+ """
4
+ Slide Search Core - BM25 search engine for slide design databases
5
+ """
6
+
7
+ import csv
8
+ import re
9
+ from pathlib import Path
10
+ from math import log
11
+ from collections import defaultdict
12
+
13
+ # ============ CONFIGURATION ============
14
+ DATA_DIR = Path(__file__).parent.parent / "data"
15
+ MAX_RESULTS = 3
16
+
17
+ CSV_CONFIG = {
18
+ "strategy": {
19
+ "file": "slide-strategies.csv",
20
+ "search_cols": ["strategy_name", "keywords", "goal", "audience", "narrative_arc"],
21
+ "output_cols": ["strategy_name", "keywords", "slide_count", "structure", "goal", "audience", "tone", "narrative_arc", "sources"]
22
+ },
23
+ "layout": {
24
+ "file": "slide-layouts.csv",
25
+ "search_cols": ["layout_name", "keywords", "use_case", "recommended_for"],
26
+ "output_cols": ["layout_name", "keywords", "use_case", "content_zones", "visual_weight", "cta_placement", "recommended_for", "avoid_for", "css_structure"]
27
+ },
28
+ "copy": {
29
+ "file": "slide-copy.csv",
30
+ "search_cols": ["formula_name", "keywords", "use_case", "emotion_trigger", "slide_type"],
31
+ "output_cols": ["formula_name", "keywords", "components", "use_case", "example_template", "emotion_trigger", "slide_type", "source"]
32
+ },
33
+ "chart": {
34
+ "file": "slide-charts.csv",
35
+ "search_cols": ["chart_type", "keywords", "best_for", "when_to_use", "slide_context"],
36
+ "output_cols": ["chart_type", "keywords", "best_for", "data_type", "when_to_use", "when_to_avoid", "max_categories", "slide_context", "css_implementation", "accessibility_notes"]
37
+ }
38
+ }
39
+
40
+ AVAILABLE_DOMAINS = list(CSV_CONFIG.keys())
41
+
42
+
43
+ # ============ BM25 IMPLEMENTATION ============
44
+ class BM25:
45
+ """BM25 ranking algorithm for text search"""
46
+
47
+ def __init__(self, k1=1.5, b=0.75):
48
+ self.k1 = k1
49
+ self.b = b
50
+ self.corpus = []
51
+ self.doc_lengths = []
52
+ self.avgdl = 0
53
+ self.idf = {}
54
+ self.doc_freqs = defaultdict(int)
55
+ self.N = 0
56
+
57
+ def tokenize(self, text):
58
+ """Lowercase, split, remove punctuation, filter short words"""
59
+ text = re.sub(r'[^\w\s]', ' ', str(text).lower())
60
+ return [w for w in text.split() if len(w) > 2]
61
+
62
+ def fit(self, documents):
63
+ """Build BM25 index from documents"""
64
+ self.corpus = [self.tokenize(doc) for doc in documents]
65
+ self.N = len(self.corpus)
66
+ if self.N == 0:
67
+ return
68
+ self.doc_lengths = [len(doc) for doc in self.corpus]
69
+ self.avgdl = sum(self.doc_lengths) / self.N
70
+
71
+ for doc in self.corpus:
72
+ seen = set()
73
+ for word in doc:
74
+ if word not in seen:
75
+ self.doc_freqs[word] += 1
76
+ seen.add(word)
77
+
78
+ for word, freq in self.doc_freqs.items():
79
+ self.idf[word] = log((self.N - freq + 0.5) / (freq + 0.5) + 1)
80
+
81
+ def score(self, query):
82
+ """Score all documents against query"""
83
+ query_tokens = self.tokenize(query)
84
+ scores = []
85
+
86
+ for idx, doc in enumerate(self.corpus):
87
+ score = 0
88
+ doc_len = self.doc_lengths[idx]
89
+ term_freqs = defaultdict(int)
90
+ for word in doc:
91
+ term_freqs[word] += 1
92
+
93
+ for token in query_tokens:
94
+ if token in self.idf:
95
+ tf = term_freqs[token]
96
+ idf = self.idf[token]
97
+ numerator = tf * (self.k1 + 1)
98
+ denominator = tf + self.k1 * (1 - self.b + self.b * doc_len / self.avgdl)
99
+ score += idf * numerator / denominator
100
+
101
+ scores.append((idx, score))
102
+
103
+ return sorted(scores, key=lambda x: x[1], reverse=True)
104
+
105
+
106
+ # ============ SEARCH FUNCTIONS ============
107
+ def _load_csv(filepath):
108
+ """Load CSV and return list of dicts"""
109
+ with open(filepath, 'r', encoding='utf-8') as f:
110
+ return list(csv.DictReader(f))
111
+
112
+
113
+ def _search_csv(filepath, search_cols, output_cols, query, max_results):
114
+ """Core search function using BM25"""
115
+ if not filepath.exists():
116
+ return []
117
+
118
+ data = _load_csv(filepath)
119
+
120
+ # Build documents from search columns
121
+ documents = [" ".join(str(row.get(col, "")) for col in search_cols) for row in data]
122
+
123
+ # BM25 search
124
+ bm25 = BM25()
125
+ bm25.fit(documents)
126
+ ranked = bm25.score(query)
127
+
128
+ # Get top results with score > 0
129
+ results = []
130
+ for idx, score in ranked[:max_results]:
131
+ if score > 0:
132
+ row = data[idx]
133
+ results.append({col: row.get(col, "") for col in output_cols if col in row})
134
+
135
+ return results
136
+
137
+
138
+ def detect_domain(query):
139
+ """Auto-detect the most relevant domain from query"""
140
+ query_lower = query.lower()
141
+
142
+ domain_keywords = {
143
+ "strategy": ["pitch", "deck", "investor", "yc", "seed", "series", "demo", "sales", "webinar",
144
+ "conference", "board", "qbr", "all-hands", "duarte", "kawasaki", "structure"],
145
+ "layout": ["slide", "layout", "grid", "column", "title", "hero", "section", "cta",
146
+ "screenshot", "quote", "timeline", "comparison", "pricing", "team"],
147
+ "copy": ["headline", "copy", "formula", "aida", "pas", "hook", "cta", "benefit",
148
+ "objection", "proof", "testimonial", "urgency", "scarcity"],
149
+ "chart": ["chart", "graph", "bar", "line", "pie", "funnel", "metrics", "data",
150
+ "visualization", "kpi", "trend", "comparison", "heatmap", "gauge"]
151
+ }
152
+
153
+ scores = {domain: sum(1 for kw in keywords if kw in query_lower) for domain, keywords in domain_keywords.items()}
154
+ best = max(scores, key=scores.get)
155
+ return best if scores[best] > 0 else "strategy"
156
+
157
+
158
+ def search(query, domain=None, max_results=MAX_RESULTS):
159
+ """Main search function with auto-domain detection"""
160
+ if domain is None:
161
+ domain = detect_domain(query)
162
+
163
+ config = CSV_CONFIG.get(domain, CSV_CONFIG["strategy"])
164
+ filepath = DATA_DIR / config["file"]
165
+
166
+ if not filepath.exists():
167
+ return {"error": f"File not found: {filepath}", "domain": domain}
168
+
169
+ results = _search_csv(filepath, config["search_cols"], config["output_cols"], query, max_results)
170
+
171
+ return {
172
+ "domain": domain,
173
+ "query": query,
174
+ "file": config["file"],
175
+ "count": len(results),
176
+ "results": results
177
+ }
178
+
179
+
180
+ def search_all(query, max_results=2):
181
+ """Search across all domains for comprehensive results"""
182
+ all_results = {}
183
+
184
+ for domain in AVAILABLE_DOMAINS:
185
+ result = search(query, domain, max_results)
186
+ if result.get("count", 0) > 0:
187
+ all_results[domain] = result
188
+
189
+ return all_results
190
+
191
+
192
+ # ============ CONTEXTUAL SEARCH (Premium Slide System) ============
193
+
194
+ # New CSV configurations for decision system
195
+ DECISION_CSV_CONFIG = {
196
+ "layout-logic": {
197
+ "file": "slide-layout-logic.csv",
198
+ "key_col": "goal"
199
+ },
200
+ "typography": {
201
+ "file": "slide-typography.csv",
202
+ "key_col": "content_type"
203
+ },
204
+ "color-logic": {
205
+ "file": "slide-color-logic.csv",
206
+ "key_col": "emotion"
207
+ },
208
+ "backgrounds": {
209
+ "file": "slide-backgrounds.csv",
210
+ "key_col": "slide_type"
211
+ }
212
+ }
213
+
214
+
215
+ def _load_decision_csv(csv_type):
216
+ """Load a decision CSV and return as dict keyed by primary column."""
217
+ config = DECISION_CSV_CONFIG.get(csv_type)
218
+ if not config:
219
+ return {}
220
+
221
+ filepath = DATA_DIR / config["file"]
222
+ if not filepath.exists():
223
+ return {}
224
+
225
+ data = _load_csv(filepath)
226
+ return {row[config["key_col"]]: row for row in data if config["key_col"] in row}
227
+
228
+
229
+ def get_layout_for_goal(goal, previous_emotion=None):
230
+ """
231
+ Get layout recommendation based on slide goal.
232
+ Uses slide-layout-logic.csv for decision.
233
+ """
234
+ layouts = _load_decision_csv("layout-logic")
235
+ row = layouts.get(goal, layouts.get("features", {}))
236
+
237
+ result = dict(row) if row else {}
238
+
239
+ # Apply pattern-breaking logic
240
+ if result.get("break_pattern") == "true" and previous_emotion:
241
+ result["_pattern_break"] = True
242
+ result["_contrast_with"] = previous_emotion
243
+
244
+ return result
245
+
246
+
247
+ def get_typography_for_slide(slide_type, has_metrics=False, has_quote=False):
248
+ """
249
+ Get typography recommendation based on slide content.
250
+ Uses slide-typography.csv for decision.
251
+ """
252
+ typography = _load_decision_csv("typography")
253
+
254
+ if has_metrics:
255
+ return typography.get("metric-callout", {})
256
+ if has_quote:
257
+ return typography.get("quote-block", {})
258
+
259
+ # Map slide types to typography
260
+ type_map = {
261
+ "hero": "hero-statement",
262
+ "hook": "hero-statement",
263
+ "title": "title-only",
264
+ "problem": "subtitle-heavy",
265
+ "agitation": "metric-callout",
266
+ "solution": "subtitle-heavy",
267
+ "features": "feature-grid",
268
+ "proof": "metric-callout",
269
+ "traction": "data-insight",
270
+ "social": "quote-block",
271
+ "testimonial": "testimonial",
272
+ "pricing": "pricing",
273
+ "team": "team",
274
+ "cta": "cta-action",
275
+ "comparison": "comparison",
276
+ "timeline": "timeline",
277
+ }
278
+
279
+ content_type = type_map.get(slide_type, "feature-grid")
280
+ return typography.get(content_type, {})
281
+
282
+
283
+ def get_color_for_emotion(emotion):
284
+ """
285
+ Get color treatment based on emotional beat.
286
+ Uses slide-color-logic.csv for decision.
287
+ """
288
+ colors = _load_decision_csv("color-logic")
289
+ return colors.get(emotion, colors.get("clarity", {}))
290
+
291
+
292
+ def get_background_config(slide_type):
293
+ """
294
+ Get background image configuration.
295
+ Uses slide-backgrounds.csv for decision.
296
+ """
297
+ backgrounds = _load_decision_csv("backgrounds")
298
+ return backgrounds.get(slide_type, {})
299
+
300
+
301
+ def should_use_full_bleed(slide_index, total_slides, emotion):
302
+ """
303
+ Determine if slide should use full-bleed background.
304
+ Premium decks use 2-3 full-bleed slides strategically.
305
+
306
+ Rules:
307
+ 1. Never consecutive full-bleed
308
+ 2. One in first third, one in middle, one at end
309
+ 3. Reserved for high-emotion beats (hope, urgency, fear)
310
+ """
311
+ high_emotion_beats = ["hope", "urgency", "fear", "curiosity"]
312
+
313
+ if emotion not in high_emotion_beats:
314
+ return False
315
+
316
+ if total_slides < 3:
317
+ return False
318
+
319
+ third = total_slides // 3
320
+ strategic_positions = [1, third, third * 2, total_slides - 1]
321
+
322
+ return slide_index in strategic_positions
323
+
324
+
325
+ def calculate_pattern_break(slide_index, total_slides, previous_emotion=None):
326
+ """
327
+ Determine if this slide should break the visual pattern.
328
+ Used for emotional contrast (Duarte Sparkline technique).
329
+ """
330
+ # Pattern breaks at strategic positions
331
+ if total_slides < 5:
332
+ return False
333
+
334
+ # Break at 1/3 and 2/3 points
335
+ third = total_slides // 3
336
+ if slide_index in [third, third * 2]:
337
+ return True
338
+
339
+ # Break when switching between frustration and hope
340
+ contrasting_emotions = {
341
+ "frustration": ["hope", "relief"],
342
+ "hope": ["frustration", "fear"],
343
+ "fear": ["hope", "relief"],
344
+ }
345
+
346
+ if previous_emotion in contrasting_emotions:
347
+ return True
348
+
349
+ return False
350
+
351
+
352
+ def search_with_context(query, slide_position=1, total_slides=9, previous_emotion=None):
353
+ """
354
+ Enhanced search that considers deck context.
355
+
356
+ Args:
357
+ query: Search query
358
+ slide_position: Current slide index (1-based)
359
+ total_slides: Total slides in deck
360
+ previous_emotion: Emotion of previous slide (for contrast)
361
+
362
+ Returns:
363
+ Search results enriched with contextual recommendations
364
+ """
365
+ # Get base results from existing BM25 search
366
+ base_results = search_all(query, max_results=2)
367
+
368
+ # Detect likely slide goal from query
369
+ goal = detect_domain(query.lower())
370
+ if "problem" in query.lower():
371
+ goal = "problem"
372
+ elif "solution" in query.lower():
373
+ goal = "solution"
374
+ elif "cta" in query.lower() or "call to action" in query.lower():
375
+ goal = "cta"
376
+ elif "hook" in query.lower() or "title" in query.lower():
377
+ goal = "hook"
378
+ elif "traction" in query.lower() or "metric" in query.lower():
379
+ goal = "traction"
380
+
381
+ # Enrich with contextual recommendations
382
+ context = {
383
+ "slide_position": slide_position,
384
+ "total_slides": total_slides,
385
+ "previous_emotion": previous_emotion,
386
+ "inferred_goal": goal,
387
+ }
388
+
389
+ # Get layout recommendation
390
+ layout = get_layout_for_goal(goal, previous_emotion)
391
+ if layout:
392
+ context["recommended_layout"] = layout.get("layout_pattern")
393
+ context["layout_direction"] = layout.get("direction")
394
+ context["visual_weight"] = layout.get("visual_weight")
395
+ context["use_background_image"] = layout.get("use_bg_image") == "true"
396
+
397
+ # Get typography recommendation
398
+ typography = get_typography_for_slide(goal)
399
+ if typography:
400
+ context["typography"] = {
401
+ "primary_size": typography.get("primary_size"),
402
+ "secondary_size": typography.get("secondary_size"),
403
+ "weight_contrast": typography.get("weight_contrast"),
404
+ }
405
+
406
+ # Get color treatment
407
+ emotion = layout.get("emotion", "clarity") if layout else "clarity"
408
+ color = get_color_for_emotion(emotion)
409
+ if color:
410
+ context["color_treatment"] = {
411
+ "background": color.get("background"),
412
+ "text_color": color.get("text_color"),
413
+ "accent_usage": color.get("accent_usage"),
414
+ "card_style": color.get("card_style"),
415
+ }
416
+
417
+ # Calculate pattern breaking
418
+ context["should_break_pattern"] = calculate_pattern_break(
419
+ slide_position, total_slides, previous_emotion
420
+ )
421
+ context["should_use_full_bleed"] = should_use_full_bleed(
422
+ slide_position, total_slides, emotion
423
+ )
424
+
425
+ # Get background config if needed
426
+ if context.get("use_background_image"):
427
+ bg_config = get_background_config(goal)
428
+ if bg_config:
429
+ context["background"] = {
430
+ "image_category": bg_config.get("image_category"),
431
+ "overlay_style": bg_config.get("overlay_style"),
432
+ "search_keywords": bg_config.get("search_keywords"),
433
+ }
434
+
435
+ # Suggested animation classes
436
+ animation_map = {
437
+ "hook": "animate-fade-up",
438
+ "problem": "animate-fade-up",
439
+ "agitation": "animate-count animate-stagger",
440
+ "solution": "animate-scale",
441
+ "features": "animate-stagger",
442
+ "traction": "animate-chart animate-count",
443
+ "proof": "animate-stagger-scale",
444
+ "social": "animate-fade-up",
445
+ "cta": "animate-pulse",
446
+ }
447
+ context["animation_class"] = animation_map.get(goal, "animate-fade-up")
448
+
449
+ return {
450
+ "query": query,
451
+ "context": context,
452
+ "base_results": base_results,
453
+ }
@@ -0,0 +1,251 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Validate token usage in codebase
4
+ * Finds hardcoded values that should use design tokens
5
+ *
6
+ * Usage:
7
+ * node validate-tokens.cjs --dir src/
8
+ * node validate-tokens.cjs --dir src/ --fix
9
+ */
10
+
11
+ const fs = require('fs');
12
+ const path = require('path');
13
+
14
+ /**
15
+ * Parse command line arguments
16
+ */
17
+ function parseArgs() {
18
+ const args = process.argv.slice(2);
19
+ const options = {
20
+ dir: null,
21
+ fix: false,
22
+ ignore: ['node_modules', '.git', 'dist', 'build', '.next']
23
+ };
24
+
25
+ for (let i = 0; i < args.length; i++) {
26
+ if (args[i] === '--dir' || args[i] === '-d') {
27
+ options.dir = args[++i];
28
+ } else if (args[i] === '--fix') {
29
+ options.fix = true;
30
+ } else if (args[i] === '--ignore' || args[i] === '-i') {
31
+ options.ignore.push(args[++i]);
32
+ } else if (args[i] === '--help' || args[i] === '-h') {
33
+ console.log(`
34
+ Usage: node validate-tokens.cjs [options]
35
+
36
+ Options:
37
+ -d, --dir <path> Directory to scan (required)
38
+ --fix Show suggested fixes (no auto-fix)
39
+ -i, --ignore <dir> Additional directories to ignore
40
+ -h, --help Show this help
41
+
42
+ Checks for:
43
+ - Hardcoded hex colors (#RGB, #RRGGBB)
44
+ - Hardcoded pixel values (except 0, 1px)
45
+ - Hardcoded rem values in CSS
46
+ `);
47
+ process.exit(0);
48
+ }
49
+ }
50
+
51
+ return options;
52
+ }
53
+
54
+ /**
55
+ * Patterns to detect hardcoded values
56
+ */
57
+ const patterns = {
58
+ hexColor: {
59
+ regex: /#([0-9A-Fa-f]{3}){1,2}\b/g,
60
+ message: 'Hardcoded hex color',
61
+ suggestion: 'Use var(--color-*) token'
62
+ },
63
+ rgbColor: {
64
+ regex: /rgb\s*\(\s*\d+\s*,\s*\d+\s*,\s*\d+\s*\)/gi,
65
+ message: 'Hardcoded RGB color',
66
+ suggestion: 'Use var(--color-*) token'
67
+ },
68
+ pixelValue: {
69
+ regex: /:\s*(\d{2,})px/g, // 2+ digit px values
70
+ message: 'Hardcoded pixel value',
71
+ suggestion: 'Use var(--space-*) or var(--radius-*) token'
72
+ },
73
+ remValue: {
74
+ regex: /:\s*\d+\.?\d*rem(?![^{]*\$value)/g, // rem not in token definition
75
+ message: 'Hardcoded rem value',
76
+ suggestion: 'Use var(--space-*) or var(--font-size-*) token'
77
+ }
78
+ };
79
+
80
+ /**
81
+ * File extensions to scan
82
+ */
83
+ const extensions = ['.css', '.scss', '.tsx', '.jsx', '.ts', '.js', '.vue', '.svelte'];
84
+
85
+ /**
86
+ * Files/patterns to skip
87
+ */
88
+ const skipPatterns = [
89
+ /\.min\.(css|js)$/,
90
+ /tailwind\.config/,
91
+ /globals\.css/, // Token definitions
92
+ /tokens\.(css|json)/
93
+ ];
94
+
95
+ /**
96
+ * Get all files recursively
97
+ */
98
+ function getFiles(dir, ignore, files = []) {
99
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
100
+
101
+ for (const entry of entries) {
102
+ const fullPath = path.join(dir, entry.name);
103
+
104
+ if (entry.isDirectory()) {
105
+ if (!ignore.includes(entry.name)) {
106
+ getFiles(fullPath, ignore, files);
107
+ }
108
+ } else if (entry.isFile()) {
109
+ const ext = path.extname(entry.name);
110
+ if (extensions.includes(ext)) {
111
+ files.push(fullPath);
112
+ }
113
+ }
114
+ }
115
+
116
+ return files;
117
+ }
118
+
119
+ /**
120
+ * Check if file should be skipped
121
+ */
122
+ function shouldSkip(filePath) {
123
+ return skipPatterns.some(pattern => pattern.test(filePath));
124
+ }
125
+
126
+ /**
127
+ * Scan file for violations
128
+ */
129
+ function scanFile(filePath) {
130
+ const content = fs.readFileSync(filePath, 'utf-8');
131
+ const lines = content.split('\n');
132
+ const violations = [];
133
+
134
+ lines.forEach((line, index) => {
135
+ // Skip comments
136
+ if (line.trim().startsWith('//') || line.trim().startsWith('/*')) {
137
+ return;
138
+ }
139
+
140
+ // Skip lines that already use CSS variables
141
+ if (line.includes('var(--')) {
142
+ return;
143
+ }
144
+
145
+ for (const [name, pattern] of Object.entries(patterns)) {
146
+ const matches = line.match(pattern.regex);
147
+ if (matches) {
148
+ matches.forEach(match => {
149
+ // Skip common exceptions
150
+ if (name === 'hexColor' && ['#000', '#fff', '#FFF', '#000000', '#FFFFFF'].includes(match.toUpperCase())) {
151
+ return; // Skip black/white, often intentional
152
+ }
153
+
154
+ violations.push({
155
+ file: filePath,
156
+ line: index + 1,
157
+ column: line.indexOf(match) + 1,
158
+ value: match,
159
+ type: name,
160
+ message: pattern.message,
161
+ suggestion: pattern.suggestion,
162
+ context: line.trim().substring(0, 80)
163
+ });
164
+ });
165
+ }
166
+ }
167
+ });
168
+
169
+ return violations;
170
+ }
171
+
172
+ /**
173
+ * Format violation report
174
+ */
175
+ function formatReport(violations) {
176
+ if (violations.length === 0) {
177
+ return 'āœ… No token violations found';
178
+ }
179
+
180
+ let report = `āš ļø Found ${violations.length} potential token violations:\n\n`;
181
+
182
+ // Group by file
183
+ const byFile = {};
184
+ violations.forEach(v => {
185
+ if (!byFile[v.file]) byFile[v.file] = [];
186
+ byFile[v.file].push(v);
187
+ });
188
+
189
+ for (const [file, fileViolations] of Object.entries(byFile)) {
190
+ report += `šŸ“ ${file}\n`;
191
+ fileViolations.forEach(v => {
192
+ report += ` Line ${v.line}: ${v.message}\n`;
193
+ report += ` Found: ${v.value}\n`;
194
+ report += ` Suggestion: ${v.suggestion}\n`;
195
+ report += ` Context: ${v.context}\n\n`;
196
+ });
197
+ }
198
+
199
+ // Summary
200
+ const byType = {};
201
+ violations.forEach(v => {
202
+ byType[v.type] = (byType[v.type] || 0) + 1;
203
+ });
204
+
205
+ report += `\nšŸ“Š Summary:\n`;
206
+ for (const [type, count] of Object.entries(byType)) {
207
+ report += ` ${patterns[type].message}: ${count}\n`;
208
+ }
209
+
210
+ return report;
211
+ }
212
+
213
+ /**
214
+ * Main
215
+ */
216
+ function main() {
217
+ const options = parseArgs();
218
+
219
+ if (!options.dir) {
220
+ console.error('Error: --dir is required');
221
+ process.exit(1);
222
+ }
223
+
224
+ const dirPath = path.resolve(process.cwd(), options.dir);
225
+
226
+ if (!fs.existsSync(dirPath)) {
227
+ console.error(`Error: Directory not found: ${dirPath}`);
228
+ process.exit(1);
229
+ }
230
+
231
+ console.log(`Scanning ${dirPath} for token violations...\n`);
232
+
233
+ const files = getFiles(dirPath, options.ignore);
234
+ const allViolations = [];
235
+
236
+ for (const file of files) {
237
+ if (shouldSkip(file)) continue;
238
+
239
+ const violations = scanFile(file);
240
+ allViolations.push(...violations);
241
+ }
242
+
243
+ console.log(formatReport(allViolations));
244
+
245
+ // Exit with error code if violations found
246
+ if (allViolations.length > 0) {
247
+ process.exit(1);
248
+ }
249
+ }
250
+
251
+ main();