equipmentRule($data,false); if(!$status) return [$status,$msg]; $update = $msg['data'][0]; Equipment::where('id',$data['id'])->update($update); return [true,'保存成功!']; } public function equipmentAdd($data){ list($status,$msg) = $this->equipmentRule($data); if(!$status) return [$status,$msg]; Equipment::insert($msg['data']); return [true,'保存成功!']; } public function equipmentDel($data){ if($this->isEmpty($data,'id')) return [false,'ID必须!']; Equipment::whereIn('id',$data['id'])->update([ 'del_time' => time() ]); return [true,'删除成功']; } public function equipmentList($data){ $model = Equipment::where('del_time',0) ->select('*'); if(! empty($data['title'])) $model->where('title', 'LIKE', '%'.$data['title'].'%'); if(! empty($data['code'])) $model->where('code', 'LIKE', '%'.$data['code'].'%'); $list = $this->limit($model,'',$data); return [200,$list]; } public function equipmentRule($data,$is_add = true){ if($this->isEmpty($data,'data')) return [false,'数据不能为空!']; $code = array_column($data['data'],'code'); $code = array_map(function($val) { return $val !== null ? $val : 0; }, $code); $code_count = array_count_values($code); foreach ($code as $value){ if(empty($value)) return [false,'编码不能为空!']; if($code_count[$value] > 1) return [false,'编码不能重复']; } $title = array_column($data['data'],'title'); $title = array_map(function($val) { return $val !== null ? $val : 0; }, $title); $title_count = array_count_values($title); foreach ($title as $value){ if(empty($value)) return [false,'名称不能为空!']; if($title_count[$value] > 1) return [false,'名称不能重复']; } foreach ($data['data'] as $key => $value){ $data['data'][$key]['upd_time'] = time(); if($is_add){ $bool = Equipment::whereRaw("title = '{$value['title']}' OR code = '{$value['code']}'") ->where('del_time',0) ->exists(); $data['data'][$key]['crt_time'] = time(); }else{ if($this->isEmpty($data,'id')) return [false,'id不能为空!']; $bool = Equipment::whereRaw("title = '{$value['title']}' OR code = '{$value['code']}'") ->where('id','<>',$data['id']) ->where('del_time',0) ->exists(); } if($bool) return [false,'名称和编码不能重复']; } return [true,$data]; } }