123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296 |
- <?php
- namespace app\store\model\qc;
- use app\common\model\qc\QcMjSendActivity as QcMjSendActivityModel;
- use app\common\model\qc\QcMjSendGoods as QcMjSendGoodsModel;
- use app\common\model\qc\QcMjSendGiftGoods as QcMjSendGiftGoodsModel;
- use think\Exception;
- use think\facade\Log;
- /**
- * 全场满件赠活动模型
- * Class QcMjSendActivity
- * @package app\store\model\qc
- */
- class QcMjSendActivity extends QcMjSendActivityModel
- {
- protected $append = ['activity_status'];
- /**
- * 允许叠加其他优惠
- *
- * @param $value
- * @param $data
- * @return string
- */
- public function getOverlayDiscountTextAttr($value, $data)
- {
- $overlay_discount = !empty($data['overlay_discount']) ? explode(',', $data['overlay_discount']) : [];
- if (empty($overlay_discount)) {
- return '无';
- }
- $res = [];
- foreach ($overlay_discount as $item) {
- if (isset(self::OVERLAY_DISCOUNT[$item])) {
- $res[] = self::OVERLAY_DISCOUNT[$item];
- }
- }
- return implode(',', $res);
- }
- public function getActivityStatusAttr($value, $data)
- {
- if ($data['status'] == 2) {
- return ['code' => 4, 'text' => '已作废'];
- }
- if ($data['start_time'] > date('Y-m-d H:i:s')) {
- return ['code' => 2, 'text' => '未开始'];
- }
- if ($data['start_time'] <= date('Y-m-d H:i:s') && $data['end_time'] >= date('Y-m-d H:i:s')) {
- return ['code' => 1, 'text' => '进行中'];
- }
- if ($data['end_time'] < date('Y-m-d H:i:s')) {
- return ['code' => 3, 'text' => '已结束'];
- }
- return ['code' => 1, 'text' => '进行中'];
- }
- /**
- * 获取列表
- * @param array $param 查询条件
- * @param int $listRows 分页数量
- * @return mixed
- * @throws \think\db\exception\DbException
- */
- public function getList(array $param = [], int $listRows = 15)
- {
- // 检索查询条件
- $filter = $this->getQueryFilter($param);
- // 执行查询
- $list = $this->with([])
- ->where($filter)
- ->order(['audit_status' => 'asc', 'create_time' => 'desc'])
- ->paginate($listRows);
- return $list;
- }
- /**
- * 检索查询条件
- * @param array $param
- * @return mixed
- */
- private function getQueryFilter(array $param)
- {
- // 商品列表获取条件
- $params = $this->setQueryDefaultValue($param, [
- // 'is_delete' => 0,
- ]);
- // 筛选条件
- $filter = [];
- // 活动起止时间
- if (!empty($params['betweenTime'])) {
- $times = between_date($params['betweenTime']);
- $filter[] = ['start_time', '>=', $times['start_date']];
- $filter[] = ['end_time', '<=', $times['end_date']];
- }
- // 活动名称
- !empty($params['name']) && $filter[] = ['name', 'like', "%{$params['name']}%"];
- // 审核状态 0待审核 1审核通过 2审核不通过
- if (isset($params['auditStatus']) && $params['auditStatus'] > -1) {
- $filter[] = ['audit_status', '=', $params['auditStatus']];
- }
- //启用状态0禁用 1启用
- if (isset($params['status']) && $params['status'] > -1) {
- $filter[] = ['status', '=', $params['status']];
- }
- //活动状态
- if (isset($params['statusText']) && $params['statusText'] > 0) {
- switch ($params['statusText']) {
- case 4://已作废
- $filter[] = ['status', '=', 2];
- break;
- case 1://进行中
- $filter[] = ['start_time', '<=', date('Y-m-d H:i:s')];
- $filter[] = ['end_time', '>=', date('Y-m-d H:i:s')];
- $filter[] = ['audit_status', '=', 1];
- break;
- case 2://未开始
- $filter[] = ['start_time', '>', date('Y-m-d H:i:s')];
- break;
- case 3://已结束
- $filter[] = ['end_time', '<', date('Y-m-d H:i:s')];
- break;
- }
- }
- // 实例化新查询对象
- return $filter;
- }
- /**
- * 启用 禁用
- * @param array $data
- * @return bool
- */
- public function status(array $data): bool
- {
- $act = QcMjSendActivityModel::detail($data['activity_id']);
- if ($data['status'] == 1 && $this->checkGoodsValid($act)) return false;
- $this->transaction(function () use ($data) {
- $this->save($data);
- });
- return true;
- }
- /**
- * 审核
- * @param array $data
- * @return bool
- */
- public function audit(array $data): bool
- {
- $act = QcMjSendActivityModel::detail($data['activity_id']);
- if ($data['audit_status'] == 1 && $this->checkGoodsValid($act)) return false;
- $this->transaction(function () use ($data) {
- $this->save($data);
- $this->addAction($data['activity_id'], $data);
- });
- return true;
- }
- /**
- * 新增记录
- * @param array $data
- * @return int
- */
- public function addOne(array $data)
- {
- try {
- //检查是否已经有有效活动时间重叠了
- if ($this->checkGoodsValid($data)) {
- throw new \Exception('活动时间内存在其他进行中的全场满件赠活动');
- }
- $data['code'] = strval(mt_rand(100000000, 999999999));
- $this->transaction(function () use ($data) {
- $this->save($data);
- // 选择的商品存入
- $goodsModel = new QcMjSendGoodsModel();
- $goodsModel->add($this->id, $data['goods_ids'] ?? []);
- //赠品写入
- $giftGoodsModel = new QcMjSendGiftGoodsModel();
- $giftGoodsModel->add($this->id, $data['gift_ids']);
- //写入行为记录
- $data['audit_status'] = 0;
- $this->addAction($this->id, $data);
- });
- } catch (\Exception $e) {
- // dd($e->getMessage());
- Log::error(__METHOD__ . '::' . $e->getMessage());
- throwError($e->getMessage());
- return false;
- }
- return true;
- }
- //添加行为记录
- public function addAction($activity_id, $data)
- {
- $behavior = '';
- switch ($data['audit_status']) {
- case 0:
- $behavior = '提交审核';
- break;
- case 1:
- $behavior = '同意并发布活动';
- break;
- case 2:
- $behavior = '不同意';
- break;
- }
- $refuse['qc_mj_send_activity_id'] = $activity_id;
- $refuse['audit_status'] = $data['audit_status'];
- $refuse['audit_reason'] = $data['audit_reason'] ?? '';
- $refuse['behavior'] = $behavior;
- $refuse['audit_time'] = date("Y-m-d H:i:s", time());
- $refuse['audit_user'] = $data['audit_user'];
- $refuse['audit_admin_id'] = $data['audit_admin_id'];
- $refuseModel = new QcMjSendActivityAction();
- $refuseModel->save($refuse);
- }
- /**
- * 更新记录
- * @param array $data
- * @return bool
- */
- public function updOne(array $data)
- {
- try {
- if ($this->checkGoodsValid($data)) {
- throw new \Exception('活动时间内存在其他进行中的全场满件赠活动');
- }
- $this->transaction(function () use ($data) {
- $data['audit_status'] = 0;
- $this->save($data);
- //写入行为记录
- $couponActivityCouponModel = new QcMjSendGoodsModel();
- $couponActivityCouponModel->add($data['id'], $data['goods_ids'] ?? []);
- //赠品写入
- $giftGoodsModel = new QcMjSendGiftGoodsModel();
- $giftGoodsModel->add($data['id'], $data['gift_ids']);
- //写入行为记录
- $this->addAction($this->id, $data);
- });
- } catch (\Exception $e) {
- Log::error(__METHOD__ . '::' . $e->getMessage());
- throwError($e->getMessage());
- return false;
- }
- return true;
- }
- /**
- * 校验同款商品不能和正在有效期的活动时间交叉
- * @param $data
- * @return false
- */
- public function checkGoodsValid($data)
- {
- $now = date('Y-m-d H:i:s');
- $filter[] = ['start_time', '<', $now];
- $filter[] = ['end_time', '>', $now];
- $filter[] = ['audit_status', '=', 1];
- $filter[] = ['status', '=', 1];
- // $goodsId = $data['goods_ids'][0]??0;
- // if (!$goodsId)return false;
- $m = self::alias('ma')->where('ma.status', 1)
- ->leftJoin('qc_mj_send_goods ag', 'ag.qc_mj_send_activity_id = ma.id');
- if (!empty($data['id'])) {
- $m->where('ma.id', '<>', $data['id']);
- }
- return $m
- // ->where('ag.goods_id','=',$goodsId)
- ->where(function ($s) use ($data) {
- $s->whereOr(function ($query) use ($data) {
- $query->whereBetweenTime('ma.start_time', $data['start_time'], $data['end_time']);
- })->whereOr(function ($query) use ($data) {
- $query->whereBetweenTime('ma.end_time', $data['start_time'], $data['end_time']);
- })->whereOr(function ($query) use ($data) {
- $query->where('ma.start_time', '<', $data['start_time'])->where('end_time', '>', $data['end_time']);
- });
- })->find();
- }
- }
|