__('Has_expire 1'), '2' => __('Has_expire 2')]; } public function getHasExpireAttr($value, $data) { $end_time = (isset($data['end_time']) ? $data['end_time'] : ''); if(!$end_time) return '2'; if( $end_time < time()) { return '1'; }else{ return '2'; } } protected static function init() { self::afterInsert(function ($row) { if (!$row['weigh']) { $pk = $row->getPk(); // $row->getQuery()->where($pk, $row[$pk])->update(['weigh' => $row[$pk]]); $row->getQuery()->where($pk, $row[$pk])->update(['weigh' => 0]); } }); } public function getAddressTypeList() { return ['1' => __('Address_type 1'), '2' => __('Address_type 2')]; } public function getStatusList() { return ['1' => __('Status 1'), '2' => __('Status 2'), '3' => __('Status 3')]; } public function getRecommendList() { return ['0' => __('Recommend 0'), '1' => __('Recommend 1')]; } public function getHotList() { return ['0' => __('Hot 0'), '1' => __('Hot 1')]; } public function getNewList() { return ['0' => __('New 0'), '1' => __('New 1')]; } public function getSelfhotList() { return ['0' => __('Selfhot 0'), '1' => __('Selfhot 1')]; } public function getAuthStatusList() { return ['0' => __('Auth_status 0'), '1' => __('Auth_status 1'), '2' => __('Auth_status 2')]; } public function getExpirestatusList() { return ['1' => __('Expirestatus 1'), '2' => __('Expirestatus 2')]; } public function getAddTypeList() { return ['1' => __('Add_type 1'), '2' => __('Add_type 2')]; } public function getAddressTypeTextAttr($value, $data) { $value = $value ? $value : (isset($data['address_type']) ? $data['address_type'] : ''); $list = $this->getAddressTypeList(); return isset($list[$value]) ? $list[$value] : ''; } 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 getSignStartTimeTextAttr($value, $data) { $value = $value ? $value : (isset($data['sign_start_time']) ? $data['sign_start_time'] : ''); return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value; } public function getSignEndTimeTextAttr($value, $data) { $value = $value ? $value : (isset($data['sign_end_time']) ? $data['sign_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] : ''; } public function getRecommendTextAttr($value, $data) { $value = $value ? $value : (isset($data['recommend']) ? $data['recommend'] : ''); $list = $this->getRecommendList(); return isset($list[$value]) ? $list[$value] : ''; } public function getHotTextAttr($value, $data) { $value = $value ? $value : (isset($data['hot']) ? $data['hot'] : ''); $list = $this->getHotList(); return isset($list[$value]) ? $list[$value] : ''; } public function getNewTextAttr($value, $data) { $value = $value ? $value : (isset($data['new']) ? $data['new'] : ''); $list = $this->getNewList(); return isset($list[$value]) ? $list[$value] : ''; } public function getSelfhotTextAttr($value, $data) { $value = $value ? $value : (isset($data['selfhot']) ? $data['selfhot'] : ''); $list = $this->getSelfhotList(); return isset($list[$value]) ? $list[$value] : ''; } public function getAuthStatusTextAttr($value, $data) { $value = $value ? $value : (isset($data['auth_status']) ? $data['auth_status'] : ''); $list = $this->getAuthStatusList(); return isset($list[$value]) ? $list[$value] : ''; } public function getExpirestatusTextAttr($value, $data) { $value = $value ? $value : (isset($data['expirestatus']) ? $data['expirestatus'] : ''); $list = $this->getExpirestatusList(); return isset($list[$value]) ? $list[$value] : ''; } public function getAddTypeTextAttr($value, $data) { $value = $value ? $value : (isset($data['add_type']) ? $data['add_type'] : ''); $list = $this->getAddTypeList(); return isset($list[$value]) ? $list[$value] : ''; } public function getAuthTimeTextAttr($value, $data) { $value = $value ? $value : (isset($data['auth_time']) ? $data['auth_time'] : ''); return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $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); } protected function setSignStartTimeAttr($value) { return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value); } protected function setSignEndTimeAttr($value) { return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value); } protected function setAuthTimeAttr($value) { return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value); } public function activity() { return $this->belongsTo(Activity::class, 'classes_activity_id', 'id', [], 'LEFT')->setEagerlyType(0); } 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 items() { return $this->hasMany(ActivityItem::class,'classes_activity_id', 'classes_activity_id')->order("weigh desc,id desc"); } public function itemauths() { return $this->hasMany(ActivityItemAuth::class,'classes_activity_auth_id')->order("weigh desc,id desc"); } public function activityCheck(&$params,$shop_id=null,$row=null,$oper_type='user',$oper_id=0) { if($row){ //统一时间格式成时间戳 if( is_string($row["start_time"]))$row["start_time"]=strtotime($row["start_time"]); if( is_string($row["end_time"]))$row["end_time"]=strtotime($row["end_time"]); if( is_string($row["sign_start_time"]))$row["sign_start_time"]=strtotime($row["sign_start_time"]); if( is_string($row["sign_end_time"]))$row["sign_end_time"]=strtotime($row["sign_end_time"]); } $params["status"] = $params["status"] ?? '3'; if(!$shop_id)$shop_id = $params["shop_id"] ?? 0; if(empty($params["weigh"]))$params["weigh"] = 0; $manystore = Manystore::where("shop_id",$shop_id)->find(); if(!$manystore){ throw new \Exception("店铺不存在"); } if(!(new \app\common\model\dyqc\ManystoreShop)->checkFull($shop_id))throw new \Exception("对方的认证信息未完善,请您先去帮忙完善!"); $params["manystore_id"] = $manystore["id"]; //开始和结束时间不能为空 $time = $params["time"]; if(empty($time))throw new \Exception("{$params["title"]}请选择开始和结束时间".$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["title"]}请选择开始和结束时间".$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["title"]}结束时间不能小于开始时间"); } //开始和结束时间不能为空 $time = $params["sign_time"]; if(empty($time))throw new \Exception("{$params["title"]}请选择开始和结束时间".$time); $split_line = " - "; $time_arr = explode($split_line,$time); $params["sign_start_time"] = $time_arr[0] ; $params["sign_end_time"] = $time_arr[1]; unset($params["sign_time"]); $start_time = $params["sign_start_time"]; $end_time = $params["sign_end_time"]; if(empty($start_time) || empty($end_time)){ throw new \Exception("{$params["title"]}请选择开始和结束时间".$time); } //转化时间戳 $start_time = $params["sign_start_time"] && !is_numeric($params["sign_start_time"]) ? strtotime($params["sign_start_time"]) : $params["sign_start_time"]; $end_time = $params["sign_end_time"] && !is_numeric($params["sign_end_time"]) ? strtotime($params["sign_end_time"]) : $params["sign_end_time"]; //结束时间不能小于开始时间 if($end_time<=$start_time){ throw new \Exception("{$params["title"]}结束时间不能小于开始时间"); } //课时必须大于等于1 // if($params["classes_num"] < 1) throw new \Exception("课时必须大于等于1"); if($params["price"] < 0) throw new \Exception("售价必须大于0"); //独立地点需传定位信息 if($params["address_type"] == "2"){ if(empty($params["address_city"]) && !empty($params["province"]) && !empty($params["city"]) && !empty($params["district"])){ $province_name = Area::where("id" ,$params['province'])->value("name"); if(!$province_name) throw new \Exception("省份不存在"); $city_name = Area::where("id" ,$params['city'])->value("name"); if(!$city_name) throw new \Exception("市不存在"); $district_name = Area::where("id" ,$params['district'])->value("name"); if(!$district_name) throw new \Exception("区县不存在"); $params['address_city'] = $province_name."/".$city_name."/".$district_name; } if(empty($params["address_city"]) || empty($params["province"]) || empty($params["city"]) || empty($params["district"]) || empty($params["longitude"]) || empty($params["latitude"]) || empty($params["address"]) || empty($params["address_detail"]) ) throw new \Exception("独立地点需传定位信息"); }else{ //地址取机构的 $shop = ManystoreShop::where("id",$shop_id)->find(); if(!$shop){ throw new \Exception("店铺不存在"); } if(empty($shop["address_city"]) || empty($shop["province"]) || empty($shop["city"]) || empty($shop["district"]) || empty($shop["longitude"]) || empty($shop["latitude"]) || empty($shop["address"]) || empty($shop["address_detail"]) ) throw new \Exception("当前机构地址并未完善,请在机构处完善!"); $params["address_city"] = $shop["address_city"]; $params["province"] = $shop["province"]; $params["city"] = $shop["city"]; $params["district"] = $shop["district"]; $params["longitude"] = $shop["longitude"]; $params["latitude"] = $shop["latitude"]; $params["address"] = $shop["address"]; $params["address_detail"] = $shop["address_detail"]; //address // var_dump($params); } ; //收费免费判断 if($params["price"]==0){ $params["feel"] = "1"; }else{ //个人认证无法下付费课程 $shop = ManystoreShop::where("id",$shop_id)->find(); if($shop["type"]=="1"){ throw new \Exception("这个机构属于个人认证,无法发布付费活动!"); } $params["feel"] = "0"; } $rule = [ 'manystore_id'=>'require', 'shop_id'=>'require', 'headimage' => 'require', 'title' => 'require', 'images' => 'require', 'address' => 'require', 'address_detail' => 'require', 'longitude' => 'require', 'latitude' => 'require', 'province' => 'require', 'city' => 'require', 'district' => 'require', 'address_city' => 'require', 'address_type' => 'require', 'content' => 'require', 'price' => 'require', ]; $rule_msg = [ "manystore_id.require"=>'机构id必填', "shop_id.require"=>'机构id必填', "headimage.require"=>'课程活动头图必填', 'title.require' => '活动名称必须填写', 'images.require' => '活动轮播图必须上传', 'address.require' => '地址必填', 'address_detail.require' => '详细地址必填', 'longitude.require' => '经度必填', 'latitude.require' => '纬度必填', 'province.require' => '省编号必填', 'city.require' => '市编号必填', 'district.require' => '县区编号必填', 'address_city.require' => '城市选择必填', 'address_type.require'=> '地址类型必填', 'content.require'=> '活动详情必填', 'price.require'=> '活动售价必填', ]; self::check($params,$rule,$rule_msg); //统一时间格式成时间戳 if( is_string($params["start_time"]))$params["start_time"]=strtotime($params["start_time"]); if( is_string($params["end_time"]))$params["end_time"]=strtotime($params["end_time"]); if( is_string($params["sign_start_time"]))$params["sign_start_time"]=strtotime($params["sign_start_time"]); if( is_string($params["sign_end_time"]))$params["sign_end_time"]=strtotime($params["sign_end_time"]); //更新 if($row){ // $this->have_auth = false; // if($this->need_auth){ // //判断更新的变动数据 // $this->no_auth_fields_check($params,$row); // if($this->have_auth){ // $params['status'] = "3"; // } // } // $this->updateCheck($row->id,$params,$row); //名称title不能与其他课程重复 $check_title = self::where('id','<>',$row["id"])->where('classes_activity_id','<>',$row["classes_activity_id"])->where('title',$params["title"])->find(); if($check_title){ throw new \Exception("活动名称已存在或被其他机构占用,请更改!"); } //如果存在课程规格,验证每个课时规格的合法性 if(isset($params["item_json"])){ //如果存在"的HTML转义字符,先反转义再解析json $params["item_json"] = html_entity_decode($params["item_json"]); $spec = json_decode($params["item_json"],true); if(empty($spec))throw new \Exception("请至少添加一个课时规格"); foreach ($spec as $k=>&$v){ unset($v["limit"]); unset($v["status_name"]); unset($v["visible"]); $v["classes_activity_auth_id"] = $row->id; $v["classes_activity_id"] = $row->classes_activity_id ?? ($params["classes_activity_id"] ?? 0); $v["manystore_id"] = $params["manystore_id"]; $v["shop_id"] = $shop_id; //先不进行判定,交给提交后再判定 $classesSpec = new ActivityItemAuth(); $classesSpec->specCheck($v,$shop_id,empty($v["id"])? null : ActivityItemAuth::get($v["id"]),false,$oper_type,$oper_id); } $params["item_json"] = $spec; } }else{ //新增 //名称title不能重复 $check_title = self::where('title',$params["title"])->find(); if($check_title){ throw new \Exception("活动名称已存在或被其他机构占用,请更改!"); } //如果存在课程规格,验证每个课时规格的合法性 if(isset($params["item_json"])){ //如果存在"的HTML转义字符,先反转义再解析json $params["item_json"] = html_entity_decode($params["item_json"]); $spec = json_decode($params["item_json"],true); if(empty($spec))throw new \Exception("请至少添加一个课时规格"); foreach ($spec as $k=>&$v){ unset($v["limit"]); unset($v["status_name"]); unset($v["id"]); $v["classes_activity_auth_id"] = 0; $v["classes_activity_id"] = $params["classes_activity_id"] ?? 0; $v["manystore_id"] = $params["manystore_id"]; $v["shop_id"] = $shop_id; (new ActivityItemAuth)->specCheck($v,$shop_id,null,true,$oper_type,$oper_id); } $params["item_json"] = $spec; } } $params["delete_spec_ids"] = []; //按前端顺序分配显示权重 if(isset($params["item_json"]) && $params["item_json"]){ //数组倒过来 $params["item_json"] = array_reverse($params["item_json"]); $insert_spec = []; foreach ($params["item_json"] as $k=>&$v){ $v["weigh"] = $k + 1; if(!empty($v["id"]))$insert_spec[] = $v["id"]; } if($insert_spec && $row){ $params["delete_spec_ids"] = ActivityItemAuth::where("classes_activity_auth_id",$row->id)->where("id","not in",$insert_spec)->column("id"); } } //存在需要删除的规格则判断规格是否能删除 if($params["delete_spec_ids"] && $row){ $check_spec = ActivityItemAuth::where("classes_activity_auth_id",$row->id)->where("id","in",$params["delete_spec_ids"])->select(); foreach ($check_spec as $k=>$vv){ (new ActivityItemAuth)->updateCheck($vv->id); } $params["delete_spec_ids"] = $check_spec; } //如果是上架,判断是否拥有课时规格,没有则无法上架 if(empty($params["item_json"])){ if(!$row)throw new \Exception("新添加的活动请先至少添加一个活动规格后再上架!"); //判断是否拥有课时规格,没有则无法上架 $check_spec = ActivityItemAuth::where("classes_activity_auth_id",$row->id)->count(); if(!$check_spec)throw new \Exception("新添加的活动请先至少添加一个活动规格后再上架!"); } } 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']}存在正在使用中的订单报名学员,规格无法继续操作,如规格有误请下架!"); } }