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() : [];
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
 | 
						|
}
 |