把想法、大纲、文档或草稿变成结构清晰、设计精良的企业级 HTML 演示文稿。
---
name: slide-writer
display_name: Slide-Writer
description: 把想法、大纲、文档或草稿变成结构清晰、设计精良的企业级 HTML 演示文稿。
version: 1.0.0
author: Feei
homepage: https://github.com/FeeiCN/slide-writer
repository: https://github.com/FeeiCN/slide-writer
license: MIT
tags:
- presentation
- slides
- ppt
- keynote
- html
- storytelling
- enterprise
entry: SKILL.md
language: zh-CN
compatible_with:
- claude-code
- codex
---
# Slide-Writer
把任意输入(想法、大纲、草稿文档、会议纪要)转化为企业级 HTML 演示文稿,自动匹配所在公司的品牌主题。
## 核心原则
1. **品牌一致** — 从请求中自动识别公司,应用对应品牌色主题;内置 14 家互联网公司主题。
2. **内容为王** — 自动润色每句话:去冗余、精简、让表达更有力。
3. **不溢出** — 每张幻灯片必须在 100vh 内完整呈现,内容多则分页,绝不出现滚动条。
4. **单文件交付** — 输出单个 `.html` 文件,CSS/JS 全部内联,零依赖,浏览器直接打开。
---
## Phase 0:准备
### 自动更新(第一步,必须执行)
```bash
git pull --ff-only
```
成功 → 静默继续;失败(无网络 / 有冲突)→ 静默忽略,继续使用当前版本。
### 模式识别
- **Mode A:全新制作** — 从主题/大纲/草稿创建,进入 Phase 1。
- **A1:内容压缩** — 用户提供了演讲稿、大纲或草稿(输入字数 ≥ 200 字),目标是提炼精简,应用演讲稿转PPT规则和密度上限。
- **A2:主题创作** — 用户只提供了主题/标题(输入字数 < 200 字),目标是**主动生成丰富内容**,充分展开每个子话题,**不受演讲稿压缩规则约束**,卡片描述上限放宽至 120 字,页数默认 10–15 页。
- **Mode B:增强改稿** — 在现有 HTML 上修改或扩充内容:
1. 完整读取现有 HTML,识别所有 `<section>` 的 `id`、`class`、标题,输出当前幻灯片清单
2. **范围判断**:修改 ≤ 3 张 → 精确改稿;修改 > 30% 或新增 > 原有 → 建议用 Mode A 重新生成
3. 识别原有主题(用户未要求更换则保留)
4. 按用户描述(序号、标题关键词)定位目标 `<section>`,**确认后再操作**
5. 只改被点名的 `<section>`,新增页插入逻辑最合适的位置
6. 未被点名的幻灯片保持原样,不做"顺手优化"
7. 改完检查:目录议程项数与内容页数是否一致?章节逻辑是否连贯?不一致则列出,询问用户是否同步更新
8. 执行与 Mode A 相同的质量检查
### 主题检测
读取 [themes/_index.md](themes/_index.md),从用户请求提取公司关键词,优先级从高到低:
1. 用户明确指定的公司名、产品名
2. 署名中的部门/团队名称
3. 内容中出现的公司名
- 识别到 → 记录主题 ID 和 `themes/[id].md` 路径
- 未识别到 → 默认蚂蚁集团+支付宝双 Logo 主题
- 多品牌冲突 → 按 `themes/_index.md` 优先级链执行
---
## Phase 1:内容收集
一次性收集以下信息(运行环境支持 `AskUserQuestion` 则用它补问,否则发一条消息补问):
| 字段 | 说明 |
|---|---|
| **公司** | 所在公司或品牌名称(用于匹配主题色) |
| **主题** | 演讲 / 汇报的核心主题 |
| **受众** | 管理层 / 团队内部 / 跨部门 / 外部客户 |
| **页数** | 5–8 页 / 10–15 页 / 20 页以上 |
| **内容** | 粘贴大纲、草稿或关键要点;只有主题时说明即可 |
| **署名** | 演讲者姓名 + 角色/岗位/Title(用于封面) |
| **日期** | 演讲日期(默认今天) |
**缺失字段的推断规则:**
- **公司** → 从内容、署名、部门名称推断;仍无法识别则默认蚂蚁集团
- **受众** → 含"汇报/review/决策/管理层" → 管理层;含"分享/复盘/团队" → 团队内部;含"提案/客户/合作" → 外部客户;无法判断 → 内部汇报
- **页数** → 按模式和字数推断:
- **Mode A2(主题创作)**:默认 10–15 页,主题内涵丰富(含多子话题、历史文化、数据等)可到 15–20 页;
- **Mode A1(内容压缩)**:< 500 字 → 4–6 页;500–1500 字 → 8–12 页;1500–3000 字 → 12–18 页;> 3000 字 → 18 页以上;
- 推断结果与内容明显不符时,进入 Phase 2 前显式确认
- **日期** → 默认今天
- **署名** → 从内容或当前用户信息推断;无法推断则默认"演讲者"
Phase 1 完成后通知:`已收集:[公司] · [受众] · [页数] 页 · [署名]`
---
## Phase 2:结构规划
### 必须包含的页面
| 页面类型 | Slide Class | 豁免条件 |
|---|---|---|
| 封面页 | `slide-cover` | 无豁免 |
| 目录页 | `slide-white` | 总页数 ≤ 6 时省略 |
| 章节过渡页 | `slide-section` | 该章节内容页 < 3 时省略;章节页总数不超过内容页的 1/3 |
| 结尾页 | `slide-qa` | 无豁免 |
> **小型 PPT(≤ 6 页)**:封面 + 内容页 + 结尾,不强插目录和章节页。
### 演讲稿转 PPT 规则(**仅 Mode A1** 执行,Mode A2 跳过)
1. **PPT 是辅助,不是原文上墙** — 禁止逐段照搬,单页文字量必须明显少于讲稿密度。
2. **一页一判断** — 提炼一个结论句作为标题,保留 2–4 个支撑点;多论点拆成多页。
3. **留金句,删铺垫** — 保留数字、判断、类比;删寒暄、重复、口语化过渡;引用只取 1 句。
4. **3 秒可读** — 满足任一条即达标:① 单页总字数 ≤ 80 字;② bullet ≤ 4 条且每条 ≤ 15 字;③ 数字 ≤ 3 个且说明 ≤ 30 字;④ 视觉块占页面 ≥ 40%。
5. **第一视角** — 标题优先用"我们 / 今天想讲",不用"作者认为""整场发言围绕"。
不适合搬到 PPT 的内容:开场寒暄、重复表达、口语化连接词、大段故事细节、抒情句、可口头补充的背景说明。
### 主题创作原则(**仅 Mode A2** 执行)
1. **内容深度优先** — 每个子话题充分展开,给出背景、细节、意义,让读者看完幻灯片本身就能获得完整信息,无需演讲者补充。
2. **完整性** — 凡主题中含有明确数量的事物(如"十景"、"三原则"、"五步骤"),必须全部列出,不得因排版便利而截断;超出单页容量则拆分为多页并在标题注明"(上)""(下)"。
3. **引用原话** — 文化/历史类主题应引用原始诗句、史料或名言,不用泛泛描述代替。
4. **卡片描述上限放宽** — 信息卡片描述 ≤ 120 字,步骤卡描述 ≤ 80 字,单页总字数 ≤ 300 字;超出则拆页,不压缩内容。
5. **标题是结论,不是话题** — 即便是介绍性内容,标题也应给出判断("苏堤是人工干预自然的最美典范"而非"苏堤简介")。
### 视觉化原则
1. **先做结构,再放文字** — 优先用数字、卡片、对比、流程承载内容。
2. **主视觉节奏清晰** — 多个视觉区块间必须有明确层级和分组;内容超出屏幕时拆页,不缩字号强塞。
3. **把段落改成组件** — 长段优先改写成组件;可复用 `stat-block`、`step-card`、`quote-box`、`agenda-item`,也可按内容需要设计新的页面骨架与信息组件。
4. **关键词可扫读** — 数字、判断句必须一眼能扫到;长句只作补充。
5. **多横向,少纵向** — 优先并列卡片、对比、矩阵,少用连续纵向文字。
6. **每 3–4 页变换节奏** — 穿插章节页、金句页、大字判断页或轻内容页。
7. **先判内容形态,再选版式** — 见「内容类型 → 组件选择」表。
8. **标题区固定** — 所有内容页标题区位置一致,不因正文密度漂移。
9. **SVG 优先** — 数量对比、趋势、占比、流程优先用内联 SVG;禁止纯数字+文字句子描述可视化数据。
10. **视觉效果分层** — 重点卡片叠加渐变背景 + 顶部色条 + pill 标签;径向渐变光圈作点缀,不要每张卡都加。
11. **组件库是起点,不是边界** — `components.md` 提供的是高频可复用参考,不是完整上限;当主题更适合地图、时间带、关系网、年表、分镜、注释图、海报式大字、档案卡、实物标注、时间切片、城市剖面等表达时,应优先为内容发明更合适的新组件。
### 内容类型 → 组件选择
在写每页 HTML 前,先判断内容形态,再选布局。优先级:**页面骨架 > 成组组件 > 普通 bullet**。下表是推荐起点,不是限制清单;若现有组件不够贴合,应自定义新骨架而不是勉强套用。
| 内容形态 | 推荐组件 / 骨架 | 避免 |
|---|---|---|
| 全文总览 / 章节预告 | `agenda-item`、分组目录页 | 普通 bullet 平铺目录 |
| 开场判断 / 问题定义 | 开场钩子页、`highlight-box` + `info-card` | 整页长段正文 |
| 单一核心结论 | `highlight-box`、`stat-block`、大数字 | 密集列表或多主题混页 |
| 核心结论 + 数据支撑 | `insight-panel` | 判断句和数字分散在两张独立卡片 |
| 并列要点 / 三原则 | `three-col`、`info-card`、`stat-block` | 三个平级观点写成纵向长段 |
| 双对象对比 | `two-col`、左右图文混排 | 单列顺序写法 |
| 分阶段推进 | `step-card`、`step-flow-grid` | 普通 bullet 描述"第一第二第三" |
| 月度 / 季度路线图 | `roadmap-col` | 普通 step-card 忽略时间轴感 |
| 工作流 / 研发流程 | `flow-item`(4列×N行) | 有序列表平铺 8 个步骤 |
| 能力成熟度 / 等级体系 | `level-row` | 普通 bullet 描述各等级 |
| 组织支撑 / 能力体系 | `support-board`、`support-card`、`role-card` | 多段正文描述体系 |
| 责任清单 / 人员分工 | `support-mini-card` + `@负责人` | 普通 bullet 列名字 |
| 多角色流转 / 跨方协同 | `demand-flow-board` | 静态列表描述角色 |
| 数据 / 占比 / 趋势 | `stat-block`、进度条、SVG 图表、表格 | 只写数字句子无图形支撑 |
| 排名 / 优先级 | `bar-rank` | 纯数字列表 |
| 业务线 / 产品集合 | `tag-cloud` | 等高等大标签平铺 |
| 产品截图 | `browser-mockup` | 裸放图片无上下文 |
| 引用原话 | `quote-box`、`insight` | 堆多段长引用 |
| 结尾总结 | 分组总结页、`agenda-item`、`highlight-box` | 结尾再展开大量新信息 |
**组件约束:**
- 先选骨架,再选骨架内组件;强结构页(`support-board`、`demand-flow-board`)不退回普通卡片页。
- 卡片未铺满一行时容器收窄居中:1张→40%、2张→60%、3张→80%、4张以上→100%;用 `style="max-width:X%;margin:0 auto;"` 写在容器上。
- 内容偏少时 `slide-body` 显式加 `justify-content:center`,避免内容贴在上半屏。
- `components.md` 是参考库,不是白名单。允许自定义 HTML、CSS class 和新的信息组件,只要遵守当前模板的 CSS 变量、字号体系、留白系统与交互约束。
- 自定义组件应优先解决“现有组件表达不清”的问题,而不是只换视觉皮肤;新组件必须有清晰的信息任务,例如表达时间跨度、地理关系、因果链、空间层级、证据标注、版本差异、结构剖面。
- 新组件优先保持语义化命名,例如 `timeline-band`、`map-note-card`、`artifact-callout`、`split-metric-stage`、`city-axis-board`,避免无语义的 `box-1`、`layout-a`。
- 新组件可以是整页骨架,不必退化成卡片拼贴;允许使用注释线、时间轴带、分层底图、局部放大框、编号锚点、档案标签、印章式视觉、报纸栏、策展墙、编年表、示意地图等展示方式。
- **叙述型卡片页禁止 5 列**:含标题+描述+bullet 的解释型页面最多 4 列;5 列只用于极短标签卡或纯图标卡。
- **禁止"上实下空"**:页面底部留白明显大于顶部时,视为未完成布局。
### 新组件设计规则
当需要超出 `components.md` 时,按以下规则设计:
1. **先定义信息任务** — 先说清楚这页要表达的是时间、空间、关系、证据、对照、层次还是叙事,再决定组件形态。
2. **一页只引入 1 个主创意** — 可以有辅助组件,但主视觉语言必须单一,避免一页内同时出现时间轴 + 地图 + 大表格 + 多层卡片。
3. **可扫读优先于炫技** — 新组件必须让读者 3 秒内看懂主结论,不能为了“新”而牺牲信息获取速度。
4. **结构先于装饰** — 先确定信息区块、阅读顺序、锚点和对齐关系,再加渐变、阴影、纹理、印章、边框等装饰。
5. **允许为主题定制组件** — 历史类可用编年轴、文物注释卡、古今对照图;战略类可用战区图、优先级棋盘;产品类可用分镜、界面放大镜、漏斗剧场;教育类可用黑板式推演、题眼拆解图。
6. **复用已有设计语言** — 即便新建组件,也要继续使用现有颜色变量、圆角、阴影、字号层级和 reveal 动画,不要做成另一个完全割裂的系统。
7. **能抽象再抽象** — 如果某个新组件在 2 页以上重复出现,第二次开始应抽成稳定 class 命名,而不是每页一套散装内联样式。
### 内容密度规则
| 内容类型 | Mode A2(主题创作) | Mode A1(内容压缩) |
|---|---|---|
| 文字要点 | 10–15 条 bullet,每条 ≤ 40 字 | **6–8 条**,每条 ≤ 25 字 |
| 信息卡片(横向) | 5–6 列,描述 ≤ 120 字 | **4–5 列**,描述 ≤ 50 字 |
| 信息卡片(纵向) | 单列 ≤ 10 张,描述 ≤ 120 字/张 | 单列 ≤ 6 张,描述 ≤ 35 字/张 |
| 数据统计 | 6–9 个 stat-block,配 1–2 句解读 | 6 个,配 1 句解读 |
| 对比/流程 | 4–6 个 step-card,描述 ≤ 80 字 | **4 个**,描述 ≤ 35 字 |
| 表格 | 最多 12 行 × 6 列 | 最多 8 行 × 5 列 |
| 引用原话 | 1–3 段,每段 ≤ 150 字 | 1 段,**≤ 80 字** |
| 卡片描述正文 | **3–5 句话**,≤ 120 字 | **2–3 句话**,≤ 50 字 |
| 单页总字数 | ≤ 300 字 | ≤ 150 字 |
超出限制 → 自动拆成多页,页间用连贯的过渡标题衔接。
### 布局多样性
**规划完成后,进入 Phase 3 前必须执行以下自检:**
1. 统计各类型布局的页数(多列卡片、流程、bullet、纯视觉)
2. 检查局部连续约束:
- `three-col` / `info-card` ≥ 4 连续 → 中间插入过渡页或大字判断页
- `step-card` ≥ 3 连续 → 第 4 页换其他骨架
- `styled-list` ≥ 4 连续 → 至少 1 页改为卡片或图表
3. 检查全局约束:
- 多列卡片页占内容页 > 55% → 替换超出部分
- 总页数 > 10 且无纯视觉页 → 插入至少 1 页(建议放中段)
4. 有调整则在规划清单中用 `[调整]` 标注改动位置
### 文字润色(自动执行)
1. **去冗余** — 删除"我们认为""需要指出的是"等无信息量前缀。
2. **名词化** — "进行分析"→"分析","做出决策"→"决策"。
3. **数字化** — 只润色原文已有数字的表达("百分之三十七"→"37%");禁止编造原文无源的具体数字。
- ✅ 原文含"50+"→ 保留"50+ 轮测试";原文含"故障率""下降"→ 可补"故障率下降 40%"
- ❌ 原文"取得成果"→ 不可杜撰"节省 200 万元";原文"反馈不错"→ 不可杜撰"满意度 92%"
4. **动词有力** — 用"推进""落地""打通""提升"替代"做""进行""开展"。
5. **层级清晰** — 主标题是结论/判断,副标题是补充说明,内容是支撑。
6. **引用克制** — 只保留最有代表性的 1 句;同页不出现多段长引用。
Phase 2 完成后通知:`规划完成,共 N 张,开始生成…`
---
## Phase 3:生成 HTML
### Step 3.1:准备文件
**① 复制模板**
```bash
cp template.html [输出文件名].html
```
- 禁止直接编辑 `template.html` 本身
- 文件名使用英文小写 + 连字符,例如 `antgroup-q1-review.html`
**② 并行读取**(同时发起)
- **`themes/[id].md`** — 获取 CSS 变量、`.slide-section` / `.slide-qa` 覆盖、logo 路径
- **`components.md`** — 只 Grep Phase 2 中用到的组件章节,不必全读
- **`components.md`** — 作为高频组件参考;若规划包含创新布局,只需读取相关章节借鉴命名、字号和留白,不要把它当成白名单
- **`icons.md`**(含图标槽时按需 Grep)— 中文主题 → 英文图标名参考:
| 中文关键词 | 推荐图标名 |
|---|---|
| 安全、防护、权限、合规 | `shield`, `lock`, `eye-off` |
| 数据、分析、统计、报告 | `bar-chart-2`, `pie-chart`, `trending-up` |
| 用户、客户、团队、人员 | `users`, `user`, `user-check` |
| 流程、步骤、推进、路径 | `arrow-right`, `git-branch`, `navigation` |
| 目标、战略、方向、规划 | `target`, `flag`, `compass` |
| 技术、系统、架构、平台 | `cpu`, `server`, `layers` |
| 效率、性能、速度、优化 | `zap`, `clock`, `activity` |
| 成本、金融、收益、预算 | `dollar-sign`, `credit-card`, `trending-down` |
| 协同、沟通、对接、整合 | `link`, `share-2`, `message-circle` |
| 风险、问题、告警、异常 | `alert-triangle`, `x-circle`, `bell` |
| 创新、产品、功能、特性 | `star`, `package`, `box` |
| 运营、推广、增长、运作 | `trending-up`, `repeat`, `refresh-cw` |
### Step 3.2:填充占位符
`template.html` 已内置蚂蚁集团默认值(双 logo、页脚文字)。标题、主题样式、logo 全部改为脚本直接写回 HTML,不再手工替换。
**① 标题**
**② 主题样式**
**③ Logo**
```bash
# `theme-id` 默认为 `ant-group`
python3 scripts/apply-template-branding.py [文件名].html \
--title "[演讲主题]" \
--speaker "[演讲者]" \
--theme-id [theme-id]
```
规则:
- `theme-id=ant-group` 时保留 `<!-- %%THEME_STYLE%% -->`
- 其他主题从 `themes/[id].md` 的 `## CSS` 代码块注入 `<style>...</style>`
- `#globalLogoGroup` 是唯一 logo 节点,**禁止在任何 `<section>` 内写 logo**
- logo 文件缺失时按脚本 fallback;必要时自动隐藏并输出 warning
**④ 幻灯片内容(必填)**
```
old: <!-- %%SLIDES%% -->
new: 所有 <section> 幻灯片 HTML
```
**主题应用说明:**
- `.slide-section` / `.slide-qa` 必须用 `!important` 覆盖基础 CSS 中的硬编码渐变
- `--primary-pale` 会自动影响 `info-card` 背景、`agenda-item` hover 等,无需逐一覆盖
### Step 3.3:写幻灯片
每张写入前先输出进度:`→ 03/12 技术架构现状`(序号补零到总数位数)
**封面页**
```html
<section class="slide slide-cover" id="slide-1">
<div class="cover-arcs" aria-hidden="true">
<div class="arc arc-1"></div><div class="arc arc-2"></div><div class="arc arc-3"></div>
</div>
<div class="cover-top reveal" style="display:flex;align-items:center;">
<span style="color:rgba(255,255,255,0.65);font-size:clamp(0.65rem,1.1vw,0.85rem);">[部门]</span>
</div>
<div class="cover-main">
<h1 class="cover-title reveal">[主标题]</h1>
<p class="cover-subtitle reveal">[副标题]</p>
<p class="reveal" style="font-size:clamp(0.85rem,1.5vw,1.1rem);color:#fff;font-weight:700;">[姓名|角色/Title]</p>
</div>
<div class="cover-bottom"><div class="cover-date reveal">[日期]</div></div>
</section>
```
**内容页(白色)**
```html
<section class="slide slide-white" id="slide-N">
<div class="slide-header center-stack">
<span class="header-mark"></span>
<h2 class="header-title">[结论/判断句]</h2>
<p class="header-sub">[补充说明]</p>
</div>
<div class="slide-body" style="justify-content:center;">
<!-- 组件区 -->
</div>
</section>
```
**章节过渡页**
```html
<section class="slide slide-section" id="slide-N">
<p class="section-num reveal">PART [N]</p>
<h2 class="section-title reveal">[章节标题]</h2>
<p class="section-desc reveal">[一句话说明本章节要回答的问题]</p>
</section>
```
**结尾页**
```html
<section class="slide slide-qa" id="slide-N">
<h2 class="qa-title reveal">Q&A</h2>
<p class="qa-sub reveal">[感谢语]</p>
</section>
```
**写入约束(所有幻灯片必须遵守):**
| 场景 | 写法 |
|---|---|
| 普通间距、字号 | `clamp()` 或 CSS 变量 |
| 固定 px 尺寸 | `calc(Npx * var(--vp-scale, 1))` |
| 容器最大宽度 | `min(calc(XYZpx * var(--vp-scale, 1)), 100%)` |
| `max-width` 写死 px | **禁止** |
| 内容区宽度 | `<div style="width:min(100%,var(--deck-safe-width));margin:0 auto;">` |
**密度自检**(每页必须执行,按模式选对应上限):
| 检查项 | A2 主题创作上限 | A1 内容压缩上限 | 处理 |
|---|---|---|---|
| bullet 条数 | ≤ 15 条 | ≤ 8 条 | 超出则拆页 |
| 每条 bullet 字数 | ≤ 40 字 | ≤ 25 字 | 超出则压缩 |
| 单页总字数 | ≤ 300 字 | ≤ 150 字 | 超出则拆页 |
| info-card 描述 | ≤ 120 字/张 | ≤ 35 字/张 | A1 超出则精简;A2 超出则拆页 |
| 标题类型 | 结论句 | 结论句 | 话题词改判断句 |
---
## Phase 4:输出
**Step 4.1:保存**
文件名英文小写 + 连字符;中文关键词转拼音或英译。
**Step 4.2:单体化兜底扫描**
logo 应在 Step 3.2 ③ 直接从 `themes/logos/*.txt` 写入。此步骤仅处理其他外部图片遗漏的边缘情况:
```bash
python3 scripts/inline-images.py [文件名].html
```
**Step 4.3:Smoke Test(必须执行,不得跳过)**
生成完成后立即运行静态检查;失败时必须修复后重跑,不得跳过也不得仅凭”看起来没问题”省略:
```bash
./scripts/smoke-test.sh [文件名].html
```
> **执行后在回复中明确写出:** `smoke-test: passed(N 张幻灯片)` 或 `smoke-test: FAILED — [原因]`。未写出视为未执行。
**Step 4.4:用浏览器直接打开文件(必须执行,不得跳过)**
```bash
open [文件名].html
```
> **执行后在回复中明确写出:** `已用 open 打开浏览器` 或 `受环境限制无法打开 — [原因]`。未写出视为未执行。
成功标准:浏览器直接打开本地 HTML 文件,且不依赖本地 HTTP 服务。
**Step 4.5:最终交付摘要(必须输出,格式固定)**
在回复的最后输出以下固定格式的摘要块,所有字段必填,缺任何一项视为未完成:
```
📦 交付摘要
文件路径:[绝对路径或相对路径]
文件大小:[X KB]
幻灯片数:[N] 张
主题:[theme-id]
smoke-test:通过 / 失败([原因])
浏览器:已打开 / 无法打开([原因])
导航:方向键 / 空格翻页 · 右侧圆点 · F 全屏
```
### Phase 4 完成门槛(硬性约束)
> **在以下全部条件满足前,禁止输出”完成””Done””已生成”或任何等价的结束表述。**
- [ ] Step 4.1 文件已保存,文件名符合命名规范
- [ ] Step 4.2 `inline-images.py` 已执行
- [ ] Step 4.3 `smoke-test.sh` 已执行,结果已在回复中明确写出
- [ ] Step 4.4 `open` 已执行,结果已在回复中明确写出
- [ ] Step 4.5 交付摘要已按固定格式输出
- [ ] Step 4.5 已向用户回报上述结果
如果任一步未完成,最终答复必须改为“当前进度 + 阻塞原因”,不能伪装成完整交付。
---
## 附录 A:支持文件
| 文件 | 用途 | 何时读取 |
|---|---|---|
| [template.html](template.html) | 预构建引擎壳(含完整 CSS/JS) | Step 3.1 `cp`(必须) |
| [themes/_index.md](themes/_index.md) | 主题识别规则 + 子品牌表 + logo 索引 | Phase 0 主题检测 |
| `themes/[id].md` | CSS 变量 + logo 路径 + 补充规则 | Step 3.1 并行读取 |
| [components.md](components.md) | 组件 HTML 片段参考 | Step 3.1 按需 Grep |
| [icons.md](icons.md) | 287 个 Feather Icons 内联 SVG | 有图标槽时按需 Grep |
| `themes/logos/` | 品牌 logo 的 data URI 文本文件 | Step 3.2 ③ 直接读取 `.txt` |
| [examples/index.html](examples/index.html) | 完整示例文档 | 需要查阅组件骨架时 |
---
## 附录 B:进度通知规范
格式统一为纯文本,不用 markdown 列表或标题。
| 时机 | 格式 | 示例 |
|---|---|---|
| Phase 1 完成后 | 一句话确认元数据 | `已收集:腾讯 · 管理层汇报 · 12 页 · 张三 总监` |
| Phase 2 完成后 | 一句话说明页数 | `规划完成,共 12 张,开始生成…` |
| Step 3.3 每张写入前 | `→ 序号/总数 标题` | `→ 03/12 技术架构现状` |
| Step 4.2 完成后 | 一句话含文件大小 | `单体化完成,1.2 MB,无外部依赖。` |
| Step 4.3 | 见 Phase 4 Step 4.3 | — |
序号统一补零到总数位数(总数 12 则写 `01`,总数 100 则写 `001`)。
---
## 附录 C:执行检查清单
### Phase 0
- [ ] `git pull --ff-only`(失败则静默忽略)
- [ ] 提取公司关键词,确定主题文件路径
### Phase 1
- [ ] 一次性收集所有字段;缺失项按推断规则补全
- [ ] 页数推断结果与内容不符时,显式确认
### Phase 2
- [ ] 演讲稿输入:应用"演讲稿转换规则",禁止逐段照搬
- [ ] 内容密度符合对应场景上限
- [ ] 布局多样性自检通过(局部连续 + 全局比例)
- [ ] 封面、目录、章节过渡、结尾均已规划
### Phase 3
- [ ] `cp template.html` 完成
- [ ] 填充 ① 标题 ② 主题样式 ③ logo(base64)④ 幻灯片内容
- [ ] 当前主题所需的 logo `.txt` 文件存在并已直接写入;文件缺失时执行 Fallback
- [ ] 每张幻灯片密度自检通过
- [ ] 所有 info-card / step-card 包含图标
### Phase 4
- [ ] Step 4.1 保存
- [ ] Step 4.2 扫描无残留外部引用
- [ ] Step 4.3 `smoke-test` 已执行并检查结果
- [ ] Step 4.4 已执行浏览器直接打开本地文件;若受限,已明确说明阻塞
- [ ] Step 4.5 已告知用户文件信息与验证结果
### 最终答复模板(必须对照)
- [ ] 文件路径
- [ ] 文件大小 / 幻灯片总数 / 主题名称
- [ ] `smoke-test` 结果
- [ ] 浏览器打开结果或阻塞原因
- [ ] 下一步可选动作
### 禁止项
- ❌ 在 `<section>` 内写 logo 代码
- ❌ `max-width` 写死 px
- ❌ 直接编辑 `template.html`
- ❌ 编造原文无源的具体数字
- ❌ 演讲稿逐段照搬
- ❌ info-card 不加图标
- ❌ 少量卡片在全宽容器里偏左留白
---
## 非目标
- 不生成 .pptx,只输出单个 HTML
- 不自动抓取互联网内容,除非用户提供素材
- 不伪造演讲者身份、职位、部门
- 不擅自修改未被点名的现有页面
- 不保证所有品牌主题与官方品牌规范完全一致
don't have the plugin yet? install it then click "run inline in claude" again.