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
153 lines
4.2 KiB
PHP
153 lines
4.2 KiB
PHP
<?php
|
||
// +----------------------------------------------------------------------
|
||
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
||
// +----------------------------------------------------------------------
|
||
// | Copyright (c) 2016~2026 https://www.crmeb.com All rights reserved.
|
||
// +----------------------------------------------------------------------
|
||
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
||
// +----------------------------------------------------------------------
|
||
// | Author: CRMEB Team <admin@crmeb.com>
|
||
// +----------------------------------------------------------------------
|
||
namespace app\controller\admin\v1\community;
|
||
|
||
use app\controller\admin\AuthController;
|
||
use app\Request;
|
||
use app\services\community\CommunityTopicServices;
|
||
use crmeb\exceptions\AdminException;use think\annotation\Inject;
|
||
|
||
/**
|
||
* 社区话题
|
||
* Class CommunityTopic
|
||
* @package app\controller\admin\v1\community
|
||
*/
|
||
class CommunityTopic extends AuthController
|
||
{
|
||
/**
|
||
* @var CommunityTopicServices
|
||
*/
|
||
#[Inject]
|
||
protected CommunityTopicServices $services;
|
||
|
||
/**
|
||
* 获取社区话题列表
|
||
* @param Request $request
|
||
* @return mixed
|
||
*/
|
||
public function index(Request $request)
|
||
{
|
||
$where = $request->postMore([
|
||
['name', ''],//标题
|
||
['is_recommend', ''],//推荐
|
||
['status', ''],//状态
|
||
]);
|
||
$data['type'] = 0;
|
||
$data['relation_id'] = 0;
|
||
return $this->success($this->services->sysPage($where));
|
||
}
|
||
|
||
/**
|
||
* 获取所有话题列表
|
||
* @return mixed
|
||
* @throws \think\db\exception\DataNotFoundException
|
||
* @throws \think\db\exception\DbException
|
||
* @throws \think\db\exception\ModelNotFoundException
|
||
*/
|
||
public function allTopic()
|
||
{
|
||
return $this->success($this->services->getAllTopic([],true));
|
||
}
|
||
|
||
|
||
/**
|
||
* 生成新增表单
|
||
* @return mixed
|
||
* @throws \FormBuilder\Exception\FormBuilderException
|
||
*/
|
||
public function create($id = '')
|
||
{
|
||
return $this->success($this->services->createForm($id));
|
||
}
|
||
|
||
/**
|
||
* 保存新增社区话题
|
||
* @return mixed
|
||
*/
|
||
public function save($id)
|
||
{
|
||
$data = $this->request->postMore([
|
||
['name', ''],
|
||
['sort', 0],
|
||
['is_recommend', 0],
|
||
['status', 0],
|
||
]);
|
||
if (!$data['name']) {
|
||
return $this->fail('请输入话题名称');
|
||
}
|
||
$topic = $this->services->getOne(['name' => $data['name'], 'is_del' => 0]);
|
||
if ($topic && (!$id || ($id && $topic['id'] != $id)) ) {
|
||
return $this->fail('话题已存在');
|
||
}
|
||
$data['type'] = 0;
|
||
$data['relation_id'] = 0;
|
||
if ($id) {
|
||
$res = $this->services->update($id, $data);
|
||
} else {
|
||
$data['add_time'] = time();
|
||
$res = $this->services->save($data);
|
||
}
|
||
if (!$res) return $this->fail('保存失败');
|
||
return $this->success('保存成功!');
|
||
}
|
||
|
||
/**
|
||
* 设置社区话题是否显示
|
||
* @param $id
|
||
* @param $status
|
||
* @return mixed
|
||
*/
|
||
public function setStatus($id, $status)
|
||
{
|
||
($status == '' || $id == '') && $this->fail('缺少参数');
|
||
$res = $this->services->update((int)$id, ['status' => (int)$status]);
|
||
if ($res) {
|
||
return $this->success('设置成功');
|
||
} else {
|
||
return $this->fail('设置失败');
|
||
}
|
||
}
|
||
|
||
|
||
/**
|
||
* 设置社区话题是否显示
|
||
* @param $id
|
||
* @param $hot
|
||
* @return mixed
|
||
*/
|
||
public function setHot($id, $hot)
|
||
{
|
||
($hot == '' || $id == '') && $this->fail('缺少参数');
|
||
$res = $this->services->update((int)$id, ['is_recommend' => (int)$hot]);
|
||
if ($res) {
|
||
return $this->success('设置成功');
|
||
} else {
|
||
return $this->fail('设置失败');
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 删除社区话题
|
||
* @param $id
|
||
* @return mixed
|
||
*/
|
||
public function delete($id)
|
||
{
|
||
if (!$id || !$this->services->count(['id' => $id, 'is_del' => 0])) {
|
||
return $this->fail('删除的数据不存在');
|
||
}
|
||
$this->services->update((int)$id, ['is_del' => 1]);
|
||
return $this->success('删除成功!');
|
||
}
|
||
|
||
|
||
}
|