Files
huangjingfen/pro_v3.5.1_副本/app/services/activity/card/CardBatchServices.php

134 lines
4.5 KiB
PHP
Raw Normal View History

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
2026-03-23 22:32:19 +08:00
<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2026 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
declare (strict_types=1);
namespace app\services\activity\card;
use app\dao\activity\card\CardBatchDao;
use app\services\BaseServices;
use think\annotation\Inject;
use think\db\exception\DataNotFoundException;
use think\db\exception\DbException;
use think\db\exception\ModelNotFoundException;
/**
* 卡次表
* Class CardBatchServices
* @package app\services\activity\card
* @mixin CardBatchDao
*/
class CardBatchServices extends BaseServices
{
/**
* @var CardBatchDao
*/
#[Inject]
protected CardBatchDao $dao;
/**
* 获取列表和总数
*
* 该方法主要用于根据给定的条件获取数据列表和总记录数
* 它封装了分页逻辑和数据获取逻辑,以简化调用
*
* @param array $where 查询条件数组
* @return array 包含数据列表和总记录数的数组
* @throws DataNotFoundException
* @throws DbException
* @throws ModelNotFoundException
*/
public function getList(array $where): array
{
[$page, $limit] = $this->getPageValue();
$where['is_del'] = 0;
$list = $this->dao->selectList($where, '*', $page, $limit, 'add_time desc', true);
$count = $this->dao->count($where);
return compact('list', 'count');
}
/**
* 保存数据方法
*
* 该方法用于处理数据的保存操作,根据提供的标识$id判断是更新现有记录还是创建新记录
* 使用事务确保数据一致性,在更新或创建过程中,涉及的操作要么全部完成,要么全部不完成
*
* @param int $id 要更新的记录的标识如果为0则表示创建新记录
* @param array $data 要保存的数据数组,包含需要更新或插入的字段和值
*
*/
public function saveData(array $data): bool
{
// 使用事务处理数据保存操作,确保数据的一致性和完整性
return $this->transaction(function () use ($data) {
// 如果$id不存在则创建新记录并在成功后处理相关的卡片信息
$saveData = $data;
// $saveData['total_num'] = pow(10, $data['total_num']);
unset($saveData['pwd_type'], $saveData['pwd_num']);
$saveData['add_time'] = time();
$res = $this->dao->save($saveData);
$data['batch_id'] = $res->id;
// 调用CardCodeServices服务的addCard方法为新创建的记录添加卡片信息
app()->make(CardCodeServices::class)->addCard($data);
return true;
});
}
/**
* 删除指定ID的批次记录
* @param int $id
* @return mixed
* User: liusl
* DateTime: 2025/5/9 15:48
*/
public function del(int $id)
{
return $this->transaction(function () use ($id) {
$this->update($id, ['is_del' => 1]);
app()->make(CardCodeServices::class)->delete(['batch_id' => $id, 'card_id' => 0]);
return true;
});
}
/**
* 获取卡密批次树形结构列表
* @return array
*/
public function getTree()
{
$list = $this->search(['is_del' => 0])->field('id,name,total_num,used_num')->select()->toArray();
foreach ($list as &$item) {
$item['remain_num'] = $item['total_num'] - $item['used_num'];
$item['remain_num'] = max($item['remain_num'], 0);
unset($item['total_num'], $item['used_num']);
}
unset($item);
return $list;
}
/**
* 分配卡密码并更新使用数量
* @param int $id 批次ID
* @return bool
*/
public function allocationCode($id)
{
$info = $this->dao->get($id);
if (!$info) {
return true;
}
$used_num = app()->make(CardCodeServices::class)->search(['batch_id' => $id])->where('status', '<>', 0)->count();
$info->used_num = $used_num;
$info->save();
return true;
}
}