@optima-chat/optima-agent 0.9.39 → 0.9.41

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.
Files changed (107) hide show
  1. package/.claude/settings.local.json +166 -0
  2. package/.claude/skills/scout/SKILL.md +46 -141
  3. package/.claude/skills/scout/references/analysis-framework.md +4 -4
  4. package/.claude/skills/scout/references/concept.md +49 -46
  5. package/.claude/skills/scout/references/cross-project.md +9 -9
  6. package/.claude/skills/scout/references/development.md +13 -13
  7. package/.claude/skills/scout/references/launch.md +1 -1
  8. package/.claude/skills/scout/references/lifecycle.md +3 -3
  9. package/.claude/skills/scout/references/market-management.md +18 -18
  10. package/.claude/skills/scout/references/planning.md +25 -24
  11. package/.claude/skills/scout/references/qualification.md +11 -11
  12. package/.claude/skills/scout/references/requirements.md +10 -10
  13. package/.claude/skills/scout/template/kb/AGENTS.md +151 -0
  14. package/.claude/skills/scout/template/kb/wiki/entities/projects-template.md +113 -0
  15. package/.claude/skills/scout/template/kb/wiki/entities/seller-profile.md +23 -0
  16. package/.claude/skills/scout/template/kb/wiki/overview/cbb.md +33 -0
  17. package/.claude/skills/scout/template/kb/wiki/overview/competition-template.md +33 -0
  18. package/.claude/skills/scout/template/kb/wiki/overview/market-template.md +32 -0
  19. package/.claude/skills/scout/template/kb/wiki/overview/pain-points-template.md +19 -0
  20. package/.claude/skills/scout/template/kb/wiki/overview/roadmap.md +41 -0
  21. package/.claude/skills/scout/template/kb/wiki/overview/suppliers-template.md +34 -0
  22. package/.claude/skills/scout/template/kb/wiki/overview/trends-template.md +23 -0
  23. package/dist/bin/bi-cli.js +0 -0
  24. package/dist/bin/browser-cli.js +0 -0
  25. package/dist/bin/channels.js +0 -0
  26. package/dist/bin/comfy.d.ts +3 -0
  27. package/dist/bin/comfy.d.ts.map +1 -0
  28. package/dist/bin/comfy.js +3 -0
  29. package/dist/bin/comfy.js.map +1 -0
  30. package/dist/bin/commerce.js +0 -0
  31. package/dist/bin/gen.js +0 -0
  32. package/dist/bin/google-ads.js +0 -0
  33. package/dist/bin/growth.d.ts +3 -0
  34. package/dist/bin/growth.d.ts.map +1 -0
  35. package/dist/bin/growth.js +3 -0
  36. package/dist/bin/growth.js.map +1 -0
  37. package/dist/bin/kb-skills.js +0 -0
  38. package/dist/bin/logistics.js +0 -0
  39. package/dist/bin/optima.js +0 -0
  40. package/dist/bin/scout.js +0 -0
  41. package/dist/bin/sentinel.js +0 -0
  42. package/dist/bin/shopify.js +0 -0
  43. package/dist/src/hooks-loader.d.ts +6 -0
  44. package/dist/src/hooks-loader.d.ts.map +1 -0
  45. package/dist/src/hooks-loader.js +215 -0
  46. package/dist/src/hooks-loader.js.map +1 -0
  47. package/dist/src/ui/App.d.ts +6 -0
  48. package/dist/src/ui/App.d.ts.map +1 -0
  49. package/dist/src/ui/App.js +164 -0
  50. package/dist/src/ui/App.js.map +1 -0
  51. package/dist/src/ui/components/Composer.d.ts +10 -0
  52. package/dist/src/ui/components/Composer.d.ts.map +1 -0
  53. package/dist/src/ui/components/Composer.js +13 -0
  54. package/dist/src/ui/components/Composer.js.map +1 -0
  55. package/dist/src/ui/components/Header.d.ts +7 -0
  56. package/dist/src/ui/components/Header.d.ts.map +1 -0
  57. package/dist/src/ui/components/Header.js +7 -0
  58. package/dist/src/ui/components/Header.js.map +1 -0
  59. package/dist/src/ui/components/Message.d.ts +12 -0
  60. package/dist/src/ui/components/Message.d.ts.map +1 -0
  61. package/dist/src/ui/components/Message.js +21 -0
  62. package/dist/src/ui/components/Message.js.map +1 -0
  63. package/dist/src/ui/components/MessageList.d.ts +9 -0
  64. package/dist/src/ui/components/MessageList.d.ts.map +1 -0
  65. package/dist/src/ui/components/MessageList.js +18 -0
  66. package/dist/src/ui/components/MessageList.js.map +1 -0
  67. package/dist/src/ui/components/Spinner.d.ts +6 -0
  68. package/dist/src/ui/components/Spinner.d.ts.map +1 -0
  69. package/dist/src/ui/components/Spinner.js +7 -0
  70. package/dist/src/ui/components/Spinner.js.map +1 -0
  71. package/dist/src/ui/components/StatusBar.d.ts +11 -0
  72. package/dist/src/ui/components/StatusBar.d.ts.map +1 -0
  73. package/dist/src/ui/components/StatusBar.js +7 -0
  74. package/dist/src/ui/components/StatusBar.js.map +1 -0
  75. package/dist/src/ui/components/index.d.ts +7 -0
  76. package/dist/src/ui/components/index.d.ts.map +1 -0
  77. package/dist/src/ui/components/index.js +7 -0
  78. package/dist/src/ui/components/index.js.map +1 -0
  79. package/dist/src/validation/error-formatter.d.ts +21 -0
  80. package/dist/src/validation/error-formatter.d.ts.map +1 -0
  81. package/dist/src/validation/error-formatter.js +98 -0
  82. package/dist/src/validation/error-formatter.js.map +1 -0
  83. package/dist/src/validation/index.d.ts +10 -0
  84. package/dist/src/validation/index.d.ts.map +1 -0
  85. package/dist/src/validation/index.js +10 -0
  86. package/dist/src/validation/index.js.map +1 -0
  87. package/dist/src/validation/json-validator.d.ts +25 -0
  88. package/dist/src/validation/json-validator.d.ts.map +1 -0
  89. package/dist/src/validation/json-validator.js +173 -0
  90. package/dist/src/validation/json-validator.js.map +1 -0
  91. package/dist/src/validation/schema.d.ts +353 -0
  92. package/dist/src/validation/schema.d.ts.map +1 -0
  93. package/dist/src/validation/schema.js +57 -0
  94. package/dist/src/validation/schema.js.map +1 -0
  95. package/dist/src/validation/suggestions.d.ts +25 -0
  96. package/dist/src/validation/suggestions.d.ts.map +1 -0
  97. package/dist/src/validation/suggestions.js +144 -0
  98. package/dist/src/validation/suggestions.js.map +1 -0
  99. package/dist/src/validation/types.d.ts +40 -0
  100. package/dist/src/validation/types.d.ts.map +1 -0
  101. package/dist/src/validation/types.js +5 -0
  102. package/dist/src/validation/types.js.map +1 -0
  103. package/dist/src/validation/yaml-validator.d.ts +25 -0
  104. package/dist/src/validation/yaml-validator.d.ts.map +1 -0
  105. package/dist/src/validation/yaml-validator.js +177 -0
  106. package/dist/src/validation/yaml-validator.js.map +1 -0
  107. package/package.json +13 -14
