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,127 @@
<template>
<view class="modal_container" v-if="visible" @touchmove.stop.prevent>
<view class="modal_box relative">
<view class="h-172 flex-col flex-center">
<view class="fs-32 lh-44rpx fw-500">核销信息</view>
<view class="fs-26 lh-36rpx mt-28" v-if="productType == 4">已核销 {{writeOff}} / 需要核销 {{writeTimes}}</view>
</view>
<view class="mt-52 flex-col flex-center">
<view class="qrcode flex-center">
<view class="qrcode_content">
<!-- #ifdef MP -->
<image :src="qrc" class="image"></image>
<!-- #endif -->
<!-- #ifdef H5 -->
<image v-if="$wechat.isWeixin()" :src="qrc" class="image"></image>
<w-qrcode v-else :options="qrcode"></w-qrcode>
<!-- #endif -->
<!-- #ifdef APP-PLUS -->
<w-qrcode :options="qrcode"></w-qrcode>
<!-- #endif -->
</view>
</view>
<view class="bg-primary-light qrocode-num rd-16rpx flex-center fs-32 fw-500 font-color mt-48">{{verifyCode}}</view>
<view class="mt-24 text--w111-999 fs-24" v-if="writeDay">核销时间{{writeDay}}</view>
</view>
<text class="iconfont icon-ic_close1 close fs-48 text--w111-fff"></text>
</view>
<view class="mask z-90" @click="closeModal"></view>
</view>
</template>
<script>
export default {
props:{
visible: {
type: Boolean,
default: false,
},
qrcode:{
type:Object,
default: ()=>{}
},
verifyCode:{
type: String,
default:""
},
writeDay:{
type: String,
default:""
},
writeOff:{
type: [String, Number],
default: 0
},
writeTimes:{
type: [String, Number],
default: 0
},
productType:{
type: Number,
default: 0
},
qrc:{
type: String,
default:""
},
},
methods:{
moveHandle(){
return false
},
closeModal(){
this.$emit('closeModal');
}
}
}
</script>
<style>
.modal_box{
position: fixed;
left: 50%;
top: 50%;
transform: translate(-50%,-50%);
z-index: 3000;
width:600rpx;
height:906rpx;
background:#fff;
border-radius:32rpx;
-webkit-mask: radial-gradient(circle at 14rpx 172rpx, transparent 14rpx, red 0) -14rpx;
}
.h-172{
height:172rpx;
border-bottom: 1px dashed #ccc;
}
.z-90{
z-index:2999;
}
.qrcode{
width:440rpx;
height:440rpx;
background-image: url('../../static/qrcode_bg.png');
background-size:100%;
background-repeat: no-repeat;
}
.qrcode_content{
width:360rpx;
height:360rpx;
}
.bg-primary-light{
background: var(--view-minorColorT);
}
.qrocode-num{
width:440rpx;
height:80rpx;
}
.close{
position: absolute;
left:50%;
bottom: -96rpx;
transform: translateX(-50%);
}
.qrcode_content .image {
width: 100%;
height: 100%;
}
</style>