$this->auth->id, 'status' => $status, ]; $list = Db::name('maintain')->field('id,orderno,createtime,info,filedata,status,eva_time') ->where($map)->order('id desc') ->autopage()->select(); if(!empty($list)){ $maintain_model = new Maintainmodel(); foreach($list as $key => $val){ $list[$key]['status_text'] = $maintain_model->status_data($val['status']); } } $this->success(1,$list); } public function info(){ $id = input('id',0); $map = [ 'worker_id' => $this->auth->id, 'id' => $id, ]; $info = Db::name('maintain') ->where($map) ->find(); $maintain_model = new Maintain(); $info['status_text'] = $maintain_model->status_data($info['status']); //追加进度 $jindu = Db::name('maintain_jindu')->field('id,title,createtime')->where('order_id',$id)->order('id desc')->select(); $info['jindu'] = $jindu; $this->success(1, $info); } //申请材料 public function shenqingcailiao(){ $order_id = input('order_id',0); $data = input('data','','htmlspecialchars_decode'); $data = json_decode($data,true); if(empty($data)){ $this->error(); } //订单 $map = [ 'worker_id' => $this->auth->id, 'id' => $order_id, ]; $info = Db::name('maintain')->where($map)->find(); if(empty($info)){ $this->error('不存在的订单'); } if($info['status'] != 50){ $this->error('状态不正确,请刷新重试'); } //准备数据 foreach($data as $key => $val){ $val['order_id'] = $info['id']; $val['company_id'] = $info['company_id']; $val['user_id'] = $info['user_id']; $val['worker_id'] = $info['worker_id']; $val['createtime'] = time(); $data[$key] = $val; } Db::startTrans(); $id = Db::name('maintain_cailiao')->insertAll($data); if(!$id){ Db::rollback(); $this->error('申请失败'); } $update = [ 'status' => 60, 'updatetime' => time(), 'cailiao_time' => time(), //材料申请时间 ]; $rs2 = Db::name('maintain')->where('id',$order_id)->update($update); if($rs2 === false){ Db::rollback(); $this->error('申请失败'); } Db::commit(); $this->success('申请成功'); } //材料计量单位 public function cailiao_danwei(){ $data = [ '个', '把', '只', ]; $this->success(1,$data); } //领取材料 public function lingqucailiao(){ $order_id = input('order_id',0); $images = input('images','','trim'); if(empty($images)){ $this->error(); } //订单 $map = [ 'worker_id' => $this->auth->id, 'id' => $order_id, ]; $info = Db::name('maintain')->where($map)->find(); if(empty($info)){ $this->error('不存在的订单'); } if($info['status'] != 60){ $this->error('状态不正确,请刷新重试'); } // $update = [ 'status' => 70, 'updatetime' => time(), 'lingqu_time' => time(), //材料申请时间 'lingqu_images' => $images, ]; $rs2 = Db::name('maintain')->where('id',$order_id)->update($update); if($rs2 === false){ $this->error('领取失败'); } $this->success('领取成功'); } //////////////////////////////循环开始/////////////////////// //立即上门 public function shangmen(){ $order_id = input('order_id',0); Db::startTrans(); //订单 $map = [ 'worker_id' => $this->auth->id, 'id' => $order_id, ]; $info = Db::name('maintain')->where($map)->lock(true)->find(); if(empty($info)){ Db::rollback(); $this->error('不存在的订单'); } if(!in_array($info['status'],[50,70])){ Db::rollback(); $this->error('状态不正确,请刷新重试'); } $nowtime = time(); //开启一个新轮回 $weixiu = [ 'order_id' => $info['id'], 'company_id' => $info['company_id'], 'user_id' => $info['user_id'], 'worker_id' => $info['worker_id'], 'weixiu_times' => $info['weixiu_times'] + 1, //次数自增1 'shangmen_time' => $nowtime, 'status' => 80, 'updatetime' => $nowtime, ]; $weixiu_id = Db::name('maintain_weixiu')->insertGetId($weixiu); if(!$weixiu_id){ Db::rollback(); $this->error('操作失败,重试一下吧'); } //新轮回第一个进度 $jindu = [ 'order_id' => $info['id'], 'company_id' => $info['company_id'], 'user_id' => $info['user_id'], 'worker_id' => $info['worker_id'], 'weixiu_times' => $weixiu['weixiu_times'], 'weixiu_id' => $weixiu_id, 'title' => '已上门', 'createtime' => $nowtime, ]; $jindu_id = Db::name('maintain_jindu')->insertGetId($jindu); if(!$jindu_id){ Db::rollback(); $this->error('操作失败,重试一下吧'); } //修改订单 $update = [ 'status' => 80, 'updatetime' => time(), 'shangmen_time' => time(), //上门时间 'weixiu_times' => $weixiu['weixiu_times'], 'weixiu_id' => $weixiu_id, ]; $rs2 = Db::name('maintain')->where('id',$order_id)->update($update); if($rs2 === false){ Db::rollback(); $this->error('操作失败,重试一下吧'); } Db::commit(); $this->success('操作成功'); } //新增维修进度 public function jindu_add(){ $order_id = input('order_id',0); $title = input('title',''); $images = input('images',''); if(empty($title)){ $this->error(); } //订单 $map = [ 'worker_id' => $this->auth->id, 'id' => $order_id, ]; $info = Db::name('maintain')->where($map)->find(); if(empty($info)){ $this->error('不存在的订单'); } if($info['status'] != 80){ $this->error('状态不正确,请刷新重试'); } $nowtime = time(); //准备数据 $jindu = [ 'order_id' => $info['id'], 'company_id' => $info['company_id'], 'user_id' => $info['user_id'], 'worker_id' => $info['worker_id'], 'weixiu_times' => $info['weixiu_times'], 'weixiu_id' => $info['weixiu_id'], 'title' => $title, 'images' => $images, 'createtime' => $nowtime, ]; $id = Db::name('maintain_jindu')->insertAll($jindu); if(!$id){ $this->error('操作失败'); } $this->success('操作成功'); } //确认完成 public function finish(){ $order_id = input('order_id',0); Db::startTrans(); //订单 $map = [ 'worker_id' => $this->auth->id, 'id' => $order_id, ]; $info = Db::name('maintain')->where($map)->lock(true)->find(); if(empty($info)){ Db::rollback(); $this->error('不存在的订单'); } if($info['status'] != 80){ Db::rollback(); $this->error('状态不正确,请刷新重试'); } $nowtime = time(); //结束最后一个轮回 $weixiu = [ 'status' => 90, //待验收 'wancheng_time' => $nowtime, 'updatetime' => $nowtime, ]; $weixiu_rs = Db::name('maintain_weixiu')->where('id',$info['weixiu_id'])->update($weixiu); if($weixiu_rs === false){ Db::rollback(); $this->error('操作失败,重试一下吧'); } //最后一个轮回,最后一个进度 $jindu = [ 'order_id' => $info['id'], 'company_id' => $info['company_id'], 'user_id' => $info['user_id'], 'worker_id' => $info['worker_id'], 'weixiu_times' => $info['weixiu_times'], 'weixiu_id' => $info['weixiu_id'], 'title' => '已完成', 'createtime' => $nowtime, ]; $jindu_id = Db::name('maintain_jindu')->insertGetId($jindu); if(!$jindu_id){ Db::rollback(); $this->error('操作失败,重试一下吧'); } //修改订单 $update = [ 'status' => 90, 'wancheng_time' => $nowtime, 'updatetime' => $nowtime, ]; $rs2 = Db::name('maintain')->where('id',$order_id)->update($update); if($rs2 === false){ Db::rollback(); $this->error('操作失败,重试一下吧'); } Db::commit(); $this->success('操作成功'); } //////////////////////////////循环结束/////////////////////// }