@@ -2,12 +2,12 @@
2
2
 
3
3
  ## 目标
4
4
 
5
- 验证产品机会是否值得投入更多资源研究。产出产品立项书初版(即完成 RESEARCH.md 概念阶段所有 checklist 项)。
5
+ 验证产品机会是否值得投入更多资源研究。产出产品立项书初版(即完成项目页概念阶段所有 checklist 项)。
6
6
 
7
7
  ## 何时进入此阶段
8
8
 
9
9
  - 新建研究项目时自动进入
10
- - RESEARCH.md 当前阶段 = 概念
10
+ - `wiki/entities/projects/{slug}.md` 当前阶段 = 概念
11
11
 
12
12
  ## 流程总览
13
13
 
@@ -45,9 +45,7 @@
45
45
  - Shein/Temu 发现低价爆品 → `scout search` 对比 Amazon 定价 → 判断品牌溢价空间
46
46
  - Reddit/Twitter 发现未满足需求 → `scout search` + `scout reviews` 验证痛点普遍性
47
47
 
48
- **落盘**:`data/social/{date}-{platform}.json` 更新 `INDEX.md` + `market/MARKET.md`
49
-
50
- **完成标准**:至少查询 2 个平台,有明确热度信号(或确认无热度)
48
+ **完成标准**:至少查询 2 个平台,有明确热度信号(或确认无热度)。CLI 自动缓存所有 API 响应到 `~/.scout/cache/{project}/`。
51
49
 
52
50
  ---
53
51
 
@@ -76,9 +74,7 @@
76
74
  - 每个子品类标注:产品数量、价格区间、头部评论数、增长信号、竞争度
77
75
  - **子品类聚类是发现细分机会的关键步骤,不能跳过**
78
76
 
79
- **落盘**:`data/searches/{date}-{keyword}.json` + `data/sellersprite/{date}-{keyword}-mine.json` 更新 `INDEX.md` + `market/MARKET.md`
80
-
81
- **完成标准**:覆盖 30+ 个不重复竞品,识别出 5+ 个子品类并标注各自规模
77
+ **完成标准**:覆盖 30+ 个不重复竞品,识别出 5+ 个子品类并标注各自规模。CLI 自动缓存所有 API 响应。
82
78
 
83
79
  ---
84
80
 
@@ -92,9 +88,7 @@
92
88
  - `scout sp seller-countries <nodeIdPath>` — 获取卖家国籍分布
93
89
  - `scout sp seller-types <nodeIdPath>` — 获取 FBA/FBM/Amazon 自营占比
94
90
 
95
- **落盘**:`data/sellersprite/{date}-brands-{nodeIdPath}.json` 更新 `INDEX.md` + `market/MARKET.md`
96
-
97
- **完成标准**:有品牌集中度(CR3/CR5 量化数据)+ 卖家国籍分布 + FBA 占比
91
+ **完成标准**:有品牌集中度(CR3/CR5 量化数据)+ 卖家国籍分布 + FBA 占比。CLI 自动缓存所有 API 响应。
98
92
 
99
93
  ---
100
94
 
@@ -106,9 +100,7 @@
106
100
  - `scout supplier-search "中文关键词" --limit 10` — 获取 1688 参考价
107
101
  - 记录:头部供应商价格区间、MOQ、供应商类型
108
102
 
109
- **落盘**:`data/suppliers/{date}-{keyword}.json` 更新 `INDEX.md`
110
-
111
- **完成标准**:有 1688 参考价(至少 3 家供应商报价)
103
+ **完成标准**:有 1688 参考价(至少 3 家供应商报价)。CLI 自动缓存所有 API 响应。
112
104
 
113
105
  ---
114
106
 
@@ -116,23 +108,30 @@
116
108
 
117
109
  **在做任何分析之前,必须通过以下检查。任何一项未通过 → 补数据,不分析。**
118
110
 
