@optima-chat/optima-agent 0.9.10 → 0.9.12

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 (94) hide show
  1. package/.claude/skills/.kb-skills-managed.json +9 -9
  2. package/.claude/skills/ads/SKILL.md +244 -244
  3. package/.claude/skills/ads/template/campaign/CREATIVES.md +18 -18
  4. package/.claude/skills/ads/template/campaign/NOTES.md +10 -10
  5. package/.claude/skills/ads/template/campaign/STRATEGY.md +29 -29
  6. package/.claude/skills/ads/template/user/ADS.md +29 -29
  7. package/.claude/skills/ads/template/user/LEARNINGS.md +15 -15
  8. package/.claude/skills/ads/template/user/PROGRESS.md +20 -20
  9. package/.claude/skills/ads/template/user/README.md +25 -25
  10. package/.claude/skills/ads/template/user/assets/.gitignore +2 -2
  11. package/.claude/skills/bi/SKILL.md +131 -131
  12. package/.claude/skills/browser/SKILL.md +201 -201
  13. package/.claude/skills/channels/SKILL.md +188 -188
  14. package/.claude/skills/collection/SKILL.md +88 -88
  15. package/.claude/skills/douyin/SKILL.md +408 -408
  16. package/.claude/skills/ffmpeg/SKILL.md +164 -164
  17. package/.claude/skills/gen/SKILL.md +279 -279
  18. package/.claude/skills/growth/SKILL.md +90 -90
  19. package/.claude/skills/growth/template/ACCOUNTS.md +14 -14
  20. package/.claude/skills/growth/template/CALENDAR.md +7 -7
  21. package/.claude/skills/growth/template/COMMENTS.md +7 -7
  22. package/.claude/skills/growth/template/GROWTH.md +37 -37
  23. package/.claude/skills/growth/template/PROGRESS.md +4 -4
  24. package/.claude/skills/growth/template/README.md +20 -20
  25. package/.claude/skills/growth/template/TOPICS.md +7 -7
  26. package/.claude/skills/homepage/SKILL.md +177 -177
  27. package/.claude/skills/i18n/SKILL.md +517 -517
  28. package/.claude/skills/ingesting-sources/SKILL.md +94 -94
  29. package/.claude/skills/initializing-kb/SKILL.md +117 -117
  30. package/.claude/skills/instagram/SKILL.md +321 -321
  31. package/.claude/skills/inventory/SKILL.md +328 -328
  32. package/.claude/skills/kol-outreach/SKILL.md +232 -232
  33. package/.claude/skills/kol-outreach/template/campaign/CONFIG.md +60 -60
  34. package/.claude/skills/kol-outreach/template/campaign/KOLS.md +6 -6
  35. package/.claude/skills/kol-outreach/template/campaign/PROGRESS.md +3 -3
  36. package/.claude/skills/kol-outreach/template/campaign/TEMPLATES.md +88 -88
  37. package/.claude/skills/kol-outreach/template/merchant/BRAND.md +36 -36
  38. package/.claude/skills/kol-outreach/template/merchant/CAMPAIGNS.md +6 -6
  39. package/.claude/skills/kol-outreach/template/merchant/MERCHANT_LIMITS.md +16 -16
  40. package/.claude/skills/kol-outreach/template/merchant/PROGRESS.md +4 -4
  41. package/.claude/skills/kol-outreach/template/merchant/README.md +20 -20
  42. package/.claude/skills/linting-the-wiki/SKILL.md +68 -68
  43. package/.claude/skills/logistics/SKILL.md +180 -180
  44. package/.claude/skills/markdown-pdf/SKILL.md +72 -72
  45. package/.claude/skills/merchant/SKILL.md +110 -110
  46. package/.claude/skills/multigrid-poster/SKILL.md +192 -192
  47. package/.claude/skills/multigrid-poster/layouts/2x2.json +34 -34
  48. package/.claude/skills/multigrid-poster/layouts/3x3.json +43 -43
  49. package/.claude/skills/multigrid-poster/scripts/compose.py +116 -116
  50. package/.claude/skills/order/SKILL.md +452 -452
  51. package/.claude/skills/product/SKILL.md +379 -379
  52. package/.claude/skills/product-page/SKILL.md +106 -106
  53. package/.claude/skills/querying-the-wiki/SKILL.md +59 -59
  54. package/.claude/skills/reddit/SKILL.md +277 -277
  55. package/.claude/skills/review/SKILL.md +321 -321
  56. package/.claude/skills/scout/SKILL.md +575 -575
  57. package/.claude/skills/sentinel/SKILL.md +281 -281
  58. package/.claude/skills/shein/SKILL.md +246 -246
  59. package/.claude/skills/shipping/SKILL.md +200 -200
  60. package/.claude/skills/shop-content/SKILL.md +101 -101
  61. package/.claude/skills/shopify/SKILL.md +282 -282
  62. package/.claude/skills/skillify/SKILL.md +114 -114
  63. package/.claude/skills/taobao/SKILL.md +238 -238
  64. package/.claude/skills/tiktok/SKILL.md +381 -381
  65. package/.claude/skills/twitter/SKILL.md +302 -302
  66. package/.claude/skills/updating-related-pages/SKILL.md +65 -65
  67. package/.claude/skills/video-edit/SKILL.md +138 -138
  68. package/.claude/skills/video-gen/SKILL.md +630 -548
  69. package/.claude/skills/video-gen/templates/INDEX.md +78 -78
  70. package/.claude/skills/video-gen/templates/before-after-beauty.md +183 -183
  71. package/.claude/skills/video-gen/templates/drama-fmcg.md +183 -183
  72. package/.claude/skills/video-gen/templates/kol-reaction-food.md +193 -193
  73. package/.claude/skills/video-gen/templates/multi-point-apparel.md +185 -185
  74. package/.claude/skills/video-gen/templates/pain-solution-home.md +184 -184
  75. package/.claude/skills/video-gen/templates/pdp-360-showcase.md +189 -189
  76. package/.claude/skills/video-gen/templates/pdp-feature-highlight.md +182 -182
  77. package/.claude/skills/video-gen/templates/scene-digital.md +183 -183
  78. package/.claude/skills/wechat/SKILL.md +174 -174
  79. package/.claude/skills/xhs/SKILL.md +170 -170
  80. package/README.md +276 -276
  81. package/dist/bin/optima.js +26 -26
  82. package/dist/bin/serve.js +23 -23
  83. package/dist/bin/video-edit.d.ts +3 -0
  84. package/dist/bin/video-edit.d.ts.map +1 -0
  85. package/dist/bin/video-edit.js +153 -0
  86. package/dist/bin/video-edit.js.map +1 -0
  87. package/dist/src/agent.d.ts +1 -1
  88. package/dist/src/agent.js +4 -4
  89. package/dist/src/system-prompt.d.ts.map +1 -1
  90. package/dist/src/system-prompt.js +175 -173
  91. package/dist/src/system-prompt.js.map +1 -1
  92. package/dist/src/tools/memory.js +10 -10
  93. package/dist/src/ui/headless.js +7 -7
  94. package/package.json +79 -79
