/install beautiful-shop
美妆电商购物助手
任务目标
- 本 Skill 用于:完整的电商购物流程
- 能力包含:用户登录、商品搜索、商品详情、加购/立即购买、下单、订单管理、物流查询、收货地址管理
- 触发条件:用户表达购买意图、查询商品、查看订单、管理地址等场景
前置准备
- 用户需先完成短信验证码登录
- 部分接口需要 accessToken 认证
核心流程
一、用户登录
触发时机:用户首次使用或需要下单时
执行步骤:
- 调用
scripts/auth/send_sms.py \x3C手机号>发送验证码 - 智能体提示用户输入验证码
- 调用
scripts/auth/sms_login.py \x3C手机号> \x3C验证码>完成登录 - 登录成功后获取 accessToken 和 refreshToken
测试环境:验证码固定为 111111
二、商品搜索
执行方式:调用脚本
python scripts/goods/search.py --keyword "洗面奶" --page 1 --size 10 --sort PRICE_ASC
参数说明:
--keyword:搜索关键词--page:页码,默认1--size:每页数量,默认10--sort:排序方式(PRICE_ASC/PRICE_DESC/SALE_DESC)
返回信息:商品列表包含 goodsId、skuId、goodsName、price、thumbnail、storeName 等
三、商品详情
执行方式:调用脚本
python scripts/goods/detail.py \x3CgoodsId> \x3CskuId>
返回信息:包含商品详细规格、SKU列表、价格、库存等
四、购物车管理
加购:python scripts/cart/add.py \x3CskuId> \x3C数量> BUY_NOW|CART
查看:python scripts/cart/list.py
数量:python scripts/cart/count.py
五、下单流程
立即购买(单个商品):
add_to_cart:加购(way=BUY_NOW)set_address:设置收货地址preview_order:预览订单确认价格create_order:创建订单获取 trade_sn- 返回支付链接
购物车结算(多个商品):
cart_list:查看购物车set_address:设置收货地址preview_order:预览订单create_order:创建订单
六、订单管理
订单列表:python scripts/order/list.py --status UNPAID --page 1
订单详情:python scripts/order/detail.py \x3CorderSn>
取消订单:python scripts/order/cancel.py \x3CorderSn> \x3C原因>
物流查询:python scripts/order/logistics.py \x3CorderSn>
七、收货地址管理
地址列表:python scripts/address/list.py
默认地址:python scripts/address/default.py
解析地址:python scripts/address/resolve.py \x3C省> \x3C市> \x3C区> [街道]
新增地址:python scripts/address/add.py \x3C姓名> \x3C手机> \x3C地址ID路径> \x3C地址名路径> \x3C详细地址> [是否默认]
设为默认:python scripts/address/set_default.py \x3CaddressId>
资源索引
认证脚本
| 脚本 | 功能 |
|---|---|
| scripts/auth/send_sms.py | 发送短信验证码 |
| scripts/auth/sms_login.py | 短信登录 |
商品脚本
| 脚本 | 功能 |
|---|---|
| scripts/goods/search.py | 搜索商品 |
| scripts/goods/detail.py | 商品详情 |
购物车脚本
| 脚本 | 功能 |
|---|---|
| scripts/cart/add.py | 加购物车/立即购买 |
| scripts/cart/list.py | 查看购物车 |
| scripts/cart/count.py | 购物车数量 |
订单脚本
| 脚本 | 功能 |
|---|---|
| scripts/order/set_address.py | 设置收货地址 |
| scripts/order/preview.py | 预览订单 |
| scripts/order/create.py | 创建订单 |
| scripts/order/list.py | 订单列表 |
| scripts/order/detail.py | 订单详情 |
| scripts/order/cancel.py | 取消订单 |
| scripts/order/logistics.py | 物流查询 |
地址脚本
| 脚本 | 功能 |
|---|---|
| scripts/address/list.py | 地址列表 |
| scripts/address/default.py | 默认地址 |
| scripts/address/resolve.py | 解析地址 |
| scripts/address/add.py | 新增地址 |
| scripts/address/set_default.py | 设为默认 |
参考文档
- references/api_guide.md:API 详细接口文档
典型对话示例
示例1:用户想购买商品
用户:我想买一款洗面奶
智能体:
1. 调用搜索脚本查找洗面奶
2. 展示商品列表(图片+价格+店铺)
3. 询问用户选择哪款商品
4. 用户确认后,调用商品详情脚本展示规格
用户:就选第一款
智能体:
1. 检查是否已登录
2. 未登录:发送验证码让用户登录
3. 登录成功后:
- 调用加购(BUY_NOW)
- 设置收货地址
- 预览订单
- 创建订单,获取 trade_sn
4. 返回支付链接给用户:
- APP支付:`https://app-buyer.filtalgo.com/pages/mine/payment/payOrder?trade_sn={trade_sn}`
- H5支付:`https://buyer.filtalgo.com/payment/cashier?paymentScene=TRADE&orderSn={trade_sn}`
示例2:用户查询订单
用户:查看我的订单
智能体:
1. 调用订单列表脚本
2. 展示订单列表(包含订单号、状态、金额、时间)
3. 询问用户需要什么操作(查看详情/取消/查物流)
示例3:新增收货地址
用户:添加一个新地址
智能体:
1. 询问收货人信息(姓名、手机、省市区、详细地址)
2. 用户提供后:
- 调用解析地址脚本获取 ID 路径
- 调用新增地址脚本
3. 确认添加成功
注意事项
- Token 管理:accessToken 有效期约 25 天,refreshToken 约 45 天
- 订单号区分:
- T 开头:交易单号(tradeSn),用于支付
- O 开头:子订单号(orderSn),用于查询/取消
- 地址类型:新增地址必须传
type=RECEIVE - way 参数:BUY_NOW=立即购买(单商品),CART=购物车模式
- 商品详情页:
- H5:
https://buyer.filtalgo.com/goodsDetail?goodsId={goodsId}&skuId={skuId} - APP:
https://app-buyer.filtalgo.com/pages/goods/product/detail?goodsId={goodsId}&skuId={skuId}
- H5:
- 确保已安装 OpenClaw(本地或 Docker 部署)
- 在对话框中输入安装命令:
/install beautiful-shop - 安装完成后,直接呼叫该 Skill 的名称或使用
/beautiful-shop触发 - 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
cosmetics-shopping 是什么?
美妆电商购物助手,支持商品搜索、加购下单、订单管理;当用户需要购买美妆产品、查询订单或管理收货地址时使用. 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 99 次。
如何安装 cosmetics-shopping?
在 OpenClaw 或 Claude Code 对话框中运行命令「/install beautiful-shop」即可一键安装,无需额外配置。
cosmetics-shopping 是免费的吗?
是的,cosmetics-shopping 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。
cosmetics-shopping 支持哪些平台?
cosmetics-shopping 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。
谁开发了 cosmetics-shopping?
由 bvcg204(@bvcg204)开发并维护,当前版本 v1.0.0。