247 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			247 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						||
 | 
						||
namespace app\common\model\school\classes;
 | 
						||
 | 
						||
use app\common\model\BaseModel;
 | 
						||
use think\Model;
 | 
						||
use traits\model\SoftDelete;
 | 
						||
 | 
						||
class ClassesSpec extends BaseModel
 | 
						||
{
 | 
						||
 | 
						||
    use SoftDelete;
 | 
						||
 | 
						||
    
 | 
						||
 | 
						||
    // 表名
 | 
						||
    protected $name = 'school_classes_lib_spec';
 | 
						||
    
 | 
						||
    // 自动写入时间戳字段
 | 
						||
    protected $autoWriteTimestamp = 'integer';
 | 
						||
 | 
						||
    // 定义时间戳字段名
 | 
						||
    protected $createTime = 'createtime';
 | 
						||
    protected $updateTime = 'updatetime';
 | 
						||
    protected $deleteTime = 'deletetime';
 | 
						||
 | 
						||
    // 追加属性
 | 
						||
    protected $append = [
 | 
						||
        'start_time_text',
 | 
						||
        'end_time_text',
 | 
						||
        'status_text' ,
 | 
						||
        'time'
 | 
						||
    ];
 | 
						||
    
 | 
						||
    public $no_auth_fields = ['name','limit_num','status','weigh',"start_time","end_time"];
 | 
						||
    protected static function init()
 | 
						||
    {
 | 
						||
        self::afterInsert(function ($row) {
 | 
						||
            if (empty($row['weigh'])) {
 | 
						||
                $pk = $row->getPk();
 | 
						||
                $row->getQuery()->where($pk, $row[$pk])->update(['weigh' => $row[$pk]]);
 | 
						||
            }
 | 
						||
        });
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
        public function getTimeAttr($value, $data)
 | 
						||
    {
 | 
						||
        $start_time = isset($data['start_time']) ? $data['start_time'] : '';
 | 
						||
        $end_time = isset($data['end_time']) ? $data['end_time'] : '';
 | 
						||
        $start_time = is_numeric($start_time) ? date("Y/m/d H:i", $start_time) : $start_time;
 | 
						||
        $end_time = is_numeric($end_time) ? date("Y/m/d H:i", $end_time) : $end_time;
 | 
						||
        return $start_time .' - '.$end_time;
 | 
						||
    }
 | 
						||
 | 
						||
    
 | 
						||
    public function getStatusList()
 | 
						||
    {
 | 
						||
        return ['1' => __('Status 1'), '2' => __('Status 2')];
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
    public function getStartTimeTextAttr($value, $data)
 | 
						||
    {
 | 
						||
        $value = $value ? $value : (isset($data['start_time']) ? $data['start_time'] : '');
 | 
						||
        return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
    public function getEndTimeTextAttr($value, $data)
 | 
						||
    {
 | 
						||
        $value = $value ? $value : (isset($data['end_time']) ? $data['end_time'] : '');
 | 
						||
        return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
    public function getStatusTextAttr($value, $data)
 | 
						||
    {
 | 
						||
        $value = $value ? $value : (isset($data['status']) ? $data['status'] : '');
 | 
						||
        $list = $this->getStatusList();
 | 
						||
        return isset($list[$value]) ? $list[$value] : '';
 | 
						||
    }
 | 
						||
 | 
						||
    protected function setStartTimeAttr($value)
 | 
						||
    {
 | 
						||
        return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
 | 
						||
    }
 | 
						||
 | 
						||
    protected function setEndTimeAttr($value)
 | 
						||
    {
 | 
						||
        return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
    public function lib()
 | 
						||
    {
 | 
						||
        return $this->belongsTo(ClassesLib::class, 'classes_lib_id', 'id', [], 'LEFT')->setEagerlyType(0);
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
        public function updateCheck($id,$params=[],$row=null){
 | 
						||
        if($params && $row){
 | 
						||
//            var_dump($this->no_auth_fields_check($params,$row));
 | 
						||
            if(!$this->no_auth_fields_check($params,$row)){
 | 
						||
                return true;
 | 
						||
            }
 | 
						||
        }
 | 
						||
 | 
						||
        // 课程存在售后订单则不允许操作
 | 
						||
        $order = \app\common\model\school\classes\hour\Order::where("classes_lib_spec_id",$id)->where("status","in","-1,0")->find();
 | 
						||
        if($order)throw new \Exception("{$order['name']}存在正在使用中的课时订单报名学员,课时规格无法继续操作,如规格有误请下架!");
 | 
						||
    }
 | 
						||
 | 
						||
 | 
						||
 public function specCheck(&$params,$shop_id=null,$row=null,$check=true,$oper_type='user',$oper_id=0)
 | 
						||
    {
 | 
						||
 | 
						||
                 //限定人数必须大于0
 | 
						||
        $limit_num = $params["limit_num"];
 | 
						||
        if($limit_num<=0){
 | 
						||
            throw new \Exception("{$params["name"]}限定人数必须大于0");
 | 
						||
        }
 | 
						||
 | 
						||
 | 
						||
 | 
						||
//开始和结束时间不能为空
 | 
						||
         $time = $params["time"];
 | 
						||
 | 
						||
        if(empty($time))throw new \Exception("{$params["name"]}请选择开始和结束时间".$time);
 | 
						||
        $split_line = " - ";
 | 
						||
        $time_arr = explode($split_line,$time);
 | 
						||
        $params["start_time"] = $time_arr[0] ;
 | 
						||
        $params["end_time"] = $time_arr[1];
 | 
						||
        unset($params["time"]);
 | 
						||
 | 
						||
        $start_time = $params["start_time"];
 | 
						||
        $end_time = $params["end_time"];
 | 
						||
 | 
						||
        if(empty($start_time) || empty($end_time)){
 | 
						||
            throw new \Exception("{$params["name"]}请选择开始和结束时间".$time);
 | 
						||
        }
 | 
						||
        //转化时间戳
 | 
						||
        $start_time = $params["start_time"] && !is_numeric($params["start_time"]) ? strtotime($params["start_time"]) : $params["start_time"];
 | 
						||
        $end_time = $params["end_time"] && !is_numeric($params["end_time"]) ? strtotime($params["end_time"]) : $params["end_time"];
 | 
						||
        //结束时间不能小于开始时间
 | 
						||
        if($end_time<=$start_time){
 | 
						||
            throw new \Exception("{$params["name"]}结束时间不能小于开始时间");
 | 
						||
        }
 | 
						||
 | 
						||
        //结束时间不能是已经过去的时间
 | 
						||
        $now_time = time();
 | 
						||
        if($end_time<=$now_time){
 | 
						||
//            throw new \Exception("{$params["name"]}结束时间不能是已经过去的时间");
 | 
						||
        }
 | 
						||
 | 
						||
        //如果是员工操作,则结束时间必须大于当前时间n秒
 | 
						||
        if($oper_type == "user" && $oper_id){
 | 
						||
           $classes_timeout_time = config("site.classes_timeout_time") ?:0;
 | 
						||
           if($classes_timeout_time > 0) {
 | 
						||
               $now_times = time() + $classes_timeout_time;
 | 
						||
               if($start_time<=$now_times){
 | 
						||
                   //$now_time时间格式化
 | 
						||
                   $now_time_text = date("Y-m-d H:i",$now_times);
 | 
						||
                   throw new \Exception("{$params["name"]}开始时间必须在{$now_time_text}之后");
 | 
						||
               }
 | 
						||
           }
 | 
						||
 | 
						||
        }
 | 
						||
 | 
						||
 | 
						||
        //开始和结束时间必须是同一天
 | 
						||
//        $start_time_date = date("Y-m-d",$start_time);
 | 
						||
//        $end_time_date = date("Y-m-d",$end_time);
 | 
						||
//        if($start_time_date!=$end_time_date){
 | 
						||
//            throw new \Exception("{$params["name"]}开始和结束时间必须是同一天");
 | 
						||
//        }
 | 
						||
 | 
						||
 | 
						||
 | 
						||
        $params["start_time"] = $start_time;
 | 
						||
        $params["end_time"] = $end_time;
 | 
						||
 | 
						||
 | 
						||
  $orderTimeTableName = (new ClassesSpec)->getWithAlisaName();
 | 
						||
        //修改
 | 
						||
        if($row){
 | 
						||
            //修复旧数据时间戳
 | 
						||
            $row["start_time"]=  strtotime(date("Y-m-d H:i",$row["start_time"]));
 | 
						||
            $row["end_time"]= strtotime(date("Y-m-d H:i",$row["end_time"]));
 | 
						||
 | 
						||
            $this->updateCheck($row->id,$params,$row);
 | 
						||
 | 
						||
             //规格名字不能一样(同课程下)
 | 
						||
            $spec_name = $params["name"];
 | 
						||
            $classes_lib_id = $params["classes_lib_id"];
 | 
						||
            $spec_name_exist = ClassesSpec::where("name",$spec_name)->where("classes_lib_id",$classes_lib_id)->where("id","<>",$row->id)->find();
 | 
						||
            if($spec_name_exist){
 | 
						||
                throw new \Exception("该课程下已存在该课时规格名称,请重新输入");
 | 
						||
            }
 | 
						||
 | 
						||
             //同课程下,各个课时的开始和结束时间不能有重叠(出现时间交叠也不行)
 | 
						||
            $spec_time_exist = ClassesSpec::where(function ($query) use ($orderTimeTableName,$start_time,$end_time) {
 | 
						||
                    //兩個時間區間重合 存在任意交集 都不行
 | 
						||
                    $query->where("start_time BETWEEN {$start_time} AND {$end_time}");
 | 
						||
                    $query->whereOr("end_time BETWEEN {$start_time} AND {$end_time}");
 | 
						||
                    $query->whereOr("start_time <= {$start_time} AND end_time >= {$end_time}");
 | 
						||
                    $query->whereOr("start_time >= {$start_time} AND end_time <= {$end_time}");
 | 
						||
                })
 | 
						||
                ->where("classes_lib_id",$classes_lib_id)
 | 
						||
                ->where("id","<>",$row->id)->find();
 | 
						||
 | 
						||
            if($check && $spec_time_exist){
 | 
						||
                throw new \Exception("该课程下,{$spec_time_exist['name']}课时的开始和结束时间与你有重叠");
 | 
						||
            }
 | 
						||
 | 
						||
        }else{
 | 
						||
 | 
						||
             //规格名字不能一样(同课程下)
 | 
						||
            $spec_name = $params["name"];
 | 
						||
            $classes_lib_id = $params["classes_lib_id"];
 | 
						||
            $spec_name_exist = ClassesSpec::where("name",$spec_name)->where("classes_lib_id",$classes_lib_id)->find();
 | 
						||
            if($spec_name_exist){
 | 
						||
                throw new \Exception("该课程下已存在该课时规格名称,请重新输入");
 | 
						||
            }
 | 
						||
 | 
						||
             //同课程下,各个课时的开始和结束时间不能有重叠(出现时间交叠也不行)
 | 
						||
            $spec_time_exist = ClassesSpec::where(function ($query) use ($orderTimeTableName,$start_time,$end_time) {
 | 
						||
                    //兩個時間區間重合 存在任意交集 都不行
 | 
						||
                    $query->where("start_time BETWEEN {$start_time} AND {$end_time}");
 | 
						||
                    $query->whereOr("end_time BETWEEN {$start_time} AND {$end_time}");
 | 
						||
                    $query->whereOr("start_time <= {$start_time} AND end_time >= {$end_time}");
 | 
						||
                    $query->whereOr("start_time >= {$start_time} AND end_time <= {$end_time}");
 | 
						||
                })
 | 
						||
                ->where("classes_lib_id",$classes_lib_id)
 | 
						||
                ->find();
 | 
						||
 | 
						||
            if($check && $spec_time_exist){
 | 
						||
                throw new \Exception("该课程下,{$spec_time_exist['name']}课时的开始和结束时间与你有重叠");
 | 
						||
            }
 | 
						||
 | 
						||
        }
 | 
						||
 | 
						||
 | 
						||
    }
 | 
						||
 | 
						||
}
 |