Orders.php 91 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181
  1. <?php
  2. namespace app\admin\controller;
  3. use think\App;
  4. use think\Db;
  5. use think\Exception;
  6. class Orders extends Auth {
  7. public function __construct(App $app = null) {
  8. parent::__construct($app);
  9. $this->model = new \app\common\model\Orders();
  10. $this->table = $this->model->table;
  11. }
  12. //用户订单列表
  13. public function selfIndex() {
  14. $mode = input('mode', 1);
  15. if (request()->isAjax()) {
  16. //分页参数
  17. $length = input('rows', 10, 'intval'); //每页条数
  18. $page = input('page', 1, 'intval'); //第几页
  19. $start = ($page - 1) * $length; //分页开始位置
  20. //排序
  21. $sortRow = input('sidx', 'id', 'trim'); //排序列
  22. $sort = input('sord', 'desc', 'trim'); //排序方式
  23. $order = $sortRow . ' ' . $sort;
  24. $map[] = ['del', '=', 0];
  25. $map[] = ['org_id', '=', $this->orgId];
  26. $order_mode = input('order_mode', '', 'trim');
  27. if ($order_mode != '') {
  28. $map[] = ['order_mode', '=', $order_mode];
  29. }
  30. if($mode >0){
  31. $map[] = ['work_type_mode', '=', $mode];
  32. }else{
  33. $map[] = ['source_type', '=', 4];
  34. }
  35. $sn = input('sn', '', 'trim');
  36. if ($sn) {
  37. $map[] = ['sn', 'like', '%' . $sn . '%'];
  38. }
  39. if (!is_admin($this->userId)) {
  40. $map[] = ['user_id', '=', $this->userId];
  41. }
  42. $map = empty($map) ? true : $map;
  43. //数据查询
  44. $lists = db($this->table)->where($map)->limit($start, $length)->order($order)->select();
  45. foreach ($lists as $k => $v) {
  46. $lists[$k] = $this->model->formatOrder($v);
  47. }
  48. //数据返回
  49. $totalCount = db($this->table)->where($map)->count();
  50. $totalPage = ceil($totalCount / $length);
  51. $result['page'] = $page;
  52. $result['total'] = $totalPage;
  53. $result['records'] = $totalCount;
  54. $result['rows'] = $lists;
  55. return json($result);
  56. }
  57. else {
  58. $mode_name = $this->getTableField('work_type_mode', ['id' => $mode], 'name');
  59. $this->assign('m_name', $mode_name);
  60. $this->assign('mode', $mode);
  61. $order_mode = Db::name('order_mode')->select();
  62. $this->assign('order_mode_list', $order_mode);
  63. if ($mode == 1) {
  64. return $this->fetch('selfIndex1');
  65. }
  66. else {
  67. if ($mode == 3) {
  68. return $this->fetch('selfIndex3');
  69. }
  70. else {
  71. return $this->fetch('selfIndex');
  72. }
  73. }
  74. }
  75. }
  76. //用户添加订单
  77. public function selfAdd($mode = 1) {
  78. if (request()->isPost()) {
  79. $data = request()->post();
  80. $data['user_id'] = $this->userId;
  81. $data['org_id'] = $this->orgId;
  82. $data['work_type_mode'] = $mode;
  83. $data['images'] = isset($data['images']) && !empty($data['images']) ? implode(',', $data['images']) : '';
  84. $res = $this->model->addSave($data);
  85. if ($res) {
  86. $this->success('操作成功');
  87. }
  88. else {
  89. $this->error($this->model->getError());
  90. }
  91. }
  92. else {
  93. $dep = $this->getTableField('user_dep', ['user_id' => $this->userId], 'dep_id');
  94. $depList = (new \app\common\model\Dep())->getList();
  95. $this->assign('dep_id', $dep);
  96. $this->assign('dep_list', $depList);
  97. $this->assign('mode', $mode);
  98. if ($mode == 3) {
  99. $address = (new \app\common\model\Address())->getListByType(2);
  100. $conveyCate = (new \app\common\model\ConveyCate());
  101. $priority = $conveyCate->priority;
  102. $order_convey = $conveyCate->getList();
  103. $order_device = (new \app\common\model\ConveyDevice())->getList();
  104. $this->assign('address', $address);
  105. $this->assign('priority', $priority);
  106. $this->assign('order_convey_type', $order_convey);
  107. $this->assign('order_device', $order_device);
  108. }
  109. $user = Db::name('user')
  110. ->where('id',$this->userId)
  111. ->find();
  112. $this->assign('user',$user);
  113. if ($mode == 3) {
  114. return $this->fetch('self_add3');
  115. }
  116. else {
  117. return $this->fetch('self_add');
  118. }
  119. }
  120. }
  121. //用户取消订单
  122. public function cancel($id) {
  123. $res = $this->model->cancel($id, $this->userId);
  124. if (!$res) {
  125. $this->error($this->model->getError());
  126. }
  127. $this->success('取消成功');
  128. }
  129. //调度取消订单
  130. public function disCancel($id) {
  131. if (request()->isGet()) {
  132. $this->assign('id', $id);
  133. return $this->fetch();
  134. }
  135. else {
  136. $reason = input('cancel_reason');
  137. $res = $this->model->cancel($id, $this->userId, 2, $reason);
  138. if (!$res) {
  139. $this->error($this->model->getError());
  140. }
  141. $this->success('取消成功');
  142. }
  143. }
  144. //延迟订单
  145. public function batchdelay($id) {
  146. if (request()->isGet()) {
  147. $delay_reason = Db::name('delay_reason')
  148. ->where('org_id', $this->orgId)
  149. ->where('enable', 1)
  150. ->where('del', 0)
  151. ->select();
  152. $this->assign('delay_reason', $delay_reason);
  153. $this->assign('id', $id);
  154. return $this->fetch();
  155. }
  156. else {
  157. $delay_reason_id = input('delay_reason_id');
  158. if (empty($delay_reason_id)) {
  159. $this->error('请选择延迟原因');
  160. }
  161. $res = $this->model->delay_reason($id, $delay_reason_id);
  162. if (!$res) {
  163. $this->error($this->model->getError());
  164. }
  165. $this->success('延迟成功');
  166. }
  167. }
  168. //取消延迟订单
  169. public function batchcanceldelay($id) {
  170. if (request()->isGet()) {
  171. $this->assign('id', $id);
  172. return $this->fetch();
  173. }
  174. else {
  175. $res = $this->model->batchcanceldelay($id);
  176. if (!$res) {
  177. $this->error($this->model->getError());
  178. }
  179. $this->success('延迟成功');
  180. }
  181. }
  182. //用户查看订单详情
  183. public function detail($id) {
  184. if (!$id) {
  185. $this->error('参数错误');
  186. }
  187. $order = Db::name('orders')->where(['id' => $id])->find();
  188. $order = $this->model->formatOrder($order, 1);
  189. $order['images'] = !empty($order['images']) ? explode(',', $order['images']) : '';
  190. $is_ch = $order['order_mode'] == 4 ? 1 : 0;
  191. $order['is_ch'] = $is_ch;
  192. if($order['work_type_mode'] == 3){
  193. // 地点路径
  194. $conveyends = Db::name('order_convey_end')
  195. ->alias('a')
  196. ->join('address b','b.id = a.addr')
  197. ->where('a.order_id',$id)
  198. ->order('a.id asc')
  199. ->field('a.addr,b.title,a.scan,a.create_time,a.update_time')
  200. ->select();
  201. $order['ends'] = $conveyends?$conveyends:[];
  202. }
  203. $this->assign('info', $order);
  204. $workTypeName = $this->getTableField('work_type_mode', ['id' => $order['work_type_mode']], 'name');
  205. $this->assign('meta_title', $workTypeName . '订单详情');
  206. return $this->fetch();
  207. }
  208. //调度订单列表
  209. public function index() {
  210. $mode = input('mode', 0);
  211. $quality_type = input('quality_type','');
  212. $level1 = check_is_dispatch($this->userId);
  213. $level2 = check_two_dispatch($this->userId);
  214. $turnoff = two_dispatch_off($this->orgId);
  215. if (request()->isAjax()) {
  216. //分页参数
  217. $length = input('rows', 10, 'intval'); //每页条数
  218. $page = input('page', 1, 'intval'); //第几页
  219. $start = ($page - 1) * $length; //分页开始位置
  220. //排序
  221. $sortRow = input('sidx', 'id', 'trim'); //排序列
  222. $sort = input('sord', 'desc', 'trim'); //排序方式
  223. $order = $sortRow . ' ' . $sort;
  224. $content = input('content', '', 'trim');
  225. if ($content) {
  226. $map[] = ['content', 'like', '%' . $content . '%'];
  227. }
  228. $dep_id = input('dep_id', '', 'trim');
  229. if ($dep_id != '') {
  230. $map[] = ['dep_id', '=', $dep_id];
  231. }
  232. $dep_cate = input('dep_cate', '', 'trim');
  233. if ($dep_cate != '') {
  234. $depIds = Db::name('dep')
  235. ->where('org_id',$this->orgId)
  236. ->where('cate_id',$dep_cate)
  237. ->where('del',0)
  238. ->column('id');
  239. if(!empty($depIds)){
  240. $map[] = ['dep_id', 'in', $depIds];
  241. }else{
  242. $map[] = ['dep_id', '=', -1];
  243. }
  244. }
  245. $order_mode = input('order_mode', '', 'trim');
  246. $map6 = [];
  247. if ($order_mode != '') {
  248. if($level1 && $turnoff && $mode != 15){ // 一级调度且二级调度开关开着,品质整改例外
  249. if ($order_mode == 1) {
  250. $map[] = ['is_deal', '=', 0];
  251. }else if ($order_mode == 4) {
  252. $map6[] = ['is_deal', '=', 1];
  253. }
  254. }
  255. if($order_mode==100){//已挂起
  256. $gq = Db::name('todo')
  257. ->where('work_type_mode',1)
  258. ->where('todo_mode',2)
  259. ->where('pause',1)
  260. ->column('order_id');
  261. if(empty($gq)){
  262. $map[] = ['id', '=', -1];
  263. }else{
  264. $map[] = ['id', 'in', $gq];
  265. }
  266. }else{
  267. $map[] = ['order_mode', '=', $order_mode];
  268. }
  269. }
  270. $b = input('start', '', 'trim');
  271. $e = input('end', '', 'trim');
  272. if ($b) {
  273. $b = date('Ymd', strtotime($b));
  274. $map[] = ['create_yyyymmdd', '>=', $b];
  275. }
  276. if ($e) {
  277. $e = date('Ymd', strtotime($e));
  278. $map[] = ['create_yyyymmdd', '<=', $e];
  279. }
  280. $map[] = ['del', '=', 0];
  281. $map[] = ['org_id', '=', $this->orgId];
  282. if($mode==-1){
  283. $map[] = ['source_type', '=', 4];
  284. }
  285. $type = input('type', '', 'trim');
  286. $oids = [];
  287. if ($type != '') {
  288. $map1[] = ['parent_id', '=', $type];
  289. $type_id = Db::name('order_type')
  290. ->where($map1)
  291. ->where('org_id', $this->orgId)
  292. ->where('enable', 1)
  293. ->column('id');
  294. if (!empty($type_id)) {
  295. $map3[] = ['type_id', 'in', $type_id];
  296. $ids = Db::name('order_repair')
  297. ->where($map3)
  298. ->column('order_id');
  299. if (!empty($ids)) {
  300. $oids = $ids;
  301. }
  302. else {
  303. $oids = [];
  304. }
  305. }
  306. else {
  307. $oids = [];
  308. }
  309. }
  310. if($level2 && $turnoff){ // 二级调度
  311. $roles_id = Db::name('user_roles')
  312. ->where('user_id', $this->userId)
  313. ->value('roles_id');
  314. $ids = Db::name('dispatch_log')
  315. ->where('roles_id', $roles_id)
  316. ->whereOr('to_user_id', $this->userId)
  317. ->column('order_id');
  318. if (empty($ids)) {
  319. $map[] = ['id', '=', -1];
  320. } else {
  321. if($type != ''){
  322. $oids = array_intersect($oids,$ids);
  323. if($oids){
  324. $map[] = ['id', 'in', $oids];
  325. }else{
  326. $map[] = ['id', '=', -1];
  327. }
  328. }else{
  329. $map[] = ['id', 'in', $ids];
  330. }
  331. }
  332. }else{
  333. if($type != ''){
  334. if($oids){
  335. $map[] = ['id', 'in', $oids];
  336. }else{
  337. $map[] = ['id', '=', 0];
  338. }
  339. }
  340. }
  341. if($mode == 15){ // 品质检查,单独处理
  342. $map[] = ['work_type_mode','=',$mode];
  343. if($quality_type!=''){
  344. $map[] = ['quality_type','=',$quality_type];
  345. }
  346. }else{
  347. $work_type_mode = input('work_type_mode','','trim');
  348. if(!is_admin($this->userId)){
  349. $auth = get_dispatch_auth($this->userId);
  350. if($auth){
  351. $map[] = ['work_type_mode', 'in', $auth];
  352. if($mode > 0){
  353. $map[] = ['work_type_mode', '=', $mode];
  354. }else{
  355. if($work_type_mode!=''){
  356. $map[] = ['work_type_mode','=',$work_type_mode];
  357. }
  358. }
  359. }else{
  360. $map[] = ['work_type_mode', '=', -1];
  361. }
  362. }else{
  363. if($mode > 0){
  364. $map[] = ['work_type_mode', '=', $mode];
  365. }else{
  366. if($work_type_mode!=''){
  367. $map[] = ['work_type_mode','=',$work_type_mode];
  368. }
  369. }
  370. }
  371. }
  372. $sn = input('sn', '', 'trim');
  373. if ($sn) {
  374. $map[] = ['sn', 'like', '%' . $sn . '%'];
  375. }
  376. $from = input('from', '', 'trim');
  377. if ($from) {
  378. if($from >3){
  379. $map[] = ['from','=',0];
  380. $map[] = ['work_type_mode','=',$from-3];
  381. }else{
  382. $map[] = ['from','=',$from];
  383. }
  384. }
  385. $mark = input('mark', '', 'trim');
  386. if ($mark != ''){
  387. $map[] = ['is_marked','=',$mark];
  388. }
  389. $map = empty($map) ? true : $map;
  390. //数据查询
  391. $lists = db($this->table)->where($map)
  392. ->whereOr($map6)
  393. ->limit($start, $length)->order($order)->select();
  394. foreach ($lists as $k => $v) {
  395. $lists[$k] = $this->model->formatOrder($v);
  396. if ($turnoff && $level1 && $v['order_mode'] == 1 && $v['is_deal'] == 1) {
  397. $lists[$k]['order_mode_text'] = '已派发';
  398. }
  399. $lists[$k]['bh_nums'] = Db::name('todo')->where('order_id',$v['id'])->where('del',0)->where('todo_mode',4)->count();
  400. $gq = Db::name('todo')
  401. ->where('order_id',$v['id'])
  402. ->where('work_type_mode',1)
  403. ->where('todo_mode',2)
  404. ->where('pause',1)
  405. ->find();
  406. $lists[$k]['gq'] = $gq?'存在挂起':'';
  407. }
  408. //数据返回
  409. $totalCount = db($this->table)->where($map)->count();
  410. $totalPage = ceil($totalCount / $length);
  411. $result['page'] = $page;
  412. $result['total'] = $totalPage;
  413. $result['records'] = $totalCount;
  414. $result['rows'] = $lists;
  415. return json($result);
  416. }
  417. else {
  418. if($mode >0){
  419. $mode_name = $this->getTableField('work_type_mode', ['id' => $mode], 'name');
  420. }else{
  421. $mode_name = '';
  422. }
  423. $auths = [1,2,3,4,15,0];
  424. if(!is_admin($this->userId)){
  425. $auth = get_dispatch_auth($this->userId);
  426. if($auth){
  427. $auths = array_intersect($auths,$auth);
  428. if($mode > 0){
  429. $auths = array_intersect($auths,[$mode]);
  430. }
  431. }else{
  432. $auths = [];
  433. }
  434. }
  435. $this->assign('auths',$auths);
  436. $dep_list = (new \app\common\model\Dep())->getList();
  437. $order_type = (new \app\common\model\OrderType())->list();
  438. $order_mode = Db::name('order_mode')
  439. ->select();
  440. $this->assign('dep_list', $dep_list);
  441. $this->assign('order_type_list', $order_type);
  442. $this->assign('m_name', $mode_name);
  443. $this->assign('mode', $mode);
  444. $this->assign('order_mode_list', $order_mode);
  445. $this->assign('dispatch_type', check_two_dispatch($this->userId));
  446. $this->assign('quality_type',$quality_type);
  447. $dep_cate = model('DepCate')->getList();
  448. $this->assign('dep_cate',$dep_cate);
  449. //抢单开关
  450. $this->assign('org_grab_order',(new \app\common\model\Config())
  451. ->getConfig('org_grab_order1',$this->orgId));
  452. $is = 0;
  453. if(!isset($_GET['quality_type']) && $mode==15){
  454. $is = 1;
  455. }
  456. $this->assign('is',$is);
  457. if ($mode == 1) {
  458. return $this->fetch('index1');
  459. }
  460. else {
  461. if ($mode == 3) {
  462. return $this->fetch('index3');
  463. }else if (in_array($mode,[0,-1])) {
  464. return $this->fetch('index0');
  465. }
  466. else {
  467. return $this->fetch('index');
  468. }
  469. }
  470. }
  471. }
  472. //调度删除订单
  473. public function del($id = 0) {
  474. if (!$id) {
  475. $this->error('参数错误');
  476. }
  477. $model = (new \app\common\model\Orders());
  478. $res = $model->del($id, $this->userId);
  479. if (!$res) {
  480. $this->error($model->getError());
  481. }
  482. $this->success('删除成功');
  483. }
  484. //调度添加订单
  485. public function dispatchAdd($mode = 1) {
  486. $id = input('id', 0);
  487. if (request()->isPost()) {
  488. $data = request()->post();
  489. $data['user_id'] = $this->userId;
  490. $data['org_id'] = $this->orgId;
  491. $data['work_type_mode'] = isset($data['work_type_mode'])?$data['work_type_mode']:$mode;
  492. $data['images'] = isset($data['images']) && !empty($data['images']) ? implode(',', $data['images']) : '';
  493. if ($id > 0) {
  494. // $phoneInfo = Db::name('phone_monitor_record')
  495. // ->where('id', $id)
  496. // ->find();
  497. $data['id'] = $id;
  498. $data['user_id'] = $this->userId;
  499. }
  500. $res = $this->model->addSave($data, 1);
  501. if ($res) {
  502. $this->success('操作成功');
  503. }
  504. else {
  505. $this->error($this->model->getError());
  506. }
  507. }
  508. else {
  509. if($mode==0){//创建一键呼叫
  510. $dep = $this->getTableField('user_dep', ['user_id' => $this->userId], 'dep_id');
  511. $depList = (new \app\common\model\Dep())->getList();
  512. $this->assign('dep_id', $dep);
  513. $this->assign('dep_list', $depList);
  514. $order_type = (new \app\common\model\OrderType())->getList();
  515. $address = (new \app\common\model\Address())->getListByType(1);
  516. $this->assign('order_type_list', $order_type);
  517. $this->assign('address_list', $address);
  518. $order_repair = Db::name('order_repair')
  519. ->where('order_id', $id)
  520. ->find();
  521. $this->assign('order_repair', $order_repair);
  522. $workType = Db::name('work_type_mode')
  523. ->where('type',1)
  524. ->select();
  525. $config = Db::name('config')
  526. ->where('name','web_order_transfer_type')
  527. ->value('value');
  528. if(empty($config)){
  529. $workType = [];
  530. }else{
  531. $ll = explode('|',$config);
  532. foreach ($workType as $kk=>$vv){
  533. if(!in_array($vv['id'],$ll)){
  534. unset($workType[$kk]);
  535. }
  536. }
  537. }
  538. if(!is_admin($this->userId)){
  539. $auth = get_dispatch_auth($this->userId);
  540. if(empty($auth)){
  541. $workType = [];
  542. }else{
  543. foreach ($workType as $kk=>$vv){
  544. if(!in_array($vv['id'],$auth)){
  545. unset($workType[$kk]);
  546. }
  547. }
  548. }
  549. }
  550. foreach ($workType as $k=>$v){
  551. $this->assign('send_user_num'.$v['id'], $this->model->sendUserNum($v['id'], $this->orgId));
  552. $this->assign('user_list'.$v['id'], (new \app\common\model\WorkTypeMode())->getRolesUserByNum($v['id'], $this->orgId, 1));
  553. $two_dispatch_roles = model('user')->get_two_dispatch_role($this->orgId, $v['id']);
  554. $this->assign('dispatch_roles'.$v['id'], $two_dispatch_roles);
  555. }
  556. $this->assign('dispatch_type', check_two_dispatch($this->userId));
  557. $this->assign('two_dispatch_off', two_dispatch_off($this->orgId));
  558. $this->assign('workType', $workType);
  559. $address = (new \app\common\model\Address())->getListByType(2);
  560. $conveyCate = (new \app\common\model\ConveyCate());
  561. $priority = $conveyCate->priority;
  562. $order_convey = $conveyCate->getList();
  563. $order_device = (new \app\common\model\ConveyDevice())->getList();
  564. $this->assign('address', $address);
  565. $this->assign('priority', $priority);
  566. $this->assign('order_convey_type', $order_convey);
  567. $this->assign('order_device', $order_device);
  568. $oCid = Db::name('order_convey')
  569. ->where('order_id',$id)
  570. ->find();
  571. $opt = Db::name('order_convey_patient')
  572. ->where('order_id',$id)
  573. ->find();
  574. $this->assign('ocid',$oCid);
  575. $this->assign('opt',$opt);
  576. $this->assign('ps',empty($opt)?1:0);
  577. $this->assign('id', $id);
  578. $this->assign('mode', $mode);
  579. return $this->fetch('yjhj_dispatch_add');
  580. }else{
  581. $dep = $this->getTableField('user_dep', ['user_id' => $this->userId], 'dep_id');
  582. $depList = (new \app\common\model\Dep())->getList();
  583. $order_type = (new \app\common\model\OrderType())->getList();
  584. $address = (new \app\common\model\Address())->getListByType(1);
  585. $this->assign('dep_id', $dep);
  586. $this->assign('dep_list', $depList);
  587. $this->assign('order_type_list', $order_type);
  588. $this->assign('mode', $mode);
  589. $this->assign('send_user_num', $this->model->sendUserNum($mode, $this->orgId));
  590. $this->assign('user_list', (new \app\common\model\WorkTypeMode())->getRolesUserByNum($mode, $this->orgId,1));
  591. $this->assign('address_list', $address);
  592. $this->assign('address_id', '');
  593. if ($mode == 3) {
  594. $address = (new \app\common\model\Address())->getListByType(2);
  595. $conveyCate = (new \app\common\model\ConveyCate());
  596. $priority = $conveyCate->priority;
  597. $order_convey = $conveyCate->getList();
  598. $order_device = (new \app\common\model\ConveyDevice())->getList();
  599. $this->assign('address', $address);
  600. $this->assign('priority', $priority);
  601. $this->assign('order_convey_type', $order_convey);
  602. $this->assign('order_device', $order_device);
  603. }
  604. if ($id > 0) {
  605. // $phoneInfo = Db::name('phone_monitor_record')
  606. // ->where('id', $id)
  607. // ->find();
  608. $this->assign('address_id', 0);
  609. // $depId = Db::name('user_dep')
  610. // ->where('user_id', $phoneInfo['user_id'])
  611. // ->value('dep_id');
  612. $this->assign('dep_id', 0);
  613. }
  614. $two_dispatch_roles = model('user')->get_two_dispatch_role($this->orgId, $mode);
  615. $this->assign('dispatch_roles', $two_dispatch_roles);
  616. $this->assign('dispatch_type', check_two_dispatch($this->userId));
  617. $this->assign('two_dispatch_off', two_dispatch_off($this->orgId));
  618. $this->assign('id', $id);
  619. if ($mode == 3) {
  620. $user = Db::name('user')
  621. ->where('id',$this->userId)
  622. ->find();
  623. $this->assign('user',$user);
  624. return $this->fetch('dispatch_add3');
  625. }
  626. else {
  627. return $this->fetch('dispatch_add');
  628. }
  629. }
  630. }
  631. }
  632. //调度查看订单详情
  633. public function detail2($id) {
  634. if (!$id) {
  635. $this->error('参数错误');
  636. }
  637. $type = input('type/d',0);
  638. $this->assign('type', $type);
  639. $order = Db::name('orders')->where(['id' => $id])->find();
  640. $order = $this->model->formatOrder($order, 1);
  641. $order['images'] = !empty($order['images']) ? explode(',', $order['images']) : '';
  642. $is_ch = 0;
  643. if($order['order_mode'] == 4){
  644. // $todoInfo = Db::name('todo')->where('order_id',$order['id'])->where('del',0)->where('todo_mode','>',1)->find();
  645. // if(!$todoInfo){
  646. // $is_ch = 1;
  647. // }
  648. $is_ch = 1;
  649. }
  650. $order['is_ch'] = $is_ch;
  651. $this->assign('info', $order);
  652. $workTypeName = $this->getTableField('work_type_mode', ['id' => $order['work_type_mode']], 'name');
  653. $this->assign('meta_title', $workTypeName . '订单详情');
  654. $level2 = check_two_dispatch($this->userId);
  655. $level1 = check_is_dispatch($this->userId);
  656. $turnoff = two_dispatch_off($this->orgId);
  657. $this->assign('level1', $level1);
  658. $this->assign('level2', $level2);
  659. $this->assign('turnoff', $turnoff);
  660. $this->assign('dispatch_type', $level2);
  661. $this->assign('org_auto_send',(new \app\common\model\Config())
  662. ->getConfig('org_auto_send',$this->orgId));
  663. return $this->fetch();
  664. }
  665. public function zg_detail($id) {
  666. if (!$id) {
  667. $this->error('参数错误');
  668. }
  669. $type = input('type/d',0);
  670. $this->assign('type', $type);
  671. $order = Db::name('orders')->where(['id' => $id])->find();
  672. $order = $this->model->formatOrder($order, 1);
  673. $order['images'] = !empty($order['images']) ? explode(',', $order['images']) : '';
  674. $this->assign('info', $order);
  675. $workTypeName = $this->getTableField('work_type_mode', ['id' => $order['work_type_mode']], 'name');
  676. $this->assign('meta_title', $workTypeName . '订单详情');
  677. $level2 = check_two_dispatch($this->userId);
  678. $level1 = check_is_dispatch($this->userId);
  679. $turnoff = two_dispatch_off($this->orgId);
  680. $this->assign('level1', $level1);
  681. $this->assign('level2', $level2);
  682. $this->assign('turnoff', $turnoff);
  683. $this->assign('dispatch_type', $level2);
  684. return $this->fetch();
  685. }
  686. public function print($id) {
  687. if (!$id) {
  688. $this->error('参数错误');
  689. }
  690. $type = input('type/d',0);
  691. $this->assign('type', $type);
  692. $order = Db::name('orders')->where(['id' => $id])->find();
  693. $order = $this->model->formatOrder($order, 1);
  694. $order['images'] = !empty($order['images']) ? explode(',', $order['images']) : '';
  695. $this->assign('info', $order);
  696. $workTypeName = $this->getTableField('work_type_mode', ['id' => $order['work_type_mode']], 'name');
  697. $this->assign('meta_title', $workTypeName . '订单详情');
  698. $level2 = check_two_dispatch($this->userId);
  699. $level1 = check_is_dispatch($this->userId);
  700. $turnoff = two_dispatch_off($this->orgId);
  701. $this->assign('level1', $level1);
  702. $this->assign('level2', $level2);
  703. $this->assign('turnoff', $turnoff);
  704. $this->assign('dispatch_type', $level2);
  705. return $this->fetch();
  706. }
  707. //派单
  708. public function send($id, $mode = 1) {
  709. if (request()->isGet()) {
  710. $this->assign('id', $id);
  711. $this->assign('mode', $mode);
  712. $orders = Db::name('orders')
  713. ->where('id',$id)
  714. ->find();
  715. if($orders['source_type']==4 && $orders['work_type_mode']==0 && $orders['is_deal']==0){//一键呼叫
  716. $order_type = (new \app\common\model\OrderType())->getList();
  717. $address = (new \app\common\model\Address())->getListByType(1);
  718. $this->assign('order_type_list', $order_type);
  719. $this->assign('address_list', $address);
  720. $order_repair = Db::name('order_repair')
  721. ->where('order_id', $id)
  722. ->find();
  723. $this->assign('order_repair', $order_repair);
  724. $workType = Db::name('work_type_mode')
  725. ->where('type',1)
  726. ->select();
  727. $config = Db::name('config')
  728. ->where('name','web_order_transfer_type')
  729. ->value('value');
  730. if(empty($config)){
  731. $workType = [];
  732. }else{
  733. $ll = explode('|',$config);
  734. foreach ($workType as $kk=>$vv){
  735. if(!in_array($vv['id'],$ll)){
  736. unset($workType[$kk]);
  737. }
  738. }
  739. }
  740. foreach ($workType as $k=>$v){
  741. $this->assign('send_user_num'.$v['id'], $this->model->sendUserNum($v['id'], $this->orgId));
  742. $this->assign('user_list'.$v['id'], (new \app\common\model\WorkTypeMode())->getRolesUserByNum($v['id'], $this->orgId, 1));
  743. $two_dispatch_roles = model('user')->get_two_dispatch_role($this->orgId, $v['id']);
  744. $this->assign('dispatch_roles'.$v['id'], $two_dispatch_roles);
  745. }
  746. $this->assign('dispatch_type', check_two_dispatch($this->userId));
  747. $this->assign('two_dispatch_off', two_dispatch_off($this->orgId));
  748. $this->assign('workType', $workType);
  749. $this->assign('orders', $orders);
  750. $address = (new \app\common\model\Address())->getListByType(2);
  751. $conveyCate = (new \app\common\model\ConveyCate());
  752. $priority = $conveyCate->priority;
  753. $order_convey = $conveyCate->getList();
  754. $order_device = (new \app\common\model\ConveyDevice())->getList();
  755. $this->assign('address', $address);
  756. $this->assign('priority', $priority);
  757. $this->assign('order_convey_type', $order_convey);
  758. $this->assign('order_device', $order_device);
  759. $oCid = Db::name('order_convey')
  760. ->where('order_id',$id)
  761. ->find();
  762. $opt = Db::name('order_convey_patient')
  763. ->where('order_id',$id)
  764. ->find();
  765. $this->assign('ocid',$oCid);
  766. $this->assign('opt',$opt);
  767. $this->assign('ps',empty($opt)?1:0);
  768. $auths = [1,2,3,4,15,0];
  769. if(!is_admin($this->userId)){
  770. $auth = get_dispatch_auth($this->userId);
  771. if($auth){
  772. $auths = array_intersect($auths,$auth);
  773. if($mode > 0){
  774. $auths = array_intersect($auths,[$mode]);
  775. }
  776. }else{
  777. $auths = [];
  778. }
  779. }
  780. $this->assign('auths',$auths);
  781. return $this->fetch('yjhj_send');
  782. }else{
  783. if ($mode == 1) {
  784. $order_type = (new \app\common\model\OrderType())->getList();
  785. $address = (new \app\common\model\Address())->getListByType(1);
  786. $this->assign('order_type_list', $order_type);
  787. $this->assign('address_list', $address);
  788. $order_repair = Db::name('order_repair')
  789. ->where('order_id', $id)
  790. ->find();
  791. $this->assign('order_repair', $order_repair);
  792. }
  793. $this->assign('send_user_num', $this->model->sendUserNum($mode, $this->orgId));
  794. $this->assign('user_list', (new \app\common\model\WorkTypeMode())->getRolesUserByNum($mode, $this->orgId, 1));
  795. $two_dispatch_roles = model('user')->get_two_dispatch_role($this->orgId, $mode);
  796. $this->assign('dispatch_roles', $two_dispatch_roles);
  797. $this->assign('dispatch_type', check_two_dispatch($this->userId));
  798. $this->assign('two_dispatch_off', two_dispatch_off($this->orgId));
  799. return $this->fetch();
  800. }
  801. }
  802. else {
  803. $data = request()->post();
  804. $data['org_id'] = $this->orgId;
  805. $res = $this->model->send($id, $this->userId, $data);
  806. if (!$res) {
  807. $this->error($this->model->getError());
  808. }
  809. $this->success('操作成功');
  810. }
  811. }
  812. //转单
  813. public function zd_send($id, $mode = 1) {
  814. if (request()->isGet()) {
  815. $this->assign('id', $id);
  816. $this->assign('mode', $mode);
  817. $orders = Db::name('orders')
  818. ->where('id',$id)
  819. ->find();
  820. if($orders['source_type']==4 && $orders['is_deal']==0){//一键呼叫
  821. $order_type = (new \app\common\model\OrderType())->getList();
  822. $address = (new \app\common\model\Address())->getListByType(1);
  823. $this->assign('order_type_list', $order_type);
  824. $this->assign('address_list', $address);
  825. $order_repair = Db::name('order_repair')
  826. ->where('order_id', $id)
  827. ->find();
  828. $this->assign('order_repair', $order_repair);
  829. $workType = Db::name('work_type_mode')
  830. ->where('type',1)
  831. ->select();
  832. $config = Db::name('config')
  833. ->where('name','web_order_transfer_type')
  834. ->value('value');
  835. if(empty($config)){
  836. $workType = [];
  837. }else{
  838. $ll = explode('|',$config);
  839. foreach ($workType as $kk=>$vv){
  840. if(!in_array($vv['id'],$ll)){
  841. unset($workType[$kk]);
  842. }
  843. }
  844. }
  845. foreach ($workType as $k=>$v){
  846. $this->assign('send_user_num'.$v['id'], $this->model->sendUserNum($v['id'], $this->orgId));
  847. $this->assign('user_list'.$v['id'], (new \app\common\model\WorkTypeMode())->getRolesUser($v['id'], $this->orgId, 1));
  848. $two_dispatch_roles = model('user')->get_two_dispatch_role($this->orgId, $v['id']);
  849. $this->assign('dispatch_roles'.$v['id'], $two_dispatch_roles);
  850. }
  851. $this->assign('dispatch_type', check_two_dispatch($this->userId));
  852. $this->assign('two_dispatch_off', two_dispatch_off($this->orgId));
  853. $this->assign('workType', $workType);
  854. $this->assign('orders', $orders);
  855. $address = (new \app\common\model\Address())->getListByType(2);
  856. $conveyCate = (new \app\common\model\ConveyCate());
  857. $priority = $conveyCate->priority;
  858. $order_convey = $conveyCate->getList();
  859. $order_device = (new \app\common\model\ConveyDevice())->getList();
  860. $this->assign('address', $address);
  861. $this->assign('priority', $priority);
  862. $this->assign('order_convey_type', $order_convey);
  863. $this->assign('order_device', $order_device);
  864. $oCid = Db::name('order_convey')
  865. ->where('order_id',$id)
  866. ->find();
  867. $opt = Db::name('order_convey_patient')
  868. ->where('order_id',$id)
  869. ->find();
  870. $this->assign('ocid',$oCid);
  871. $this->assign('opt',$opt);
  872. $this->assign('ps',empty($opt)?1:0);
  873. $auths = [1,2,3,4,15,0];
  874. if(!is_admin($this->userId)){
  875. $auth = get_dispatch_auth($this->userId);
  876. if($auth){
  877. $auths = array_intersect($auths,$auth);
  878. if($mode > 0){
  879. $auths = array_intersect($auths,[$mode]);
  880. }
  881. }else{
  882. $auths = [];
  883. }
  884. }
  885. $this->assign('auths',$auths);
  886. return $this->fetch('yjhj_zd_send');
  887. }
  888. }
  889. else {
  890. $data = request()->post();
  891. $data['org_id'] = $this->orgId;
  892. $res = $this->model->zd_send($id, $data);
  893. if (!$res) {
  894. $this->error($this->model->getError());
  895. }
  896. $this->success('操作成功');
  897. }
  898. }
  899. //批量派单
  900. public function batchsend($id, $mode = 1) {
  901. if (request()->isGet()) {
  902. $this->assign('id', $id);
  903. $this->assign('mode', $mode);
  904. if ($mode == 1) {
  905. $order_type = (new \app\common\model\OrderType())->getList();
  906. $address = (new \app\common\model\Address())->getListByType(1);
  907. $this->assign('order_type_list', $order_type);
  908. $this->assign('address_list', $address);
  909. $order_repair = Db::name('order_repair')
  910. ->where('order_id', $id)
  911. ->find();
  912. $this->assign('order_repair', $order_repair);
  913. }
  914. $user = (new \app\common\model\WorkTypeMode())->getRolesUser($mode, $this->orgId, 1);
  915. $newUser = [];
  916. foreach ($user as $k => $v) {
  917. foreach ($v['user'] as $k1 => $v1) {
  918. $newUser[] = $v1;
  919. }
  920. }
  921. foreach ($newUser as $key => $value) {
  922. $nums = Db::name('todo')
  923. ->where(['to_user_id' => $value['id'], 'work_type_mode' => 3])
  924. ->where('create_yyyymmdd', date('ymd'))
  925. ->where('todo_mode', 'in', [1, 2, 3])
  926. ->count();
  927. $newUser[$key]['nums'] = $nums;
  928. $addr = Db::name('convey_plan_record')
  929. ->alias('cpr')
  930. ->join('address ca', 'ca.id = cpr.addr_id')
  931. ->field('ca.title,cpr.create_time')
  932. ->where('cpr.user_id', $value['id'])
  933. ->order('cpr.id desc')
  934. ->find();
  935. $newUser[$key]['title'] = $addr ? $addr['title'] : '';
  936. $newUser[$key]['addr_time'] = $addr ? $addr['create_time'] : '';
  937. }
  938. $this->assign('user_list', $newUser);
  939. return $this->fetch();
  940. }
  941. else {
  942. $data = request()->post();
  943. $data['org_id'] = $this->orgId;
  944. if (empty($data['to_user_id'])) {
  945. $this->error('请选择执行人');
  946. }
  947. $data['to_user_id'] = implode(',', $data['to_user_id']);
  948. $res = $this->model->batchsend($id, $this->userId, $data);
  949. if (!$res) {
  950. $this->error($this->model->getError());
  951. }
  952. $this->success('操作成功');
  953. }
  954. }
  955. //完成订单
  956. public function finish($id) {
  957. $res = $this->model->finish($id);
  958. if (!$res) {
  959. $this->error($this->model->getError());
  960. }
  961. $this->success('操作成功');
  962. }
  963. //批量完成订单
  964. public function batchfinish($id) {
  965. $res = $this->model->batchfinish($id);
  966. if (!$res) {
  967. $this->error($this->model->getError());
  968. }
  969. $this->success('操作成功');
  970. }
  971. //评价
  972. public function comment() {
  973. $id = input('id');
  974. $score = input('score');
  975. $content = input('content');
  976. if ($score <= 0 || $score > 5) {
  977. $this->error('参数错误');
  978. }
  979. $res = $this->model->addComment($id, $score, $content, $this->userId, $this->orgId);
  980. if (!$res) {
  981. $this->error($this->model->getError());
  982. }
  983. $this->success('操作成功');
  984. }
  985. public function phone() {
  986. $phone = input('phone','','trim');
  987. $fp = input('fp','','trim');
  988. $id = input('id/d',0,'trim');
  989. if($phone){
  990. $fp = $fp?base64_decode($fp):'';
  991. $md5 = md5($this->orgId.'|'.$fp);
  992. $ret = Db::name('phone_monitor_record')->where('md5',$md5)->find();
  993. if(!$ret){
  994. $id = Db::name('phone_monitor_record')->insertGetId([
  995. 'org_id' => $this->orgId,
  996. 'phone' => $phone,
  997. 'path' => $fp,
  998. 'md5' => $md5,
  999. 'create_time' => date('Y-m-d H:i:s')
  1000. ]);
  1001. }else{
  1002. $id = $ret['id'];
  1003. }
  1004. }
  1005. $worktype = [
  1006. ['id' => 1, 'title' => '报修'],
  1007. ['id' => 2, 'title' => '保洁'],
  1008. ['id' => 3, 'title' => '运送'],
  1009. ['id' => 4, 'title' => '安保'],
  1010. ];
  1011. $info = Db::name('phone_monitor_record')->where('id',$id)->find();
  1012. if(!$info){
  1013. halt('数据存储失败');
  1014. }
  1015. $this->assign('worktype', $worktype);
  1016. $this->assign('info', $info);
  1017. $this->assign('id', $id);
  1018. return $this->fetch();
  1019. }
  1020. public function phoneAdd() {
  1021. $id = input('id');
  1022. $worktype = [
  1023. ['id' => 1, 'title' => '报修'],
  1024. ['id' => 2, 'title' => '保洁'],
  1025. ['id' => 3, 'title' => '运送'],
  1026. ['id' => 4, 'title' => '安保'],
  1027. ];
  1028. $info = Db::name('phone_monitor')
  1029. ->where('id', $id)->find();
  1030. if (!$info) {
  1031. echo '负责人不存在', exit();
  1032. }
  1033. $info['real_name'] = Db::name('user')
  1034. ->where('id', $info['user_id'])
  1035. ->value('real_name');
  1036. $info['dep'] = Db::name('user_dep')
  1037. ->alias('a')
  1038. ->join('dep b', 'a.dep_id=b.id')
  1039. ->where('a.user_id', $info['user_id'])
  1040. ->value('b.title');
  1041. $this->assign('worktype', $worktype);
  1042. $this->assign('info', $info);
  1043. $this->assign('id', $id);
  1044. return $this->fetch();
  1045. }
  1046. //运送调度订单列表
  1047. public function convey() {
  1048. $mode = input('mode', 1);
  1049. if (request()->isAjax()) {
  1050. //分页参数
  1051. $length = input('rows', 10, 'intval'); //每页条数
  1052. $page = input('page', 1, 'intval'); //第几页
  1053. $start = ($page - 1) * $length; //分页开始位置
  1054. //排序
  1055. $sortRow = input('sidx', 'id', 'trim'); //排序列
  1056. $sort = input('sord', 'desc', 'trim'); //排序方式
  1057. $order = $sortRow . ' ' . $sort;
  1058. $content = input('content', '', 'trim');
  1059. if ($content) {
  1060. $map[] = ['o.content', 'like', '%' . $content . '%'];
  1061. }
  1062. $dep_id = input('dep_id', '', 'trim');
  1063. if ($dep_id != '') {
  1064. $map[] = ['o.dep_id', '=', $dep_id];
  1065. }
  1066. $priority = input('priority', '', 'trim');
  1067. if ($priority) {
  1068. $map[] = ['oc.priority', '=', $priority];
  1069. }
  1070. $s = input('start', '', 'trim');
  1071. $end = input('end', '', 'trim');
  1072. if ($s) {
  1073. $map[] = ['oc.start', '=', $start];
  1074. }
  1075. if ($end) {
  1076. $map[] = ['oc.end', '=', $end];
  1077. }
  1078. $type = input('type', '', 'trim');
  1079. if ($type) {
  1080. $map[] = ['oc.type', '=', $type];
  1081. }
  1082. $xqtime = input('xqtime', '', 'trim');
  1083. $ywctime = input('ywctime', '', 'trim');
  1084. if ($xqtime) {
  1085. $xqtimes = explode(' - ', $xqtime);
  1086. $x1 = date('Ymd', strtotime($xqtimes[0]));
  1087. $x2 = date('Ymd', strtotime($xqtimes[1]));
  1088. $map[] = ['oc.xq_time', '>=', $x1];
  1089. $map[] = ['oc.xq_time', '<=', $x2];
  1090. }
  1091. if ($ywctime) {
  1092. $ywctimes = explode(' - ', $ywctime);
  1093. $y1 = date('Ymd', strtotime($ywctimes[0]));
  1094. $y2 = date('Ymd', strtotime($ywctimes[1]));
  1095. $map[] = ['oc.ywc_time', '>=', $y1];
  1096. $map[] = ['oc.ywc_time', '<=', $y2];
  1097. }
  1098. $map[] = ['o.del', '=', 0];
  1099. $map[] = ['o.org_id', '=', $this->orgId];
  1100. $map[] = ['o.work_type_mode', '=', 3];
  1101. $map[] = ['o.order_mode', 'in', [1, 4]];
  1102. $status = input('status', '', 'trim');
  1103. $ysName = input('ysname', '');
  1104. if ($ysName) {
  1105. $orders = Db::name('todo')
  1106. ->alias('t')
  1107. ->where('t.org_id', $this->orgId)
  1108. ->where('t.del', 0)
  1109. ->where('t.work_type_mode', 3)
  1110. ->where('t.todo_mode', [1, 2, 4])
  1111. ->where('u.real_name', 'like', '%' . $ysName . '%')
  1112. ->join('orders o', 'o.id = t.order_id')
  1113. ->join('user u', 't.to_user_id = u.id')
  1114. ->group('o.id')
  1115. ->column('o.id');
  1116. if ($orders) {
  1117. $map[] = ['o.id', 'in', $orders];
  1118. }
  1119. else {
  1120. $map[] = ['o.id', '=', 0];
  1121. }
  1122. }
  1123. $map = empty($map) ? true : $map;
  1124. //数据查询
  1125. $lists = db($this->table)->alias('o')
  1126. ->join('order_convey oc', 'oc.order_id=o.id')
  1127. ->field('o.*,oc.type,oc.start,oc.end,oc.xq_time,oc.ywc_time,oc.device_id,oc.name,oc.phone,oc.priority')
  1128. ->where($map)
  1129. ->order(['o.order_mode' => 'asc', 'oc.xq_time' => 'desc'])
  1130. ->select();
  1131. $newret = [];
  1132. foreach ($lists as $k => $v) {
  1133. $v = $this->model->formatOrder($v);
  1134. $todo = Db::name('todo')
  1135. ->alias('t')
  1136. ->where('t.order_id', $v['id'])
  1137. ->join('user u', 'u.id = t.to_user_id')
  1138. ->where('t.todo_mode', 'in', [1, 2, 3, 4])
  1139. ->where('t.del', 0)
  1140. ->field('u.real_name,t.create_time,t.confirm_time')
  1141. ->order('t.id asc')
  1142. ->select();
  1143. $users = [];
  1144. $confirmtime = '';
  1145. foreach ($todo as $kk => $vv) {
  1146. $users[] = $vv['real_name'];
  1147. if (!$confirmtime && $vv['confirm_time']) {
  1148. $confirmtime = $vv['confirm_time'];
  1149. }
  1150. else {
  1151. if ($confirmtime && $vv['confirm_time'] && $vv['confirm_time'] < $confirmtime) {
  1152. $confirmtime = $vv['confirm_time'];
  1153. }
  1154. }
  1155. }
  1156. $v['real_names'] = implode(',', $users);
  1157. $v['confirm_time'] = $confirmtime;
  1158. $last = strtotime($v['ywc_time']) - time();
  1159. $v['last_time'] = $last > 0 ? round($last / 60) : 0;
  1160. //是否有延时
  1161. $v['delay'] = 0; // 0=未延迟 1=延迟
  1162. $v['delay_diff'] = 0;
  1163. $v['delay_reason'] = '';
  1164. $delays = Db::name('order_delay')
  1165. ->where('order_id', $v['id'])
  1166. ->select();
  1167. $delays = $delays ? $delays : [];
  1168. foreach ($delays as $vv) {
  1169. if ($vv['status'] == 0) {
  1170. $v['delay'] = 1;
  1171. $v['delay_reason'] = $this->gettablefield('delay_reason', ['id' => $vv['delay_reason_id']], 'title');
  1172. $vv['diff'] = time() - strtotime($vv['start_time']);
  1173. }
  1174. $v['delay_diff'] += $vv['diff'];
  1175. }
  1176. $v['delay_diff'] = round($v['delay_diff'] / 60);
  1177. if ($v['delay'] == 1) {
  1178. $v['status'] = 3;
  1179. } else {
  1180. if ($v['order_mode'] == 1) {
  1181. $v['status'] = 1;
  1182. } else {
  1183. $v['status'] = 2;
  1184. }
  1185. }
  1186. $convey = Db::name('convey_cate')
  1187. ->alias('oc')
  1188. ->join('time ot', 'ot.id = oc.time_id')
  1189. ->where('oc.id', $v['type'])
  1190. ->field('ot.*')
  1191. ->find();
  1192. $createtime = strtotime($v['create_time']);
  1193. $curtime = time();
  1194. $ct = round(($curtime - $createtime) / 60);
  1195. if ($ct < $convey['yy_time']) {
  1196. $ss = 0;
  1197. }
  1198. else {
  1199. if ($ct >= $convey['yy_time'] && $ct < $convey['bz_time']) {
  1200. $ss = 1;
  1201. }
  1202. else {
  1203. if ($ct >= $convey['bz_time'] && $ct < $convey['jg_time']) {
  1204. $ss = 2;
  1205. }
  1206. else {
  1207. if ($ct >= $convey['jg_time'] && $ct < $convey['wjjg_time']) {
  1208. $ss = 3;
  1209. }
  1210. else {
  1211. $ss = 4;
  1212. }
  1213. }
  1214. }
  1215. }
  1216. $v['ss'] = $ss;
  1217. $v['xtime'] = date('H:i', strtotime($v['xq_time']));
  1218. $v['stime'] = $v['send_time'] ? date('H:i', strtotime($v['send_time'])) : "";
  1219. $v['ctime'] = $v['confirm_time'] ? date('H:i', strtotime($v['confirm_time'])) : "";
  1220. $v['priorityName'] = isset($this->model->priority[$v['priority']])?$this->model->priority[$v['priority']]:'';
  1221. if ($status == 3 && $v['delay'] == 1) { //延时任务
  1222. $newret[] = $v;
  1223. }
  1224. if ($status == 1 && $v['order_mode'] == 1) { //新任务
  1225. $newret[] = $v;
  1226. }
  1227. if ($status == 2 && $v['order_mode'] == 4) { // 进行中
  1228. $newret[] = $v;
  1229. }
  1230. if (!$status || !in_array($status, [1, 2, 3])) {
  1231. $newret[] = $v;
  1232. }
  1233. $lists[$k] = $v;
  1234. }
  1235. if(!empty($newret)){
  1236. $newret = arraySequence($newret,'status');//返回数组中指定的一列
  1237. }
  1238. //数据返回
  1239. $totalCount = count($lists);
  1240. $totalPage = ceil($totalCount / $length);
  1241. $result['page'] = $page;
  1242. $result['total'] = $totalPage;
  1243. $result['records'] = $totalCount;
  1244. $result['rows'] = $newret;
  1245. return json($result);
  1246. }
  1247. else {
  1248. $mode_name = $this->getTableField('work_type_mode', ['id' => $mode], 'name');
  1249. $order_type = (new \app\common\model\ConveyCate())->getList();
  1250. $order_mode = Db::name('order_mode')
  1251. ->select();
  1252. $this->assign('order_type_list', $order_type);
  1253. $this->assign('m_name', $mode_name);
  1254. $this->assign('mode', $mode);
  1255. $this->assign('order_mode_list', $order_mode);
  1256. $this->assign('dispatch_type', check_two_dispatch($this->userId));
  1257. $address = (new \app\common\model\Address())->getListByType(2);
  1258. $this->assign('address', $address);
  1259. $count = Db::name('todo')
  1260. ->where('org_id', $this->orgId)
  1261. ->where('del', 0)
  1262. ->where('work_type_mode', 3)
  1263. ->where('todo_mode', 4)
  1264. ->count();
  1265. $this->assign('count', $count);
  1266. $info = Db::name('config')->where('name','org_order_refresh')
  1267. ->find();
  1268. $orgConfig = Db::name('config_org')
  1269. ->where('config_id',$info['id'])
  1270. ->where('org_id',$this->orgId)
  1271. ->find();
  1272. $value = $orgConfig?$orgConfig['value']:0;
  1273. $this->assign('refresh',$value);
  1274. return $this->fetch();
  1275. }
  1276. }
  1277. //运送员状态
  1278. public function conveystatus($id='') {
  1279. if (request()->isAjax()) {
  1280. //分页参数
  1281. $length = input('rows', 10, 'intval'); //每页条数
  1282. $page = input('page', 1, 'intval'); //第几页
  1283. $start = ($page - 1) * $length; //分页开始位置
  1284. //排序
  1285. $sortRow = input('sidx', 'id', 'trim'); //排序列
  1286. $sort = input('sord', 'desc', 'trim'); //排序方式
  1287. $order = $sortRow . ' ' . $sort;
  1288. $real_name = input('real_name', '');
  1289. $map8 = [];
  1290. if ($real_name) {
  1291. $map8[] = ['real_name', 'like', '%'.$real_name.'%'];
  1292. }
  1293. $user = (new \app\common\model\WorkTypeMode())->getRolesUser(3, $this->orgId);
  1294. $newUser = [];
  1295. foreach ($user as $k => $v) {
  1296. foreach ($v['user'] as $k1 => $v1) {
  1297. $newUser[] = $v1['id'];
  1298. }
  1299. }
  1300. $userIds1 = [];
  1301. if($id){
  1302. $ids = explode(',', $id);
  1303. $map[] = ['order_id', 'in', $ids];
  1304. $map[] = ['del', '=', 0];
  1305. $map[] = ['org_id', '=', $this->orgId];
  1306. $map[] = ['work_type_mode', '=', 3];
  1307. $userIds = Db::name('todo')->where($map)->column('to_user_id');
  1308. $userIds1 = $userIds?$userIds:[];
  1309. $newUser = array_intersect($userIds1,$newUser);
  1310. }
  1311. if(empty($newUser)){
  1312. $map8[] = ['id','=',0];
  1313. }else{
  1314. $map8[] = ['id','in',$newUser];
  1315. }
  1316. $lists = db('user')
  1317. ->where($map8)->limit($start, $length)
  1318. ->order($order)->select();
  1319. foreach ($lists as $key => $value) {
  1320. $nums = Db::name('todo')
  1321. ->where(['to_user_id' => $value['id'], 'work_type_mode' => 3])
  1322. ->where('create_yyyymmdd', date('ymd'))
  1323. ->where('todo_mode', 'in', [1, 2, 3])
  1324. ->count();
  1325. $lists[$key]['nums'] = $nums;
  1326. $addr = Db::name('convey_plan_record')
  1327. ->alias('cpr')
  1328. ->join('address ca', 'ca.id = cpr.addr_id')
  1329. ->field('ca.title,cpr.create_time')
  1330. ->where('cpr.user_id', $value['id'])
  1331. ->order('cpr.id desc')
  1332. ->find();
  1333. $lists[$key]['title'] = $addr ? $addr['title'] : '';
  1334. $lists[$key]['addr_time'] = $addr ? $addr['create_time'] : '';
  1335. $lists[$key]['worktxt'] = $value['work'] == 1 ? '上班' : '下班';
  1336. $lists[$key]['stationtxt'] = $value['station'] == 1 ? '驻守' : '取消驻守';
  1337. }
  1338. //数据返回
  1339. // $totalCount = db('user')
  1340. // ->where($map1)->count();
  1341. $totalCount = db('user')
  1342. ->where($map8)->count();
  1343. $totalPage = ceil($totalCount / $length);
  1344. $result['page'] = $page;
  1345. $result['total'] = $totalPage;
  1346. $result['records'] = $totalCount;
  1347. $result['rows'] = $lists;
  1348. return json($result);
  1349. }
  1350. else {
  1351. $this->assign('id', $id);
  1352. return $this->fetch();
  1353. }
  1354. }
  1355. //上下班
  1356. public function work($id) {
  1357. $user = Db::name('user')
  1358. ->where('id', $id)
  1359. ->find();
  1360. $value = $user['work'] == 1 ? 0 : 1;
  1361. $res = Db::name('user')
  1362. ->where('id', $id)
  1363. ->update(['work' => $value, 'update_time' => getTime()]);
  1364. $res ? $this->success('操作成功') : $this->error('操作失败');
  1365. }
  1366. //驻守
  1367. public function station($id) {
  1368. $user = Db::name('user')
  1369. ->where('id', $id)
  1370. ->find();
  1371. $value = $user['station'] == 1 ? 0 : 1;
  1372. $res = Db::name('user')
  1373. ->where('id', $id)
  1374. ->update(['station' => $value, 'update_time' => getTime()]);
  1375. $res ? $this->success('操作成功') : $this->error('操作失败');
  1376. }
  1377. //驳回工单列表
  1378. public function bhTodoList() {
  1379. if (request()->isAjax()) {
  1380. $length = input('rows', 10, 'intval'); //每页条数
  1381. $page = input('page', 1, 'intval'); //第几页
  1382. $start = ($page - 1) * $length; //分页开始位置
  1383. $map[] = ['todo.org_id', '=', $this->orgId];
  1384. $map[] = ['todo.del', '=', 0];
  1385. $map[] = ['todo.todo_mode', '=', 4];
  1386. $map[] = ['todo.work_type_mode', '=', 3];
  1387. $totalCount = Db::name('todo')
  1388. ->alias('todo')
  1389. ->join('orders orders', 'orders.id = todo.order_id')
  1390. ->join('order_convey oc', 'oc.order_id = orders.id')
  1391. ->join('user u', 'u.id = todo.to_user_id')
  1392. ->where($map)
  1393. ->count();
  1394. $totalPage = ceil($totalCount / $length);
  1395. $ret = Db::name('todo')
  1396. ->alias('todo')
  1397. ->join('orders orders', 'orders.id = todo.order_id')
  1398. ->join('order_convey oc', 'oc.order_id = orders.id')
  1399. ->join('user u', 'u.id = todo.to_user_id')
  1400. ->field('orders.*,u.real_name as to_real_name,oc.type,oc.start,oc.end,oc.xq_time,oc.ywc_time,oc.device_id,oc.name,oc.phone,oc.priority,todo.nodo_reason,todo.id,todo.reject_time')
  1401. ->order('oc.xq_time', 'desc')
  1402. ->where($map)
  1403. ->limit($start, $length)
  1404. ->select();
  1405. foreach ($ret as $k => $v) {
  1406. $ret[$k]['start_name'] = $this->gettablefield('address', array('id' => $v['start']), 'title');
  1407. $ret[$k]['end_name'] = $this->gettablefield('address', array('id' => $v['end']), 'title');
  1408. $ret[$k]['type_name'] = $this->gettablefield('convey_cate', array('id' => $v['type']), 'title');
  1409. $ret[$k]['real_name'] = $this->gettablefield('user', array('id' => $v['user_id']), 'real_name');
  1410. $ret[$k]['device_name'] = '';
  1411. if ($v['device_id'] > 0) {
  1412. $ret[$k]['device_name'] = $this->gettablefield('convey_device', array('id' => $v['device_id']), 'title');
  1413. }
  1414. $last = strtotime($v['ywc_time']) - time();
  1415. $ret[$k]['last_time'] = $last > 0 ? round($last / 60) : 0;
  1416. $ret[$k]['reject_time'] = $v['reject_time'] ? date('Y-m-d h:i', strtotime($v['reject_time'])) : '';
  1417. }
  1418. $result['page'] = $page;
  1419. $result['total'] = $totalPage;
  1420. $result['records'] = $totalCount;
  1421. $result['rows'] = $ret;
  1422. return json($result);
  1423. }
  1424. else {
  1425. return $this->fetch();
  1426. }
  1427. }
  1428. //excel导出
  1429. public function export($mode) {
  1430. set_time_limit(0);
  1431. ini_set("memory_limit", "1024M");
  1432. $meta_title = '订单列表';
  1433. if ($mode == 1) {
  1434. $meta_title = '报修' . $meta_title;
  1435. }
  1436. elseif ($mode == 2) {
  1437. $meta_title = '保洁' . $meta_title;
  1438. }
  1439. elseif ($mode == 3) {
  1440. $meta_title = '运送' . $meta_title;
  1441. }
  1442. elseif ($mode == 4) {
  1443. $meta_title = '安保' . $meta_title;
  1444. }
  1445. elseif ($mode == 15) {
  1446. $meta_title = '品质整改' . $meta_title;
  1447. }elseif ($mode == -1) {
  1448. $meta_title = '一键呼叫' . $meta_title;
  1449. }
  1450. $level1 = check_is_dispatch($this->userId);
  1451. $level2 = check_two_dispatch($this->userId);
  1452. $turnoff = two_dispatch_off($this->orgId);
  1453. $quality_type = input('quality_type','');
  1454. if (request()->isGet()) {
  1455. //排序
  1456. $sortRow = input('sidx', 'id', 'trim'); //排序列
  1457. $sort = input('sord', 'desc', 'trim'); //排序方式
  1458. $order = $sortRow . ' ' . $sort;
  1459. $content = input('content', '', 'trim');
  1460. if ($content) {
  1461. $map[] = ['content', 'like', '%' . $content . '%'];
  1462. }
  1463. $dep_id = input('dep_id', '', 'trim');
  1464. if ($dep_id != '') {
  1465. $map[] = ['dep_id', '=', $dep_id];
  1466. }
  1467. $order_mode = input('order_mode', '', 'trim');
  1468. $map6 = [];
  1469. if ($order_mode != '') {
  1470. if($level1 && $turnoff && $mode != 15){ // 一级调度且二级调度开关开着,品质整改例外
  1471. if ($order_mode == 1) {
  1472. $map[] = ['is_deal', '=', 0];
  1473. }else if ($order_mode == 4) {
  1474. $map6[] = ['is_deal', '=', 1];
  1475. }
  1476. }
  1477. if($order_mode==100){//已挂起
  1478. $gq = Db::name('todo')
  1479. ->where('work_type_mode',1)
  1480. ->where('todo_mode',2)
  1481. ->where('pause',1)
  1482. ->column('order_id');
  1483. if(empty($gq)){
  1484. $map[] = ['id', '=', -1];
  1485. }else{
  1486. $map[] = ['id', 'in', $gq];
  1487. }
  1488. }else{
  1489. $map[] = ['order_mode', '=', $order_mode];
  1490. }
  1491. }
  1492. $b = input('start', '', 'trim');
  1493. $e = input('end', '', 'trim');
  1494. if ($b) {
  1495. $b = date('Ymd', strtotime($b));
  1496. $map[] = ['create_yyyymmdd', '>=', $b];
  1497. }
  1498. if ($e) {
  1499. $e = date('Ymd', strtotime($e));
  1500. $map[] = ['create_yyyymmdd', '<=', $e];
  1501. }
  1502. $map[] = ['del', '=', 0];
  1503. $map[] = ['org_id', '=', $this->orgId];
  1504. if($mode==-1){
  1505. $map[] = ['source_type', '=', 4];
  1506. }
  1507. $type = input('type', '', 'trim');
  1508. $oids = [];
  1509. if ($type != '') {
  1510. $map1[] = ['parent_id', '=', $type];
  1511. $type_id = Db::name('order_type')
  1512. ->where($map1)
  1513. ->where('org_id', $this->orgId)
  1514. ->where('enable', 1)
  1515. ->column('id');
  1516. if (!empty($type_id)) {
  1517. $map3[] = ['type_id', 'in', $type_id];
  1518. $ids = Db::name('order_repair')
  1519. ->where($map3)
  1520. ->column('order_id');
  1521. if (!empty($ids)) {
  1522. $oids = $ids;
  1523. }
  1524. else {
  1525. $oids = [];
  1526. }
  1527. }
  1528. else {
  1529. $oids = [];
  1530. }
  1531. }
  1532. if($level2 && $turnoff){ // 二级调度
  1533. $roles_id = Db::name('user_roles')
  1534. ->where('user_id', $this->userId)
  1535. ->value('roles_id');
  1536. $ids = Db::name('dispatch_log')
  1537. ->where('roles_id', $roles_id)
  1538. ->whereOr('to_user_id', $this->userId)
  1539. ->column('order_id');
  1540. if (empty($ids)) {
  1541. $map[] = ['id', '=', -1];
  1542. } else {
  1543. if($type != ''){
  1544. $oids = array_intersect($oids,$ids);
  1545. if($oids){
  1546. $map[] = ['id', 'in', $oids];
  1547. }else{
  1548. $map[] = ['id', '=', -1];
  1549. }
  1550. }else{
  1551. $map[] = ['id', 'in', $ids];
  1552. }
  1553. }
  1554. }else{
  1555. if($type != ''){
  1556. if($oids){
  1557. $map[] = ['id', 'in', $oids];
  1558. }else{
  1559. $map[] = ['id', '=', 0];
  1560. }
  1561. }
  1562. }
  1563. if($mode == 15){ // 品质检查,单独处理
  1564. $map[] = ['work_type_mode','=',$mode];
  1565. if($quality_type !=''){
  1566. $map[] = ['quality_type','=',$quality_type];
  1567. }
  1568. }else{
  1569. $work_type_mode = input('work_type_mode','','trim');
  1570. if(!is_admin($this->userId)){
  1571. $auth = get_dispatch_auth($this->userId);
  1572. if($auth){
  1573. $map[] = ['work_type_mode', 'in', $auth];
  1574. if($mode > 0){
  1575. $map[] = ['work_type_mode', '=', $mode];
  1576. }else{
  1577. if($work_type_mode!=''){
  1578. $map[] = ['work_type_mode','=',$work_type_mode];
  1579. }
  1580. }
  1581. }else{
  1582. $map[] = ['work_type_mode', '=', -1];
  1583. }
  1584. }else{
  1585. if($mode > 0){
  1586. $map[] = ['work_type_mode', '=', $mode];
  1587. }else{
  1588. if($work_type_mode!=''){
  1589. $map[] = ['work_type_mode','=',$work_type_mode];
  1590. }
  1591. }
  1592. }
  1593. }
  1594. $sn = input('sn', '', 'trim');
  1595. if ($sn) {
  1596. $map[] = ['sn', 'like', '%' . $sn . '%'];
  1597. }
  1598. $from = input('from', '', 'trim');
  1599. if ($from) {
  1600. if($from >3){
  1601. $map[] = ['from','=',0];
  1602. $map[] = ['work_type_mode','=',$from-3];
  1603. }else{
  1604. $map[] = ['from','=',$from];
  1605. }
  1606. }
  1607. $dep_cate = input('dep_cate', '', 'trim');
  1608. if ($dep_cate != '') {
  1609. $depIds = Db::name('dep')
  1610. ->where('org_id',$this->orgId)
  1611. ->where('cate_id',$dep_cate)
  1612. ->where('del',0)
  1613. ->column('id');
  1614. if(!empty($depIds)){
  1615. $map[] = ['dep_id', 'in', $depIds];
  1616. }else{
  1617. $map[] = ['dep_id', '=', -1];
  1618. }
  1619. }
  1620. $map = empty($map) ? true : $map;
  1621. //数据查询
  1622. $lists = db($this->table)->where($map)
  1623. ->whereOr($map6)
  1624. ->order($order)->select();
  1625. foreach ($lists as $k => $v) {
  1626. $lists[$k] = $this->model->newFormatOrder($v);
  1627. if ($turnoff && $level1 && $v['order_mode'] == 1 && $v['is_deal'] == 1) {
  1628. $lists[$k]['order_mode_text'] = '已派发';
  1629. }
  1630. $content = removeEmojiChar($v['content']);
  1631. $lists[$k]['content'] = preg_replace('/[^\p{L}\p{N}\p{P}\p{Z}^\n]/u', '', $content);
  1632. }
  1633. include_once env('root_path') . '/extend/phpexcel/Classes/PHPExcel.php';
  1634. //实例化PHPExcel类
  1635. $objPHPExcel = new \PHPExcel();
  1636. //激活当前的sheet表
  1637. $objPHPExcel->setActiveSheetIndex(0);
  1638. //设置表格头(即excel表格的第一行)
  1639. if ($mode == 1) {
  1640. $objPHPExcel->setActiveSheetIndex(0)
  1641. ->setCellValue('A1', '编号')
  1642. ->setCellValue('B1', '申请时间')
  1643. ->setCellValue('C1', '内容')
  1644. ->setCellValue('D1', '所在科室/部门')
  1645. ->setCellValue('E1', '报修类型')
  1646. ->setCellValue('F1', '状态')
  1647. ->setCellValue('G1', '紧急程度')
  1648. ->setCellValue('H1', '来源')
  1649. ->setCellValue('I1', '部门分类');
  1650. }
  1651. else {
  1652. if ($mode == 3) {
  1653. $objPHPExcel->setActiveSheetIndex(0)
  1654. ->setCellValue('A1', '编号')
  1655. ->setCellValue('B1', '申请时间')
  1656. ->setCellValue('C1', '始发大厅')
  1657. ->setCellValue('D1', '内容')
  1658. ->setCellValue('E1', '所在科室/部门')
  1659. ->setCellValue('F1', '状态')
  1660. ->setCellValue('G1', '来源')
  1661. ->setCellValue('H1', '部门分类');
  1662. }
  1663. else {
  1664. if($mode==0){
  1665. $objPHPExcel->setActiveSheetIndex(0)
  1666. ->setCellValue('A1', '编号')
  1667. ->setCellValue('B1', '申请时间')
  1668. ->setCellValue('C1', '内容')
  1669. ->setCellValue('D1', '所在科室/部门')
  1670. ->setCellValue('E1', '状态')
  1671. ->setCellValue('F1', '订单类型')
  1672. ->setCellValue('G1', '来源')
  1673. ->setCellValue('H1', '部门分类');
  1674. }else{
  1675. if($mode==15){
  1676. $objPHPExcel->setActiveSheetIndex(0)
  1677. ->setCellValue('A1', '编号')
  1678. ->setCellValue('B1', '申请时间')
  1679. ->setCellValue('C1', '内容')
  1680. ->setCellValue('D1', '所在科室/部门')
  1681. ->setCellValue('E1', '状态')
  1682. ->setCellValue('F1', '来源')
  1683. ->setCellValue('G1', '部门分类')
  1684. ->setCellValue('H1', '整改分类');
  1685. }else{
  1686. $objPHPExcel->setActiveSheetIndex(0)
  1687. ->setCellValue('A1', '编号')
  1688. ->setCellValue('B1', '申请时间')
  1689. ->setCellValue('C1', '内容')
  1690. ->setCellValue('D1', '所在科室/部门')
  1691. ->setCellValue('E1', '状态')
  1692. ->setCellValue('F1', '来源')
  1693. ->setCellValue('G1', '部门分类');
  1694. }
  1695. }
  1696. }
  1697. }
  1698. // 设置表格头水平居中
  1699. $objPHPExcel->setActiveSheetIndex(0)->getStyle('A1')->getAlignment()
  1700. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1701. $objPHPExcel->setActiveSheetIndex(0)->getStyle('B1')->getAlignment()
  1702. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1703. $objPHPExcel->setActiveSheetIndex(0)->getStyle('C1')->getAlignment()
  1704. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1705. $objPHPExcel->setActiveSheetIndex(0)->getStyle('D1')->getAlignment()
  1706. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1707. $objPHPExcel->setActiveSheetIndex(0)->getStyle('E1')->getAlignment()
  1708. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1709. $objPHPExcel->setActiveSheetIndex(0)->getStyle('F1')->getAlignment()
  1710. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1711. $objPHPExcel->setActiveSheetIndex(0)->getStyle('G1')->getAlignment()
  1712. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1713. $objPHPExcel->setActiveSheetIndex(0)->getStyle('H1')->getAlignment()
  1714. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1715. //设置列水平居中
  1716. $objPHPExcel->setActiveSheetIndex(0)->getStyle('A')->getAlignment()
  1717. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1718. $objPHPExcel->setActiveSheetIndex(0)->getStyle('B')->getAlignment()
  1719. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1720. $objPHPExcel->setActiveSheetIndex(0)->getStyle('C')->getAlignment()
  1721. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1722. $objPHPExcel->setActiveSheetIndex(0)->getStyle('D')->getAlignment()
  1723. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1724. $objPHPExcel->setActiveSheetIndex(0)->getStyle('E')->getAlignment()
  1725. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1726. $objPHPExcel->setActiveSheetIndex(0)->getStyle('F')->getAlignment()
  1727. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1728. $objPHPExcel->setActiveSheetIndex(0)->getStyle('G')->getAlignment()
  1729. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1730. $objPHPExcel->setActiveSheetIndex(0)->getStyle('H')->getAlignment()
  1731. ->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
  1732. //设置单元格宽度
  1733. $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('A')->setWidth(10);
  1734. $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('B')->setWidth(20);
  1735. $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('C')->setWidth(20);
  1736. $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('D')->setWidth(20);
  1737. $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('E')->setWidth(20);
  1738. $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('F')->setWidth(50);
  1739. $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('G')->setWidth(20);
  1740. $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('H')->setWidth(20);
  1741. //循环刚取出来的数组,将数据逐一添加到excel表格。
  1742. if ($mode == 1) {
  1743. for ($i = 0; $i < count($lists); $i++) {
  1744. $objPHPExcel->getActiveSheet()->setCellValue('A' . ($i + 2), $lists[$i]['sn']);
  1745. $objPHPExcel->getActiveSheet()->setCellValue('B' . ($i + 2), $lists[$i]['create_time']);
  1746. $objPHPExcel->getActiveSheet()->setCellValue('C' . ($i + 2), $lists[$i]['content']);
  1747. $objPHPExcel->getActiveSheet()->setCellValue('D' . ($i + 2), $lists[$i]['dep']);
  1748. $objPHPExcel->getActiveSheet()->setCellValue('E' . ($i + 2), $lists[$i]['order_type']);
  1749. $objPHPExcel->getActiveSheet()->setCellValue('F' . ($i + 2), $lists[$i]['order_mode_text']);
  1750. $objPHPExcel->getActiveSheet()->setCellValue('G' . ($i + 2), $lists[$i]['repair_priority']);
  1751. $objPHPExcel->getActiveSheet()->setCellValue('H' . ($i + 2), $lists[$i]['source_type_text']);
  1752. $objPHPExcel->getActiveSheet()->setCellValue('I' . ($i + 2), $lists[$i]['dep_cate_name']);
  1753. }
  1754. }
  1755. else {
  1756. if ($mode == 3) {
  1757. for ($i = 0; $i < count($lists); $i++) {
  1758. $objPHPExcel->getActiveSheet()->setCellValue('A' . ($i + 2), $lists[$i]['sn']);
  1759. $objPHPExcel->getActiveSheet()->setCellValue('B' . ($i + 2), $lists[$i]['create_time']);
  1760. $objPHPExcel->getActiveSheet()->setCellValue('C' . ($i + 2), $lists[$i]['start_name']);
  1761. $objPHPExcel->getActiveSheet()->setCellValue('D' . ($i + 2), $lists[$i]['content']);
  1762. $objPHPExcel->getActiveSheet()->setCellValue('E' . ($i + 2), $lists[$i]['dep']);
  1763. $objPHPExcel->getActiveSheet()->setCellValue('F' . ($i + 2), $lists[$i]['order_mode_text']);
  1764. $objPHPExcel->getActiveSheet()->setCellValue('G' . ($i + 2), $lists[$i]['source_type_text']);
  1765. $objPHPExcel->getActiveSheet()->setCellValue('H' . ($i + 2), $lists[$i]['dep_cate_name']);
  1766. }
  1767. }
  1768. else {
  1769. if($mode==0){
  1770. for ($i = 0; $i < count($lists); $i++) {
  1771. $objPHPExcel->getActiveSheet()->setCellValue('A' . ($i + 2), $lists[$i]['sn']);
  1772. $objPHPExcel->getActiveSheet()->setCellValue('B' . ($i + 2), $lists[$i]['create_time']);
  1773. $objPHPExcel->getActiveSheet()->setCellValue('C' . ($i + 2), $lists[$i]['content']);
  1774. $objPHPExcel->getActiveSheet()->setCellValue('D' . ($i + 2), $lists[$i]['dep']);
  1775. $objPHPExcel->getActiveSheet()->setCellValue('E' . ($i + 2), $lists[$i]['order_mode_text']);
  1776. $objPHPExcel->getActiveSheet()->setCellValue('F' . ($i + 2), $lists[$i]['work_type_mode_text']);
  1777. $objPHPExcel->getActiveSheet()->setCellValue('G' . ($i + 2), $lists[$i]['source_type_text']);
  1778. $objPHPExcel->getActiveSheet()->setCellValue('H' . ($i + 2), $lists[$i]['dep_cate_name']);
  1779. }
  1780. }else{
  1781. if($mode==15){
  1782. for ($i = 0; $i < count($lists); $i++) {
  1783. $objPHPExcel->getActiveSheet()->setCellValue('A' . ($i + 2), $lists[$i]['sn']);
  1784. $objPHPExcel->getActiveSheet()->setCellValue('B' . ($i + 2), $lists[$i]['create_time']);
  1785. $objPHPExcel->getActiveSheet()->setCellValue('C' . ($i + 2), $lists[$i]['content']);
  1786. $objPHPExcel->getActiveSheet()->setCellValue('D' . ($i + 2), $lists[$i]['dep']);
  1787. $objPHPExcel->getActiveSheet()->setCellValue('E' . ($i + 2), $lists[$i]['order_mode_text']);
  1788. $objPHPExcel->getActiveSheet()->setCellValue('F' . ($i + 2), $lists[$i]['source_type_text']);
  1789. $objPHPExcel->getActiveSheet()->setCellValue('G' . ($i + 2), $lists[$i]['dep_cate_name']);
  1790. $objPHPExcel->getActiveSheet()->setCellValue('H' . ($i + 2), $lists[$i]['quality_cate_name']);
  1791. }
  1792. }else{
  1793. for ($i = 0; $i < count($lists); $i++) {
  1794. $objPHPExcel->getActiveSheet()->setCellValue('A' . ($i + 2), $lists[$i]['sn']);
  1795. $objPHPExcel->getActiveSheet()->setCellValue('B' . ($i + 2), $lists[$i]['create_time']);
  1796. $objPHPExcel->getActiveSheet()->setCellValue('C' . ($i + 2), $lists[$i]['content']);
  1797. $objPHPExcel->getActiveSheet()->setCellValue('D' . ($i + 2), $lists[$i]['dep']);
  1798. $objPHPExcel->getActiveSheet()->setCellValue('E' . ($i + 2), $lists[$i]['order_mode_text']);
  1799. $objPHPExcel->getActiveSheet()->setCellValue('F' . ($i + 2), $lists[$i]['source_type_text']);
  1800. $objPHPExcel->getActiveSheet()->setCellValue('G' . ($i + 2), $lists[$i]['dep_cate_name']);
  1801. }
  1802. }
  1803. }
  1804. }
  1805. }
  1806. //设置保存的Excel表格名称
  1807. $filename = $meta_title . '_' . date('YmdHis', time()) . '.xls';
  1808. //设置当前激活的sheet表格名称
  1809. $objPHPExcel->getActiveSheet()->setTitle($meta_title);
  1810. //设置浏览器窗口下载表格
  1811. ob_end_clean();
  1812. header("Content-Type: application/force-download");
  1813. header("Content-Type: application/octet-stream");
  1814. header("Content-Type: application/download");
  1815. header('Content-Disposition:inline;filename="' . $filename);
  1816. //生成excel文件
  1817. $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
  1818. //下载文件在浏览器窗口
  1819. return $objWriter->save('php://output');
  1820. }
  1821. }
  1822. public function rejectTodoList(){
  1823. $orderId = input('orderId',0);
  1824. if (request()->isAjax()) {
  1825. $length = input('rows', 10, 'intval'); //每页条数
  1826. $page = input('page', 1, 'intval'); //第几页
  1827. $start = ($page - 1) * $length; //分页开始位置
  1828. $map[] = ['org_id','=',$this->orgId];
  1829. $map[] = ['del','=',0];
  1830. $map[] = ['todo_mode','=',4];
  1831. $map[] = ['order_id','=',$orderId];
  1832. $lists = Db::name('todo')
  1833. ->where($map)
  1834. ->limit($start,$length)
  1835. ->order('id desc')
  1836. ->select();
  1837. $workTypeMode = [
  1838. '0'=>'一键呼叫',
  1839. '1'=>'报修',
  1840. '2'=>'保洁',
  1841. '3'=>'运送',
  1842. '4'=>'安保',
  1843. ];
  1844. foreach ($lists as $k=>$v){
  1845. $lists[$k]['to_user_name'] = Db::name('user')->where('id',$v['to_user_id'])->value('real_name');
  1846. $lists[$k]['work_type_mode_text'] = $workTypeMode[$v['work_type_mode']];
  1847. $lists[$k]['todo_mode_in_content'] = Db::name('todo_mode')->where('id',$v['todo_mode'])->value('in_content');
  1848. $lists[$k]['todo_mode_color'] = Db::name('todo_mode')->where('id',$v['todo_mode'])->value('color');
  1849. }
  1850. $totalCount = Db::name('todo')
  1851. ->where($map)
  1852. ->count();
  1853. $totalPage = ceil($totalCount / $length);
  1854. $result['page'] = $page;
  1855. $result['total'] = $totalPage;
  1856. $result['records'] = $totalCount;
  1857. $result['rows'] = $lists;
  1858. return json($result);
  1859. }
  1860. else {
  1861. $this->assign('orderId',$orderId);
  1862. return $this->fetch();
  1863. }
  1864. }
  1865. public function orderRefreshOff(){
  1866. $info = Db::name('config')->where('name','org_order_refresh')
  1867. ->find();
  1868. $orgConfig = Db::name('config_org')
  1869. ->where('config_id',$info['id'])
  1870. ->where('org_id',$this->orgId)
  1871. ->find();
  1872. if($orgConfig){
  1873. $value = $orgConfig['value']==1?0:1;
  1874. $res = Db::name('config_org')
  1875. ->where('config_id',$info['id'])
  1876. ->where('org_id',$this->orgId)
  1877. ->update(['value'=>$value]);
  1878. }else{
  1879. $value = 1;
  1880. $res = Db::name('config_org')
  1881. ->insertGetId([
  1882. 'config_id'=>$info['id'],
  1883. 'org_id'=>$this->orgId,
  1884. 'value'=>$value,
  1885. ]);
  1886. }
  1887. $res?$this->success('操作成功','',['status'=>$value]):$this->error('操作失败');
  1888. }
  1889. public function print1($id){
  1890. $order = Db::name('orders')->where(['id' => $id])->find();
  1891. $depName = Db::name('dep')
  1892. ->where('id',$order['dep_id'])
  1893. ->value('title');
  1894. $info['depName'] = $depName;
  1895. $info['create_time'] = $order['create_time'];
  1896. $users = Db::name('todo')
  1897. ->alias('t')
  1898. ->join('user u','u.id=t.to_user_id')
  1899. ->where('t.order_id',$order['id'])
  1900. ->column('u.real_name');
  1901. $info['users'] = $users?implode(',',$users):'';
  1902. $info['content'] = $order['content'];
  1903. $info['cons'] = [];
  1904. $tList = Db::name('todo')
  1905. ->where('order_id',$order['id'])
  1906. ->select();
  1907. $total = $totalPrice = 0;
  1908. $signs = [];
  1909. foreach ($tList as $k=>$v){
  1910. if($v['sign']){
  1911. $signs[] = $v['sign'];
  1912. }
  1913. $mate = Db::name('todo_mate_item')
  1914. ->alias('tmi')
  1915. ->join('todo_mate tm','tmi.todo_mate_id = tm.id')
  1916. ->join('mate_goods mg','mg.id = tmi.items_id')
  1917. ->field('tmi.items_id,tmi.total,tmi.money,tmi.total_money,mg.title')
  1918. ->where('tm.todo_id',$v['id'])
  1919. ->select();
  1920. if(!empty($mate)){
  1921. foreach ($mate as $kk=>$todo_mate){
  1922. $info['cons'][] = [
  1923. 'title' =>$todo_mate['title'],
  1924. 'total' =>$todo_mate['total'],
  1925. 'money' =>$todo_mate['money'],
  1926. 'total_money' =>$todo_mate['total_money'],
  1927. ];
  1928. $total +=$todo_mate['total'];
  1929. $totalPrice +=$todo_mate['total_money'];
  1930. }
  1931. }
  1932. }
  1933. $aa = [
  1934. 'title'=>'',
  1935. 'total'=>'',
  1936. 'money'=>'',
  1937. 'total_money'=>'',
  1938. ];
  1939. if(empty($info['cons'])){
  1940. for ($i=1;$i<=4;$i++){
  1941. $info['cons'][] = $aa;
  1942. }
  1943. }elseif (count($info['cons']) <4){
  1944. $ii = 4-count($info['cons']);
  1945. for ($i=1;$i<=$ii;$i++){
  1946. $info['cons'][] = $aa;
  1947. }
  1948. }
  1949. $info['total'] = $total;
  1950. $info['totalPrice'] = round($totalPrice,2);
  1951. $info['signs'] = $signs;
  1952. $this->assign('info', $info);
  1953. return $this->fetch();
  1954. }
  1955. public function withdraw(){
  1956. $id = input('id');
  1957. $info = Db::name('orders')
  1958. ->where('id',$id)
  1959. ->where('del',0)
  1960. ->where('order_mode',4)
  1961. ->find();
  1962. if(!$info){
  1963. $this->error('参数错误');
  1964. }
  1965. $saveOrder = Db::name('orders')
  1966. ->where('id',$id)
  1967. ->update(['order_mode'=>1,'withdraw_time'=>getTime()]);
  1968. $saveTodo = Db::name('todo')
  1969. ->where('order_id',$id)
  1970. ->update(['del'=>1]);
  1971. $todoIds = Db::name('todo')
  1972. ->where('order_id',$id)
  1973. ->where('todo_mode',1)
  1974. ->column('id');
  1975. $task = Db::name('task')
  1976. ->where('type',1)
  1977. ->whereIn('bus_id',$todoIds)
  1978. ->delete();
  1979. if(!$saveOrder){
  1980. $this->error('操作失败');
  1981. }
  1982. $this->success('操作成功');
  1983. }
  1984. public function autoSend($id,$form=0) {
  1985. if(request()->isGet() && $form==0){
  1986. $order_type = (new \app\common\model\OrderType())->getList();
  1987. $order_repair = Db::name('order_repair')
  1988. ->where('order_id', $id)
  1989. ->find();
  1990. $this->assign('order_repair', $order_repair);
  1991. $this->assign('order_type_list',$order_type);
  1992. $this->assign('id',$id);
  1993. return $this->fetch();
  1994. }else{
  1995. $type_id = input('type_id/d','');
  1996. if(!empty($type_id)){
  1997. $old = Db::name('order_repair')
  1998. ->where('order_id', $id)
  1999. ->find();
  2000. $rData['type_id'] = $type_id;
  2001. if ($old) {
  2002. $rData['update_time'] = getTime();
  2003. Db::name('order_repair')
  2004. ->where('order_id', $id)
  2005. ->update($rData);
  2006. }
  2007. else {
  2008. $rData['order_id'] = $id;
  2009. Db::name('order_repair')
  2010. ->insert($rData);
  2011. }
  2012. }
  2013. $res = $this->model->autoSend($id);
  2014. if (!$res) {
  2015. $this->error($this->model->getError());
  2016. }
  2017. $this->success('操作成功');
  2018. }
  2019. }
  2020. public function setType($id) {
  2021. if(request()->isGet()){
  2022. $order_type = (new \app\common\model\OrderType())->getList();
  2023. $order_repair = Db::name('order_repair')
  2024. ->where('order_id', $id)
  2025. ->find();
  2026. $this->assign('order_repair', $order_repair);
  2027. $this->assign('order_type_list',$order_type);
  2028. $this->assign('id',$id);
  2029. return $this->fetch();
  2030. }else{
  2031. $type_id = input('type_id/d','');
  2032. if(empty($type_id)){
  2033. $this->error('请选择报修事项');
  2034. }
  2035. $old = Db::name('order_repair')
  2036. ->where('order_id', $id)
  2037. ->find();
  2038. $rData['type_id'] = $type_id;
  2039. if ($old) {
  2040. $rData['update_time'] = getTime();
  2041. $r = Db::name('order_repair')
  2042. ->where('order_id', $id)
  2043. ->update($rData);
  2044. }
  2045. else {
  2046. $rData['order_id'] = $id;
  2047. $r = Db::name('order_repair')
  2048. ->insert($rData);
  2049. }
  2050. $r?$this->success('操作成功'):$this->error('操作失败');
  2051. }
  2052. }
  2053. //调度附言
  2054. public function ps($id) {
  2055. if (request()->isGet()) {
  2056. $this->assign('id', $id);
  2057. $ps = Db::name('orders')
  2058. ->where('id', $id)
  2059. ->value('ps');
  2060. $this->assign('ps', $ps);
  2061. $this->assign('id', $id);
  2062. return $this->fetch();
  2063. }else {
  2064. $ps = input('ps');
  2065. $res = Db::name('orders')
  2066. ->where('id', $id)
  2067. ->update(['ps'=>$ps,'update_time'=>getTime()]);
  2068. if (!$res) {
  2069. $this->error('操作失败');
  2070. }
  2071. $this->success('操作成功');
  2072. }
  2073. }
  2074. //标记订单
  2075. public function mark($id=0,$value=''){
  2076. if($value == '' || !$id){
  2077. $this->error('参数错误');
  2078. }
  2079. $res = db('orders')->where('id',$id)->setField('is_marked',$value);
  2080. if($res){
  2081. $this->success('操作成功');
  2082. }else{
  2083. $this->error('操作失败');
  2084. }
  2085. }
  2086. }