111
+ 使用 `scout cache list` 查看已缓存的文件列表。
112
+
119
113
  ```
120
114
  数据完整性检查清单:
121
115
 
122
- 搜索覆盖度:INDEX.md 中不重复 ASIN 数量 30
123
- 子品类聚类:MARKET.md 子品类分布表 5 行?
124
- □ 精确搜索量:有 scout sp keywords-mine 数据(searches + purchases + bid)?
125
- □ 品牌集中度:有 scout sp brands 数据(CR3/CR5 + 份额)?
126
- □ 卖家国籍:有 scout sp seller-countries 数据?
127
- 供应端成本:有 1688 供应商报价(≥ 3 家)?
128
- 卖家类型:有 scout sp seller-types 数据(FBA/FBM 占比)?
129
- □ 趋势信号:有至少 2 个社交平台数据?
130
- 原始 JSON 落盘:data/ 目录文件数命令执行数?(每次命令都存了 JSON?)
131
- INDEX.md 一致:INDEX.md 中列出的文件在 data/ 目录中都存在?
116
+ 搜索覆盖度:~/.scout/cache/{project}/ 中搜索结果文件包含 30 个不重复 ASIN
117
+ 子品类聚类:完成后需在 ingest 时体现在 overview/market-{project}
118
+ □ 精确搜索量:有 sp-keywords-mine 缓存文件?
119
+ □ 品牌集中度:有 sp-brands 缓存文件?
120
+ □ 卖家国籍:有 sp-seller-countries 缓存文件?
121
+ 卖家类型:有 sp-seller-types 缓存文件?
122
+ 供应端成本:有 supplier-search 缓存文件?
123
+ □ 趋势信号:有至少 2 个社交平台缓存文件?
124
+ 缓存完整:~/.scout/cache/{project}/ 文件数命令执行数?
125
+ 全部 ingest:所有缓存文件已 ingest 到 KB(raw/ + wiki/sources/ 对应存在)?
132
126
  ```
133
127
 
134
128
  **如果有未通过的项,告知用户缺什么,补齐后重新检查。**
135
129
 
130
+ 检查通过后,批量 ingest 所有缓存文件到 ~/kb/product-research/:
131
+ - 对每个缓存文件调用 kb-skills 的 ingesting-sources 流程
132
+ - 确认 wiki/sources/ 中所有来源页已创建
133
+ - 确认相关 entity 和 overview 页已更新
134
+
136
135
  **输出格式**:
137
136
  ```
138
137
  📋 数据完整性检查
@@ -143,8 +142,8 @@
143
142
  ❌ 卖家国籍:未采集 → 需要执行 scout sp seller-countries
144
143
  ✅ 供应端成本:5 家供应商报价
145
144
  ✅ 趋势信号:TikTok + Reddit
146
- 原始 JSON:12/12 已落盘
147
- INDEX.md 一致
145
+ 缓存完整:12/12 已缓存
146
+ 全部 ingest:已完成
148
147
 
149
148
  结论:2 项未通过,需要补充品牌集中度和卖家国籍数据。
150
149
  ```
@@ -168,11 +167,11 @@
168
167
  - 战略价值:品类协同、复购潜力
169
168
  - X 轴:竞争地位(1-5 分)
170
169
  - 差异化能力:子品类聚类中的空白机会
171
- - 资金匹配度:对照 PROFILE.md
170
+ - 资金匹配度:对照 seller-profile.md
172
171
  - 供应链能力:1688 供应商数量和质量
173
172
  - 进入壁垒:用 `scout sp brands` 的品牌份额数据判断
174
173
 
175
- **落盘**:更新 `RESEARCH.md` SPAN 定位 + `market/MARKET.md` SPAN 评分
174
+ **记录**:更新 `wiki/entities/projects/{slug}.md` SPAN 定位 + `wiki/overview/market-{slug}.md` SPAN 评分
176
175
 
177
176
  ---
178
177
 
@@ -188,9 +187,9 @@
188
187
  - 毛利 = 售价 - COGS - FBA 费
189
188
  - 粗略净利 = 毛利 - PPC 估算 - 退货估算
190
189
 
191
- **对照**:`PROFILE.md` 中的最低毛利率和最低净利率。如果 PROFILE 未填写,必须让用户确认。
190
+ **对照**:`seller-profile.md` 中的最低毛利率和最低净利率。如果未填写,必须让用户确认。
192
191
 
193
- **落盘**:记录在 `RESEARCH.md` 关键发现中
192
+ **记录**:更新 `wiki/entities/projects/{slug}.md` 关键发现
194
193
 
195
194
  ---
196
195
 
@@ -201,7 +200,7 @@
201
200
  **方法**:
202
201
  - Web Search 查询:商标(USPTO/WIPO)、外观专利、品类认证(FDA/FCC/UL/CPSIA)、Amazon 品类限制
203
202
 
204
- **落盘**:记录在 `RESEARCH.md` 关键发现中(如有风险则同时记入风险清单)
203
+ **记录**:更新 `wiki/entities/projects/{slug}.md` 关键发现(如有风险则同时记入风险清单)
205
204
 
206
205
  ---
207
206
 
@@ -225,8 +224,8 @@
225
224
  3. 给出 **Go / Kill / Redirect** 建议
226
225
  4. 等待用户确认决策
227
226
  5. 确认后更新:
228
- - `RESEARCH.md`(阶段 → 计划,记录决策)
229
- - `OVERVIEW.md`(状态更新)
227
+ - `wiki/entities/projects/{slug}.md`(阶段 → 计划,记录决策)
228
+ - `index.md`(状态更新)
230
229
 
231
230
  ### 评审输出格式模板
232
231
 
@@ -260,22 +259,22 @@
260
259
  ### 各决策结果的具体操作
261
260
 
262
261
  **Go:**
263
- 1. **生成产品立项书**,保存到 `reports/YYYY-MM-DD-产品立项书.md`。产品立项书必含:市场概况(含子品类分布)、SPAN 定位、竞争格局(含品牌集中度和卖家国籍)、初步利润估算(含 PPC)、机会与风险、Go 建议
264
- 2. 更新 RESEARCH.md 当前阶段 → 计划
265
- 3. 更新 RESEARCH.md 决策记录
266
- 4. 更新 OVERVIEW.md 阶段列
267
- 5. 更新 ROADMAP.md(该产品状态 → 已通过 CDCP)
262
+ 1. **生成产品立项书**,保存到 `wiki/analyses/{slug}-charter.md`。产品立项书必含:市场概况(含子品类分布)、SPAN 定位、竞争格局(含品牌集中度和卖家国籍)、初步利润估算(含 PPC)、机会与风险、Go 建议
263
+ 2. 更新 `wiki/entities/projects/{slug}.md` 当前阶段 → 计划
264
+ 3. 更新 `wiki/entities/projects/{slug}.md` 决策记录
265
+ 4. 更新 `index.md` 阶段列
266
+ 5. 更新 `wiki/overview/roadmap.md`(该产品状态 → 已通过 CDCP)
268
267
  6. 加载 planning.md 开始计划阶段
