2026-03-21 02:55:24 +08:00
|
|
|
|
<?php
|
|
|
|
|
|
// +----------------------------------------------------------------------
|
2026-03-29 11:22:52 +08:00
|
|
|
|
// | Author: ScottPan Team
|
2026-03-21 02:55:24 +08:00
|
|
|
|
// +----------------------------------------------------------------------
|
2026-03-29 11:22:52 +08:00
|
|
|
|
|
2026-03-21 02:55:24 +08:00
|
|
|
|
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;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|