164 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			164 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| 
								 | 
							
								<?php
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								namespace app\admin\model\xilufitness\work;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								use think\Model;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								class Camp extends Model
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    // 表名
							 | 
						||
| 
								 | 
							
								    protected $name = 'xilufitness_work_camp';
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    // 自动写入时间戳字段
							 | 
						||
| 
								 | 
							
								    protected $autoWriteTimestamp = 'integer';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    // 定义时间戳字段名
							 | 
						||
| 
								 | 
							
								    protected $createTime = 'createtime';
							 | 
						||
| 
								 | 
							
								    protected $updateTime = 'updatetime';
							 | 
						||
| 
								 | 
							
								    protected $deleteTime = false;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    // 追加属性
							 | 
						||
| 
								 | 
							
								    protected $append = [
							 | 
						||
| 
								 | 
							
								        'status_text'
							 | 
						||
| 
								 | 
							
								    ];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    //时间监听
							 | 
						||
| 
								 | 
							
								    public static function init()
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        //新增
							 | 
						||
| 
								 | 
							
								        self::afterInsert(function ($row){
							 | 
						||
| 
								 | 
							
								           $pk = $row->getPk();
							 | 
						||
| 
								 | 
							
								           if(!empty($row['plan_data'])){
							 | 
						||
| 
								 | 
							
								               $planModel = new \app\admin\model\xilufitness\work\CampPlan;
							 | 
						||
| 
								 | 
							
								               $campModel = new \app\admin\model\xilufitness\course\Camp;
							 | 
						||
| 
								 | 
							
								               $plan_data = $row['plan_data'];
							 | 
						||
| 
								 | 
							
								               foreach ($plan_data as $key => $val){
							 | 
						||
| 
								 | 
							
								                   $plan_data[$key]['work_camp_id'] = $row[$pk];
							 | 
						||
| 
								 | 
							
								                   $plan_data[$key]['week'] = date('w',strtotime($val['day_date']));
							 | 
						||
| 
								 | 
							
								               }
							 | 
						||
| 
								 | 
							
								               $planModel->allowField(true)->saveAll($plan_data);
							 | 
						||
| 
								 | 
							
								               $campInfo = $campModel
							 | 
						||
| 
								 | 
							
								                   ->where(['id' => $row['camp_id'] ])
							 | 
						||
| 
								 | 
							
								                   ->field(['camp_price','write_off_price','market_price'])
							 | 
						||
| 
								 | 
							
								                   ->find();
							 | 
						||
| 
								 | 
							
								               $row->getQuery()->where($pk,$row[$pk])->update([
							 | 
						||
| 
								 | 
							
								                   'class_count' => count($plan_data),
							 | 
						||
| 
								 | 
							
								                   'camp_price'  => $campInfo['camp_price'],
							 | 
						||
| 
								 | 
							
								                   'write_off_price' => $campInfo['write_off_price'],
							 | 
						||
| 
								 | 
							
								                   'market_price' => $campInfo['market_price']
							 | 
						||
| 
								 | 
							
								               ]);
							 | 
						||
| 
								 | 
							
								           }
							 | 
						||
| 
								 | 
							
								        });
							 | 
						||
| 
								 | 
							
								       //更新
							 | 
						||