269
268
 
270
269
  **Kill:**
271
- 1. 更新 RESEARCH.md 状态 → 已决策(No-Go)
272
- 2. 更新 RESEARCH.md 决策记录(记录放弃原因)
273
- 3. 更新 OVERVIEW.md:从活跃移到已完结
274
- 4. 更新 ROADMAP.md(该产品状态 → 已放弃)
275
- 5. 提示更新 CBB.md(即使失败也可能积累了有用信息)
270
+ 1. 更新 `wiki/entities/projects/{slug}.md` 状态 → 已决策(No-Go)
271
+ 2. 更新 `wiki/entities/projects/{slug}.md` 决策记录(记录放弃原因)
272
+ 3. 更新 `index.md`:从活跃移到已完结
273
+ 4. 更新 `wiki/overview/roadmap.md`(该产品状态 → 已放弃)
274
+ 5. 提示更新 `wiki/overview/cbb.md`(即使失败也可能积累了有用信息)
276
275
 
277
276
  **Redirect:**
278
- 1. 更新 RESEARCH.md 决策记录(记录调整原因和新方向)
277
+ 1. 更新 `wiki/entities/projects/{slug}.md` 决策记录(记录调整原因和新方向)
279
278
  2. 根据调整幅度决定:
280
279
  - **小调整**(如从"无线耳机"缩窄到"开放式耳机"):修改当前项目的研究目标,重置概念阶段 checklist 中受影响的项,重新执行
281
280
  - **大调整**(方向完全不同):归档当前项目(No-Go),新建项目重新开始
@@ -314,11 +313,15 @@ scout sp seller-types <nodeIdPath>
314
313
  scout supplier-search "钛合金杯子" --limit 10
