dggzichahu/application/admin/validate/SeckillGoods.php

121 lines
4.2 KiB
PHP
Executable File

<?php
// +----------------------------------------------------------------------
// | 宏驰云科技开发团队 版权所有 拥有最终解释权
// +----------------------------------------------------------------------
// | Author: HcyShop-kiki
// +----------------------------------------------------------------------
namespace app\admin\validate;
use think\Db;
use think\Validate;
class SeckillGoods extends Validate{
protected $rule = [
'seckill_id' => 'require|checkSeckill',
'item' => 'require|checkActivity'
];
protected $message = [
'seckill_id.require' => '请选择秒杀时段',
'item.require' => '请选择秒杀商品',
];
public function checkSeckill($value,$rule,$data){
$seckill = Db::name('seckill_time')->where(['del'=>0,'id'=>$value])->find();
if(empty($seckill)){
return '秒杀时间段已被调整,请重新选择时间段';
}
return true;
}
public function sceneAdd(){
$this->append('item','checkAddGoods');
}
public function sceneEdit(){
$this->append('item','checkEditGoods');
}
public function checkActivity($value,$rule,$data){
$goods_ids = array_unique(array_column($value,'goods_id'));
$team_goods= Db::name('team_goods_item')->alias('TGI')
->join('team_activity TA','TA.team_id = TGI.team_id')
->where(['TGI.goods_id'=>$goods_ids,'TA.del'=>0])
->find();
if($team_goods){
return '该商品正在参加拼团活动中,不能在参加秒杀活动';
}
$bargain_goods = Db::name('bargain_item')->alias('bi')
->join('bargain b', 'b.id = bi.bargain_id')
->where(['bi.goods_id' => $goods_ids, 'b.del' => 0])
->find();
if($bargain_goods){
return '该商品正在参加砍价活动中,不能在参加秒杀活动';
}
return true;
}
public function checkAddGoods($value,$rule,$data){
$goods_ids = array_unique(array_column($value,'goods_id'));
$goods = Db::name('goods')->where(['del'=>0])->column('id');
$goods_item = Db::name('goods_item')->where(['goods_id'=>$goods_ids])->column('price,spec_value_str','id');
$seckill_goods = Db::name('seckill_goods')->where(['seckill_id'=>$data['seckill_id'],'del'=>0])->column('item_id');
foreach ($value as $item){
if(!in_array($item['goods_id'],$goods)){
return '商品ID:'.$item['goods_id'].'已下架';
}
if($seckill_goods && in_array($item['item_id'],$seckill_goods)){
return '商品规格:'.$goods_item[$item['item_id']]['spec_value_str'].'已在活动中,请勿重复添加';
}
$goods_price = $goods_item[$item['item_id']]['price'] ?? 0;
//验证商品价格
if($item['price'] > $goods_price){
return '商品规格:'.$goods_item[$item['item_id']]['spec_value_str'] .'的秒杀价格高于原价';
}
}
return true;
}
public function checkEditGoods($value,$rule,$data){
$goods_ids = array_unique(array_column($value,'goods_id'));
$seckill_ids = array_column($value,'id');
$seckill_goods = Db::name('seckill_goods')
->where(['goods_id'=>$goods_ids,'seckill_id'=>$data['seckill_id']])
->where('id','not in',$seckill_ids)
->find();
if($seckill_goods){
return '该时间段已存在相同的商品';
}
$goods = Db::name('goods')->where(['del'=>0])->column('id');
$goods_item = Db::name('goods_item')->where(['goods_id'=>$goods_ids])->column('price,spec_value_str','id');
foreach ($value as $item){
if(!in_array($item['goods_id'],$goods)){
return '商品ID:'.$item['goods_id'].'已下架';
}
$goods_price = $goods_item[$item['item_id']]['price'] ?? 0;
//验证商品价格
if($item['price'] > $goods_price){
return '商品规格:'.$goods_item[$item['item_id']]['spec_value_str'] .'的秒杀价格高于原价';
}
}
return true;
}
}