@hiai-gg/hiai-opencode 0.2.1 → 0.2.2
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 +4 -0
- package/AGENTS.md +34 -38
- package/ARCHITECTURE.md +4 -3
- package/LICENSE.md +14 -0
- package/README.md +52 -21
- package/config/hiai-opencode.schema.json +11 -13
- package/dist/agents/{bob.d.ts → bob/claude.d.ts} +6 -2
- package/dist/agents/bob/core.d.ts +6 -0
- package/dist/agents/bob/gpt.d.ts +11 -0
- package/dist/agents/bob/index.d.ts +3 -0
- package/dist/agents/coder/core.d.ts +4 -0
- package/dist/agents/coder/gpt.d.ts +1 -4
- package/dist/agents/coder/index.d.ts +1 -0
- package/dist/agents/manager/agent.d.ts +1 -1
- package/dist/agents/manager/default-prompt-sections.d.ts +3 -3
- package/dist/agents/manager/guard-integration.d.ts +1 -0
- package/dist/agents/prompt-library/index.d.ts +0 -1
- package/dist/agents/prompt-library/shared-execution.d.ts +9 -0
- package/dist/agents/strategist/behavioral-summary.d.ts +1 -1
- package/dist/agents/strategist/identity-constraints.d.ts +1 -1
- package/dist/agents/strategist/plan-generation.d.ts +1 -1
- package/dist/agents/types.d.ts +2 -1
- package/dist/config/defaults.d.ts +1 -0
- package/dist/config/platform-schema.d.ts +26 -26
- package/dist/config/schema/agent-names.d.ts +6 -6
- package/dist/config/schema/agent-overrides.d.ts +0 -128
- package/dist/config/schema/hiai-opencode-config.d.ts +0 -128
- package/dist/config/types.d.ts +2 -2
- package/dist/features/background-agent/manager-notifier.d.ts +46 -0
- package/dist/features/background-agent/manager-types.d.ts +40 -0
- package/dist/features/background-agent/manager.d.ts +3 -19
- package/dist/features/background-agent/polling-manager.d.ts +51 -0
- package/dist/features/boulder-state/storage.d.ts +1 -0
- package/dist/features/builtin-commands/templates/loop.d.ts +2 -0
- package/dist/features/builtin-commands/templates/start-work.d.ts +1 -1
- package/dist/features/builtin-skills/skills/interview-me.d.ts +2 -0
- package/dist/features/builtin-skills/skills/planning-and-task-breakdown.d.ts +2 -0
- package/dist/hooks/reasoning-content-cache/hook.d.ts +11 -0
- package/dist/hooks/reasoning-content-cache/index.d.ts +1 -0
- package/dist/hooks/session-recovery/checkpoint.d.ts +48 -0
- package/dist/hooks/session-recovery/enhanced-hook.d.ts +30 -0
- package/dist/hooks/session-recovery/state-backup.d.ts +76 -0
- package/dist/hooks/shared/compaction-in-progress.d.ts +4 -0
- package/dist/hooks/start-work/git-operations.d.ts +47 -0
- package/dist/hooks/token-budget.d.ts +30 -0
- package/dist/index.js +1185 -1078
- package/dist/mcp/rate-limiter.d.ts +68 -0
- package/dist/plugin/chat-message.d.ts +8 -0
- package/dist/plugin/command-execute-before.d.ts +1 -1
- package/dist/plugin/event-handlers/message-updated.d.ts +2 -0
- package/dist/plugin/event-handlers/session-error.d.ts +2 -0
- package/dist/plugin/event-handlers/session-status.d.ts +2 -0
- package/dist/plugin/event-handlers/types.d.ts +62 -0
- package/dist/plugin/event-handlers/utils.d.ts +11 -0
- package/dist/plugin/event.d.ts +1 -1
- package/dist/shared/data-path.d.ts +1 -1
- package/dist/shared/errors.d.ts +70 -0
- package/dist/shared/extract-session-id.d.ts +8 -0
- package/dist/shared/git-worktree/get-git-state-summary.d.ts +14 -0
- package/dist/shared/index.d.ts +67 -68
- package/dist/shared/internal-initiator-marker.d.ts +1 -1
- package/dist/shared/logger.d.ts +5 -1
- package/dist/shared/reasoning-content-cache.d.ts +68 -0
- package/dist/shared/safe-create-hook.d.ts +4 -4
- package/dist/tools/call-hiai-agent/constants.d.ts +2 -2
- package/dist/tools/delegate-task/sub-agent.d.ts +1 -1
- package/dist/tools/look-at/constants.d.ts +1 -1
- package/docs/architecture/bob-manager-architecture.md +244 -0
- package/docs/hiai-opencode/adr/ADR-001-agent-identity-section-injection.md +66 -0
- package/docs/hiai-opencode/adr/ADR-002-anti-loop-guard-priority.md +63 -0
- package/docs/hiai-opencode/adr/ADR-003-compaction-mechanism.md +71 -0
- package/docs/hiai-opencode/adr/ADR-004-session-recovery.md +76 -0
- package/docs/hiai-opencode/api.md +305 -0
- package/docs/hiai-opencode/hooks-architecture.md +225 -0
- package/docs/hiai-opencode/migration.md +209 -0
- package/docs/skill-discovery.md +288 -0
- package/package.json +1 -1
- package/skills/agent-browser/SKILL.md +193 -0
- package/skills/apple-hig/SKILL.md +43 -0
- package/skills/article-magazine/SKILL.md +46 -0
- package/skills/article-magazine/example.html +81 -0
- package/skills/article-magazine/example.md +38 -0
- package/skills/canvas-design/SKILL.md +45 -0
- package/skills/design-templates/audio-jingle/SKILL.md +132 -0
- package/skills/design-templates/audio-jingle/example.html +128 -0
- package/skills/design-templates/blog-post/SKILL.md +80 -0
- package/skills/design-templates/blog-post/example.html +80 -0
- package/skills/design-templates/clinical-case-report/SKILL.md +209 -0
- package/skills/design-templates/clinical-case-report/example.html +698 -0
- package/skills/design-templates/clinical-case-report/examples/example-stemi.html +698 -0
- package/skills/design-templates/clinical-case-report/references/case-formats.md +94 -0
- package/skills/design-templates/clinical-case-report/references/checklist.md +41 -0
- package/skills/design-templates/critique/SKILL.md +258 -0
- package/skills/design-templates/critique/example.html +671 -0
- package/skills/design-templates/dashboard/SKILL.md +76 -0
- package/skills/design-templates/dashboard/example.html +118 -0
- package/skills/design-templates/dating-web/SKILL.md +92 -0
- package/skills/design-templates/dating-web/example.html +265 -0
- package/skills/design-templates/dcf-valuation/SKILL.md +140 -0
- package/skills/design-templates/dcf-valuation/references/sector-wacc.md +42 -0
- package/skills/design-templates/digital-eguide/SKILL.md +94 -0
- package/skills/design-templates/digital-eguide/example.html +204 -0
- package/skills/design-templates/docs-page/SKILL.md +80 -0
- package/skills/design-templates/docs-page/example.html +122 -0
- package/skills/design-templates/email-marketing/SKILL.md +84 -0
- package/skills/design-templates/email-marketing/example.html +159 -0
- package/skills/design-templates/eng-runbook/SKILL.md +51 -0
- package/skills/design-templates/eng-runbook/example.html +250 -0
- package/skills/design-templates/finance-report/SKILL.md +61 -0
- package/skills/design-templates/finance-report/example.html +242 -0
- package/skills/design-templates/flowai-live-dashboard-template/SKILL.md +87 -0
- package/skills/design-templates/flowai-live-dashboard-template/assets/template.html +387 -0
- package/skills/design-templates/flowai-live-dashboard-template/example.html +13 -0
- package/skills/design-templates/flowai-live-dashboard-template/references/checklist.md +35 -0
- package/skills/design-templates/gamified-app/SKILL.md +108 -0
- package/skills/design-templates/gamified-app/example.html +292 -0
- package/skills/design-templates/github-dashboard/SKILL.md +130 -0
- package/skills/design-templates/github-dashboard/example.html +473 -0
- package/skills/design-templates/github-dashboard/references/README.md +10 -0
- package/skills/design-templates/github-dashboard/references/artifact-example.json +15 -0
- package/skills/design-templates/github-dashboard/references/example-data.json +138 -0
- package/skills/design-templates/github-dashboard/references/provenance-example.json +92 -0
- package/skills/design-templates/github-dashboard/references/template.html +473 -0
- package/skills/design-templates/guizang-ppt/LICENSE +21 -0
- package/skills/design-templates/guizang-ppt/README.en.md +119 -0
- package/skills/design-templates/guizang-ppt/README.md +120 -0
- package/skills/design-templates/guizang-ppt/README.pt-BR.md +121 -0
- package/skills/design-templates/guizang-ppt/SKILL.md +313 -0
- package/skills/design-templates/guizang-ppt/assets/example-slides.html +318 -0
- package/skills/design-templates/guizang-ppt/assets/template.html +647 -0
- package/skills/design-templates/guizang-ppt/references/checklist.md +265 -0
- package/skills/design-templates/guizang-ppt/references/components.md +363 -0
- package/skills/design-templates/guizang-ppt/references/layouts.md +630 -0
- package/skills/design-templates/guizang-ppt/references/styles.md +195 -0
- package/skills/design-templates/guizang-ppt/references/themes.md +122 -0
- package/skills/design-templates/hr-onboarding/SKILL.md +52 -0
- package/skills/design-templates/hr-onboarding/example.html +219 -0
- package/skills/design-templates/html-ppt/.clawscan-allow +12 -0
- package/skills/design-templates/html-ppt/LICENSE +21 -0
- package/skills/design-templates/html-ppt/README.md +234 -0
- package/skills/design-templates/html-ppt/README.pt-BR.md +239 -0
- package/skills/design-templates/html-ppt/README.zh-CN.md +238 -0
- package/skills/design-templates/html-ppt/SKILL.md +250 -0
- package/skills/design-templates/html-ppt/assets/animations/animations.css +138 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/_util.js +63 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/chain-react.js +41 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/confetti-cannon.js +49 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/constellation.js +44 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/counter-explosion.js +58 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/data-stream.js +45 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/firework.js +51 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/galaxy-swirl.js +33 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/gradient-blob.js +39 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/knowledge-graph.js +69 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/letter-explode.js +50 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/magnetic-field.js +40 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/matrix-rain.js +33 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/neural-net.js +75 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/orbit-ring.js +38 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/particle-burst.js +42 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/shockwave.js +39 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/sparkle-trail.js +62 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/starfield.js +30 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/typewriter-multi.js +51 -0
- package/skills/design-templates/html-ppt/assets/animations/fx/word-cascade.js +47 -0
- package/skills/design-templates/html-ppt/assets/animations/fx-runtime.js +99 -0
- package/skills/design-templates/html-ppt/assets/base.css +150 -0
- package/skills/design-templates/html-ppt/assets/fonts.css +9 -0
- package/skills/design-templates/html-ppt/assets/runtime.js +960 -0
- package/skills/design-templates/html-ppt/assets/themes/academic-paper.css +23 -0
- package/skills/design-templates/html-ppt/assets/themes/arctic-cool.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/aurora.css +20 -0
- package/skills/design-templates/html-ppt/assets/themes/bauhaus.css +16 -0
- package/skills/design-templates/html-ppt/assets/themes/blueprint.css +19 -0
- package/skills/design-templates/html-ppt/assets/themes/catppuccin-latte.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/catppuccin-mocha.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/corporate-clean.css +19 -0
- package/skills/design-templates/html-ppt/assets/themes/cyberpunk-neon.css +23 -0
- package/skills/design-templates/html-ppt/assets/themes/dracula.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/editorial-serif.css +18 -0
- package/skills/design-templates/html-ppt/assets/themes/engineering-whiteprint.css +26 -0
- package/skills/design-templates/html-ppt/assets/themes/glassmorphism.css +21 -0
- package/skills/design-templates/html-ppt/assets/themes/gruvbox-dark.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/japanese-minimal.css +21 -0
- package/skills/design-templates/html-ppt/assets/themes/magazine-bold.css +21 -0
- package/skills/design-templates/html-ppt/assets/themes/memphis-pop.css +20 -0
- package/skills/design-templates/html-ppt/assets/themes/midcentury.css +19 -0
- package/skills/design-templates/html-ppt/assets/themes/minimal-white.css +16 -0
- package/skills/design-templates/html-ppt/assets/themes/neo-brutalism.css +17 -0
- package/skills/design-templates/html-ppt/assets/themes/news-broadcast.css +20 -0
- package/skills/design-templates/html-ppt/assets/themes/nord.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/pitch-deck-vc.css +21 -0
- package/skills/design-templates/html-ppt/assets/themes/rainbow-gradient.css +16 -0
- package/skills/design-templates/html-ppt/assets/themes/retro-tv.css +22 -0
- package/skills/design-templates/html-ppt/assets/themes/rose-pine.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/sharp-mono.css +17 -0
- package/skills/design-templates/html-ppt/assets/themes/soft-pastel.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/solarized-light.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/sunset-warm.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/swiss-grid.css +17 -0
- package/skills/design-templates/html-ppt/assets/themes/terminal-green.css +18 -0
- package/skills/design-templates/html-ppt/assets/themes/tokyo-night.css +14 -0
- package/skills/design-templates/html-ppt/assets/themes/vaporwave.css +21 -0
- package/skills/design-templates/html-ppt/assets/themes/xiaohongshu-white.css +16 -0
- package/skills/design-templates/html-ppt/assets/themes/y2k-chrome.css +20 -0
- package/skills/design-templates/html-ppt/docs/readme/_theme-cell.html +56 -0
- package/skills/design-templates/html-ppt/docs/readme/animations.png +0 -0
- package/skills/design-templates/html-ppt/docs/readme/hero.gif +0 -0
- package/skills/design-templates/html-ppt/docs/readme/layouts-live.gif +0 -0
- package/skills/design-templates/html-ppt/docs/readme/layouts.png +0 -0
- package/skills/design-templates/html-ppt/docs/readme/montage-animations.html +61 -0
- package/skills/design-templates/html-ppt/docs/readme/montage-layouts.html +72 -0
- package/skills/design-templates/html-ppt/docs/readme/montage-templates.html +72 -0
- package/skills/design-templates/html-ppt/docs/readme/montage-themes.html +38 -0
- package/skills/design-templates/html-ppt/docs/readme/presenter-mode.png +0 -0
- package/skills/design-templates/html-ppt/docs/readme/templates.png +0 -0
- package/skills/design-templates/html-ppt/docs/readme/themes.png +0 -0
- package/skills/design-templates/html-ppt/examples/demo-deck/index.html +161 -0
- package/skills/design-templates/html-ppt/references/animations.md +147 -0
- package/skills/design-templates/html-ppt/references/authoring-guide.md +141 -0
- package/skills/design-templates/html-ppt/references/full-decks.md +98 -0
- package/skills/design-templates/html-ppt/references/layouts.md +103 -0
- package/skills/design-templates/html-ppt/references/presenter-mode.md +240 -0
- package/skills/design-templates/html-ppt/references/themes.md +107 -0
- package/skills/design-templates/html-ppt/scripts/new-deck.sh +46 -0
- package/skills/design-templates/html-ppt/scripts/render.sh +71 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_01.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_02.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_03.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_04.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_05.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_06.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_07.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_08.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_09.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_10.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_11.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_12.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_13.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_14.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_15.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_16.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_17.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_18.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_19.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_20.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_01.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_02.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_03.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_04.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_05.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_06.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_07.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_08.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_09.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_10.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_11.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_12.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_13.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_14.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_15.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_16.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_17.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_18.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_19.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_20.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_21.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_22.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_23.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_24.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_25.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_26.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_27.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_28.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_29.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_30.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_31.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_32.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_33.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_34.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_35.png +0 -0
- package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_36.png +0 -0
- package/skills/design-templates/html-ppt/templates/animation-showcase.html +172 -0
- package/skills/design-templates/html-ppt/templates/deck.html +69 -0
- package/skills/design-templates/html-ppt/templates/full-decks/course-module/README.md +8 -0
- package/skills/design-templates/html-ppt/templates/full-decks/course-module/index.html +189 -0
- package/skills/design-templates/html-ppt/templates/full-decks/course-module/style.css +46 -0
- package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/index.html +138 -0
- package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/style.css +60 -0
- package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/index.html +180 -0
- package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/style.css +54 -0
- package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/index.html +199 -0
- package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/style.css +55 -0
- package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/index.html +190 -0
- package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/style.css +49 -0
- package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/index.html +144 -0
- package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/style.css +59 -0
- package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/README.md +9 -0
- package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/index.html +148 -0
- package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/style.css +40 -0
- package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/README.md +102 -0
- package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/index.html +187 -0
- package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/style.css +216 -0
- package/skills/design-templates/html-ppt/templates/full-decks/product-launch/README.md +8 -0
- package/skills/design-templates/html-ppt/templates/full-decks/product-launch/index.html +121 -0
- package/skills/design-templates/html-ppt/templates/full-decks/product-launch/style.css +39 -0
- package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/README.md +8 -0
- package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/index.html +156 -0
- package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/style.css +49 -0
- package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/index.html +183 -0
- package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/style.css +62 -0
- package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/README.md +8 -0
- package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/index.html +127 -0
- package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/style.css +55 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/index.html +147 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/style.css +66 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/README.md +9 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/index.html +133 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/style.css +47 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/README.md +11 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/index.html +187 -0
- package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/style.css +63 -0
- package/skills/design-templates/html-ppt/templates/full-decks-index.html +82 -0
- package/skills/design-templates/html-ppt/templates/layout-showcase.html +47 -0
- package/skills/design-templates/html-ppt/templates/single-page/arch-diagram.html +46 -0
- package/skills/design-templates/html-ppt/templates/single-page/big-quote.html +18 -0
- package/skills/design-templates/html-ppt/templates/single-page/bullets.html +19 -0
- package/skills/design-templates/html-ppt/templates/single-page/chart-bar.html +30 -0
- package/skills/design-templates/html-ppt/templates/single-page/chart-line.html +35 -0
- package/skills/design-templates/html-ppt/templates/single-page/chart-pie.html +36 -0
- package/skills/design-templates/html-ppt/templates/single-page/chart-radar.html +31 -0
- package/skills/design-templates/html-ppt/templates/single-page/code.html +33 -0
- package/skills/design-templates/html-ppt/templates/single-page/comparison.html +47 -0
- package/skills/design-templates/html-ppt/templates/single-page/cover.html +32 -0
- package/skills/design-templates/html-ppt/templates/single-page/cta.html +27 -0
- package/skills/design-templates/html-ppt/templates/single-page/diff.html +35 -0
- package/skills/design-templates/html-ppt/templates/single-page/flow-diagram.html +33 -0
- package/skills/design-templates/html-ppt/templates/single-page/gantt.html +29 -0
- package/skills/design-templates/html-ppt/templates/single-page/image-grid.html +34 -0
- package/skills/design-templates/html-ppt/templates/single-page/image-hero.html +33 -0
- package/skills/design-templates/html-ppt/templates/single-page/kpi-grid.html +19 -0
- package/skills/design-templates/html-ppt/templates/single-page/mindmap.html +38 -0
- package/skills/design-templates/html-ppt/templates/single-page/process-steps.html +27 -0
- package/skills/design-templates/html-ppt/templates/single-page/pros-cons.html +31 -0
- package/skills/design-templates/html-ppt/templates/single-page/roadmap.html +46 -0
- package/skills/design-templates/html-ppt/templates/single-page/section-divider.html +17 -0
- package/skills/design-templates/html-ppt/templates/single-page/stat-highlight.html +17 -0
- package/skills/design-templates/html-ppt/templates/single-page/table.html +33 -0
- package/skills/design-templates/html-ppt/templates/single-page/terminal.html +35 -0
- package/skills/design-templates/html-ppt/templates/single-page/thanks.html +21 -0
- package/skills/design-templates/html-ppt/templates/single-page/three-column.html +18 -0
- package/skills/design-templates/html-ppt/templates/single-page/timeline.html +32 -0
- package/skills/design-templates/html-ppt/templates/single-page/toc.html +26 -0
- package/skills/design-templates/html-ppt/templates/single-page/todo-checklist.html +33 -0
- package/skills/design-templates/html-ppt/templates/single-page/two-column.html +39 -0
- package/skills/design-templates/html-ppt/templates/theme-showcase.html +151 -0
- package/skills/design-templates/html-ppt-course-module/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-course-module/example.html +542 -0
- package/skills/design-templates/html-ppt-dir-key-nav-minimal/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-dir-key-nav-minimal/example.html +366 -0
- package/skills/design-templates/html-ppt-graphify-dark-graph/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-graphify-dark-graph/example.html +402 -0
- package/skills/design-templates/html-ppt-hermes-cyber-terminal/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-hermes-cyber-terminal/example.html +422 -0
- package/skills/design-templates/html-ppt-knowledge-arch-blueprint/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-knowledge-arch-blueprint/example.html +407 -0
- package/skills/design-templates/html-ppt-obsidian-claude-gradient/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-obsidian-claude-gradient/example.html +371 -0
- package/skills/design-templates/html-ppt-pitch-deck/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-pitch-deck/example.html +495 -0
- package/skills/design-templates/html-ppt-presenter-mode-reveal/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-presenter-mode-reveal/example.html +725 -0
- package/skills/design-templates/html-ppt-product-launch/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-product-launch/example.html +467 -0
- package/skills/design-templates/html-ppt-taste-brutalist/SKILL.md +70 -0
- package/skills/design-templates/html-ppt-taste-brutalist/example.html +774 -0
- package/skills/design-templates/html-ppt-taste-editorial/SKILL.md +62 -0
- package/skills/design-templates/html-ppt-taste-editorial/example.html +689 -0
- package/skills/design-templates/html-ppt-tech-sharing/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-tech-sharing/example.html +512 -0
- package/skills/design-templates/html-ppt-testing-safety-alert/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-testing-safety-alert/example.html +413 -0
- package/skills/design-templates/html-ppt-weekly-report/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-weekly-report/example.html +489 -0
- package/skills/design-templates/html-ppt-xhs-pastel-card/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-xhs-pastel-card/example.html +381 -0
- package/skills/design-templates/html-ppt-xhs-post/SKILL.md +78 -0
- package/skills/design-templates/html-ppt-xhs-post/example.html +487 -0
- package/skills/design-templates/html-ppt-xhs-white-editorial/SKILL.md +77 -0
- package/skills/design-templates/html-ppt-xhs-white-editorial/example.html +418 -0
- package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/example.html +1640 -0
- package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/template.json +48 -0
- package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/example.html +833 -0
- package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/template.json +49 -0
- package/skills/design-templates/html-ppt-zhangzara-block-frame/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-block-frame/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-block-frame/example.html +1453 -0
- package/skills/design-templates/html-ppt-zhangzara-block-frame/template.json +47 -0
- package/skills/design-templates/html-ppt-zhangzara-blue-professional/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-blue-professional/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-blue-professional/example.html +1423 -0
- package/skills/design-templates/html-ppt-zhangzara-blue-professional/template.json +44 -0
- package/skills/design-templates/html-ppt-zhangzara-bold-poster/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-bold-poster/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-bold-poster/example.html +876 -0
- package/skills/design-templates/html-ppt-zhangzara-bold-poster/template.json +45 -0
- package/skills/design-templates/html-ppt-zhangzara-broadside/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-broadside/SKILL.md +92 -0
- package/skills/design-templates/html-ppt-zhangzara-broadside/example.html +2144 -0
- package/skills/design-templates/html-ppt-zhangzara-broadside/template.json +49 -0
- package/skills/design-templates/html-ppt-zhangzara-capsule/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-capsule/SKILL.md +92 -0
- package/skills/design-templates/html-ppt-zhangzara-capsule/example.html +1413 -0
- package/skills/design-templates/html-ppt-zhangzara-capsule/template.json +51 -0
- package/skills/design-templates/html-ppt-zhangzara-cartesian/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-cartesian/SKILL.md +92 -0
- package/skills/design-templates/html-ppt-zhangzara-cartesian/example.html +1136 -0
- package/skills/design-templates/html-ppt-zhangzara-cartesian/template.json +47 -0
- package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/example.html +1205 -0
- package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/template.json +49 -0
- package/skills/design-templates/html-ppt-zhangzara-coral/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-coral/SKILL.md +92 -0
- package/skills/design-templates/html-ppt-zhangzara-coral/example.html +1487 -0
- package/skills/design-templates/html-ppt-zhangzara-coral/template.json +45 -0
- package/skills/design-templates/html-ppt-zhangzara-creative-mode/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-creative-mode/SKILL.md +99 -0
- package/skills/design-templates/html-ppt-zhangzara-creative-mode/assets/deck-stage.js +619 -0
- package/skills/design-templates/html-ppt-zhangzara-creative-mode/example.html +636 -0
- package/skills/design-templates/html-ppt-zhangzara-creative-mode/template.json +47 -0
- package/skills/design-templates/html-ppt-zhangzara-daisy-days/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-daisy-days/SKILL.md +93 -0
- package/skills/design-templates/html-ppt-zhangzara-daisy-days/example.html +469 -0
- package/skills/design-templates/html-ppt-zhangzara-daisy-days/template.json +54 -0
- package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/SKILL.md +98 -0
- package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/assets/deck-stage.js +619 -0
- package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/example.html +737 -0
- package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/template.json +44 -0
- package/skills/design-templates/html-ppt-zhangzara-grove/LICENSE +21 -0
- package/skills/design-templates/html-ppt-zhangzara-grove/SKILL.md +92 -0
- package/skills/design-templates/html-ppt-zhangzara-grove/example.html +1676 -0
- package/skills/design-templates/html-ppt-zhangzara-grove/template.json +51 -0
- package/skills/figma-code-connect-components/SKILL.md +42 -0
- package/skills/figma-create-design-system-rules/SKILL.md +42 -0
- package/skills/figma-create-new-file/SKILL.md +41 -0
- package/skills/figma-generate-design/SKILL.md +42 -0
- package/skills/figma-generate-library/SKILL.md +42 -0
- package/skills/figma-implement-design/SKILL.md +42 -0
- package/skills/figma-use/SKILL.md +42 -0
- package/skills/full-page-screenshot/SKILL.md +42 -0
- package/skills/interview-me/SKILL.md +64 -0
- package/skills/planning-and-task-breakdown/SKILL.md +52 -0
- package/skills/sora/SKILL.md +43 -0
- package/skills/theme-factory/SKILL.md +43 -0
- package/skills/web-design-guidelines/SKILL.md +42 -0
- package/dist/agents/prompt-library/orchestration.d.ts +0 -4
- package/skills/brainstorming/SKILL.md +0 -164
- package/skills/brainstorming/scripts/frame-template.html +0 -214
- package/skills/brainstorming/scripts/helper.js +0 -88
- package/skills/brainstorming/scripts/server.cjs +0 -354
- package/skills/brainstorming/scripts/start-server.sh +0 -148
- package/skills/brainstorming/scripts/stop-server.sh +0 -56
- package/skills/brainstorming/spec-document-reviewer-prompt.md +0 -49
- package/skills/brainstorming/visual-companion.md +0 -287
|
@@ -0,0 +1,630 @@
|
|
|
1
|
+
# 页面布局库(Layouts)
|
|
2
|
+
|
|
3
|
+
本文档收录 10 种最常用的页面布局骨架。每种都是一个完整可粘贴的 `<section class="slide ...">...</section>` 代码块,直接替换文案/图片即可使用。
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## ⚠️ 生成前必读(Pre-flight)
|
|
8
|
+
|
|
9
|
+
### A. 类名必须来自 template.html
|
|
10
|
+
|
|
11
|
+
layouts.md 使用的所有类(`h-hero` / `h-xl` / `h-sub` / `h-md` / `lead` / `meta-row` / `stat-card` / `stat-label` / `stat-nb` / `stat-unit` / `stat-note` / `pipeline-section` / `pipeline-label` / `pipeline` / `step` / `step-nb` / `step-title` / `step-desc` / `grid-2-7-5` / `grid-2-6-6` / `grid-2-8-4` / `grid-3-3` / `grid-6` / `grid-3` / `grid-4` / `frame` / `frame-img` / `img-cap` / `callout` / `callout-src` / `kicker`)都在 `assets/template.html` 的 `<style>` 块里预定义。
|
|
12
|
+
|
|
13
|
+
**不要发明新类名**。如果必须自定义,用 `style="..."` inline 写。生成前若不确定某个类是否存在,grep template.html 确认。
|
|
14
|
+
|
|
15
|
+
### B. 图片比例规范(非常重要)
|
|
16
|
+
|
|
17
|
+
**永远用标准比例**,不要用原图 `aspect-ratio: 2592/1798` 这种奇葩比例:
|
|
18
|
+
|
|
19
|
+
| 场景 | 推荐比例 | 写法 |
|
|
20
|
+
|------|---------|------|
|
|
21
|
+
| 左文右图 主图 | 16:10 或 4:3 | `aspect-ratio:16/10; max-height:54vh` |
|
|
22
|
+
| 图片网格(多图对比) | 统一 | **固定 `height:26vh`,不用 aspect-ratio** |
|
|
23
|
+
| 左小图 + 右文字 | 1:1 或 3:2 | `aspect-ratio:1/1; max-width:40vw` |
|
|
24
|
+
| 全屏主视觉 | 16:9 | `aspect-ratio:16/9; max-height:64vh` |
|
|
25
|
+
| 图文混排小插图 | 3:2 | `aspect-ratio:3/2; max-width:30vw` |
|
|
26
|
+
|
|
27
|
+
图片必须包在 `<figure class="frame-img">` 里,里面的 `<img>` 会自动 `object-fit:cover + object-position:top center`,只裁底部,不裁顶/左/右。
|
|
28
|
+
|
|
29
|
+
### C. 图片定位准则(避免图片堆到页面最底部、被浏览器工具栏遮挡)
|
|
30
|
+
|
|
31
|
+
**错误做法**(已踩坑,不要再犯):
|
|
32
|
+
- 在非 grid 容器里用 `align-self:end`:`align-self` 在 flex/grid 之外完全无效,图片会掉到文档流末尾堆底
|
|
33
|
+
- 用 `position:absolute + bottom:0` 把图"固定"到底:会被底部 `.foot` 和 `#nav` 圆点遮挡
|
|
34
|
+
- 单张图片只写 `height:N vh` 不限 `max-height`:在低分屏会撑出视口
|
|
35
|
+
|
|
36
|
+
**正确做法**:
|
|
37
|
+
- 图文混排**必须用 `.frame.grid-2-7-5`**(或 `.grid-2-6-6` / `.grid-2-8-4`)的 grid 结构
|
|
38
|
+
- grid 容器默认 `align-items:start`(已在 template 中设置),图片自然贴到 cell 顶端
|
|
39
|
+
- 如果需要"图片底对齐左列 callout":**左列用 flex column + `justify-content:space-between`**(让 callout 自己贴左列底),**右列 figure 直接保持 align-items:start 即可**,不要加 `align-self:end`
|
|
40
|
+
- 所有 grid 父容器建议加 inline `style="padding-top:6vh"`,给标题区留呼吸空间
|
|
41
|
+
|
|
42
|
+
### D. 主题色与主题节奏
|
|
43
|
+
|
|
44
|
+
- 主题色从 `references/themes.md` 的 5 套预设里选一套,不允许自定义 hex 值
|
|
45
|
+
- 主题节奏(每页用 light / dark / hero light / hero dark 哪一个)在下文"主题节奏规划"一节有硬规则,生成前必读
|
|
46
|
+
- 两件事都要在挑布局之前决定,避免返工
|
|
47
|
+
|
|
48
|
+
---
|
|
49
|
+
|
|
50
|
+
## 0. 基础结构(所有 slide 都一样)
|
|
51
|
+
|
|
52
|
+
```html
|
|
53
|
+
<section class="slide [light|dark|hero light|hero dark]">
|
|
54
|
+
<div class="chrome">
|
|
55
|
+
<div>上下文标签 · 子标签</div>
|
|
56
|
+
<div>ACT · 页号 / 总页数</div>
|
|
57
|
+
</div>
|
|
58
|
+
<!-- 主内容 -->
|
|
59
|
+
<div class="foot">
|
|
60
|
+
<div>页码说明 · Page Description</div>
|
|
61
|
+
<div>— · —</div>
|
|
62
|
+
</div>
|
|
63
|
+
</section>
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
- 非 hero 页建议加 `light` 或 `dark` 主题;hero 页加 `hero light` 或 `hero dark`(参与 WebGL 主题插值)
|
|
67
|
+
- `chrome` 和 `foot` 是可选但推荐保留的上下左右四角元数据
|
|
68
|
+
- **hero 页用于章节封面/开场/收束/转场**,非 hero 页用于正文
|
|
69
|
+
|
|
70
|
+
### ⚠️ chrome 和 kicker 不要写同一句话
|
|
71
|
+
|
|
72
|
+
这是最常见的内容重复问题。两者在语义上完全不同的维度:
|
|
73
|
+
|
|
74
|
+
| 位置 | 角色 | 内容性质 | 例子 |
|
|
75
|
+
|------|------|---------|------|
|
|
76
|
+
| `.chrome` 左上 | **杂志页眉 / 导航元数据** | 稳定的"栏目名"或"章节分类",跨多页可以相同 | "Act II · Workflow" / "Data · Result" / "lukew.com · 2026.04" |
|
|
77
|
+
| `.chrome` 右上 | **页号 + 幕号** | 固定格式 | "Act II · 15 / 25" |
|
|
78
|
+
| `.kicker` | **这一页独一份的引导句** | 是大标题的"小前缀",像杂志大标题上方的一行话,每页都应不同 | "BUT" / "一个人,做了什么。" / "Phase 01 · 设计阶段" |
|
|
79
|
+
|
|
80
|
+
**反例**(已踩坑):chrome 写"设计先行 · Design First",kicker 又写"Phase 01 · 设计阶段"——意思重复,读者一眼就觉得 AI 生成的。
|
|
81
|
+
|
|
82
|
+
**正确做法**:chrome 是**栏目标签**(稳定、跨页可复用),kicker 是**本页钩子**(短句、有戏剧性),两者互为补充,不互相翻译。
|
|
83
|
+
|
|
84
|
+
### ⚠️ 主题节奏规划(必读 · 生成前必做)
|
|
85
|
+
|
|
86
|
+
**核心机制**:每页 `<section>` 必须带 `light` / `dark` / `hero light` / `hero dark` 之一。JS 根据 class 推断主题,决定 body 加不加 `light-bg`,从而切换暗/亮两张 WebGL canvas 哪张在前。不带主题或写自定义名 = fallback 出错。
|
|
87
|
+
|
|
88
|
+
#### 按布局的主题默认值
|
|
89
|
+
|
|
90
|
+
| Layout | 默认主题 | 原因 |
|
|
91
|
+
|---|---|---|
|
|
92
|
+
| 1. 开场封面 | `hero dark` | 开场仪式感,暗底强冲击 |
|
|
93
|
+
| 2. 章节幕封 | `hero dark` 与 `hero light` **必须交替** | 呼吸节奏 |
|
|
94
|
+
| 3. 大字报(数据) | `light` | 数字需纸白底;多幕连发时可偶插 `dark` |
|
|
95
|
+
| 4. 左文右图 | **`light` / `dark` 交替** | 正文节奏主力 |
|
|
96
|
+
| 5. 图片网格 | `light` | 截图需亮底 |
|
|
97
|
+
| 6. Pipeline | `light` | 流程图需清晰 |
|
|
98
|
+
| 7. 问题页 | `hero dark` | 强视觉冲击默认 |
|
|
99
|
+
| 8. 大引用 | **`dark` 优先**,偶用 `light` | 金句仪式感靠暗底 |
|
|
100
|
+
| 9. 对比页 | `light` | 双列需清晰 |
|
|
101
|
+
| 10. 图文混排 | **`light` / `dark` 交替** | 节奏 |
|
|
102
|
+
|
|
103
|
+
#### 节奏硬规则(生成后 grep 自检)
|
|
104
|
+
|
|
105
|
+
- ❌ **禁止**连续 3 页以上相同主题(包括 light 堆叠和 dark 堆叠)
|
|
106
|
+
- ❌ **禁止**8 页以上的 deck 没有至少 1 个 `hero dark` + 1 个 `hero light`
|
|
107
|
+
- ❌ **禁止**整个 deck 只有 `light` 正文页没有任何 `dark` 正文页——会显得平淡、没呼吸
|
|
108
|
+
- ✅ **推荐**每 3-4 页插入 1 个 hero(封面/幕封/问题/大引用)
|
|
109
|
+
|
|
110
|
+
#### 8 页节奏模板(可直接套用)
|
|
111
|
+
|
|
112
|
+
| 页 | 主题 | 布局 | 备注 |
|
|
113
|
+
|---|---|---|---|
|
|
114
|
+
| 1 | `hero dark` | 封面 | 开场 |
|
|
115
|
+
| 2 | `light` | 大字报 | 数据抛出 |
|
|
116
|
+
| 3 | `dark` | 左文右图 | 对比/故事 |
|
|
117
|
+
| 4 | `light` | Pipeline | 流程 |
|
|
118
|
+
| 5 | `hero light` | 章节幕封 | 呼吸 |
|
|
119
|
+
| 6 | `dark` | 左文右图 or 大引用 | |
|
|
120
|
+
| 7 | `hero dark` | 问题页 | 悬念收束 |
|
|
121
|
+
| 8 | `light` | 大引用/结尾 | 收尾 |
|
|
122
|
+
|
|
123
|
+
**先画这张表对齐,再动手写 slide**。跳过规划直接粘骨架 = 全是 light。
|
|
124
|
+
|
|
125
|
+
---
|
|
126
|
+
|
|
127
|
+
## Layout 1: 开场封面(Hero Cover)
|
|
128
|
+
|
|
129
|
+
```html
|
|
130
|
+
<section class="slide hero dark">
|
|
131
|
+
<div class="chrome">
|
|
132
|
+
<div>A Talk · 2026.04.22</div>
|
|
133
|
+
<div>Vol.01</div>
|
|
134
|
+
</div>
|
|
135
|
+
<div class="frame" style="display:grid; gap:4vh; align-content:center; min-height:80vh">
|
|
136
|
+
<div class="kicker">私享会 · 李继刚</div>
|
|
137
|
+
<h1 class="h-hero">一人公司</h1>
|
|
138
|
+
<h2 class="h-sub">被 AI 折叠的组织</h2>
|
|
139
|
+
<p class="lead" style="max-width:60vw">
|
|
140
|
+
一个 AI 创作者 —— 在 64 天里做了 11 万行代码、在 9 个平台上持续输出,生活节奏几乎没有被改变。
|
|
141
|
+
</p>
|
|
142
|
+
<div class="meta-row">
|
|
143
|
+
<span>歸藏 Guizang</span><span>·</span><span>独立创作者 / CodePilot 作者</span>
|
|
144
|
+
</div>
|
|
145
|
+
</div>
|
|
146
|
+
<div class="foot">
|
|
147
|
+
<div>一场关于 AI · 组织 · 个体的分享</div>
|
|
148
|
+
<div>— 2026 —</div>
|
|
149
|
+
</div>
|
|
150
|
+
</section>
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
**要点**:
|
|
154
|
+
- 用 `hero dark` 让 WebGL 背景在大部分区域透出
|
|
155
|
+
- `h-hero` 是最大字号(10vw),这里作标题主视觉
|
|
156
|
+
- 用 `min-height:80vh + align-content:center` 让内容整体垂直居中
|
|
157
|
+
- 不需要 `.chrome` 里写页码,封面页自成一体
|
|
158
|
+
|
|
159
|
+
---
|
|
160
|
+
|
|
161
|
+
## Layout 2: 章节幕封(Act Divider)
|
|
162
|
+
|
|
163
|
+
```html
|
|
164
|
+
<section class="slide hero light">
|
|
165
|
+
<div class="chrome">
|
|
166
|
+
<div>第一幕 · 硬数据</div>
|
|
167
|
+
<div>Act I · 01 / 25</div>
|
|
168
|
+
</div>
|
|
169
|
+
<div class="frame" style="display:grid; gap:6vh; align-content:center; min-height:80vh">
|
|
170
|
+
<div class="kicker">Act I</div>
|
|
171
|
+
<h1 class="h-hero" style="font-size:8.5vw">硬数据</h1>
|
|
172
|
+
<p class="lead" style="max-width:55vw">
|
|
173
|
+
先看数字,再谈方法。
|
|
174
|
+
</p>
|
|
175
|
+
</div>
|
|
176
|
+
<div class="foot">
|
|
177
|
+
<div>第一幕引子</div>
|
|
178
|
+
<div>— · —</div>
|
|
179
|
+
</div>
|
|
180
|
+
</section>
|
|
181
|
+
```
|
|
182
|
+
|
|
183
|
+
**要点**:
|
|
184
|
+
- 极简,只需要 kicker + 大标题 + 一行引语
|
|
185
|
+
- 两个幕的封面可以交替 `hero light` / `hero dark`,制造节奏
|
|
186
|
+
- `h-hero` 字号可以从 10vw 调到 8.5vw 适配长短
|
|
187
|
+
|
|
188
|
+
---
|
|
189
|
+
|
|
190
|
+
## Layout 3: 数据大字报(Big Numbers Grid)
|
|
191
|
+
|
|
192
|
+
```html
|
|
193
|
+
<section class="slide light">
|
|
194
|
+
<div class="chrome">
|
|
195
|
+
<div>过去 64 天 · 开发篇</div>
|
|
196
|
+
<div>Act I / Dev · 02 / 25</div>
|
|
197
|
+
</div>
|
|
198
|
+
<div class="frame" style="padding-top:6vh">
|
|
199
|
+
<div class="kicker">一个人,做了什么。</div>
|
|
200
|
+
<h2 class="h-xl">过去 64 天</h2>
|
|
201
|
+
<p class="lead" style="margin-bottom:5vh">从 0 到开源 CodePilot。</p>
|
|
202
|
+
|
|
203
|
+
<div class="grid-6" style="margin-top:6vh">
|
|
204
|
+
<div class="stat-card">
|
|
205
|
+
<div class="stat-label">Duration</div>
|
|
206
|
+
<div class="stat-nb">64 <span class="stat-unit">天</span></div>
|
|
207
|
+
<div class="stat-note">从 0 到现在</div>
|
|
208
|
+
</div>
|
|
209
|
+
<div class="stat-card">
|
|
210
|
+
<div class="stat-label">Lines of Code</div>
|
|
211
|
+
<div class="stat-nb">110K+</div>
|
|
212
|
+
<div class="stat-note">一行行写到 11 万+</div>
|
|
213
|
+
</div>
|
|
214
|
+
<div class="stat-card">
|
|
215
|
+
<div class="stat-label">GitHub Stars</div>
|
|
216
|
+
<div class="stat-nb">5,166</div>
|
|
217
|
+
<div class="stat-note">一个开源仓库</div>
|
|
218
|
+
</div>
|
|
219
|
+
<div class="stat-card">
|
|
220
|
+
<div class="stat-label">Downloads</div>
|
|
221
|
+
<div class="stat-nb">41K+</div>
|
|
222
|
+
<div class="stat-note">装到了几万台电脑里</div>
|
|
223
|
+
</div>
|
|
224
|
+
<div class="stat-card">
|
|
225
|
+
<div class="stat-label">AI Providers</div>
|
|
226
|
+
<div class="stat-nb">19</div>
|
|
227
|
+
<div class="stat-note">跨平台接入</div>
|
|
228
|
+
</div>
|
|
229
|
+
<div class="stat-card">
|
|
230
|
+
<div class="stat-label">Commits</div>
|
|
231
|
+
<div class="stat-nb">608+</div>
|
|
232
|
+
<div class="stat-note">没有协作者</div>
|
|
233
|
+
</div>
|
|
234
|
+
</div>
|
|
235
|
+
</div>
|
|
236
|
+
<div class="foot">
|
|
237
|
+
<div>项目 · CodePilot | github.com/codepilot</div>
|
|
238
|
+
<div>Act I · Dev Numbers</div>
|
|
239
|
+
</div>
|
|
240
|
+
</section>
|
|
241
|
+
```
|
|
242
|
+
|
|
243
|
+
**要点**:
|
|
244
|
+
- 3×2 或 4×2 网格最稳(见 `.grid-6`)
|
|
245
|
+
- 每个 `stat-card` 结构固定:label(英文小字)→ nb(大字数字)→ note(注释)
|
|
246
|
+
- 数字建议 2-3 位字符(太长会溢出),用 K / M 简写
|
|
247
|
+
- 留 5vh 以上的上方缓冲,让标题区先抢眼球
|
|
248
|
+
|
|
249
|
+
---
|
|
250
|
+
|
|
251
|
+
## Layout 4: 左文右图(Quote + Image)
|
|
252
|
+
|
|
253
|
+
```html
|
|
254
|
+
<section class="slide light">
|
|
255
|
+
<div class="chrome">
|
|
256
|
+
<div>身份反差 · The Twist</div>
|
|
257
|
+
<div>03 / 25</div>
|
|
258
|
+
</div>
|
|
259
|
+
<div class="frame grid-2-7-5" style="padding-top:6vh">
|
|
260
|
+
<!-- 左列:标题 + 正文 + callout,flex column 让 callout 贴列底 -->
|
|
261
|
+
<div style="display:flex; flex-direction:column; justify-content:space-between; gap:3vh">
|
|
262
|
+
<div>
|
|
263
|
+
<div class="kicker">BUT</div>
|
|
264
|
+
<h2 class="h-xl" style="white-space:nowrap; font-size:7.2vw">
|
|
265
|
+
我不是程序员。
|
|
266
|
+
</h2>
|
|
267
|
+
<p class="lead" style="margin-top:3vh">
|
|
268
|
+
大学毕业之后再也没写过一行代码。过去十年做的是 UI 设计和 AI 特效。
|
|
269
|
+
</p>
|
|
270
|
+
</div>
|
|
271
|
+
<div class="callout">
|
|
272
|
+
"这东西在三年前,<br>
|
|
273
|
+
需要一个十人团队做一年。"
|
|
274
|
+
<div class="callout-src">— 一个观察者的判断</div>
|
|
275
|
+
</div>
|
|
276
|
+
</div>
|
|
277
|
+
<!-- 右列:图片用标准 16/10 比例 + max-height,不要 align-self:end -->
|
|
278
|
+
<figure class="frame-img" style="aspect-ratio:16/10; max-height:56vh">
|
|
279
|
+
<img src="images/codepilot.png" alt="CodePilot 产品截图">
|
|
280
|
+
<figcaption class="img-cap">CodePilot · 产品截图</figcaption>
|
|
281
|
+
</figure>
|
|
282
|
+
</div>
|
|
283
|
+
<div class="foot">
|
|
284
|
+
<div>Page 03 · 我不是程序员</div>
|
|
285
|
+
<div>— · —</div>
|
|
286
|
+
</div>
|
|
287
|
+
</section>
|
|
288
|
+
```
|
|
289
|
+
|
|
290
|
+
**要点**:
|
|
291
|
+
- 用 `grid-2-7-5`(左 7 份、右 5 份),`align-items:start` 已在 template 预设
|
|
292
|
+
- **左列**用 flex column + `justify-content:space-between`:标题贴顶,callout 自然贴底
|
|
293
|
+
- **右列图片** **不要加 `align-self:end`**。会让图片滑到 cell 底部,低分屏下被浏览器工具栏遮挡
|
|
294
|
+
- 图片必须用 **标准比例 16/10 或 4/3 + `max-height:56vh`**,不要用原图奇葩比例(`2592/1798` 这种)
|
|
295
|
+
|
|
296
|
+
---
|
|
297
|
+
|
|
298
|
+
## Layout 5: 图片网格(多图对比)
|
|
299
|
+
|
|
300
|
+
```html
|
|
301
|
+
<section class="slide light">
|
|
302
|
+
<div class="chrome">
|
|
303
|
+
<div>平台粉丝实证</div>
|
|
304
|
+
<div>Act I / Ops · 05 / 27</div>
|
|
305
|
+
</div>
|
|
306
|
+
<div class="frame" style="padding-top:5vh">
|
|
307
|
+
<div class="kicker">Proof · 粉丝实证</div>
|
|
308
|
+
<h2 class="h-xl">10 个平台 · 6 张截图</h2>
|
|
309
|
+
|
|
310
|
+
<div class="grid-3-3" style="margin-top:4vh">
|
|
311
|
+
<figure class="frame-img" style="height:26vh">
|
|
312
|
+
<img src="images/weibo.png" alt="微博 289K">
|
|
313
|
+
<figcaption class="img-cap">微博 · 289K</figcaption>
|
|
314
|
+
</figure>
|
|
315
|
+
<figure class="frame-img" style="height:26vh">
|
|
316
|
+
<img src="images/twitter.png" alt="推特 137K">
|
|
317
|
+
<figcaption class="img-cap">推特 · 137K</figcaption>
|
|
318
|
+
</figure>
|
|
319
|
+
<figure class="frame-img" style="height:26vh">
|
|
320
|
+
<img src="images/wechat.png" alt="公众号 96K">
|
|
321
|
+
<figcaption class="img-cap">公众号 · 96K</figcaption>
|
|
322
|
+
</figure>
|
|
323
|
+
<figure class="frame-img" style="height:26vh">
|
|
324
|
+
<img src="images/jike.png" alt="即刻 26K">
|
|
325
|
+
<figcaption class="img-cap">即刻 · 26K</figcaption>
|
|
326
|
+
</figure>
|
|
327
|
+
<figure class="frame-img" style="height:26vh">
|
|
328
|
+
<img src="images/xhs.png" alt="小红书 19K">
|
|
329
|
+
<figcaption class="img-cap">小红书 · 19K</figcaption>
|
|
330
|
+
</figure>
|
|
331
|
+
<figure class="frame-img" style="height:26vh">
|
|
332
|
+
<img src="images/douyin.png" alt="抖音 10K">
|
|
333
|
+
<figcaption class="img-cap">抖音 · 10K</figcaption>
|
|
334
|
+
</figure>
|
|
335
|
+
</div>
|
|
336
|
+
</div>
|
|
337
|
+
<div class="foot">
|
|
338
|
+
<div>截图时间 · 2026.04</div>
|
|
339
|
+
<div>Page 05 · 粉丝实证</div>
|
|
340
|
+
</div>
|
|
341
|
+
</section>
|
|
342
|
+
```
|
|
343
|
+
|
|
344
|
+
**要点**:
|
|
345
|
+
- 关键:每个 `frame-img` 必须写死 `height:NNvh`(不要用 `aspect-ratio`),否则网格会撑破
|
|
346
|
+
- 图片会自动 `object-fit:cover + object-position:top`,只裁底部
|
|
347
|
+
- 用 `.grid-3-3`(3×2)或 `.grid-3`(3×1)承载
|
|
348
|
+
|
|
349
|
+
---
|
|
350
|
+
|
|
351
|
+
## Layout 6: 两列流水线(Pipeline)
|
|
352
|
+
|
|
353
|
+
```html
|
|
354
|
+
<section class="slide light">
|
|
355
|
+
<div class="chrome">
|
|
356
|
+
<div>我的工作流 · Workflow</div>
|
|
357
|
+
<div>Act II · 15 / 27</div>
|
|
358
|
+
</div>
|
|
359
|
+
<div class="frame">
|
|
360
|
+
<div class="kicker">Pipeline · 流水线</div>
|
|
361
|
+
<h2 class="h-xl">两条流水线</h2>
|
|
362
|
+
|
|
363
|
+
<!-- 第一组:文本侧 -->
|
|
364
|
+
<div class="pipeline-section">
|
|
365
|
+
<div class="pipeline-label">文本侧 · Text Pipeline</div>
|
|
366
|
+
<div class="pipeline">
|
|
367
|
+
<div class="step">
|
|
368
|
+
<div class="step-nb">01</div>
|
|
369
|
+
<div class="step-title">Draft</div>
|
|
370
|
+
<div class="step-desc">AI 帮我起草初稿</div>
|
|
371
|
+
</div>
|
|
372
|
+
<div class="step">
|
|
373
|
+
<div class="step-nb">02</div>
|
|
374
|
+
<div class="step-title">Polish</div>
|
|
375
|
+
<div class="step-desc">AI 润色去 AI 味</div>
|
|
376
|
+
</div>
|
|
377
|
+
<div class="step">
|
|
378
|
+
<div class="step-nb">03</div>
|
|
379
|
+
<div class="step-title">Morph</div>
|
|
380
|
+
<div class="step-desc">AI 变形成推特 / 小红书</div>
|
|
381
|
+
</div>
|
|
382
|
+
<div class="step">
|
|
383
|
+
<div class="step-nb">04</div>
|
|
384
|
+
<div class="step-title">Illustrate</div>
|
|
385
|
+
<div class="step-desc">AI 生成信息图</div>
|
|
386
|
+
</div>
|
|
387
|
+
<div class="step">
|
|
388
|
+
<div class="step-nb">05</div>
|
|
389
|
+
<div class="step-title">Distribute</div>
|
|
390
|
+
<div class="step-desc">一键分发 9 平台</div>
|
|
391
|
+
</div>
|
|
392
|
+
</div>
|
|
393
|
+
</div>
|
|
394
|
+
|
|
395
|
+
<!-- 第二组:视频侧 -->
|
|
396
|
+
<div class="pipeline-section">
|
|
397
|
+
<div class="pipeline-label">视觉 · 视频侧 · Video Pipeline</div>
|
|
398
|
+
<div class="pipeline">
|
|
399
|
+
<div class="step">
|
|
400
|
+
<div class="step-nb">06</div>
|
|
401
|
+
<div class="step-title">Cut</div>
|
|
402
|
+
<div class="step-desc">AI 帮我剪辑</div>
|
|
403
|
+
</div>
|
|
404
|
+
<div class="step">
|
|
405
|
+
<div class="step-nb">07</div>
|
|
406
|
+
<div class="step-title">Wrap</div>
|
|
407
|
+
<div class="step-desc">AI 帮我包装</div>
|
|
408
|
+
</div>
|
|
409
|
+
<div class="step">
|
|
410
|
+
<div class="step-nb">08</div>
|
|
411
|
+
<div class="step-title">Cover</div>
|
|
412
|
+
<div class="step-desc">AI 生成封面</div>
|
|
413
|
+
</div>
|
|
414
|
+
</div>
|
|
415
|
+
</div>
|
|
416
|
+
</div>
|
|
417
|
+
<div class="foot">
|
|
418
|
+
<div>Page 15 · 我的内容工厂</div>
|
|
419
|
+
<div>Workflow</div>
|
|
420
|
+
</div>
|
|
421
|
+
</section>
|
|
422
|
+
```
|
|
423
|
+
|
|
424
|
+
**要点**:
|
|
425
|
+
- 用 `.pipeline-section` 分组 + `.pipeline-label` 作组标题
|
|
426
|
+
- 两组之间用 3.6vh 的间距 + 顶部细分隔线(已在 CSS 中预设)
|
|
427
|
+
- 每个 step 是固定的 nb → title → desc 结构
|
|
428
|
+
- 步骤数不限但单行最好 ≤5 个,否则换到第二 pipeline
|
|
429
|
+
|
|
430
|
+
---
|
|
431
|
+
|
|
432
|
+
## Layout 7: 悬念收束 / 问题页(Hero Question)
|
|
433
|
+
|
|
434
|
+
```html
|
|
435
|
+
<section class="slide hero dark">
|
|
436
|
+
<div class="chrome">
|
|
437
|
+
<div>留给你的问题</div>
|
|
438
|
+
<div>24 / 27</div>
|
|
439
|
+
</div>
|
|
440
|
+
<div class="frame" style="display:grid; gap:8vh; align-content:center; min-height:80vh">
|
|
441
|
+
<div class="kicker">The Question</div>
|
|
442
|
+
<h1 class="h-hero" style="font-size:7vw; line-height:1.15">
|
|
443
|
+
你的公司里,<br>
|
|
444
|
+
哪些岗位本来就<br>
|
|
445
|
+
不该由人来做?
|
|
446
|
+
</h1>
|
|
447
|
+
<p class="lead" style="max-width:50vw">
|
|
448
|
+
这个问题,不是技术问题,是架构问题。
|
|
449
|
+
</p>
|
|
450
|
+
</div>
|
|
451
|
+
<div class="foot">
|
|
452
|
+
<div>Page 24 · The Question</div>
|
|
453
|
+
<div>— · —</div>
|
|
454
|
+
</div>
|
|
455
|
+
</section>
|
|
456
|
+
```
|
|
457
|
+
|
|
458
|
+
**要点**:
|
|
459
|
+
- Hero 页留白越多越好,只放一个问题
|
|
460
|
+
- `h-hero` 字号视长度调整(7vw 适合 3 行,10vw 适合 1 行)
|
|
461
|
+
- 用 `<br>` 手工断行,确保断点在语义处
|
|
462
|
+
- 尾巴可以再给一行 `lead` 作为点破
|
|
463
|
+
|
|
464
|
+
---
|
|
465
|
+
|
|
466
|
+
## Layout 8: 大引用页(Big Quote · 衬线金句)
|
|
467
|
+
|
|
468
|
+
```html
|
|
469
|
+
<section class="slide light">
|
|
470
|
+
<div class="chrome">
|
|
471
|
+
<div>The Takeaway · 核心金句</div>
|
|
472
|
+
<div>18 / 25</div>
|
|
473
|
+
</div>
|
|
474
|
+
<div class="frame" style="display:grid; gap:5vh; align-content:center; min-height:80vh">
|
|
475
|
+
<div class="kicker">Quote · 金句</div>
|
|
476
|
+
<blockquote style="font-family:var(--serif-zh); font-weight:700; font-size:5.8vw; line-height:1.2; letter-spacing:-.01em; max-width:72vw">
|
|
477
|
+
"没有交接,<br>所有人都在构建。"
|
|
478
|
+
</blockquote>
|
|
479
|
+
<p class="lead" style="max-width:55vw; opacity:.65">
|
|
480
|
+
Without the handoff, everyone builds.<br>
|
|
481
|
+
And that makes all the difference.
|
|
482
|
+
</p>
|
|
483
|
+
<div class="meta-row">
|
|
484
|
+
<span>— Luke Wroblewski</span><span>·</span><span>2026.04.16</span>
|
|
485
|
+
</div>
|
|
486
|
+
</div>
|
|
487
|
+
<div class="foot">
|
|
488
|
+
<div>Page 18 · 金句</div>
|
|
489
|
+
<div>— · —</div>
|
|
490
|
+
</div>
|
|
491
|
+
</section>
|
|
492
|
+
```
|
|
493
|
+
|
|
494
|
+
**要点**:
|
|
495
|
+
- 整页留白,只放一个大引用 + 出处
|
|
496
|
+
- `<blockquote>` 用 inline style 单独放大(5-6vw),不要用 `h-hero`(那是页面主标题的命名)
|
|
497
|
+
- 下面跟随英文原文(lead · opacity:.65)制造层级
|
|
498
|
+
- 配 `meta-row` 写出处 · 日期
|
|
499
|
+
|
|
500
|
+
---
|
|
501
|
+
|
|
502
|
+
## Layout 9: 并列对比(A vs B · 旧 vs 新)
|
|
503
|
+
|
|
504
|
+
```html
|
|
505
|
+
<section class="slide light">
|
|
506
|
+
<div class="chrome">
|
|
507
|
+
<div>旧 vs 新 · The Shift</div>
|
|
508
|
+
<div>12 / 25</div>
|
|
509
|
+
</div>
|
|
510
|
+
<div class="frame" style="padding-top:5vh">
|
|
511
|
+
<div class="kicker">Before / After · 范式转变</div>
|
|
512
|
+
<h2 class="h-xl" style="margin-bottom:4vh">从交接到共建</h2>
|
|
513
|
+
|
|
514
|
+
<div class="grid-2-6-6" style="gap:5vw 4vh">
|
|
515
|
+
<!-- 左列:旧 -->
|
|
516
|
+
<div style="padding:3vh 2vw; border-left:3px solid currentColor; opacity:.55">
|
|
517
|
+
<div class="kicker" style="opacity:.9">Before · 旧模式</div>
|
|
518
|
+
<h3 class="h-md" style="margin-top:2vh">设计 → 开发 → 交接</h3>
|
|
519
|
+
<ul style="margin-top:3vh; padding-left:1.2em; display:flex; flex-direction:column; gap:1.4vh; font-family:var(--sans-zh); font-size:max(14px,1.1vw); line-height:1.55">
|
|
520
|
+
<li>设计师在 Figma 做稿</li>
|
|
521
|
+
<li>开发者盯着文件翻译像素</li>
|
|
522
|
+
<li>反复 PR 沟通对齐</li>
|
|
523
|
+
<li>非技术人员无法触碰代码</li>
|
|
524
|
+
</ul>
|
|
525
|
+
</div>
|
|
526
|
+
<!-- 右列:新 -->
|
|
527
|
+
<div style="padding:3vh 2vw; border-left:3px solid currentColor">
|
|
528
|
+
<div class="kicker" style="opacity:.9">After · 新模式</div>
|
|
529
|
+
<h3 class="h-md" style="margin-top:2vh">同工具 · 并行 · 共建</h3>
|
|
530
|
+
<ul style="margin-top:3vh; padding-left:1.2em; display:flex; flex-direction:column; gap:1.4vh; font-family:var(--sans-zh); font-size:max(14px,1.1vw); line-height:1.55">
|
|
531
|
+
<li>三个角色同时在 Intent 工作</li>
|
|
532
|
+
<li>agents.md 作为共享上下文</li>
|
|
533
|
+
<li>代理处理对齐 / 冲突 / 动画</li>
|
|
534
|
+
<li>任何人都能安全贡献代码</li>
|
|
535
|
+
</ul>
|
|
536
|
+
</div>
|
|
537
|
+
</div>
|
|
538
|
+
</div>
|
|
539
|
+
<div class="foot">
|
|
540
|
+
<div>Page 12 · 范式转变</div>
|
|
541
|
+
<div>Before / After</div>
|
|
542
|
+
</div>
|
|
543
|
+
</section>
|
|
544
|
+
```
|
|
545
|
+
|
|
546
|
+
**要点**:
|
|
547
|
+
- 用 `.grid-2-6-6`(1:1)左右分半
|
|
548
|
+
- 左列 `opacity:.55` 做"旧"的视觉弱化,右列满亮度做"新"的突出
|
|
549
|
+
- 两列都用 `border-left:3px solid` + `padding-left` 做引用块感
|
|
550
|
+
- 每列结构统一:`kicker` → `h-md` → `<ul>` 要点,节奏一致
|
|
551
|
+
|
|
552
|
+
---
|
|
553
|
+
|
|
554
|
+
## Layout 10: 图文混排(Lead Image + Side Text)
|
|
555
|
+
|
|
556
|
+
```html
|
|
557
|
+
<section class="slide light">
|
|
558
|
+
<div class="chrome">
|
|
559
|
+
<div>Design First · 设计先行</div>
|
|
560
|
+
<div>08 / 16</div>
|
|
561
|
+
</div>
|
|
562
|
+
<div class="frame grid-2-8-4" style="padding-top:6vh">
|
|
563
|
+
<!-- 左列:大段正文 + 引用 -->
|
|
564
|
+
<div>
|
|
565
|
+
<div class="kicker">Phase 01 · 设计阶段</div>
|
|
566
|
+
<h2 class="h-xl" style="margin-top:1vh; margin-bottom:3vh">设计先行 · 2 周</h2>
|
|
567
|
+
|
|
568
|
+
<p class="lead" style="margin-bottom:3vh">
|
|
569
|
+
在 Figma 中完成视觉探索与设计系统,网格 / 排版 / 颜色变量 / 可复用组件,桌面和移动端稿件几轮反馈迭代。
|
|
570
|
+
</p>
|
|
571
|
+
|
|
572
|
+
<p style="font-family:var(--sans-zh); font-size:max(14px,1.15vw); line-height:1.75; opacity:.78; margin-bottom:2.4vh">
|
|
573
|
+
两周之内,视觉风格、粗略结构、方向性内容全部稳定。这是扎实的传统设计流程——在这里还没什么新鲜事。
|
|
574
|
+
</p>
|
|
575
|
+
|
|
576
|
+
<div class="callout" style="margin-top:3vh">
|
|
577
|
+
"This phase was pretty standard.<br>Just a solid Web design process."
|
|
578
|
+
<div class="callout-src">— Luke Wroblewski</div>
|
|
579
|
+
</div>
|
|
580
|
+
</div>
|
|
581
|
+
<!-- 右列:辅助图 · 竖版或方形 -->
|
|
582
|
+
<figure class="frame-img" style="aspect-ratio:3/4; max-height:60vh">
|
|
583
|
+
<img src="images/figma.png" alt="Figma design system">
|
|
584
|
+
<figcaption class="img-cap">Figma · Design System</figcaption>
|
|
585
|
+
</figure>
|
|
586
|
+
</div>
|
|
587
|
+
<div class="foot">
|
|
588
|
+
<div>Page 08 · Design First</div>
|
|
589
|
+
<div>约 2 周</div>
|
|
590
|
+
</div>
|
|
591
|
+
</section>
|
|
592
|
+
```
|
|
593
|
+
|
|
594
|
+
**要点**:
|
|
595
|
+
- `.grid-2-8-4`(8:4) 让正文占主导,图片作辅助
|
|
596
|
+
- 左列包含多种信息层级:kicker → 大标题 → lead → 正文段落 → callout(引用)
|
|
597
|
+
- 右列图片用 **竖版 3:4** 或方形 1:1,避免和左列文本竞争注意力
|
|
598
|
+
- 这种布局适合**页面信息量偏大**的场景(不像 Layout 4 只有一句金句)
|
|
599
|
+
|
|
600
|
+
---
|
|
601
|
+
|
|
602
|
+
## 附录:常用网格模板
|
|
603
|
+
|
|
604
|
+
| 类名 | 配比 | 用途 |
|
|
605
|
+
|---|---|---|
|
|
606
|
+
| `.grid-2-6-6` | 6:6(1:1) | 对半分 |
|
|
607
|
+
| `.grid-2-7-5` | 7:5 | 文字为主 + 辅助图 |
|
|
608
|
+
| `.grid-2-8-4` | 8:4(2:1) | 大段文字 + 小图/数据 |
|
|
609
|
+
| `.grid-3` | 1:1:1 | 3 项并列(案例/截图) |
|
|
610
|
+
| `.grid-3-3` | 3×2 | 6 图矩阵 |
|
|
611
|
+
| `.grid-6` | 3×2 | 6 个数据卡片 |
|
|
612
|
+
|
|
613
|
+
所有网格都预留 `gap: 3vw 4vh`(水平 3vw、竖直 4vh),可以单独覆写。
|
|
614
|
+
|
|
615
|
+
---
|
|
616
|
+
|
|
617
|
+
## 页面节奏建议
|
|
618
|
+
|
|
619
|
+
一场 25-30 页的分享,推荐以下节奏:
|
|
620
|
+
|
|
621
|
+
1. **Hero Cover**(第 1 页)
|
|
622
|
+
2. **Act Divider**(第一幕开场,hero light 或 hero dark)
|
|
623
|
+
3. **Big Numbers**(抛硬数据制造冲击)
|
|
624
|
+
4. **Quote + Image**(讲身份反差/挂钩)
|
|
625
|
+
5. **Image Grid**(证据支撑)
|
|
626
|
+
6. **Hero Question**(幕收束,留悬念)
|
|
627
|
+
7. ... 第二幕、第三幕同样节奏 ...
|
|
628
|
+
8. **Hero Close**(最后一页,问题或致谢)
|
|
629
|
+
|
|
630
|
+
hero 页与 non-hero 页应该 **2-3 : 1 比例交错**,不要连续超过 3 页 non-hero,也不要连续超过 2 页 hero。
|