@@ -1,452 +1,452 @@
1
- ---
2
- name: order
3
- description: Order fulfillment and shipping management. Process orders, ship packages, handle cancellations, manage refunds, track shipments. Use when user needs to fulfill orders, ship products, cancel orders, process refunds, or check shipping status.
4
- ---
5
-
6
- # Commerce CLI - Order Fulfillment
7
-
8
- 订单履行模块,用于处理订单、发货、售后和物流跟踪。
9
-
10
- ## 典型场景
11
-
12
- 当用户说:
13
- - "查看待发货订单" → `commerce order list --status paid`
14
- - "订单XX发货" → 先查订单详情,根据 shipping_mode_used 决定发货方式(见下方流程)
15
- - "单号XX发货" / "只有运单号" → 只需提供运单号即可发货,carrier 可选,后端自动检测快递公司
16
- - "查询订单物流" / "包裹到哪了" → `commerce order tracking --id XX`
17
- - "运单标签好了吗" / "查标签" → `commerce order refresh-label --id XX`
18
- - "取消订单XX" → `commerce order cancel --id XX --yes`
19
- - "标记订单已送达" → `commerce order mark-delivered --id XX`
20
- - "处理退款" → `commerce refund create --order-id XX --amount YY`
21
-
22
- ### 场景决策表
23
-
24
- | 用户需求 | 推荐命令 | 关键注意点 |
25
- |---------|---------|-----------|
26
- | 查看待发货订单 | `order list --status paid` | 按付款时间升序,优先处理早期订单 |
27
- | 批量发货 | 循环 `order ship` | 必须有真实tracking号,避免虚假发货 |
28
- | 取消订单 | `order cancel --yes` | 检查是否已发货,避免错误取消 |
29
- | 处理退款 | `refund create` → `refund approve` | 先创建后审批,保留审计记录 |
30
- | 物流异常 | `order tracking` → `order update-shipping-status` | 主动更新状态,及时通知客户 |
31
-
32
- ### 标准订单履行流程
33
- 1. **查看待发货** - `commerce order list --status paid` 按时间升序
34
- 2. **验证订单** - 检查库存、地址、特殊要求
35
- 3. **批量打包** - 准备商品、包装材料、打印面单
36
- 4. **标记发货** - 循环 `commerce order ship --id XX --tracking YY`(carrier 可选)
37
- 5. **物流跟踪** - 定期 `commerce order tracking` 监控异常
38
- 6. **确认送达** - 签收后 `commerce order mark-delivered --id XX`
39
-
40
- ### 发货流程详解(重要)
41
-
42
- 订单发货需要根据 `shipping_mode_used` 字段选择正确的发货方式。
43
-
44
- #### 运费模式说明
45
-
46
- | shipping_mode_used | 含义 | 发货方式 |
47
- |--------------------|------|----------|
48
- | `easyship` | 买家选择了动态运费快递(DYNAMIC) | 自动发货 / 指定方案 / 手动 |
49
- | `fixed` | 买家使用固定运费 | 指定方案 / 手动 |
50
- | `free` | 全球免运费 | 指定方案 / 手动 |
51
- | 空/null | 历史订单 | 指定方案 / 手动 |
52
-
53
- #### 发货流程
54
-
55
- 卖家说"发货" → 查订单 → AskUserQuestion "如何发货?"
56
-
57
- **DYNAMIC 订单**(买家已选物流方案,有 selected_courier_id):
58
- - 选项 1: 使用买家选择的物流方案 → `commerce order ship --id <order-id> --auto`
59
- - 选项 2: 使用其他系统物流方案 → 先 `logistics rates query` 查报价 → AskUserQuestion 展示方案 → 卖家选 → `commerce order ship --id <order-id> --rate-id <selected-rate-id>`
60
- - 选项 3: 自己处理 → 卖家提供 tracking number → `commerce order ship --id <order-id> --tracking <number> [--carrier <name>]`
61
-
62
- **FREE/FIXED 订单**(无 selected_courier_id):
63
- - 选项 1: 使用系统物流 → 先 `logistics rates query` 查报价 → AskUserQuestion 展示方案 → 卖家选 → `commerce order ship --id <order-id> --rate-id <selected-rate-id>`
64
- - 选项 2: 自己处理 → 卖家提供 tracking number → `commerce order ship --id <order-id> --tracking <number> [--carrier <name>]`
65
-
66
- 三种 CLI 路径:
67
- - `--auto`:仅 DYNAMIC 默认方案(使用买家 checkout 时选的 courier)
68
- - `--rate-id <id>`:任意模式,卖家/AI 指定方案
69
- - `--tracking <number>`:手动发货
70
-
71
- #### 发货决策规则(必须严格遵守)
72
-
73
- 当用户说"订单XXX发货"时,按以下步骤执行:
74
-
75
- **步骤1**:执行 `commerce order get --id XXX` 获取订单详情
76
-
77
- **步骤2**:在返回结果中找到 `shipping_mode_used` 字段的值
78
-
79
- **步骤3**:根据字段值决定下一步操作:
80
-
81
- - **如果 `shipping_mode_used = "easyship"`(DYNAMIC 订单)**:
82
- 1. **必须**使用 AskUserQuestion 工具询问用户
83
- 2. 提供三个选项:使用买家方案(--auto)、选择其他方案(--rate-id)、手动发货(--tracking)
84
- 3. **禁止**直接询问运单号
85
- 4. 等待用户选择后再执行对应命令
86
-
87
- - **如果 `shipping_mode_used = "fixed"` 或 `"free"` 或字段为空**:
88
- 1. **必须**使用 AskUserQuestion 工具询问用户
89
- 2. 提供两个选项:使用系统物流(--rate-id)、手动发货(--tracking)
90
- 3. 如果用户选择系统物流,先 `logistics rates query` 查报价,再用 AskUserQuestion 展示可用方案
91
- 4. 如果用户选择手动发货:询问运单号,快递公司名称为**可选**
92
- 5. **即使用户提供了快递公司名称,发货时也统一不传 carrier**,让后端根据运单号自动检测并存储准确的快递公司名称(人类可读,如 "SF Express"、"UPS")。发货成功后对比响应中的 carrier 与用户所说的:
93
- - 一致 → 正常告知
94
- - 不一致 → 告知用户:"您提供的是 XX,系统根据运单号识别为 YY,已按识别结果记录。如有误请告知。"
95
-
96
- #### 系统物流发货
97
-
98
- **适用场景**:任意 shipping_mode_used,用户选择使用系统物流
99
-
100
- **命令**:
101
- ```bash
102
- # DYNAMIC 订单 — 使用买家选择的快递(推荐)
103
- commerce order ship --id <order-id> --auto
104
-
105
- # DYNAMIC 订单 — 指定其他快递
106
- commerce order ship --id <order-id> --auto --courier-id <courier-id>
107
-
108
- # 任意模式 — 使用指定的物流方案(先查 logistics rates query)
109
- commerce order ship --id <order-id> --rate-id <rate-id>
110
- ```
111
-
112
- **返回结果包含**:
113
- - `tracking_number`: 自动生成的运单号
114
- - `tracking_url`: 快递跟踪链接
115
- - `label_url`: 运单标签下载链接(可能为空)
116
- - `label_state`: 标签状态
117
- - `carrier`: 快递公司名称
118
-
119
- **运单标签处理(重要)**:
120
-
121
- 运单标签是用户必须打印并贴在包裹上的快递单。物流服务生成标签需要几秒到几分钟。
122
-
123
- **发货后根据 label_state 处理**:
124
-
125
- | label_state | 含义 | 处理方式 |
126
- |-------------|------|----------|
127
- | `generated` / `printed` | 标签已生成 | 提供 `label_url` 让用户下载打印 |
128
- | `pending` / `generating` | 标签生成中 | 告知用户「标签正在生成,稍后可以让我帮你查询」 |
129
- | `failed` / `technical_failed` | 生成失败 | 告知用户需要检查物流服务后台或重新发货 |
130
-
131
- **查询标签状态**:
132
-
133
- 如果发货时 label_state 为 pending/generating,稍后使用 `order refresh-label` 同步最新状态:
134
- ```bash
135
- commerce order refresh-label --id <order-id>
136
- ```
137
- 返回最新的 `label_state` 和 `label_url`(如已生成)。
138
-
139
- **查看可用快递**:
140
- ```bash
141
- commerce easyship couriers
142
- ```
143
-
144
- #### 手动发货
145
-
146
- **适用场景**:
147
- - `shipping_mode_used = "fixed"` 或 `"free"` 或为空
148
- - 或用户选择不使用 Easyship
149
-
150
- **命令**:
151
- ```bash
152
- # 推荐:只提供运单号,后端自动检测快递公司并生成追踪链接
153
- commerce order ship --id <order-id> --tracking <运单号>
154
-
155
- # 可选参数(一般不需要手动指定)
156
- # --carrier <快递公司名称> 后端会自动检测,通常无需手动指定
157
- # --tracking-url <跟踪链接> 后端自动生成 AfterShip 链接
158
- ```
159
-
160
- **示例**:
161
- ```bash
162
- # 只提供运单号(推荐,后端自动检测快递公司和生成追踪链接)
163
- commerce order ship --id order_123 --tracking SF1234567890
164
-
165
- # 指定快递公司
166
- commerce order ship --id order_123 \
167
- --tracking SF1234567890 \
168
- --carrier "顺丰速运"
169
-
170
- # 完整参数(带跟踪链接)
171
- commerce order ship --id order_123 \
172
- --tracking DHL9876543210 \
173
- --carrier "DHL Express" \
174
- --tracking-url "https://www.dhl.com/track?num=DHL9876543210"
175
- ```
176
-
177
- #### 物流状态更新(手动发货后)
178
-
179
- ```bash
180
- # 更新为运输中
181
- commerce order update-shipping-status --id <order-id> --status in_transit
182
-
183
- # 更新为派送中
184
- commerce order update-shipping-status --id <order-id> --status out_for_delivery
185
-
186
- # 标记已送达
187
- commerce order mark-delivered --id <order-id>
188
- ```
189
-
190
- #### 发货场景示例对话
191
-
192
- **场景1:DYNAMIC 订单(买家已选物流方案)**
193
- ```
194
- 用户:订单 order_abc 发货
195
-
196
- 助手:[执行 Bash: commerce order get --id order_abc]
197
- [发现 shipping_mode_used = "easyship",有 selected_courier_id]
198
- [使用 AskUserQuestion 工具]
199
-
200
- AskUserQuestion:
201
- question: "该订单买家已选择物流方案,请选择发货方式"
202
- options:
203
- - label: "使用买家选择的物流方案(推荐)"
204
- description: "自动生成运单号和标签,使用买家 checkout 时选的快递"
205
- - label: "选择其他系统物流方案"
206
- description: "查询可用物流方案,选择后创建运单"
207
- - label: "手动填写运单号"
208
- description: "自己处理物流,需要提供运单号"
209
-
210
- 用户:[选择使用买家方案]
211
-
212
- 助手:[执行 Bash: commerce order ship --id order_abc --auto]
213
- [检查返回结果中的 label_state]
214
- 发货成功!运单号 ES123456789,快递公司 FedEx。
215
- 运单标签已生成,请下载打印后贴在包裹上:https://...
216
- ```
217
-
218
- **场景2:FREE/FIXED 订单(使用系统物流)**
219
- ```
220
- 用户:订单 order_xyz 发货
221
-
222
- 助手:[执行 Bash: commerce order get --id order_xyz]
223
- [发现 shipping_mode_used = "fixed",无 selected_courier_id]
224
- [使用 AskUserQuestion 工具]
225
-
226
- AskUserQuestion:
227
- question: "该订单使用固定运费模式,请选择发货方式"
228
- options:
229
- - label: "使用系统物流"
230
- description: "查询可用物流方案,选择后自动创建运单和标签"
231
- - label: "手动填写运单号"
232
- description: "自己处理物流,需要提供运单号"
233
-
234
- 用户:[选择系统物流]
235
-
236
- 助手:[执行 Bash: logistics rates query --origin '...' --destination '...' --items '...']
237
- [查到 3 个可用方案]
238
- [使用 AskUserQuestion 展示方案]
239
-
240
- AskUserQuestion:
241
- question: "以下是可用的物流方案,请选择"
242
- options:
243
- - label: "Standard Shipping (7-15 days) - ¥72.00 CNY"
244
- - label: "Economy Shipping (15-25 days) - ¥45.00 CNY"
245
- - label: "Express Shipping (3-7 days) - ¥128.00 CNY"
246
-
247
- 用户:[选择 Standard Shipping]
248
-
249
- 助手:[执行 Bash: commerce order ship --id order_xyz --rate-id rate_abc123]
250
- 发货成功!运单号 JD123456789。
251
- ```
252
-
253
- **场景3:手动发货(用户直接提供运单号)**
254
- ```
255
- 用户:订单 order_abc 发货,单号 YT9876543210
256
-
257
- 助手:[执行 Bash: commerce order get --id order_abc]
258
- [发现 shipping_mode_used = "fixed"]
259
- [用户已提供运单号,直接发货]
260
- [执行 Bash: commerce order ship --id order_abc --tracking YT9876543210]
261
- 发货成功!运单号 YT9876543210,快递公司 YTO Express(自动识别)。
262
- 随时可以让我帮你查询物流状态。
263
- ```
264
-
265
- **场景4:用户提供了快递公司名称(carrier 确认)**
266
- ```
267
- 用户:订单 order_def 发货,顺丰,单号 773456789012
268
-
269
- 助手:[执行 Bash: commerce order get --id order_def]
270
- [发现 shipping_mode_used = "fixed"]
271
- [用户提供了 carrier "顺丰",但统一不传 carrier,让后端自动检测]
272
- [执行 Bash: commerce order ship --id order_def --tracking 773456789012]
273
-
274
- [情况A:检测结果与用户一致]
275
- 发货成功!运单号 773456789012,快递公司 SF Express(自动识别)。
276
- 随时可以让我帮你查询物流状态。
277
-
278
- [情况B:检测结果与用户不一致]
279
- 发货成功!运单号 773456789012。
280
- 提示:您说的快递公司是顺丰,但系统根据运单号识别为 YTO Express,已按识别结果记录。如有误请告知我修正。
281
- 随时可以让我帮你查询物流状态。
282
- ```
283
-
284
- ### 退款处理流程
285
- 1. **创建退款** - `commerce refund create` 填写详细原因
286
- 2. **审核评估** - 检查商品状态、退货凭证、历史记录
287
- 3. **批准/拒绝** - `commerce refund approve/reject` 并通知客户
288
- 4. **跟踪反馈** - 记录退款原因,优化产品和服务
289
-
290
- ## 卓越标准
291
-
292
- ### 订单处理质量指标
293
- - **发货及时性**: 付款后24小时内发货(标品),48小时内发货(定制品)
294
- - **物流信息准确性**: 100%订单有tracking number,无虚假单号
295
- - **客户满意度**: 退款率 < 5%,客服投诉响应 < 2小时
296
- - **订单完成率**: 取消率 < 3%,拒收率 < 2%
297
-
298
- ### 订单状态管理原则
299
- - **3-5-7原则**: 3分钟确认订单,5小时内完成打包,7天内跟踪售后
300
- - **自动化优先**: 批量处理相同状态订单,优先处理付款时间早的订单
301
- - **数据完整性**: 发货前验证库存、收货地址、物流商可达性
302
- - **客户沟通**: 关键状态变更后及时通知(发货、延迟、退款、取消)
303
- - **审计留痕**: 所有操作记录原因和操作人,便于问题追溯
304
-
305
- ## 常见问题
306
-
307
- ### 批量发货错误
308
-
309
- ❌ **危险做法 - 不验证就批量发货**:
310
- ```bash
311
- # 可能发错货或虚假发货
312
- for order_id in $(commerce order list --status paid --json | jq -r '.[].id'); do
313
- commerce order ship --id $order_id --tracking FAKE123 --carrier DHL
314
- done
315
- ```
316
-
317
- ✅ **正确做法 - 先验证再批量发货**:
318
- ```bash
319
- # 先查看订单列表
320
- commerce order list --status paid
321
-
322
- # 准备好所有真实tracking号后,逐个发货(carrier 可选)
323
- commerce order ship --id order_123 --tracking DHL123456
324
- commerce order ship --id order_456 --tracking DHL123457
325
- commerce order ship --id order_789 --tracking DHL123458
326
- ```
327
-
328
- ### 订单取消场景
329
-
330
- ❌ **错误操作 - 已发货还取消**:
331
- - 不检查订单状态直接取消,导致客户收到货但订单已取消
332
-
333
- ✅ **正确处理**:
334
- - **客户主动取消** → 检查是否已发货,未发货立即取消
335
- - **地址错误无法送达** → 联系客户更新地址或取消退款
336
- - **库存不足** → 立即通知客户,协商补货或退款
337
-
338
- ### 退款处理错误
339
-
340
- ❌ **错误流程 - 直接批准未审核的退款**:
341
- - 不检查商品状态、退货凭证就批准,容易被恶意退款
342
-
343
- ✅ **正确流程**:
344
- - **商品质量问题** → 无需退货,直接全额退款
345
- - **客户不满意** → 要求退货,收到货后退款
346
- - **物流丢失** → 联系物流商理赔,先行退款给客户
347
-
348
- ### 物流延迟处理
349
-
350
- ❌ **错误做法 - 不主动通知客户**:
351
- - 物流延迟不告知客户,导致客户投诉和差评
352
-
353
- ✅ **正确处理**:
354
- - **国内延迟 > 3天** → 主动联系客户说明情况
355
- - **国际延迟 > 7天** → 提供物流追踪链接,协商解决方案
356
- - **物流丢失** → 联系物流商查询,必要时补发或退款
357
-
358
- ## 命令参考
359
-
360
- ### 订单管理
361
- - `commerce order list` - 查看订单列表
362
- - `commerce order get` - 查看订单详情
363
- - `commerce order ship` - 标记订单发货(carrier 可选,后端自动检测)
364
- - `commerce order tracking` - 查询物流跟踪(含轨迹、预计送达)
365
- - `commerce order refresh-label` - 刷新 Easyship 运单标签状态
366
- - `commerce order update-shipping-status` - 更新物流状态
367
- - `commerce order cancel` - 取消订单
368
- - `commerce order complete` - 完成订单
369
- - `commerce order mark-delivered` - 标记已送达
370
-
371
- ### 退款管理
372
- - `commerce refund create` - 创建退款
373
- - `commerce refund list` - 查看退款列表
374
- - `commerce refund get` - 查看退款详情
375
- - `commerce refund approve` - 批准退款
376
- - `commerce refund reject` - 拒绝退款
377
-
378
- ### Easyship 集成
379
- - `commerce easyship couriers` - 查看可用快递公司
380
- - `commerce easyship rates --order-id <id>` - 获取订单运费报价
381
-
382
- ## 详细示例
383
-
384
- ### 查看待处理订单
385
- ```bash
386
- # 用户说:"查看今天待发货的订单"
387
- commerce order list --status paid --limit 50
388
- ```
389
-
390
- ### 订单发货
391
- ```bash
392
- # 步骤1:先获取订单信息,检查 shipping_mode_used
393
- commerce order get --id order_123
394
-
395
- # DYNAMIC 订单 — 使用买家选择的方案
396
- commerce order ship --id order_123 --auto
397
-
398
- # 任意模式 — 指定物流方案(先查 logistics rates query 获取 rate-id)
399
- commerce order ship --id order_123 --rate-id rate_abc123
400
-
401
- # 手动发货 — 只需提供运单号,carrier 可选
402
- commerce order ship --id order_123 --tracking DHL123456
403
- ```
404
-
405
- ### 取消订单
406
- ```bash
407
- # 用户说:"取消订单order_456,原因是客户要求"
408
- commerce order cancel \
409
- --id order_456 \
410
- --reason "客户要求取消" \
411
- --yes
412
- ```
413
-
414
- ### 标记订单完成
415
- ```bash
416
- # 用户说:"标记订单order_789已送达"
417
- commerce order mark-delivered --id order_789
418
- ```
419
-
420
- ### 处理退款
421
- ```bash
422
- # 用户说:"订单order_123要退款150美元"
423
- commerce refund create \
424
- --order-id order_123 \
425
- --amount 150 \
426
- --reason "商品有瑕疵"
427
-
428
- # 批准退款
429
- commerce refund approve --id refund_456
430
- ```
431
-
432
- ### 物流追踪
433
- ```bash
434
- # 用户说:"查询订单order_123的物流信息"
435
- # 返回物流轨迹(checkpoints)、预计送达时间、当前状态
436
- commerce order tracking --id order_123
437
- ```
438
-
439
- **响应指导**:
440
- - **有 checkpoints**:展示当前状态、预计送达时间、轨迹列表
441
- - **checkpoints 为空**:告诉用户"物流信息同步中,快递公司通常需要几小时更新,稍后可以再查"
442
- - **可以**:展示返回的 tracking_url(用户自己决定是否点击)
443
- - **禁止**:主动建议用户"去快递官网查询"或"用小程序/APP查询"。平台提供物流追踪服务,应引导用户通过平台查询
444
-
445
- ## 重要提示
446
-
447
- - 订单状态流转:pending → paid → shipped → delivered → completed
448
- - 取消和删除操作需要 `--yes` 确认
449
- - 发货后订单状态自动变为 shipped
450
- - 退款需要先创建,然后批准才会实际退款
451
- - 发货后**主动告知用户**"随时可以让我帮你查询物流状态"
452
- - 使用 `--help` 查看命令详细参数
1
+ ---
2
+ name: order
3
+ description: Order fulfillment and shipping management. Process orders, ship packages, handle cancellations, manage refunds, track shipments. Use when user needs to fulfill orders, ship products, cancel orders, process refunds, or check shipping status.
4
+ ---
5
+
6
+ # Commerce CLI - Order Fulfillment
7
+
8
+ 订单履行模块,用于处理订单、发货、售后和物流跟踪。
9
+
10
+ ## 典型场景
11
+
12
+ 当用户说:
13
+ - "查看待发货订单" → `commerce order list --status paid`
14
+ - "订单XX发货" → 先查订单详情,根据 shipping_mode_used 决定发货方式(见下方流程)
15
+ - "单号XX发货" / "只有运单号" → 只需提供运单号即可发货,carrier 可选,后端自动检测快递公司
16
+ - "查询订单物流" / "包裹到哪了" → `commerce order tracking --id XX`
17
+ - "运单标签好了吗" / "查标签" → `commerce order refresh-label --id XX`
18
+ - "取消订单XX" → `commerce order cancel --id XX --yes`
19
+ - "标记订单已送达" → `commerce order mark-delivered --id XX`
20
+ - "处理退款" → `commerce refund create --order-id XX --amount YY`
21
+
22
+ ### 场景决策表
23
+
24
+ | 用户需求 | 推荐命令 | 关键注意点 |
25
+ |---------|---------|-----------|
26
+ | 查看待发货订单 | `order list --status paid` | 按付款时间升序,优先处理早期订单 |
27
+ | 批量发货 | 循环 `order ship` | 必须有真实tracking号,避免虚假发货 |
28
+ | 取消订单 | `order cancel --yes` | 检查是否已发货,避免错误取消 |
29
+ | 处理退款 | `refund create` → `refund approve` | 先创建后审批,保留审计记录 |
30
+ | 物流异常 | `order tracking` → `order update-shipping-status` | 主动更新状态,及时通知客户 |
31
+
32
+ ### 标准订单履行流程
33
+ 1. **查看待发货** - `commerce order list --status paid` 按时间升序
34
+ 2. **验证订单** - 检查库存、地址、特殊要求
35
+ 3. **批量打包** - 准备商品、包装材料、打印面单
36
+ 4. **标记发货** - 循环 `commerce order ship --id XX --tracking YY`(carrier 可选)
37
+ 5. **物流跟踪** - 定期 `commerce order tracking` 监控异常
38
+ 6. **确认送达** - 签收后 `commerce order mark-delivered --id XX`
39
+
40
+ ### 发货流程详解(重要)
41
+
42
+ 订单发货需要根据 `shipping_mode_used` 字段选择正确的发货方式。
43
+
44
+ #### 运费模式说明
45
+
46
+ | shipping_mode_used | 含义 | 发货方式 |
47
+ |--------------------|------|----------|
48
+ | `easyship` | 买家选择了动态运费快递(DYNAMIC) | 自动发货 / 指定方案 / 手动 |
49
+ | `fixed` | 买家使用固定运费 | 指定方案 / 手动 |
50
+ | `free` | 全球免运费 | 指定方案 / 手动 |
51
+ | 空/null | 历史订单 | 指定方案 / 手动 |
52
+
53
+ #### 发货流程
54
+
55
+ 卖家说"发货" → 查订单 → AskUserQuestion "如何发货?"
56
+
57
+ **DYNAMIC 订单**(买家已选物流方案,有 selected_courier_id):
58
+ - 选项 1: 使用买家选择的物流方案 → `commerce order ship --id <order-id> --auto`
59
+ - 选项 2: 使用其他系统物流方案 → 先 `logistics rates query` 查报价 → AskUserQuestion 展示方案 → 卖家选 → `commerce order ship --id <order-id> --rate-id <selected-rate-id>`
60
+ - 选项 3: 自己处理 → 卖家提供 tracking number → `commerce order ship --id <order-id> --tracking <number> [--carrier <name>]`
61
+
62
+ **FREE/FIXED 订单**(无 selected_courier_id):
63
+ - 选项 1: 使用系统物流 → 先 `logistics rates query` 查报价 → AskUserQuestion 展示方案 → 卖家选 → `commerce order ship --id <order-id> --rate-id <selected-rate-id>`
64
+ - 选项 2: 自己处理 → 卖家提供 tracking number → `commerce order ship --id <order-id> --tracking <number> [--carrier <name>]`
65
+
66
+ 三种 CLI 路径:
67
+ - `--auto`:仅 DYNAMIC 默认方案(使用买家 checkout 时选的 courier)
68
+ - `--rate-id <id>`:任意模式,卖家/AI 指定方案
69
+ - `--tracking <number>`:手动发货
70
+
71
+ #### 发货决策规则(必须严格遵守)
72
+
73
+ 当用户说"订单XXX发货"时,按以下步骤执行:
74
+
75
+ **步骤1**:执行 `commerce order get --id XXX` 获取订单详情
76
+
77
+ **步骤2**:在返回结果中找到 `shipping_mode_used` 字段的值
78
+
79
+ **步骤3**:根据字段值决定下一步操作:
80
+
81
+ - **如果 `shipping_mode_used = "easyship"`(DYNAMIC 订单)**:
82
+ 1. **必须**使用 AskUserQuestion 工具询问用户
83
+ 2. 提供三个选项:使用买家方案(--auto)、选择其他方案(--rate-id)、手动发货(--tracking)
84
+ 3. **禁止**直接询问运单号
85
+ 4. 等待用户选择后再执行对应命令
86
+
87
+ - **如果 `shipping_mode_used = "fixed"` 或 `"free"` 或字段为空**:
88
+ 1. **必须**使用 AskUserQuestion 工具询问用户
89
+ 2. 提供两个选项:使用系统物流(--rate-id)、手动发货(--tracking)
90
+ 3. 如果用户选择系统物流,先 `logistics rates query` 查报价,再用 AskUserQuestion 展示可用方案
91
+ 4. 如果用户选择手动发货:询问运单号,快递公司名称为**可选**
92
+ 5. **即使用户提供了快递公司名称,发货时也统一不传 carrier**,让后端根据运单号自动检测并存储准确的快递公司名称(人类可读,如 "SF Express"、"UPS")。发货成功后对比响应中的 carrier 与用户所说的:
93
+ - 一致 → 正常告知
94
+ - 不一致 → 告知用户:"您提供的是 XX,系统根据运单号识别为 YY,已按识别结果记录。如有误请告知。"
95
+
96
+ #### 系统物流发货
97
+
98
+ **适用场景**:任意 shipping_mode_used,用户选择使用系统物流
99
+
100
+ **命令**:
101
+ ```bash
102
+ # DYNAMIC 订单 — 使用买家选择的快递(推荐)
103
+ commerce order ship --id <order-id> --auto
104
+
105
+ # DYNAMIC 订单 — 指定其他快递
106
+ commerce order ship --id <order-id> --auto --courier-id <courier-id>
107
+
108
+ # 任意模式 — 使用指定的物流方案(先查 logistics rates query)
109
+ commerce order ship --id <order-id> --rate-id <rate-id>
110
+ ```
111
+
112
+ **返回结果包含**:
113
+ - `tracking_number`: 自动生成的运单号
114
+ - `tracking_url`: 快递跟踪链接
115
+ - `label_url`: 运单标签下载链接(可能为空)
116
+ - `label_state`: 标签状态
117
+ - `carrier`: 快递公司名称
118
+
119
+ **运单标签处理(重要)**:
120
+
121
+ 运单标签是用户必须打印并贴在包裹上的快递单。物流服务生成标签需要几秒到几分钟。
122
+
123
+ **发货后根据 label_state 处理**:
124
+
125
+ | label_state | 含义 | 处理方式 |
126
+ |-------------|------|----------|
127
+ | `generated` / `printed` | 标签已生成 | 提供 `label_url` 让用户下载打印 |
128
+ | `pending` / `generating` | 标签生成中 | 告知用户「标签正在生成,稍后可以让我帮你查询」 |
129
+ | `failed` / `technical_failed` | 生成失败 | 告知用户需要检查物流服务后台或重新发货 |
130
+
131
+ **查询标签状态**:
132
+
133
+ 如果发货时 label_state 为 pending/generating,稍后使用 `order refresh-label` 同步最新状态:
134
+ ```bash
135
+ commerce order refresh-label --id <order-id>
136
+ ```
137
+ 返回最新的 `label_state` 和 `label_url`(如已生成)。
138
+
139
+ **查看可用快递**:
140
+ ```bash
141
+ commerce easyship couriers
142
+ ```
143
+
144
+ #### 手动发货
145
+
146
+ **适用场景**:
147
+ - `shipping_mode_used = "fixed"` 或 `"free"` 或为空
148
+ - 或用户选择不使用 Easyship
149
+
150
+ **命令**:
151
+ ```bash
152
+ # 推荐:只提供运单号,后端自动检测快递公司并生成追踪链接
153
+ commerce order ship --id <order-id> --tracking <运单号>
154
+
155
+ # 可选参数(一般不需要手动指定)
156
+ # --carrier <快递公司名称> 后端会自动检测,通常无需手动指定
157
+ # --tracking-url <跟踪链接> 后端自动生成 AfterShip 链接
158
+ ```
159
+
160
+ **示例**:
161
+ ```bash
162
+ # 只提供运单号(推荐,后端自动检测快递公司和生成追踪链接)
163
+ commerce order ship --id order_123 --tracking SF1234567890
164
+
165
+ # 指定快递公司
166
+ commerce order ship --id order_123 \
167
+ --tracking SF1234567890 \
168
+ --carrier "顺丰速运"
169
+
170
+ # 完整参数(带跟踪链接)
171
+ commerce order ship --id order_123 \
172
+ --tracking DHL9876543210 \
173
+ --carrier "DHL Express" \
174
+ --tracking-url "https://www.dhl.com/track?num=DHL9876543210"
175
+ ```
176
+
177
+ #### 物流状态更新(手动发货后)
178
+
179
+ ```bash
180
+ # 更新为运输中
181
+ commerce order update-shipping-status --id <order-id> --status in_transit
182
+
183
+ # 更新为派送中
184
+ commerce order update-shipping-status --id <order-id> --status out_for_delivery
185
+
186
+ # 标记已送达
187
+ commerce order mark-delivered --id <order-id>
188
+ ```
189
+
190
+ #### 发货场景示例对话
191
+
192
+ **场景1:DYNAMIC 订单(买家已选物流方案)**
193
+ ```
194
+ 用户:订单 order_abc 发货
195
+
196
+ 助手:[执行 Bash: commerce order get --id order_abc]
197
+ [发现 shipping_mode_used = "easyship",有 selected_courier_id]
198
+ [使用 AskUserQuestion 工具]
199
+
200
+ AskUserQuestion:
201
+ question: "该订单买家已选择物流方案,请选择发货方式"
202
+ options:
203
+ - label: "使用买家选择的物流方案(推荐)"
204
+ description: "自动生成运单号和标签,使用买家 checkout 时选的快递"
205
+ - label: "选择其他系统物流方案"
206
+ description: "查询可用物流方案,选择后创建运单"
207
+ - label: "手动填写运单号"
208
+ description: "自己处理物流,需要提供运单号"
209
+
210
+ 用户:[选择使用买家方案]
211
+
212
+ 助手:[执行 Bash: commerce order ship --id order_abc --auto]
213
+ [检查返回结果中的 label_state]
214
+ 发货成功!运单号 ES123456789,快递公司 FedEx。
215
+ 运单标签已生成,请下载打印后贴在包裹上:https://...
216
+ ```
217
+
218
+ **场景2:FREE/FIXED 订单(使用系统物流)**
219
+ ```
220
+ 用户:订单 order_xyz 发货
221
+
222
+ 助手:[执行 Bash: commerce order get --id order_xyz]
223
+ [发现 shipping_mode_used = "fixed",无 selected_courier_id]
224
+ [使用 AskUserQuestion 工具]
225
+
226
+ AskUserQuestion:
227
+ question: "该订单使用固定运费模式,请选择发货方式"
228
+ options:
229
+ - label: "使用系统物流"
230
+ description: "查询可用物流方案,选择后自动创建运单和标签"
231
+ - label: "手动填写运单号"
232
+ description: "自己处理物流,需要提供运单号"
233
+
234
+ 用户:[选择系统物流]
235
+
236
+ 助手:[执行 Bash: logistics rates query --origin '...' --destination '...' --items '...']
237
+ [查到 3 个可用方案]
238
+ [使用 AskUserQuestion 展示方案]
239
+
240
+ AskUserQuestion:
241
+ question: "以下是可用的物流方案,请选择"
242
+ options:
243
+ - label: "Standard Shipping (7-15 days) - ¥72.00 CNY"
244
+ - label: "Economy Shipping (15-25 days) - ¥45.00 CNY"
245
+ - label: "Express Shipping (3-7 days) - ¥128.00 CNY"
246
+
247
+ 用户:[选择 Standard Shipping]
248
+
249
+ 助手:[执行 Bash: commerce order ship --id order_xyz --rate-id rate_abc123]
250
+ 发货成功!运单号 JD123456789。
251
+ ```
252
+
253
+ **场景3:手动发货(用户直接提供运单号)**
254
+ ```
255
+ 用户:订单 order_abc 发货,单号 YT9876543210
256
+
257
+ 助手:[执行 Bash: commerce order get --id order_abc]
258
+ [发现 shipping_mode_used = "fixed"]
259
+ [用户已提供运单号,直接发货]
260
+ [执行 Bash: commerce order ship --id order_abc --tracking YT9876543210]
261
+ 发货成功!运单号 YT9876543210,快递公司 YTO Express(自动识别)。
262
+ 随时可以让我帮你查询物流状态。
263
+ ```
264
+
265
+ **场景4:用户提供了快递公司名称(carrier 确认)**
266
+ ```
267
+ 用户:订单 order_def 发货,顺丰,单号 773456789012
268
+
269
+ 助手:[执行 Bash: commerce order get --id order_def]
270
+ [发现 shipping_mode_used = "fixed"]
271
+ [用户提供了 carrier "顺丰",但统一不传 carrier,让后端自动检测]
272
+ [执行 Bash: commerce order ship --id order_def --tracking 773456789012]
273
+
274
+ [情况A:检测结果与用户一致]
275
+ 发货成功!运单号 773456789012,快递公司 SF Express(自动识别)。
276
+ 随时可以让我帮你查询物流状态。
277
+
278
+ [情况B:检测结果与用户不一致]
279
+ 发货成功!运单号 773456789012。
280
+ 提示:您说的快递公司是顺丰,但系统根据运单号识别为 YTO Express,已按识别结果记录。如有误请告知我修正。
281
+ 随时可以让我帮你查询物流状态。
282
+ ```
283
+
284
+ ### 退款处理流程
285
+ 1. **创建退款** - `commerce refund create` 填写详细原因
286
+ 2. **审核评估** - 检查商品状态、退货凭证、历史记录
287
+ 3. **批准/拒绝** - `commerce refund approve/reject` 并通知客户
288
+ 4. **跟踪反馈** - 记录退款原因,优化产品和服务
289
+
290
+ ## 卓越标准
291
+
292
+ ### 订单处理质量指标
293
+ - **发货及时性**: 付款后24小时内发货(标品),48小时内发货(定制品)
294
+ - **物流信息准确性**: 100%订单有tracking number,无虚假单号
295
+ - **客户满意度**: 退款率 < 5%,客服投诉响应 < 2小时
296
+ - **订单完成率**: 取消率 < 3%,拒收率 < 2%
297
+
298
+ ### 订单状态管理原则
299
+ - **3-5-7原则**: 3分钟确认订单,5小时内完成打包,7天内跟踪售后
300
+ - **自动化优先**: 批量处理相同状态订单,优先处理付款时间早的订单
301
+ - **数据完整性**: 发货前验证库存、收货地址、物流商可达性
302
+ - **客户沟通**: 关键状态变更后及时通知(发货、延迟、退款、取消)
303
+ - **审计留痕**: 所有操作记录原因和操作人,便于问题追溯
304
+
305
+ ## 常见问题
306
+
307
+ ### 批量发货错误
308
+
309
+ ❌ **危险做法 - 不验证就批量发货**:
310
+ ```bash
311
+ # 可能发错货或虚假发货
312
+ for order_id in $(commerce order list --status paid --json | jq -r '.[].id'); do
313
+ commerce order ship --id $order_id --tracking FAKE123 --carrier DHL
314
+ done
315
+ ```
316
+
317
+ ✅ **正确做法 - 先验证再批量发货**:
318
+ ```bash
319
+ # 先查看订单列表
320
+ commerce order list --status paid
321
+
322
+ # 准备好所有真实tracking号后,逐个发货(carrier 可选)
323
+ commerce order ship --id order_123 --tracking DHL123456
324
+ commerce order ship --id order_456 --tracking DHL123457
325
+ commerce order ship --id order_789 --tracking DHL123458
326
+ ```
327
+
328
+ ### 订单取消场景
329
+
330
+ ❌ **错误操作 - 已发货还取消**:
331
+ - 不检查订单状态直接取消,导致客户收到货但订单已取消
332
+
333
+ ✅ **正确处理**:
334
+ - **客户主动取消** → 检查是否已发货,未发货立即取消
335
+ - **地址错误无法送达** → 联系客户更新地址或取消退款
336
+ - **库存不足** → 立即通知客户,协商补货或退款
337
+
338
+ ### 退款处理错误
339
+
340
+ ❌ **错误流程 - 直接批准未审核的退款**:
341
+ - 不检查商品状态、退货凭证就批准,容易被恶意退款
342
+
343
+ ✅ **正确流程**:
344
+ - **商品质量问题** → 无需退货,直接全额退款
345
+ - **客户不满意** → 要求退货,收到货后退款
346
+ - **物流丢失** → 联系物流商理赔,先行退款给客户
347
+
348
+ ### 物流延迟处理
349
+
350
+ ❌ **错误做法 - 不主动通知客户**:
351
+ - 物流延迟不告知客户,导致客户投诉和差评
352
+
353
+ ✅ **正确处理**:
354
+ - **国内延迟 > 3天** → 主动联系客户说明情况
355
+ - **国际延迟 > 7天** → 提供物流追踪链接,协商解决方案
356
+ - **物流丢失** → 联系物流商查询,必要时补发或退款
357
+
358
+ ## 命令参考
359
+
360
+ ### 订单管理
361
+ - `commerce order list` - 查看订单列表
362
+ - `commerce order get` - 查看订单详情
363
+ - `commerce order ship` - 标记订单发货(carrier 可选,后端自动检测)
364
+ - `commerce order tracking` - 查询物流跟踪(含轨迹、预计送达)
365
+ - `commerce order refresh-label` - 刷新 Easyship 运单标签状态
366
+ - `commerce order update-shipping-status` - 更新物流状态
367
+ - `commerce order cancel` - 取消订单
368
+ - `commerce order complete` - 完成订单
369
+ - `commerce order mark-delivered` - 标记已送达
370
+
371
+ ### 退款管理
372
+ - `commerce refund create` - 创建退款
373
+ - `commerce refund list` - 查看退款列表
374
+ - `commerce refund get` - 查看退款详情
375
+ - `commerce refund approve` - 批准退款
376
+ - `commerce refund reject` - 拒绝退款
377
+
378
+ ### Easyship 集成
379
+ - `commerce easyship couriers` - 查看可用快递公司
380
+ - `commerce easyship rates --order-id <id>` - 获取订单运费报价
381
+
382
+ ## 详细示例
383
+
384
+ ### 查看待处理订单
385
+ ```bash
386
+ # 用户说:"查看今天待发货的订单"
387
+ commerce order list --status paid --limit 50
388
+ ```
389
+
390
+ ### 订单发货
391
+ ```bash
392
+ # 步骤1:先获取订单信息,检查 shipping_mode_used
393
+ commerce order get --id order_123
394
+
395
+ # DYNAMIC 订单 — 使用买家选择的方案
396
+ commerce order ship --id order_123 --auto
397
+
398
+ # 任意模式 — 指定物流方案(先查 logistics rates query 获取 rate-id)
399
+ commerce order ship --id order_123 --rate-id rate_abc123
400
+
401
+ # 手动发货 — 只需提供运单号,carrier 可选
402
+ commerce order ship --id order_123 --tracking DHL123456
403
+ ```
404
+
405
+ ### 取消订单
406
+ ```bash
407
+ # 用户说:"取消订单order_456,原因是客户要求"
408
+ commerce order cancel \
409
+ --id order_456 \
410
+ --reason "客户要求取消" \
411
+ --yes
412
+ ```
413
+
414
+ ### 标记订单完成
415
+ ```bash
416
+ # 用户说:"标记订单order_789已送达"
417
+ commerce order mark-delivered --id order_789
418
+ ```
419
+
420
+ ### 处理退款
421
+ ```bash
422
+ # 用户说:"订单order_123要退款150美元"
423
+ commerce refund create \
424
+ --order-id order_123 \
425
+ --amount 150 \
426
+ --reason "商品有瑕疵"
427
+
428
+ # 批准退款
429
+ commerce refund approve --id refund_456
430
+ ```
431
+
432
+ ### 物流追踪
433
+ ```bash
434
+ # 用户说:"查询订单order_123的物流信息"
435
+ # 返回物流轨迹(checkpoints)、预计送达时间、当前状态
436
+ commerce order tracking --id order_123
437
+ ```
438
+
439
+ **响应指导**:
440
+ - **有 checkpoints**:展示当前状态、预计送达时间、轨迹列表
441
+ - **checkpoints 为空**:告诉用户"物流信息同步中,快递公司通常需要几小时更新,稍后可以再查"
442
+ - **可以**:展示返回的 tracking_url(用户自己决定是否点击)
443
+ - **禁止**:主动建议用户"去快递官网查询"或"用小程序/APP查询"。平台提供物流追踪服务,应引导用户通过平台查询
444
+
445
+ ## 重要提示
446
+
447
+ - 订单状态流转:pending → paid → shipped → delivered → completed
448
+ - 取消和删除操作需要 `--yes` 确认
449
+ - 发货后订单状态自动变为 shipped
450
+ - 退款需要先创建,然后批准才会实际退款
451
+ - 发货后**主动告知用户**"随时可以让我帮你查询物流状态"
452
+ - 使用 `--help` 查看命令详细参数