@su-record/vibe 2.9.32 → 2.9.34
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/.env.example +37 -37
- package/CLAUDE.md +109 -109
- package/LICENSE +21 -21
- package/README.en.md +220 -220
- package/README.md +171 -171
- package/agents/architect-low.md +41 -41
- package/agents/architect-medium.md +59 -59
- package/agents/architect.md +80 -80
- package/agents/build-error-resolver.md +115 -115
- package/agents/compounder.md +261 -261
- package/agents/diagrammer.md +178 -178
- package/agents/docs/api-documenter.md +99 -99
- package/agents/docs/changelog-writer.md +93 -93
- package/agents/e2e-tester.md +294 -294
- package/agents/event/event-comms.md +78 -78
- package/agents/event/event-content.md +68 -68
- package/agents/event/event-image.md +95 -95
- package/agents/event/event-ops.md +84 -84
- package/agents/event/event-scheduler.md +69 -69
- package/agents/event/event-speaker.md +86 -86
- package/agents/explorer-low.md +42 -42
- package/agents/explorer-medium.md +59 -59
- package/agents/explorer.md +48 -48
- package/agents/implementer-low.md +43 -43
- package/agents/implementer-medium.md +52 -52
- package/agents/implementer.md +54 -54
- package/agents/junior-mentor.md +141 -141
- package/agents/planning/requirements-analyst.md +84 -84
- package/agents/planning/ux-advisor.md +83 -83
- package/agents/qa/acceptance-tester.md +86 -86
- package/agents/qa/edge-case-finder.md +93 -93
- package/agents/qa/qa-coordinator.md +131 -131
- package/agents/refactor-cleaner.md +143 -143
- package/agents/research/best-practices-agent.md +199 -199
- package/agents/research/codebase-patterns-agent.md +157 -157
- package/agents/research/framework-docs-agent.md +188 -188
- package/agents/research/security-advisory-agent.md +213 -213
- package/agents/review/architecture-reviewer.md +107 -107
- package/agents/review/complexity-reviewer.md +116 -116
- package/agents/review/data-integrity-reviewer.md +88 -88
- package/agents/review/git-history-reviewer.md +103 -103
- package/agents/review/performance-reviewer.md +86 -86
- package/agents/review/python-reviewer.md +150 -150
- package/agents/review/rails-reviewer.md +139 -139
- package/agents/review/react-reviewer.md +144 -144
- package/agents/review/security-reviewer.md +80 -80
- package/agents/review/simplicity-reviewer.md +140 -140
- package/agents/review/test-coverage-reviewer.md +116 -116
- package/agents/review/typescript-reviewer.md +127 -127
- package/agents/searcher.md +54 -54
- package/agents/simplifier.md +120 -120
- package/agents/teams/debug-team.md +70 -70
- package/agents/teams/dev-team.md +88 -88
- package/agents/teams/docs-team.md +80 -80
- package/agents/teams/figma/figma-analyst.md +52 -52
- package/agents/teams/figma/figma-architect.md +112 -112
- package/agents/teams/figma/figma-auditor.md +82 -82
- package/agents/teams/figma/figma-builder.md +100 -100
- package/agents/teams/figma-team.md +85 -85
- package/agents/teams/fullstack-team.md +83 -83
- package/agents/teams/lite-team.md +69 -69
- package/agents/teams/migration-team.md +78 -78
- package/agents/teams/refactor-team.md +94 -94
- package/agents/teams/research-team.md +86 -86
- package/agents/teams/review-debate-team.md +125 -125
- package/agents/teams/security-team.md +81 -81
- package/agents/tester.md +49 -49
- package/agents/ui/ui-a11y-auditor.md +93 -93
- package/agents/ui/ui-antipattern-detector.md +102 -102
- package/agents/ui/ui-dataviz-advisor.md +69 -69
- package/agents/ui/ui-design-system-gen.md +57 -57
- package/agents/ui/ui-industry-analyzer.md +49 -49
- package/agents/ui/ui-layout-architect.md +65 -65
- package/agents/ui/ui-stack-implementer.md +68 -68
- package/agents/ui/ux-compliance-reviewer.md +81 -81
- package/agents/ui-previewer.md +258 -258
- package/commands/vibe.analyze.md +533 -533
- package/commands/vibe.contract.md +105 -105
- package/commands/vibe.docs.md +33 -33
- package/commands/vibe.event.md +163 -163
- package/commands/vibe.figma.md +600 -600
- package/commands/vibe.harness.md +177 -177
- package/commands/vibe.regress.md +73 -73
- package/commands/vibe.review.md +624 -624
- package/commands/vibe.run.md +1946 -1946
- package/commands/vibe.scaffold.md +195 -195
- package/commands/vibe.spec.md +577 -577
- package/commands/vibe.test.md +49 -49
- package/commands/vibe.trace.md +276 -276
- package/commands/vibe.utils.md +413 -413
- package/commands/vibe.verify.md +572 -572
- package/dist/cli/collaborator.js +52 -52
- package/dist/cli/commands/codex-proxy.js +15 -15
- package/dist/cli/commands/config.js +9 -9
- package/dist/cli/commands/evolution.js +12 -12
- package/dist/cli/commands/figma.js +20 -20
- package/dist/cli/commands/info.d.ts.map +1 -1
- package/dist/cli/commands/info.js +48 -46
- package/dist/cli/commands/info.js.map +1 -1
- package/dist/cli/commands/init.d.ts +6 -3
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +60 -30
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/remove.js +14 -14
- package/dist/cli/commands/sentinel.js +27 -27
- package/dist/cli/commands/skills.js +5 -5
- package/dist/cli/commands/slack.js +10 -10
- package/dist/cli/commands/stats.js +6 -6
- package/dist/cli/commands/telegram.js +12 -12
- package/dist/cli/commands/update.d.ts.map +1 -1
- package/dist/cli/commands/update.js +29 -11
- package/dist/cli/commands/update.js.map +1 -1
- package/dist/cli/detect.js +32 -32
- package/dist/cli/index.js +40 -34
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/llm/claude-commands.js +16 -16
- package/dist/cli/llm/config.js +18 -18
- package/dist/cli/llm/gemini-commands.js +16 -16
- package/dist/cli/llm/gpt-commands.js +19 -19
- package/dist/cli/llm/help.js +21 -21
- package/dist/cli/postinstall/cursor-agents.js +32 -32
- package/dist/cli/postinstall/cursor-rules.js +83 -83
- package/dist/cli/postinstall/cursor-skills.js +743 -743
- package/dist/cli/postinstall/main.d.ts.map +1 -1
- package/dist/cli/postinstall/main.js +15 -1
- package/dist/cli/postinstall/main.js.map +1 -1
- package/dist/cli/setup/ProjectSetup.d.ts +25 -6
- package/dist/cli/setup/ProjectSetup.d.ts.map +1 -1
- package/dist/cli/setup/ProjectSetup.js +132 -80
- package/dist/cli/setup/ProjectSetup.js.map +1 -1
- package/dist/cli/setup/Provisioner.js +42 -42
- package/dist/cli/setup.d.ts +1 -1
- package/dist/cli/setup.d.ts.map +1 -1
- package/dist/cli/setup.js +1 -1
- package/dist/cli/setup.js.map +1 -1
- package/dist/infra/lib/DeepInit.js +24 -24
- package/dist/infra/lib/IterationTracker.js +11 -11
- package/dist/infra/lib/PythonParser.js +108 -108
- package/dist/infra/lib/ReviewRace.js +96 -96
- package/dist/infra/lib/SkillFrontmatter.js +28 -28
- package/dist/infra/lib/SkillQualityGate.js +9 -9
- package/dist/infra/lib/SkillRepository.js +159 -159
- package/dist/infra/lib/UltraQA.js +99 -99
- package/dist/infra/lib/autonomy/AuditStore.js +41 -41
- package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
- package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
- package/dist/infra/lib/autonomy/PolicyEngine.d.ts +3 -3
- package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
- package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
- package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
- package/dist/infra/lib/embedding/VectorStore.js +22 -22
- package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
- package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
- package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
- package/dist/infra/lib/evolution/InsightStore.js +90 -90
- package/dist/infra/lib/evolution/ParityTester.js +57 -57
- package/dist/infra/lib/evolution/RollbackManager.js +5 -5
- package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
- package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
- package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
- package/dist/infra/lib/evolution/UsageTracker.js +28 -28
- package/dist/infra/lib/gemini/orchestration.js +5 -5
- package/dist/infra/lib/gpt/orchestration.js +4 -4
- package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
- package/dist/infra/lib/memory/MemorySearch.js +57 -57
- package/dist/infra/lib/memory/MemoryStorage.js +181 -181
- package/dist/infra/lib/memory/ObservationStore.js +28 -28
- package/dist/infra/lib/memory/ReflectionStore.js +30 -30
- package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
- package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
- package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
- package/dist/infra/orchestrator/AgentManager.js +12 -12
- package/dist/infra/orchestrator/AgentRegistry.js +65 -65
- package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
- package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
- package/dist/infra/orchestrator/parallelResearch.js +24 -24
- package/dist/tools/convention/analyzeComplexity.test.js +115 -115
- package/dist/tools/convention/validateCodeQuality.test.js +104 -104
- package/dist/tools/memory/createMemoryTimeline.js +10 -10
- package/dist/tools/memory/getMemoryGraph.js +12 -12
- package/dist/tools/memory/getSessionContext.js +9 -9
- package/dist/tools/memory/linkMemories.js +14 -14
- package/dist/tools/memory/listMemories.js +4 -4
- package/dist/tools/memory/recallMemory.js +4 -4
- package/dist/tools/memory/saveMemory.js +4 -4
- package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
- package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
- package/dist/tools/semantic/astGrep.test.js +6 -6
- package/dist/tools/spec/prdParser.test.js +171 -171
- package/dist/tools/spec/specGenerator.js +169 -169
- package/dist/tools/spec/traceabilityMatrix.js +64 -64
- package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
- package/hooks/gemini-hooks.json +73 -73
- package/hooks/hooks.json +134 -134
- package/hooks/scripts/__tests__/keyword-detector.test.js +199 -199
- package/hooks/scripts/__tests__/pre-tool-guard.test.js +409 -409
- package/hooks/scripts/__tests__/sentinel-guard.test.js +208 -208
- package/hooks/scripts/auto-commit.js +97 -97
- package/hooks/scripts/auto-format.js +64 -64
- package/hooks/scripts/auto-test.js +81 -81
- package/hooks/scripts/code-check.js +271 -271
- package/hooks/scripts/codex-detect.js +46 -46
- package/hooks/scripts/codex-review-gate.js +80 -80
- package/hooks/scripts/command-log.js +32 -32
- package/hooks/scripts/context-save.js +353 -353
- package/hooks/scripts/evolution-engine.js +91 -91
- package/hooks/scripts/figma-extract.js +768 -768
- package/hooks/scripts/figma-guard.js +219 -219
- package/hooks/scripts/figma-refine.js +315 -315
- package/hooks/scripts/figma-to-scss.js +394 -394
- package/hooks/scripts/figma-validate.js +353 -353
- package/hooks/scripts/hud-status.js +321 -321
- package/hooks/scripts/keyword-detector.js +214 -214
- package/hooks/scripts/lib/dispatcher.js +95 -87
- package/hooks/scripts/lib/scope-from-spec.js +276 -276
- package/hooks/scripts/llm-orchestrate.js +645 -645
- package/hooks/scripts/post-edit-dispatcher.js +9 -6
- package/hooks/scripts/post-edit.js +35 -35
- package/hooks/scripts/pr-test-gate.js +52 -52
- package/hooks/scripts/pre-tool-dispatcher.js +9 -1
- package/hooks/scripts/pre-tool-guard.js +259 -259
- package/hooks/scripts/prompt-dispatcher.js +200 -192
- package/hooks/scripts/scope-guard.js +145 -145
- package/hooks/scripts/sentinel-guard.js +130 -130
- package/hooks/scripts/session-start.js +186 -186
- package/hooks/scripts/skill-injector.js +83 -83
- package/hooks/scripts/step-counter.js +45 -45
- package/hooks/scripts/stop-dispatcher.js +9 -6
- package/hooks/scripts/stop-notify.js +209 -209
- package/hooks/scripts/utils.js +315 -315
- package/languages/csharp-unity.md +515 -515
- package/languages/gdscript-godot.md +470 -470
- package/languages/ruby-rails.md +489 -489
- package/languages/typescript-angular.md +433 -433
- package/languages/typescript-astro.md +416 -416
- package/languages/typescript-electron.md +406 -406
- package/languages/typescript-nestjs.md +524 -524
- package/languages/typescript-svelte.md +407 -407
- package/languages/typescript-tauri.md +365 -365
- package/package.json +106 -106
- package/skills/agents-md/SKILL.md +121 -121
- package/skills/agents-md/rubrics/what-to-keep.md +49 -49
- package/skills/agents-md/templates/agents-md.md +36 -36
- package/skills/arch-guard/SKILL.md +181 -181
- package/skills/arch-guard/agents/detector.md +48 -48
- package/skills/arch-guard/agents/reporter.md +48 -48
- package/skills/arch-guard/agents/rule-generator.md +49 -49
- package/skills/arch-guard/agents/violation-checker.md +51 -51
- package/skills/arch-guard/frameworks/clean-architecture.md +108 -108
- package/skills/arch-guard/frameworks/solid.md +102 -102
- package/skills/arch-guard/scripts/check-boundaries.js +90 -90
- package/skills/arch-guard/templates/arch-rules.json +47 -47
- package/skills/arch-guard/templates/violation-report.md +53 -53
- package/skills/brand-assets/SKILL.md +147 -147
- package/skills/brand-assets/rubrics/asset-checklist.md +98 -98
- package/skills/brand-assets/templates/brand-guide.md +161 -161
- package/skills/capability-loop/SKILL.md +272 -272
- package/skills/capability-loop/agents/capability-designer.md +61 -61
- package/skills/capability-loop/agents/failure-analyst.md +55 -55
- package/skills/capability-loop/agents/implementer.md +50 -50
- package/skills/capability-loop/agents/tester.md +53 -53
- package/skills/capability-loop/templates/capability-spec.md +118 -118
- package/skills/capability-loop/templates/failure-analysis.md +118 -118
- package/skills/characterization-test/SKILL.md +207 -207
- package/skills/characterization-test/agents/behavior-capturer.md +50 -50
- package/skills/characterization-test/agents/coverage-checker.md +54 -54
- package/skills/characterization-test/agents/reporter.md +50 -50
- package/skills/characterization-test/agents/test-writer.md +49 -49
- package/skills/characterization-test/rubrics/coverage-criteria.md +53 -53
- package/skills/characterization-test/templates/test-template.ts +101 -101
- package/skills/chub-usage/SKILL.md +139 -139
- package/skills/claude-md-guide/SKILL.md +351 -351
- package/skills/claude-md-guide/rubrics/anti-patterns.md +88 -88
- package/skills/claude-md-guide/templates/claude-md.md +54 -54
- package/skills/commerce-patterns/SKILL.md +64 -64
- package/skills/commerce-patterns/rubrics/checkout-flow.md +48 -48
- package/skills/commerce-patterns/templates/product-schema.md +85 -85
- package/skills/commit-push-pr/SKILL.md +77 -77
- package/skills/commit-push-pr/agents/change-analyzer.md +55 -55
- package/skills/commit-push-pr/agents/message-writer.md +50 -50
- package/skills/commit-push-pr/agents/pr-writer.md +58 -58
- package/skills/commit-push-pr/agents/reviewer.md +52 -52
- package/skills/commit-push-pr/rubrics/commit-message.md +73 -73
- package/skills/commit-push-pr/templates/pr-body.md +63 -63
- package/skills/context7-usage/SKILL.md +106 -106
- package/skills/context7-usage/rubrics/when-to-use.md +50 -50
- package/skills/create-prd/SKILL.md +90 -90
- package/skills/create-prd/agents/edge-case-finder.md +48 -48
- package/skills/create-prd/agents/prioritizer.md +60 -60
- package/skills/create-prd/agents/requirements-writer.md +48 -48
- package/skills/create-prd/agents/researcher.md +55 -55
- package/skills/create-prd/agents/reviewer.md +54 -54
- package/skills/create-prd/frameworks/jobs-to-be-done.md +96 -96
- package/skills/create-prd/frameworks/rice-scoring.md +97 -97
- package/skills/create-prd/orchestrator.md +70 -70
- package/skills/create-prd/rubrics/completeness.md +58 -58
- package/skills/create-prd/templates/prd.md +139 -139
- package/skills/design-audit/SKILL.md +152 -152
- package/skills/design-audit/agents/a11y-auditor.md +43 -43
- package/skills/design-audit/agents/performance-auditor.md +46 -46
- package/skills/design-audit/agents/responsive-auditor.md +46 -46
- package/skills/design-audit/agents/scorer.md +47 -47
- package/skills/design-audit/agents/slop-detector.md +47 -47
- package/skills/design-audit/frameworks/core-web-vitals.md +107 -107
- package/skills/design-audit/frameworks/wcag-checklist.md +64 -64
- package/skills/design-audit/orchestrator.md +64 -64
- package/skills/design-audit/rubrics/ai-slop-patterns.md +83 -83
- package/skills/design-audit/rubrics/scoring.md +63 -63
- package/skills/design-audit/templates/report.md +88 -88
- package/skills/design-critique/SKILL.md +139 -139
- package/skills/design-critique/rubrics/ux-heuristics.md +143 -143
- package/skills/design-critique/templates/critique-report.md +86 -86
- package/skills/design-distill/SKILL.md +130 -130
- package/skills/design-distill/templates/design-system.md +132 -132
- package/skills/design-normalize/SKILL.md +133 -133
- package/skills/design-normalize/rubrics/token-naming.md +117 -117
- package/skills/design-normalize/templates/token-audit.md +89 -89
- package/skills/design-polish/SKILL.md +131 -131
- package/skills/design-polish/rubrics/polish-checklist.md +68 -68
- package/skills/design-polish/templates/polish-report.md +64 -64
- package/skills/design-teach/SKILL.md +182 -182
- package/skills/design-teach/rubrics/brand-personality.md +73 -73
- package/skills/design-teach/templates/design-context.json +36 -36
- package/skills/devlog/SKILL.md +143 -143
- package/skills/e2e-commerce/SKILL.md +62 -62
- package/skills/e2e-commerce/templates/test-scenarios.md +170 -170
- package/skills/event-comms/SKILL.md +172 -172
- package/skills/event-comms/templates/email-invite.md +99 -99
- package/skills/event-comms/templates/sns-post.md +133 -133
- package/skills/event-ops/SKILL.md +207 -207
- package/skills/event-ops/rubrics/contingency.md +85 -85
- package/skills/event-ops/templates/d-day-checklist.md +65 -65
- package/skills/event-planning/SKILL.md +144 -144
- package/skills/event-planning/rubrics/timeline.md +70 -70
- package/skills/event-planning/templates/event-plan.md +91 -91
- package/skills/exec-plan/SKILL.md +149 -149
- package/skills/exec-plan/agents/decomposer.md +47 -47
- package/skills/exec-plan/agents/dependency-mapper.md +44 -44
- package/skills/exec-plan/agents/estimator.md +43 -43
- package/skills/exec-plan/agents/validator.md +55 -55
- package/skills/exec-plan/orchestrator.md +70 -70
- package/skills/exec-plan/rubrics/complexity-scoring.md +75 -75
- package/skills/exec-plan/templates/plan.md +147 -147
- package/skills/git-worktree/SKILL.md +73 -73
- package/skills/git-worktree/rubrics/when-to-use.md +55 -55
- package/skills/handoff/SKILL.md +110 -110
- package/skills/handoff/agents/context-summarizer.md +51 -51
- package/skills/handoff/agents/document-writer.md +63 -63
- package/skills/handoff/agents/state-collector.md +53 -53
- package/skills/handoff/agents/verifier.md +48 -48
- package/skills/handoff/rubrics/completeness.md +62 -62
- package/skills/handoff/templates/handoff.md +107 -107
- package/skills/parallel-research/SKILL.md +104 -104
- package/skills/parallel-research/agents/best-practices.md +43 -43
- package/skills/parallel-research/agents/codebase-patterns.md +46 -46
- package/skills/parallel-research/agents/framework-docs.md +45 -45
- package/skills/parallel-research/agents/security-advisory.md +46 -46
- package/skills/parallel-research/agents/synthesizer.md +57 -57
- package/skills/parallel-research/experts/best-practices.md +50 -50
- package/skills/parallel-research/experts/codebase-patterns.md +70 -70
- package/skills/parallel-research/experts/framework-docs.md +65 -65
- package/skills/parallel-research/experts/security-advisory.md +69 -69
- package/skills/parallel-research/orchestrator.md +79 -79
- package/skills/parallel-research/templates/awesome-list.md +32 -32
- package/skills/parallel-research/templates/paper.md +88 -88
- package/skills/parallel-research/templates/synthesis.md +101 -101
- package/skills/prioritization-frameworks/SKILL.md +87 -87
- package/skills/prioritization-frameworks/rubrics/frameworks.md +79 -79
- package/skills/prioritization-frameworks/templates/scoring-matrix.md +69 -69
- package/skills/priority-todos/SKILL.md +64 -64
- package/skills/priority-todos/rubrics/prioritization.md +70 -70
- package/skills/priority-todos/templates/todo-board.md +59 -59
- package/skills/seo-checklist/SKILL.md +58 -58
- package/skills/seo-checklist/frameworks/structured-data.md +153 -153
- package/skills/seo-checklist/rubrics/content-seo.md +42 -42
- package/skills/seo-checklist/rubrics/technical-seo.md +48 -48
- package/skills/techdebt/SKILL.md +124 -124
- package/skills/techdebt/agents/analyzer.md +50 -50
- package/skills/techdebt/agents/fixer.md +41 -41
- package/skills/techdebt/agents/reviewer.md +47 -47
- package/skills/techdebt/agents/scanner.md +44 -44
- package/skills/techdebt/orchestrator.md +70 -70
- package/skills/techdebt/rubrics/severity.md +51 -51
- package/skills/techdebt/scripts/scan.js +90 -90
- package/skills/techdebt/templates/report.md +86 -86
- package/skills/tool-fallback/SKILL.md +104 -104
- package/skills/tool-fallback/rubrics/fallback-chain.md +58 -58
- package/skills/typescript-advanced-types/SKILL.md +67 -67
- package/skills/typescript-advanced-types/rubrics/type-patterns.md +109 -109
- package/skills/ui-ux-pro-max/SKILL.md +236 -236
- package/skills/ui-ux-pro-max/reference/color-and-contrast.md +517 -517
- package/skills/ui-ux-pro-max/reference/interaction-design.md +544 -544
- package/skills/ui-ux-pro-max/reference/motion-design.md +591 -591
- package/skills/ui-ux-pro-max/reference/responsive-design.md +463 -463
- package/skills/ui-ux-pro-max/reference/spatial-design.md +390 -390
- package/skills/ui-ux-pro-max/reference/typography.md +455 -455
- package/skills/ui-ux-pro-max/reference/ux-writing.md +469 -469
- package/skills/ui-ux-pro-max/rubrics/interaction-states.md +83 -83
- package/skills/ui-ux-pro-max/rubrics/responsive-breakpoints.md +99 -99
- package/skills/user-personas/SKILL.md +75 -75
- package/skills/user-personas/rubrics/research-methods.md +56 -56
- package/skills/user-personas/templates/persona.md +89 -89
- package/skills/vercel-react-best-practices/SKILL.md +60 -60
- package/skills/vercel-react-best-practices/rubrics/performance.md +82 -82
- package/skills/vercel-react-best-practices/rubrics/server-components.md +86 -86
- package/skills/vibe-contract/SKILL.md +166 -166
- package/skills/vibe-docs/templates/architecture.md +80 -80
- package/skills/vibe-docs/templates/readme.md +84 -84
- package/skills/vibe-docs/templates/release-notes.md +74 -74
- package/skills/vibe-figma/SKILL.md +363 -363
- package/skills/vibe-figma/rubrics/extraction-checklist.md +51 -51
- package/skills/vibe-figma/templates/component-index.md +126 -126
- package/skills/vibe-figma/templates/component-spec.md +168 -168
- package/skills/vibe-figma/templates/figma-handoff.md +100 -100
- package/skills/vibe-figma/templates/remapped-tree.md +277 -277
- package/skills/vibe-figma-convert/SKILL.md +235 -235
- package/skills/vibe-figma-convert/rubrics/conversion-rules.md +141 -141
- package/skills/vibe-figma-convert/templates/component.md +140 -140
- package/skills/vibe-figma-extract/SKILL.md +241 -241
- package/skills/vibe-figma-extract/rubrics/image-rules.md +157 -157
- package/skills/vibe-interview/SKILL.md +358 -358
- package/skills/vibe-interview/checklists/api.md +101 -101
- package/skills/vibe-interview/checklists/feature.md +88 -88
- package/skills/vibe-interview/checklists/library.md +95 -95
- package/skills/vibe-interview/checklists/mobile.md +89 -89
- package/skills/vibe-interview/checklists/webapp.md +97 -97
- package/skills/vibe-interview/checklists/website.md +99 -99
- package/skills/vibe-plan/SKILL.md +254 -254
- package/skills/vibe-regress/SKILL.md +174 -174
- package/skills/vibe-regress/templates/bug.md +44 -44
- package/skills/vibe-regress/templates/test-jest.md +29 -29
- package/skills/vibe-regress/templates/test-vitest.md +30 -30
- package/skills/vibe-spec/SKILL.md +1195 -1195
- package/skills/vibe-spec-review/SKILL.md +726 -726
- package/skills/vibe-test/SKILL.md +140 -140
- package/skills/video-production/SKILL.md +52 -52
- package/skills/video-production/rubrics/quality-checklist.md +58 -58
- package/skills/video-production/templates/production-plan.md +104 -104
- package/vibe/config.json +29 -29
- package/vibe/constitution.md +227 -227
- package/vibe/rules/principles/communication-guide.md +98 -98
- package/vibe/rules/principles/development-philosophy.md +52 -52
- package/vibe/rules/principles/quick-start.md +102 -102
- package/vibe/rules/quality/bdd-contract-testing.md +393 -393
- package/vibe/rules/quality/checklist.md +276 -276
- package/vibe/rules/quality/performance.md +236 -236
- package/vibe/rules/quality/testing-strategy.md +440 -440
- package/vibe/rules/standards/anti-patterns.md +541 -541
- package/vibe/rules/standards/code-structure.md +291 -291
- package/vibe/rules/standards/complexity-metrics.md +313 -313
- package/vibe/rules/standards/git-workflow.md +237 -237
- package/vibe/rules/standards/naming-conventions.md +198 -198
- package/vibe/rules/standards/security.md +305 -305
- package/vibe/rules/writing/document-style.md +74 -74
- package/vibe/setup.sh +31 -31
- package/vibe/templates/claudemd-template.md +74 -74
- package/vibe/templates/constitution-template.md +267 -267
- package/vibe/templates/contract-backend-template.md +526 -526
- package/vibe/templates/contract-frontend-template.md +599 -599
- package/vibe/templates/feature-template.md +96 -96
- package/vibe/templates/plan-template.md +194 -194
- package/vibe/templates/spec-template.md +221 -221
- package/vibe/ui-ux-data/charts.csv +26 -26
- package/vibe/ui-ux-data/colors.csv +97 -97
- package/vibe/ui-ux-data/icons.csv +101 -101
- package/vibe/ui-ux-data/landing.csv +31 -31
- package/vibe/ui-ux-data/products.csv +96 -96
- package/vibe/ui-ux-data/react-performance.csv +45 -45
- package/vibe/ui-ux-data/stacks/astro.csv +54 -54
- package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
- package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
- package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
- package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
- package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
- package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
- package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
- package/vibe/ui-ux-data/stacks/react.csv +54 -54
- package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
- package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
- package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
- package/vibe/ui-ux-data/stacks/vue.csv +50 -50
- package/vibe/ui-ux-data/styles.csv +68 -68
- package/vibe/ui-ux-data/typography.csv +57 -57
- package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
- package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
- package/vibe/ui-ux-data/version.json +31 -31
- package/vibe/ui-ux-data/web-interface.csv +31 -31
|
@@ -1,241 +1,241 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: vibe-figma-extract
|
|
3
|
-
description: Acquire code generation data via Figma REST API — tree (primary), images, screenshots (for validation)
|
|
4
|
-
triggers: []
|
|
5
|
-
tier: standard
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
# vibe.figma.extract — Acquire Code Generation Data
|
|
9
|
-
|
|
10
|
-
Uses the Figma REST API (`src/infra/lib/figma/`) to extract **all data needed for structural code generation**.
|
|
11
|
-
|
|
12
|
-
```
|
|
13
|
-
Extraction priority:
|
|
14
|
-
1st: Node tree + CSS (PRIMARY source for code generation)
|
|
15
|
-
2nd: Image assets (fill images + item node rendering)
|
|
16
|
-
3rd: Screenshots (for Phase 6 visual validation — not used for code generation)
|
|
17
|
-
```
|
|
18
|
-
|
|
19
|
-
---
|
|
20
|
-
|
|
21
|
-
## 1. Node Tree + CSS — Source of Truth for Code Generation
|
|
22
|
-
|
|
23
|
-
```
|
|
24
|
-
Bash:
|
|
25
|
-
node "{{VIBE_PATH}}/hooks/scripts/figma-extract.js" tree {fileKey} {nodeId}
|
|
26
|
-
|
|
27
|
-
Returns (FigmaNode JSON):
|
|
28
|
-
{
|
|
29
|
-
nodeId, name, type, size: { width, height },
|
|
30
|
-
css: { display, flexDirection, gap, ... },
|
|
31
|
-
text: "text content" (TEXT nodes only),
|
|
32
|
-
imageRef: "abc123" (image fill),
|
|
33
|
-
imageScaleMode: "FILL" (FILL/FIT/CROP/TILE),
|
|
34
|
-
layoutSizingH: "HUG" (FIXED/HUG/FILL),
|
|
35
|
-
layoutSizingV: "FILL",
|
|
36
|
-
fills: [...] (only when 2 or more),
|
|
37
|
-
isMask: true (mask nodes only),
|
|
38
|
-
raw: { itemSpacing, paddingTop/..., cornerRadius, strokeWeight, strokeAlign,
|
|
39
|
-
blendMode, opacity, fontSize, lineHeightPx, letterSpacing, fontWeight,
|
|
40
|
-
leadingTrim, textBoxTrim }, ← numeric Figma values for Phase 6 raw-vs-computed reconciliation
|
|
41
|
-
warnings: [ { property, value, severity: "P1"|"P2", reason } ], ← translation-loss only
|
|
42
|
-
children: [...]
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
Root node also carries:
|
|
46
|
-
auditSummary: { total, p1, p2, items: [{ nodeId, name, property, value, severity, reason }] }
|
|
47
|
-
|
|
48
|
-
→ Save to /tmp/{feature}/tree.json
|
|
49
|
-
```
|
|
50
|
-
|
|
51
|
-
### Translation-loss Audit (Figma → CSS Incompatibilities)
|
|
52
|
-
|
|
53
|
-
The extractor flags properties Figma's native renderer supports but CSS cannot reproduce cleanly. These appear in each node's `warnings[]` and are rolled up at the root as `auditSummary`.
|
|
54
|
-
|
|
55
|
-
**P1 (block Phase 3 until resolved or waived):**
|
|
56
|
-
- `strokeAlign` ≠ `CENTER` — CSS border only renders centered strokes; INSIDE/OUTSIDE cannot match without box-sizing trade-offs.
|
|
57
|
-
- `blendMode` ∈ { `LINEAR_BURN`, `LINEAR_DODGE`, `PLUS_DARKER`, `PLUS_LIGHTER` } — no CSS equivalent for `mix-blend-mode` / `background-blend-mode`.
|
|
58
|
-
|
|
59
|
-
**P2 (record + proceed):**
|
|
60
|
-
- `leadingTrim` / `textBoxTrim` ≠ `NONE` — `text-box-trim` has limited browser support (Firefox lacks it).
|
|
61
|
-
- `constraints.horizontal|vertical` ∈ { `SCALE`, `CENTER` } — no direct CSS layout mapping; responsive behavior diverges.
|
|
62
|
-
- `individualStrokeWeights` with `strokeAlign` ≠ `CENTER` — per-side border widths only align cleanly when stroke is centered.
|
|
63
|
-
|
|
64
|
-
**Phase 2 gate rule:** if `auditSummary.p1 > 0`, resolve each item (replace layer in Figma, accept approximation with user sign-off, or mark as known deviation) before Phase 3. P2 items should be logged into the feature notes for Phase 6 reviewer attention.
|
|
65
|
-
|
|
66
|
-
### Figma Property → CSS Direct Mapping Table
|
|
67
|
-
|
|
68
|
-
Properties automatically converted by the tree extraction tool. **These values map directly to SCSS:**
|
|
69
|
-
|
|
70
|
-
**Layout:**
|
|
71
|
-
|
|
72
|
-
| Figma Property | CSS | vw conversion |
|
|
73
|
-
|-----------|-----|---------|
|
|
74
|
-
| `layoutMode=VERTICAL` | `display:flex; flex-direction:column` | No |
|
|
75
|
-
| `layoutMode=HORIZONTAL` | `display:flex; flex-direction:row` | No |
|
|
76
|
-
| `primaryAxisAlignItems` | `justify-content` | No |
|
|
77
|
-
| `counterAxisAlignItems` | `align-items` | No |
|
|
78
|
-
| `itemSpacing` | `gap` | Yes |
|
|
79
|
-
| `layoutGrow=1` | `flex-grow: 1` | No |
|
|
80
|
-
| `padding*` | `padding` | Yes |
|
|
81
|
-
| `absoluteBoundingBox.width/height` | `width/height` | Yes |
|
|
82
|
-
| `layoutPositioning=ABSOLUTE` | `position: absolute` + `top/left` (relative to parent) | Yes |
|
|
83
|
-
| `layoutSizingHorizontal=HUG` | remove width (auto) | — |
|
|
84
|
-
| `layoutSizingHorizontal=FILL` | metadata `layoutSizingH` (converter decides flex:1/100%) | — |
|
|
85
|
-
| `layoutSizingVertical=HUG` | remove height (auto) | — |
|
|
86
|
-
| `layoutSizingVertical=FILL` | metadata `layoutSizingV` (converter decides) | — |
|
|
87
|
-
| `clipsContent` | `overflow: hidden` | No |
|
|
88
|
-
|
|
89
|
-
**Visual:**
|
|
90
|
-
|
|
91
|
-
| Figma Property | CSS | vw conversion |
|
|
92
|
-
|-----------|-----|---------|
|
|
93
|
-
| `fills[].SOLID` | `background-color` | No |
|
|
94
|
-
| `fills[].IMAGE` | `imageRef` + `imageScaleMode` (FILL/FIT/CROP/TILE) | — |
|
|
95
|
-
| `fills[].GRADIENT_LINEAR` | `background-image: linear-gradient(...)` | No |
|
|
96
|
-
| `fills[].GRADIENT_RADIAL` | `background-image: radial-gradient(...)` | No |
|
|
97
|
-
| `fills[] (2 or more)` | `fills` array (type, color, imageRef, gradient, blendMode, filters) | — |
|
|
98
|
-
| `fills[].blendMode` | `background-blend-mode` | No |
|
|
99
|
-
| `fills[].filters.saturation` | `filter: grayscale(X%)` / `saturate(X%)` | No |
|
|
100
|
-
| `fills[].color` (TEXT) | `color` | No |
|
|
101
|
-
| `strokes[] + strokeAlign=INSIDE` | `border` + `box-sizing: border-box` | Yes (width only) |
|
|
102
|
-
| `strokes[] + strokeAlign=OUTSIDE` | `outline` | Yes (width only) |
|
|
103
|
-
| `individualStrokeWeights` | `border-top/right/bottom/left` individually | Yes (width only) |
|
|
104
|
-
| `strokeDashes` | `border-style: dashed` | No |
|
|
105
|
-
| `effects[].DROP_SHADOW` | `box-shadow` | Yes (px only) |
|
|
106
|
-
| `effects[].INNER_SHADOW` | `box-shadow` (inset) | Yes (px only) |
|
|
107
|
-
| `effects[].LAYER_BLUR` | `filter: blur()` (accumulated) | Yes |
|
|
108
|
-
| `effects[].BACKGROUND_BLUR` | `backdrop-filter: blur()` | Yes |
|
|
109
|
-
| `cornerRadius` | `border-radius` | Yes |
|
|
110
|
-
| `opacity` | `opacity` | No |
|
|
111
|
-
| `rotation` | `transform: rotate(Xdeg)` | No |
|
|
112
|
-
| `blendMode` (node level) | `mix-blend-mode` | No |
|
|
113
|
-
|
|
114
|
-
**Text:**
|
|
115
|
-
|
|
116
|
-
| Figma Property | CSS | vw conversion |
|
|
117
|
-
|-----------|-----|---------|
|
|
118
|
-
| `style.fontFamily` | `font-family` | No |
|
|
119
|
-
| `style.fontSize` | `font-size` | Yes |
|
|
120
|
-
| `style.fontWeight` | `font-weight` | No |
|
|
121
|
-
| `style.lineHeightPx` | `line-height` | No |
|
|
122
|
-
| `style.letterSpacing` | `letter-spacing` | Yes |
|
|
123
|
-
| `style.textAlignHorizontal` | `text-align` | No |
|
|
124
|
-
| `style.textCase` | `text-transform` | No |
|
|
125
|
-
| `style.textTruncation` | `overflow: hidden; text-overflow: ellipsis` | No |
|
|
126
|
-
| `style.paragraphSpacing` | `margin-bottom` | Yes |
|
|
127
|
-
| `characters` | text content | — |
|
|
128
|
-
|
|
129
|
-
---
|
|
130
|
-
|
|
131
|
-
## 2. Image Assets — Node Rendering Based
|
|
132
|
-
|
|
133
|
-
```
|
|
134
|
-
Do NOT download imageRef individually
|
|
135
|
-
→ If a texture fill is shared, the original texture (22.7MB) will be downloaded
|
|
136
|
-
→ Rendering the node produces the final result as applied to that node (364KB)
|
|
137
|
-
|
|
138
|
-
All images must be rendered as nodes via the Figma screenshot API
|
|
139
|
-
```
|
|
140
|
-
|
|
141
|
-
### 2-1. BG Frame Rendering
|
|
142
|
-
|
|
143
|
-
```
|
|
144
|
-
BG frame identification criteria:
|
|
145
|
-
- name contains "BG" or "bg"
|
|
146
|
-
- OR same size as parent (±10%) + 3 or more child images
|
|
147
|
-
|
|
148
|
-
Rendering:
|
|
149
|
-
node "{{VIBE_PATH}}/hooks/scripts/figma-extract.js" screenshot {fileKey} {bg.nodeId} --out=/tmp/{feature}/bg/{section}-bg.webp
|
|
150
|
-
```
|
|
151
|
-
|
|
152
|
-
### 2-2. Content Node Rendering
|
|
153
|
-
|
|
154
|
-
```
|
|
155
|
-
Targets (identified from tree.json):
|
|
156
|
-
- Icons (VECTOR/GROUP size ≤ 64px)
|
|
157
|
-
- Item/reward thumbnails (name contains "item", "reward", "token", "coin")
|
|
158
|
-
- Vector text GROUPs (3 or more VECTORs under parent, each <60px)
|
|
159
|
-
- Design text (any of the following):
|
|
160
|
-
· TEXT node with 2 or more fills (gradient + solid overlap)
|
|
161
|
-
· TEXT node has effects (DROP_SHADOW, stroke)
|
|
162
|
-
· TEXT node fills contain GRADIENT type
|
|
163
|
-
· fontFamily not in project web fonts
|
|
164
|
-
→ Must be included in rendering targets
|
|
165
|
-
- Decorative panels (wooden signs, metal plates, and other textured backgrounds)
|
|
166
|
-
→ Render the same way as BG frames
|
|
167
|
-
|
|
168
|
-
Rendering:
|
|
169
|
-
node "{{VIBE_PATH}}/hooks/scripts/figma-extract.js" screenshot {fileKey} {node.nodeId} --out=/tmp/{feature}/content/{name}.webp
|
|
170
|
-
```
|
|
171
|
-
|
|
172
|
-
### 2-3. imageRef Download (Fallback)
|
|
173
|
-
|
|
174
|
-
```
|
|
175
|
-
Only when node rendering is not possible (API failure, DOCUMENT level):
|
|
176
|
-
File size exceeds 5MB → texture fill warning
|
|
177
|
-
```
|
|
178
|
-
|
|
179
|
-
---
|
|
180
|
-
|
|
181
|
-
## 3. Screenshots — Reference for Phase 6 Validation
|
|
182
|
-
|
|
183
|
-
```
|
|
184
|
-
Not used for code generation.
|
|
185
|
-
|
|
186
|
-
Full: screenshot → /tmp/{feature}/full-screenshot.webp
|
|
187
|
-
Per section: each 1-depth child → /tmp/{feature}/sections/{name}.webp
|
|
188
|
-
```
|
|
189
|
-
|
|
190
|
-
---
|
|
191
|
-
|
|
192
|
-
## 4. Extracted Data Summary
|
|
193
|
-
|
|
194
|
-
```
|
|
195
|
-
/tmp/{feature}/
|
|
196
|
-
├── tree.json ← PRIMARY source
|
|
197
|
-
├── bg/ ← BG frame rendering
|
|
198
|
-
├── content/ ← Content node rendering
|
|
199
|
-
├── full-screenshot.webp ← For validation
|
|
200
|
-
└── sections/ ← Per-section validation
|
|
201
|
-
|
|
202
|
-
Image classification summary:
|
|
203
|
-
| Category | Handling |
|
|
204
|
-
|------|------|
|
|
205
|
-
| BG frames | Frame rendering → bg/ |
|
|
206
|
-
| Design text | Node rendering → content/ |
|
|
207
|
-
| Vector text | GROUP rendering → content/ |
|
|
208
|
-
| Content | Node rendering → content/ |
|
|
209
|
-
| Decorative panels | Frame rendering → content/ |
|
|
210
|
-
| Decorations | Included in BG rendering |
|
|
211
|
-
```
|
|
212
|
-
|
|
213
|
-
---
|
|
214
|
-
|
|
215
|
-
## 5. Extraction Completion Validation (Required Before Entering Phase 3)
|
|
216
|
-
|
|
217
|
-
```
|
|
218
|
-
If any item is missing → re-extract (do NOT proceed to Phase 3)
|
|
219
|
-
|
|
220
|
-
1. tree.json exists + root node children > 0
|
|
221
|
-
2. BG for each section → file exists in bg/
|
|
222
|
-
3. Design text check:
|
|
223
|
-
Traverse tree.json → generate list of TEXT nodes with 2 or more fills or effects
|
|
224
|
-
→ All such nodes must have rendering files in content/
|
|
225
|
-
4. Vector text check:
|
|
226
|
-
GROUP with 3 or more VECTORs → rendering file exists in content/
|
|
227
|
-
5. Per-section validation screenshots → files exist in sections/
|
|
228
|
-
6. File naming convention: all kebab-case (no hash filenames)
|
|
229
|
-
```
|
|
230
|
-
|
|
231
|
-
---
|
|
232
|
-
|
|
233
|
-
## Error Recovery
|
|
234
|
-
|
|
235
|
-
| Failure | Recovery |
|
|
236
|
-
|---------|----------|
|
|
237
|
-
| Figma API 401 (unauthorized) | Prompt user to set FIGMA_ACCESS_TOKEN in environment or ~/.vibe/config.json |
|
|
238
|
-
| Figma API 404 (file not found) | Verify fileKey extracted from URL. Check if file is shared/accessible. |
|
|
239
|
-
| Figma API 429 (rate limit) | Wait 60s, retry with reduced node scope (single page instead of full file) |
|
|
240
|
-
| API timeout on large file | Split request by page — fetch one page at a time via nodeId parameter |
|
|
241
|
-
| Screenshot download failure | Skip screenshot, proceed with tree.json only (mark visual verification as manual) |
|
|
1
|
+
---
|
|
2
|
+
name: vibe-figma-extract
|
|
3
|
+
description: Acquire code generation data via Figma REST API — tree (primary), images, screenshots (for validation)
|
|
4
|
+
triggers: []
|
|
5
|
+
tier: standard
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# vibe.figma.extract — Acquire Code Generation Data
|
|
9
|
+
|
|
10
|
+
Uses the Figma REST API (`src/infra/lib/figma/`) to extract **all data needed for structural code generation**.
|
|
11
|
+
|
|
12
|
+
```
|
|
13
|
+
Extraction priority:
|
|
14
|
+
1st: Node tree + CSS (PRIMARY source for code generation)
|
|
15
|
+
2nd: Image assets (fill images + item node rendering)
|
|
16
|
+
3rd: Screenshots (for Phase 6 visual validation — not used for code generation)
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
---
|
|
20
|
+
|
|
21
|
+
## 1. Node Tree + CSS — Source of Truth for Code Generation
|
|
22
|
+
|
|
23
|
+
```
|
|
24
|
+
Bash:
|
|
25
|
+
node "{{VIBE_PATH}}/hooks/scripts/figma-extract.js" tree {fileKey} {nodeId}
|
|
26
|
+
|
|
27
|
+
Returns (FigmaNode JSON):
|
|
28
|
+
{
|
|
29
|
+
nodeId, name, type, size: { width, height },
|
|
30
|
+
css: { display, flexDirection, gap, ... },
|
|
31
|
+
text: "text content" (TEXT nodes only),
|
|
32
|
+
imageRef: "abc123" (image fill),
|
|
33
|
+
imageScaleMode: "FILL" (FILL/FIT/CROP/TILE),
|
|
34
|
+
layoutSizingH: "HUG" (FIXED/HUG/FILL),
|
|
35
|
+
layoutSizingV: "FILL",
|
|
36
|
+
fills: [...] (only when 2 or more),
|
|
37
|
+
isMask: true (mask nodes only),
|
|
38
|
+
raw: { itemSpacing, paddingTop/..., cornerRadius, strokeWeight, strokeAlign,
|
|
39
|
+
blendMode, opacity, fontSize, lineHeightPx, letterSpacing, fontWeight,
|
|
40
|
+
leadingTrim, textBoxTrim }, ← numeric Figma values for Phase 6 raw-vs-computed reconciliation
|
|
41
|
+
warnings: [ { property, value, severity: "P1"|"P2", reason } ], ← translation-loss only
|
|
42
|
+
children: [...]
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
Root node also carries:
|
|
46
|
+
auditSummary: { total, p1, p2, items: [{ nodeId, name, property, value, severity, reason }] }
|
|
47
|
+
|
|
48
|
+
→ Save to /tmp/{feature}/tree.json
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
### Translation-loss Audit (Figma → CSS Incompatibilities)
|
|
52
|
+
|
|
53
|
+
The extractor flags properties Figma's native renderer supports but CSS cannot reproduce cleanly. These appear in each node's `warnings[]` and are rolled up at the root as `auditSummary`.
|
|
54
|
+
|
|
55
|
+
**P1 (block Phase 3 until resolved or waived):**
|
|
56
|
+
- `strokeAlign` ≠ `CENTER` — CSS border only renders centered strokes; INSIDE/OUTSIDE cannot match without box-sizing trade-offs.
|
|
57
|
+
- `blendMode` ∈ { `LINEAR_BURN`, `LINEAR_DODGE`, `PLUS_DARKER`, `PLUS_LIGHTER` } — no CSS equivalent for `mix-blend-mode` / `background-blend-mode`.
|
|
58
|
+
|
|
59
|
+
**P2 (record + proceed):**
|
|
60
|
+
- `leadingTrim` / `textBoxTrim` ≠ `NONE` — `text-box-trim` has limited browser support (Firefox lacks it).
|
|
61
|
+
- `constraints.horizontal|vertical` ∈ { `SCALE`, `CENTER` } — no direct CSS layout mapping; responsive behavior diverges.
|
|
62
|
+
- `individualStrokeWeights` with `strokeAlign` ≠ `CENTER` — per-side border widths only align cleanly when stroke is centered.
|
|
63
|
+
|
|
64
|
+
**Phase 2 gate rule:** if `auditSummary.p1 > 0`, resolve each item (replace layer in Figma, accept approximation with user sign-off, or mark as known deviation) before Phase 3. P2 items should be logged into the feature notes for Phase 6 reviewer attention.
|
|
65
|
+
|
|
66
|
+
### Figma Property → CSS Direct Mapping Table
|
|
67
|
+
|
|
68
|
+
Properties automatically converted by the tree extraction tool. **These values map directly to SCSS:**
|
|
69
|
+
|
|
70
|
+
**Layout:**
|
|
71
|
+
|
|
72
|
+
| Figma Property | CSS | vw conversion |
|
|
73
|
+
|-----------|-----|---------|
|
|
74
|
+
| `layoutMode=VERTICAL` | `display:flex; flex-direction:column` | No |
|
|
75
|
+
| `layoutMode=HORIZONTAL` | `display:flex; flex-direction:row` | No |
|
|
76
|
+
| `primaryAxisAlignItems` | `justify-content` | No |
|
|
77
|
+
| `counterAxisAlignItems` | `align-items` | No |
|
|
78
|
+
| `itemSpacing` | `gap` | Yes |
|
|
79
|
+
| `layoutGrow=1` | `flex-grow: 1` | No |
|
|
80
|
+
| `padding*` | `padding` | Yes |
|
|
81
|
+
| `absoluteBoundingBox.width/height` | `width/height` | Yes |
|
|
82
|
+
| `layoutPositioning=ABSOLUTE` | `position: absolute` + `top/left` (relative to parent) | Yes |
|
|
83
|
+
| `layoutSizingHorizontal=HUG` | remove width (auto) | — |
|
|
84
|
+
| `layoutSizingHorizontal=FILL` | metadata `layoutSizingH` (converter decides flex:1/100%) | — |
|
|
85
|
+
| `layoutSizingVertical=HUG` | remove height (auto) | — |
|
|
86
|
+
| `layoutSizingVertical=FILL` | metadata `layoutSizingV` (converter decides) | — |
|
|
87
|
+
| `clipsContent` | `overflow: hidden` | No |
|
|
88
|
+
|
|
89
|
+
**Visual:**
|
|
90
|
+
|
|
91
|
+
| Figma Property | CSS | vw conversion |
|
|
92
|
+
|-----------|-----|---------|
|
|
93
|
+
| `fills[].SOLID` | `background-color` | No |
|
|
94
|
+
| `fills[].IMAGE` | `imageRef` + `imageScaleMode` (FILL/FIT/CROP/TILE) | — |
|
|
95
|
+
| `fills[].GRADIENT_LINEAR` | `background-image: linear-gradient(...)` | No |
|
|
96
|
+
| `fills[].GRADIENT_RADIAL` | `background-image: radial-gradient(...)` | No |
|
|
97
|
+
| `fills[] (2 or more)` | `fills` array (type, color, imageRef, gradient, blendMode, filters) | — |
|
|
98
|
+
| `fills[].blendMode` | `background-blend-mode` | No |
|
|
99
|
+
| `fills[].filters.saturation` | `filter: grayscale(X%)` / `saturate(X%)` | No |
|
|
100
|
+
| `fills[].color` (TEXT) | `color` | No |
|
|
101
|
+
| `strokes[] + strokeAlign=INSIDE` | `border` + `box-sizing: border-box` | Yes (width only) |
|
|
102
|
+
| `strokes[] + strokeAlign=OUTSIDE` | `outline` | Yes (width only) |
|
|
103
|
+
| `individualStrokeWeights` | `border-top/right/bottom/left` individually | Yes (width only) |
|
|
104
|
+
| `strokeDashes` | `border-style: dashed` | No |
|
|
105
|
+
| `effects[].DROP_SHADOW` | `box-shadow` | Yes (px only) |
|
|
106
|
+
| `effects[].INNER_SHADOW` | `box-shadow` (inset) | Yes (px only) |
|
|
107
|
+
| `effects[].LAYER_BLUR` | `filter: blur()` (accumulated) | Yes |
|
|
108
|
+
| `effects[].BACKGROUND_BLUR` | `backdrop-filter: blur()` | Yes |
|
|
109
|
+
| `cornerRadius` | `border-radius` | Yes |
|
|
110
|
+
| `opacity` | `opacity` | No |
|
|
111
|
+
| `rotation` | `transform: rotate(Xdeg)` | No |
|
|
112
|
+
| `blendMode` (node level) | `mix-blend-mode` | No |
|
|
113
|
+
|
|
114
|
+
**Text:**
|
|
115
|
+
|
|
116
|
+
| Figma Property | CSS | vw conversion |
|
|
117
|
+
|-----------|-----|---------|
|
|
118
|
+
| `style.fontFamily` | `font-family` | No |
|
|
119
|
+
| `style.fontSize` | `font-size` | Yes |
|
|
120
|
+
| `style.fontWeight` | `font-weight` | No |
|
|
121
|
+
| `style.lineHeightPx` | `line-height` | No |
|
|
122
|
+
| `style.letterSpacing` | `letter-spacing` | Yes |
|
|
123
|
+
| `style.textAlignHorizontal` | `text-align` | No |
|
|
124
|
+
| `style.textCase` | `text-transform` | No |
|
|
125
|
+
| `style.textTruncation` | `overflow: hidden; text-overflow: ellipsis` | No |
|
|
126
|
+
| `style.paragraphSpacing` | `margin-bottom` | Yes |
|
|
127
|
+
| `characters` | text content | — |
|
|
128
|
+
|
|
129
|
+
---
|
|
130
|
+
|
|
131
|
+
## 2. Image Assets — Node Rendering Based
|
|
132
|
+
|
|
133
|
+
```
|
|
134
|
+
Do NOT download imageRef individually
|
|
135
|
+
→ If a texture fill is shared, the original texture (22.7MB) will be downloaded
|
|
136
|
+
→ Rendering the node produces the final result as applied to that node (364KB)
|
|
137
|
+
|
|
138
|
+
All images must be rendered as nodes via the Figma screenshot API
|
|
139
|
+
```
|
|
140
|
+
|
|
141
|
+
### 2-1. BG Frame Rendering
|
|
142
|
+
|
|
143
|
+
```
|
|
144
|
+
BG frame identification criteria:
|
|
145
|
+
- name contains "BG" or "bg"
|
|
146
|
+
- OR same size as parent (±10%) + 3 or more child images
|
|
147
|
+
|
|
148
|
+
Rendering:
|
|
149
|
+
node "{{VIBE_PATH}}/hooks/scripts/figma-extract.js" screenshot {fileKey} {bg.nodeId} --out=/tmp/{feature}/bg/{section}-bg.webp
|
|
150
|
+
```
|
|
151
|
+
|
|
152
|
+
### 2-2. Content Node Rendering
|
|
153
|
+
|
|
154
|
+
```
|
|
155
|
+
Targets (identified from tree.json):
|
|
156
|
+
- Icons (VECTOR/GROUP size ≤ 64px)
|
|
157
|
+
- Item/reward thumbnails (name contains "item", "reward", "token", "coin")
|
|
158
|
+
- Vector text GROUPs (3 or more VECTORs under parent, each <60px)
|
|
159
|
+
- Design text (any of the following):
|
|
160
|
+
· TEXT node with 2 or more fills (gradient + solid overlap)
|
|
161
|
+
· TEXT node has effects (DROP_SHADOW, stroke)
|
|
162
|
+
· TEXT node fills contain GRADIENT type
|
|
163
|
+
· fontFamily not in project web fonts
|
|
164
|
+
→ Must be included in rendering targets
|
|
165
|
+
- Decorative panels (wooden signs, metal plates, and other textured backgrounds)
|
|
166
|
+
→ Render the same way as BG frames
|
|
167
|
+
|
|
168
|
+
Rendering:
|
|
169
|
+
node "{{VIBE_PATH}}/hooks/scripts/figma-extract.js" screenshot {fileKey} {node.nodeId} --out=/tmp/{feature}/content/{name}.webp
|
|
170
|
+
```
|
|
171
|
+
|
|
172
|
+
### 2-3. imageRef Download (Fallback)
|
|
173
|
+
|
|
174
|
+
```
|
|
175
|
+
Only when node rendering is not possible (API failure, DOCUMENT level):
|
|
176
|
+
File size exceeds 5MB → texture fill warning
|
|
177
|
+
```
|
|
178
|
+
|
|
179
|
+
---
|
|
180
|
+
|
|
181
|
+
## 3. Screenshots — Reference for Phase 6 Validation
|
|
182
|
+
|
|
183
|
+
```
|
|
184
|
+
Not used for code generation.
|
|
185
|
+
|
|
186
|
+
Full: screenshot → /tmp/{feature}/full-screenshot.webp
|
|
187
|
+
Per section: each 1-depth child → /tmp/{feature}/sections/{name}.webp
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
---
|
|
191
|
+
|
|
192
|
+
## 4. Extracted Data Summary
|
|
193
|
+
|
|
194
|
+
```
|
|
195
|
+
/tmp/{feature}/
|
|
196
|
+
├── tree.json ← PRIMARY source
|
|
197
|
+
├── bg/ ← BG frame rendering
|
|
198
|
+
├── content/ ← Content node rendering
|
|
199
|
+
├── full-screenshot.webp ← For validation
|
|
200
|
+
└── sections/ ← Per-section validation
|
|
201
|
+
|
|
202
|
+
Image classification summary:
|
|
203
|
+
| Category | Handling |
|
|
204
|
+
|------|------|
|
|
205
|
+
| BG frames | Frame rendering → bg/ |
|
|
206
|
+
| Design text | Node rendering → content/ |
|
|
207
|
+
| Vector text | GROUP rendering → content/ |
|
|
208
|
+
| Content | Node rendering → content/ |
|
|
209
|
+
| Decorative panels | Frame rendering → content/ |
|
|
210
|
+
| Decorations | Included in BG rendering |
|
|
211
|
+
```
|
|
212
|
+
|
|
213
|
+
---
|
|
214
|
+
|
|
215
|
+
## 5. Extraction Completion Validation (Required Before Entering Phase 3)
|
|
216
|
+
|
|
217
|
+
```
|
|
218
|
+
If any item is missing → re-extract (do NOT proceed to Phase 3)
|
|
219
|
+
|
|
220
|
+
1. tree.json exists + root node children > 0
|
|
221
|
+
2. BG for each section → file exists in bg/
|
|
222
|
+
3. Design text check:
|
|
223
|
+
Traverse tree.json → generate list of TEXT nodes with 2 or more fills or effects
|
|
224
|
+
→ All such nodes must have rendering files in content/
|
|
225
|
+
4. Vector text check:
|
|
226
|
+
GROUP with 3 or more VECTORs → rendering file exists in content/
|
|
227
|
+
5. Per-section validation screenshots → files exist in sections/
|
|
228
|
+
6. File naming convention: all kebab-case (no hash filenames)
|
|
229
|
+
```
|
|
230
|
+
|
|
231
|
+
---
|
|
232
|
+
|
|
233
|
+
## Error Recovery
|
|
234
|
+
|
|
235
|
+
| Failure | Recovery |
|
|
236
|
+
|---------|----------|
|
|
237
|
+
| Figma API 401 (unauthorized) | Prompt user to set FIGMA_ACCESS_TOKEN in environment or ~/.vibe/config.json |
|
|
238
|
+
| Figma API 404 (file not found) | Verify fileKey extracted from URL. Check if file is shared/accessible. |
|
|
239
|
+
| Figma API 429 (rate limit) | Wait 60s, retry with reduced node scope (single page instead of full file) |
|
|
240
|
+
| API timeout on large file | Split request by page — fetch one page at a time via nodeId parameter |
|
|
241
|
+
| Screenshot download failure | Skip screenshot, proceed with tree.json only (mark visual verification as manual) |
|