| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859 | 
							- <?php
 
- namespace app\admin\controller;
 
- use think\App;
 
- use think\Db;
 
- use think\Exception;
 
- class Todo extends Auth
 
- {
 
-     public function __construct(App $app = null) {
 
-         parent::__construct($app);
 
-         $this->model= new \app\common\model\Todo();
 
-         $this->table='todo_view';
 
-     }
 
-     //工单列表
 
-     public function index(){
 
-         $mode = input('mode',0);
 
-         $quality_type = input('quality_type','');
 
-         if(request()->isAjax()){
 
-             //分页参数
 
-             $length = input('rows',10,'intval');   //每页条数
 
-             $page = input('page',1,'intval');      //第几页
 
-             $start = ($page - 1) * $length;     //分页开始位置
 
-             //排序
 
-             $sortRow = input('sidx','id','trim');      //排序列
 
-             $sort = input('sord','desc','trim');        //排序方式
 
-             $order = $sortRow.' '.$sort;
 
-             $content = input('content','','trim');
 
-             if($content){
 
-                 $map[] = ['content','like','%'.$content.'%'];
 
-             }
 
-             $name = input('name','','trim');
 
-             if($name){
 
-                 $map[] = ['to_real_name','like','%'.$name.'%'];
 
-             }
 
-             $todo_mode = input('todo_mode','','trim');
 
-             if($todo_mode != ''){
 
-                 if($todo_mode==100){//已挂起
 
-                     $map[] = ['todo_mode','=',2];
 
-                     $map[] = ['pause','=',1];
 
-                 }else{
 
-                     $map[] = ['todo_mode','=',$todo_mode];
 
-                 }
 
-             }
 
-             $b = input('start','','trim');
 
-             $e = input('end','','trim');
 
-             if($b){
 
- //                $b = date('Ymd',strtotime($b));
 
- //                $map[] = ['create_yyyymmdd','>=',$b];
 
-                 $map[] = ['create_time', '>=', $b];
 
-             }
 
-             if($e){
 
- //                $e = date('Ymd',strtotime($e));
 
- //                $map[] = ['create_yyyymmdd','<=',$e];
 
-                 $map[] = ['create_time', '<=', $e];
 
-             }
 
-             $map[] = ['org_id','=',$this->orgId];
 
-             if($mode==-1){//一键呼叫订单
 
-                 $map[] = ['source_type','=',4];
 
-             }
 
-             if($mode==-2){ //一键呼叫工单
 
-                 $map[] = ['work_type_mode','=',0];
 
-             }
 
-             if($mode == 15){ // 品质检查,单独处理
 
-                 $map[] = ['work_type_mode','=',$mode];
 
-                 if($quality_type !=''){
 
-                     $map[] = ['quality_type','=',$quality_type];
 
-                 }
 
-             }else{
 
-                 $work_type_mode = input('work_type_mode','','trim');
 
-                 if(!is_admin($this->userId)){
 
-                     $auth = get_dispatch_auth($this->userId);
 
-                     if($auth){
 
-                         $map[] = ['work_type_mode', 'in', $auth];
 
-                         if($mode > 0){
 
-                             $map[] = ['work_type_mode', '=', $mode];
 
-                         }else{
 
-                             if($work_type_mode!=''){
 
-                                 $map[] = ['work_type_mode','=',$work_type_mode];
 
-                             }
 
-                         }
 
-                     }else{
 
-                         $map[] = ['work_type_mode', '=', -1];
 
-                     }
 
-                 }else{
 
-                     if($mode > 0){
 
-                         $map[] = ['work_type_mode', '=', $mode];
 
-                     }else{
 
-                         if($work_type_mode!=''){
 
-                             $map[] = ['work_type_mode','=',$work_type_mode];
 
-                         }
 
-                     }
 
-                 }
 
-             }
 
-             $sn = input('sn', '', 'trim');
 
-             if ($sn) {
 
-                 $map[] = ['sn', 'like', '%' . $sn . '%'];
 
-             }
 
-             $order_sn = input('order_sn', '', 'trim');
 
-             if ($order_sn) {
 
-                 $map[] = ['order_sn', 'like', '%' . $order_sn . '%'];
 
-             }
 
-             $dep_cate = input('dep_cate', '', 'trim');
 
-             if ($dep_cate != '') {
 
-                 $depIds = Db::name('dep')
 
-                     ->where('org_id',$this->orgId)
 
-                     ->where('cate_id',$dep_cate)
 
-                     ->where('del',0)
 
-                     ->column('id');
 
-                 if(!empty($depIds)){
 
-                     $map[] = ['dep_id', 'in', $depIds];
 
-                 }else{
 
-                     $map[] = ['dep_id', '=', -1];
 
-                 }
 
-             }
 
-             $from = input('from', '', 'trim');
 
-             if ($from) {
 
-                 if($from >3){
 
-                     $map[] = ['from','=',0];
 
-                     $map[] = ['work_type_mode','=',$from-3];
 
-                 }else{
 
-                     $map[] = ['from','=',$from];
 
-                 }
 
-             }
 
-             $priority = input('priority', '', 'trim');
 
-             if($priority !=''){
 
-                 $map[] = ['priority', '=',$priority];
 
-             }
 
-             $map= empty($map) ? true: $map;
 
-             //数据查询
 
-             $lists = db($this->table)->where($map)
 
-                 ->limit($start,$length)
 
-                 ->order($order)->select();
 
-             foreach ($lists as $k=>$v){
 
-                 $lists[$k] = $this->model->newFormatTodo($v);
 
-                 $lists[$k]['priority'] = isset(model('Orders')->priority[$v['priority']])?model('Orders')->priority[$v['priority']]:"";
 
-             }
 
-             //数据返回
 
-             $totalCount = db($this->table)->where($map)->count();
 
-             $totalPage = ceil($totalCount/$length);
 
-             $result['page'] = $page;
 
-             $result['total'] = $totalPage;
 
-             $result['records'] = $totalCount;
 
-             $result['rows'] = $lists;
 
-             return json($result);
 
-         }else{
 
-             if($mode>0){
 
-                 $mode_name = $this->getTableField('work_type_mode',['id'=>$mode],'name');
 
-             }else{
 
-                 $mode_name = '';
 
-             }
 
-             $auths = [1,2,3,4,15,0];
 
-             if(!is_admin($this->userId)){
 
-                 $auth = get_dispatch_auth($this->userId);
 
-                 if($auth){
 
-                     $auths = array_intersect($auths,$auth);
 
-                     if($mode > 0){
 
-                         $auths = array_intersect($auths,[$mode]);
 
-                     }
 
-                 }else{
 
-                     $auths = [];
 
-                 }
 
-             }
 
-             $this->assign('auths',$auths);
 
-             $todo_order_mode = Db::name('todo_mode')
 
-                 ->select();
 
-             $this->assign('todo_mode_list',$todo_order_mode);
 
-             $this->assign('m_name',$mode_name);
 
-             $this->assign('mode',$mode);
 
-             $this->assign('quality_type',$quality_type);
 
-             $dep_cate = model('DepCate')->getList();
 
-             $this->assign('dep_cate',$dep_cate);
 
-             $this->assign('priority', model("Orders")->priority);
 
-             $is = 0;
 
-             if(!isset($_GET['quality_type']) && $mode==15){
 
-                 $is = 1;
 
-             }
 
-             $this->assign('is',$is);
 
-             if($mode==1){
 
-                 return $this->fetch('index1');
 
-             }else if ($mode==3){
 
-                 return $this->fetch('index3');
 
-             }else if ($mode==0 || $mode==-1){
 
-                 return $this->fetch('index0');
 
-             }else{
 
-                 return $this->fetch('index');
 
-             }
 
-         }
 
-     }
 
-     //用户取消订单
 
-     public function cancel($id){
 
-         $res = $this->model->cancel($id,$this->userId);
 
-         if(!$res){
 
-             $this->error($this->model->getError());
 
-         }
 
-         $this->success('取消成功');
 
-     }
 
-     //调度取消订单
 
-     public function disCancel($id){
 
-        if(request()->isGet()){
 
-            $this->assign('id',$id);
 
-            return $this->fetch();
 
-        }else{
 
-            $reason = input('cancel_reason');
 
-            $res = $this->model->cancel($id,$reason);
 
-            if(!$res){
 
-                $this->error($this->model->getError());
 
-            }
 
-            $this->success('取消成功');
 
-        }
 
-     }
 
-     //工单详情
 
-     public function detail($id){
 
-         if (!$id) {
 
-             $this->error('参数错误');
 
-         }
 
-         $order = Db::name('todo_view')->where(['id' => $id])->find();
 
-         $order = $this->model->formatTodo($order);
 
-         $order['images'] = !empty($order['images'])?explode(',',$order['images']):'';
 
-         $order['to_ok_images'] = !empty($order['to_ok_images'])?explode(',',$order['to_ok_images']):'';
 
-         $this->assign('info', $order);
 
-         $workTypeName = $this->getTableField('work_type_mode',['id'=>$order['work_type_mode']],'name');
 
-         $this->assign('meta_title', $workTypeName.'工单详情');
 
-         if($order['work_type_mode']==3){
 
-             return $this->fetch('detail3');
 
-         }else{
 
-             return $this->fetch('detail');
 
-         }
 
-     }
 
-     //调度删除订单
 
-     public function del($id=0){
 
-         if(!$id){
 
-             $this->error('参数错误');
 
-         }
 
-         $model = (new \app\common\model\Orders());
 
-         $res = $model->del($id,$this->userId);
 
-         if(!$res){
 
-             $this->error($model->getError());
 
-         }
 
-         $this->success('删除成功');
 
-     }
 
-     //派单
 
-     public function send($id,$mode=1){
 
-         if(request()->isGet()){
 
-             $this->assign('id',$id);
 
-             $this->assign('mode',$mode);
 
-             if($mode==1){
 
-                 $order_type = (new \app\common\model\OrderType())->getList();
 
-                 $address = (new \app\common\model\Address())->getListByType(1);
 
-                 $todoInfo = Db::name('todo')
 
-                     ->where('id',$id)
 
-                     ->find();
 
-                 $order_repair = Db::name('order_repair')
 
-                     ->where('order_id',$todoInfo['order_id'])
 
-                     ->find();
 
-                 $this->assign('order_repair',$order_repair);
 
-                 $this->assign('order_type_list',$order_type);
 
-                 $this->assign('address_list',$address);
 
-             }
 
-             $this->assign('send_user_num',model('orders')->sendUserNum($mode,$this->orgId));
 
-             $this->assign('user_list',(new \app\common\model\WorkTypeMode())->getRolesUser($mode,$this->orgId,1));
 
-             return $this->fetch();
 
-         }else{
 
-             $data = request()->post();
 
-             $data['org_id'] = $this->orgId;
 
-             $res = $this->model->send($id,$this->userId,$data);
 
-             if(!$res){
 
-                 $this->error($this->model->getError());
 
-             }
 
-             $this->success('操作成功');
 
-         }
 
-     }
 
-     //完成工单
 
-     public function finish($id){
 
-         $res = $this->model->finish($id);
 
-         if(!$res){
 
-             $this->error($this->model->getError());
 
-         }
 
-         $this->success('操作成功');
 
-     }
 
-     public function removeEmojiChar($str)
 
-     {
 
-         $mbLen = mb_strlen($str);
 
-         $strArr = [];
 
-         for ($i = 0; $i < $mbLen; $i++) {
 
-             $mbSubstr = mb_substr($str, $i, 1, 'utf-8');
 
-             if (strlen($mbSubstr) >= 4) {
 
-                 continue;
 
-             }
 
-             $strArr[] = $mbSubstr;
 
-         }
 
-         return implode('', $strArr);
 
-     }
 
-     //excel导出
 
-     public function export($mode) {
 
-         set_time_limit(0);
 
-         ini_set("memory_limit", "1024M");
 
-         $meta_title = '工单列表';
 
-         if ($mode == 1) {
 
-             $meta_title = '报修' . $meta_title;
 
-         }
 
-         elseif ($mode == 2) {
 
-             $meta_title = '保洁' . $meta_title;
 
-         }
 
-         elseif ($mode == 3) {
 
-             $meta_title = '运送' . $meta_title;
 
-         }
 
-         elseif ($mode == 4) {
 
-             $meta_title = '应急' . $meta_title;
 
-         }
 
-         elseif ($mode == 15) {
 
-             $meta_title = '品质整改' . $meta_title;
 
-         }elseif ($mode == -1) {
 
-             $meta_title = '一键呼叫' . $meta_title;
 
-         }
 
-         $quality_type = input('quality_type','');
 
-         if (request()->isGet()) {
 
-             //排序
 
-             $sortRow = input('sidx','id','trim');      //排序列
 
-             $sort = input('sord','desc','trim');        //排序方式
 
-             $order = $sortRow.' '.$sort;
 
-             $content = input('content','','trim');
 
-             if($content){
 
-                 $map[] = ['content','like','%'.$content.'%'];
 
-             }
 
-             $name = input('name','','trim');
 
-             if($name){
 
-                 $map[] = ['to_real_name','like','%'.$name.'%'];
 
-             }
 
-             $todo_mode = input('todo_mode','','trim');
 
-             if($todo_mode != ''){
 
-                 if($todo_mode==100){//已挂起
 
-                     $map[] = ['todo_mode','=',2];
 
-                     $map[] = ['pause','=',1];
 
-                 }else{
 
-                     $map[] = ['todo_mode','=',$todo_mode];
 
-                 }
 
-             }
 
-             $b = input('start','','trim');
 
-             $e = input('end','','trim');
 
-             if($b){
 
- //                $b = date('Ymd',strtotime($b));
 
- //                $map[] = ['create_yyyymmdd','>=',$b];
 
-                 $map[] = ['create_time', '>=', $b];
 
-             }
 
-             if($e){
 
- //                $e = date('Ymd',strtotime($e));
 
- //                $map[] = ['create_yyyymmdd','<=',$e];
 
-                 $map[] = ['create_time', '<=', $e];
 
-             }
 
-             $map[] = ['org_id','=',$this->orgId];
 
-             if($mode==-1){//一键呼叫订单
 
-                 $map[] = ['source_type','=',4];
 
-             }
 
-             if($mode == 15){ // 品质检查,单独处理
 
-                 $map[] = ['work_type_mode','=',$mode];
 
-                 if($quality_type !=''){
 
-                     $map[] = ['quality_type','=',$quality_type];
 
-                 }
 
-             }else{
 
-                 $work_type_mode = input('work_type_mode','','trim');
 
-                 if(!is_admin($this->userId)){
 
-                     $auth = get_dispatch_auth($this->userId);
 
-                     if($auth){
 
-                         $map[] = ['work_type_mode', 'in', $auth];
 
-                         if($mode > 0){
 
-                             $map[] = ['work_type_mode', '=', $mode];
 
-                         }else{
 
-                             if($work_type_mode!=''){
 
-                                 $map[] = ['work_type_mode','=',$work_type_mode];
 
-                             }
 
-                         }
 
-                     }else{
 
-                         $map[] = ['work_type_mode', '=', -1];
 
-                     }
 
-                 }else{
 
-                     if($mode > 0){
 
-                         $map[] = ['work_type_mode', '=', $mode];
 
-                     }else{
 
-                         if($work_type_mode!=''){
 
-                             $map[] = ['work_type_mode','=',$work_type_mode];
 
-                         }
 
-                     }
 
-                 }
 
-             }
 
-             $sn = input('sn', '', 'trim');
 
-             if ($sn) {
 
-                 $map[] = ['sn', 'like', '%' . $sn . '%'];
 
-             }
 
-             $order_sn = input('order_sn', '', 'trim');
 
-             if ($order_sn) {
 
-                 $map[] = ['order_sn', 'like', '%' . $order_sn . '%'];
 
-             }
 
-             $dep_cate = input('dep_cate', '', 'trim');
 
-             if ($dep_cate != '') {
 
-                 $depIds = Db::name('dep')
 
-                     ->where('org_id',$this->orgId)
 
-                     ->where('cate_id',$dep_cate)
 
-                     ->where('del',0)
 
-                     ->column('id');
 
-                 if(!empty($depIds)){
 
-                     $map[] = ['dep_id', 'in', $depIds];
 
-                 }else{
 
-                     $map[] = ['dep_id', '=', -1];
 
-                 }
 
-             }
 
-             $from = input('from', '', 'trim');
 
-             if ($from) {
 
-                 if($from >3){
 
-                     $map[] = ['from','=',0];
 
-                     $map[] = ['work_type_mode','=',$from-3];
 
-                 }else{
 
-                     $map[] = ['from','=',$from];
 
-                 }
 
-             }
 
-             $priority = input('priority', '', 'trim');
 
-             if($priority !=''){
 
-                 $map[] = ['priority', '=',$priority];
 
-             }
 
-             $map= empty($map) ? true: $map;
 
-             //数据查询
 
-             $lists = db($this->table)->where($map)
 
-                 ->order($order)->select();
 
-             foreach ($lists as $k=>$v){
 
-                 $lists[$k] = $this->model->newFormatTodo($v);
 
-                 $lists[$k]['content'] = $this->removeEmojiChar($v['content']);
 
-                 $lists[$k]['priority'] = isset(model('Orders')->priority[$v['priority']])?model('Orders')->priority[$v['priority']]:"";
 
-                 $lists[$k]['cons'] = [];
 
-                 if($v['work_type_mode'] == 1){
 
-                     $todo_mate = Db::name('todo_mate')
 
-                         ->where('todo_id',$v['id'])
 
-                         ->select();
 
-                     if(!empty($todo_mate)){
 
-                         $cons = Db::name('todo_mate_item')
 
-                             ->alias('a')
 
-                             ->join('mate_goods b','b.id = a.items_id')
 
-                             ->where('a.todo_mate_id','in',array_column($todo_mate,'id'))
 
-                             ->field('a.*,b.title')
 
-                             ->select();
 
-                         foreach ($cons as $k1=>$v1){
 
-                             $lists[$k]['cons'][] = [
 
-                                 'title' =>$v1['title'],
 
-                                 'total' =>$v1['total'],
 
-                                 'money' =>$v1['money'],
 
-                                 'total_money' =>$v1['total_money'],
 
-                             ];
 
-                         }
 
-                     }
 
-                 }
 
-             }
 
-             include_once env('root_path') . '/extend/phpexcel/Classes/PHPExcel.php';
 
-             //实例化PHPExcel类
 
-             $objPHPExcel = new \PHPExcel();
 
-             //激活当前的sheet表
 
-             $objActSheet = $objPHPExcel->setActiveSheetIndex(0);
 
-             //设置表格头(即excel表格的第一行)
 
-             if ($mode == 1) {
 
-                 $objPHPExcel->setActiveSheetIndex(0)
 
-                     ->setCellValue('A1', '编号')
 
-                     ->setCellValue('B1', '订单编号')
 
-                     ->setCellValue('C1', '发起人')
 
-                     ->setCellValue('D1', '执行人')
 
-                     ->setCellValue('E1', '报修类型')
 
-                     ->setCellValue('F1', '报修事项')
 
-                     ->setCellValue('G1', '报修地点')
 
-                     ->setCellValue('H1', '内容')
 
-                     ->setCellValue('I1', '订单发起时间')
 
-                     ->setCellValue('J1', '调度分派时间')
 
-                     ->setCellValue('K1', '接单时间')
 
-                     ->setCellValue('L1', '完成时间')
 
-                     ->setCellValue('M1', '状态')
 
-                     ->setCellValue('N1', '调度分派时长')
 
-                     ->setCellValue('O1', '接单时长')
 
-                     ->setCellValue('P1', '处理时长')
 
-                     ->setCellValue('Q1', '挂起开始时间')
 
-                     ->setCellValue('R1', '挂起结束时间')
 
-                     ->setCellValue('S1', '挂起时长')
 
-                     ->setCellValue('T1', '所在科室/部门')
 
-                     ->setCellValue('U1', '来源')
 
-                     ->setCellValue('V1', '部门分类')
 
-                     ->setCellValue('W1', '物品名称')
 
-                     ->setCellValue('X1', '单价')
 
-                     ->setCellValue('Y1', '数量')
 
-                     ->setCellValue('Z1', '总价')
 
-                     ->setCellValue('AA1', '签名图');
 
-             }
 
-             else {
 
-                 if ($mode == 3) {
 
-                     $objPHPExcel->setActiveSheetIndex(0)
 
-                         ->setCellValue('A1', '订单编号')
 
-                         ->setCellValue('B1', '优先级')
 
-                         ->setCellValue('C1', '申请人')
 
-                         ->setCellValue('D1', '申请时间')
 
-                         ->setCellValue('E1', '所在科室/部门')
 
-                         ->setCellValue('F1', '运送类型')
 
-                         ->setCellValue('G1', '工单编号')
 
-                         ->setCellValue('H1', '执行人')
 
-                         ->setCellValue('I1', '备注内容')
 
-                         ->setCellValue('J1', '分派时间')
 
-                         ->setCellValue('K1', '接单时间')
 
-                         ->setCellValue('L1', '完成时间')
 
-                         ->setCellValue('M1', '开始地点')
 
-                         ->setCellValue('N1', '扫码开始时间')
 
-                         ->setCellValue('O1', '结束地点')
 
-                         ->setCellValue('P1', '扫码结束时间')
 
-                         ->setCellValue('Q1', '床号')
 
-                         ->setCellValue('R1', '姓名')
 
-                         ->setCellValue('S1', '状态');
 
-                 }
 
-                 else {
 
-                     if($mode==0){
 
-                         $objPHPExcel->setActiveSheetIndex(0)
 
-                             ->setCellValue('A1', '编号')
 
-                             ->setCellValue('B1', '订单编号')
 
-                             ->setCellValue('C1', '发起人')
 
-                             ->setCellValue('D1', '执行人')
 
-                             ->setCellValue('E1', '内容')
 
-                             ->setCellValue('F1', '订单发起时间')
 
-                             ->setCellValue('G1', '调度分派时间')
 
-                             ->setCellValue('H1', '接单时间')
 
-                             ->setCellValue('I1', '完成时间')
 
-                             ->setCellValue('J1', '状态')
 
-                             ->setCellValue('K1', '工单类型')
 
-                             ->setCellValue('L1', '调度分派时长')
 
-                             ->setCellValue('M1', '接单时长')
 
-                             ->setCellValue('N1', '处理时长')
 
-                             ->setCellValue('O1', '所在科室/部门')
 
-                             ->setCellValue('P1', '来源')
 
-                             ->setCellValue('Q1', '部门分类');
 
-                     }else{
 
-                         $objPHPExcel->setActiveSheetIndex(0)
 
-                             ->setCellValue('A1', '编号')
 
-                             ->setCellValue('B1', '订单编号')
 
-                             ->setCellValue('C1', '发起人')
 
-                             ->setCellValue('D1', '执行人')
 
-                             ->setCellValue('E1', '内容')
 
-                             ->setCellValue('F1', '订单发起时间')
 
-                             ->setCellValue('G1', '调度分派时间')
 
-                             ->setCellValue('H1', '接单时间')
 
-                             ->setCellValue('I1', '完成时间')
 
-                             ->setCellValue('J1', '状态')
 
-                             ->setCellValue('K1', '调度分派时长')
 
-                             ->setCellValue('L1', '接单时长')
 
-                             ->setCellValue('M1', '处理时长')
 
-                             ->setCellValue('N1', '所在科室/部门')
 
-                             ->setCellValue('O1', '来源')
 
-                             ->setCellValue('P1', '部门分类');
 
-                     }
 
-                 }
 
-             }
 
-             // 设置表格头水平居中
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('A1')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('B1')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('C1')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('D1')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('E1')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('F1')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('G1')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('H1')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             //设置列水平居中
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('A')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('B')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('C')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('D')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('E')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('F')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('G')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getStyle('H')->getAlignment()
 
-                 ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
-             //设置单元格宽度
 
-             $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('A')->setWidth(20);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('B')->setWidth(20);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('C')->setWidth(20);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('D')->setWidth(20);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('E')->setWidth(20);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('F')->setWidth(20);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('G')->setWidth(20);
 
-             $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('H')->setWidth(20);
 
-             //循环刚取出来的数组,将数据逐一添加到excel表格。
 
-             if ($mode == 1) {
 
-                 for ($i = 0; $i < count($lists); $i++) {
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('A' . ($i + 2), $lists[$i]['sn']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('B' . ($i + 2), $lists[$i]['order_sn']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('C' . ($i + 2), $lists[$i]['real_name']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('D' . ($i + 2), $lists[$i]['to_real_name']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('E' . ($i + 2), $lists[$i]['order_type']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('F' . ($i + 2), $lists[$i]['order_type_matter']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('G' . ($i + 2), $lists[$i]['address_title']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('H' . ($i + 2), $lists[$i]['content']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('I' . ($i + 2), $lists[$i]['create_time']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('J' . ($i + 2), $lists[$i]['to_create_time']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('K' . ($i + 2), $lists[$i]['confirm_time']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('L' . ($i + 2), $lists[$i]['done_time']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('M' . ($i + 2), $lists[$i]['todo_mode_in_content']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('N' . ($i + 2), $lists[$i]['dispatch_time']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('O' . ($i + 2), $lists[$i]['jiedan_time']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('P' . ($i + 2), $lists[$i]['time_cost']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('Q' . ($i + 2), $lists[$i]['pause_time']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('R' . ($i + 2), $lists[$i]['pause_end']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('S' . ($i + 2), $lists[$i]['pause_cost']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('T' . ($i + 2), $lists[$i]['dep']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('U' . ($i + 2), $lists[$i]['source_type_text']);
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('V' . ($i + 2), $lists[$i]['dep_cate_name']);
 
- //                    $signList = explode(".",$lists[$i]['sign']);
 
- //                    if($signList){
 
- //                        $ext = end($signList);
 
- //                        $img ='';
 
- //                        if ($ext == 'jpg' || $ext == 'jpeg'){
 
- //                            $img = @imagecreatefromjpeg($lists[$i]['sign']);
 
- //                        }
 
- //                        if ($ext == 'png'){
 
- //                            $img = @imagecreatefrompng($lists[$i]['sign']);
 
- //                        }
 
- //                        if($img){
 
- //                            //实例化图片操作类
 
- //                            $objDrawing = new \PHPExcel_Worksheet_MemoryDrawing();
 
- //                            $objDrawing->setImageResource($img);
 
- //                            $objDrawing->setRenderingFunction(\PHPExcel_Worksheet_MemoryDrawing::RENDERING_DEFAULT);//渲染方法
 
- //
 
- //                            $objDrawing->setMimeType(\PHPExcel_Worksheet_MemoryDrawing::MIMETYPE_DEFAULT);
 
- //
 
- //                            $objDrawing->setHeight(40);//照片高度
 
- //                            $objDrawing->setWidth(40); //照片宽度
 
- //                            $objDrawing->setCoordinates('W'.($i+2));//图片要插入的单元格
 
- //
 
- //                            $objDrawing->setOffsetX(8);//图片X轴偏移
 
- //                            $objDrawing->setOffsetY(8);//图片Y轴偏移
 
- //                            $objDrawing->setWorksheet($objPHPExcel->getActiveSheet());
 
- //                            //设置每一行高度
 
- //
 
- //                        }else{
 
- //                            $objPHPExcel->getActiveSheet()->setCellValue('W' . ($i + 2), '');
 
- //                        }
 
- //
 
- //
 
- //                    }else{
 
- //                        $objPHPExcel->getActiveSheet()->setCellValue('W' . ($i + 2), '');
 
- //                    }
 
- //                    $objActSheet->getRowDimension($i + 2)->setRowHeight(40); // 行高
 
-                     $goodsName = $goodsPrice = $goodsNum = $goodsTotal  = '';
 
-                     if(empty($lists[$i]['cons'])){
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('W' . ($i + 2), "");
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('X' . ($i + 2), "");
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('Y' . ($i + 2), "");
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('Z' . ($i + 2), "");
 
-                     }else{
 
-                         $objPHPExcel->getActiveSheet()->getStyle('W'.($i + 2))->getAlignment()->setWrapText(true);
 
-                         $objPHPExcel->getActiveSheet()->getStyle('X'.($i + 2))->getAlignment()->setWrapText(true);
 
-                         $objPHPExcel->getActiveSheet()->getStyle('Y'.($i + 2))->getAlignment()->setWrapText(true);
 
-                         $objPHPExcel->getActiveSheet()->getStyle('Z'.($i + 2))->getAlignment()->setWrapText(true);
 
-                         foreach ($lists[$i]['cons'] as $kk=>$vv){
 
-                             $goodsName.= $vv['title']."\r\n";
 
-                             $goodsPrice.= $vv['money']."\r\n";
 
-                             $goodsNum.= $vv['total']."\r\n";
 
-                             $goodsTotal.= $vv['total_money']."\r\n";
 
-                         }
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('W' . ($i + 2), $goodsName);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('X' . ($i + 2), $goodsPrice);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('Y' . ($i + 2), $goodsNum);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('Z' . ($i + 2), $goodsTotal);
 
-                     }
 
-                     $objPHPExcel->getActiveSheet()->setCellValue('AA' . ($i + 2), $lists[$i]['sign']);
 
-                 }
 
-             }
 
-             else {
 
-                 if ($mode == 3) {
 
-                     for ($i = 0; $i < count($lists); $i++) {
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('A' . ($i + 2), $lists[$i]['order_sn']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('B' . ($i + 2), $lists[$i]['priority']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('C' . ($i + 2), $lists[$i]['sq_real_name']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('D' . ($i + 2), $lists[$i]['create_time']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('E' . ($i + 2), $lists[$i]['dep']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('F' . ($i + 2), $lists[$i]['type_name']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('G' . ($i + 2), $lists[$i]['sn']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('H' . ($i + 2), $lists[$i]['to_real_name']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('I' . ($i + 2), $lists[$i]['content']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('J' . ($i + 2), $lists[$i]['to_create_time']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('K' . ($i + 2), $lists[$i]['confirm_time']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('L' . ($i + 2), $lists[$i]['done_time']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('M' . ($i + 2), $lists[$i]['start_name']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('N' . ($i + 2), $lists[$i]['tco']['start_time']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('O' . ($i + 2), $lists[$i]['end_name']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('P' . ($i + 2), $lists[$i]['tco']['end_time']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('Q' . ($i + 2), $lists[$i]['ocps']['bed_number']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('R' . ($i + 2), $lists[$i]['ocps']['name']);
 
-                         $objPHPExcel->getActiveSheet()->setCellValue('S' . ($i + 2), $lists[$i]['todo_mode_in_content']);
 
-                     }
 
-                 }
 
-                 else {
 
-                     if($mode==0){
 
-                         for ($i = 0; $i < count($lists); $i++) {
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('A' . ($i + 2), $lists[$i]['sn']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('B' . ($i + 2), $lists[$i]['order_sn']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('C' . ($i + 2), $lists[$i]['real_name']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('D' . ($i + 2), $lists[$i]['to_real_name']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('E' . ($i + 2), $lists[$i]['content']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('F' . ($i + 2), $lists[$i]['create_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('G' . ($i + 2), $lists[$i]['to_create_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('H' . ($i + 2), $lists[$i]['confirm_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('I' . ($i + 2), $lists[$i]['done_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('J' . ($i + 2), $lists[$i]['todo_mode_in_content']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('K' . ($i + 2), $lists[$i]['work_type_mode_text']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('L' . ($i + 2), $lists[$i]['dispatch_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('M' . ($i + 2), $lists[$i]['jiedan_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('N' . ($i + 2), $lists[$i]['time_cost']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('O' . ($i + 2), $lists[$i]['dep']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('P' . ($i + 2), $lists[$i]['source_type_text']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('Q' . ($i + 2), $lists[$i]['dep_cate_name']);
 
-                         }
 
-                     }else{
 
-                         for ($i = 0; $i < count($lists); $i++) {
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('A' . ($i + 2), $lists[$i]['sn']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('B' . ($i + 2), $lists[$i]['order_sn']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('C' . ($i + 2), $lists[$i]['real_name']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('D' . ($i + 2), $lists[$i]['to_real_name']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('E' . ($i + 2), $lists[$i]['content']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('F' . ($i + 2), $lists[$i]['create_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('G' . ($i + 2), $lists[$i]['to_create_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('H' . ($i + 2), $lists[$i]['confirm_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('I' . ($i + 2), $lists[$i]['done_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('J' . ($i + 2), $lists[$i]['todo_mode_in_content']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('K' . ($i + 2), $lists[$i]['dispatch_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('L' . ($i + 2), $lists[$i]['jiedan_time']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('M' . ($i + 2), $lists[$i]['time_cost']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('N' . ($i + 2), $lists[$i]['dep']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('O' . ($i + 2), $lists[$i]['source_type_text']);
 
-                             $objPHPExcel->getActiveSheet()->setCellValue('P' . ($i + 2), $lists[$i]['dep_cate_name']);
 
-                         }
 
-                     }
 
-                 }
 
-             }
 
-             //设置保存的Excel表格名称
 
-             $filename = $meta_title . '_' . date('YmdHis', time()) . '.xls';
 
-             //设置当前激活的sheet表格名称
 
-             $objPHPExcel->getActiveSheet()->setTitle($meta_title);
 
-             //设置浏览器窗口下载表格
 
-             ob_end_clean();
 
-             header("Content-Type: application/force-download");
 
-             header("Content-Type: application/octet-stream");
 
-             header("Content-Type: application/download");
 
-             header('Content-Disposition:inline;filename="' . $filename);
 
-             //生成excel文件
 
-             $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
 
-             //下载文件在浏览器窗口
 
-             return $objWriter->save('php://output');
 
-         }
 
-     }
 
-     public function print($id){
 
-         $info = Db::name('todo_view')->where('id',$id)->find();
 
-         $depName = Db::name('dep')
 
-             ->where('id',$info['dep_id'])
 
-             ->value('title');
 
-         $info['depName'] = $depName;
 
-         $info['cons'] = [];
 
-         $info['sign'] = Db::name('todo')->where('id',$id)->value('sign');
 
-         $total = $totalPrice = 0;
 
-         $mate = Db::name('todo_mate_item')
 
-             ->alias('tmi')
 
-             ->join('todo_mate tm','tmi.todo_mate_id = tm.id')
 
-             ->join('mate_goods mg','mg.id = tmi.items_id')
 
-             ->field('tmi.items_id,tmi.total,tmi.money,tmi.total_money,mg.title')
 
-             ->where('tm.todo_id',$info['id'])
 
-             ->select();
 
-         if(!empty($mate)){
 
-             foreach ($mate as $kk=>$todo_mate){
 
-                 $info['cons'][] = [
 
-                     'title' =>$todo_mate['title'],
 
-                     'total' =>$todo_mate['total'],
 
-                     'money' =>$todo_mate['money'],
 
-                     'total_money' =>$todo_mate['total_money'],
 
-                 ];
 
-                 $total +=$todo_mate['total'];
 
-                 $totalPrice +=$todo_mate['total_money'];
 
-             }
 
-         }
 
-         $aa = [
 
-             'title'=>'',
 
-             'total'=>'',
 
-             'money'=>'',
 
-             'total_money'=>'',
 
-         ];
 
-         if(empty($info['cons'])){
 
-             for ($i=1;$i<=4;$i++){
 
-                 $info['cons'][] = $aa;
 
-             }
 
-         }elseif (count($info['cons']) <4){
 
-             $ii = 4-count($info['cons']);
 
-             for ($i=1;$i<=$ii;$i++){
 
-                 $info['cons'][] = $aa;
 
-             }
 
-         }
 
-         $info['total'] = $total;
 
-         $info['totalPrice'] = round($totalPrice,2);
 
-         $this->assign('info', $info);
 
-         return $this->fetch();
 
-     }
 
- }
 
 
  |