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.
- package/.claude-plugin/marketplace.json +19 -0
- package/.claude-plugin/plugin.json +54 -0
- package/CLAUDE.md +81 -0
- package/LICENSE +33 -0
- package/LICENSE-ui-ux-pro-max.txt +21 -0
- package/README.md +294 -0
- package/agents/architect.md +211 -0
- package/agents/brainstormer.md +103 -0
- package/agents/build-error-resolver.md +114 -0
- package/agents/chief-of-staff.md +151 -0
- package/agents/code-reviewer.md +285 -0
- package/agents/copywriter.md +111 -0
- package/agents/database-admin.md +91 -0
- package/agents/debugger.md +135 -0
- package/agents/docs-manager.md +119 -0
- package/agents/e2e-runner.md +107 -0
- package/agents/git-manager.md +199 -0
- package/agents/harness-optimizer.md +35 -0
- package/agents/loop-operator.md +36 -0
- package/agents/planner.md +245 -0
- package/agents/project-manager.md +117 -0
- package/agents/quality-gate.md +173 -0
- package/agents/refactor-cleaner.md +85 -0
- package/agents/scout.md +105 -0
- package/agents/security-reviewer.md +108 -0
- package/agents/skill-router.md +112 -0
- package/agents/tdd-guide.md +91 -0
- package/agents/ui-ux-designer.md +220 -0
- package/assets/canvas-fonts/ArsenalSC-OFL.txt +93 -0
- package/assets/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
- package/assets/canvas-fonts/BigShoulders-Bold.ttf +0 -0
- package/assets/canvas-fonts/BigShoulders-OFL.txt +93 -0
- package/assets/canvas-fonts/BigShoulders-Regular.ttf +0 -0
- package/assets/canvas-fonts/Boldonse-OFL.txt +93 -0
- package/assets/canvas-fonts/Boldonse-Regular.ttf +0 -0
- package/assets/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
- package/assets/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
- package/assets/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
- package/assets/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
- package/assets/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
- package/assets/canvas-fonts/CrimsonPro-OFL.txt +93 -0
- package/assets/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
- package/assets/canvas-fonts/DMMono-OFL.txt +93 -0
- package/assets/canvas-fonts/DMMono-Regular.ttf +0 -0
- package/assets/canvas-fonts/EricaOne-OFL.txt +94 -0
- package/assets/canvas-fonts/EricaOne-Regular.ttf +0 -0
- package/assets/canvas-fonts/GeistMono-Bold.ttf +0 -0
- package/assets/canvas-fonts/GeistMono-OFL.txt +93 -0
- package/assets/canvas-fonts/GeistMono-Regular.ttf +0 -0
- package/assets/canvas-fonts/Gloock-OFL.txt +93 -0
- package/assets/canvas-fonts/Gloock-Regular.ttf +0 -0
- package/assets/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
- package/assets/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
- package/assets/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
- package/assets/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
- package/assets/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
- package/assets/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
- package/assets/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
- package/assets/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
- package/assets/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
- package/assets/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
- package/assets/canvas-fonts/InstrumentSans-OFL.txt +93 -0
- package/assets/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
- package/assets/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
- package/assets/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
- package/assets/canvas-fonts/Italiana-OFL.txt +93 -0
- package/assets/canvas-fonts/Italiana-Regular.ttf +0 -0
- package/assets/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
- package/assets/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
- package/assets/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
- package/assets/canvas-fonts/Jura-Light.ttf +0 -0
- package/assets/canvas-fonts/Jura-Medium.ttf +0 -0
- package/assets/canvas-fonts/Jura-OFL.txt +93 -0
- package/assets/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
- package/assets/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
- package/assets/canvas-fonts/Lora-Bold.ttf +0 -0
- package/assets/canvas-fonts/Lora-BoldItalic.ttf +0 -0
- package/assets/canvas-fonts/Lora-Italic.ttf +0 -0
- package/assets/canvas-fonts/Lora-OFL.txt +93 -0
- package/assets/canvas-fonts/Lora-Regular.ttf +0 -0
- package/assets/canvas-fonts/NationalPark-Bold.ttf +0 -0
- package/assets/canvas-fonts/NationalPark-OFL.txt +93 -0
- package/assets/canvas-fonts/NationalPark-Regular.ttf +0 -0
- package/assets/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
- package/assets/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
- package/assets/canvas-fonts/Outfit-Bold.ttf +0 -0
- package/assets/canvas-fonts/Outfit-OFL.txt +93 -0
- package/assets/canvas-fonts/Outfit-Regular.ttf +0 -0
- package/assets/canvas-fonts/PixelifySans-Medium.ttf +0 -0
- package/assets/canvas-fonts/PixelifySans-OFL.txt +93 -0
- package/assets/canvas-fonts/PoiretOne-OFL.txt +93 -0
- package/assets/canvas-fonts/PoiretOne-Regular.ttf +0 -0
- package/assets/canvas-fonts/RedHatMono-Bold.ttf +0 -0
- package/assets/canvas-fonts/RedHatMono-OFL.txt +93 -0
- package/assets/canvas-fonts/RedHatMono-Regular.ttf +0 -0
- package/assets/canvas-fonts/Silkscreen-OFL.txt +93 -0
- package/assets/canvas-fonts/Silkscreen-Regular.ttf +0 -0
- package/assets/canvas-fonts/SmoochSans-Medium.ttf +0 -0
- package/assets/canvas-fonts/SmoochSans-OFL.txt +93 -0
- package/assets/canvas-fonts/Tektur-Medium.ttf +0 -0
- package/assets/canvas-fonts/Tektur-OFL.txt +93 -0
- package/assets/canvas-fonts/Tektur-Regular.ttf +0 -0
- package/assets/canvas-fonts/WorkSans-Bold.ttf +0 -0
- package/assets/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
- package/assets/canvas-fonts/WorkSans-Italic.ttf +0 -0
- package/assets/canvas-fonts/WorkSans-OFL.txt +93 -0
- package/assets/canvas-fonts/WorkSans-Regular.ttf +0 -0
- package/assets/canvas-fonts/YoungSerif-OFL.txt +93 -0
- package/assets/canvas-fonts/YoungSerif-Regular.ttf +0 -0
- package/commands/ask.md +56 -0
- package/commands/audit.md +25 -0
- package/commands/bootstrap/auto/fast.md +111 -0
- package/commands/bootstrap/auto.md +115 -0
- package/commands/bootstrap.md +137 -0
- package/commands/brainstorm.md +69 -0
- package/commands/build-fix.md +66 -0
- package/commands/code-review.md +44 -0
- package/commands/code.md +93 -0
- package/commands/commit_gen.md +44 -0
- package/commands/content/cro.md +43 -0
- package/commands/content/enhance.md +14 -0
- package/commands/content/fast.md +13 -0
- package/commands/content/good.md +16 -0
- package/commands/cook/auto/fast.md +26 -0
- package/commands/cook/auto.md +15 -0
- package/commands/cook.md +105 -0
- package/commands/debug.md +13 -0
- package/commands/design/3d.md +74 -0
- package/commands/design/describe.md +21 -0
- package/commands/design/fast.md +22 -0
- package/commands/design/good.md +26 -0
- package/commands/design/screenshot.md +32 -0
- package/commands/design/video.md +32 -0
- package/commands/docs/init.md +15 -0
- package/commands/docs/summarize.md +22 -0
- package/commands/docs/update.md +23 -0
- package/commands/e2e.md +365 -0
- package/commands/evolve.md +178 -0
- package/commands/fix/ci.md +20 -0
- package/commands/fix/fast.md +19 -0
- package/commands/fix/hard.md +43 -0
- package/commands/fix/logs.md +20 -0
- package/commands/fix/test.md +20 -0
- package/commands/fix/types.md +9 -0
- package/commands/fix/ui.md +35 -0
- package/commands/fix.md +12 -0
- package/commands/git/cm.md +11 -0
- package/commands/git/cp.md +9 -0
- package/commands/git/pr.md +15 -0
- package/commands/integrate/polar.md +28 -0
- package/commands/integrate/sepay.md +28 -0
- package/commands/journal.md +5 -0
- package/commands/learn.md +74 -0
- package/commands/loop-start.md +36 -0
- package/commands/loop-status.md +28 -0
- package/commands/model-route.md +30 -0
- package/commands/plan.md +115 -0
- package/commands/prompt-optimize.md +38 -0
- package/commands/quality-gate.md +33 -0
- package/commands/refactor-clean.md +84 -0
- package/commands/review/codebase.md +49 -0
- package/commands/route.md +28 -0
- package/commands/scout/ext.md +35 -0
- package/commands/scout.md +28 -0
- package/commands/skill/add.md +29 -0
- package/commands/skill/create.md +22 -0
- package/commands/skill/fix-logs.md +21 -0
- package/commands/skill/optimize.md +28 -0
- package/commands/skill-create.md +174 -0
- package/commands/tdd.md +328 -0
- package/commands/test.md +8 -0
- package/commands/verify.md +63 -0
- package/commands/watzup.md +8 -0
- package/hooks/hooks.json +86 -0
- package/hooks/scripts/block-no-verify.js +19 -0
- package/hooks/scripts/check-console-log.js +71 -0
- package/hooks/scripts/check-hook-enabled.js +12 -0
- package/hooks/scripts/config-protection.js +125 -0
- package/hooks/scripts/post-edit-console-warn.js +54 -0
- package/hooks/scripts/post-edit-format.js +109 -0
- package/hooks/scripts/post-edit-typecheck.js +96 -0
- package/hooks/scripts/quality-gate.js +168 -0
- package/hooks/scripts/run-with-flags-shell.sh +32 -0
- package/hooks/scripts/run-with-flags.js +120 -0
- package/hooks/scripts/session-end.js +301 -0
- package/hooks/scripts/session-start.js +98 -0
- package/manifests/install-modules.json +96 -0
- package/manifests/install-profiles.json +17 -0
- package/package.json +52 -0
- package/scripts/install.js +144 -0
- package/scripts/lib/hook-flags.js +74 -0
- package/scripts/lib/profile-utils.js +97 -0
- package/scripts/lib/resolve-formatter.js +185 -0
- package/scripts/lib/resolve-root.js +89 -0
- package/scripts/lib/utils.js +564 -0
- package/scripts/sl.js +677 -0
- package/skills/manifest.json +493 -0
- package/skills/tier-1/api-design/SKILL.md +523 -0
- package/skills/tier-1/backend-development/SKILL.md +95 -0
- package/skills/tier-1/backend-development/references/backend-api-design.md +495 -0
- package/skills/tier-1/backend-development/references/backend-architecture.md +454 -0
- package/skills/tier-1/backend-development/references/backend-authentication.md +338 -0
- package/skills/tier-1/backend-development/references/backend-code-quality.md +659 -0
- package/skills/tier-1/backend-development/references/backend-debugging.md +904 -0
- package/skills/tier-1/backend-development/references/backend-devops.md +494 -0
- package/skills/tier-1/backend-development/references/backend-mindset.md +387 -0
- package/skills/tier-1/backend-development/references/backend-performance.md +397 -0
- package/skills/tier-1/backend-development/references/backend-security.md +290 -0
- package/skills/tier-1/backend-development/references/backend-technologies.md +256 -0
- package/skills/tier-1/backend-development/references/backend-testing.md +429 -0
- package/skills/tier-1/code-review/SKILL.md +143 -0
- package/skills/tier-1/code-review/references/code-review-reception.md +209 -0
- package/skills/tier-1/code-review/references/requesting-code-review.md +105 -0
- package/skills/tier-1/code-review/references/verification-before-completion.md +139 -0
- package/skills/tier-1/databases/SKILL.md +232 -0
- package/skills/tier-1/databases/references/mongodb-aggregation.md +447 -0
- package/skills/tier-1/databases/references/mongodb-atlas.md +465 -0
- package/skills/tier-1/databases/references/mongodb-crud.md +408 -0
- package/skills/tier-1/databases/references/mongodb-indexing.md +442 -0
- package/skills/tier-1/databases/references/postgresql-administration.md +594 -0
- package/skills/tier-1/databases/references/postgresql-performance.md +527 -0
- package/skills/tier-1/databases/references/postgresql-psql-cli.md +467 -0
- package/skills/tier-1/databases/references/postgresql-queries.md +475 -0
- package/skills/tier-1/databases/scripts/.coverage +0 -0
- package/skills/tier-1/databases/scripts/db_backup.py +502 -0
- package/skills/tier-1/databases/scripts/db_migrate.py +414 -0
- package/skills/tier-1/databases/scripts/db_performance_check.py +444 -0
- package/skills/tier-1/databases/scripts/requirements.txt +20 -0
- package/skills/tier-1/databases/scripts/tests/coverage-db.json +1 -0
- package/skills/tier-1/databases/scripts/tests/requirements.txt +4 -0
- package/skills/tier-1/databases/scripts/tests/test_db_backup.py +340 -0
- package/skills/tier-1/databases/scripts/tests/test_db_migrate.py +277 -0
- package/skills/tier-1/databases/scripts/tests/test_db_performance_check.py +370 -0
- package/skills/tier-1/debugging/SKILL.md +84 -0
- package/skills/tier-1/debugging/references/defense-in-depth.md +124 -0
- package/skills/tier-1/debugging/references/root-cause-tracing.md +122 -0
- package/skills/tier-1/debugging/references/systematic-debugging.md +102 -0
- package/skills/tier-1/debugging/references/verification.md +123 -0
- package/skills/tier-1/debugging/scripts/find-polluter.sh +63 -0
- package/skills/tier-1/debugging/scripts/find-polluter.test.md +102 -0
- package/skills/tier-1/devops/.env.example +76 -0
- package/skills/tier-1/devops/SKILL.md +285 -0
- package/skills/tier-1/devops/references/browser-rendering.md +305 -0
- package/skills/tier-1/devops/references/cloudflare-d1-kv.md +123 -0
- package/skills/tier-1/devops/references/cloudflare-platform.md +271 -0
- package/skills/tier-1/devops/references/cloudflare-r2-storage.md +280 -0
- package/skills/tier-1/devops/references/cloudflare-workers-advanced.md +312 -0
- package/skills/tier-1/devops/references/cloudflare-workers-apis.md +309 -0
- package/skills/tier-1/devops/references/cloudflare-workers-basics.md +418 -0
- package/skills/tier-1/devops/references/docker-basics.md +297 -0
- package/skills/tier-1/devops/references/docker-compose.md +292 -0
- package/skills/tier-1/devops/references/gcloud-platform.md +297 -0
- package/skills/tier-1/devops/references/gcloud-services.md +304 -0
- package/skills/tier-1/devops/scripts/cloudflare_deploy.py +269 -0
- package/skills/tier-1/devops/scripts/docker_optimize.py +320 -0
- package/skills/tier-1/devops/scripts/requirements.txt +20 -0
- package/skills/tier-1/devops/scripts/tests/requirements.txt +3 -0
- package/skills/tier-1/devops/scripts/tests/test_cloudflare_deploy.py +285 -0
- package/skills/tier-1/devops/scripts/tests/test_docker_optimize.py +436 -0
- package/skills/tier-1/frontend-development/SKILL.md +399 -0
- package/skills/tier-1/frontend-development/resources/common-patterns.md +331 -0
- package/skills/tier-1/frontend-development/resources/complete-examples.md +872 -0
- package/skills/tier-1/frontend-development/resources/component-patterns.md +502 -0
- package/skills/tier-1/frontend-development/resources/data-fetching.md +767 -0
- package/skills/tier-1/frontend-development/resources/file-organization.md +502 -0
- package/skills/tier-1/frontend-development/resources/loading-and-error-states.md +501 -0
- package/skills/tier-1/frontend-development/resources/performance.md +406 -0
- package/skills/tier-1/frontend-development/resources/routing-guide.md +364 -0
- package/skills/tier-1/frontend-development/resources/styling-guide.md +428 -0
- package/skills/tier-1/frontend-development/resources/typescript-standards.md +418 -0
- package/skills/tier-1/react-best-practices/AGENTS.md +2410 -0
- package/skills/tier-1/react-best-practices/README.md +123 -0
- package/skills/tier-1/react-best-practices/SKILL.md +125 -0
- package/skills/tier-1/react-best-practices/metadata.json +15 -0
- package/skills/tier-1/react-best-practices/rules/_sections.md +46 -0
- package/skills/tier-1/react-best-practices/rules/_template.md +28 -0
- package/skills/tier-1/react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/skills/tier-1/react-best-practices/rules/advanced-use-latest.md +49 -0
- package/skills/tier-1/react-best-practices/rules/async-api-routes.md +38 -0
- package/skills/tier-1/react-best-practices/rules/async-defer-await.md +80 -0
- package/skills/tier-1/react-best-practices/rules/async-dependencies.md +36 -0
- package/skills/tier-1/react-best-practices/rules/async-parallel.md +28 -0
- package/skills/tier-1/react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/skills/tier-1/react-best-practices/rules/bundle-barrel-imports.md +59 -0
- package/skills/tier-1/react-best-practices/rules/bundle-conditional.md +31 -0
- package/skills/tier-1/react-best-practices/rules/bundle-defer-third-party.md +49 -0
- package/skills/tier-1/react-best-practices/rules/bundle-dynamic-imports.md +35 -0
- package/skills/tier-1/react-best-practices/rules/bundle-preload.md +50 -0
- package/skills/tier-1/react-best-practices/rules/client-event-listeners.md +74 -0
- package/skills/tier-1/react-best-practices/rules/client-localstorage-schema.md +71 -0
- package/skills/tier-1/react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/skills/tier-1/react-best-practices/rules/client-swr-dedup.md +56 -0
- package/skills/tier-1/react-best-practices/rules/js-batch-dom-css.md +82 -0
- package/skills/tier-1/react-best-practices/rules/js-cache-function-results.md +80 -0
- package/skills/tier-1/react-best-practices/rules/js-cache-property-access.md +28 -0
- package/skills/tier-1/react-best-practices/rules/js-cache-storage.md +70 -0
- package/skills/tier-1/react-best-practices/rules/js-combine-iterations.md +32 -0
- package/skills/tier-1/react-best-practices/rules/js-early-exit.md +50 -0
- package/skills/tier-1/react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/skills/tier-1/react-best-practices/rules/js-index-maps.md +37 -0
- package/skills/tier-1/react-best-practices/rules/js-length-check-first.md +49 -0
- package/skills/tier-1/react-best-practices/rules/js-min-max-loop.md +82 -0
- package/skills/tier-1/react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/skills/tier-1/react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/skills/tier-1/react-best-practices/rules/rendering-activity.md +26 -0
- package/skills/tier-1/react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
- package/skills/tier-1/react-best-practices/rules/rendering-conditional-render.md +40 -0
- package/skills/tier-1/react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/skills/tier-1/react-best-practices/rules/rendering-hoist-jsx.md +46 -0
- package/skills/tier-1/react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
- package/skills/tier-1/react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/skills/tier-1/react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/skills/tier-1/react-best-practices/rules/rerender-dependencies.md +45 -0
- package/skills/tier-1/react-best-practices/rules/rerender-derived-state.md +29 -0
- package/skills/tier-1/react-best-practices/rules/rerender-functional-setstate.md +74 -0
- package/skills/tier-1/react-best-practices/rules/rerender-lazy-state-init.md +58 -0
- package/skills/tier-1/react-best-practices/rules/rerender-memo.md +44 -0
- package/skills/tier-1/react-best-practices/rules/rerender-transitions.md +40 -0
- package/skills/tier-1/react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/skills/tier-1/react-best-practices/rules/server-cache-lru.md +41 -0
- package/skills/tier-1/react-best-practices/rules/server-cache-react.md +76 -0
- package/skills/tier-1/react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/skills/tier-1/react-best-practices/rules/server-serialization.md +38 -0
- package/skills/tier-1/research/SKILL.md +168 -0
- package/skills/tier-1/security-review/SKILL.md +495 -0
- package/skills/tier-1/security-review/cloud-infrastructure-security.md +361 -0
- package/skills/tier-1/sequential-thinking/.env.example +8 -0
- package/skills/tier-1/sequential-thinking/README.md +183 -0
- package/skills/tier-1/sequential-thinking/SKILL.md +94 -0
- package/skills/tier-1/sequential-thinking/package.json +31 -0
- package/skills/tier-1/sequential-thinking/references/advanced-strategies.md +79 -0
- package/skills/tier-1/sequential-thinking/references/advanced-techniques.md +76 -0
- package/skills/tier-1/sequential-thinking/references/core-patterns.md +95 -0
- package/skills/tier-1/sequential-thinking/references/examples-api.md +88 -0
- package/skills/tier-1/sequential-thinking/references/examples-architecture.md +94 -0
- package/skills/tier-1/sequential-thinking/references/examples-debug.md +90 -0
- package/skills/tier-1/sequential-thinking/scripts/format-thought.js +159 -0
- package/skills/tier-1/sequential-thinking/scripts/process-thought.js +236 -0
- package/skills/tier-1/sequential-thinking/tests/format-thought.test.js +133 -0
- package/skills/tier-1/sequential-thinking/tests/process-thought.test.js +215 -0
- package/skills/tier-1/tdd-workflow/SKILL.md +410 -0
- package/skills/tier-1/testing/SKILL.md +56 -0
- package/skills/tier-1/ui-styling/LICENSE.txt +202 -0
- package/skills/tier-1/ui-styling/SKILL.md +321 -0
- package/skills/tier-1/ui-styling/references/canvas-design-system.md +320 -0
- package/skills/tier-1/ui-styling/references/shadcn-accessibility.md +471 -0
- package/skills/tier-1/ui-styling/references/shadcn-components.md +424 -0
- package/skills/tier-1/ui-styling/references/shadcn-theming.md +373 -0
- package/skills/tier-1/ui-styling/references/tailwind-customization.md +483 -0
- package/skills/tier-1/ui-styling/references/tailwind-responsive.md +382 -0
- package/skills/tier-1/ui-styling/references/tailwind-utilities.md +455 -0
- package/skills/tier-1/ui-styling/scripts/.coverage +0 -0
- package/skills/tier-1/ui-styling/scripts/requirements.txt +17 -0
- package/skills/tier-1/ui-styling/scripts/shadcn_add.py +292 -0
- package/skills/tier-1/ui-styling/scripts/tailwind_config_gen.py +456 -0
- package/skills/tier-1/ui-styling/scripts/tests/coverage-ui.json +1 -0
- package/skills/tier-1/ui-styling/scripts/tests/requirements.txt +3 -0
- package/skills/tier-1/ui-styling/scripts/tests/test_shadcn_add.py +266 -0
- package/skills/tier-1/ui-styling/scripts/tests/test_tailwind_config_gen.py +336 -0
- package/skills/tier-1/ui-ux-pro-max/SKILL.md +659 -0
- package/skills/tier-1/ui-ux-pro-max/data/_sync_all.py +414 -0
- package/skills/tier-1/ui-ux-pro-max/data/app-interface.csv +31 -0
- package/skills/tier-1/ui-ux-pro-max/data/charts.csv +26 -0
- package/skills/tier-1/ui-ux-pro-max/data/colors.csv +162 -0
- package/skills/tier-1/ui-ux-pro-max/data/design.csv +1776 -0
- package/skills/tier-1/ui-ux-pro-max/data/draft.csv +1779 -0
- package/skills/tier-1/ui-ux-pro-max/data/google-fonts.csv +1924 -0
- package/skills/tier-1/ui-ux-pro-max/data/icons.csv +106 -0
- package/skills/tier-1/ui-ux-pro-max/data/landing.csv +35 -0
- package/skills/tier-1/ui-ux-pro-max/data/products.csv +162 -0
- package/skills/tier-1/ui-ux-pro-max/data/react-performance.csv +45 -0
- package/skills/tier-1/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
- package/skills/tier-1/ui-ux-pro-max/data/styles.csv +85 -0
- package/skills/tier-1/ui-ux-pro-max/data/typography.csv +74 -0
- package/skills/tier-1/ui-ux-pro-max/data/ui-reasoning.csv +162 -0
- package/skills/tier-1/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
- package/skills/tier-1/ui-ux-pro-max/scripts/core.py +247 -0
- package/skills/tier-1/ui-ux-pro-max/scripts/design_system.py +1067 -0
- package/skills/tier-1/ui-ux-pro-max/scripts/search.py +114 -0
- package/skills/tier-1/ui-ux-pro-max/templates/base/quick-reference.md +297 -0
- package/skills/tier-1/ui-ux-pro-max/templates/base/skill-content.md +358 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/agent.json +21 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/claude.json +21 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/codebuddy.json +21 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/codex.json +21 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/continue.json +21 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/copilot.json +18 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/cursor.json +18 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/droid.json +21 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/gemini.json +21 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/kiro.json +18 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/opencode.json +21 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/qoder.json +21 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/roocode.json +18 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/trae.json +21 -0
- package/skills/tier-1/ui-ux-pro-max/templates/platforms/windsurf.json +18 -0
- package/skills/tier-1/web-frameworks/SKILL.md +324 -0
- package/skills/tier-1/web-frameworks/references/nextjs-app-router.md +465 -0
- package/skills/tier-1/web-frameworks/references/nextjs-data-fetching.md +459 -0
- package/skills/tier-1/web-frameworks/references/nextjs-optimization.md +511 -0
- package/skills/tier-1/web-frameworks/references/nextjs-server-components.md +495 -0
- package/skills/tier-1/web-frameworks/references/remix-icon-integration.md +603 -0
- package/skills/tier-1/web-frameworks/references/turborepo-caching.md +551 -0
- package/skills/tier-1/web-frameworks/references/turborepo-pipelines.md +517 -0
- package/skills/tier-1/web-frameworks/references/turborepo-setup.md +542 -0
- package/skills/tier-1/web-frameworks/scripts/.coverage +0 -0
- package/skills/tier-1/web-frameworks/scripts/__init__.py +0 -0
- package/skills/tier-1/web-frameworks/scripts/nextjs_init.py +547 -0
- package/skills/tier-1/web-frameworks/scripts/requirements.txt +16 -0
- package/skills/tier-1/web-frameworks/scripts/tests/coverage-web.json +1 -0
- package/skills/tier-1/web-frameworks/scripts/tests/requirements.txt +3 -0
- package/skills/tier-1/web-frameworks/scripts/tests/test_nextjs_init.py +319 -0
- package/skills/tier-1/web-frameworks/scripts/tests/test_turborepo_migrate.py +374 -0
- package/skills/tier-1/web-frameworks/scripts/turborepo_migrate.py +394 -0
- package/skills/tier-2/ai-multimodal/.env.example +97 -0
- package/skills/tier-2/ai-multimodal/SKILL.md +353 -0
- package/skills/tier-2/ai-multimodal/references/audio-processing.md +373 -0
- package/skills/tier-2/ai-multimodal/references/image-generation.md +558 -0
- package/skills/tier-2/ai-multimodal/references/video-analysis.md +498 -0
- package/skills/tier-2/ai-multimodal/references/vision-understanding.md +479 -0
- package/skills/tier-2/ai-multimodal/scripts/.coverage +0 -0
- package/skills/tier-2/ai-multimodal/scripts/document_converter.py +395 -0
- package/skills/tier-2/ai-multimodal/scripts/gemini_batch_process.py +480 -0
- package/skills/tier-2/ai-multimodal/scripts/media_optimizer.py +506 -0
- package/skills/tier-2/ai-multimodal/scripts/requirements.txt +26 -0
- package/skills/tier-2/ai-multimodal/scripts/tests/.coverage +0 -0
- package/skills/tier-2/ai-multimodal/scripts/tests/requirements.txt +20 -0
- package/skills/tier-2/ai-multimodal/scripts/tests/test_document_converter.py +74 -0
- package/skills/tier-2/ai-multimodal/scripts/tests/test_failures.log +258 -0
- package/skills/tier-2/ai-multimodal/scripts/tests/test_gemini_batch_process.py +362 -0
- package/skills/tier-2/ai-multimodal/scripts/tests/test_media_optimizer.py +373 -0
- package/skills/tier-2/autonomous-loops/SKILL.md +610 -0
- package/skills/tier-2/backend-patterns/SKILL.md +598 -0
- package/skills/tier-2/better-auth/SKILL.md +204 -0
- package/skills/tier-2/better-auth/references/advanced-features.md +553 -0
- package/skills/tier-2/better-auth/references/database-integration.md +577 -0
- package/skills/tier-2/better-auth/references/email-password-auth.md +416 -0
- package/skills/tier-2/better-auth/references/oauth-providers.md +430 -0
- package/skills/tier-2/better-auth/scripts/.coverage +0 -0
- package/skills/tier-2/better-auth/scripts/better_auth_init.py +521 -0
- package/skills/tier-2/better-auth/scripts/requirements.txt +15 -0
- package/skills/tier-2/better-auth/scripts/tests/.coverage +0 -0
- package/skills/tier-2/better-auth/scripts/tests/test_better_auth_init.py +421 -0
- package/skills/tier-2/brand/SKILL.md +97 -0
- package/skills/tier-2/brand/references/approval-checklist.md +169 -0
- package/skills/tier-2/brand/references/asset-organization.md +157 -0
- package/skills/tier-2/brand/references/brand-guideline-template.md +140 -0
- package/skills/tier-2/brand/references/color-palette-management.md +186 -0
- package/skills/tier-2/brand/references/consistency-checklist.md +94 -0
- package/skills/tier-2/brand/references/logo-usage-rules.md +185 -0
- package/skills/tier-2/brand/references/messaging-framework.md +85 -0
- package/skills/tier-2/brand/references/typography-specifications.md +214 -0
- package/skills/tier-2/brand/references/update.md +118 -0
- package/skills/tier-2/brand/references/visual-identity.md +96 -0
- package/skills/tier-2/brand/references/voice-framework.md +88 -0
- package/skills/tier-2/brand/scripts/extract-colors.cjs +341 -0
- package/skills/tier-2/brand/scripts/inject-brand-context.cjs +349 -0
- package/skills/tier-2/brand/scripts/sync-brand-to-tokens.cjs +266 -0
- package/skills/tier-2/brand/scripts/validate-asset.cjs +387 -0
- package/skills/tier-2/brand/templates/brand-guidelines-starter.md +275 -0
- package/skills/tier-2/claude-code/SKILL.md +188 -0
- package/skills/tier-2/claude-code/references/advanced-features.md +399 -0
- package/skills/tier-2/claude-code/references/agent-skills.md +399 -0
- package/skills/tier-2/claude-code/references/api-reference.md +498 -0
- package/skills/tier-2/claude-code/references/best-practices.md +447 -0
- package/skills/tier-2/claude-code/references/cicd-integration.md +428 -0
- package/skills/tier-2/claude-code/references/configuration.md +480 -0
- package/skills/tier-2/claude-code/references/enterprise-features.md +472 -0
- package/skills/tier-2/claude-code/references/getting-started.md +252 -0
- package/skills/tier-2/claude-code/references/hooks-and-plugins.md +441 -0
- package/skills/tier-2/claude-code/references/ide-integration.md +316 -0
- package/skills/tier-2/claude-code/references/mcp-integration.md +386 -0
- package/skills/tier-2/claude-code/references/slash-commands.md +489 -0
- package/skills/tier-2/claude-code/references/troubleshooting.md +456 -0
- package/skills/tier-2/codebase-onboarding/SKILL.md +233 -0
- package/skills/tier-2/coding-standards/SKILL.md +530 -0
- package/skills/tier-2/continuous-learning/SKILL.md +365 -0
- package/skills/tier-2/continuous-learning/agents/observer-loop.sh +191 -0
- package/skills/tier-2/continuous-learning/agents/observer.md +198 -0
- package/skills/tier-2/continuous-learning/agents/session-guardian.sh +150 -0
- package/skills/tier-2/continuous-learning/agents/start-observer.sh +240 -0
- package/skills/tier-2/continuous-learning/config.json +8 -0
- package/skills/tier-2/continuous-learning/hooks/observe.sh +412 -0
- package/skills/tier-2/continuous-learning/scripts/detect-project.sh +228 -0
- package/skills/tier-2/continuous-learning/scripts/instinct-cli.py +1426 -0
- package/skills/tier-2/continuous-learning/scripts/test_parse_instinct.py +984 -0
- package/skills/tier-2/database-migrations/SKILL.md +429 -0
- package/skills/tier-2/deployment-patterns/SKILL.md +427 -0
- package/skills/tier-2/design/SKILL.md +302 -0
- package/skills/tier-2/design/data/cip/deliverables.csv +51 -0
- package/skills/tier-2/design/data/cip/industries.csv +21 -0
- package/skills/tier-2/design/data/cip/mockup-contexts.csv +21 -0
- package/skills/tier-2/design/data/cip/styles.csv +21 -0
- package/skills/tier-2/design/data/icon/styles.csv +16 -0
- package/skills/tier-2/design/data/logo/colors.csv +56 -0
- package/skills/tier-2/design/data/logo/industries.csv +56 -0
- package/skills/tier-2/design/data/logo/styles.csv +56 -0
- package/skills/tier-2/design/references/banner-sizes-and-styles.md +118 -0
- package/skills/tier-2/design/references/cip-deliverable-guide.md +95 -0
- package/skills/tier-2/design/references/cip-design.md +121 -0
- package/skills/tier-2/design/references/cip-prompt-engineering.md +84 -0
- package/skills/tier-2/design/references/cip-style-guide.md +68 -0
- package/skills/tier-2/design/references/design-routing.md +207 -0
- package/skills/tier-2/design/references/icon-design.md +122 -0
- package/skills/tier-2/design/references/logo-color-psychology.md +101 -0
- package/skills/tier-2/design/references/logo-design.md +92 -0
- package/skills/tier-2/design/references/logo-prompt-engineering.md +158 -0
- package/skills/tier-2/design/references/logo-style-guide.md +109 -0
- package/skills/tier-2/design/references/slides-copywriting-formulas.md +84 -0
- package/skills/tier-2/design/references/slides-create.md +4 -0
- package/skills/tier-2/design/references/slides-html-template.md +295 -0
- package/skills/tier-2/design/references/slides-layout-patterns.md +137 -0
- package/skills/tier-2/design/references/slides-strategies.md +94 -0
- package/skills/tier-2/design/references/slides.md +42 -0
- package/skills/tier-2/design/references/social-photos-design.md +329 -0
- package/skills/tier-2/design/scripts/cip/core.py +215 -0
- package/skills/tier-2/design/scripts/cip/generate.py +484 -0
- package/skills/tier-2/design/scripts/cip/render-html.py +424 -0
- package/skills/tier-2/design/scripts/cip/search.py +127 -0
- package/skills/tier-2/design/scripts/icon/generate.py +487 -0
- package/skills/tier-2/design/scripts/logo/core.py +175 -0
- package/skills/tier-2/design/scripts/logo/generate.py +362 -0
- package/skills/tier-2/design/scripts/logo/search.py +114 -0
- package/skills/tier-2/design-system/SKILL.md +244 -0
- package/skills/tier-2/design-system/data/slide-backgrounds.csv +11 -0
- package/skills/tier-2/design-system/data/slide-charts.csv +26 -0
- package/skills/tier-2/design-system/data/slide-color-logic.csv +14 -0
- package/skills/tier-2/design-system/data/slide-copy.csv +26 -0
- package/skills/tier-2/design-system/data/slide-layout-logic.csv +16 -0
- package/skills/tier-2/design-system/data/slide-layouts.csv +26 -0
- package/skills/tier-2/design-system/data/slide-strategies.csv +16 -0
- package/skills/tier-2/design-system/data/slide-typography.csv +15 -0
- package/skills/tier-2/design-system/references/component-specs.md +236 -0
- package/skills/tier-2/design-system/references/component-tokens.md +214 -0
- package/skills/tier-2/design-system/references/primitive-tokens.md +203 -0
- package/skills/tier-2/design-system/references/semantic-tokens.md +215 -0
- package/skills/tier-2/design-system/references/states-and-variants.md +241 -0
- package/skills/tier-2/design-system/references/tailwind-integration.md +251 -0
- package/skills/tier-2/design-system/references/token-architecture.md +224 -0
- package/skills/tier-2/design-system/scripts/embed-tokens.cjs +99 -0
- package/skills/tier-2/design-system/scripts/fetch-background.py +317 -0
- package/skills/tier-2/design-system/scripts/generate-slide.py +753 -0
- package/skills/tier-2/design-system/scripts/generate-tokens.cjs +205 -0
- package/skills/tier-2/design-system/scripts/html-token-validator.py +327 -0
- package/skills/tier-2/design-system/scripts/search-slides.py +218 -0
- package/skills/tier-2/design-system/scripts/slide-token-validator.py +35 -0
- package/skills/tier-2/design-system/scripts/slide_search_core.py +453 -0
- package/skills/tier-2/design-system/scripts/validate-tokens.cjs +251 -0
- package/skills/tier-2/design-system/templates/design-tokens-starter.json +143 -0
- package/skills/tier-2/docker-patterns/SKILL.md +364 -0
- package/skills/tier-2/e2e-testing/SKILL.md +326 -0
- package/skills/tier-2/eval-harness/SKILL.md +270 -0
- package/skills/tier-2/frontend-patterns/SKILL.md +642 -0
- package/skills/tier-2/google-adk-python/SKILL.md +242 -0
- package/skills/tier-2/mcp-management/README.md +219 -0
- package/skills/tier-2/mcp-management/SKILL.md +209 -0
- package/skills/tier-2/mcp-management/assets/tools.json +3146 -0
- package/skills/tier-2/mcp-management/references/configuration.md +114 -0
- package/skills/tier-2/mcp-management/references/gemini-cli-integration.md +215 -0
- package/skills/tier-2/mcp-management/references/mcp-protocol.md +116 -0
- package/skills/tier-2/mcp-management/scripts/.env.example +10 -0
- package/skills/tier-2/mcp-management/scripts/cli.ts +195 -0
- package/skills/tier-2/mcp-management/scripts/dist/analyze-tools.js +70 -0
- package/skills/tier-2/mcp-management/scripts/dist/cli.js +127 -0
- package/skills/tier-2/mcp-management/scripts/dist/mcp-client.js +115 -0
- package/skills/tier-2/mcp-management/scripts/mcp-client.ts +230 -0
- package/skills/tier-2/mcp-management/scripts/package.json +20 -0
- package/skills/tier-2/mcp-management/scripts/tsconfig.json +15 -0
- package/skills/tier-2/mcp-server-patterns/SKILL.md +67 -0
- package/skills/tier-2/media-processing/SKILL.md +358 -0
- package/skills/tier-2/media-processing/references/ffmpeg-encoding.md +358 -0
- package/skills/tier-2/media-processing/references/ffmpeg-filters.md +503 -0
- package/skills/tier-2/media-processing/references/ffmpeg-streaming.md +403 -0
- package/skills/tier-2/media-processing/references/format-compatibility.md +375 -0
- package/skills/tier-2/media-processing/references/imagemagick-batch.md +612 -0
- package/skills/tier-2/media-processing/references/imagemagick-editing.md +623 -0
- package/skills/tier-2/media-processing/scripts/batch_resize.py +342 -0
- package/skills/tier-2/media-processing/scripts/media_convert.py +311 -0
- package/skills/tier-2/media-processing/scripts/requirements.txt +24 -0
- package/skills/tier-2/media-processing/scripts/tests/.coverage +0 -0
- package/skills/tier-2/media-processing/scripts/tests/requirements.txt +2 -0
- package/skills/tier-2/media-processing/scripts/tests/test_batch_resize.py +372 -0
- package/skills/tier-2/media-processing/scripts/tests/test_media_convert.py +259 -0
- package/skills/tier-2/media-processing/scripts/tests/test_video_optimize.py +397 -0
- package/skills/tier-2/media-processing/scripts/video_optimize.py +414 -0
- package/skills/tier-2/mobile-development/SKILL.md +212 -0
- package/skills/tier-2/mobile-development/references/mobile-android.md +604 -0
- package/skills/tier-2/mobile-development/references/mobile-best-practices.md +545 -0
- package/skills/tier-2/mobile-development/references/mobile-debugging.md +1089 -0
- package/skills/tier-2/mobile-development/references/mobile-frameworks.md +465 -0
- package/skills/tier-2/mobile-development/references/mobile-ios.md +496 -0
- package/skills/tier-2/mobile-development/references/mobile-mindset.md +544 -0
- package/skills/tier-2/payment-integration/README.md +185 -0
- package/skills/tier-2/payment-integration/SKILL.md +118 -0
- package/skills/tier-2/payment-integration/references/polar/benefits.md +396 -0
- package/skills/tier-2/payment-integration/references/polar/best-practices.md +482 -0
- package/skills/tier-2/payment-integration/references/polar/checkouts.md +266 -0
- package/skills/tier-2/payment-integration/references/polar/overview.md +184 -0
- package/skills/tier-2/payment-integration/references/polar/products.md +244 -0
- package/skills/tier-2/payment-integration/references/polar/sdk.md +436 -0
- package/skills/tier-2/payment-integration/references/polar/subscriptions.md +340 -0
- package/skills/tier-2/payment-integration/references/polar/webhooks.md +405 -0
- package/skills/tier-2/payment-integration/references/sepay/api.md +140 -0
- package/skills/tier-2/payment-integration/references/sepay/best-practices.md +337 -0
- package/skills/tier-2/payment-integration/references/sepay/overview.md +138 -0
- package/skills/tier-2/payment-integration/references/sepay/qr-codes.md +228 -0
- package/skills/tier-2/payment-integration/references/sepay/sdk.md +213 -0
- package/skills/tier-2/payment-integration/references/sepay/webhooks.md +208 -0
- package/skills/tier-2/payment-integration/scripts/.env.example +20 -0
- package/skills/tier-2/payment-integration/scripts/checkout-helper.js +244 -0
- package/skills/tier-2/payment-integration/scripts/package.json +17 -0
- package/skills/tier-2/payment-integration/scripts/polar-webhook-verify.js +202 -0
- package/skills/tier-2/payment-integration/scripts/sepay-webhook-verify.js +193 -0
- package/skills/tier-2/payment-integration/scripts/test-scripts.js +237 -0
- package/skills/tier-2/planning/SKILL.md +88 -0
- package/skills/tier-2/planning/references/codebase-understanding.md +62 -0
- package/skills/tier-2/planning/references/output-standards.md +87 -0
- package/skills/tier-2/planning/references/plan-organization.md +100 -0
- package/skills/tier-2/planning/references/research-phase.md +49 -0
- package/skills/tier-2/planning/references/solution-design.md +63 -0
- package/skills/tier-2/postgres-patterns/SKILL.md +147 -0
- package/skills/tier-2/problem-solving/SKILL.md +96 -0
- package/skills/tier-2/problem-solving/references/attribution.md +69 -0
- package/skills/tier-2/problem-solving/references/collision-zone-thinking.md +79 -0
- package/skills/tier-2/problem-solving/references/inversion-exercise.md +91 -0
- package/skills/tier-2/problem-solving/references/meta-pattern-recognition.md +87 -0
- package/skills/tier-2/problem-solving/references/scale-game.md +95 -0
- package/skills/tier-2/problem-solving/references/simplification-cascades.md +80 -0
- package/skills/tier-2/problem-solving/references/when-stuck.md +72 -0
- package/skills/tier-2/strategic-compact/SKILL.md +131 -0
- package/skills/tier-2/strategic-compact/suggest-compact.sh +54 -0
- package/skills/tier-2/verification-loop/SKILL.md +126 -0
- package/skills/tier-3/agentic-engineering/SKILL.md +63 -0
- package/skills/tier-3/banner-design/SKILL.md +192 -0
- package/skills/tier-3/banner-design/references/banner-sizes-and-styles.md +118 -0
- package/skills/tier-3/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/skills/tier-3/django-patterns/SKILL.md +734 -0
- package/skills/tier-3/golang-patterns/SKILL.md +674 -0
- package/skills/tier-3/kotlin-patterns/SKILL.md +711 -0
- package/skills/tier-3/laravel-patterns/SKILL.md +415 -0
- package/skills/tier-3/prompt-optimizer/SKILL.md +397 -0
- package/skills/tier-3/python-patterns/SKILL.md +750 -0
- package/skills/tier-3/pytorch-patterns/SKILL.md +396 -0
- package/skills/tier-3/rust-patterns/SKILL.md +499 -0
- package/skills/tier-3/shopify/README.md +66 -0
- package/skills/tier-3/shopify/SKILL.md +319 -0
- package/skills/tier-3/shopify/references/app-development.md +470 -0
- package/skills/tier-3/shopify/references/extensions.md +493 -0
- package/skills/tier-3/shopify/references/themes.md +498 -0
- package/skills/tier-3/shopify/scripts/.coverage +0 -0
- package/skills/tier-3/shopify/scripts/requirements.txt +19 -0
- package/skills/tier-3/shopify/scripts/shopify_init.py +423 -0
- package/skills/tier-3/shopify/scripts/tests/.coverage +0 -0
- package/skills/tier-3/shopify/scripts/tests/test_shopify_init.py +385 -0
- package/skills/tier-3/slides/SKILL.md +42 -0
- package/skills/tier-3/slides/references/copywriting-formulas.md +84 -0
- package/skills/tier-3/slides/references/create.md +4 -0
- package/skills/tier-3/slides/references/html-template.md +295 -0
- package/skills/tier-3/slides/references/layout-patterns.md +137 -0
- package/skills/tier-3/slides/references/slide-strategies.md +94 -0
- package/skills/tier-3/springboot-patterns/SKILL.md +314 -0
- package/skills/tier-3/swiftui-patterns/SKILL.md +259 -0
- package/skills/tier-3/threejs/SKILL.md +89 -0
- package/skills/tier-3/threejs/references/01-getting-started.md +177 -0
- package/skills/tier-3/threejs/references/02-loaders.md +169 -0
- package/skills/tier-3/threejs/references/03-textures.md +170 -0
- package/skills/tier-3/threejs/references/04-cameras.md +195 -0
- package/skills/tier-3/threejs/references/05-lights.md +183 -0
- package/skills/tier-3/threejs/references/06-animations.md +214 -0
- package/skills/tier-3/threejs/references/07-math.md +260 -0
- package/skills/tier-3/threejs/references/08-interaction.md +267 -0
- package/skills/tier-3/threejs/references/09-postprocessing.md +240 -0
- package/skills/tier-3/threejs/references/10-controls.md +259 -0
- package/skills/tier-3/threejs/references/11-materials-advanced.md +270 -0
- package/skills/tier-3/threejs/references/12-performance.md +269 -0
- package/skills/tier-3/threejs/references/13-node-materials.md +298 -0
- package/skills/tier-3/threejs/references/14-physics-vr.md +304 -0
- package/skills/tier-3/threejs/references/15-specialized-loaders.md +333 -0
- package/skills/tier-3/threejs/references/16-webgpu.md +302 -0
- package/skills/tier-3/vercel-deploy/SKILL.md +112 -0
- package/skills/tier-3/vercel-deploy/scripts/deploy.sh +249 -0
- package/workflows/development-rules.md +49 -0
- package/workflows/orchestration-protocol.md +16 -0
- 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();
|