315
314
  ```
316
315
 
317
- 每个命令执行后立即落盘(JSON + INDEX.md)。
316
+ CLI 自动缓存所有 API 响应到 `~/.scout/cache/{project}/`,无需手动落盘。
318
317
 
319
318
  **第二步:完整性检查**
320
319
 
321
- > "📋 数据完整性检查:9/9 全部通过。可以开始分析了。"
320
+ 使用 `scout cache list` 确认所有缓存文件存在。
321
+
322
+ > "📋 数据完整性检查:10/10 全部通过。可以开始分析了。"
323
+
324
+ 检查通过后 ingest 所有缓存文件到 KB。
322
325
 
323
326
  **第三步:分析**
324
327
 
@@ -10,8 +10,8 @@
10
10
 
11
11
  ## 数据获取
12
12
 
13
- 1. 读取 ~/products/OVERVIEW.md 获取项目列表和状态
14
- 2. 对每个相关项目读取 RESEARCH.md(SPAN、FAN、$APPEALS)
13
+ 1. 读取 ~/kb/product-research/index.md 获取项目列表和状态
14
+ 2. 对每个相关项目读取 wiki/entities/projects/{slug}.md(SPAN、FAN、$APPEALS)
15
15
  3. 如需详细对比,读取各项目活文档
16
16
 
17
17
  ## 分析类型
@@ -31,7 +31,7 @@
31
31
 
32
32
  ### 供应商资源复用
33
33
 
34
- 检查各项目 data/suppliers/ 目录:
34
+ 检查各项目供应商数据(CLI 自动缓存在 ~/.scout/cache/{project}/):
35
35
  - 同一供应商能否供多个产品
36
36
  - 合并采购的议价空间
37
37
  - 供应商地域风险分散
@@ -46,7 +46,7 @@
46
46
 
47
47
  CBB(Common Building Block,共用构建模块)是跨产品可复用的能力模块。
48
48
 
49
- **数据位置:** `~/products/CBB.md`
49
+ **数据位置:** `~/kb/product-research/wiki/overview/cbb.md`
50
50
 
51
51
  **CBB 的 6 种类型:**
52
52
 
@@ -61,10 +61,10 @@ CBB(Common Building Block,共用构建模块)是跨产品可复用的能
61
61
 
62
62
  **何时更新 CBB:**
63
63
  - 项目完成(Go 或 No-Go)后,提示用户:"这次研究积累了什么可复用的能力?"
64
- - 用户确认后更新 `~/products/CBB.md` 对应分类
64
+ - 用户确认后更新 `~/kb/product-research/wiki/overview/cbb.md` 对应分类
65
65
 
66
66
  **何时查询 CBB:**
67
- - 新建项目时,读取 CBB.md 识别可复用能力
67
+ - 新建项目时,读取 wiki/overview/cbb.md 识别可复用能力
68
68
  - 影响 SPAN 评分:有可复用的供应商/品类知识/品牌资产 → 竞争地位中"供应链能力"和"差异化能力"得分提升
69
69
  - 影响 FAN 模型:已有供应商关系可降低成本估算风险,已有物流线路可精确运费
70
70
 
@@ -74,6 +74,6 @@ CBB(Common Building Block,共用构建模块)是跨产品可复用的能
74
74
 
75
75
  ## 产出
76
76
 
77
- 更新 ~/products/OVERVIEW.md "跨产品洞察"部分。
78
- 如用户要求,生成 Portfolio 分析报告。
79
- 项目完成后更新 ~/products/CBB.md 能力货架。
77
+ 更新 ~/kb/product-research/index.md "跨产品洞察"部分。
78
+ 如用户要求,生成 Portfolio 分析报告(保存到 wiki/analyses/)。
79
+ 项目完成后更新 ~/kb/product-research/wiki/overview/cbb.md 能力货架。
@@ -5,7 +5,7 @@
5
5
 
6
6
  ## 何时进入此阶段
7
7
  - PDCP Gate 通过后自动进入
8
- - RESEARCH.md 当前阶段 = 开发
8
+ - wiki/entities/projects/{slug}.md 当前阶段 = 开发
9
9
 
10
10
  ## Scout 在此阶段的角色
11
11
 
@@ -14,46 +14,46 @@
14
14
  - **分析员**:用 FAN 模型验证成本变化对财务的影响
15
15
  - **提醒员**:追踪 checklist 进度,适时提醒 Gate 评审
16
16
 
17
- 当用户汇报线下进展时,agent 帮助更新 RESEARCH.md 和相关文档。
17
+ 当用户汇报线下进展时,agent 帮助更新 wiki/entities/projects/{slug}.md 和相关文档。
18
18
 
19
19
  ## 执行步骤
20
20
 
21
21
  ### 1. 供应商评估与选定
22
22
  - 评估矩阵 7 维度(各 1-10 分):产品质量、MOQ灵活性、交期可靠性、沟通配合度、定制能力、价格竞争力、认证资质
23
23
  - 建议选 2 家(主选+备选)
24
- - 更新 suppliers/SUPPLIERS.md 评估矩阵
24
+ - 更新 wiki/overview/suppliers-{slug}.md 评估矩阵
25
25
 
26
26
  ### 2. 成本模型定稿
27
27
  - 用实际报价替换计划阶段估算
28
- - 更新 RESEARCH.md FAN 财务模型
28
+ - 更新 wiki/entities/projects/{slug}.md FAN 财务模型
29
29
  - 重新计算场景分析
30
30
 
31
31
  ### 3. 产品规格确认
32
32
  - 材料、尺寸重量(影响FBA费分级)、包装、颜色/变体、认证清单
33
- - **落盘位置**:记录在 RESEARCH.md 关键发现中
33
+ - **更新页面**:记录在 wiki/entities/projects/{slug}.md 关键发现中
34
34
 
35
35
  ### 4. 样品迭代
36
36
  - 至少 2 轮(基础功能确认 → 修改后最终确认)
37
37
  - 记录每轮问题和修改
38
- - **落盘位置**:记录在 RESEARCH.md 关键发现中(每轮追加)
38
+ - **更新页面**:记录在 wiki/entities/projects/{slug}.md 关键发现中(每轮追加)
39
39
 
40
40
  ### 5. 包装设计
41
41
  - 品牌包装、FBA 尺寸优化、内包装保护、Insert card
42
- - **落盘位置**:记录在 RESEARCH.md 关键发现中
42
+ - **更新页面**:记录在 wiki/entities/projects/{slug}.md 关键发现中
43
43
 
44
44
  ### 6. Listing 素材准备
45
45
  - 主图+6副图、A+ Content、视频(可选)、关键词列表
46
- - **落盘位置**:记录在 RESEARCH.md 关键发现中(可附注素材链接)
46
+ - **更新页面**:记录在 wiki/entities/projects/{slug}.md 关键发现中(可附注素材链接)
47
47
 
48
48
  ## 开发 Gate 评审
49
49
 
50
50
  5 个问题:样品达标?成本在预算内?认证已获得?Listing就绪?供应商可承诺批量交期?
51
51
 
52
52
  **Go(全 Yes):**
53
- 1. **生成产品规格书 + 供应商评估报告**,保存到 `reports/YYYY-MM-DD-产品规格书.md`
54
- 2. 更新 RESEARCH.md 当前阶段 → 验证
55
- 3. 更新 RESEARCH.md 决策记录
56
- 4. 更新 OVERVIEW.md 阶段列
57
- 5. 更新 ROADMAP.md(状态 → 已通过开发 Gate)
53
+ 1. **生成产品规格书 + 供应商评估报告**,保存到 `wiki/analyses/YYYY-MM-DD-产品规格书.md`
54
+ 2. 更新 wiki/entities/projects/{slug}.md 当前阶段 → 验证
55
+ 3. 更新 wiki/entities/projects/{slug}.md 决策记录
56
+ 4. 更新 index.md 阶段列
57
+ 5. 更新 wiki/overview/roadmap.md(状态 → 已通过开发 Gate)
58
58
 
59
59
  **不通过:** 标注具体不达标项,回到对应步骤修正后重新评审
@@ -5,7 +5,7 @@
5
5
 
6
6
  ## 何时进入此阶段
7
7
  - ADCP Gate 通过后进入
8
- - RESEARCH.md 当前阶段 = 发布
8
+ - wiki/entities/projects/{slug}.md 当前阶段 = 发布
9
9
 
10
10
  ## 关键活动
11
11
 
@@ -5,7 +5,7 @@
5
5
 
6
6
  ## 何时进入此阶段
7
7
  - 产品正式上架并稳定销售后
8
- - RESEARCH.md 当前阶段 = 生命周期
8
+ - wiki/entities/projects/{slug}.md 当前阶段 = 生命周期
9
9
 
10
10
  ## 关键活动
11
11
 
@@ -28,12 +28,12 @@
28
28
 
29
29
  ### EOL 决策(LDCP)
30
30
  退出信号:
31
- - 连续 3 月利润低于 PROFILE.md 最低净利率
31
+ - 连续 3 月利润低于 wiki/entities/seller-profile.md 最低净利率
32
32
  - BSR 持续恶化无改善
33
33
  - ACoS 不可控
34
34
  - 库存积压超 6 月周转
35
35
 
36
- EOL 后:清仓策略 → 更新 RESEARCH.md 状态(No-Go) → 更新 OVERVIEW.md 移入已完结
36
+ EOL 后:清仓策略 → 更新 wiki/entities/projects/{slug}.md 状态(No-Go) → 更新 index.md 移入已完结
37
37
 
38
38
  ## Scout 在此阶段的作用
39
39
  定期手动复查数据,更新月度对比。未来可通过定时任务自动化。
@@ -2,19 +2,19 @@
2
2
 
3
3
  ## 目标
4
4
 
5
- MM 是产品开发的前置流程,负责"做正确的事"。通过系统化的市场扫描和机会评估,确定未来的选品方向和优先级,输出产品路标规划(ROADMAP.md)。
5
+ MM 是产品开发的前置流程,负责"做正确的事"。通过系统化的市场扫描和机会评估,确定未来的选品方向和优先级,输出产品路标规划(wiki/overview/roadmap.md)。
6
6
 
7
7
  ## 何时触发
8
8
 
9
9
  - 用户问"接下来做什么品类?"、"年度选品方向"、"产品线规划"
10
10
  - 季度复盘时主动建议
11
- - 首次使用且 ROADMAP.md 为空时
11
+ - 首次使用且 wiki/overview/roadmap.md 为空时
12
12
  - 用户要求"帮我扫描一下市场机会"
13
13
 
14
14
  ## 与概念阶段的关系
15
15
 
16
- - MM 产出的是**方向和机会清单**(ROADMAP.md 品类机会池)
17
- - 概念阶段针对**具体产品**做深入验证(RESEARCH.md)
16
+ - MM 产出的是**方向和机会清单**(wiki/overview/roadmap.md 品类机会池)
17
+ - 概念阶段针对**具体产品**做深入验证(wiki/entities/projects/{slug}.md)
18
18
  - MM 是宏观选择(做哪个品类),概念是微观验证(这个具体产品行不行)
19
19
  - MM 可以同时评估 5-10 个方向,概念阶段一次专注 1 个产品
20
20
 
@@ -25,8 +25,8 @@ MM 是产品开发的前置流程,负责"做正确的事"。通过系统化的
25
25
  **目的:** 明确本次 MM 要探索的方向。
26
26
 
27
27
  **输入来源:**
28
- - PROFILE.md 中的偏好品类和回避品类
29
- - CBB.md 中已有能力可延伸的品类
28
+ - wiki/entities/seller-profile.md 中的偏好品类和回避品类
29
+ - wiki/overview/cbb.md 中已有能力可延伸的品类
30
30
  - 用户提出的兴趣方向
31
31
  - 外部趋势信号(社交媒体热度、行业新闻)
32
32
 
@@ -61,7 +61,7 @@ scout tiktok search-videos "品类关键词"
61
61
  **方法:** 参考 analysis-framework.md 的 SPAN 评分标准,但允许粗略估算:
62
62
 
63
63
  - 市场吸引力(1-5):基于步骤 2 收集的市场规模和增长信号
64
- - 竞争地位(1-5):基于 PROFILE.md 能力 + CBB.md 可复用资源
64
+ - 竞争地位(1-5):基于 wiki/entities/seller-profile.md 能力 + wiki/overview/cbb.md 可复用资源
65
65
 
66
66
  **产出:** 每个方向一个 SPAN 坐标 + 象限判断
67
67
 
@@ -72,21 +72,21 @@ scout tiktok search-videos "品类关键词"
72
72
  **排序依据(权重递减):**
73
73
 
74
74
  1. **SPAN 象限**:投资 > 选择性投入 > 收割 > 退出
75
- 2. **与 PROFILE.md 匹配度**:价位区间、品类偏好、风险偏好
76
- 3. **CBB 复用度**:能从能力货架取用多少现有模块?复用越多风险越低
75
+ 2. **与 seller-profile 匹配度**:价位区间、品类偏好、风险偏好
76
+ 3. **CBB 复用度**:能从能力货架(wiki/overview/cbb.md)取用多少现有模块?复用越多风险越低
77
77
  4. **时间窗口**:是否有季节性或趋势紧迫性?
78
78
 
79
79
  **优先级分类:**
80
80
  - **P1**:SPAN 投资象限 + 高匹配 + 有 CBB 复用 → 立即立项研究
81
81
  - **P2**:SPAN 投资/选择性投入 + 中匹配 → 排队等资源
82
82
  - **P3**:有潜力但需补强或时机未到 → 持续观察
83
- - **放弃**:SPAN 退出象限 / 与 PROFILE 不匹配 / 无法补强
83
+ - **放弃**:SPAN 退出象限 / 与 seller-profile 不匹配 / 无法补强
84
84
 
85
85
  ---
86
86
 
87
87
  ### 5. 更新产品路标
88
88
 
89
- **更新 `~/products/ROADMAP.md`:**
89
+ **更新 `~/kb/product-research/wiki/overview/roadmap.md`:**
90
90
  - 品类机会池:添加新机会,标注优先级和 SPAN 评分
91
91
  - 产品线规划:P1 机会排入时间线
92
92
  - 资源预算分配:根据优先级分配预算
@@ -96,14 +96,14 @@ scout tiktok search-videos "品类关键词"
96
96
 
97
97
  ### 6. 生成品类分析报告
98
98
 
99
- **生成品类分析报告**,保存到 `~/products/reports/YYYY-MM-DD-品类分析报告.md`。
99
+ **生成品类分析报告**,保存到 `~/kb/product-research/wiki/analyses/YYYY-MM-DD-品类分析报告.md`。
100
100
 
101
101
  必含章节:
102
102
  - 扫描范围(评估了哪些品类方向)
103
103
  - 各品类 SPAN 评分(市场吸引力 + 竞争地位)
104
104
  - 优先级排序结果(P1/P2/P3/放弃)及理由
105
- - 与 PROFILE.md 的匹配度分析
106
- - CBB 复用度评估
105
+ - 与 seller-profile 的匹配度分析
106
+ - CBB 复用度评估(wiki/overview/cbb.md)
107
107
  - 最终选择的方向和下一步行动
108
108
 
109
109
  ---
@@ -111,13 +111,13 @@ scout tiktok search-videos "品类关键词"
111
111
  ### 7. 立项触发
112
112
 
113
113
  **P1 机会 → 发起概念阶段:**
114
- - 从 ROADMAP.md 选取 P1 机会
115
- - 创建新项目(template/product/ → ~/products/{slug}/)
114
+ - 从 wiki/overview/roadmap.md 选取 P1 机会
115
+ - 创建新项目(wiki/entities/projects/{slug}.md)
116
116
  - 进入概念阶段深入验证
117
117
 
118
118
  **控制节奏:**
119
119
  - 同时进行中的概念/计划阶段项目不宜超过 3 个(避免资源分散)
120
- - 参考 PROFILE.md 单品启动预算和总资金情况
120
+ - 参考 wiki/entities/seller-profile.md 单品启动预算和总资金情况
121
121
 
122
122
  ## MM 复盘节奏
123
123
 
@@ -131,4 +131,4 @@ scout tiktok search-videos "品类关键词"
131
131
 
132
132
  - MM 负责**输入端**:发现新机会,决定做什么
133
133
  - Portfolio 负责**管理端**:已立项产品的资源分配和 Go/Kill 决策
134
- - 两者共享 SPAN 框架和 ROADMAP.md
134
+ - 两者共享 SPAN 框架和 wiki/overview/roadmap.md
@@ -7,7 +7,7 @@
7
7
  ## 何时进入此阶段
8
8
 
9
9
  - CDCP Gate 通过后自动进入
10
- - RESEARCH.md 当前阶段 = 计划
10
+ - `wiki/entities/projects/{slug}.md` 当前阶段 = 计划
11
11
 
12
12
  ## 执行步骤
13
13
 
@@ -46,7 +46,7 @@
46
46
 
47
47
  - 这张表反映竞品的运营成熟度,A+ 和视频覆盖率高 = 竞争壁垒高
48
48
 
49
- **落盘位置**:`data/products/{ASIN}.json` + `data/sellersprite/{ASIN}-predict.json` → 更新 `INDEX.md` + `competitors/COMPETITORS.md`
49
+ **更新页面**:`wiki/overview/competition-{slug}.md`
50
50
 
51
51
  **完成标准**:5-8 个竞品有完整数据(产品详情 + 流量关键词 + 历史销量 + Listing 能力)
52
52
 
@@ -72,7 +72,7 @@
72
72
  - 差异化公式:用户在乎 × 竞品弱 = 机会
73
73
  - 可选:`scout sp keywords <ASIN>` 的 badges 字段可判断竞品是否投了广告(含 "ads" = 有投放),辅助评估竞品的广告投入力度
74
74
 
75
- **落盘位置**:更新 `RESEARCH.md` $APPEALS 评分卡 + `competitors/COMPETITORS.md`
75
+ **更新页面**:`wiki/entities/projects/{slug}.md` $APPEALS 评分卡 + `wiki/overview/competition-{slug}.md`
76
76
 
77
77
  **完成标准**:≥3 竞品完成 8 维度打分,识别出差异化方向
78
78
 
@@ -91,7 +91,7 @@
91
91
  - 评估改进可行性(技术难度、成本影响)
92
92
  - 同时分析好评高频词(判断维度权重)
93
93
 
94
- **落盘位置**:`data/reviews/{ASIN}-{star}.json` → 更新 `INDEX.md` + `reviews/PAIN-POINTS.md`
94
+ **更新页面**:`wiki/overview/pain-points-{slug}.md`
95
95
 
96
96
  **推荐补充**:`scout sp keywords-order <ASIN>` 反查竞品出单词(哪些关键词真正带来转化),区分流量词和出单词,找到竞品的核心转化路径
97
97
 
@@ -116,7 +116,7 @@
116
116
  - 成熟期:BSR 平稳 + 评论稳定增长 + 价格竞争加剧
117
117
  - 衰退期:BSR 上升 + 评论增速放缓 + 卖家数减少
118
118
 
119
- **落盘位置**:`data/keepa/{date}-batch.json` → 更新 `INDEX.md` + `trends/TRENDS.md`
119
+ **更新页面**:`wiki/overview/trends-{slug}.md`
120
120
 
121
121
  **完成标准**:有 Keepa 数据,判断了生命周期
122
122
 
@@ -133,7 +133,7 @@
133
133
  - 定价策略(基于竞品定价分布和差异化溢价)
134
134
  - 目标客群画像
135
135
 
136
- **落盘位置**:更新 `competitors/COMPETITORS.md` 差异化机会总结
136
+ **更新页面**:`wiki/overview/competition-{slug}.md` 差异化机会总结
137
137
 
138
138
  **完成标准**:有明确策略可传达给供应商
139
139
 
@@ -141,7 +141,7 @@
141
141
 
142
142
  **目的**:验证产品财务可行性,确认利润空间
143
143
 
144
- **前置检查**:读取 `~/products/PROFILE.md` 的决策标准(最低毛利率、最低净利率)。如果 PROFILE 未填写这些阈值,**必须先让用户确认**:"你的最低可接受净利率是多少?(默认 30%)"——否则 PDCP Gate 无法判断。
144
+ **前置检查**:读取决策标准(最低毛利率、最低净利率)。如果未填写这些阈值,**必须先让用户确认**:"你的最低可接受净利率是多少?(默认 30%)"——否则 PDCP Gate 无法判断。
145
145
 
146
146
  **具体命令**:
147
147
  - `scout supplier-search "关键词" --limit 20`(文字搜索供应商)
@@ -164,7 +164,7 @@
164
164
  - 盈亏平衡点
165
165
  - 回本周期
166
166
 
167
- **落盘位置**:`data/suppliers/{date}-keyword.json` → 更新 `INDEX.md` + `RESEARCH.md` FAN + `suppliers/SUPPLIERS.md`
167
+ **更新页面**:`wiki/entities/projects/{slug}.md` FAN 部分 + `wiki/overview/suppliers-{slug}.md`
168
168
 
169
169
  **完成标准**:单元经济完整,有场景分析
170
170
 
@@ -181,7 +181,7 @@
181
181
  - 定制能力(能否实现差异化设计)
182
182
  - 价格(阶梯报价、含税含运)
183
183
 
184
- **落盘位置**:更新 `suppliers/SUPPLIERS.md` TOP 供应商对比表
184
+ **更新页面**:`wiki/overview/suppliers-{slug}.md` TOP 供应商对比表
185
185
 
186
186
  **完成标准**:至少 1 家可行(MOQ/交期/价格可接受)
187
187
 
@@ -201,7 +201,7 @@
201
201
  - 评估发生概率(高/中/低)
202
202
  - 制定应对方案(规避/转移/减轻/接受)
203
203
 
204
- **落盘位置**:更新 `RESEARCH.md` 风险清单
204
+ **更新页面**:`wiki/entities/projects/{slug}.md` 风险清单
205
205
 
206
206
  **完成标准**:主要风险识别,每个有应对方案
207
207
 
@@ -212,19 +212,20 @@
212
212
  ```
