@agentskillkit/agent-skills 1.0.1 → 3.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.agent/ARCHITECTURE.md +406 -149
- package/.agent/CONTINUOUS_EXECUTION_POLICY.md +623 -0
- package/.agent/GEMINI.md +935 -67
- package/.agent/WORKFLOW_CHAINS.md +683 -0
- package/.agent/agents/{code-archaeologist.md → analyst.md} +37 -25
- package/.agent/agents/assessor.md +186 -0
- package/.agent/agents/{backend-specialist.md → backend.md} +44 -30
- package/.agent/agents/critic.md +164 -0
- package/.agent/agents/{database-architect.md → database.md} +36 -24
- package/.agent/agents/{debugger.md → debug.md} +49 -43
- package/.agent/agents/{devops-engineer.md → devops.md} +50 -50
- package/.agent/agents/{documentation-writer.md → docs.md} +13 -13
- package/.agent/agents/{explorer-agent.md → explorer.md} +12 -6
- package/.agent/agents/{frontend-specialist.md → frontend.md} +79 -33
- package/.agent/agents/{game-developer.md → gamedev.md} +30 -30
- package/.agent/agents/lead.md +447 -0
- package/.agent/agents/learner.md +143 -0
- package/.agent/agents/mobile.md +383 -0
- package/.agent/agents/orchestrator.md +122 -339
- package/.agent/agents/pentest.md +188 -0
- package/.agent/agents/{performance-optimizer.md → perf.md} +44 -40
- package/.agent/agents/planner.md +413 -0
- package/.agent/agents/{product-manager.md → pm.md} +38 -23
- package/.agent/agents/po.md +106 -0
- package/.agent/agents/qa.md +109 -0
- package/.agent/agents/recovery.md +168 -0
- package/.agent/agents/security.md +171 -0
- package/.agent/agents/{seo-specialist.md → seo.md} +24 -24
- package/.agent/agents/{test-engineer.md → testing.md} +39 -39
- package/.agent/archive/registry.json.v1-backup +514 -0
- package/.agent/config/execution-policy.json +90 -0
- package/.agent/config/metrics-config.json +109 -0
- package/.agent/config/notification-config.json +43 -0
- package/.agent/knowledge/README.md +95 -0
- package/.agent/knowledge/_migration_backup/lessons-learned_2026-01-27T07-45-58.862Z.yaml +55 -0
- package/.agent/knowledge/_needs_review.yaml +24 -0
- package/.agent/knowledge/autopilot-metrics.json +93 -0
- package/.agent/knowledge/autopilot-runs.json +11 -0
- package/.agent/knowledge/backups/2026-01-25T17-08-04-097Z/lessons-learned.yaml +12 -0
- package/.agent/knowledge/backups/2026-01-25T17-08-04-097Z/settings.yaml +5 -0
- package/.agent/knowledge/backups/2026-01-25T17-08-08-345Z/lessons-learned.yaml +12 -0
- package/.agent/knowledge/backups/2026-01-25T17-08-08-345Z/settings.yaml +5 -0
- package/.agent/knowledge/backups/2026-01-25T17-08-09-232Z/lessons-learned.yaml +12 -0
- package/.agent/knowledge/backups/2026-01-25T17-08-09-232Z/settings.yaml +5 -0
- package/.agent/knowledge/backups/2026-01-29T15-15-32-715Z/lessons-learned.yaml +37 -0
- package/.agent/knowledge/backups/2026-01-29T15-15-32-715Z/settings.yaml +24 -0
- package/.agent/knowledge/backups/lessons-learned.yaml.archived +58 -0
- package/.agent/knowledge/backups/lessons-learned.yaml.bak-20260128-180048 +58 -0
- package/.agent/knowledge/backups/lessons.yaml.archived +2 -0
- package/.agent/knowledge/detected-errors.json +5 -0
- package/.agent/knowledge/evolution-signals.json +95 -0
- package/.agent/knowledge/improvements.yaml +68 -0
- package/.agent/knowledge/index.json +133 -0
- package/.agent/knowledge/lessons-learned.json +15 -0
- package/.agent/knowledge/lessons-learned.yaml +10 -15
- package/.agent/knowledge/metrics.json +66 -0
- package/.agent/knowledge/mistakes.yaml +74 -0
- package/.agent/knowledge/retention.yaml +165 -0
- package/.agent/knowledge/scans/scan_1769543882183.json +13 -0
- package/.agent/knowledge/scans/scan_1769543882322.json +13 -0
- package/.agent/knowledge/scans/scan_1769543882443.json +13 -0
- package/.agent/knowledge/scans/scan_1769543889157.json +13 -0
- package/.agent/knowledge/scans/scan_1769543950029.json +13 -0
- package/.agent/knowledge/scans/scan_1769696246716.json +13 -0
- package/.agent/knowledge/scans/scan_1769696247452.json +13 -0
- package/.agent/knowledge/scans/scan_1769698907767.json +13 -0
- package/.agent/knowledge/scans/scan_1769698934018.json +13 -0
- package/.agent/knowledge/scans/scan_1769699718013.json +13 -0
- package/.agent/knowledge/schema/common.schema.json +140 -0
- package/.agent/knowledge/schema/evolution-signals.schema.json +93 -0
- package/.agent/knowledge/schema/improvements.schema.json +132 -0
- package/.agent/knowledge/schema/mistakes.schema.json +138 -0
- package/.agent/knowledge/schema/settings.schema.json +102 -0
- package/.agent/knowledge/settings.yaml +5 -0
- package/.agent/knowledge/taxonomy.yaml +218 -0
- package/.agent/metrics/autopilot-metrics-schema.yaml +183 -0
- package/.agent/scripts-js/adaptive-workflow.js +504 -0
- package/.agent/scripts-js/auto_preview.js +166 -0
- package/.agent/scripts-js/autopilot-metrics.js +567 -0
- package/.agent/scripts-js/autopilot-runner.js +455 -0
- package/.agent/scripts-js/batch-skill-update.cjs +248 -0
- package/.agent/scripts-js/benchmark.cjs +147 -0
- package/.agent/scripts-js/checklist.js +174 -0
- package/.agent/scripts-js/compact-registry.cjs +79 -0
- package/.agent/scripts-js/execution-history.js +119 -0
- package/.agent/scripts-js/execution-policy.js +339 -0
- package/.agent/scripts-js/health-check.js +192 -0
- package/.agent/scripts-js/metrics-collector.js +364 -0
- package/.agent/scripts-js/metrics-dashboard.js +372 -0
- package/.agent/scripts-js/preflight-assessment.js +347 -0
- package/.agent/scripts-js/scaffold-nextjs.js +197 -0
- package/.agent/scripts-js/session_manager.js +200 -0
- package/.agent/scripts-js/skill-validator.js +318 -0
- package/.agent/scripts-js/utils/colors.js +56 -0
- package/.agent/scripts-js/utils/process-manager.js +148 -0
- package/.agent/scripts-js/utils/reporter.js +168 -0
- package/.agent/scripts-js/utils/runner.js +117 -0
- package/.agent/scripts-js/verify-skills.js +252 -0
- package/.agent/scripts-js/verify_all.js +242 -0
- package/.agent/scripts-js/workflow-engine.js +545 -0
- package/.agent/scripts-js/workflow-validator.js +417 -0
- package/.agent/skill-lock.json +343 -0
- package/.agent/skills/agent-patterns/SKILL.md +761 -0
- package/.agent/skills/auto-learner/SKILL.md +280 -0
- package/.agent/skills/auto-learner/dashboard/index.html +494 -0
- package/.agent/skills/auto-learner/references/learned-imports.md +50 -0
- package/.agent/skills/auto-learner/scripts/dashboard_server.js +224 -0
- package/.agent/skills/auto-learner/scripts/error_sensor.js +460 -0
- package/.agent/skills/auto-learner/scripts/learn_from_failure.js +225 -0
- package/.agent/skills/auto-learner/scripts/pattern_analyzer.js +594 -0
- package/.agent/skills/auto-learner/scripts/pre_execution_check.js +464 -0
- package/.agent/skills/auto-learner/scripts/user_correction_sensor.js +426 -0
- package/.agent/skills/debug-pro/SKILL.md +354 -0
- package/.agent/skills/execution-reporter/SKILL.md +195 -0
- package/.agent/skills/gitops/SKILL.md +303 -0
- package/.agent/skills/gitops/references/argocd-setup.md +134 -0
- package/.agent/skills/gitops/references/sync-policies.md +131 -0
- package/.agent/skills/lifecycle-orchestrator/SKILL.md +83 -0
- package/.agent/skills/mobile-design/SKILL.md +258 -50
- package/.agent/skills/mobile-developer/SKILL.md +205 -0
- package/.agent/skills/mobile-security-coder/SKILL.md +184 -0
- package/.agent/skills/observability/SKILL.md +397 -0
- package/.agent/skills/problem-checker/SKILL.md +195 -0
- package/.agent/skills/problem-checker/scripts/check_problems.js +261 -0
- package/.agent/skills/registry.backup.json +2251 -0
- package/.agent/skills/registry.json +940 -366
- package/.agent/skills/registry.phase1.backup.json +1278 -0
- package/.agent/skills/requirements-python.txt +25 -0
- package/.agent/skills/requirements.txt +96 -0
- package/.agent/skills/state-rollback/SKILL.md +240 -0
- package/.agent/skills/state-rollback/scripts/state_manager.js +282 -0
- package/.agent/skills/studio/SKILL.md +107 -0
- package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/styles.csv +16 -16
- package/.agent/skills/studio/scripts-js/core.js +344 -0
- package/.agent/skills/studio/scripts-js/design_system.js +952 -0
- package/.agent/skills/studio/scripts-js/jsconfig.json +27 -0
- package/.agent/skills/studio/scripts-js/search.js +191 -0
- package/.agent/skills/studio/scripts-js/types.d.ts +276 -0
- package/.agent/skills/studio/scripts-js/utils/component-specs.js +153 -0
- package/.agent/skills/studio/scripts-js/utils/config-loader.js +164 -0
- package/.agent/skills/studio/scripts-js/utils/css-templates.js +168 -0
- package/.agent/skills/studio/scripts-js/utils/css-validator.js +94 -0
- package/.agent/skills/studio/scripts-js/utils/csv-loader.js +55 -0
- package/.agent/skills/studio/scripts-js/utils/intelligent-overrides.js +128 -0
- package/.agent/skills/studio/scripts-js/utils/page-override-formatter.js +142 -0
- package/.agent/skills/studio/scripts-js/utils/page-type-detector.js +123 -0
- package/.agent/skills/studio/scripts-js/utils/search-cache.js +190 -0
- package/.agent/skills/studio/scripts-js/utils/text-utils.js +54 -0
- package/.agent/skills/typescript-expert/SKILL.md +429 -0
- package/.agent/skills/typescript-expert/references/tsconfig-strict.json +92 -0
- package/.agent/skills/typescript-expert/references/typescript-cheatsheet.md +383 -0
- package/.agent/skills/typescript-expert/references/utility-types.ts +335 -0
- package/.agent/skills/typescript-expert/scripts/ts_diagnostic.py +203 -0
- package/.agent/skills-audit-report.md +114 -0
- package/.agent/workflows/README.md +707 -0
- package/.agent/workflows/agent.md +77 -0
- package/.agent/workflows/alert.md +333 -0
- package/.agent/workflows/api.md +209 -0
- package/.agent/workflows/architect.md +148 -42
- package/.agent/workflows/auto-accept-process.md +275 -0
- package/.agent/workflows/autopilot.md +755 -92
- package/.agent/workflows/benchmark.md +221 -0
- package/.agent/workflows/boost.md +61 -26
- package/.agent/workflows/build.md +114 -54
- package/.agent/workflows/chronicle.md +19 -0
- package/.agent/workflows/diagnose.md +72 -30
- package/.agent/workflows/diagram.md +121 -0
- package/.agent/workflows/flags.md +149 -0
- package/.agent/workflows/forge.md +15 -5
- package/.agent/workflows/game.md +142 -0
- package/.agent/workflows/inspect.md +76 -40
- package/.agent/workflows/launch.md +183 -40
- package/.agent/workflows/mobile.md +106 -0
- package/.agent/workflows/monitor.md +283 -0
- package/.agent/workflows/optimize.md +220 -0
- package/.agent/workflows/pulse.md +113 -43
- package/.agent/workflows/stage.md +37 -10
- package/.agent/workflows/studio.md +35 -13
- package/.agent/workflows/think.md +19 -0
- package/.agent/workflows/validate.md +21 -1
- package/CHANGELOG.md +448 -24
- package/LICENSE +29 -7
- package/README.backup.md +540 -0
- package/README.md +870 -203
- package/docs/README.md +62 -0
- package/docs/archive/plan-v21.md +170 -0
- package/docs/getting-started.md +337 -0
- package/docs/guides/migration.md +70 -0
- package/docs/guides/publishing.md +88 -0
- package/docs/reference/python-strategy.md +393 -0
- package/docs/reference/scripts.md +56 -0
- package/docs/reference/skill-standard.md +457 -0
- package/package.json +51 -7
- package/packages/cli/.agent/knowledge/evolution-signals.json +51 -0
- package/packages/cli/.agent/knowledge/lessons-learned.yaml +25 -15
- package/packages/cli/.agent/knowledge/scans/scan_demo.json +58 -0
- package/packages/cli/README.md +21 -0
- package/packages/cli/bin/{ag-smart.js → agent.js} +37 -5
- package/packages/cli/examples/demo-violations.js +27 -0
- package/packages/cli/lib/audit.js +134 -49
- package/packages/cli/lib/audit.test.js +100 -0
- package/packages/cli/lib/auto-learn.js +1 -1
- package/packages/cli/lib/backup.js +138 -0
- package/packages/cli/lib/backup.test.js +78 -0
- package/packages/cli/lib/cognitive-lesson.js +476 -0
- package/packages/cli/lib/completion.js +149 -0
- package/packages/cli/lib/config.js +8 -2
- package/packages/cli/lib/eslint-fix.js +1 -1
- package/packages/cli/lib/evolution-signal.js +215 -0
- package/packages/cli/lib/export.js +86 -0
- package/packages/cli/lib/export.test.js +65 -0
- package/packages/cli/lib/fix.js +61 -2
- package/packages/cli/lib/fix.test.js +80 -0
- package/packages/cli/lib/gemini-export.js +83 -0
- package/packages/cli/lib/hooks/install-hooks.js +8 -32
- package/packages/cli/lib/hooks/lint-learn.js +2 -2
- package/packages/cli/lib/icons.js +93 -0
- package/packages/cli/lib/ignore.js +116 -0
- package/packages/cli/lib/ignore.test.js +58 -0
- package/packages/cli/lib/init.js +124 -0
- package/packages/cli/lib/knowledge-index.js +326 -0
- package/packages/cli/lib/knowledge-metrics.js +335 -0
- package/packages/cli/lib/knowledge-retention.js +398 -0
- package/packages/cli/lib/knowledge-validator.js +312 -0
- package/packages/cli/lib/learn.js +115 -33
- package/packages/cli/lib/migrate-to-v4.js +322 -0
- package/packages/cli/lib/proposals.js +199 -0
- package/packages/cli/lib/proposals.test.js +56 -0
- package/packages/cli/lib/recall.js +792 -41
- package/packages/cli/lib/recall.test.js +107 -0
- package/packages/cli/lib/selfevolution-bridge.js +167 -0
- package/packages/cli/lib/settings.js +203 -0
- package/packages/cli/lib/skill-learn.js +1 -1
- package/packages/cli/lib/stats.js +31 -42
- package/packages/cli/lib/stats.test.js +94 -0
- package/packages/cli/lib/ui/audit-ui.js +146 -0
- package/packages/cli/lib/ui/backup-ui.js +107 -0
- package/packages/cli/lib/ui/clack-helpers.js +317 -0
- package/packages/cli/lib/ui/common.js +83 -0
- package/packages/cli/lib/ui/completion-ui.js +126 -0
- package/packages/cli/lib/ui/custom-select.js +69 -0
- package/packages/cli/lib/ui/evolution-signals-ui.js +107 -0
- package/packages/cli/lib/ui/export-ui.js +94 -0
- package/packages/cli/lib/ui/fix-all-ui.js +191 -0
- package/packages/cli/lib/ui/help-ui.js +26 -0
- package/packages/cli/lib/ui/index.js +147 -0
- package/packages/cli/lib/ui/init-ui.js +56 -0
- package/packages/cli/lib/ui/knowledge-ui.js +55 -0
- package/packages/cli/lib/ui/learn-ui.js +706 -0
- package/packages/cli/lib/ui/lessons-ui.js +148 -0
- package/packages/cli/lib/ui/pretty.js +145 -0
- package/packages/cli/lib/ui/proposals-ui.js +99 -0
- package/packages/cli/lib/ui/recall-ui.js +342 -0
- package/packages/cli/lib/ui/routing-demo.js +79 -0
- package/packages/cli/lib/ui/routing-ui.js +325 -0
- package/packages/cli/lib/ui/settings-ui.js +103 -0
- package/packages/cli/lib/ui/stats-ui.js +73 -0
- package/packages/cli/lib/ui/watch-ui.js +236 -0
- package/packages/cli/lib/watcher.js +1 -1
- package/packages/cli/lib/watcher.test.js +85 -0
- package/packages/cli/node_modules/.package-lock.json +1529 -0
- package/packages/cli/node_modules/.vite/vitest/results.json +1 -0
- package/packages/cli/package-lock.json +1164 -688
- package/packages/cli/package.json +39 -10
- package/packages/cli/scripts/export-key.js +80 -0
- package/packages/cli/src/MIGRATION.md +418 -0
- package/packages/cli/src/README.md +367 -0
- package/packages/cli/src/core/evolution/evolution-signal.js +42 -0
- package/packages/cli/src/core/evolution/index.js +17 -0
- package/packages/cli/src/core/evolution/review-gate.js +40 -0
- package/packages/cli/src/core/evolution/signal-detector.js +137 -0
- package/packages/cli/src/core/evolution/signal-queue.js +79 -0
- package/packages/cli/src/core/evolution/threshold-checker.js +79 -0
- package/packages/cli/src/core/index.js +15 -0
- package/packages/cli/src/core/learning/cognitive-enhancer.js +282 -0
- package/packages/cli/src/core/learning/index.js +12 -0
- package/packages/cli/src/core/learning/lesson-synthesizer.js +83 -0
- package/packages/cli/src/core/scanning/index.js +14 -0
- package/packages/cli/src/data/index.js +13 -0
- package/packages/cli/src/data/repositories/index.js +8 -0
- package/packages/cli/src/data/repositories/lesson-repository.js +130 -0
- package/packages/cli/src/data/repositories/signal-repository.js +119 -0
- package/packages/cli/src/data/storage/index.js +8 -0
- package/packages/cli/src/data/storage/json-storage.js +64 -0
- package/packages/cli/src/data/storage/yaml-storage.js +66 -0
- package/packages/cli/src/infrastructure/index.js +13 -0
- package/packages/cli/src/presentation/formatters/skill-formatter.js +232 -0
- package/packages/cli/src/services/export-service.js +162 -0
- package/packages/cli/src/services/index.js +13 -0
- package/packages/cli/src/services/learning-service.js +99 -0
- package/packages/cli/tests/integration/evolution-signals.test.js +46 -0
- package/packages/cli/tests/integration/gemini-export.test.js +53 -0
- package/packages/cli/tests/integration/learning-service.test.js +33 -0
- package/packages/cli/tests/integration/signal-detector.test.js +29 -0
- package/packages/cli/tests/unit/cognitive-enhancer.test.js +56 -0
- package/packages/cli/tests/unit/lesson-synthesizer.test.js +84 -0
- package/packages/cli/tests/unit/skill-formatter.test.js +106 -0
- package/packages/cli/vitest.config.js +28 -1
- package/scripts/rebrand/README.md +472 -0
- package/scripts/rebrand/index.mjs +449 -0
- package/scripts/rebrand/v4.mjs +800 -0
- package/tests/e2e/studio-workflow.test.js +100 -0
- package/tests/e2e/validate-workflow.test.js +71 -0
- package/tests/scripts/colors.test.js +75 -0
- package/tests/scripts/component-specs.test.js +157 -0
- package/tests/scripts/config-loader.test.js +204 -0
- package/tests/scripts/core-bm25.test.js +112 -0
- package/tests/scripts/css-templates.test.js +123 -0
- package/tests/scripts/css-validator.test.js +137 -0
- package/tests/scripts/format-master-md.test.js +232 -0
- package/tests/scripts/integration/studio-integration.test.js +183 -0
- package/tests/scripts/intelligent-overrides.test.js +181 -0
- package/tests/scripts/page-override-formatter.test.js +227 -0
- package/tests/scripts/page-type-detector.test.js +141 -0
- package/tests/scripts/process-manager.test.js +79 -0
- package/tests/scripts/reporter.test.js +96 -0
- package/tests/scripts/runner.test.js +82 -0
- package/tests/scripts/search-cache.test.js +210 -0
- package/tests/scripts/text-utils.test.js +63 -0
- package/.agent/.shared/ui-ux-pro-max/scripts/__pycache__/core.cpython-313.pyc +0 -0
- package/.agent/.shared/ui-ux-pro-max/scripts/__pycache__/design_system.cpython-313.pyc +0 -0
- package/.agent/.shared/ui-ux-pro-max/scripts/core.py +0 -258
- package/.agent/.shared/ui-ux-pro-max/scripts/design_system.py +0 -1067
- package/.agent/.shared/ui-ux-pro-max/scripts/search.py +0 -106
- package/.agent/agents/mobile-developer.md +0 -377
- package/.agent/agents/penetration-tester.md +0 -188
- package/.agent/agents/product-owner.md +0 -95
- package/.agent/agents/project-planner.md +0 -406
- package/.agent/agents/qa-automation-engineer.md +0 -103
- package/.agent/agents/security-auditor.md +0 -170
- package/.agent/rules/GEMINI.md +0 -253
- package/.agent/scripts/auto_preview.py +0 -148
- package/.agent/scripts/checklist.py +0 -217
- package/.agent/scripts/session_manager.py +0 -120
- package/.agent/scripts/verify_all.py +0 -327
- package/.agent/skills/aesthetic/SKILL.md +0 -121
- package/.agent/skills/aesthetic/assets/design-guideline-template.md +0 -163
- package/.agent/skills/aesthetic/assets/design-story-template.md +0 -135
- package/.agent/skills/aesthetic/references/design-principles.md +0 -62
- package/.agent/skills/aesthetic/references/design-resources.md +0 -75
- package/.agent/skills/aesthetic/references/micro-interactions.md +0 -53
- package/.agent/skills/aesthetic/references/storytelling-design.md +0 -50
- package/.agent/skills/api-patterns/SKILL.md +0 -81
- package/.agent/skills/api-patterns/rules/api-style.md +0 -42
- package/.agent/skills/api-patterns/rules/auth.md +0 -24
- package/.agent/skills/api-patterns/rules/documentation.md +0 -26
- package/.agent/skills/api-patterns/rules/graphql.md +0 -41
- package/.agent/skills/api-patterns/rules/rate-limiting.md +0 -31
- package/.agent/skills/api-patterns/rules/response.md +0 -37
- package/.agent/skills/api-patterns/rules/rest.md +0 -40
- package/.agent/skills/api-patterns/rules/security-testing.md +0 -122
- package/.agent/skills/api-patterns/rules/trpc.md +0 -41
- package/.agent/skills/api-patterns/rules/versioning.md +0 -22
- package/.agent/skills/api-patterns/scripts/api_validator.py +0 -211
- package/.agent/skills/app-builder/SKILL.md +0 -75
- package/.agent/skills/app-builder/agent-coordination.md +0 -71
- package/.agent/skills/app-builder/feature-building.md +0 -53
- package/.agent/skills/app-builder/project-detection.md +0 -34
- package/.agent/skills/app-builder/scaffolding.md +0 -118
- package/.agent/skills/app-builder/tech-stack.md +0 -40
- package/.agent/skills/app-builder/templates/SKILL.md +0 -39
- package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +0 -76
- package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +0 -92
- package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +0 -88
- package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +0 -88
- package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +0 -83
- package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +0 -90
- package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +0 -90
- package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +0 -82
- package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +0 -100
- package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +0 -106
- package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +0 -101
- package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +0 -83
- package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +0 -93
- package/.agent/skills/architecture/SKILL.md +0 -55
- package/.agent/skills/architecture/context-discovery.md +0 -43
- package/.agent/skills/architecture/examples.md +0 -94
- package/.agent/skills/architecture/pattern-selection.md +0 -68
- package/.agent/skills/architecture/patterns-reference.md +0 -50
- package/.agent/skills/architecture/trade-off-analysis.md +0 -77
- package/.agent/skills/bash-linux/SKILL.md +0 -199
- package/.agent/skills/behavioral-modes/SKILL.md +0 -242
- package/.agent/skills/brainstorming/SKILL.md +0 -163
- package/.agent/skills/brainstorming/dynamic-questioning.md +0 -350
- package/.agent/skills/clean-code/SKILL.md +0 -201
- package/.agent/skills/code-review-checklist/SKILL.md +0 -109
- package/.agent/skills/code-reviewer/.skill-source.json +0 -8
- package/.agent/skills/code-reviewer/SKILL.md +0 -32
- package/.agent/skills/code-reviewer/enforcement/checklists/backend-api-review-checklist.md +0 -5
- package/.agent/skills/code-reviewer/examples/approved-pr/review-output.md +0 -76
- package/.agent/skills/code-reviewer/examples/rejected-pr/review-output.md +0 -99
- package/.agent/skills/code-reviewer/examples/scenarios.md +0 -3
- package/.agent/skills/code-reviewer/metadata/doctrine-mapping.yaml +0 -167
- package/.agent/skills/code-reviewer/metadata/intent-triggers.yaml +0 -41
- package/.agent/skills/code-reviewer/resources/links.md +0 -59
- package/.agent/skills/code-reviewer/scripts/audit_pr.js +0 -8
- package/.agent/skills/code-reviewer/scripts/audit_pr.v2.js +0 -417
- package/.agent/skills/code-reviewer/scripts/validate_doctrine.js +0 -307
- package/.agent/skills/context-engineering/SKILL.md +0 -86
- package/.agent/skills/context-engineering/references/context-compression.md +0 -84
- package/.agent/skills/context-engineering/references/context-degradation.md +0 -93
- package/.agent/skills/context-engineering/references/context-fundamentals.md +0 -75
- package/.agent/skills/context-engineering/references/context-optimization.md +0 -82
- package/.agent/skills/context-engineering/references/evaluation.md +0 -89
- package/.agent/skills/context-engineering/references/memory-systems.md +0 -88
- package/.agent/skills/context-engineering/references/multi-agent-patterns.md +0 -90
- package/.agent/skills/context-engineering/references/project-development.md +0 -97
- package/.agent/skills/context-engineering/references/tool-design.md +0 -86
- package/.agent/skills/context-engineering/scripts/compression_evaluator.py +0 -329
- package/.agent/skills/context-engineering/scripts/context_analyzer.py +0 -294
- package/.agent/skills/database-design/SKILL.md +0 -52
- package/.agent/skills/database-design/database-selection.md +0 -43
- package/.agent/skills/database-design/indexing.md +0 -39
- package/.agent/skills/database-design/migrations.md +0 -48
- package/.agent/skills/database-design/optimization.md +0 -36
- package/.agent/skills/database-design/orm-selection.md +0 -30
- package/.agent/skills/database-design/schema-design.md +0 -56
- package/.agent/skills/database-design/scripts/schema_validator.py +0 -172
- package/.agent/skills/debugging/SKILL.md +0 -42
- package/.agent/skills/deployment-procedures/SKILL.md +0 -241
- package/.agent/skills/doc.md +0 -177
- package/.agent/skills/document-skills/SKILL.md +0 -49
- package/.agent/skills/document-skills/docx/LICENSE.txt +0 -30
- package/.agent/skills/document-skills/docx/SKILL.md +0 -197
- package/.agent/skills/document-skills/docx/docx-js.md +0 -350
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
- package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
- package/.agent/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
- package/.agent/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
- package/.agent/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
- package/.agent/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
- package/.agent/skills/document-skills/docx/ooxml/schemas/mce/mc.xsd +0 -75
- package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2010.xsd +0 -560
- package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2012.xsd +0 -67
- package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2018.xsd +0 -14
- package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +0 -20
- package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +0 -13
- package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
- package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +0 -8
- package/.agent/skills/document-skills/docx/ooxml/scripts/pack.py +0 -159
- package/.agent/skills/document-skills/docx/ooxml/scripts/unpack.py +0 -29
- package/.agent/skills/document-skills/docx/ooxml/scripts/validate.py +0 -69
- package/.agent/skills/document-skills/docx/ooxml/scripts/validation/__init__.py +0 -15
- package/.agent/skills/document-skills/docx/ooxml/scripts/validation/base.py +0 -951
- package/.agent/skills/document-skills/docx/ooxml/scripts/validation/docx.py +0 -274
- package/.agent/skills/document-skills/docx/ooxml/scripts/validation/pptx.py +0 -315
- package/.agent/skills/document-skills/docx/ooxml/scripts/validation/redlining.py +0 -279
- package/.agent/skills/document-skills/docx/ooxml.md +0 -610
- package/.agent/skills/document-skills/docx/scripts/__init__.py +0 -1
- package/.agent/skills/document-skills/docx/scripts/document.py +0 -1276
- package/.agent/skills/document-skills/docx/scripts/templates/comments.xml +0 -3
- package/.agent/skills/document-skills/docx/scripts/templates/commentsExtended.xml +0 -3
- package/.agent/skills/document-skills/docx/scripts/templates/commentsExtensible.xml +0 -3
- package/.agent/skills/document-skills/docx/scripts/templates/commentsIds.xml +0 -3
- package/.agent/skills/document-skills/docx/scripts/templates/people.xml +0 -3
- package/.agent/skills/document-skills/docx/scripts/utilities.py +0 -374
- package/.agent/skills/document-skills/pdf/LICENSE.txt +0 -30
- package/.agent/skills/document-skills/pdf/SKILL.md +0 -294
- package/.agent/skills/document-skills/pdf/forms.md +0 -205
- package/.agent/skills/document-skills/pdf/reference.md +0 -612
- package/.agent/skills/document-skills/pdf/scripts/check_bounding_boxes.py +0 -70
- package/.agent/skills/document-skills/pdf/scripts/check_bounding_boxes_test.py +0 -226
- package/.agent/skills/document-skills/pdf/scripts/check_fillable_fields.py +0 -12
- package/.agent/skills/document-skills/pdf/scripts/convert_pdf_to_images.py +0 -35
- package/.agent/skills/document-skills/pdf/scripts/create_validation_image.py +0 -41
- package/.agent/skills/document-skills/pdf/scripts/extract_form_field_info.py +0 -152
- package/.agent/skills/document-skills/pdf/scripts/fill_fillable_fields.py +0 -114
- package/.agent/skills/document-skills/pdf/scripts/fill_pdf_form_with_annotations.py +0 -108
- package/.agent/skills/document-skills/pptx/LICENSE.txt +0 -30
- package/.agent/skills/document-skills/pptx/SKILL.md +0 -484
- package/.agent/skills/document-skills/pptx/html2pptx.md +0 -625
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
- package/.agent/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
- package/.agent/skills/document-skills/pptx/ooxml/schemas/mce/mc.xsd +0 -75
- package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2010.xsd +0 -560
- package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2012.xsd +0 -67
- package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2018.xsd +0 -14
- package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +0 -20
- package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +0 -13
- package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
- package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +0 -8
- package/.agent/skills/document-skills/pptx/ooxml/scripts/pack.py +0 -159
- package/.agent/skills/document-skills/pptx/ooxml/scripts/unpack.py +0 -29
- package/.agent/skills/document-skills/pptx/ooxml/scripts/validate.py +0 -69
- package/.agent/skills/document-skills/pptx/ooxml/scripts/validation/__init__.py +0 -15
- package/.agent/skills/document-skills/pptx/ooxml/scripts/validation/base.py +0 -951
- package/.agent/skills/document-skills/pptx/ooxml/scripts/validation/docx.py +0 -274
- package/.agent/skills/document-skills/pptx/ooxml/scripts/validation/pptx.py +0 -315
- package/.agent/skills/document-skills/pptx/ooxml/scripts/validation/redlining.py +0 -279
- package/.agent/skills/document-skills/pptx/ooxml.md +0 -427
- package/.agent/skills/document-skills/pptx/scripts/html2pptx.js +0 -979
- package/.agent/skills/document-skills/pptx/scripts/inventory.py +0 -1020
- package/.agent/skills/document-skills/pptx/scripts/rearrange.py +0 -231
- package/.agent/skills/document-skills/pptx/scripts/replace.py +0 -385
- package/.agent/skills/document-skills/pptx/scripts/thumbnail.py +0 -450
- package/.agent/skills/document-skills/xlsx/LICENSE.txt +0 -30
- package/.agent/skills/document-skills/xlsx/SKILL.md +0 -289
- package/.agent/skills/document-skills/xlsx/recalc.py +0 -178
- package/.agent/skills/documentation-templates/SKILL.md +0 -194
- package/.agent/skills/frontend/SKILL.md +0 -38
- package/.agent/skills/frontend/rules/_sections.md +0 -46
- package/.agent/skills/frontend/rules/_template.md +0 -28
- package/.agent/skills/frontend/rules/advanced-event-handler-refs.md +0 -55
- package/.agent/skills/frontend/rules/advanced-init-once.md +0 -42
- package/.agent/skills/frontend/rules/advanced-use-latest.md +0 -39
- package/.agent/skills/frontend/rules/async-api-routes.md +0 -38
- package/.agent/skills/frontend/rules/async-defer-await.md +0 -80
- package/.agent/skills/frontend/rules/async-dependencies.md +0 -51
- package/.agent/skills/frontend/rules/async-parallel.md +0 -28
- package/.agent/skills/frontend/rules/async-suspense-boundaries.md +0 -99
- package/.agent/skills/frontend/rules/bundle-barrel-imports.md +0 -59
- package/.agent/skills/frontend/rules/bundle-conditional.md +0 -31
- package/.agent/skills/frontend/rules/bundle-defer-third-party.md +0 -49
- package/.agent/skills/frontend/rules/bundle-dynamic-imports.md +0 -35
- package/.agent/skills/frontend/rules/bundle-preload.md +0 -50
- package/.agent/skills/frontend/rules/client-event-listeners.md +0 -74
- package/.agent/skills/frontend/rules/client-localstorage-schema.md +0 -71
- package/.agent/skills/frontend/rules/client-passive-event-listeners.md +0 -48
- package/.agent/skills/frontend/rules/client-swr-dedup.md +0 -56
- package/.agent/skills/frontend/rules/js-batch-dom-css.md +0 -107
- package/.agent/skills/frontend/rules/js-cache-function-results.md +0 -80
- package/.agent/skills/frontend/rules/js-cache-property-access.md +0 -28
- package/.agent/skills/frontend/rules/js-cache-storage.md +0 -70
- package/.agent/skills/frontend/rules/js-combine-iterations.md +0 -32
- package/.agent/skills/frontend/rules/js-early-exit.md +0 -50
- package/.agent/skills/frontend/rules/js-hoist-regexp.md +0 -45
- package/.agent/skills/frontend/rules/js-index-maps.md +0 -37
- package/.agent/skills/frontend/rules/js-length-check-first.md +0 -49
- package/.agent/skills/frontend/rules/js-min-max-loop.md +0 -82
- package/.agent/skills/frontend/rules/js-set-map-lookups.md +0 -24
- package/.agent/skills/frontend/rules/js-tosorted-immutable.md +0 -57
- package/.agent/skills/frontend/rules/rendering-activity.md +0 -26
- package/.agent/skills/frontend/rules/rendering-animate-svg-wrapper.md +0 -47
- package/.agent/skills/frontend/rules/rendering-conditional-render.md +0 -40
- package/.agent/skills/frontend/rules/rendering-content-visibility.md +0 -38
- package/.agent/skills/frontend/rules/rendering-hoist-jsx.md +0 -46
- package/.agent/skills/frontend/rules/rendering-hydration-no-flicker.md +0 -82
- package/.agent/skills/frontend/rules/rendering-hydration-suppress-warning.md +0 -30
- package/.agent/skills/frontend/rules/rendering-svg-precision.md +0 -28
- package/.agent/skills/frontend/rules/rendering-usetransition-loading.md +0 -75
- package/.agent/skills/frontend/rules/rerender-defer-reads.md +0 -39
- package/.agent/skills/frontend/rules/rerender-dependencies.md +0 -45
- package/.agent/skills/frontend/rules/rerender-derived-state-no-effect.md +0 -40
- package/.agent/skills/frontend/rules/rerender-derived-state.md +0 -29
- package/.agent/skills/frontend/rules/rerender-functional-setstate.md +0 -74
- package/.agent/skills/frontend/rules/rerender-lazy-state-init.md +0 -58
- package/.agent/skills/frontend/rules/rerender-memo-with-default-value.md +0 -38
- package/.agent/skills/frontend/rules/rerender-memo.md +0 -44
- package/.agent/skills/frontend/rules/rerender-move-effect-to-event.md +0 -45
- package/.agent/skills/frontend/rules/rerender-simple-expression-in-memo.md +0 -35
- package/.agent/skills/frontend/rules/rerender-transitions.md +0 -40
- package/.agent/skills/frontend/rules/rerender-use-ref-transient-values.md +0 -73
- package/.agent/skills/frontend/rules/schema.json +0 -34
- package/.agent/skills/frontend/rules/server-after-nonblocking.md +0 -73
- package/.agent/skills/frontend/rules/server-auth-actions.md +0 -96
- package/.agent/skills/frontend/rules/server-cache-lru.md +0 -41
- package/.agent/skills/frontend/rules/server-cache-react.md +0 -76
- package/.agent/skills/frontend/rules/server-dedup-props.md +0 -65
- package/.agent/skills/frontend/rules/server-parallel-fetching.md +0 -83
- package/.agent/skills/frontend/rules/server-serialization.md +0 -38
- package/.agent/skills/frontend-design/SKILL.md +0 -33
- package/.agent/skills/frontend-design/rules/animation-guide.md +0 -331
- package/.agent/skills/frontend-design/rules/color-system.md +0 -311
- package/.agent/skills/frontend-design/rules/decision-trees.md +0 -418
- package/.agent/skills/frontend-design/rules/motion-graphics.md +0 -306
- package/.agent/skills/frontend-design/rules/typography-system.md +0 -345
- package/.agent/skills/frontend-design/rules/ux-psychology.md +0 -541
- package/.agent/skills/frontend-design/rules/visual-effects.md +0 -383
- package/.agent/skills/frontend-design/scripts/accessibility_checker.py +0 -183
- package/.agent/skills/frontend-design/scripts/ux_audit.py +0 -722
- package/.agent/skills/geo-fundamentals/SKILL.md +0 -156
- package/.agent/skills/geo-fundamentals/scripts/geo_checker.py +0 -289
- package/.agent/skills/git-conventions/.skill-source.json +0 -8
- package/.agent/skills/git-conventions/SKILL.md +0 -28
- package/.agent/skills/git-conventions/enforcement/commit-validation-rules.md +0 -55
- package/.agent/skills/git-conventions/examples/bad-commits.md +0 -201
- package/.agent/skills/git-conventions/examples/good-commits.md +0 -135
- package/.agent/skills/git-conventions/metadata/commit-config.yaml +0 -79
- package/.agent/skills/git-conventions/metadata/intent-triggers.yaml +0 -25
- package/.agent/skills/git-conventions/metadata/scope-mapping.yaml +0 -83
- package/.agent/skills/git-conventions/resources/BEST_PRACTICES.md +0 -121
- package/.agent/skills/git-conventions/resources/references.md +0 -53
- package/.agent/skills/git-conventions/scripts/format-commit.js +0 -393
- package/.agent/skills/git-conventions/scripts/validate-commit-msg.sh +0 -27
- package/.agent/skills/governance/.skill-source.json +0 -8
- package/.agent/skills/governance/CHANGELOG.md +0 -222
- package/.agent/skills/governance/README.md +0 -250
- package/.agent/skills/governance/SKILL.md +0 -199
- package/.agent/skills/governance/VERSION +0 -4
- package/.agent/skills/governance/examples/violation-backend-mutation/after.tsx +0 -59
- package/.agent/skills/governance/examples/violation-backend-mutation/before.tsx +0 -42
- package/.agent/skills/governance/examples/violation-backend-mutation/explanation.md +0 -87
- package/.agent/skills/governance/examples/violation-chart-injection/after.tsx +0 -99
- package/.agent/skills/governance/examples/violation-chart-injection/before.tsx +0 -57
- package/.agent/skills/governance/examples/violation-chart-injection/explanation.md +0 -116
- package/.agent/skills/governance/knowledge/lessons-learned.yaml +0 -3
- package/.agent/skills/governance/metadata/precedence.yaml +0 -117
- package/.agent/skills/governance/metadata/scope-map.yaml +0 -156
- package/.agent/skills/governance/proposals/v1.1-change-proposal-template.md +0 -197
- package/.agent/skills/governance/resources/AUTHORITY_MODEL.md +0 -111
- package/.agent/skills/governance/resources/ENFORCEMENT_GUIDE.md +0 -242
- package/.agent/skills/governance/resources/LOAD_ORDER.md +0 -82
- package/.agent/skills/governance/rules/constitution/coinpika-master-constitution.md +0 -206
- package/.agent/skills/governance/rules/doctrines/architecture/coinpika-architecture-doctrine.md +0 -184
- package/.agent/skills/governance/rules/doctrines/backend/coinpika-backend-data-engine-doctrine.md +0 -214
- package/.agent/skills/governance/rules/doctrines/commercial/coinpika-commercial-guardrails-doctrine.md +0 -192
- package/.agent/skills/governance/rules/doctrines/data/coinpika-chart-data-doctrine.md +0 -198
- package/.agent/skills/governance/rules/doctrines/frontend/coinpika-frontend-mobile-doctrine.md +0 -165
- package/.agent/skills/governance/rules/doctrines/frontend/coinpika-swipe-tabs-doctrine.md +0 -172
- package/.agent/skills/governance/rules/doctrines/learning/coinpika-learning-engine-doctrine.md +0 -188
- package/.agent/skills/governance/rules/doctrines/performance/coinpika-performance-doctrine.md +0 -176
- package/.agent/skills/governance/rules/doctrines/review/coinpika-code-review-doctrine.md +0 -170
- package/.agent/skills/governance/rules/enforcement/agents/coinpika-agent-enforcement-protocol.md +0 -214
- package/.agent/skills/governance/rules/enforcement/agents/coinpika-agent-system-prompt.md +0 -192
- package/.agent/skills/governance/rules/enforcement/checklists/backend-api-review-checklist.md +0 -127
- package/.agent/skills/governance/rules/enforcement/checklists/chart-component-review-checklist.md +0 -143
- package/.agent/skills/governance/rules/enforcement/checklists/coinpika-frontend-gesture-review-checklist.md +0 -190
- package/.agent/skills/governance/rules/enforcement/playbooks/doctrine-violation-playbook.md +0 -232
- package/.agent/skills/governance/scripts/audit_pr.js +0 -218
- package/.agent/skills/governance/scripts/learn.js +0 -161
- package/.agent/skills/governance/scripts/validate_doctrine.js +0 -286
- package/.agent/skills/i18n-localization/SKILL.md +0 -154
- package/.agent/skills/i18n-localization/scripts/i18n_checker.py +0 -241
- package/.agent/skills/intelligent-routing/SKILL.md +0 -335
- package/.agent/skills/lint-and-validate/SKILL.md +0 -45
- package/.agent/skills/lint-and-validate/scripts/lint_runner.py +0 -172
- package/.agent/skills/lint-and-validate/scripts/type_coverage.py +0 -173
- package/.agent/skills/mcp-builder/SKILL.md +0 -176
- package/.agent/skills/mermaidjs-v11/SKILL.md +0 -115
- package/.agent/skills/mermaidjs-v11/references/cli-usage.md +0 -228
- package/.agent/skills/mermaidjs-v11/references/configuration.md +0 -232
- package/.agent/skills/mermaidjs-v11/references/diagram-types.md +0 -315
- package/.agent/skills/mermaidjs-v11/references/examples.md +0 -344
- package/.agent/skills/mermaidjs-v11/references/integration.md +0 -310
- package/.agent/skills/mobile-design/references/anti-patterns.md +0 -46
- package/.agent/skills/nextjs-best-practices/SKILL.md +0 -203
- package/.agent/skills/nodejs-best-practices/SKILL.md +0 -76
- package/.agent/skills/nodejs-best-practices/references/architecture-patterns.md +0 -34
- package/.agent/skills/nodejs-best-practices/references/async-patterns.md +0 -32
- package/.agent/skills/nodejs-best-practices/references/error-handling.md +0 -39
- package/.agent/skills/nodejs-best-practices/references/framework-selection.md +0 -39
- package/.agent/skills/nodejs-best-practices/references/runtime-modules.md +0 -33
- package/.agent/skills/nodejs-best-practices/references/testing-strategy.md +0 -25
- package/.agent/skills/nodejs-best-practices/references/validation-security.md +0 -45
- package/.agent/skills/parallel-agents/SKILL.md +0 -175
- package/.agent/skills/performance-profiling/SKILL.md +0 -143
- package/.agent/skills/performance-profiling/scripts/lighthouse_audit.py +0 -76
- package/.agent/skills/plan-writing/SKILL.md +0 -152
- package/.agent/skills/powershell-windows/SKILL.md +0 -167
- package/.agent/skills/problem-solving/ABOUT.md +0 -40
- package/.agent/skills/problem-solving/SKILL.md +0 -69
- package/.agent/skills/problem-solving/collision-zone-thinking/SKILL.md +0 -62
- package/.agent/skills/problem-solving/inversion-exercise/SKILL.md +0 -58
- package/.agent/skills/problem-solving/meta-pattern-recognition/SKILL.md +0 -54
- package/.agent/skills/problem-solving/scale-game/SKILL.md +0 -63
- package/.agent/skills/problem-solving/simplification-cascades/SKILL.md +0 -76
- package/.agent/skills/problem-solving/when-stuck/SKILL.md +0 -88
- package/.agent/skills/python-patterns/SKILL.md +0 -80
- package/.agent/skills/python-patterns/references/async-patterns.md +0 -57
- package/.agent/skills/python-patterns/references/django-patterns.md +0 -41
- package/.agent/skills/python-patterns/references/fastapi-patterns.md +0 -54
- package/.agent/skills/python-patterns/references/framework-selection.md +0 -39
- package/.agent/skills/python-patterns/references/project-structure.md +0 -80
- package/.agent/skills/python-patterns/references/testing-patterns.md +0 -34
- package/.agent/skills/python-patterns/references/type-hints.md +0 -51
- package/.agent/skills/react-patterns/SKILL.md +0 -198
- package/.agent/skills/red-team-tactics/SKILL.md +0 -199
- package/.agent/skills/seo-fundamentals/SKILL.md +0 -129
- package/.agent/skills/seo-fundamentals/scripts/seo_checker.py +0 -219
- package/.agent/skills/sequential-thinking/README.md +0 -118
- package/.agent/skills/sequential-thinking/SKILL.md +0 -93
- package/.agent/skills/sequential-thinking/references/advanced.md +0 -122
- package/.agent/skills/sequential-thinking/references/examples.md +0 -274
- package/.agent/skills/server-management/SKILL.md +0 -161
- package/.agent/skills/skill-creator/LICENSE.txt +0 -202
- package/.agent/skills/skill-creator/SKILL.md +0 -237
- package/.agent/skills/skill-creator/scripts/init_skill.py +0 -303
- package/.agent/skills/skill-creator/scripts/package_skill.py +0 -110
- package/.agent/skills/skill-creator/scripts/quick_validate.py +0 -65
- package/.agent/skills/systematic-debugging/SKILL.md +0 -109
- package/.agent/skills/tailwind-patterns/SKILL.md +0 -269
- package/.agent/skills/tdd-workflow/SKILL.md +0 -149
- package/.agent/skills/testing-patterns/SKILL.md +0 -178
- package/.agent/skills/testing-patterns/scripts/test_runner.py +0 -219
- package/.agent/skills/vulnerability-scanner/SKILL.md +0 -276
- package/.agent/skills/vulnerability-scanner/checklists.md +0 -121
- package/.agent/skills/vulnerability-scanner/scripts/security_scan.py +0 -458
- package/.agent/skills/webapp-testing/SKILL.md +0 -187
- package/.agent/skills/webapp-testing/scripts/playwright_runner.py +0 -173
- package/.editorconfig +0 -21
- package/.github/workflows/release.yml +0 -39
- package/docs/PLAN-consolidation-final.md +0 -14
- package/docs/PLAN-integration.md +0 -28
- package/docs/PLAN-rebrand-agent-skills-kit.md +0 -104
- package/docs/PLAN-refactor.md +0 -48
- package/docs/PYTHON_SCRIPTS.md +0 -55
- package/docs/awf-user-guide.md +0 -436
- package/packages/cli/bin/ag-smart.v1.js +0 -78
- package/packages/cli/lib/audit.v2.js +0 -151
- package/packages/cli/lib/auto_preview.py +0 -148
- package/packages/cli/lib/checklist.py +0 -222
- package/packages/cli/lib/learn.v2.js +0 -255
- package/packages/cli/lib/recall.v2.js +0 -252
- package/packages/cli/lib/session_manager.py +0 -120
- package/packages/cli/lib/verify_all.py +0 -327
- /package/.agent/skills/{debugging → debug-pro}/defense-in-depth/SKILL.md +0 -0
- /package/.agent/skills/{debugging → debug-pro}/root-cause-tracing/SKILL.md +0 -0
- /package/.agent/skills/{debugging → debug-pro}/root-cause-tracing/find-polluter.sh +0 -0
- /package/.agent/skills/{debugging → debug-pro}/verification-before-completion/SKILL.md +0 -0
- /package/.agent/skills/mobile-design/{references/decision-trees.md → decision-trees.md} +0 -0
- /package/.agent/skills/mobile-design/{references/mobile-backend.md → mobile-backend.md} +0 -0
- /package/.agent/skills/mobile-design/{references/mobile-color-system.md → mobile-color-system.md} +0 -0
- /package/.agent/skills/mobile-design/{references/mobile-debugging.md → mobile-debugging.md} +0 -0
- /package/.agent/skills/mobile-design/{references/mobile-design-thinking.md → mobile-design-thinking.md} +0 -0
- /package/.agent/skills/mobile-design/{references/mobile-navigation.md → mobile-navigation.md} +0 -0
- /package/.agent/skills/mobile-design/{references/mobile-performance.md → mobile-performance.md} +0 -0
- /package/.agent/skills/mobile-design/{references/mobile-testing.md → mobile-testing.md} +0 -0
- /package/.agent/skills/mobile-design/{references/mobile-typography.md → mobile-typography.md} +0 -0
- /package/.agent/skills/mobile-design/{references/platform-android.md → platform-android.md} +0 -0
- /package/.agent/skills/mobile-design/{references/platform-ios.md → platform-ios.md} +0 -0
- /package/.agent/skills/mobile-design/{references/touch-psychology.md → touch-psychology.md} +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/charts.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/colors.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/icons.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/landing.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/products.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/prompts.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/react-performance.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/flutter.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/html-tailwind.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/jetpack-compose.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/nextjs.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/nuxt-ui.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/nuxtjs.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/react-native.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/react.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/shadcn.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/svelte.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/swiftui.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/stacks/vue.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/typography.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/ui-reasoning.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/ux-guidelines.csv +0 -0
- /package/.agent/{.shared/ui-ux-pro-max → skills/studio}/data/web-interface.csv +0 -0
- /package/docs/{PATTERNS_REFERENCE.md → archive/patterns-anthropic.md} +0 -0
- /package/docs/{context-engineering-guide.md → guides/context-engineering.md} +0 -0
- /package/{VERSIONING.md → docs/guides/versioning.md} +0 -0
|
@@ -1,1067 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
# -*- coding: utf-8 -*-
|
|
3
|
-
"""
|
|
4
|
-
Design System Generator - Aggregates search results and applies reasoning
|
|
5
|
-
to generate comprehensive design system recommendations.
|
|
6
|
-
|
|
7
|
-
Usage:
|
|
8
|
-
from design_system import generate_design_system
|
|
9
|
-
result = generate_design_system("SaaS dashboard", "My Project")
|
|
10
|
-
|
|
11
|
-
# With persistence (Master + Overrides pattern)
|
|
12
|
-
result = generate_design_system("SaaS dashboard", "My Project", persist=True)
|
|
13
|
-
result = generate_design_system("SaaS dashboard", "My Project", persist=True, page="dashboard")
|
|
14
|
-
"""
|
|
15
|
-
|
|
16
|
-
import csv
|
|
17
|
-
import json
|
|
18
|
-
import os
|
|
19
|
-
from datetime import datetime
|
|
20
|
-
from pathlib import Path
|
|
21
|
-
from core import search, DATA_DIR
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
# ============ CONFIGURATION ============
|
|
25
|
-
REASONING_FILE = "ui-reasoning.csv"
|
|
26
|
-
|
|
27
|
-
SEARCH_CONFIG = {
|
|
28
|
-
"product": {"max_results": 1},
|
|
29
|
-
"style": {"max_results": 3},
|
|
30
|
-
"color": {"max_results": 2},
|
|
31
|
-
"landing": {"max_results": 2},
|
|
32
|
-
"typography": {"max_results": 2}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
# ============ DESIGN SYSTEM GENERATOR ============
|
|
37
|
-
class DesignSystemGenerator:
|
|
38
|
-
"""Generates design system recommendations from aggregated searches."""
|
|
39
|
-
|
|
40
|
-
def __init__(self):
|
|
41
|
-
self.reasoning_data = self._load_reasoning()
|
|
42
|
-
|
|
43
|
-
def _load_reasoning(self) -> list:
|
|
44
|
-
"""Load reasoning rules from CSV."""
|
|
45
|
-
filepath = DATA_DIR / REASONING_FILE
|
|
46
|
-
if not filepath.exists():
|
|
47
|
-
return []
|
|
48
|
-
with open(filepath, 'r', encoding='utf-8') as f:
|
|
49
|
-
return list(csv.DictReader(f))
|
|
50
|
-
|
|
51
|
-
def _multi_domain_search(self, query: str, style_priority: list = None) -> dict:
|
|
52
|
-
"""Execute searches across multiple domains."""
|
|
53
|
-
results = {}
|
|
54
|
-
for domain, config in SEARCH_CONFIG.items():
|
|
55
|
-
if domain == "style" and style_priority:
|
|
56
|
-
# For style, also search with priority keywords
|
|
57
|
-
priority_query = " ".join(style_priority[:2]) if style_priority else query
|
|
58
|
-
combined_query = f"{query} {priority_query}"
|
|
59
|
-
results[domain] = search(combined_query, domain, config["max_results"])
|
|
60
|
-
else:
|
|
61
|
-
results[domain] = search(query, domain, config["max_results"])
|
|
62
|
-
return results
|
|
63
|
-
|
|
64
|
-
def _find_reasoning_rule(self, category: str) -> dict:
|
|
65
|
-
"""Find matching reasoning rule for a category."""
|
|
66
|
-
category_lower = category.lower()
|
|
67
|
-
|
|
68
|
-
# Try exact match first
|
|
69
|
-
for rule in self.reasoning_data:
|
|
70
|
-
if rule.get("UI_Category", "").lower() == category_lower:
|
|
71
|
-
return rule
|
|
72
|
-
|
|
73
|
-
# Try partial match
|
|
74
|
-
for rule in self.reasoning_data:
|
|
75
|
-
ui_cat = rule.get("UI_Category", "").lower()
|
|
76
|
-
if ui_cat in category_lower or category_lower in ui_cat:
|
|
77
|
-
return rule
|
|
78
|
-
|
|
79
|
-
# Try keyword match
|
|
80
|
-
for rule in self.reasoning_data:
|
|
81
|
-
ui_cat = rule.get("UI_Category", "").lower()
|
|
82
|
-
keywords = ui_cat.replace("/", " ").replace("-", " ").split()
|
|
83
|
-
if any(kw in category_lower for kw in keywords):
|
|
84
|
-
return rule
|
|
85
|
-
|
|
86
|
-
return {}
|
|
87
|
-
|
|
88
|
-
def _apply_reasoning(self, category: str, search_results: dict) -> dict:
|
|
89
|
-
"""Apply reasoning rules to search results."""
|
|
90
|
-
rule = self._find_reasoning_rule(category)
|
|
91
|
-
|
|
92
|
-
if not rule:
|
|
93
|
-
return {
|
|
94
|
-
"pattern": "Hero + Features + CTA",
|
|
95
|
-
"style_priority": ["Minimalism", "Flat Design"],
|
|
96
|
-
"color_mood": "Professional",
|
|
97
|
-
"typography_mood": "Clean",
|
|
98
|
-
"key_effects": "Subtle hover transitions",
|
|
99
|
-
"anti_patterns": "",
|
|
100
|
-
"decision_rules": {},
|
|
101
|
-
"severity": "MEDIUM"
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
# Parse decision rules JSON
|
|
105
|
-
decision_rules = {}
|
|
106
|
-
try:
|
|
107
|
-
decision_rules = json.loads(rule.get("Decision_Rules", "{}"))
|
|
108
|
-
except json.JSONDecodeError:
|
|
109
|
-
pass
|
|
110
|
-
|
|
111
|
-
return {
|
|
112
|
-
"pattern": rule.get("Recommended_Pattern", ""),
|
|
113
|
-
"style_priority": [s.strip() for s in rule.get("Style_Priority", "").split("+")],
|
|
114
|
-
"color_mood": rule.get("Color_Mood", ""),
|
|
115
|
-
"typography_mood": rule.get("Typography_Mood", ""),
|
|
116
|
-
"key_effects": rule.get("Key_Effects", ""),
|
|
117
|
-
"anti_patterns": rule.get("Anti_Patterns", ""),
|
|
118
|
-
"decision_rules": decision_rules,
|
|
119
|
-
"severity": rule.get("Severity", "MEDIUM")
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
def _select_best_match(self, results: list, priority_keywords: list) -> dict:
|
|
123
|
-
"""Select best matching result based on priority keywords."""
|
|
124
|
-
if not results:
|
|
125
|
-
return {}
|
|
126
|
-
|
|
127
|
-
if not priority_keywords:
|
|
128
|
-
return results[0]
|
|
129
|
-
|
|
130
|
-
# First: try exact style name match
|
|
131
|
-
for priority in priority_keywords:
|
|
132
|
-
priority_lower = priority.lower().strip()
|
|
133
|
-
for result in results:
|
|
134
|
-
style_name = result.get("Style Category", "").lower()
|
|
135
|
-
if priority_lower in style_name or style_name in priority_lower:
|
|
136
|
-
return result
|
|
137
|
-
|
|
138
|
-
# Second: score by keyword match in all fields
|
|
139
|
-
scored = []
|
|
140
|
-
for result in results:
|
|
141
|
-
result_str = str(result).lower()
|
|
142
|
-
score = 0
|
|
143
|
-
for kw in priority_keywords:
|
|
144
|
-
kw_lower = kw.lower().strip()
|
|
145
|
-
# Higher score for style name match
|
|
146
|
-
if kw_lower in result.get("Style Category", "").lower():
|
|
147
|
-
score += 10
|
|
148
|
-
# Lower score for keyword field match
|
|
149
|
-
elif kw_lower in result.get("Keywords", "").lower():
|
|
150
|
-
score += 3
|
|
151
|
-
# Even lower for other field matches
|
|
152
|
-
elif kw_lower in result_str:
|
|
153
|
-
score += 1
|
|
154
|
-
scored.append((score, result))
|
|
155
|
-
|
|
156
|
-
scored.sort(key=lambda x: x[0], reverse=True)
|
|
157
|
-
return scored[0][1] if scored and scored[0][0] > 0 else results[0]
|
|
158
|
-
|
|
159
|
-
def _extract_results(self, search_result: dict) -> list:
|
|
160
|
-
"""Extract results list from search result dict."""
|
|
161
|
-
return search_result.get("results", [])
|
|
162
|
-
|
|
163
|
-
def generate(self, query: str, project_name: str = None) -> dict:
|
|
164
|
-
"""Generate complete design system recommendation."""
|
|
165
|
-
# Step 1: First search product to get category
|
|
166
|
-
product_result = search(query, "product", 1)
|
|
167
|
-
product_results = product_result.get("results", [])
|
|
168
|
-
category = "General"
|
|
169
|
-
if product_results:
|
|
170
|
-
category = product_results[0].get("Product Type", "General")
|
|
171
|
-
|
|
172
|
-
# Step 2: Get reasoning rules for this category
|
|
173
|
-
reasoning = self._apply_reasoning(category, {})
|
|
174
|
-
style_priority = reasoning.get("style_priority", [])
|
|
175
|
-
|
|
176
|
-
# Step 3: Multi-domain search with style priority hints
|
|
177
|
-
search_results = self._multi_domain_search(query, style_priority)
|
|
178
|
-
search_results["product"] = product_result # Reuse product search
|
|
179
|
-
|
|
180
|
-
# Step 4: Select best matches from each domain using priority
|
|
181
|
-
style_results = self._extract_results(search_results.get("style", {}))
|
|
182
|
-
color_results = self._extract_results(search_results.get("color", {}))
|
|
183
|
-
typography_results = self._extract_results(search_results.get("typography", {}))
|
|
184
|
-
landing_results = self._extract_results(search_results.get("landing", {}))
|
|
185
|
-
|
|
186
|
-
best_style = self._select_best_match(style_results, reasoning.get("style_priority", []))
|
|
187
|
-
best_color = color_results[0] if color_results else {}
|
|
188
|
-
best_typography = typography_results[0] if typography_results else {}
|
|
189
|
-
best_landing = landing_results[0] if landing_results else {}
|
|
190
|
-
|
|
191
|
-
# Step 5: Build final recommendation
|
|
192
|
-
# Combine effects from both reasoning and style search
|
|
193
|
-
style_effects = best_style.get("Effects & Animation", "")
|
|
194
|
-
reasoning_effects = reasoning.get("key_effects", "")
|
|
195
|
-
combined_effects = style_effects if style_effects else reasoning_effects
|
|
196
|
-
|
|
197
|
-
return {
|
|
198
|
-
"project_name": project_name or query.upper(),
|
|
199
|
-
"category": category,
|
|
200
|
-
"pattern": {
|
|
201
|
-
"name": best_landing.get("Pattern Name", reasoning.get("pattern", "Hero + Features + CTA")),
|
|
202
|
-
"sections": best_landing.get("Section Order", "Hero > Features > CTA"),
|
|
203
|
-
"cta_placement": best_landing.get("Primary CTA Placement", "Above fold"),
|
|
204
|
-
"color_strategy": best_landing.get("Color Strategy", ""),
|
|
205
|
-
"conversion": best_landing.get("Conversion Optimization", "")
|
|
206
|
-
},
|
|
207
|
-
"style": {
|
|
208
|
-
"name": best_style.get("Style Category", "Minimalism"),
|
|
209
|
-
"type": best_style.get("Type", "General"),
|
|
210
|
-
"effects": style_effects,
|
|
211
|
-
"keywords": best_style.get("Keywords", ""),
|
|
212
|
-
"best_for": best_style.get("Best For", ""),
|
|
213
|
-
"performance": best_style.get("Performance", ""),
|
|
214
|
-
"accessibility": best_style.get("Accessibility", "")
|
|
215
|
-
},
|
|
216
|
-
"colors": {
|
|
217
|
-
"primary": best_color.get("Primary (Hex)", "#2563EB"),
|
|
218
|
-
"secondary": best_color.get("Secondary (Hex)", "#3B82F6"),
|
|
219
|
-
"cta": best_color.get("CTA (Hex)", "#F97316"),
|
|
220
|
-
"background": best_color.get("Background (Hex)", "#F8FAFC"),
|
|
221
|
-
"text": best_color.get("Text (Hex)", "#1E293B"),
|
|
222
|
-
"notes": best_color.get("Notes", "")
|
|
223
|
-
},
|
|
224
|
-
"typography": {
|
|
225
|
-
"heading": best_typography.get("Heading Font", "Inter"),
|
|
226
|
-
"body": best_typography.get("Body Font", "Inter"),
|
|
227
|
-
"mood": best_typography.get("Mood/Style Keywords", reasoning.get("typography_mood", "")),
|
|
228
|
-
"best_for": best_typography.get("Best For", ""),
|
|
229
|
-
"google_fonts_url": best_typography.get("Google Fonts URL", ""),
|
|
230
|
-
"css_import": best_typography.get("CSS Import", "")
|
|
231
|
-
},
|
|
232
|
-
"key_effects": combined_effects,
|
|
233
|
-
"anti_patterns": reasoning.get("anti_patterns", ""),
|
|
234
|
-
"decision_rules": reasoning.get("decision_rules", {}),
|
|
235
|
-
"severity": reasoning.get("severity", "MEDIUM")
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
# ============ OUTPUT FORMATTERS ============
|
|
240
|
-
BOX_WIDTH = 90 # Wider box for more content
|
|
241
|
-
|
|
242
|
-
def format_ascii_box(design_system: dict) -> str:
|
|
243
|
-
"""Format design system as ASCII box with emojis (MCP-style)."""
|
|
244
|
-
project = design_system.get("project_name", "PROJECT")
|
|
245
|
-
pattern = design_system.get("pattern", {})
|
|
246
|
-
style = design_system.get("style", {})
|
|
247
|
-
colors = design_system.get("colors", {})
|
|
248
|
-
typography = design_system.get("typography", {})
|
|
249
|
-
effects = design_system.get("key_effects", "")
|
|
250
|
-
anti_patterns = design_system.get("anti_patterns", "")
|
|
251
|
-
|
|
252
|
-
def wrap_text(text: str, prefix: str, width: int) -> list:
|
|
253
|
-
"""Wrap long text into multiple lines."""
|
|
254
|
-
if not text:
|
|
255
|
-
return []
|
|
256
|
-
words = text.split()
|
|
257
|
-
lines = []
|
|
258
|
-
current_line = prefix
|
|
259
|
-
for word in words:
|
|
260
|
-
if len(current_line) + len(word) + 1 <= width - 2:
|
|
261
|
-
current_line += (" " if current_line != prefix else "") + word
|
|
262
|
-
else:
|
|
263
|
-
if current_line != prefix:
|
|
264
|
-
lines.append(current_line)
|
|
265
|
-
current_line = prefix + word
|
|
266
|
-
if current_line != prefix:
|
|
267
|
-
lines.append(current_line)
|
|
268
|
-
return lines
|
|
269
|
-
|
|
270
|
-
# Build sections from pattern
|
|
271
|
-
sections = pattern.get("sections", "").split(">")
|
|
272
|
-
sections = [s.strip() for s in sections if s.strip()]
|
|
273
|
-
|
|
274
|
-
# Build output lines
|
|
275
|
-
lines = []
|
|
276
|
-
w = BOX_WIDTH - 1
|
|
277
|
-
|
|
278
|
-
lines.append("+" + "-" * w + "+")
|
|
279
|
-
lines.append(f"| TARGET: {project} - RECOMMENDED DESIGN SYSTEM".ljust(BOX_WIDTH) + "|")
|
|
280
|
-
lines.append("+" + "-" * w + "+")
|
|
281
|
-
lines.append("|" + " " * BOX_WIDTH + "|")
|
|
282
|
-
|
|
283
|
-
# Pattern section
|
|
284
|
-
lines.append(f"| PATTERN: {pattern.get('name', '')}".ljust(BOX_WIDTH) + "|")
|
|
285
|
-
if pattern.get('conversion'):
|
|
286
|
-
lines.append(f"| Conversion: {pattern.get('conversion', '')}".ljust(BOX_WIDTH) + "|")
|
|
287
|
-
if pattern.get('cta_placement'):
|
|
288
|
-
lines.append(f"| CTA: {pattern.get('cta_placement', '')}".ljust(BOX_WIDTH) + "|")
|
|
289
|
-
lines.append("| Sections:".ljust(BOX_WIDTH) + "|")
|
|
290
|
-
for i, section in enumerate(sections, 1):
|
|
291
|
-
lines.append(f"| {i}. {section}".ljust(BOX_WIDTH) + "|")
|
|
292
|
-
lines.append("|" + " " * BOX_WIDTH + "|")
|
|
293
|
-
|
|
294
|
-
# Style section
|
|
295
|
-
lines.append(f"| STYLE: {style.get('name', '')}".ljust(BOX_WIDTH) + "|")
|
|
296
|
-
if style.get("keywords"):
|
|
297
|
-
for line in wrap_text(f"Keywords: {style.get('keywords', '')}", "| ", BOX_WIDTH):
|
|
298
|
-
lines.append(line.ljust(BOX_WIDTH) + "|")
|
|
299
|
-
if style.get("best_for"):
|
|
300
|
-
for line in wrap_text(f"Best For: {style.get('best_for', '')}", "| ", BOX_WIDTH):
|
|
301
|
-
lines.append(line.ljust(BOX_WIDTH) + "|")
|
|
302
|
-
if style.get("performance") or style.get("accessibility"):
|
|
303
|
-
perf_a11y = f"Performance: {style.get('performance', '')} | Accessibility: {style.get('accessibility', '')}"
|
|
304
|
-
lines.append(f"| {perf_a11y}".ljust(BOX_WIDTH) + "|")
|
|
305
|
-
lines.append("|" + " " * BOX_WIDTH + "|")
|
|
306
|
-
|
|
307
|
-
# Colors section
|
|
308
|
-
lines.append("| COLORS:".ljust(BOX_WIDTH) + "|")
|
|
309
|
-
lines.append(f"| Primary: {colors.get('primary', '')}".ljust(BOX_WIDTH) + "|")
|
|
310
|
-
lines.append(f"| Secondary: {colors.get('secondary', '')}".ljust(BOX_WIDTH) + "|")
|
|
311
|
-
lines.append(f"| CTA: {colors.get('cta', '')}".ljust(BOX_WIDTH) + "|")
|
|
312
|
-
lines.append(f"| Background: {colors.get('background', '')}".ljust(BOX_WIDTH) + "|")
|
|
313
|
-
lines.append(f"| Text: {colors.get('text', '')}".ljust(BOX_WIDTH) + "|")
|
|
314
|
-
if colors.get("notes"):
|
|
315
|
-
for line in wrap_text(f"Notes: {colors.get('notes', '')}", "| ", BOX_WIDTH):
|
|
316
|
-
lines.append(line.ljust(BOX_WIDTH) + "|")
|
|
317
|
-
lines.append("|" + " " * BOX_WIDTH + "|")
|
|
318
|
-
|
|
319
|
-
# Typography section
|
|
320
|
-
lines.append(f"| TYPOGRAPHY: {typography.get('heading', '')} / {typography.get('body', '')}".ljust(BOX_WIDTH) + "|")
|
|
321
|
-
if typography.get("mood"):
|
|
322
|
-
for line in wrap_text(f"Mood: {typography.get('mood', '')}", "| ", BOX_WIDTH):
|
|
323
|
-
lines.append(line.ljust(BOX_WIDTH) + "|")
|
|
324
|
-
if typography.get("best_for"):
|
|
325
|
-
for line in wrap_text(f"Best For: {typography.get('best_for', '')}", "| ", BOX_WIDTH):
|
|
326
|
-
lines.append(line.ljust(BOX_WIDTH) + "|")
|
|
327
|
-
if typography.get("google_fonts_url"):
|
|
328
|
-
lines.append(f"| Google Fonts: {typography.get('google_fonts_url', '')}".ljust(BOX_WIDTH) + "|")
|
|
329
|
-
if typography.get("css_import"):
|
|
330
|
-
lines.append(f"| CSS Import: {typography.get('css_import', '')[:70]}...".ljust(BOX_WIDTH) + "|")
|
|
331
|
-
lines.append("|" + " " * BOX_WIDTH + "|")
|
|
332
|
-
|
|
333
|
-
# Key Effects section
|
|
334
|
-
if effects:
|
|
335
|
-
lines.append("| KEY EFFECTS:".ljust(BOX_WIDTH) + "|")
|
|
336
|
-
for line in wrap_text(effects, "| ", BOX_WIDTH):
|
|
337
|
-
lines.append(line.ljust(BOX_WIDTH) + "|")
|
|
338
|
-
lines.append("|" + " " * BOX_WIDTH + "|")
|
|
339
|
-
|
|
340
|
-
# Anti-patterns section
|
|
341
|
-
if anti_patterns:
|
|
342
|
-
lines.append("| AVOID (Anti-patterns):".ljust(BOX_WIDTH) + "|")
|
|
343
|
-
for line in wrap_text(anti_patterns, "| ", BOX_WIDTH):
|
|
344
|
-
lines.append(line.ljust(BOX_WIDTH) + "|")
|
|
345
|
-
lines.append("|" + " " * BOX_WIDTH + "|")
|
|
346
|
-
|
|
347
|
-
# Pre-Delivery Checklist section
|
|
348
|
-
lines.append("| PRE-DELIVERY CHECKLIST:".ljust(BOX_WIDTH) + "|")
|
|
349
|
-
checklist_items = [
|
|
350
|
-
"[ ] No emojis as icons (use SVG: Heroicons/Lucide)",
|
|
351
|
-
"[ ] cursor-pointer on all clickable elements",
|
|
352
|
-
"[ ] Hover states with smooth transitions (150-300ms)",
|
|
353
|
-
"[ ] Light mode: text contrast 4.5:1 minimum",
|
|
354
|
-
"[ ] Focus states visible for keyboard nav",
|
|
355
|
-
"[ ] prefers-reduced-motion respected",
|
|
356
|
-
"[ ] Responsive: 375px, 768px, 1024px, 1440px"
|
|
357
|
-
]
|
|
358
|
-
for item in checklist_items:
|
|
359
|
-
lines.append(f"| {item}".ljust(BOX_WIDTH) + "|")
|
|
360
|
-
lines.append("|" + " " * BOX_WIDTH + "|")
|
|
361
|
-
|
|
362
|
-
lines.append("+" + "-" * w + "+")
|
|
363
|
-
|
|
364
|
-
return "\n".join(lines)
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
def format_markdown(design_system: dict) -> str:
|
|
368
|
-
"""Format design system as markdown."""
|
|
369
|
-
project = design_system.get("project_name", "PROJECT")
|
|
370
|
-
pattern = design_system.get("pattern", {})
|
|
371
|
-
style = design_system.get("style", {})
|
|
372
|
-
colors = design_system.get("colors", {})
|
|
373
|
-
typography = design_system.get("typography", {})
|
|
374
|
-
effects = design_system.get("key_effects", "")
|
|
375
|
-
anti_patterns = design_system.get("anti_patterns", "")
|
|
376
|
-
|
|
377
|
-
lines = []
|
|
378
|
-
lines.append(f"## Design System: {project}")
|
|
379
|
-
lines.append("")
|
|
380
|
-
|
|
381
|
-
# Pattern section
|
|
382
|
-
lines.append("### Pattern")
|
|
383
|
-
lines.append(f"- **Name:** {pattern.get('name', '')}")
|
|
384
|
-
if pattern.get('conversion'):
|
|
385
|
-
lines.append(f"- **Conversion Focus:** {pattern.get('conversion', '')}")
|
|
386
|
-
if pattern.get('cta_placement'):
|
|
387
|
-
lines.append(f"- **CTA Placement:** {pattern.get('cta_placement', '')}")
|
|
388
|
-
if pattern.get('color_strategy'):
|
|
389
|
-
lines.append(f"- **Color Strategy:** {pattern.get('color_strategy', '')}")
|
|
390
|
-
lines.append(f"- **Sections:** {pattern.get('sections', '')}")
|
|
391
|
-
lines.append("")
|
|
392
|
-
|
|
393
|
-
# Style section
|
|
394
|
-
lines.append("### Style")
|
|
395
|
-
lines.append(f"- **Name:** {style.get('name', '')}")
|
|
396
|
-
if style.get('keywords'):
|
|
397
|
-
lines.append(f"- **Keywords:** {style.get('keywords', '')}")
|
|
398
|
-
if style.get('best_for'):
|
|
399
|
-
lines.append(f"- **Best For:** {style.get('best_for', '')}")
|
|
400
|
-
if style.get('performance') or style.get('accessibility'):
|
|
401
|
-
lines.append(f"- **Performance:** {style.get('performance', '')} | **Accessibility:** {style.get('accessibility', '')}")
|
|
402
|
-
lines.append("")
|
|
403
|
-
|
|
404
|
-
# Colors section
|
|
405
|
-
lines.append("### Colors")
|
|
406
|
-
lines.append(f"| Role | Hex |")
|
|
407
|
-
lines.append(f"|------|-----|")
|
|
408
|
-
lines.append(f"| Primary | {colors.get('primary', '')} |")
|
|
409
|
-
lines.append(f"| Secondary | {colors.get('secondary', '')} |")
|
|
410
|
-
lines.append(f"| CTA | {colors.get('cta', '')} |")
|
|
411
|
-
lines.append(f"| Background | {colors.get('background', '')} |")
|
|
412
|
-
lines.append(f"| Text | {colors.get('text', '')} |")
|
|
413
|
-
if colors.get("notes"):
|
|
414
|
-
lines.append(f"\n*Notes: {colors.get('notes', '')}*")
|
|
415
|
-
lines.append("")
|
|
416
|
-
|
|
417
|
-
# Typography section
|
|
418
|
-
lines.append("### Typography")
|
|
419
|
-
lines.append(f"- **Heading:** {typography.get('heading', '')}")
|
|
420
|
-
lines.append(f"- **Body:** {typography.get('body', '')}")
|
|
421
|
-
if typography.get("mood"):
|
|
422
|
-
lines.append(f"- **Mood:** {typography.get('mood', '')}")
|
|
423
|
-
if typography.get("best_for"):
|
|
424
|
-
lines.append(f"- **Best For:** {typography.get('best_for', '')}")
|
|
425
|
-
if typography.get("google_fonts_url"):
|
|
426
|
-
lines.append(f"- **Google Fonts:** {typography.get('google_fonts_url', '')}")
|
|
427
|
-
if typography.get("css_import"):
|
|
428
|
-
lines.append(f"- **CSS Import:**")
|
|
429
|
-
lines.append(f"```css")
|
|
430
|
-
lines.append(f"{typography.get('css_import', '')}")
|
|
431
|
-
lines.append(f"```")
|
|
432
|
-
lines.append("")
|
|
433
|
-
|
|
434
|
-
# Key Effects section
|
|
435
|
-
if effects:
|
|
436
|
-
lines.append("### Key Effects")
|
|
437
|
-
lines.append(f"{effects}")
|
|
438
|
-
lines.append("")
|
|
439
|
-
|
|
440
|
-
# Anti-patterns section
|
|
441
|
-
if anti_patterns:
|
|
442
|
-
lines.append("### Avoid (Anti-patterns)")
|
|
443
|
-
newline_bullet = '\n- '
|
|
444
|
-
lines.append(f"- {anti_patterns.replace(' + ', newline_bullet)}")
|
|
445
|
-
lines.append("")
|
|
446
|
-
|
|
447
|
-
# Pre-Delivery Checklist section
|
|
448
|
-
lines.append("### Pre-Delivery Checklist")
|
|
449
|
-
lines.append("- [ ] No emojis as icons (use SVG: Heroicons/Lucide)")
|
|
450
|
-
lines.append("- [ ] cursor-pointer on all clickable elements")
|
|
451
|
-
lines.append("- [ ] Hover states with smooth transitions (150-300ms)")
|
|
452
|
-
lines.append("- [ ] Light mode: text contrast 4.5:1 minimum")
|
|
453
|
-
lines.append("- [ ] Focus states visible for keyboard nav")
|
|
454
|
-
lines.append("- [ ] prefers-reduced-motion respected")
|
|
455
|
-
lines.append("- [ ] Responsive: 375px, 768px, 1024px, 1440px")
|
|
456
|
-
lines.append("")
|
|
457
|
-
|
|
458
|
-
return "\n".join(lines)
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
# ============ MAIN ENTRY POINT ============
|
|
462
|
-
def generate_design_system(query: str, project_name: str = None, output_format: str = "ascii",
|
|
463
|
-
persist: bool = False, page: str = None, output_dir: str = None) -> str:
|
|
464
|
-
"""
|
|
465
|
-
Main entry point for design system generation.
|
|
466
|
-
|
|
467
|
-
Args:
|
|
468
|
-
query: Search query (e.g., "SaaS dashboard", "e-commerce luxury")
|
|
469
|
-
project_name: Optional project name for output header
|
|
470
|
-
output_format: "ascii" (default) or "markdown"
|
|
471
|
-
persist: If True, save design system to design-system/ folder
|
|
472
|
-
page: Optional page name for page-specific override file
|
|
473
|
-
output_dir: Optional output directory (defaults to current working directory)
|
|
474
|
-
|
|
475
|
-
Returns:
|
|
476
|
-
Formatted design system string
|
|
477
|
-
"""
|
|
478
|
-
generator = DesignSystemGenerator()
|
|
479
|
-
design_system = generator.generate(query, project_name)
|
|
480
|
-
|
|
481
|
-
# Persist to files if requested
|
|
482
|
-
if persist:
|
|
483
|
-
persist_design_system(design_system, page, output_dir, query)
|
|
484
|
-
|
|
485
|
-
if output_format == "markdown":
|
|
486
|
-
return format_markdown(design_system)
|
|
487
|
-
return format_ascii_box(design_system)
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
# ============ PERSISTENCE FUNCTIONS ============
|
|
491
|
-
def persist_design_system(design_system: dict, page: str = None, output_dir: str = None, page_query: str = None) -> dict:
|
|
492
|
-
"""
|
|
493
|
-
Persist design system to design-system/<project>/ folder using Master + Overrides pattern.
|
|
494
|
-
|
|
495
|
-
Args:
|
|
496
|
-
design_system: The generated design system dictionary
|
|
497
|
-
page: Optional page name for page-specific override file
|
|
498
|
-
output_dir: Optional output directory (defaults to current working directory)
|
|
499
|
-
page_query: Optional query string for intelligent page override generation
|
|
500
|
-
|
|
501
|
-
Returns:
|
|
502
|
-
dict with created file paths and status
|
|
503
|
-
"""
|
|
504
|
-
base_dir = Path(output_dir) if output_dir else Path.cwd()
|
|
505
|
-
|
|
506
|
-
# Use project name for project-specific folder
|
|
507
|
-
project_name = design_system.get("project_name", "default")
|
|
508
|
-
project_slug = project_name.lower().replace(' ', '-')
|
|
509
|
-
|
|
510
|
-
design_system_dir = base_dir / "design-system" / project_slug
|
|
511
|
-
pages_dir = design_system_dir / "pages"
|
|
512
|
-
|
|
513
|
-
created_files = []
|
|
514
|
-
|
|
515
|
-
# Create directories
|
|
516
|
-
design_system_dir.mkdir(parents=True, exist_ok=True)
|
|
517
|
-
pages_dir.mkdir(parents=True, exist_ok=True)
|
|
518
|
-
|
|
519
|
-
master_file = design_system_dir / "MASTER.md"
|
|
520
|
-
|
|
521
|
-
# Generate and write MASTER.md
|
|
522
|
-
master_content = format_master_md(design_system)
|
|
523
|
-
with open(master_file, 'w', encoding='utf-8') as f:
|
|
524
|
-
f.write(master_content)
|
|
525
|
-
created_files.append(str(master_file))
|
|
526
|
-
|
|
527
|
-
# If page is specified, create page override file with intelligent content
|
|
528
|
-
if page:
|
|
529
|
-
page_file = pages_dir / f"{page.lower().replace(' ', '-')}.md"
|
|
530
|
-
page_content = format_page_override_md(design_system, page, page_query)
|
|
531
|
-
with open(page_file, 'w', encoding='utf-8') as f:
|
|
532
|
-
f.write(page_content)
|
|
533
|
-
created_files.append(str(page_file))
|
|
534
|
-
|
|
535
|
-
return {
|
|
536
|
-
"status": "success",
|
|
537
|
-
"design_system_dir": str(design_system_dir),
|
|
538
|
-
"created_files": created_files
|
|
539
|
-
}
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
def format_master_md(design_system: dict) -> str:
|
|
543
|
-
"""Format design system as MASTER.md with hierarchical override logic."""
|
|
544
|
-
project = design_system.get("project_name", "PROJECT")
|
|
545
|
-
pattern = design_system.get("pattern", {})
|
|
546
|
-
style = design_system.get("style", {})
|
|
547
|
-
colors = design_system.get("colors", {})
|
|
548
|
-
typography = design_system.get("typography", {})
|
|
549
|
-
effects = design_system.get("key_effects", "")
|
|
550
|
-
anti_patterns = design_system.get("anti_patterns", "")
|
|
551
|
-
|
|
552
|
-
timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
|
|
553
|
-
|
|
554
|
-
lines = []
|
|
555
|
-
|
|
556
|
-
# Logic header
|
|
557
|
-
lines.append("# Design System Master File")
|
|
558
|
-
lines.append("")
|
|
559
|
-
lines.append("> **LOGIC:** When building a specific page, first check `design-system/pages/[page-name].md`.")
|
|
560
|
-
lines.append("> If that file exists, its rules **override** this Master file.")
|
|
561
|
-
lines.append("> If not, strictly follow the rules below.")
|
|
562
|
-
lines.append("")
|
|
563
|
-
lines.append("---")
|
|
564
|
-
lines.append("")
|
|
565
|
-
lines.append(f"**Project:** {project}")
|
|
566
|
-
lines.append(f"**Generated:** {timestamp}")
|
|
567
|
-
lines.append(f"**Category:** {design_system.get('category', 'General')}")
|
|
568
|
-
lines.append("")
|
|
569
|
-
lines.append("---")
|
|
570
|
-
lines.append("")
|
|
571
|
-
|
|
572
|
-
# Global Rules section
|
|
573
|
-
lines.append("## Global Rules")
|
|
574
|
-
lines.append("")
|
|
575
|
-
|
|
576
|
-
# Color Palette
|
|
577
|
-
lines.append("### Color Palette")
|
|
578
|
-
lines.append("")
|
|
579
|
-
lines.append("| Role | Hex | CSS Variable |")
|
|
580
|
-
lines.append("|------|-----|--------------|")
|
|
581
|
-
lines.append(f"| Primary | `{colors.get('primary', '#2563EB')}` | `--color-primary` |")
|
|
582
|
-
lines.append(f"| Secondary | `{colors.get('secondary', '#3B82F6')}` | `--color-secondary` |")
|
|
583
|
-
lines.append(f"| CTA/Accent | `{colors.get('cta', '#F97316')}` | `--color-cta` |")
|
|
584
|
-
lines.append(f"| Background | `{colors.get('background', '#F8FAFC')}` | `--color-background` |")
|
|
585
|
-
lines.append(f"| Text | `{colors.get('text', '#1E293B')}` | `--color-text` |")
|
|
586
|
-
lines.append("")
|
|
587
|
-
if colors.get("notes"):
|
|
588
|
-
lines.append(f"**Color Notes:** {colors.get('notes', '')}")
|
|
589
|
-
lines.append("")
|
|
590
|
-
|
|
591
|
-
# Typography
|
|
592
|
-
lines.append("### Typography")
|
|
593
|
-
lines.append("")
|
|
594
|
-
lines.append(f"- **Heading Font:** {typography.get('heading', 'Inter')}")
|
|
595
|
-
lines.append(f"- **Body Font:** {typography.get('body', 'Inter')}")
|
|
596
|
-
if typography.get("mood"):
|
|
597
|
-
lines.append(f"- **Mood:** {typography.get('mood', '')}")
|
|
598
|
-
if typography.get("google_fonts_url"):
|
|
599
|
-
lines.append(f"- **Google Fonts:** [{typography.get('heading', '')} + {typography.get('body', '')}]({typography.get('google_fonts_url', '')})")
|
|
600
|
-
lines.append("")
|
|
601
|
-
if typography.get("css_import"):
|
|
602
|
-
lines.append("**CSS Import:**")
|
|
603
|
-
lines.append("```css")
|
|
604
|
-
lines.append(typography.get("css_import", ""))
|
|
605
|
-
lines.append("```")
|
|
606
|
-
lines.append("")
|
|
607
|
-
|
|
608
|
-
# Spacing Variables
|
|
609
|
-
lines.append("### Spacing Variables")
|
|
610
|
-
lines.append("")
|
|
611
|
-
lines.append("| Token | Value | Usage |")
|
|
612
|
-
lines.append("|-------|-------|-------|")
|
|
613
|
-
lines.append("| `--space-xs` | `4px` / `0.25rem` | Tight gaps |")
|
|
614
|
-
lines.append("| `--space-sm` | `8px` / `0.5rem` | Icon gaps, inline spacing |")
|
|
615
|
-
lines.append("| `--space-md` | `16px` / `1rem` | Standard padding |")
|
|
616
|
-
lines.append("| `--space-lg` | `24px` / `1.5rem` | Section padding |")
|
|
617
|
-
lines.append("| `--space-xl` | `32px` / `2rem` | Large gaps |")
|
|
618
|
-
lines.append("| `--space-2xl` | `48px` / `3rem` | Section margins |")
|
|
619
|
-
lines.append("| `--space-3xl` | `64px` / `4rem` | Hero padding |")
|
|
620
|
-
lines.append("")
|
|
621
|
-
|
|
622
|
-
# Shadow Depths
|
|
623
|
-
lines.append("### Shadow Depths")
|
|
624
|
-
lines.append("")
|
|
625
|
-
lines.append("| Level | Value | Usage |")
|
|
626
|
-
lines.append("|-------|-------|-------|")
|
|
627
|
-
lines.append("| `--shadow-sm` | `0 1px 2px rgba(0,0,0,0.05)` | Subtle lift |")
|
|
628
|
-
lines.append("| `--shadow-md` | `0 4px 6px rgba(0,0,0,0.1)` | Cards, buttons |")
|
|
629
|
-
lines.append("| `--shadow-lg` | `0 10px 15px rgba(0,0,0,0.1)` | Modals, dropdowns |")
|
|
630
|
-
lines.append("| `--shadow-xl` | `0 20px 25px rgba(0,0,0,0.15)` | Hero images, featured cards |")
|
|
631
|
-
lines.append("")
|
|
632
|
-
|
|
633
|
-
# Component Specs section
|
|
634
|
-
lines.append("---")
|
|
635
|
-
lines.append("")
|
|
636
|
-
lines.append("## Component Specs")
|
|
637
|
-
lines.append("")
|
|
638
|
-
|
|
639
|
-
# Buttons
|
|
640
|
-
lines.append("### Buttons")
|
|
641
|
-
lines.append("")
|
|
642
|
-
lines.append("```css")
|
|
643
|
-
lines.append("/* Primary Button */")
|
|
644
|
-
lines.append(".btn-primary {")
|
|
645
|
-
lines.append(f" background: {colors.get('cta', '#F97316')};")
|
|
646
|
-
lines.append(" color: white;")
|
|
647
|
-
lines.append(" padding: 12px 24px;")
|
|
648
|
-
lines.append(" border-radius: 8px;")
|
|
649
|
-
lines.append(" font-weight: 600;")
|
|
650
|
-
lines.append(" transition: all 200ms ease;")
|
|
651
|
-
lines.append(" cursor: pointer;")
|
|
652
|
-
lines.append("}")
|
|
653
|
-
lines.append("")
|
|
654
|
-
lines.append(".btn-primary:hover {")
|
|
655
|
-
lines.append(" opacity: 0.9;")
|
|
656
|
-
lines.append(" transform: translateY(-1px);")
|
|
657
|
-
lines.append("}")
|
|
658
|
-
lines.append("")
|
|
659
|
-
lines.append("/* Secondary Button */")
|
|
660
|
-
lines.append(".btn-secondary {")
|
|
661
|
-
lines.append(f" background: transparent;")
|
|
662
|
-
lines.append(f" color: {colors.get('primary', '#2563EB')};")
|
|
663
|
-
lines.append(f" border: 2px solid {colors.get('primary', '#2563EB')};")
|
|
664
|
-
lines.append(" padding: 12px 24px;")
|
|
665
|
-
lines.append(" border-radius: 8px;")
|
|
666
|
-
lines.append(" font-weight: 600;")
|
|
667
|
-
lines.append(" transition: all 200ms ease;")
|
|
668
|
-
lines.append(" cursor: pointer;")
|
|
669
|
-
lines.append("}")
|
|
670
|
-
lines.append("```")
|
|
671
|
-
lines.append("")
|
|
672
|
-
|
|
673
|
-
# Cards
|
|
674
|
-
lines.append("### Cards")
|
|
675
|
-
lines.append("")
|
|
676
|
-
lines.append("```css")
|
|
677
|
-
lines.append(".card {")
|
|
678
|
-
lines.append(f" background: {colors.get('background', '#FFFFFF')};")
|
|
679
|
-
lines.append(" border-radius: 12px;")
|
|
680
|
-
lines.append(" padding: 24px;")
|
|
681
|
-
lines.append(" box-shadow: var(--shadow-md);")
|
|
682
|
-
lines.append(" transition: all 200ms ease;")
|
|
683
|
-
lines.append(" cursor: pointer;")
|
|
684
|
-
lines.append("}")
|
|
685
|
-
lines.append("")
|
|
686
|
-
lines.append(".card:hover {")
|
|
687
|
-
lines.append(" box-shadow: var(--shadow-lg);")
|
|
688
|
-
lines.append(" transform: translateY(-2px);")
|
|
689
|
-
lines.append("}")
|
|
690
|
-
lines.append("```")
|
|
691
|
-
lines.append("")
|
|
692
|
-
|
|
693
|
-
# Inputs
|
|
694
|
-
lines.append("### Inputs")
|
|
695
|
-
lines.append("")
|
|
696
|
-
lines.append("```css")
|
|
697
|
-
lines.append(".input {")
|
|
698
|
-
lines.append(" padding: 12px 16px;")
|
|
699
|
-
lines.append(" border: 1px solid #E2E8F0;")
|
|
700
|
-
lines.append(" border-radius: 8px;")
|
|
701
|
-
lines.append(" font-size: 16px;")
|
|
702
|
-
lines.append(" transition: border-color 200ms ease;")
|
|
703
|
-
lines.append("}")
|
|
704
|
-
lines.append("")
|
|
705
|
-
lines.append(".input:focus {")
|
|
706
|
-
lines.append(f" border-color: {colors.get('primary', '#2563EB')};")
|
|
707
|
-
lines.append(" outline: none;")
|
|
708
|
-
lines.append(f" box-shadow: 0 0 0 3px {colors.get('primary', '#2563EB')}20;")
|
|
709
|
-
lines.append("}")
|
|
710
|
-
lines.append("```")
|
|
711
|
-
lines.append("")
|
|
712
|
-
|
|
713
|
-
# Modals
|
|
714
|
-
lines.append("### Modals")
|
|
715
|
-
lines.append("")
|
|
716
|
-
lines.append("```css")
|
|
717
|
-
lines.append(".modal-overlay {")
|
|
718
|
-
lines.append(" background: rgba(0, 0, 0, 0.5);")
|
|
719
|
-
lines.append(" backdrop-filter: blur(4px);")
|
|
720
|
-
lines.append("}")
|
|
721
|
-
lines.append("")
|
|
722
|
-
lines.append(".modal {")
|
|
723
|
-
lines.append(" background: white;")
|
|
724
|
-
lines.append(" border-radius: 16px;")
|
|
725
|
-
lines.append(" padding: 32px;")
|
|
726
|
-
lines.append(" box-shadow: var(--shadow-xl);")
|
|
727
|
-
lines.append(" max-width: 500px;")
|
|
728
|
-
lines.append(" width: 90%;")
|
|
729
|
-
lines.append("}")
|
|
730
|
-
lines.append("```")
|
|
731
|
-
lines.append("")
|
|
732
|
-
|
|
733
|
-
# Style section
|
|
734
|
-
lines.append("---")
|
|
735
|
-
lines.append("")
|
|
736
|
-
lines.append("## Style Guidelines")
|
|
737
|
-
lines.append("")
|
|
738
|
-
lines.append(f"**Style:** {style.get('name', 'Minimalism')}")
|
|
739
|
-
lines.append("")
|
|
740
|
-
if style.get("keywords"):
|
|
741
|
-
lines.append(f"**Keywords:** {style.get('keywords', '')}")
|
|
742
|
-
lines.append("")
|
|
743
|
-
if style.get("best_for"):
|
|
744
|
-
lines.append(f"**Best For:** {style.get('best_for', '')}")
|
|
745
|
-
lines.append("")
|
|
746
|
-
if effects:
|
|
747
|
-
lines.append(f"**Key Effects:** {effects}")
|
|
748
|
-
lines.append("")
|
|
749
|
-
|
|
750
|
-
# Layout Pattern
|
|
751
|
-
lines.append("### Page Pattern")
|
|
752
|
-
lines.append("")
|
|
753
|
-
lines.append(f"**Pattern Name:** {pattern.get('name', '')}")
|
|
754
|
-
lines.append("")
|
|
755
|
-
if pattern.get('conversion'):
|
|
756
|
-
lines.append(f"- **Conversion Strategy:** {pattern.get('conversion', '')}")
|
|
757
|
-
if pattern.get('cta_placement'):
|
|
758
|
-
lines.append(f"- **CTA Placement:** {pattern.get('cta_placement', '')}")
|
|
759
|
-
lines.append(f"- **Section Order:** {pattern.get('sections', '')}")
|
|
760
|
-
lines.append("")
|
|
761
|
-
|
|
762
|
-
# Anti-Patterns section
|
|
763
|
-
lines.append("---")
|
|
764
|
-
lines.append("")
|
|
765
|
-
lines.append("## Anti-Patterns (Do NOT Use)")
|
|
766
|
-
lines.append("")
|
|
767
|
-
if anti_patterns:
|
|
768
|
-
anti_list = [a.strip() for a in anti_patterns.split("+")]
|
|
769
|
-
for anti in anti_list:
|
|
770
|
-
if anti:
|
|
771
|
-
lines.append(f"- ❌ {anti}")
|
|
772
|
-
lines.append("")
|
|
773
|
-
lines.append("### Additional Forbidden Patterns")
|
|
774
|
-
lines.append("")
|
|
775
|
-
lines.append("- ❌ **Emojis as icons** — Use SVG icons (Heroicons, Lucide, Simple Icons)")
|
|
776
|
-
lines.append("- ❌ **Missing cursor:pointer** — All clickable elements must have cursor:pointer")
|
|
777
|
-
lines.append("- ❌ **Layout-shifting hovers** — Avoid scale transforms that shift layout")
|
|
778
|
-
lines.append("- ❌ **Low contrast text** — Maintain 4.5:1 minimum contrast ratio")
|
|
779
|
-
lines.append("- ❌ **Instant state changes** — Always use transitions (150-300ms)")
|
|
780
|
-
lines.append("- ❌ **Invisible focus states** — Focus states must be visible for a11y")
|
|
781
|
-
lines.append("")
|
|
782
|
-
|
|
783
|
-
# Pre-Delivery Checklist
|
|
784
|
-
lines.append("---")
|
|
785
|
-
lines.append("")
|
|
786
|
-
lines.append("## Pre-Delivery Checklist")
|
|
787
|
-
lines.append("")
|
|
788
|
-
lines.append("Before delivering any UI code, verify:")
|
|
789
|
-
lines.append("")
|
|
790
|
-
lines.append("- [ ] No emojis used as icons (use SVG instead)")
|
|
791
|
-
lines.append("- [ ] All icons from consistent icon set (Heroicons/Lucide)")
|
|
792
|
-
lines.append("- [ ] `cursor-pointer` on all clickable elements")
|
|
793
|
-
lines.append("- [ ] Hover states with smooth transitions (150-300ms)")
|
|
794
|
-
lines.append("- [ ] Light mode: text contrast 4.5:1 minimum")
|
|
795
|
-
lines.append("- [ ] Focus states visible for keyboard navigation")
|
|
796
|
-
lines.append("- [ ] `prefers-reduced-motion` respected")
|
|
797
|
-
lines.append("- [ ] Responsive: 375px, 768px, 1024px, 1440px")
|
|
798
|
-
lines.append("- [ ] No content hidden behind fixed navbars")
|
|
799
|
-
lines.append("- [ ] No horizontal scroll on mobile")
|
|
800
|
-
lines.append("")
|
|
801
|
-
|
|
802
|
-
return "\n".join(lines)
|
|
803
|
-
|
|
804
|
-
|
|
805
|
-
def format_page_override_md(design_system: dict, page_name: str, page_query: str = None) -> str:
|
|
806
|
-
"""Format a page-specific override file with intelligent AI-generated content."""
|
|
807
|
-
project = design_system.get("project_name", "PROJECT")
|
|
808
|
-
timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
|
|
809
|
-
page_title = page_name.replace("-", " ").replace("_", " ").title()
|
|
810
|
-
|
|
811
|
-
# Detect page type and generate intelligent overrides
|
|
812
|
-
page_overrides = _generate_intelligent_overrides(page_name, page_query, design_system)
|
|
813
|
-
|
|
814
|
-
lines = []
|
|
815
|
-
|
|
816
|
-
lines.append(f"# {page_title} Page Overrides")
|
|
817
|
-
lines.append("")
|
|
818
|
-
lines.append(f"> **PROJECT:** {project}")
|
|
819
|
-
lines.append(f"> **Generated:** {timestamp}")
|
|
820
|
-
lines.append(f"> **Page Type:** {page_overrides.get('page_type', 'General')}")
|
|
821
|
-
lines.append("")
|
|
822
|
-
lines.append("> ⚠️ **IMPORTANT:** Rules in this file **override** the Master file (`design-system/MASTER.md`).")
|
|
823
|
-
lines.append("> Only deviations from the Master are documented here. For all other rules, refer to the Master.")
|
|
824
|
-
lines.append("")
|
|
825
|
-
lines.append("---")
|
|
826
|
-
lines.append("")
|
|
827
|
-
|
|
828
|
-
# Page-specific rules with actual content
|
|
829
|
-
lines.append("## Page-Specific Rules")
|
|
830
|
-
lines.append("")
|
|
831
|
-
|
|
832
|
-
# Layout Overrides
|
|
833
|
-
lines.append("### Layout Overrides")
|
|
834
|
-
lines.append("")
|
|
835
|
-
layout = page_overrides.get("layout", {})
|
|
836
|
-
if layout:
|
|
837
|
-
for key, value in layout.items():
|
|
838
|
-
lines.append(f"- **{key}:** {value}")
|
|
839
|
-
else:
|
|
840
|
-
lines.append("- No overrides — use Master layout")
|
|
841
|
-
lines.append("")
|
|
842
|
-
|
|
843
|
-
# Spacing Overrides
|
|
844
|
-
lines.append("### Spacing Overrides")
|
|
845
|
-
lines.append("")
|
|
846
|
-
spacing = page_overrides.get("spacing", {})
|
|
847
|
-
if spacing:
|
|
848
|
-
for key, value in spacing.items():
|
|
849
|
-
lines.append(f"- **{key}:** {value}")
|
|
850
|
-
else:
|
|
851
|
-
lines.append("- No overrides — use Master spacing")
|
|
852
|
-
lines.append("")
|
|
853
|
-
|
|
854
|
-
# Typography Overrides
|
|
855
|
-
lines.append("### Typography Overrides")
|
|
856
|
-
lines.append("")
|
|
857
|
-
typography = page_overrides.get("typography", {})
|
|
858
|
-
if typography:
|
|
859
|
-
for key, value in typography.items():
|
|
860
|
-
lines.append(f"- **{key}:** {value}")
|
|
861
|
-
else:
|
|
862
|
-
lines.append("- No overrides — use Master typography")
|
|
863
|
-
lines.append("")
|
|
864
|
-
|
|
865
|
-
# Color Overrides
|
|
866
|
-
lines.append("### Color Overrides")
|
|
867
|
-
lines.append("")
|
|
868
|
-
colors = page_overrides.get("colors", {})
|
|
869
|
-
if colors:
|
|
870
|
-
for key, value in colors.items():
|
|
871
|
-
lines.append(f"- **{key}:** {value}")
|
|
872
|
-
else:
|
|
873
|
-
lines.append("- No overrides — use Master colors")
|
|
874
|
-
lines.append("")
|
|
875
|
-
|
|
876
|
-
# Component Overrides
|
|
877
|
-
lines.append("### Component Overrides")
|
|
878
|
-
lines.append("")
|
|
879
|
-
components = page_overrides.get("components", [])
|
|
880
|
-
if components:
|
|
881
|
-
for comp in components:
|
|
882
|
-
lines.append(f"- {comp}")
|
|
883
|
-
else:
|
|
884
|
-
lines.append("- No overrides — use Master component specs")
|
|
885
|
-
lines.append("")
|
|
886
|
-
|
|
887
|
-
# Page-Specific Components
|
|
888
|
-
lines.append("---")
|
|
889
|
-
lines.append("")
|
|
890
|
-
lines.append("## Page-Specific Components")
|
|
891
|
-
lines.append("")
|
|
892
|
-
unique_components = page_overrides.get("unique_components", [])
|
|
893
|
-
if unique_components:
|
|
894
|
-
for comp in unique_components:
|
|
895
|
-
lines.append(f"- {comp}")
|
|
896
|
-
else:
|
|
897
|
-
lines.append("- No unique components for this page")
|
|
898
|
-
lines.append("")
|
|
899
|
-
|
|
900
|
-
# Recommendations
|
|
901
|
-
lines.append("---")
|
|
902
|
-
lines.append("")
|
|
903
|
-
lines.append("## Recommendations")
|
|
904
|
-
lines.append("")
|
|
905
|
-
recommendations = page_overrides.get("recommendations", [])
|
|
906
|
-
if recommendations:
|
|
907
|
-
for rec in recommendations:
|
|
908
|
-
lines.append(f"- {rec}")
|
|
909
|
-
lines.append("")
|
|
910
|
-
|
|
911
|
-
return "\n".join(lines)
|
|
912
|
-
|
|
913
|
-
|
|
914
|
-
def _generate_intelligent_overrides(page_name: str, page_query: str, design_system: dict) -> dict:
|
|
915
|
-
"""
|
|
916
|
-
Generate intelligent overrides based on page type using layered search.
|
|
917
|
-
|
|
918
|
-
Uses the existing search infrastructure to find relevant style, UX, and layout
|
|
919
|
-
data instead of hardcoded page types.
|
|
920
|
-
"""
|
|
921
|
-
from core import search
|
|
922
|
-
|
|
923
|
-
page_lower = page_name.lower()
|
|
924
|
-
query_lower = (page_query or "").lower()
|
|
925
|
-
combined_context = f"{page_lower} {query_lower}"
|
|
926
|
-
|
|
927
|
-
# Search across multiple domains for page-specific guidance
|
|
928
|
-
style_search = search(combined_context, "style", max_results=1)
|
|
929
|
-
ux_search = search(combined_context, "ux", max_results=3)
|
|
930
|
-
landing_search = search(combined_context, "landing", max_results=1)
|
|
931
|
-
|
|
932
|
-
# Extract results from search response
|
|
933
|
-
style_results = style_search.get("results", [])
|
|
934
|
-
ux_results = ux_search.get("results", [])
|
|
935
|
-
landing_results = landing_search.get("results", [])
|
|
936
|
-
|
|
937
|
-
# Detect page type from search results or context
|
|
938
|
-
page_type = _detect_page_type(combined_context, style_results)
|
|
939
|
-
|
|
940
|
-
# Build overrides from search results
|
|
941
|
-
layout = {}
|
|
942
|
-
spacing = {}
|
|
943
|
-
typography = {}
|
|
944
|
-
colors = {}
|
|
945
|
-
components = []
|
|
946
|
-
unique_components = []
|
|
947
|
-
recommendations = []
|
|
948
|
-
|
|
949
|
-
# Extract style-based overrides
|
|
950
|
-
if style_results:
|
|
951
|
-
style = style_results[0]
|
|
952
|
-
style_name = style.get("Style Category", "")
|
|
953
|
-
keywords = style.get("Keywords", "")
|
|
954
|
-
best_for = style.get("Best For", "")
|
|
955
|
-
effects = style.get("Effects & Animation", "")
|
|
956
|
-
|
|
957
|
-
# Infer layout from style keywords
|
|
958
|
-
if any(kw in keywords.lower() for kw in ["data", "dense", "dashboard", "grid"]):
|
|
959
|
-
layout["Max Width"] = "1400px or full-width"
|
|
960
|
-
layout["Grid"] = "12-column grid for data flexibility"
|
|
961
|
-
spacing["Content Density"] = "High — optimize for information display"
|
|
962
|
-
elif any(kw in keywords.lower() for kw in ["minimal", "simple", "clean", "single"]):
|
|
963
|
-
layout["Max Width"] = "800px (narrow, focused)"
|
|
964
|
-
layout["Layout"] = "Single column, centered"
|
|
965
|
-
spacing["Content Density"] = "Low — focus on clarity"
|
|
966
|
-
else:
|
|
967
|
-
layout["Max Width"] = "1200px (standard)"
|
|
968
|
-
layout["Layout"] = "Full-width sections, centered content"
|
|
969
|
-
|
|
970
|
-
if effects:
|
|
971
|
-
recommendations.append(f"Effects: {effects}")
|
|
972
|
-
|
|
973
|
-
# Extract UX guidelines as recommendations
|
|
974
|
-
for ux in ux_results:
|
|
975
|
-
category = ux.get("Category", "")
|
|
976
|
-
do_text = ux.get("Do", "")
|
|
977
|
-
dont_text = ux.get("Don't", "")
|
|
978
|
-
if do_text:
|
|
979
|
-
recommendations.append(f"{category}: {do_text}")
|
|
980
|
-
if dont_text:
|
|
981
|
-
components.append(f"Avoid: {dont_text}")
|
|
982
|
-
|
|
983
|
-
# Extract landing pattern info for section structure
|
|
984
|
-
if landing_results:
|
|
985
|
-
landing = landing_results[0]
|
|
986
|
-
sections = landing.get("Section Order", "")
|
|
987
|
-
cta_placement = landing.get("Primary CTA Placement", "")
|
|
988
|
-
color_strategy = landing.get("Color Strategy", "")
|
|
989
|
-
|
|
990
|
-
if sections:
|
|
991
|
-
layout["Sections"] = sections
|
|
992
|
-
if cta_placement:
|
|
993
|
-
recommendations.append(f"CTA Placement: {cta_placement}")
|
|
994
|
-
if color_strategy:
|
|
995
|
-
colors["Strategy"] = color_strategy
|
|
996
|
-
|
|
997
|
-
# Add page-type specific defaults if no search results
|
|
998
|
-
if not layout:
|
|
999
|
-
layout["Max Width"] = "1200px"
|
|
1000
|
-
layout["Layout"] = "Responsive grid"
|
|
1001
|
-
|
|
1002
|
-
if not recommendations:
|
|
1003
|
-
recommendations = [
|
|
1004
|
-
"Refer to MASTER.md for all design rules",
|
|
1005
|
-
"Add specific overrides as needed for this page"
|
|
1006
|
-
]
|
|
1007
|
-
|
|
1008
|
-
return {
|
|
1009
|
-
"page_type": page_type,
|
|
1010
|
-
"layout": layout,
|
|
1011
|
-
"spacing": spacing,
|
|
1012
|
-
"typography": typography,
|
|
1013
|
-
"colors": colors,
|
|
1014
|
-
"components": components,
|
|
1015
|
-
"unique_components": unique_components,
|
|
1016
|
-
"recommendations": recommendations
|
|
1017
|
-
}
|
|
1018
|
-
|
|
1019
|
-
|
|
1020
|
-
def _detect_page_type(context: str, style_results: list) -> str:
|
|
1021
|
-
"""Detect page type from context and search results."""
|
|
1022
|
-
context_lower = context.lower()
|
|
1023
|
-
|
|
1024
|
-
# Check for common page type patterns
|
|
1025
|
-
page_patterns = [
|
|
1026
|
-
(["dashboard", "admin", "analytics", "data", "metrics", "stats", "monitor", "overview"], "Dashboard / Data View"),
|
|
1027
|
-
(["checkout", "payment", "cart", "purchase", "order", "billing"], "Checkout / Payment"),
|
|
1028
|
-
(["settings", "profile", "account", "preferences", "config"], "Settings / Profile"),
|
|
1029
|
-
(["landing", "marketing", "homepage", "hero", "home", "promo"], "Landing / Marketing"),
|
|
1030
|
-
(["login", "signin", "signup", "register", "auth", "password"], "Authentication"),
|
|
1031
|
-
(["pricing", "plans", "subscription", "tiers", "packages"], "Pricing / Plans"),
|
|
1032
|
-
(["blog", "article", "post", "news", "content", "story"], "Blog / Article"),
|
|
1033
|
-
(["product", "item", "detail", "pdp", "shop", "store"], "Product Detail"),
|
|
1034
|
-
(["search", "results", "browse", "filter", "catalog", "list"], "Search Results"),
|
|
1035
|
-
(["empty", "404", "error", "not found", "zero"], "Empty State"),
|
|
1036
|
-
]
|
|
1037
|
-
|
|
1038
|
-
for keywords, page_type in page_patterns:
|
|
1039
|
-
if any(kw in context_lower for kw in keywords):
|
|
1040
|
-
return page_type
|
|
1041
|
-
|
|
1042
|
-
# Fallback: try to infer from style results
|
|
1043
|
-
if style_results:
|
|
1044
|
-
style_name = style_results[0].get("Style Category", "").lower()
|
|
1045
|
-
best_for = style_results[0].get("Best For", "").lower()
|
|
1046
|
-
|
|
1047
|
-
if "dashboard" in best_for or "data" in best_for:
|
|
1048
|
-
return "Dashboard / Data View"
|
|
1049
|
-
elif "landing" in best_for or "marketing" in best_for:
|
|
1050
|
-
return "Landing / Marketing"
|
|
1051
|
-
|
|
1052
|
-
return "General"
|
|
1053
|
-
|
|
1054
|
-
|
|
1055
|
-
# ============ CLI SUPPORT ============
|
|
1056
|
-
if __name__ == "__main__":
|
|
1057
|
-
import argparse
|
|
1058
|
-
|
|
1059
|
-
parser = argparse.ArgumentParser(description="Generate Design System")
|
|
1060
|
-
parser.add_argument("query", help="Search query (e.g., 'SaaS dashboard')")
|
|
1061
|
-
parser.add_argument("--project-name", "-p", type=str, default=None, help="Project name")
|
|
1062
|
-
parser.add_argument("--format", "-f", choices=["ascii", "markdown"], default="ascii", help="Output format")
|
|
1063
|
-
|
|
1064
|
-
args = parser.parse_args()
|
|
1065
|
-
|
|
1066
|
-
result = generate_design_system(args.query, args.project_name, args.format)
|
|
1067
|
-
print(result)
|