getPk(); $row->getQuery()->where($pk, $row[$pk])->update(['weigh' => $row[$pk]]); } }); } public function getStatusList() { return ['1' => __('Status 1'), '2' => __('Status 2')]; } public function getSexList() { return ['1' => __('Sex 1'), '2' => __('Sex 2'), '3' => __('Sex 3')]; } public function getStatusTextAttr($value, $data) { $value = $value ? $value : (isset($data['status']) ? $data['status'] : ''); $list = $this->getStatusList(); return isset($list[$value]) ? $list[$value] : ''; } public function getSexTextAttr($value, $data) { $value = $value ? $value : (isset($data['sex']) ? $data['sex'] : ''); $list = $this->getSexList(); return isset($list[$value]) ? $list[$value] : ''; } public function manystore() { return $this->belongsTo(Manystore::class, 'manystore_id', 'id', [], 'LEFT')->setEagerlyType(0); } public function shop() { return $this->belongsTo(ManystoreShop::class, 'shop_id', 'id', [], 'LEFT')->setEagerlyType(0); } public function activity() { return $this->belongsTo(Activity::class, 'classes_activity_id', 'id', [], 'LEFT')->setEagerlyType(0); } 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"); } //收费免费判断 if($params["price"]==0){ $params["feel"] = "1"; }else{ //个人认证无法下付费课程 $shop = ManystoreShop::where("id",$params["shop_id"] )->find(); if($shop["type"]=="1"){ throw new \Exception("这个机构属于个人认证,无法发布付费活动!"); } $params["feel"] = "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_activity_id"]; $spec_name_exist = self::where("name",$spec_name)->where("classes_activity_id",$classes_lib_id)->where("id","<>",$row->id)->find(); if($spec_name_exist){ throw new \Exception("该活动下已存在该课时规格名称,请重新输入1"); } // //同课程下,各个课时的开始和结束时间不能有重叠(出现时间交叠也不行) // $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_activity_id"]; $spec_name_exist = self::where("name",$spec_name)->where("classes_activity_id",$classes_lib_id)->find(); if($spec_name_exist){ throw new \Exception("该活动下已存在该课时规格名称,请重新输入2"); } // //同课程下,各个课时的开始和结束时间不能有重叠(出现时间交叠也不行) // $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']}课时的开始和结束时间与你有重叠"); // } } } 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 = Order::where("classes_activity_item_id",$id)->where("status","not in","-3,6,9")->find(); if($order)throw new \Exception("{$order['name']}存在正在使用中的订单报名学员,规格无法继续操作,如规格有误请下架!"); } }