| 
								 | 
							
								        self::afterUpdate(function ($row){
							 | 
						||
| 
								 | 
							
								            $pk = $row->getPk();
							 | 
						||
| 
								 | 
							
								            if(!empty($row['plan_data'])){
							 | 
						||
| 
								 | 
							
								                $planModel = new \app\admin\model\xilufitness\work\CampPlan;
							 | 
						||
| 
								 | 
							
								                $campModel = new \app\admin\model\xilufitness\course\Camp;
							 | 
						||
| 
								 | 
							
								                $campInfo = $campModel
							 | 
						||
| 
								 | 
							
								                    ->where(['id' => $row['camp_id'] ])
							 | 
						||
| 
								 | 
							
								                    ->field(['camp_price','write_off_price','market_price'])
							 | 
						||
| 
								 | 
							
								                    ->find();
							 | 
						||
| 
								 | 
							
								                $plan_data = $row['plan_data'];
							 | 
						||
| 
								 | 
							
								                foreach ($plan_data as $key => $val){
							 | 
						||
| 
								 | 
							
								                    $plan_data[$key]['work_camp_id'] = $row[$pk];
							 | 
						||
| 
								 | 
							
								                    $plan_data[$key]['week'] = date('w',strtotime($val['day_date']));
							 | 
						||
| 
								 | 
							
								                }
							 | 
						||
| 
								 | 
							
								                $plan_ids = array_filter(array_column($plan_data,'id'));
							 | 
						||
| 
								 | 
							
								                if(!empty($plan_ids)){
							 | 
						||
| 
								 | 
							
								                    //删除已删除数据
							 | 
						||
| 
								 | 
							
								                    $planModel->where(['work_camp_id' => $row[$pk], 'id' => ['notin',$plan_ids]])->delete();
							 | 
						||
| 
								 | 
							
								                }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								                $planModel->allowField(true)->saveAll($plan_data);
							 | 
						||
| 
								 | 
							
								                $row->getQuery()->where($pk,$row[$pk])->update([
							 | 
						||
| 
								 | 
							
								                    'class_count' => count($plan_data),
							 | 
						||
| 
								 | 
							
								                    'camp_price'  => $campInfo['camp_price'],
							 | 
						||
| 
								 | 
							
								                    'write_off_price' => $campInfo['write_off_price'],
							 | 
						||
| 
								 | 
							
								                    'market_price' => $campInfo['market_price']
							 | 
						||
| 
								 | 
							
								                ]);
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								        });
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function getStatusList()
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        return ['normal' => __('Normal'), 'complete' => __('Complete') ,'failed' => __('Failed'),'hidden' => __('Hidden')];
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function getStatusTextAttr($value, $data)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $value = $value ? $value : (isset($data['status']) ? $data['status'] : '');
							 | 
						||
| 
								 | 
							
								        $list = $this->getStatusList();
							 | 
						||
| 
								 | 
							
								        return isset($list[$value]) ? $list[$value] : '';
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    //开始时间
							 | 
						||
| 
								 | 
							
								    protected function setStartAtAttr($value)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    //结束时间
							 | 
						||
| 
								 | 
							
								    protected function setEndAtAttr($value)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 关联品牌商
							 | 
						||
| 
								 | 
							
								     * 查询
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function brand(){
							 | 
						||
| 
								 | 
							
								        return $this->belongsTo('\\app\\admin\\model\\xilufitness\\brand\\Index','brand_id','id',[],'LEFT')->setEagerlyType(0);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 活动
							 | 
						||
| 
								 | 
							
								     * 查询
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function camps(){
							 | 
						||
| 
								 | 
							
								        return $this->belongsTo('\\app\\admin\\model\\xilufitness\\course\\Camp','camp_id','id',[],'LEFT')->setEagerlyType(0);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 关联门店
							 | 
						||
| 
								 | 
							
								     * 查询
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function shop(){
							 | 
						||
| 
								 | 
							
								        return $this->belongsTo('\\app\\admin\\model\\xilufitness\\shop\\Index','shop_id','id',[],'LEFT')->setEagerlyType(0);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 关联教练
							 | 
						||
| 
								 | 
							
								     * 查询
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function coach(){
							 | 
						||
| 
								 | 
							
								        return $this->belongsTo('\\app\\admin\\model\\xilufitness\\coach\\Index','coach_id','id',[],'LEFT')->setEagerlyType(0);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * 获取计划明细
							 | 
						||
| 
								 | 
							
								     * @param int $work_camp_id 营期id
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function getPlanList(int $work_camp_id): array {
							 | 
						||
| 
								 | 
							
								        $model = new \app\admin\model\xilufitness\work\CampPlan;
							 | 
						||
| 
								 | 
							
								        $list = $model
							 | 
						||
| 
								 | 
							
								            ->where(['work_camp_id' => $work_camp_id])
							 | 
						||
| 
								 | 
							
								            ->field(['id','day_date','day_start_at','day_end_at'])
							 | 
						||
| 
								 | 
							
								            ->select();
							 | 
						||
| 
								 | 
							
								        return !empty($list) ? collection($list)->toArray() : [];
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								}
							 |