@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,119 @@
|
|
|
1
|
+
# Magazine Web PPT · Editorial-Style Web Slide Deck Skill
|
|
2
|
+
|
|
3
|
+
A [Claude Code / Claude Agent Skills](https://agentskills.io/) skill that generates **single-file HTML horizontal-swipe decks** with an "**editorial magazine × electronic ink**" aesthetic — picture *Monocle* with code stitched in.
|
|
4
|
+
|
|
5
|
+
> Distilled by [Guizang](https://x.com/op7418) from offline talks like "One-Person Company: Organizations Folded by AI" and "A New Way of Working." Every pitfall hit during those decks is logged in `checklist.md`.
|
|
6
|
+
|
|
7
|
+

|
|
8
|
+
|
|
9
|
+
## What you get
|
|
10
|
+
|
|
11
|
+
- 🖋 **Three-tier type system**: serif for headlines, sans-serif for body, mono for metadata
|
|
12
|
+
- 🌊 **WebGL fluid / dispersion backgrounds** — visible on hero pages, restrained on body pages
|
|
13
|
+
- 📐 **Horizontal swipe navigation**: ← → arrows / scroll wheel / touch swipe / bottom dots / ESC for index
|
|
14
|
+
- 🎨 **5 curated theme presets**: Ink Classic / Indigo Porcelain / Forest Ink / Kraft Paper / Dune
|
|
15
|
+
- 🧩 **10 page layouts**: cover, act divider, big numbers, lead image + text, image grid, pipeline, hero question, big quote, before/after, image + text mix
|
|
16
|
+
- 📄 **Single HTML file** — no build, no server, open directly in the browser
|
|
17
|
+
|
|
18
|
+
## Fits / Doesn't fit
|
|
19
|
+
|
|
20
|
+
**✅ Fits**: offline talks, industry keynotes, private salons, AI product launches, demo day, presentations with strong personal voice
|
|
21
|
+
|
|
22
|
+
**❌ Doesn't fit**: data-heavy tables, training decks (density too low), multi-user collaborative editing (static HTML)
|
|
23
|
+
|
|
24
|
+
## Install
|
|
25
|
+
|
|
26
|
+
### Option 1: Paste this to an AI (recommended)
|
|
27
|
+
|
|
28
|
+
> Install the `guizang-ppt-skill` Claude Code skill for me. Steps:
|
|
29
|
+
>
|
|
30
|
+
> 1. Make sure `~/.claude/skills/` exists (create if not)
|
|
31
|
+
> 2. Run `git clone https://github.com/op7418/guizang-ppt-skill.git ~/.claude/skills/magazine-web-ppt`
|
|
32
|
+
> 3. Verify: `ls ~/.claude/skills/magazine-web-ppt/` should show `SKILL.md`, `assets/`, `references/`
|
|
33
|
+
> 4. Tell me when done. Later, saying things like "make me a magazine-style deck" will trigger this skill.
|
|
34
|
+
|
|
35
|
+
Paste the block above into Claude Code / Cursor / any AI agent with shell access and it handles the install.
|
|
36
|
+
|
|
37
|
+
### Option 2: Manual CLI
|
|
38
|
+
|
|
39
|
+
```bash
|
|
40
|
+
git clone https://github.com/op7418/guizang-ppt-skill.git ~/.claude/skills/magazine-web-ppt
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
### How to trigger it
|
|
44
|
+
|
|
45
|
+
Once installed, Claude Code auto-detects the skill. Trigger phrases:
|
|
46
|
+
|
|
47
|
+
- "Make me a magazine-style deck"
|
|
48
|
+
- "Generate a horizontal swipe deck"
|
|
49
|
+
- "Editorial magazine style presentation"
|
|
50
|
+
- "Electronic ink slides for my talk"
|
|
51
|
+
|
|
52
|
+
## Workflow
|
|
53
|
+
|
|
54
|
+
The skill is a structured 6-step flow; Claude walks you through each:
|
|
55
|
+
|
|
56
|
+
1. **Clarify intent** — 6-question checklist: audience, duration, source material, images, theme, hard constraints
|
|
57
|
+
2. **Copy template** — `assets/template.html` → project folder, update `<title>`, swap theme vars
|
|
58
|
+
3. **Fill content** — pick from 10 layout skeletons, paste, edit copy (with class-name pre-flight + theme rhythm plan)
|
|
59
|
+
4. **Self-check** — match against `references/checklist.md`; P0 issues must all pass
|
|
60
|
+
5. **Preview** — open the HTML in a browser
|
|
61
|
+
6. **Iterate** — use inline styles to tune font size, height, spacing
|
|
62
|
+
|
|
63
|
+
Full spec in [`SKILL.md`](./SKILL.md).
|
|
64
|
+
|
|
65
|
+
## Directory
|
|
66
|
+
|
|
67
|
+
```
|
|
68
|
+
magazine-web-ppt/
|
|
69
|
+
├── SKILL.md ← main skill file: workflow, principles, common mistakes
|
|
70
|
+
├── README.md ← Chinese README
|
|
71
|
+
├── README.en.md ← this file
|
|
72
|
+
├── assets/
|
|
73
|
+
│ └── template.html ← runnable seed HTML (CSS + WebGL + swipe JS pre-wired)
|
|
74
|
+
└── references/
|
|
75
|
+
├── components.md ← component catalog (type, color, grid, icons, callout, stat, pipeline)
|
|
76
|
+
├── layouts.md ← 10 layout skeletons (paste-ready)
|
|
77
|
+
├── themes.md ← 5 theme presets (pick, don't customize)
|
|
78
|
+
└── checklist.md ← quality checklist (P0 / P1 / P2 / P3 tiers)
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
## Theme presets
|
|
82
|
+
|
|
83
|
+
Pick from `references/themes.md`. **Custom hex values are not allowed** — protecting the aesthetic matters more than freedom of choice.
|
|
84
|
+
|
|
85
|
+
| Theme | Best for |
|
|
86
|
+
|------|---------|
|
|
87
|
+
| 🖋 Ink Classic | general default, commercial launches, when in doubt |
|
|
88
|
+
| 🌊 Indigo Porcelain | tech / research / AI / technical keynotes |
|
|
89
|
+
| 🌿 Forest Ink | nature / sustainability / culture / non-fiction |
|
|
90
|
+
| 🍂 Kraft Paper | nostalgic / humanist / literary / indie zines |
|
|
91
|
+
| 🌙 Dune | art / design / creative / gallery |
|
|
92
|
+
|
|
93
|
+
Switching themes only requires replacing the 6 variables at the top of `template.html`'s `:root{}` block — all other CSS flows through `var(--...)`.
|
|
94
|
+
|
|
95
|
+
## Core design principles
|
|
96
|
+
|
|
97
|
+
1. **Restraint over flash** — WebGL backgrounds only bleed through on hero pages
|
|
98
|
+
2. **Structure over decoration** — information hierarchy via type size + typeface + grid whitespace, not shadows or floating cards
|
|
99
|
+
3. **Images are first-class citizens** — crop only from the bottom; top and sides stay intact
|
|
100
|
+
4. **Rhythm lives on hero pages** — hero / non-hero alternation keeps the eye from fatiguing
|
|
101
|
+
5. **Terms stay consistent** — Skills is Skills; no mix-and-match translations
|
|
102
|
+
|
|
103
|
+
## Visual references
|
|
104
|
+
|
|
105
|
+
- [*Monocle*](https://monocle.com) magazine layouts
|
|
106
|
+
- YC Garry Tan — "Thin Harness, Fat Skills"
|
|
107
|
+
- Guizang's offline talk deck series
|
|
108
|
+
|
|
109
|
+
## Contributing
|
|
110
|
+
|
|
111
|
+
Bugs, layout issues, new layout requests — Issues and PRs welcome. Prioritize:
|
|
112
|
+
|
|
113
|
+
- Add new classes to `template.html` first; don't let `layouts.md` reference undefined classes
|
|
114
|
+
- Log pitfalls into `checklist.md` at the matching P0 / P1 / P2 / P3 tier
|
|
115
|
+
- New theme colors go into `themes.md` with a recommended use case
|
|
116
|
+
|
|
117
|
+
## License
|
|
118
|
+
|
|
119
|
+
MIT © 2026 [op7418](https://github.com/op7418)
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
# Magazine Web PPT · 电子杂志风网页 PPT Skill
|
|
2
|
+
|
|
3
|
+
> 🌏 **English version: [README.en.md](./README.en.md)**
|
|
4
|
+
|
|
5
|
+
一个 [Claude Code / Claude Agent Skills](https://agentskills.io/) 技能,用于生成**单文件 HTML 横向翻页 PPT**,视觉基调是"**电子杂志 × 电子墨水**"——像 *Monocle* 贴上了代码的样子。
|
|
6
|
+
|
|
7
|
+
> 由 [歸藏](https://x.com/op7418) 在"一人公司:被 AI 折叠的组织"、"一种新的工作方式"等线下分享中沉淀而成,踩过的每一个坑都写进了 `checklist.md`。
|
|
8
|
+
|
|
9
|
+

|
|
10
|
+
|
|
11
|
+
## 效果
|
|
12
|
+
|
|
13
|
+
- 🖋 **衬线大标题 + 非衬线正文 + 等宽元数据**的三级字体分工
|
|
14
|
+
- 🌊 **WebGL 流体/色散背景**,hero 页可见,正文页克制
|
|
15
|
+
- 📐 **横向左右翻页**:键盘 ← → / 滚轮 / 触屏滑动 / 底部圆点 / ESC 索引
|
|
16
|
+
- 🎨 **5 套主题色预设**:墨水经典 / 靛蓝瓷 / 森林墨 / 牛皮纸 / 沙丘
|
|
17
|
+
- 🧩 **10 种页面布局**:开场封面、章节幕封、数据大字报、左文右图、图片网格、Pipeline、悬念问题、大引用、Before/After 对比、图文混排
|
|
18
|
+
- 📄 **单文件 HTML**:不需要构建、不需要服务器,浏览器直接打开
|
|
19
|
+
|
|
20
|
+
## 适合 / 不适合
|
|
21
|
+
|
|
22
|
+
**✅ 合适**:线下分享 / 行业内部讲话 / 私享会 / AI 产品发布 / demo day / 带强烈个人风格的演讲
|
|
23
|
+
|
|
24
|
+
**❌ 不合适**:大段表格数据 / 培训课件(信息密度不够)/ 需要多人协作编辑(静态 HTML)
|
|
25
|
+
|
|
26
|
+
## 安装
|
|
27
|
+
|
|
28
|
+
### 方式一:把下面这段话直接发给 AI(推荐)
|
|
29
|
+
|
|
30
|
+
> 帮我安装 `guizang-ppt-skill` 这个 Claude Code skill。请按下面步骤做:
|
|
31
|
+
>
|
|
32
|
+
> 1. 确保 `~/.claude/skills/` 目录存在(不存在就创建)
|
|
33
|
+
> 2. 执行 `git clone https://github.com/op7418/guizang-ppt-skill.git ~/.claude/skills/magazine-web-ppt`
|
|
34
|
+
> 3. 验证:`ls ~/.claude/skills/magazine-web-ppt/` 应该看到 `SKILL.md`、`assets/`、`references/` 三项
|
|
35
|
+
> 4. 告诉我安装好了,之后我说"做一份杂志风 PPT"之类的话就会触发这个 skill
|
|
36
|
+
|
|
37
|
+
把这段话复制粘贴给 Claude Code / Cursor / 任何有 shell 权限的 AI Agent,它会自动完成安装。
|
|
38
|
+
|
|
39
|
+
### 方式二:手动命令行
|
|
40
|
+
|
|
41
|
+
```bash
|
|
42
|
+
git clone https://github.com/op7418/guizang-ppt-skill.git ~/.claude/skills/magazine-web-ppt
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
### 触发方式
|
|
46
|
+
|
|
47
|
+
装好后,Claude Code 会在对话里自动发现并调用这个 skill。触发关键词:
|
|
48
|
+
|
|
49
|
+
- "帮我做一份杂志风 PPT"
|
|
50
|
+
- "生成一个 horizontal swipe deck"
|
|
51
|
+
- "editorial magazine style presentation"
|
|
52
|
+
- "electronic ink 风格演讲 slides"
|
|
53
|
+
|
|
54
|
+
## 使用流程
|
|
55
|
+
|
|
56
|
+
Skill 本身是结构化的 6 步工作流,Claude 会逐步引导:
|
|
57
|
+
|
|
58
|
+
1. **需求澄清** — 6 问清单:受众、时长、素材、图片、主题色、硬约束
|
|
59
|
+
2. **拷贝模板** — `assets/template.html` → 项目目录,改 `<title>`,换主题色
|
|
60
|
+
3. **填充内容** — 从 10 种 layout 骨架里挑、粘、改文案(先做类名预检 + 主题节奏规划)
|
|
61
|
+
4. **自检** — 对照 `references/checklist.md`,P0 级问题必须全过
|
|
62
|
+
5. **预览** — 浏览器直接打开
|
|
63
|
+
6. **迭代** — inline style 改字号/高度/间距
|
|
64
|
+
|
|
65
|
+
详细说明见 [`SKILL.md`](./SKILL.md)。
|
|
66
|
+
|
|
67
|
+
## 目录结构
|
|
68
|
+
|
|
69
|
+
```
|
|
70
|
+
magazine-web-ppt/
|
|
71
|
+
├── SKILL.md ← Skill 主文件:工作流、原则、常见错误
|
|
72
|
+
├── README.md ← 本文件
|
|
73
|
+
├── assets/
|
|
74
|
+
│ └── template.html ← 完整可运行的种子 HTML(CSS + WebGL + 翻页 JS 全配好)
|
|
75
|
+
└── references/
|
|
76
|
+
├── components.md ← 组件手册(字体、色、网格、图标、callout、stat、pipeline)
|
|
77
|
+
├── layouts.md ← 10 种页面布局骨架(可直接粘贴)
|
|
78
|
+
├── themes.md ← 5 套主题色预设(只能选不能自定义)
|
|
79
|
+
└── checklist.md ← 质量检查清单(P0 / P1 / P2 / P3 分级)
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
## 主题色预设
|
|
83
|
+
|
|
84
|
+
从 `references/themes.md` 里选一套——**不允许自定义 hex 值**,保护美学比给自由更重要。
|
|
85
|
+
|
|
86
|
+
| 主题 | 适合场景 |
|
|
87
|
+
|------|---------|
|
|
88
|
+
| 🖋 墨水经典 | 通用默认、商业发布、不知道选啥 |
|
|
89
|
+
| 🌊 靛蓝瓷 | 科技 / 研究 / AI / 技术发布会 |
|
|
90
|
+
| 🌿 森林墨 | 自然 / 可持续 / 文化 / 非虚构 |
|
|
91
|
+
| 🍂 牛皮纸 | 怀旧 / 人文 / 文学 / 独立杂志 |
|
|
92
|
+
| 🌙 沙丘 | 艺术 / 设计 / 创意 / 画廊 |
|
|
93
|
+
|
|
94
|
+
切换主题只需替换 `template.html` 开头 `:root{}` 里的 6 行变量,其他 CSS 全走 `var(--...)`。
|
|
95
|
+
|
|
96
|
+
## 核心设计原则
|
|
97
|
+
|
|
98
|
+
1. **克制优于炫技** — WebGL 背景只在 hero 页透出
|
|
99
|
+
2. **结构优于装饰** — 信息靠字号 + 字体对比 + 网格留白,不用阴影和浮动卡片
|
|
100
|
+
3. **图片是第一公民** — 只裁底部,顶部和左右完整
|
|
101
|
+
4. **节奏靠 hero 页** — hero / non-hero 交替,才不累眼睛
|
|
102
|
+
5. **术语统一** — Skills 就是 Skills,不中英混译
|
|
103
|
+
|
|
104
|
+
## 视觉参考
|
|
105
|
+
|
|
106
|
+
- [*Monocle*](https://monocle.com) 杂志的版式
|
|
107
|
+
- YC Garry Tan "Thin Harness, Fat Skills"
|
|
108
|
+
- 歸藏线下分享 PPT 系列
|
|
109
|
+
|
|
110
|
+
## 贡献
|
|
111
|
+
|
|
112
|
+
Bug、排版问题、新布局需求——欢迎开 Issue 或 PR。改动请优先:
|
|
113
|
+
|
|
114
|
+
- 在 `template.html` 里补类,不要让 layouts.md 使用未定义的类
|
|
115
|
+
- 把踩过的坑写到 `checklist.md` 对应的 P0 / P1 / P2 / P3 级别
|
|
116
|
+
- 新主题色进 `themes.md` 并给出适合的场景
|
|
117
|
+
|
|
118
|
+
## License
|
|
119
|
+
|
|
120
|
+
MIT © 2026 [op7418](https://github.com/op7418)
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
# Magazine Web PPT · Skill de PPT estilo revista eletrônica em web
|
|
2
|
+
|
|
3
|
+
> 🌏 **English version: [README.en.md](./README.en.md)**
|
|
4
|
+
> 🌏 **中文版: [README.md](./README.md)**
|
|
5
|
+
|
|
6
|
+
Uma skill do [Claude Code / Claude Agent Skills](https://agentskills.io/) para gerar **PPTs HTML em arquivo único com swipe horizontal**. O tom visual é "**revista eletrônica × tinta digital**" — como se a *Monocle* tivesse colado código.
|
|
7
|
+
|
|
8
|
+
> Destilada por [歸藏](https://x.com/op7418) em palestras presenciais como "Empresa de uma pessoa só: a organização dobrada pela IA" e "Uma nova forma de trabalhar"; cada armadilha que ele já pisou virou linha em `checklist.md`.
|
|
9
|
+
|
|
10
|
+

|
|
11
|
+
|
|
12
|
+
## Resultado
|
|
13
|
+
|
|
14
|
+
- 🖋 **Título grande em serifa + corpo sem serifa + metadados monoespaçados**, divisão tipográfica em três níveis
|
|
15
|
+
- 🌊 **Background WebGL com fluido / dispersão**, presente na hero, contido nas páginas internas
|
|
16
|
+
- 📐 **Swipe horizontal**: teclado ← → / scroll / swipe touch / dots inferiores / ESC para o índice
|
|
17
|
+
- 🎨 **5 paletas predefinidas**: Tinta Clássica / Azul-Índigo Porcelana / Tinta Floresta / Papel Kraft / Duna
|
|
18
|
+
- 🧩 **10 layouts de página**: capa de abertura, abertura de capítulo, manchete de dado, texto-à-esquerda imagem-à-direita, grade de imagens, pipeline, página de mistério/pergunta, citação grande, comparação Before/After, mistura texto+imagem
|
|
19
|
+
- 📄 **HTML de arquivo único**: sem build, sem servidor, abre direto no navegador
|
|
20
|
+
|
|
21
|
+
## Quando encaixa / quando não encaixa
|
|
22
|
+
|
|
23
|
+
**✅ Boa escolha**: palestras presenciais / conversas internas de mercado / sessões privadas / lançamentos de produtos de IA / demo day / discursos com forte estilo pessoal
|
|
24
|
+
|
|
25
|
+
**❌ Má escolha**: tabelões de dados / material de treinamento (densidade de informação insuficiente) / edição colaborativa multi-usuário (HTML estático)
|
|
26
|
+
|
|
27
|
+
## Instalação
|
|
28
|
+
|
|
29
|
+
### Forma 1: mande o texto abaixo direto para a IA (recomendado)
|
|
30
|
+
|
|
31
|
+
> Me ajude a instalar a skill `guizang-ppt-skill` do Claude Code. Siga estes passos:
|
|
32
|
+
>
|
|
33
|
+
> 1. Garanta que o diretório `~/.claude/skills/` existe (crie se não existir)
|
|
34
|
+
> 2. Rode `git clone https://github.com/op7418/guizang-ppt-skill.git ~/.claude/skills/magazine-web-ppt`
|
|
35
|
+
> 3. Verifique: `ls ~/.claude/skills/magazine-web-ppt/` deve mostrar `SKILL.md`, `assets/` e `references/`
|
|
36
|
+
> 4. Me avise quando estiver instalado; depois disso, quando eu disser "faça um PPT estilo revista" ou similar, essa skill é disparada
|
|
37
|
+
|
|
38
|
+
Cole esse texto no Claude Code / Cursor / qualquer agente de IA com permissão de shell, e ele faz a instalação automaticamente.
|
|
39
|
+
|
|
40
|
+
### Forma 2: linha de comando manual
|
|
41
|
+
|
|
42
|
+
```bash
|
|
43
|
+
git clone https://github.com/op7418/guizang-ppt-skill.git ~/.claude/skills/magazine-web-ppt
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
### Como disparar
|
|
47
|
+
|
|
48
|
+
Depois de instalada, o Claude Code descobre e chama a skill automaticamente na conversa. Palavras-chave de gatilho:
|
|
49
|
+
|
|
50
|
+
- "me faça um PPT estilo revista"
|
|
51
|
+
- "gere um horizontal swipe deck"
|
|
52
|
+
- "editorial magazine style presentation"
|
|
53
|
+
- "slides de palestra estilo electronic ink"
|
|
54
|
+
|
|
55
|
+
## Fluxo de uso
|
|
56
|
+
|
|
57
|
+
A skill é um workflow estruturado de 6 passos; o Claude conduz:
|
|
58
|
+
|
|
59
|
+
1. **Esclarecimento de requisitos** — checklist de 6 perguntas: audiência, duração, material, imagens, tema, restrições rígidas
|
|
60
|
+
2. **Cópia do template** — `assets/template.html` → diretório do projeto, ajuste `<title>`, troque a paleta
|
|
61
|
+
3. **Preenchimento de conteúdo** — escolha entre os 10 esqueletos de layout, cole, edite o copy (com pré-checagem de classes + planejamento de ritmo das paletas antes)
|
|
62
|
+
4. **Autoavaliação** — confronto com `references/checklist.md`; questões P0 precisam passar todas
|
|
63
|
+
5. **Preview** — abre direto no navegador
|
|
64
|
+
6. **Iteração** — ajusta tamanho de fonte / altura / espaçamento via inline style
|
|
65
|
+
|
|
66
|
+
Detalhes em [`SKILL.md`](./SKILL.md).
|
|
67
|
+
|
|
68
|
+
## Estrutura de diretórios
|
|
69
|
+
|
|
70
|
+
```
|
|
71
|
+
magazine-web-ppt/
|
|
72
|
+
├── SKILL.md ← Skill 主文件:工作流、原则、常见错误
|
|
73
|
+
├── README.md ← 本文件
|
|
74
|
+
├── assets/
|
|
75
|
+
│ └── template.html ← 完整可运行的种子 HTML(CSS + WebGL + 翻页 JS 全配好)
|
|
76
|
+
└── references/
|
|
77
|
+
├── components.md ← 组件手册(字体、色、网格、图标、callout、stat、pipeline)
|
|
78
|
+
├── layouts.md ← 10 种页面布局骨架(可直接粘贴)
|
|
79
|
+
├── themes.md ← 5 套主题色预设(只能选不能自定义)
|
|
80
|
+
└── checklist.md ← 质量检查清单(P0 / P1 / P2 / P3 分级)
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
## Paletas predefinidas
|
|
84
|
+
|
|
85
|
+
Escolha uma em `references/themes.md` — **valores hex personalizados não são permitidos**; preservar a estética importa mais do que dar liberdade.
|
|
86
|
+
|
|
87
|
+
| Paleta | Cenário ideal |
|
|
88
|
+
|--------|---------------|
|
|
89
|
+
| 🖋 Tinta Clássica | Default genérico, lançamento comercial, quando estiver na dúvida |
|
|
90
|
+
| 🌊 Azul-Índigo Porcelana | Tecnologia / pesquisa / IA / lançamentos técnicos |
|
|
91
|
+
| 🌿 Tinta Floresta | Natureza / sustentabilidade / cultura / não-ficção |
|
|
92
|
+
| 🍂 Papel Kraft | Nostálgico / humanidades / literatura / revistas independentes |
|
|
93
|
+
| 🌙 Duna | Arte / design / criativo / galeria |
|
|
94
|
+
|
|
95
|
+
Para trocar a paleta basta substituir as 6 linhas de variáveis dentro do `:root{}` no início do `template.html`; todo o resto do CSS usa `var(--...)`.
|
|
96
|
+
|
|
97
|
+
## Princípios centrais de design
|
|
98
|
+
|
|
99
|
+
1. **Contenção acima de fogos** — o background WebGL só vaza na página hero
|
|
100
|
+
2. **Estrutura acima de decoração** — informação nasce de tamanho de fonte + contraste tipográfico + grid e respiro, não de sombras nem cards flutuantes
|
|
101
|
+
3. **Imagem é cidadã de primeira classe** — corte só pelo rodapé; topo e laterais ficam íntegros
|
|
102
|
+
4. **O ritmo vem das hero** — alternar hero / não-hero é o que evita cansar a vista
|
|
103
|
+
5. **Termos uniformes** — Skills permanece Skills, sem misturar tradução en-zh
|
|
104
|
+
|
|
105
|
+
## Referências visuais
|
|
106
|
+
|
|
107
|
+
- Diagramação da revista [*Monocle*](https://monocle.com)
|
|
108
|
+
- "Thin Harness, Fat Skills" do Garry Tan (YC)
|
|
109
|
+
- Série de PPTs de palestras presenciais do 歸藏
|
|
110
|
+
|
|
111
|
+
## Contribuindo
|
|
112
|
+
|
|
113
|
+
Bugs, problemas de tipografia, pedidos de novos layouts — abra Issue ou PR. Para mudanças, prefira:
|
|
114
|
+
|
|
115
|
+
- Adicionar classes em `template.html` para que `layouts.md` não use classes indefinidas
|
|
116
|
+
- Registrar pegadinhas em `checklist.md` no nível P0 / P1 / P2 / P3 correspondente
|
|
117
|
+
- Levar nova paleta para `themes.md` e indicar o cenário em que ela cabe
|
|
118
|
+
|
|
119
|
+
## Licença
|
|
120
|
+
|
|
121
|
+
MIT © 2026 [op7418](https://github.com/op7418)
|
|
@@ -0,0 +1,313 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: magazine-web-ppt
|
|
3
|
+
description: 生成"电子杂志 × 电子墨水"风格的横向翻页网页 PPT(单 HTML 文件),含 WebGL 流体背景、衬线标题 + 非衬线正文、章节幕封、数据大字报、图片网格等模板。当用户需要制作分享 / 演讲 / 发布会风格的网页 PPT,或提到"杂志风 PPT"、"horizontal swipe deck"、"editorial magazine"、"e-ink presentation"时使用。
|
|
4
|
+
triggers:
|
|
5
|
+
- "ppt"
|
|
6
|
+
- "deck"
|
|
7
|
+
- "slides"
|
|
8
|
+
- "presentation"
|
|
9
|
+
- "magazine"
|
|
10
|
+
- "杂志"
|
|
11
|
+
- "杂志风 PPT"
|
|
12
|
+
- "horizontal swipe"
|
|
13
|
+
- "horizontal swipe deck"
|
|
14
|
+
- "editorial magazine"
|
|
15
|
+
- "e-ink presentation"
|
|
16
|
+
- "网页 PPT"
|
|
17
|
+
- "发布会"
|
|
18
|
+
- "分享 PPT"
|
|
19
|
+
od:
|
|
20
|
+
mode: deck
|
|
21
|
+
scenario: marketing
|
|
22
|
+
default_for: deck
|
|
23
|
+
upstream: "https://github.com/op7418/guizang-ppt-skill"
|
|
24
|
+
preview:
|
|
25
|
+
type: html
|
|
26
|
+
entry: index.html
|
|
27
|
+
design_system:
|
|
28
|
+
requires: false
|
|
29
|
+
example_prompt: "帮我做一份杂志风的 PPT —— 关于'一人公司 · 被 AI 折叠的组织',25 分钟分享会,目标受众是设计师 + 创业者。先推荐一个方向(Monocle / WIRED / Kinfolk / Domus / Lab)让我选。"
|
|
30
|
+
---
|
|
31
|
+
|
|
32
|
+
# Magazine Web Ppt
|
|
33
|
+
|
|
34
|
+
## 这个 Skill 做什么
|
|
35
|
+
|
|
36
|
+
生成一份**单文件 HTML**的横向翻页 PPT,视觉基调是:
|
|
37
|
+
|
|
38
|
+
- **电子杂志 + 电子墨水**混血风格
|
|
39
|
+
- **WebGL 流体 / 等高线 / 色散背景**(hero 页可见)
|
|
40
|
+
- **衬线标题(Noto Serif SC + Playfair Display)+ 非衬线正文(Noto Sans SC + Inter)+ 等宽元数据(IBM Plex Mono)**
|
|
41
|
+
- **Lucide 线性图标**(不用 emoji)
|
|
42
|
+
- **横向左右翻页**(键盘 ← →、滚轮、触屏滑动、底部圆点、ESC 索引)
|
|
43
|
+
- **主题平滑插值**:翻到 hero 页时颜色和 shader 柔顺过渡
|
|
44
|
+
|
|
45
|
+
这个 skill 的美学不是"商务 PPT",也不是"消费互联网 UI"——它像 *Monocle* 杂志贴上了代码后的样子。
|
|
46
|
+
|
|
47
|
+
## 何时使用
|
|
48
|
+
|
|
49
|
+
**合适的场景**:
|
|
50
|
+
- 线下分享 / 行业内部讲话 / 私享会
|
|
51
|
+
- AI 新产品发布 / demo day
|
|
52
|
+
- 带有强烈个人风格的演讲
|
|
53
|
+
- 需要"一次做完,不用翻页工具"的网页版 slides
|
|
54
|
+
|
|
55
|
+
**不合适的场景**:
|
|
56
|
+
- 大段表格数据、图表叠加(用常规 PPT)
|
|
57
|
+
- 培训课件(信息密度不够)
|
|
58
|
+
- 需要多人协作编辑(这是静态 HTML)
|
|
59
|
+
|
|
60
|
+
## 工作流
|
|
61
|
+
|
|
62
|
+
### Step 0 · 选方向(Direction · 必做的第一步)
|
|
63
|
+
|
|
64
|
+
**在问 6 个澄清问题之前,先让用户在 5 个 magazine 方向里挑一个**。每个方向都把"主题色 / 推荐 layout / chrome 风格 / 推荐 slide 数"打包好,挑了方向就回答掉一半澄清问题。
|
|
65
|
+
|
|
66
|
+
打开 `references/styles.md`,**整段拷过来**给用户看 5 个方向的 1-line summary,然后让他选:
|
|
67
|
+
|
|
68
|
+
```
|
|
69
|
+
1. Monocle Editorial · 国际杂志风 ✦ 默认
|
|
70
|
+
2. WIRED Tech · 数据 + 工程
|
|
71
|
+
3. Kinfolk Slow · 慢生活 / 人文
|
|
72
|
+
4. Domus Architectural · 建筑 / 空间感
|
|
73
|
+
5. Lab / Reference · 学术 + 工艺手册
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
如果用户说"不知道,你推荐"——**默认推 Monocle Editorial**,因为它失败概率最低。如果用户提到"AI / benchmark / 技术发布"——推 WIRED;"读书 / 私享 / 朋友圈"——推 Kinfolk;"设计 / 建筑 / portfolio"——推 Domus;"研究 / 学术 / 方法论"——推 Lab。
|
|
77
|
+
|
|
78
|
+
挑完方向后,在项目目录下创建或更新 `项目记录.md`,第一行写清方向 + 主题色 + 受众 + 时长(模板见 `styles.md` 末尾)。**全程不要换方向**——半路换 = 前面全废。
|
|
79
|
+
|
|
80
|
+
### Step 1 · 需求澄清(**动手前必做**)
|
|
81
|
+
|
|
82
|
+
**如果用户已经给了完整的大纲 + 图片**,可以跳过直接进 Step 2。
|
|
83
|
+
|
|
84
|
+
**如果用户只给了主题或一个模糊想法**,用这 6 个问题逐个对齐后再动手。不要基于猜测就开始写 slide——一旦结构定错,后期翻修代价很高:
|
|
85
|
+
|
|
86
|
+
#### 6 问澄清清单
|
|
87
|
+
|
|
88
|
+
> 第 5 题已在 Step 0 选方向时一并回答(方向→主题色)。下面的 5 题里,第 5 题留白即可。
|
|
89
|
+
|
|
90
|
+
| # | 问题 | 为什么要问 |
|
|
91
|
+
|---|------|-----------|
|
|
92
|
+
| 1 | **受众是谁?分享场景?**(行业内部 / 商业发布 / demo day / 私享会) | 决定语言风格和深度 |
|
|
93
|
+
| 2 | **分享时长?** | 15 分钟 ≈ 10 页,30 分钟 ≈ 20 页,45 分钟 ≈ 25-30 页(每个方向的推荐范围见 `styles.md`) |
|
|
94
|
+
| 3 | **有没有原始素材?**(文档 / 数据 / 旧 PPT / 文章链接) | 有素材就基于素材,没有就帮他搭 |
|
|
95
|
+
| 4 | **有没有图片?放在哪?** | 详见下方"图片约定" |
|
|
96
|
+
| 5 | ~~**想要哪套主题色?**~~ | ✓ 已在 Step 0 由方向决定 |
|
|
97
|
+
| 6 | **有没有硬约束?**(必须包含 XX 数据 / 不能出现 YY) | 避免返工 |
|
|
98
|
+
|
|
99
|
+
#### 大纲协助(如果用户没有大纲)
|
|
100
|
+
|
|
101
|
+
用"叙事弧"模板搭骨架,再填内容:
|
|
102
|
+
|
|
103
|
+
```
|
|
104
|
+
钩子(Hook) → 1 页 : 抛一个反差 / 问题 / 硬数据让人停下来
|
|
105
|
+
定调(Context) → 1-2 页 : 说明背景 / 你是谁 / 为什么讲这个
|
|
106
|
+
主体(Core) → 3-5 页 : 核心内容,用 Layout 4/5/6/9/10 穿插
|
|
107
|
+
转折(Shift) → 1 页 : 打破预期 / 提出新观点
|
|
108
|
+
收束(Takeaway) → 1-2 页 : 金句 / 悬念问题 / 行动建议
|
|
109
|
+
```
|
|
110
|
+
|
|
111
|
+
叙事弧 + 页数规划 + 主题节奏表(见 `layouts.md`),**三张表对齐后**再进 Step 2。
|
|
112
|
+
|
|
113
|
+
大纲建议保存为 `项目记录.md` 或 `大纲-v1.md`,便于后续迭代。
|
|
114
|
+
|
|
115
|
+
#### 图片约定(告知用户)
|
|
116
|
+
|
|
117
|
+
在动手前向用户说清:
|
|
118
|
+
|
|
119
|
+
- **文件夹位置**:`项目/XXX/ppt/images/` 下(和 `index.html` 同级)
|
|
120
|
+
- **命名规范**:`{页号}-{语义}.{ext}`,例如 `01-cover.jpg` / `03-figma.jpg` / `05-dashboard.png`
|
|
121
|
+
- 页号补零便于排序
|
|
122
|
+
- 语义用英文,短、具体、和内容对应
|
|
123
|
+
- **规格建议**:
|
|
124
|
+
- 单张 ≥ 1600px 宽(避免大屏模糊)
|
|
125
|
+
- JPG 用于照片/截图,PNG 用于透明 UI/图表
|
|
126
|
+
- 总大小控制在 10MB 内(影响翻页流畅度)
|
|
127
|
+
- **如何替换**:保持**同名覆盖**最稳(HTML 里不用改路径);如果文件名变了,记得全局搜 `images/旧名` 改成新名
|
|
128
|
+
- **没图怎么办**:和用户对齐,可以先用占位色块生成结构,等图片后期补;但要告知 layout 4/5/10 等图文混排页没图就没法验证视觉效果
|
|
129
|
+
|
|
130
|
+
### Step 2 · 拷贝模板
|
|
131
|
+
|
|
132
|
+
从 `assets/template.html` 拷贝一份到目标位置(通常是 `项目/XXX/ppt/index.html`),同时在同级建一个 `images/` 文件夹准备接图片。
|
|
133
|
+
|
|
134
|
+
```bash
|
|
135
|
+
mkdir -p "项目/XXX/ppt/images"
|
|
136
|
+
cp "<SKILL_ROOT>/assets/template.html" "项目/XXX/ppt/index.html"
|
|
137
|
+
```
|
|
138
|
+
|
|
139
|
+
`template.html` 是一个**完整可运行**的文件——CSS、WebGL shader、翻页 JS、字体/图标 CDN 全已预设好,只有 `<main id="deck">` 里面是 3 个示例 slide(封面、章节幕封、空白填充页)。
|
|
140
|
+
|
|
141
|
+
#### 2.1 · 必改占位符(**容易漏**)
|
|
142
|
+
|
|
143
|
+
拷贝后立刻改掉以下占位符,否则浏览器 Tab 会显示"[必填] 替换为 PPT 标题"这种尴尬文字:
|
|
144
|
+
|
|
145
|
+
| 位置 | 原始 | 需改为 |
|
|
146
|
+
|------|------|--------|
|
|
147
|
+
| `<title>` | `[必填] 替换为 PPT 标题 · Deck Title` | 实际 deck 标题(如 `一种新的工作方式 · Luke Wroblewski`) |
|
|
148
|
+
|
|
149
|
+
每次拷贝完 template.html 第一件事:grep 一下"[必填]" 确认全部替换完。
|
|
150
|
+
|
|
151
|
+
#### 2.2 · 选定主题色(5 套预设 · 不允许自定义)
|
|
152
|
+
|
|
153
|
+
本 skill **只允许从 5 套精心调配的预设里选一套**,不接受用户自定义 hex 值——颜色搭配错了画面瞬间变丑,保护美学比给自由更重要。
|
|
154
|
+
|
|
155
|
+
| # | 主题 | 适合 |
|
|
156
|
+
|---|------|------|
|
|
157
|
+
| 1 | 🖋 墨水经典 | 通用 / 商业发布 / 不知道选啥的默认 |
|
|
158
|
+
| 2 | 🌊 靛蓝瓷 | 科技 / 研究 / 数据 / 技术发布会 |
|
|
159
|
+
| 3 | 🌿 森林墨 | 自然 / 可持续 / 文化 / 非虚构 |
|
|
160
|
+
| 4 | 🍂 牛皮纸 | 怀旧 / 人文 / 文学 / 独立杂志 |
|
|
161
|
+
| 5 | 🌙 沙丘 | 艺术 / 设计 / 创意 / 画廊 |
|
|
162
|
+
|
|
163
|
+
**操作**:
|
|
164
|
+
1. 基于内容主题推荐一套,或直接问用户选哪一套
|
|
165
|
+
2. 打开 `references/themes.md`,找到对应主题的 `:root` 块
|
|
166
|
+
3. **整体替换** `assets/template.html`(已拷贝版本)开头 `:root{` 块里标有"主题色"注释的那几行(`--ink` / `--ink-rgb` / `--paper` / `--paper-rgb` / `--paper-tint` / `--ink-tint`)
|
|
167
|
+
4. 其他 CSS 都走 `var(--...)`,无需任何其他改动
|
|
168
|
+
|
|
169
|
+
**硬规则**:
|
|
170
|
+
- 一份 deck 只用一套主题,不要中途换色
|
|
171
|
+
- 不要接受用户给的任意 hex 值——委婉拒绝并展示 5 套让选
|
|
172
|
+
- 不要混搭(例如 ink 取墨水经典、paper 取沙丘)——会彻底违和
|
|
173
|
+
|
|
174
|
+
### Step 3 · 填充内容
|
|
175
|
+
|
|
176
|
+
#### 3.0 · 预检:类名必须在 template.html 里有定义(**最重要**)
|
|
177
|
+
|
|
178
|
+
**这是所有生成问题的源头**。layouts.md 的骨架使用了很多类名(`h-hero` / `h-xl` / `stat-card` / `pipeline` / `grid-2-7-5` 等),如果 `assets/template.html` 的 `<style>` 里没有对应定义,浏览器会 fallback 到默认样式——大标题变成非衬线、数据卡片挤成一团、pipeline 糊成一行、图片堆到页面底部。
|
|
179
|
+
|
|
180
|
+
**在写任何 slide 代码之前:**
|
|
181
|
+
|
|
182
|
+
1. **先 Read `assets/template.html`**(至少读到 `<style>` 块末尾)
|
|
183
|
+
2. **对照 layouts.md 的 Pre-flight 列表**,确认你要用的每个类都在 `<style>` 里存在
|
|
184
|
+
3. 如果某个类缺失:**在 template.html 的 `<style>` 里补上**,不要在每个 slide 里 inline 重写
|
|
185
|
+
4. **template.html 是唯一的类名来源**——不要发明新类名,如需自定义用 `style="..."` inline
|
|
186
|
+
|
|
187
|
+
常见容易遗漏的类(必须预先确认存在):
|
|
188
|
+
`h-hero` / `h-xl` / `h-sub` / `h-md` / `lead` / `kicker` / `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` / `chrome` / `foot`
|
|
189
|
+
|
|
190
|
+
#### 3.0.5 · 规划主题节奏(**和类预检同等重要**)
|
|
191
|
+
|
|
192
|
+
**在挑布局之前**,必须先列出每一页的主题 class(`hero dark` / `hero light` / `light` / `dark`)并写到文档或草稿里对齐。详细规则看 `references/layouts.md` 开头的"主题节奏规划"一节。
|
|
193
|
+
|
|
194
|
+
**强制规则**:
|
|
195
|
+
|
|
196
|
+
- 每页 section 必须带 `light` / `dark` / `hero light` / `hero dark` 之一,不要只写 `hero`
|
|
197
|
+
- 连续 3 页以上同主题 = 视觉疲劳,不允许
|
|
198
|
+
- 8 页以上必须有 ≥1 个 `hero dark` + ≥1 个 `hero light`
|
|
199
|
+
- 整个 deck 不能只有 `light` 正文页,必须有 `dark` 正文页制造呼吸
|
|
200
|
+
- 每 3-4 页插入 1 个 hero 页(封面/幕封/问题/大引用)
|
|
201
|
+
|
|
202
|
+
**生成后自检**:`grep 'class="slide' index.html` 列出所有主题,人工确认节奏合理再交付。
|
|
203
|
+
|
|
204
|
+
#### 3.1 · 挑布局
|
|
205
|
+
|
|
206
|
+
**不要从零写 slide**。打开 `references/layouts.md`,里面有 10 种现成布局骨架,每种都是完整可粘贴的 `<section>` 代码块:
|
|
207
|
+
|
|
208
|
+
| Layout | 用途 |
|
|
209
|
+
|---|---|
|
|
210
|
+
| 1. 开场封面 | 第 1 页 |
|
|
211
|
+
| 2. 章节幕封 | 每幕开场 |
|
|
212
|
+
| 3. 数据大字报 | 抛硬数据 |
|
|
213
|
+
| 4. 左文右图(Quote + Image) | 身份反差 / 故事 |
|
|
214
|
+
| 5. 图片网格 | 多图对比 / 截图实证 |
|
|
215
|
+
| 6. 两列流水线(Pipeline) | 工作流程 |
|
|
216
|
+
| 7. 悬念收束 / 问题页 | 幕末 / 收尾 |
|
|
217
|
+
| 8. 大引用页(Big Quote) | 衬线金句 / takeaway |
|
|
218
|
+
| 9. 并列对比(Before / After) | 旧模式 vs 新模式 |
|
|
219
|
+
| 10. 图文混排(Lead Image + Side Text) | 信息密集的图文页 |
|
|
220
|
+
|
|
221
|
+
选对应 layout,粘过去,改文案和图片路径即可。**务必先完成 3.0 预检**。
|
|
222
|
+
|
|
223
|
+
#### 3.2 · 图片比例规范
|
|
224
|
+
|
|
225
|
+
永远用**标准比例**,不要用原图奇葩比例(如 `2592/1798`):
|
|
226
|
+
|
|
227
|
+
| 场景 | 推荐比例 |
|
|
228
|
+
|------|---------|
|
|
229
|
+
| 左文右图 主图 | 16:10 或 4:3 + `max-height:56vh` |
|
|
230
|
+
| 图片网格(多图对比) | **固定 `height:26vh`**,不用 aspect-ratio |
|
|
231
|
+
| 左小图 + 右文字 | 1:1 或 3:2 |
|
|
232
|
+
| 全屏主视觉 | 16:9 + `max-height:64vh` |
|
|
233
|
+
| 图文混排小插图 | 3:2 或 3:4 |
|
|
234
|
+
|
|
235
|
+
**图片绝不使用 `align-self:end`**——会滑到 cell 底被浏览器工具栏遮挡。用 grid 容器 + `align-items:start`(template 已预设)让图片贴顶即可;左列若想贴底,用 flex column + `justify-content:space-between`。
|
|
236
|
+
|
|
237
|
+
组件细节(字体、颜色、网格、图标、callout、stat-card 等)在 `references/components.md`。
|
|
238
|
+
|
|
239
|
+
### Step 4 · 对照检查清单自检
|
|
240
|
+
|
|
241
|
+
生成完一定要打开 `references/checklist.md`,逐项对照。里面总结了**真实迭代过程中踩过的所有坑**,P0 级别的问题(emoji、图片撑破、标题换行、字体分工)必须全部通过。
|
|
242
|
+
|
|
243
|
+
特别要注意的几条:
|
|
244
|
+
|
|
245
|
+
1. **大标题必须是衬线字体**——如果显示成非衬线,99% 是 Step 3.0 预检没做,`h-hero` 类在 template.html 里缺失
|
|
246
|
+
2. **图片网格里只用 `height:Nvh`,不用 `aspect-ratio`**(会撑破)
|
|
247
|
+
3. **图片不能堆到页面底部**——不要用 `align-self:end`,用 grid + `align-items:start`(见 Step 3.2)
|
|
248
|
+
4. **图片只能用标准比例**(16:10 / 4:3 / 3:2 / 1:1 / 16:9),不要复制原图的奇葩比例
|
|
249
|
+
5. **中文大标题 ≤ 5 字且 `nowrap`**(避免 1 字 1 行)
|
|
250
|
+
6. **用 Lucide,不用 emoji**
|
|
251
|
+
7. **标题用衬线,正文用非衬线,元数据用等宽**
|
|
252
|
+
|
|
253
|
+
### Step 5 · 本地预览
|
|
254
|
+
|
|
255
|
+
直接在浏览器打开 `index.html` 就行。macOS 下:
|
|
256
|
+
|
|
257
|
+
```bash
|
|
258
|
+
open "项目/XXX/ppt/index.html"
|
|
259
|
+
```
|
|
260
|
+
|
|
261
|
+
不需要本地服务器。图片走相对路径 `images/xxx.png`。
|
|
262
|
+
|
|
263
|
+
### Step 6 · 迭代
|
|
264
|
+
|
|
265
|
+
根据用户反馈修改——模板的 CSS 已经高度参数化,90% 的调整都是改 inline style(字号 `font-size:Xvw` / 高度 `height:Yvh` / 间距 `gap:Zvh`)。
|
|
266
|
+
|
|
267
|
+
---
|
|
268
|
+
|
|
269
|
+
## 资源文件导览
|
|
270
|
+
|
|
271
|
+
```
|
|
272
|
+
magazine-web-ppt/
|
|
273
|
+
├── SKILL.md ← 你正在读
|
|
274
|
+
├── assets/
|
|
275
|
+
│ ├── template.html ← 完整的可运行模板(种子文件)
|
|
276
|
+
│ └── example-slides.html ← 9 页样例 deck(用于 Examples 预览)
|
|
277
|
+
└── references/
|
|
278
|
+
├── styles.md ← 5 个 magazine 方向(Monocle / WIRED / Kinfolk / Domus / Lab)
|
|
279
|
+
├── components.md ← 组件手册(字体、色、网格、图标、callout、stat、pipeline...)
|
|
280
|
+
├── layouts.md ← 10 种页面布局骨架(可直接粘贴)
|
|
281
|
+
├── themes.md ← 5 套主题色预设(只能选不能自定义)
|
|
282
|
+
└── checklist.md ← 质量检查清单(P0/P1/P2/P3 分级)
|
|
283
|
+
```
|
|
284
|
+
|
|
285
|
+
**加载顺序建议**:
|
|
286
|
+
1. 先读完 `SKILL.md`(这个文件)了解整体
|
|
287
|
+
2. **Step 0 选方向时,读 `styles.md`**——5 个方向各自打包好了主题色 + 推荐 layout + chrome 风格
|
|
288
|
+
3. Step 1 需求澄清完成后,如果方向需要确认,再读 `themes.md` 看色板细节
|
|
289
|
+
4. **动手前 Read `assets/template.html` 的 `<style>` 块**——这是类名的唯一来源,缺类会导致整页样式崩
|
|
290
|
+
5. 读 `layouts.md` 挑布局(顶部有 Pre-flight 类名清单和主题节奏规划)
|
|
291
|
+
6. 细节调整时读 `components.md` 查组件
|
|
292
|
+
7. 生成后读 `checklist.md` 自检(顶部 P0-0 规则强制预检)
|
|
293
|
+
|
|
294
|
+
## 核心设计原则(哲学)
|
|
295
|
+
|
|
296
|
+
> 这些原则是"一人公司"分享 PPT 的 5 轮迭代总结出来的。违反其中任何一条,视觉感都会垮。
|
|
297
|
+
|
|
298
|
+
1. **克制优于炫技** — WebGL 背景只在 hero 页透出,普通页几乎看不见
|
|
299
|
+
2. **结构优于装饰** — 不用阴影、不用浮动卡片、不用 padding box,一切信息靠**大字号 + 字体对比 + 网格留白**
|
|
300
|
+
3. **内容层级由字号和字体共同定义** — 最大衬线 = 主标题,中衬线 = 副标,大非衬线 = lead,小非衬线 = body,等宽 = 元数据
|
|
301
|
+
4. **图片是第一公民** — 图片只裁底部,保证顶部和左右完整;网格用 `height:Nvh` 固定,不要用 `aspect-ratio` 撑
|
|
302
|
+
5. **节奏靠 hero 页** — hero 和 non-hero 交替,才不累眼睛
|
|
303
|
+
6. **术语统一** — Skills 就是 Skills,不要中英混合翻译
|
|
304
|
+
|
|
305
|
+
## 参考作品
|
|
306
|
+
|
|
307
|
+
本 skill 的视觉基调参考了:
|
|
308
|
+
|
|
309
|
+
- 歸藏 "一人公司:被 AI 折叠的组织" 分享(2026-04-22,27 页)
|
|
310
|
+
- *Monocle* 杂志的版式
|
|
311
|
+
- YC 总裁 Garry Tan "Thin Harness, Fat Skills" 那篇博客的 demo
|
|
312
|
+
|
|
313
|
+
可以把它们当做风格锚点。
|