feat(fsgx): 完成全部24项开发任务 Phase1-7

Phase1 后端核心:
- 新增 fsgx_v1.sql 迁移脚本(is_queue_goods/frozen_points/available_points/no_assess)
- SystemConfigServices 返佣设置扩展(周期人数/分档比例/范围/时机)
- StoreOrderCreateServices 周期循环佣金计算
- StoreOrderTakeServices 佣金发放后同步冻结积分
- StoreProductServices/StoreProduct 保存 is_queue_goods

Phase2 后端接口:
- GET /api/hjf/brokerage/progress 佣金周期进度
- GET /api/hjf/assets/overview 资产总览
- HjfPointsServices 每日 frozen_points 0.4‰ 释放定时任务
- PUT /adminapi/hjf/member/{uid}/no_assess 不考核接口
- GET /adminapi/hjf/points/release_log 积分日志接口

Phase3 前端清理:
- hjfCustom.js 路由精简(仅保留 points/log)
- hjfQueue.js/hjfMember.js API 清理/重定向至 CRMEB 原生接口
- pages.json 公排→推荐佣金/佣金记录/佣金规则

Phase4-5 前端改造:
- queue/status.vue 推荐佣金进度页整体重写
- 商品详情/订单确认/支付结果页文案与逻辑改造
- 个人中心/资产页/引导页/规则页文案改造
- HjfQueueProgress/HjfRefundNotice/HjfAssetCard 组件改造
- 推广中心嵌入佣金进度摘要
- hjfMockData.js 全量更新(公排字段→佣金字段)

Phase6 Admin 增强:
- 用户列表新增 frozen_points/available_points 列及不考核操作按钮
- hjfPoints.js USE_MOCK=false 对接真实积分日志接口

Phase7 配置文档:
- docs/fsgx-phase7-config-checklist.md 后台配置与全链路验收清单

Made-with: Cursor
This commit is contained in:
apple
2026-03-23 22:32:19 +08:00
parent 788ee0c0c0
commit 434aa8c69d
13098 changed files with 2008990 additions and 961 deletions

View File

@@ -0,0 +1,48 @@
# Conversation - 2026-03-10 19:20:13
## Prompt
改造页面 users/user_spread_money/index.vue推荐收益页
文件路径: /Users/apple/scott2026/huangjingfen/pro_v3.5.1/view/uniapp/pages/users/user_spread_money/index.vue
改造要求:
1. 使用 Vue 2 Options API
2. 导入 getTeamData, getTeamIncome from '@/api/hjfMember.js'
3. 在现有推荐收益基础上,添加团队收益统计(直推人数、伞下人数、团队订单数)
4. data: 新增 teamData, teamIncome 字段
5. onShow: 加载团队数据
6. 模板: 在收益列表上方添加团队统计卡片
7. 参考: docs/frontend-new-pages-spec.md 第 5.1.7 节
完整 JSDoc。
## Response
The file has been updated. Here's a summary of every change made:
**导入**
- 新增 `import { getTeamData, getTeamIncome } from '@/api/hjfMember.js'`
**data**
- 旧的 `teamStats`(直接拼接在 `spreadCount` 调用里)替换为两个独立字段:
- `teamData: { direct_count, umbrella_count, umbrella_orders }` — 对应 `MOCK_TEAM_DATA` 的字段
- `teamIncome: []` — 存储 `getTeamIncome` 返回的收益明细列表
**onShow**
- 每次页面显示时调用 `this.loadTeamData()`(在记录列表加载之前)
- 导航栏标题统一改为"推荐收益"(对应 spec 6.1.5 §1
**methods**
- 新增 `loadTeamData()`:并行调用 `getTeamData()``getTeamIncome()`,分别写入 `teamData``teamIncome`,带 `catch` 防止接口失败阻断页面
- 移除旧的 `getRecordListCount``getTeamStats`(已被 `loadTeamData` 整合)
- 全部方法补充 JSDoc 注释
**模板**
- 团队统计卡片改为读取 `teamData.direct_count``teamData.umbrella_count``teamData.umbrella_orders`(三栏:直推人数 / 伞下人数 / 团队订单数)
- 列表项积分数量展示:优先取 `item.points``MOCK_TEAM_INCOME` 字段),兼容旧字段 `item.number`,不带 ¥ 符号
- 新增积分来源标签(`直推奖励` / `伞下奖励`),通过 `item.type` 判断
**样式**
- 团队统计卡片使用绿色渐变背景,三栏等宽,分隔线半透明
- 新增 `.tag-direct` / `.tag-umbrella` 积分来源标签样式