213
213
  计划阶段数据完整性检查清单:
214
214
 
215
- □ 竞品深度:5-8 个竞品有完整 product detail?
216
- □ 流量关键词:5-8 个竞品有 scout sp keywords 数据?
217
- □ 历史销量:5-8 个竞品有 scout sp predict 14 个月数据?
218
- □ 季节性分析:COMPETITORS.md 季节性分析表已填写?
219
- □ Listing 能力矩阵:COMPETITORS.md 能力矩阵表已填写?
215
+ □ 竞品深度:5-8 个竞品有 product 缓存文件?
216
+ □ 流量关键词:5-8 个竞品有 sp-keywords 缓存文件?
217
+ □ 历史销量:5-8 个竞品有 sp-predict 缓存文件?
218
+ □ 季节性分析:wiki/overview/competition-{slug}.md 季节性分析已更新?
219
+ □ Listing 能力矩阵:wiki/overview/competition-{slug}.md 能力矩阵表已填写?
220
220
  □ $APPEALS 评分:≥ 3 个竞品完成 8 维度打分?
221
221
  □ 差评分析:≥ 30 条差评已聚类?
222
222
  □ Keepa 趋势:有 180 天 BSR 趋势 + 生命周期判断?
223
223
  □ FAN 模型:单元经济 + 4 场景分析完整?(含真实 PPC 竞价)
224
224
  □ 供应商:≥ 1 家可行供应商?
225
- □ 差异化策略:COMPETITORS.md 差异化机会总结已填写?
225
+ □ 差异化策略:wiki/overview/competition-{slug}.md 差异化机会总结已填写?
226
226
  □ 风险清单:主要风险已识别且有应对方案?
227
- 原始 JSON 落盘:所有命令结果已存到 data/?
227
+ 缓存完整:~/.scout/cache/{project}/ 文件数 命令执行数?
228
+ □ 全部 ingest:所有缓存文件已 ingest 到 KB?
228
229
  ```
229
230
 
230
231
  ## PDCP Gate 评审
@@ -239,7 +240,7 @@
239
240
  |---|------|----------|
240
241
  | 1 | 差异化明确? | $APPEALS 至少 2 个维度领先竞品均值 2+ 分 |
241
242
  | 2 | 供应商可行? | 至少 1 家通过评估(MOQ/交期/价格可接受) |
242
- | 3 | 财务成立? | FAN 基准净利率 ≥ PROFILE 最低净利率,悲观场景不亏损 |
243
+ | 3 | 财务成立? | FAN 基准净利率 ≥ seller-profile 最低净利率,悲观场景不亏损 |
243
244
  | 4 | 风险可控? | 无致命风险,每个已识别风险有应对方案 |
244
245
  | 5 | 时间窗口? | 非衰退期,趋势向上或平稳 |
245
246
 
@@ -273,13 +274,13 @@
273
274
  ### Go/Kill/Redirect 标准及操作
274
275
 
275
276
  **Go(5 项全部通过):**
276
- 1. **生成商业计划书**,保存到 `reports/YYYY-MM-DD-商业计划书.md`。必含:$APPEALS 对比、痛点与差异化策略、Keepa 趋势、FAN 财务模型(含场景分析)、供应商评估、风险清单、进入策略
277
- 2. 更新 RESEARCH.md 当前阶段 → 开发
278
- 3. 更新 RESEARCH.md 决策记录
279
- 4. 更新 OVERVIEW.md 阶段列
280
- 5. 更新 ROADMAP.md(状态 → 已通过 PDCP)
277
+ 1. **生成商业计划书**,保存到 `wiki/analyses/{slug}-business-case.md`。必含:$APPEALS 对比、痛点与差异化策略、Keepa 趋势、FAN 财务模型(含场景分析)、供应商评估、风险清单、进入策略
278
+ 2. 更新 `wiki/entities/projects/{slug}.md` 当前阶段 → 开发
279
+ 3. 更新 `wiki/entities/projects/{slug}.md` 决策记录
280
+ 4. 更新 `index.md` 阶段列
281
+ 5. 更新 `wiki/overview/roadmap.md`(状态 → 已通过 PDCP)
281
282
  6. 加载 development.md 开始开发阶段
282
283
 
283
- **Kill:** 财务不成立/致命风险/差异化不足 → 终止项目,更新 RESEARCH.md(No-Go) + OVERVIEW.md(已完结) + ROADMAP.md(已放弃) + CBB.md
284
+ **Kill:** 财务不成立/致命风险/差异化不足 → 终止项目,更新 `wiki/entities/projects/{slug}.md`(No-Go) + `index.md`(已完结) + `wiki/overview/roadmap.md`(已放弃) + `wiki/overview/cbb.md`
284
285
 
285
286
  **Redirect:** 部分通过但有改进路径 → 调整方向后重新评估(记录调整内容和重评时间)