Threelevel.php 85 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241
  1. <?php
  2. namespace app\api\controller\screen;
  3. use app\hander\HelpHander;
  4. use think\Controller;
  5. use think\Db;
  6. use think\helper\Str;
  7. use think\Request;
  8. class Threelevel extends Controller{
  9. private $orgId = 0; //组织id
  10. private $title = '';
  11. private $spOrgId = 5; //国天sp 厦门中山医院
  12. private $bjOrgId = 11; //霸洁云 贵州省黔西市人民医院
  13. private $xcOrgId = 18; //新城悦 嘉善县中医院
  14. protected function initialize()
  15. {
  16. parent::initialize();
  17. $dd = think_decrypt(input('orgId','','trim'));
  18. if(!$dd){
  19. HelpHander::error('参数错误1');
  20. }
  21. $dd = explode('|',$dd);
  22. if(count($dd) != 2){
  23. HelpHander::error('参数错误2');
  24. }
  25. $orgId = (int)$dd[0];
  26. if($orgId < 1){
  27. HelpHander::error('参数错误3');
  28. }
  29. $this->orgId = $orgId;
  30. // $orgId = input('orgId',0);
  31. // if($orgId < 1){
  32. // HelpHander::error('参数错误');
  33. // }
  34. // $this->orgId = $orgId;
  35. $org = Db::name('org')->where('del',0)->where('id',$orgId)->find();
  36. if(!$org){
  37. HelpHander::error('参数错误');
  38. }
  39. $this->title = $org['name'].'后勤总数据大屏';
  40. }
  41. public function getTitle(){
  42. HelpHander::success($this->title);
  43. }
  44. public function projectCount(){
  45. if($this->orgId == 3){
  46. $userCount = gtspdb('user')
  47. ->alias('u')
  48. ->join('user_org uo','uo.USER_ID=u.USER_ID')
  49. ->join('org o','o.ORG_ID=uo.ORG_ID')
  50. ->where('u.DEL_REF',0)
  51. ->where('u.TYPE',0)
  52. ->where('o.ENABLE',1)
  53. ->where('o.DEL_REF',0)
  54. ->where('o.ORG_ID',$this->spOrgId)
  55. ->count();
  56. $orderCount = gtspdb('orders')
  57. ->where('DEL_REF',0)
  58. ->where('ORG_ID',$this->spOrgId)
  59. ->count();
  60. $todoCount = gtspdb('todo')
  61. ->where('DEL_REF',0)
  62. ->where('ORG_ID',$this->spOrgId)
  63. ->count();
  64. $task1 = gtspdb('patrol_task')
  65. ->where('DEL_REF',0)
  66. ->where('ORG_ID',$this->spOrgId)
  67. ->count();
  68. $taskCount = $task1;
  69. }elseif($this->orgId == 24){
  70. $userCount = bjydb('user')
  71. ->alias('u')
  72. ->join('user_org uo','uo.user_id=u.id')
  73. ->join('org o','o.id=uo.org_id')
  74. ->where('u.del',0)
  75. ->where('u.type',0)
  76. ->where('o.enable',1)
  77. ->where('o.del',0)
  78. ->where('o.id',$this->bjOrgId)
  79. ->count();
  80. $orderCount = bjydb('orders')
  81. ->where('del',0)
  82. ->where('org_id',$this->bjOrgId)
  83. ->count();
  84. $todoCount = bjydb('todo')
  85. ->where('del',0)
  86. ->where('org_id',$this->bjOrgId)
  87. ->count();
  88. $task1 = bjydb('patrol_task')
  89. ->where('del',0)
  90. ->where('org_id',$this->bjOrgId)
  91. ->count();
  92. $task2 = bjydb('device_task')
  93. ->where('del',0)
  94. ->where('org_id',$this->bjOrgId)
  95. ->count();
  96. $taskCount = $task1 + $task2;
  97. }elseif($this->orgId == 26){
  98. $userCount = xcydb('user')
  99. ->alias('u')
  100. ->join('user_org uo','uo.user_id=u.id')
  101. ->join('org o','o.id=uo.org_id')
  102. ->where('u.del',0)
  103. ->where('u.type',0)
  104. ->where('o.enable',1)
  105. ->where('o.del',0)
  106. ->where('o.id',$this->xcOrgId)
  107. ->count();
  108. $orderCount = xcydb('orders')
  109. ->where('del',0)
  110. ->where('org_id',$this->xcOrgId)
  111. ->count();
  112. $todoCount = xcydb('todo')
  113. ->where('del',0)
  114. ->where('org_id',$this->xcOrgId)
  115. ->count();
  116. $task1 = xcydb('patrol_task')
  117. ->where('del',0)
  118. ->where('org_id',$this->xcOrgId)
  119. ->count();
  120. $task2 = xcydb('device_task')
  121. ->where('del',0)
  122. ->where('org_id',$this->xcOrgId)
  123. ->count();
  124. $taskCount = $task1 + $task2;
  125. }else{
  126. $userCount = Db::name('user')
  127. ->alias('u')
  128. ->join('user_org uo','uo.user_id=u.id')
  129. ->join('org o','o.id=uo.org_id')
  130. ->where('u.del',0)
  131. ->where('u.type',0)
  132. ->where('o.enable',1)
  133. ->where('o.del',0)
  134. ->where('o.id',$this->orgId)
  135. ->count();
  136. $orderCount = Db::name('orders')
  137. ->where('del',0)
  138. ->where('org_id',$this->orgId)
  139. ->count();
  140. $todoCount = Db::name('todo')
  141. ->where('del',0)
  142. ->where('org_id',$this->orgId)
  143. ->count();
  144. $task1 = Db::name('patrol_task')
  145. ->where('del',0)
  146. ->where('org_id',$this->orgId)
  147. ->count();
  148. $task2 = Db::name('device_task')
  149. ->where('del',0)
  150. ->where('org_id',$this->orgId)
  151. ->count();
  152. $taskCount = $task1 + $task2;
  153. }
  154. $data = [
  155. 'count1'=>$userCount,
  156. 'count2'=>$orderCount,
  157. 'count3'=>$todoCount,
  158. 'count4'=>$taskCount,
  159. 'count5'=>23,
  160. ];
  161. HelpHander::success($data);
  162. }
  163. public function todayTodoInfo(){
  164. $date = date('Ymd');
  165. if($this->orgId == 3){
  166. $map[] = ['CREATE_YYYYMMDD','=',$date];
  167. $map[] = ['DEL_REF','=',0];
  168. $count = gtspdb('todo')->where($map)->where('ORG_ID',$this->spOrgId)->count();
  169. $map[] = ['TODO_MODE','=',3];
  170. $overCount = gtspdb('todo')->where($map)->where('ORG_ID',$this->spOrgId)->count();
  171. $overBl = 0;
  172. if($count > 0){
  173. $overBl = round($overCount/$count*100,0);
  174. }
  175. }elseif($this->orgId == 24){
  176. $map[] = ['create_yyyymmdd','=',$date];
  177. $map[] = ['del','=',0];
  178. $count = bjydb('todo')->where($map)->where('org_id',$this->bjOrgId)->count();
  179. $map[] = ['todo_mode','=',3];
  180. $overCount = bjydb('todo')->where($map)->where('org_id',$this->bjOrgId)->count();
  181. $overBl = 0;
  182. if($count > 0){
  183. $overBl = round($overCount/$count*100,0);
  184. }
  185. }elseif($this->orgId == 26){
  186. $map[] = ['create_yyyymmdd','=',$date];
  187. $map[] = ['del','=',0];
  188. $count = xcydb('todo')->where($map)->where('org_id',$this->xcOrgId)->count();
  189. $map[] = ['todo_mode','=',3];
  190. $overCount = xcydb('todo')->where($map)->where('org_id',$this->xcOrgId)->count();
  191. $overBl = 0;
  192. if($count > 0){
  193. $overBl = round($overCount/$count*100,0);
  194. }
  195. }else{
  196. $map[] = ['create_yyyymmdd','=',$date];
  197. $map[] = ['del','=',0];
  198. $count = Db::name('todo')->where($map)->where('org_id',$this->orgId)->count();
  199. $map[] = ['todo_mode','=',3];
  200. $overCount = Db::name('todo')->where($map)->where('org_id',$this->orgId)->count();
  201. $overBl = 0;
  202. if($count > 0){
  203. $overBl = round($overCount/$count*100,0);
  204. }
  205. }
  206. $data = [
  207. 'count'=>$count,
  208. 'value'=>$overBl
  209. ];
  210. HelpHander::success($data);
  211. }
  212. public function todayTodoType(){
  213. $date = date('Ymd');
  214. if($this->orgId == 3){
  215. $map[] = ['CREATE_YYYYMMDD','=',$date];
  216. $map[] = ['DEL_REF','=',0];
  217. $map[] = ['ORG_ID','=',$this->spOrgId];
  218. $count = gtspdb('todo')->where($map)->where('WORK_TYPE_MODE',1)->count();
  219. $count2 = gtspdb('todo')->where($map)->where('WORK_TYPE_MODE',2)->count();
  220. $count3 = gtspdb('todo')->where($map)->where('WORK_TYPE_MODE',3)->count();
  221. $count4 = gtspdb('todo')->where($map)->where('WORK_TYPE_MODE',4)->count();
  222. $map[] = ['TODO_MODE','=',3];
  223. //保修
  224. $bxCount = gtspdb('todo')->where($map)->where('WORK_TYPE_MODE',1)->count();
  225. //保洁
  226. $bjCount = gtspdb('todo')->where($map)->where('WORK_TYPE_MODE',2)->count();
  227. //运送
  228. $ysCount = gtspdb('todo')->where($map)->where('WORK_TYPE_MODE',3)->count();
  229. //隐患
  230. $yhCount = gtspdb('todo')->where($map)->where('WORK_TYPE_MODE',4)->count();
  231. }elseif($this->orgId == 24){
  232. $map[] = ['create_yyyymmdd','=',$date];
  233. $map[] = ['del','=',0];
  234. $count = bjydb('todo')->where($map)->where('work_type_mode',1)->where('org_id',$this->bjOrgId)->count();
  235. $count2 = bjydb('todo')->where($map)->where('work_type_mode',2)->where('org_id',$this->bjOrgId)->count();
  236. $count3 = bjydb('todo')->where($map)->where('work_type_mode',3)->where('org_id',$this->bjOrgId)->count();
  237. $count4 = bjydb('todo')->where($map)->where('work_type_mode',4)->where('org_id',$this->bjOrgId)->count();
  238. $map[] = ['todo_mode','=',3];
  239. //保修
  240. $bxCount = bjydb('todo')->where($map)->where('work_type_mode',1)->where('org_id',$this->bjOrgId)->count();
  241. //保洁
  242. $bjCount = bjydb('todo')->where($map)->where('work_type_mode',2)->where('org_id',$this->bjOrgId)->count();
  243. //运送
  244. $ysCount = bjydb('todo')->where($map)->where('work_type_mode',3)->where('org_id',$this->bjOrgId)->count();
  245. //隐患
  246. $yhCount = bjydb('todo')->where($map)->where('work_type_mode',4)->where('org_id',$this->bjOrgId)->count();
  247. }elseif($this->orgId == 26){
  248. $map[] = ['create_yyyymmdd','=',$date];
  249. $map[] = ['del','=',0];
  250. $count = xcydb('todo')->where($map)->where('work_type_mode',1)->where('org_id',$this->xcOrgId)->count();
  251. $count2 = xcydb('todo')->where($map)->where('work_type_mode',2)->where('org_id',$this->xcOrgId)->count();
  252. $count3 = xcydb('todo')->where($map)->where('work_type_mode',3)->where('org_id',$this->xcOrgId)->count();
  253. $count4 = xcydb('todo')->where($map)->where('work_type_mode',4)->where('org_id',$this->xcOrgId)->count();
  254. $map[] = ['todo_mode','=',3];
  255. //保修
  256. $bxCount = xcydb('todo')->where($map)->where('work_type_mode',1)->where('org_id',$this->xcOrgId)->count();
  257. //保洁
  258. $bjCount = xcydb('todo')->where($map)->where('work_type_mode',2)->where('org_id',$this->xcOrgId)->count();
  259. //运送
  260. $ysCount = xcydb('todo')->where($map)->where('work_type_mode',3)->where('org_id',$this->xcOrgId)->count();
  261. //隐患
  262. $yhCount = xcydb('todo')->where($map)->where('work_type_mode',4)->where('org_id',$this->xcOrgId)->count();
  263. }else{
  264. $map[] = ['create_yyyymmdd','=',$date];
  265. $map[] = ['del','=',0];
  266. $count = Db::name('todo')->where($map)->where('work_type_mode',1)->where('org_id',$this->orgId)->count();
  267. $count2 = Db::name('todo')->where($map)->where('work_type_mode',2)->where('org_id',$this->orgId)->count();
  268. $count3 = Db::name('todo')->where($map)->where('work_type_mode',3)->where('org_id',$this->orgId)->count();
  269. $count4 = Db::name('todo')->where($map)->where('work_type_mode',4)->where('org_id',$this->orgId)->count();
  270. $map[] = ['todo_mode','=',3];
  271. //保修
  272. $bxCount = Db::name('todo')->where($map)->where('work_type_mode',1)->where('org_id',$this->orgId)->count();
  273. //保洁
  274. $bjCount = Db::name('todo')->where($map)->where('work_type_mode',2)->where('org_id',$this->orgId)->count();
  275. //运送
  276. $ysCount = Db::name('todo')->where($map)->where('work_type_mode',3)->where('org_id',$this->orgId)->count();
  277. //隐患
  278. $yhCount = Db::name('todo')->where($map)->where('work_type_mode',4)->where('org_id',$this->orgId)->count();
  279. }
  280. $bxBl = $bjBl = $ysBl = $yhBl =0;
  281. if($count > 0){
  282. $bxBl = round($bxCount/$count*100,0);
  283. }
  284. if($count2 >0){
  285. $bjBl = round($bjCount/$count2*100,0);
  286. }
  287. if($count3 >0){
  288. $ysBl = round($ysCount/$count3*100,0);
  289. }
  290. if($count4 >0){
  291. $yhBl = round($yhCount/$count4*100,0);
  292. }
  293. $data = [
  294. 'bx'=>['count'=>$bxCount,'bl'=>$bxBl],
  295. 'bj'=>['count'=>$bjCount,'bl'=>$bjBl],
  296. 'ys'=>['count'=>$ysCount,'bl'=>$ysBl],
  297. 'yh'=>['count'=>$yhCount,'bl'=>$yhBl],
  298. ];
  299. HelpHander::success($data);
  300. }
  301. public function rolesUserList(){
  302. if($this->orgId == 3){
  303. $initarr = array(
  304. array(
  305. 'type' => 1,
  306. 'name' => '客户人员',
  307. 'mode' => 182838,
  308. ),
  309. array(
  310. 'type' => 2,
  311. 'name' => '综合人员',
  312. 'mode' => 182848,
  313. ),
  314. array(
  315. 'type' => 3,
  316. 'name' => '运送人员',
  317. 'mode' => 182868,
  318. ),
  319. array(
  320. 'type' => 4,
  321. 'name' => '维修人员',
  322. 'mode' => 182878,
  323. ),
  324. array(
  325. 'type' => 5,
  326. 'name' => '保洁人员',
  327. 'mode' => 1828108,
  328. ),
  329. array(
  330. 'type' => 6,
  331. 'name' => '保安人员',
  332. 'mode' => 182858,
  333. ),
  334. array(
  335. 'type' => 7,
  336. 'name' => '调度人员',
  337. 'mode' => 1828118,
  338. ),
  339. array(
  340. 'type' => 8,
  341. 'name' => '监管人员',
  342. 'mode' => 1828128,
  343. )
  344. );
  345. $roles = [];
  346. foreach ($initarr as $k=>$v){
  347. $roles[$k]['name'] = $v['name'];
  348. $rolesId = gtspdb('roles')
  349. ->where('mode','like',$v['mode'].'%')
  350. ->where('MODE','<>',$v['mode'])
  351. ->where('ORG_ID',$this->spOrgId)
  352. ->column('ROLES_ID');
  353. $roles[$k]['ids'] = $rolesId;
  354. }
  355. foreach ($roles as $k=>$v){
  356. $roles[$k]['value'] = gtspdb('user_roles')
  357. ->alias('ur')
  358. ->join('user u','u.USER_ID=ur.USER_ID')
  359. ->whereIn('ur.ROLES_ID',$v['ids'])
  360. ->where('u.DEL_REF',0)
  361. ->count();
  362. }
  363. }elseif($this->orgId == 24){
  364. $roles = bjydb('roles')
  365. ->field('id,name')
  366. ->where('parent_id',0)
  367. ->whereIn('id',[5,6,7,8,9,11])
  368. ->where('type',1)
  369. ->where('del',0)
  370. ->where('enable',1)
  371. ->select();
  372. foreach ($roles as $k=>$v){
  373. $roles[$k]['ids'] = bjydb('roles')
  374. ->where('parent_id',$v['id'])
  375. ->where('type',1)
  376. ->where('del',0)
  377. ->where('enable',1)
  378. ->where('org_id',$this->bjOrgId)
  379. ->column('id');
  380. }
  381. foreach ($roles as $k=>$v){
  382. $roles[$k]['value'] = bjydb('user_roles')
  383. ->alias('ur')
  384. ->join('user u','u.id=ur.user_id')
  385. ->whereIn('ur.roles_id',$v['ids'])
  386. ->where('u.del',0)
  387. ->count();
  388. }
  389. }elseif($this->orgId == 26){
  390. $roles = xcydb('roles')
  391. ->field('id,name')
  392. ->where('parent_id',0)
  393. ->whereIn('id',[5,6,7,8,9,11])
  394. ->where('type',1)
  395. ->where('del',0)
  396. ->where('enable',1)
  397. ->select();
  398. foreach ($roles as $k=>$v){
  399. $roles[$k]['ids'] = xcydb('roles')
  400. ->where('parent_id',$v['id'])
  401. ->where('type',1)
  402. ->where('del',0)
  403. ->where('enable',1)
  404. ->where('org_id',$this->xcOrgId)
  405. ->column('id');
  406. }
  407. foreach ($roles as $k=>$v){
  408. $roles[$k]['value'] = xcydb('user_roles')
  409. ->alias('ur')
  410. ->join('user u','u.id=ur.user_id')
  411. ->whereIn('ur.roles_id',$v['ids'])
  412. ->where('u.del',0)
  413. ->count();
  414. }
  415. }else{
  416. $roles = Db::name('roles')
  417. ->field('id,name')
  418. ->where('parent_id',0)
  419. ->whereIn('id',[5,6,7,8,9,11])
  420. ->where('type',1)
  421. ->where('del',0)
  422. ->where('enable',1)
  423. ->select();
  424. foreach ($roles as $k=>$v){
  425. $roles[$k]['ids'] = Db::name('roles')
  426. ->where('parent_id',$v['id'])
  427. ->where('type',1)
  428. ->where('del',0)
  429. ->where('enable',1)
  430. ->where('org_id',$this->orgId)
  431. ->column('id');
  432. }
  433. foreach ($roles as $k=>$v){
  434. $roles[$k]['value'] = Db::name('user_roles')
  435. ->alias('ur')
  436. ->join('user u','u.id=ur.user_id')
  437. ->whereIn('ur.roles_id',$v['ids'])
  438. ->where('u.del',0)
  439. ->count();
  440. }
  441. }
  442. HelpHander::success($roles);
  443. }
  444. public function workTypeModeList(){
  445. if($this->orgId == 3){
  446. $map[] = ['ORG_ID','=',$this->spOrgId];
  447. $map[] = ['CREATE_TIME','>=',date('Y-m').'-01 00:00:00'];
  448. $map[] = ['CREATE_TIME','<=',date('Y-m').'-31 23:59:59'];
  449. $map[] = ['DEL_REF','=',0];
  450. $count = gtspdb('todo')->where($map)->count();
  451. $bj = gtspdb('todo')->where('WORK_TYPE_MODE',2)->where($map)->count();
  452. $ys = gtspdb('todo')->where('WORK_TYPE_MODE',3)->where($map)->count();
  453. $bx = gtspdb('todo')->where('WORK_TYPE_MODE',1)->where($map)->count();
  454. $yh = gtspdb('todo')->where('WORK_TYPE_MODE',4)->where($map)->count();
  455. $data = [
  456. 'title'=>['总数','保洁','运送','保修','隐患',],
  457. 'list'=>[ $count,$bj,$ys,$bx,$yh],
  458. ];
  459. }elseif($this->orgId == 24){
  460. $map[] = ['org_id','=',$this->bjOrgId];
  461. $map[] = ['create_time','>=',date('Y-m').'-01 00:00:00'];
  462. $map[] = ['create_time','<=',date('Y-m').'-31 23:59:59'];
  463. $count = bjydb('todo')->where($map)->count();
  464. $bj = bjydb('todo')->where('work_type_mode',2)->where('del',0)->where($map)->count();
  465. $ys = bjydb('todo')->where('work_type_mode',3)->where('del',0)->where($map)->count();
  466. $bx = bjydb('todo')->where('work_type_mode',1)->where('del',0)->where($map)->count();
  467. $yh = bjydb('todo')->where('work_type_mode',4)->where('del',0)->where($map)->count();
  468. $ph = bjydb('ph_todo')->where($map)->count();
  469. $data = [
  470. 'title'=>['总数','保洁','运送','保修','隐患','陪护'],
  471. 'list'=>[ $count+$ph,$bj,$ys,$bx,$yh,$ph],
  472. ];
  473. }elseif($this->orgId == 26){
  474. $map[] = ['org_id','=',$this->xcOrgId];
  475. $map[] = ['create_time','>=',date('Y-m').'-01 00:00:00'];
  476. $map[] = ['create_time','<=',date('Y-m').'-31 23:59:59'];
  477. $count = xcydb('todo')->where($map)->count();
  478. $bj = xcydb('todo')->where('work_type_mode',2)->where('del',0)->where($map)->count();
  479. $ys = xcydb('todo')->where('work_type_mode',3)->where('del',0)->where($map)->count();
  480. $bx = xcydb('todo')->where('work_type_mode',1)->where('del',0)->where($map)->count();
  481. $yh = xcydb('todo')->where('work_type_mode',4)->where('del',0)->where($map)->count();
  482. $ph = xcydb('ph_todo')->where($map)->count();
  483. $data = [
  484. 'title'=>['总数','保洁','运送','保修','隐患','陪护'],
  485. 'list'=>[ $count+$ph,$bj,$ys,$bx,$yh,$ph],
  486. ];
  487. }else{
  488. $map[] = ['org_id','=',$this->orgId];
  489. $map[] = ['create_time','>=',date('Y-m').'-01 00:00:00'];
  490. $map[] = ['create_time','<=',date('Y-m').'-31 23:59:59'];
  491. $count = Db::name('todo')->where($map)->count();
  492. $bj = Db::name('todo')->where('work_type_mode',2)->where('del',0)->where($map)->count();
  493. $ys = Db::name('todo')->where('work_type_mode',3)->where('del',0)->where($map)->count();
  494. $bx = Db::name('todo')->where('work_type_mode',1)->where('del',0)->where($map)->count();
  495. $yh = Db::name('todo')->where('work_type_mode',4)->where('del',0)->where($map)->count();
  496. $ph = Db::name('ph_todo')->where($map)->count();
  497. $data = [
  498. 'title'=>['总数','保洁','运送','保修','隐患','陪护'],
  499. 'list'=>[ $count+$ph,$bj,$ys,$bx,$yh,$ph],
  500. ];
  501. }
  502. HelpHander::success($data);
  503. }
  504. public function userCommentScoreList(){
  505. if($this->orgId == 3){
  506. $user = gtspdb('comment')
  507. ->field('USER_ID')
  508. ->where('ORG_ID',$this->spOrgId)
  509. ->group('USER_ID')
  510. ->select();
  511. foreach ($user as $k=>$v){
  512. $user[$k]['score'] = gtspdb('comment')
  513. ->where('USER_ID',$v['USER_ID'])
  514. ->sum('SCORE');
  515. $user[$k]['name'] = gtspdb('user')->where('USER_ID',$v['USER_ID'])->value('REAL_NAME');
  516. $user[$k]['dep'] = gtspdb('user_org')
  517. ->alias('uo')
  518. ->join('org o','o.ORG_ID=uo.ORG_ID')
  519. ->where('uo.USER_ID',$v['USER_ID'])
  520. ->where('uo.ORG_TYPE',1)
  521. ->where('o.TYPE',3)
  522. ->value('NAME');
  523. $roles = gtspdb('user_roles')
  524. ->alias('ur')
  525. ->join('roles r','r.ROLES_ID=ur.ROLES_ID')
  526. ->where('ur.USER_ID',$v['USER_ID'])
  527. ->value('r.NAME');
  528. $user[$k]['roles'] = $roles ? $roles:'';
  529. // $task1 = gtspdb('patrol_task')
  530. // ->alias('pt')
  531. // ->join('patrol_record pr','pr.PATROL_TASK_ID=pt.PATROL_TASK_ID')
  532. // ->where('pr.USER_ID',$v['USER_ID'])
  533. // ->where('pt.STATUS',2)
  534. // ->where('pt.DEL_REF',0)
  535. // ->where('pr.ORG_ID',$this->spOrgId)
  536. // ->count();
  537. $task1 = gtspdb('comment')
  538. ->where('USER_ID',$v['USER_ID'])
  539. ->count();
  540. $taskCount = $task1;
  541. $user[$k]['task'] = $taskCount;
  542. }
  543. $list = list_sort_by($user,'score','desc');
  544. $data = [];
  545. $host = request()->domain(true);
  546. foreach ($list as $k=>$v){
  547. if(isset($k) && $k==0){
  548. $top = '<img src="'.$host.'/screen/images/TOP1.png" width="20" >';
  549. }elseif (isset($k) && $k==1){
  550. $top = '<img src="'.$host.'/screen/images/TOP2.png" width="20" >';
  551. }elseif (isset($k) && $k==2){
  552. $top = '<img src="'.$host.'/screen/images/TOP3.png" width="20">';
  553. }else{
  554. $top = 'TOP'.($k+1);
  555. }
  556. $data[] = [$top,$v['name'],$v['dep'],$v['roles'],$v['task'],$v['score']];
  557. }
  558. }elseif($this->orgId == 24){
  559. $user = bjydb('comment')
  560. ->field('user_id')
  561. ->where('org_id',$this->bjOrgId)
  562. ->group('user_id')
  563. ->select();
  564. foreach ($user as $k=>$v){
  565. $user[$k]['score'] = bjydb('comment')
  566. ->where('org_id',$this->bjOrgId)
  567. ->where('user_id',$v['user_id'])
  568. ->sum('score');
  569. $user[$k]['name'] = bjydb('user')->where('id',$v['user_id'])->value('real_name');
  570. $user[$k]['dep'] = bjydb('user_dep')
  571. ->alias('ud')
  572. ->join('dep d','d.id=ud.dep_id')
  573. ->where('ud.user_id',$v['user_id'])
  574. ->value('title');
  575. $rolesId = bjydb('user_roles')
  576. ->alias('ur')
  577. ->join('roles r','r.id=ur.roles_id')
  578. ->where('ur.user_id',$v['user_id'])
  579. ->value('r.parent_id');
  580. $user[$k]['roles'] = $rolesId ? bjydb('roles')->where('id',$rolesId)->value('name'):'';
  581. $user[$k]['task'] = bjydb('comment')
  582. ->where('org_id',$this->bjOrgId)
  583. ->where('user_id',$v['user_id'])
  584. ->count();
  585. }
  586. $list = list_sort_by($user,'score','desc');
  587. $data = [];
  588. $host = request()->domain(true);
  589. foreach ($list as $k=>$v){
  590. if(isset($k) && $k==0){
  591. $top = '<img src="'.$host.'/screen/images/TOP1.png" width="20" >';
  592. }elseif (isset($k) && $k==1){
  593. $top = '<img src="'.$host.'/screen/images/TOP2.png" width="20" >';
  594. }elseif (isset($k) && $k==2){
  595. $top = '<img src="'.$host.'/screen/images/TOP3.png" width="20">';
  596. }else{
  597. $top = 'TOP'.($k+1);
  598. }
  599. $data[] = [$top,$v['name'],$v['dep'],$v['roles'],$v['task'],$v['score']];
  600. }
  601. }elseif($this->orgId == 26){
  602. $user = xcydb('comment')
  603. ->field('user_id')
  604. ->where('org_id',$this->xcOrgId)
  605. ->group('user_id')
  606. ->select();
  607. foreach ($user as $k=>$v){
  608. $user[$k]['score'] = xcydb('comment')
  609. ->where('org_id',$this->xcOrgId)
  610. ->where('user_id',$v['user_id'])
  611. ->sum('score');
  612. $user[$k]['name'] = xcydb('user')->where('id',$v['user_id'])->value('real_name');
  613. $user[$k]['dep'] = xcydb('user_dep')
  614. ->alias('ud')
  615. ->join('dep d','d.id=ud.dep_id')
  616. ->where('ud.user_id',$v['user_id'])
  617. ->value('title');
  618. $rolesId = xcydb('user_roles')
  619. ->alias('ur')
  620. ->join('roles r','r.id=ur.roles_id')
  621. ->where('ur.user_id',$v['user_id'])
  622. ->value('r.parent_id');
  623. $user[$k]['roles'] = $rolesId ? xcydb('roles')->where('id',$rolesId)->value('name'):'';
  624. $user[$k]['task'] = xcydb('comment')
  625. ->where('org_id',$this->xcOrgId)
  626. ->where('user_id',$v['user_id'])
  627. ->count();
  628. }
  629. $list = list_sort_by($user,'score','desc');
  630. $data = [];
  631. $host = request()->domain(true);
  632. foreach ($list as $k=>$v){
  633. if(isset($k) && $k==0){
  634. $top = '<img src="'.$host.'/screen/images/TOP1.png" width="20" >';
  635. }elseif (isset($k) && $k==1){
  636. $top = '<img src="'.$host.'/screen/images/TOP2.png" width="20" >';
  637. }elseif (isset($k) && $k==2){
  638. $top = '<img src="'.$host.'/screen/images/TOP3.png" width="20">';
  639. }else{
  640. $top = 'TOP'.($k+1);
  641. }
  642. $data[] = [$top,$v['name'],$v['dep'],$v['roles'],$v['task'],$v['score']];
  643. }
  644. }else{
  645. $user = Db::name('comment')
  646. ->field('user_id')
  647. ->where('org_id',$this->orgId)
  648. ->group('user_id')
  649. ->select();
  650. foreach ($user as $k=>$v){
  651. $user[$k]['score'] = Db::name('comment')
  652. ->where('org_id',$this->orgId)
  653. ->where('user_id',$v['user_id'])
  654. ->sum('score');
  655. $user[$k]['name'] = Db::name('user')->where('id',$v['user_id'])->value('real_name');
  656. $user[$k]['dep'] = Db::name('user_dep')
  657. ->alias('ud')
  658. ->join('dep d','d.id=ud.dep_id')
  659. ->where('ud.user_id',$v['user_id'])
  660. ->value('title');
  661. $rolesId = Db::name('user_roles')
  662. ->alias('ur')
  663. ->join('roles r','r.id=ur.roles_id')
  664. ->where('ur.user_id',$v['user_id'])
  665. ->value('r.parent_id');
  666. $user[$k]['roles'] = $rolesId ? Db::name('roles')->where('id',$rolesId)->value('name'):'';
  667. // $task1 = Db::name('patrol_task')
  668. // ->alias('pt')
  669. // ->join('patrol_record pr','pr.patrol_task_id=pt.id')
  670. // ->where('pr.user_id',$v['user_id'])
  671. // ->where('pt.status',2)
  672. // ->where('pt.del',0)
  673. // ->where('pr.org_id',$this->orgId)
  674. // ->count();
  675. //
  676. // $task2 = Db::name('device_task')
  677. // ->alias('dt')
  678. // ->join('device_record dr','dr.task_id=dt.id')
  679. // ->where('dr.user_id',$v['user_id'])
  680. // ->where('dt.status',2)
  681. // ->where('dt.del',0)
  682. // ->where('dr.org_id',$this->orgId)
  683. // ->count();
  684. //
  685. // $task3 = Db::name('daily_task')
  686. // ->alias('dt')
  687. // ->join('daily_record dr','dr.task_id=dt.id')
  688. // ->where('dr.user_id',$v['user_id'])
  689. // ->where('dt.status',2)
  690. // ->where('dt.del',0)
  691. // ->where('dr.org_id',$this->orgId)
  692. // ->count();
  693. //
  694. // $taskCount = $task1 + $task2 + $task3;
  695. $user[$k]['task'] = Db::name('comment')
  696. ->where('org_id',$this->orgId)
  697. ->where('user_id',$v['user_id'])
  698. ->count();
  699. }
  700. $list = list_sort_by($user,'score','desc');
  701. $data = [];
  702. $host = request()->domain(true);
  703. foreach ($list as $k=>$v){
  704. if(isset($k) && $k==0){
  705. $top = '<img src="'.$host.'/screen/images/TOP1.png" width="20" >';
  706. }elseif (isset($k) && $k==1){
  707. $top = '<img src="'.$host.'/screen/images/TOP2.png" width="20" >';
  708. }elseif (isset($k) && $k==2){
  709. $top = '<img src="'.$host.'/screen/images/TOP3.png" width="20">';
  710. }else{
  711. $top = 'TOP'.($k+1);
  712. }
  713. $data[] = [$top,$v['name'],$v['dep'],$v['roles'],$v['task'],$v['score']];
  714. }
  715. }
  716. HelpHander::success($data);
  717. }
  718. // 获取大屏紧急联系人或图片
  719. public function getOrgInfo(){
  720. $data = [
  721. 'name' => model('Config')->getConfig('org_emergency_name',$this->orgId),
  722. 'phone' => model('Config')->getConfig('org_emergency_phone',$this->orgId),
  723. 'img' => model('Config')->getConfig('org_screen_img',$this->orgId)
  724. ];
  725. HelpHander::success($data);
  726. }
  727. public function orgQuarterRankList(){
  728. //获取当前季度
  729. $season = ceil((date('n'))/3);
  730. //当前季度开始时间戳
  731. $startTime = date('Y-m-d H:i:s', mktime(0,0,0,$season*3-3+1,1,date('Y')));
  732. //获取当前季度结束时间戳
  733. $overTime = date('Y-m-d H:i:s', mktime(23,59,59,$season*3,date('t',mktime(0,0,0,$season*3,1,date("Y"))),date('Y')));
  734. $orgList = Db::name('org')
  735. ->field('id,name')
  736. ->where('type',2)
  737. ->where('enable',1)
  738. ->where('del',0)
  739. ->select();
  740. foreach ($orgList as $k=>$v){
  741. if($v['id'] == 3){
  742. $orgList[$k]['count'] = gtspdb('comment')
  743. ->where('ORG_ID',$v['id'])
  744. ->where('CREATE_TIME','>=',$startTime)
  745. ->where('CREATE_TIME','<=',$overTime)
  746. ->sum('SCORE');
  747. }elseif ($v['id'] == 24){
  748. $orgList[$k]['count'] = bjydb('comment')
  749. ->where('org_id',$this->bjOrgId)
  750. ->where('create_time','>=',$startTime)
  751. ->where('create_time','<=',$overTime)
  752. ->sum('score');
  753. }elseif ($v['id'] == 26){
  754. $orgList[$k]['count'] = xcydb('comment')
  755. ->where('org_id',$this->xcOrgId)
  756. ->where('create_time','>=',$startTime)
  757. ->where('create_time','<=',$overTime)
  758. ->sum('score');
  759. }else{
  760. $orgList[$k]['count'] = Db::name('comment')
  761. ->where('org_id',$v['id'])
  762. ->where('create_time','>=',$startTime)
  763. ->where('create_time','<=',$overTime)
  764. ->sum('score');
  765. }
  766. }
  767. $list = list_sort_by($orgList,'count','desc');
  768. $curTop = 1;
  769. $curNums = 0;
  770. foreach ($list as $k=>$v){
  771. if($v['id'] == $this->orgId){
  772. $curTop = $k+1;
  773. $curNums = $v['count'];
  774. }
  775. }
  776. $data = [
  777. 'my'=>['top'=>$curTop,'nums'=>$curNums],
  778. 'jn'=>['top'=>2,'nums'=>4.6],
  779. ];
  780. HelpHander::success($data);
  781. }
  782. //任务数据总览
  783. public function taskList(){
  784. $mode = input('mode/d',3);
  785. if(!in_array($mode,[1,2,3,4])){
  786. HelpHander::error('参数错误');
  787. }
  788. if($this->orgId == 3){
  789. $data = [];
  790. $header = ['状态', '类型', '始发地', '目的地', '需求时间', '执行人', '派工时间', '接收时间'];
  791. if($mode == 5){
  792. $header = ['状态', '订单号', '类型', '护工', '下单时间'];
  793. $lists = Db::name('ph_orders')
  794. ->where('org_id',$this->orgId)
  795. ->where('status','in',[1,2])
  796. ->order('id desc')
  797. ->field('id,sn,cate_id,status,create_time')
  798. ->limit(20)
  799. ->select();
  800. foreach ($lists as $k=>$v){
  801. $cate = Db::name('cate')->where('id',$v['cate_id'])->value('title');
  802. $stxt = '新订单';
  803. $users = '';
  804. if($v['status'] == 2){
  805. $stxt = '服务中';
  806. $unames = Db::name('ph_todo')
  807. ->alias('t')
  808. ->join('worker w','t.worker_id = w.id')
  809. ->join('user u','u.id = w.user_id')
  810. ->where('t.order_id',$v['id'])
  811. ->where('t.status',1)
  812. ->column('real_name');
  813. $users = $unames?implode(',',$unames):'';
  814. }
  815. $data[] = [$stxt,$v['sn'],$cate,$users,$v['create_time']];
  816. }
  817. }else{
  818. if($mode == 1){
  819. $header = ['状态', '科室', '报修事项', '内容', '下单时间'];
  820. }else if($mode == 2||$mode == 4){
  821. $header = ['状态', '科室', '内容', '下单时间'];
  822. }
  823. $lists = gtspdb('orders')
  824. ->where('ORG_ID',$this->spOrgId)
  825. ->where('CURR_ORDER_MODE','in',[1,5])
  826. ->where('WORK_TYPE_MODE',$mode)
  827. ->where('DEL_REF',0)
  828. ->order('ORDER_ID DESC')
  829. ->limit(20)
  830. ->field('ORDER_ID,CURR_ORDER_MODE,CREATTE_TIME,SEND_TIME,CONTENT,DEP_ID')
  831. ->select();
  832. foreach ($lists as $k=>$v){
  833. $dep = gtspdb('org')->where('ORG_ID',$v['DEP_ID'])->value('NAME');
  834. $status = gtspdb('order_mode')->where('ORDER_MODE',$v['CURR_ORDER_MODE'])->value('OUT_CONTENT');
  835. if($mode == 1){ // 报修
  836. $type = gtspdb('order_repair')
  837. ->alias('or')
  838. ->leftJoin('order_type ot','ot.ORDER_TYPE_ID = or.TYPE_ID')
  839. ->where('or.ORDER_ID',$v['ORDER_ID'])
  840. ->value('NAME');
  841. $data[] = [$status,$dep,$type?$type:'',$v['CONTENT'],$v['CREATTE_TIME']];
  842. }else if($mode == 3){ //运送
  843. $convey = gtspdb('order_convey')
  844. ->alias('oc')
  845. ->join('convey_cate cc','cc.ID = oc.TYPE')
  846. ->where('oc.ORDER_ID',$v['ORDER_ID'])
  847. ->field('oc.*,cc.NAME as cate_title')
  848. ->find();
  849. $sa = gtspdb('address')->where('ADDRESS_ID',$convey['START'])->find();
  850. $sa1 = $ea1 = '';
  851. if($sa){
  852. $sa1 = gtspdb('address')->where('PARENT_ID',$sa['ADDRESS_ID'])->value('NAME');
  853. }
  854. $start = $sa1.$sa['NAME'];
  855. $ea = gtspdb('address')->where('ADDRESS_ID',$convey['END'])->find();
  856. if($ea){
  857. $ea1 = gtspdb('address')->where('PARENT_ID',$sa['ADDRESS_ID'])->value('NAME');
  858. }
  859. $end = $ea1.$ea['NAME'];
  860. $todos = gtspdb('todo')
  861. ->alias('t')
  862. ->join('user u','u.USER_ID = t.TO_USER_ID')
  863. ->where('t.ORDER_ID',$v['ORDER_ID'])
  864. ->where('t.DEL_REF',0)
  865. ->where('t.TODO_MODE','in',[1,2,3])
  866. ->field('t.CONFIRM_TIME,u.REAL_NAME')
  867. ->select();
  868. $todos = $todos?$todos:[];
  869. $unames = [];
  870. $confirm = '';
  871. foreach ($todos as $tk=>$tv){
  872. $unames[] = $tv['REAL_NAME'];
  873. if(!$confirm){
  874. $confirm = $tv['CONFIRM_TIME'];
  875. }
  876. }
  877. $un = $unames?implode(',',$unames):'';
  878. $send = $v['SEND_TIME']?date('H:i',strtotime($v['SEND_TIME'])):'';
  879. $xq = date('H:i',strtotime($convey['XQ_TIME']));
  880. $confirm = $confirm?date('H:i',strtotime($confirm)):'';
  881. $data[] = [$status,$convey['cate_title'],$start,$end,$xq,$un,$send,$confirm];
  882. }else{ // 保洁,隐患预警
  883. $data[] = [$status,$dep,$v['CONTENT'],$v['CREATTE_TIME']];
  884. }
  885. }
  886. }
  887. }elseif ($this->orgId == 24){
  888. $data = [];
  889. $header = ['状态', '类型', '始发地', '目的地', '需求时间', '执行人', '派工时间', '接收时间'];
  890. if($mode == 1){
  891. $header = ['状态', '科室', '报修事项', '内容', '下单时间'];
  892. }else if($mode == 2||$mode == 4){
  893. $header = ['状态', '科室', '内容', '下单时间'];
  894. }
  895. $lists = bjydb('orders')
  896. ->where('org_id',$this->bjOrgId)
  897. ->where('order_mode','in',[1,4])
  898. ->where('work_type_mode',$mode)
  899. ->where('del',0)
  900. ->order('id desc')
  901. ->limit(20)
  902. ->field('id,order_mode,create_time,send_time,content,dep_id')
  903. ->select();
  904. foreach ($lists as $k=>$v){
  905. $dep = bjydb('dep')->where('id',$v['dep_id'])->value('title');
  906. $status = bjydb('order_mode')->where('id',$v['order_mode'])->value('out_content');
  907. if($mode == 1){ // 报修
  908. $type = bjydb('order_repair')
  909. ->alias('or')
  910. ->leftJoin('order_type ot','ot.id = or.type_id')
  911. ->where('or.order_id',$v['id'])
  912. ->value('title');
  913. $data[] = [$status,$dep,$type?$type:'',$v['content'],$v['create_time']];
  914. }else if($mode == 3){ //运送
  915. $convey = bjydb('order_convey')
  916. ->alias('oc')
  917. ->join('convey_cate cc','cc.id = oc.type')
  918. ->where('oc.order_id',$v['id'])
  919. ->field('oc.*,cc.title as cate_title')
  920. ->find();
  921. $start = bjydb('address')->where('id',$convey['start'])->value('title');
  922. $end = bjydb('address')->where('id',$convey['end'])->value('title');
  923. $todos = bjydb('todo')
  924. ->alias('t')
  925. ->join('user u','u.id = t.to_user_id')
  926. ->where('t.order_id',$v['id'])
  927. ->where('t.del',0)
  928. ->where('t.todo_mode','in',[1,2,3])
  929. ->field('t.confirm_time,u.real_name')
  930. ->select();
  931. $todos = $todos?$todos:[];
  932. $unames = [];
  933. $confirm = '';
  934. foreach ($todos as $tk=>$tv){
  935. $unames[] = $tv['real_name'];
  936. if(!$confirm){
  937. $confirm = $tv['confirm_time'];
  938. }
  939. }
  940. $un = $unames?implode(',',$unames):'';
  941. $send = $v['send_time']?date('H:i',strtotime($v['send_time'])):'';
  942. $xq = date('H:i',strtotime($convey['xq_time']));
  943. $confirm = $confirm?date('H:i',strtotime($confirm)):'';
  944. $data[] = [$status,$convey['cate_title'],$start,$end,$xq,$un,$send,$confirm];
  945. }else{ // 保洁,隐患预警
  946. $data[] = [$status,$dep,$v['content'],$v['create_time']];
  947. }
  948. }
  949. }elseif ($this->orgId == 26){
  950. $data = [];
  951. $header = ['状态', '类型', '始发地', '目的地', '需求时间', '执行人', '派工时间', '接收时间'];
  952. if($mode == 1){
  953. $header = ['状态', '科室', '报修事项', '内容', '下单时间'];
  954. }else if($mode == 2||$mode == 4){
  955. $header = ['状态', '科室', '内容', '下单时间'];
  956. }
  957. $lists = xcydb('orders')
  958. ->where('org_id',$this->xcOrgId)
  959. ->where('order_mode','in',[1,4])
  960. ->where('work_type_mode',$mode)
  961. ->where('del',0)
  962. ->order('id desc')
  963. ->limit(20)
  964. ->field('id,order_mode,create_time,send_time,content,dep_id')
  965. ->select();
  966. foreach ($lists as $k=>$v){
  967. $dep = xcydb('dep')->where('id',$v['dep_id'])->value('title');
  968. $status = xcydb('order_mode')->where('id',$v['order_mode'])->value('out_content');
  969. if($mode == 1){ // 报修
  970. $type = xcydb('order_repair')
  971. ->alias('or')
  972. ->leftJoin('order_type ot','ot.id = or.type_id')
  973. ->where('or.order_id',$v['id'])
  974. ->value('title');
  975. $data[] = [$status,$dep,$type?$type:'',$v['content'],$v['create_time']];
  976. }else if($mode == 3){ //运送
  977. $convey = xcydb('order_convey')
  978. ->alias('oc')
  979. ->join('convey_cate cc','cc.id = oc.type')
  980. ->where('oc.order_id',$v['id'])
  981. ->field('oc.*,cc.title as cate_title')
  982. ->find();
  983. $start = xcydb('address')->where('id',$convey['start'])->value('title');
  984. $end = xcydb('address')->where('id',$convey['end'])->value('title');
  985. $todos = xcydb('todo')
  986. ->alias('t')
  987. ->join('user u','u.id = t.to_user_id')
  988. ->where('t.order_id',$v['id'])
  989. ->where('t.del',0)
  990. ->where('t.todo_mode','in',[1,2,3])
  991. ->field('t.confirm_time,u.real_name')
  992. ->select();
  993. $todos = $todos?$todos:[];
  994. $unames = [];
  995. $confirm = '';
  996. foreach ($todos as $tk=>$tv){
  997. $unames[] = $tv['real_name'];
  998. if(!$confirm){
  999. $confirm = $tv['confirm_time'];
  1000. }
  1001. }
  1002. $un = $unames?implode(',',$unames):'';
  1003. $send = $v['send_time']?date('H:i',strtotime($v['send_time'])):'';
  1004. $xq = date('H:i',strtotime($convey['xq_time']));
  1005. $confirm = $confirm?date('H:i',strtotime($confirm)):'';
  1006. $data[] = [$status,$convey['cate_title'],$start,$end,$xq,$un,$send,$confirm];
  1007. }else{ // 保洁,隐患预警
  1008. $data[] = [$status,$dep,$v['content'],$v['create_time']];
  1009. }
  1010. }
  1011. }else{
  1012. $data = [];
  1013. $header = ['状态', '类型', '始发地', '目的地', '需求时间', '执行人', '派工时间', '接收时间'];
  1014. if($mode == 5){
  1015. $header = ['状态', '订单号', '类型', '护工', '下单时间'];
  1016. $lists = Db::name('ph_orders')
  1017. ->where('org_id',$this->orgId)
  1018. ->where('status','in',[1,2])
  1019. ->order('id desc')
  1020. ->field('id,sn,cate_id,status,create_time')
  1021. ->limit(20)
  1022. ->select();
  1023. foreach ($lists as $k=>$v){
  1024. $cate = Db::name('cate')->where('id',$v['cate_id'])->value('title');
  1025. $stxt = '新订单';
  1026. $users = '';
  1027. if($v['status'] == 2){
  1028. $stxt = '服务中';
  1029. $unames = Db::name('ph_todo')
  1030. ->alias('t')
  1031. ->join('worker w','t.worker_id = w.id')
  1032. ->join('user u','u.id = w.user_id')
  1033. ->where('t.order_id',$v['id'])
  1034. ->where('t.status',1)
  1035. ->column('real_name');
  1036. $users = $unames?implode(',',$unames):'';
  1037. }
  1038. $data[] = [$stxt,$v['sn'],$cate,$users,$v['create_time']];
  1039. }
  1040. }else{
  1041. if($mode == 1){
  1042. $header = ['状态', '科室', '报修事项', '内容', '下单时间'];
  1043. }else if($mode == 2||$mode == 4){
  1044. $header = ['状态', '科室', '内容', '下单时间'];
  1045. }
  1046. $lists = Db::name('orders')
  1047. ->where('org_id',$this->orgId)
  1048. ->where('order_mode','in',[1,4])
  1049. ->where('work_type_mode',$mode)
  1050. ->where('del',0)
  1051. ->order('id desc')
  1052. ->limit(20)
  1053. ->field('id,order_mode,create_time,send_time,content,dep_id')
  1054. ->select();
  1055. foreach ($lists as $k=>$v){
  1056. $dep = Db::name('dep')->where('id',$v['dep_id'])->value('title');
  1057. $status = Db::name('order_mode')->where('id',$v['order_mode'])->value('out_content');
  1058. if($mode == 1){ // 报修
  1059. $type = Db::name('order_repair')
  1060. ->alias('or')
  1061. ->leftJoin('order_type ot','ot.id = or.type_id')
  1062. ->where('or.order_id',$v['id'])
  1063. ->value('title');
  1064. $data[] = [$status,$dep,$type?$type:'',$v['content'],$v['create_time']];
  1065. }else if($mode == 3){ //运送
  1066. $convey = Db::name('order_convey')
  1067. ->alias('oc')
  1068. ->join('convey_cate cc','cc.id = oc.type')
  1069. ->where('oc.order_id',$v['id'])
  1070. ->field('oc.*,cc.title as cate_title')
  1071. ->find();
  1072. $start = Db::name('address')->where('id',$convey['start'])->value('title');
  1073. $end = Db::name('address')->where('id',$convey['end'])->value('title');
  1074. $todos = Db::name('todo')
  1075. ->alias('t')
  1076. ->join('user u','u.id = t.to_user_id')
  1077. ->where('t.order_id',$v['id'])
  1078. ->where('t.del',0)
  1079. ->where('t.todo_mode','in',[1,2,3])
  1080. ->field('t.confirm_time,u.real_name')
  1081. ->select();
  1082. $todos = $todos?$todos:[];
  1083. $unames = [];
  1084. $confirm = '';
  1085. foreach ($todos as $tk=>$tv){
  1086. $unames[] = $tv['real_name'];
  1087. if(!$confirm){
  1088. $confirm = $tv['confirm_time'];
  1089. }
  1090. }
  1091. $un = $unames?implode(',',$unames):'';
  1092. $send = $v['send_time']?date('H:i',strtotime($v['send_time'])):'';
  1093. $xq = date('H:i',strtotime($convey['xq_time']));
  1094. $confirm = $confirm?date('H:i',strtotime($confirm)):'';
  1095. $data[] = [$status,$convey['cate_title'],$start,$end,$xq,$un,$send,$confirm];
  1096. }else{ // 保洁,隐患预警
  1097. $data[] = [$status,$dep,$v['content'],$v['create_time']];
  1098. }
  1099. }
  1100. }
  1101. }
  1102. HelpHander::success(['data'=>$data,'header'=>$header]);
  1103. }
  1104. public function wasteRecordList(){
  1105. $date = date('Ymd');
  1106. $edate = date("Ymd",strtotime("-1 months",strtotime($date)));
  1107. if($this->orgId == 3){
  1108. $addr = gtspdb('waste_device')
  1109. ->field('WASTE_DEVICE_ID,TITLE')
  1110. ->where('DEL_REF',0)
  1111. ->where('ENABLE',1)
  1112. ->where('ORG_ID',$this->spOrgId)
  1113. ->select();
  1114. foreach ($addr as $k=>$v){
  1115. $nums1 = gtspdb('waste_record')
  1116. ->where('CREATE_YYYYMMDD',$date)
  1117. ->where('WASTE_DEVICE_ID',$v['WASTE_DEVICE_ID'])
  1118. ->sum('WEIGHT');
  1119. $addr[$k]['nums1'] = $nums1 ? round($nums1/1000,0) : 0;
  1120. $nums2 = gtspdb('waste_record')
  1121. ->where('CREATE_YYYYMM','=',$edate)
  1122. ->where('WASTE_DEVICE_ID',$v['WASTE_DEVICE_ID'])
  1123. ->sum('WEIGHT');
  1124. $addr[$k]['nums2'] = $nums2 ? round($nums2/30/1000,0) : 0;
  1125. }
  1126. $lists =array_slice(list_sort_by($addr,'nums1','desc'),0,5) ;
  1127. $data1 = array_column($lists,'nums1');
  1128. $data2 = array_column($lists,'nums2');
  1129. $title = array_column($lists,'TITLE');
  1130. }elseif($this->orgId == 24){
  1131. $addr = bjydb('address')
  1132. ->field('id,title')
  1133. ->where('del',0)
  1134. ->where('enable',1)
  1135. ->where('org_id',$this->bjOrgId)
  1136. ->where('','exp',Db::raw("FIND_IN_SET(7,types)"))
  1137. ->select();
  1138. foreach ($addr as $k=>$v){
  1139. $nums1 = bjydb('waste_record')
  1140. ->where('create_yyyymmdd','=',$date)
  1141. ->where('waste_device_id',$v['id'])
  1142. ->sum('weight');
  1143. $addr[$k]['nums1'] = $nums1 ? round($nums1/1000,0) : 0;
  1144. $nums2 = bjydb('waste_record')
  1145. ->where('create_yyyymm','=',$edate)
  1146. ->where('waste_device_id',$v['id'])
  1147. ->sum('weight');
  1148. $addr[$k]['nums2'] = $nums2 ? round($nums2/30/1000,0) : 0;
  1149. }
  1150. $lists =array_slice(list_sort_by($addr,'nums1','desc'),0,5) ;
  1151. $data1 = array_column($lists,'nums1');
  1152. $data2 = array_column($lists,'nums2');
  1153. $title = array_column($lists,'title');
  1154. }elseif($this->orgId == 26){
  1155. $addr = xcydb('address')
  1156. ->field('id,title')
  1157. ->where('del',0)
  1158. ->where('enable',1)
  1159. ->where('org_id',$this->xcOrgId)
  1160. ->where('','exp',Db::raw("FIND_IN_SET(7,types)"))
  1161. ->select();
  1162. foreach ($addr as $k=>$v){
  1163. $nums1 = xcydb('waste_record')
  1164. ->where('create_yyyymmdd','=',$date)
  1165. ->where('waste_device_id',$v['id'])
  1166. ->sum('weight');
  1167. $addr[$k]['nums1'] = $nums1 ? round($nums1/1000,0) : 0;
  1168. $nums2 = xcydb('waste_record')
  1169. ->where('create_yyyymm','=',$edate)
  1170. ->where('waste_device_id',$v['id'])
  1171. ->sum('weight');
  1172. $addr[$k]['nums2'] = $nums2 ? round($nums2/30/1000,0) : 0;
  1173. }
  1174. $lists =array_slice(list_sort_by($addr,'nums1','desc'),0,5) ;
  1175. $data1 = array_column($lists,'nums1');
  1176. $data2 = array_column($lists,'nums2');
  1177. $title = array_column($lists,'title');
  1178. }else{
  1179. $addr = Db::name('address')
  1180. ->field('id,title')
  1181. ->where('del',0)
  1182. ->where('enable',1)
  1183. ->where('org_id',$this->orgId)
  1184. ->where('','exp',Db::raw("FIND_IN_SET(7,types)"))
  1185. ->select();
  1186. foreach ($addr as $k=>$v){
  1187. $nums1 = Db::name('waste_record')
  1188. ->where('create_yyyymmdd','=',$date)
  1189. ->where('waste_device_id',$v['id'])
  1190. ->sum('weight');
  1191. $addr[$k]['nums1'] = $nums1 ? round($nums1/1000,0) : 0;
  1192. $nums2 = Db::name('waste_record')
  1193. ->where('create_yyyymm','=',$edate)
  1194. ->where('waste_device_id',$v['id'])
  1195. ->sum('weight');
  1196. $addr[$k]['nums2'] = $nums2 ? round($nums2/30/1000,0) : 0;
  1197. }
  1198. $lists =array_slice(list_sort_by($addr,'nums1','desc'),0,5) ;
  1199. $data1 = array_column($lists,'nums1');
  1200. $data2 = array_column($lists,'nums2');
  1201. $title = array_column($lists,'title');
  1202. }
  1203. $data = [
  1204. 'data1'=>$data1,
  1205. 'data2'=>$data2,
  1206. 'title'=>$title,
  1207. ];
  1208. HelpHander::success($data);
  1209. }
  1210. // 巡更任务数据统计 当天及30天异常数量
  1211. public function addrRecord(){
  1212. //先取30内的巡更地点
  1213. $curDay = date('Ymd');
  1214. $start = date('Ymd',strtotime(date('Y-m-d')) - 29*24*60*60);
  1215. if($this->orgId == 3||$this->orgId == 26){
  1216. $lists = gtspdb('patrol_record')
  1217. ->alias('pr')
  1218. ->join('patrol_addr a','a.PATROL_ADDR_ID = pr.PATROL_ADDR_ID')
  1219. ->where('pr.ORG_ID',$this->spOrgId)
  1220. ->where('pr.PATROL_MODE',4)
  1221. ->where('pr.CREATE_YYYYMMDD','<=',$curDay)
  1222. ->where('pr.CREATE_YYYYMMDD','>=',$start)
  1223. ->field('a.PATROL_ADDR_ID,a.TITLE')
  1224. ->group('pr.PATROL_ADDR_ID')
  1225. ->distinct(true)
  1226. ->select();
  1227. $titles = [];
  1228. $y1 = [];
  1229. $y2 = [];
  1230. foreach ($lists as $k=>$v){
  1231. $titles[] = mb_substr($v['TITLE'],0,4).'..';
  1232. $count1 = gtspdb('patrol_record')
  1233. ->where('ORG_ID',$this->spOrgId)
  1234. ->where('PATROL_MODE',4)
  1235. ->where('CREATE_YYYYMMDD','=',$curDay)
  1236. ->where('PATROL_ADDR_ID','=',$v['PATROL_ADDR_ID'])
  1237. ->count();
  1238. $y1[] = $count1;
  1239. $count2 = gtspdb('patrol_record')
  1240. ->where('ORG_ID',$this->spOrgId)
  1241. ->where('PATROL_MODE',4)
  1242. ->where('IS_NORMAL',1)
  1243. ->where('CREATE_YYYYMMDD','<=',$curDay)
  1244. ->where('CREATE_YYYYMMDD','>=',$start)
  1245. ->where('PATROL_ADDR_ID','=',$v['PATROL_ADDR_ID'])
  1246. ->count();
  1247. $y2[] = $count2;
  1248. }
  1249. }elseif($this->orgId == 24){
  1250. $lists = bjydb('patrol_record')
  1251. ->alias('pr')
  1252. ->join('address a','a.id = pr.patrol_addr_id')
  1253. ->where('pr.org_id',$this->bjOrgId)
  1254. ->where('pr.patrol_mode',1)
  1255. ->where('pr.create_yyyymmdd','<=',$curDay)
  1256. ->where('pr.create_yyyymmdd','>=',$start)
  1257. ->field('a.id,a.title')
  1258. ->group('pr.patrol_addr_id')
  1259. ->distinct(true)
  1260. ->select();
  1261. $titles = [];
  1262. $y1 = [];
  1263. $y2 = [];
  1264. foreach ($lists as $k=>$v){
  1265. $titles[] = $v['title'];
  1266. $count1 = bjydb('patrol_record')
  1267. ->where('org_id',$this->bjOrgId)
  1268. ->where('patrol_mode',1)
  1269. ->where('create_yyyymmdd','=',$curDay)
  1270. ->where('patrol_addr_id','=',$v['id'])
  1271. ->count();
  1272. $y1[] = $count1;
  1273. $count2 = bjydb('patrol_record')
  1274. ->where('org_id',$this->bjOrgId)
  1275. ->where('patrol_mode',1)
  1276. ->where('is_normal',1)
  1277. ->where('create_yyyymmdd','<=',$curDay)
  1278. ->where('create_yyyymmdd','>=',$start)
  1279. ->where('patrol_addr_id','=',$v['id'])
  1280. ->count();
  1281. $y2[] = $count2;
  1282. }
  1283. }else{
  1284. $lists = Db::name('patrol_record')
  1285. ->alias('pr')
  1286. ->join('address a','a.id = pr.patrol_addr_id')
  1287. ->where('pr.org_id',$this->orgId)
  1288. ->where('pr.patrol_mode',1)
  1289. ->where('pr.create_yyyymmdd','<=',$curDay)
  1290. ->where('pr.create_yyyymmdd','>=',$start)
  1291. ->field('a.id,a.title')
  1292. ->group('pr.patrol_addr_id')
  1293. ->distinct(true)
  1294. ->select();
  1295. $titles = [];
  1296. $y1 = [];
  1297. $y2 = [];
  1298. foreach ($lists as $k=>$v){
  1299. $titles[] = $v['title'];
  1300. $count1 = Db::name('patrol_record')
  1301. ->where('org_id',$this->orgId)
  1302. ->where('patrol_mode',1)
  1303. ->where('create_yyyymmdd','=',$curDay)
  1304. ->where('patrol_addr_id','=',$v['id'])
  1305. ->count();
  1306. $y1[] = $count1;
  1307. $count2 = Db::name('patrol_record')
  1308. ->where('org_id',$this->orgId)
  1309. ->where('patrol_mode',1)
  1310. ->where('is_normal',1)
  1311. ->where('create_yyyymmdd','<=',$curDay)
  1312. ->where('create_yyyymmdd','>=',$start)
  1313. ->where('patrol_addr_id','=',$v['id'])
  1314. ->count();
  1315. $y2[] = $count2;
  1316. }
  1317. }
  1318. HelpHander::success(['titles' => $titles,'y1' => $y1,'y2' => $y2]);
  1319. }
  1320. //巡查图片
  1321. public function patrolImg(){
  1322. if($this->orgId == 3||$this->orgId == 26){
  1323. $data = gtspdb('patrol_record')
  1324. ->where('IMAGES','<>','')
  1325. ->where('ORG_ID',$this->spOrgId)
  1326. ->limit(20)
  1327. ->order('PATROL_RECORD_ID desc')
  1328. ->select();
  1329. foreach ($data as $k=>$v){
  1330. $img = explode(',',$v['IMAGES']);
  1331. if($img){
  1332. $data[$k]['images'] = $img[0];
  1333. }
  1334. }
  1335. }elseif($this->orgId == 24){
  1336. $data = bjydb('patrol_record')
  1337. ->where('images','<>','')
  1338. ->where('org_id',$this->bjOrgId)
  1339. ->limit(20)
  1340. ->order('id desc')
  1341. ->select();
  1342. foreach ($data as $k=>$v){
  1343. $img = explode(',',$v['images']);
  1344. if($img){
  1345. $data[$k]['images'] = $img[0];
  1346. }
  1347. }
  1348. }else{
  1349. $data = Db::name('patrol_record')
  1350. ->where('images','<>','')
  1351. ->where('org_id',$this->orgId)
  1352. ->limit(20)
  1353. ->order('id desc')
  1354. ->select();
  1355. foreach ($data as $k=>$v){
  1356. $img = explode(',',$v['images']);
  1357. if($img){
  1358. $data[$k]['images'] = $img[0];
  1359. }
  1360. }
  1361. }
  1362. if(count($data)>3){
  1363. $key = array_rand($data,4);
  1364. $list[] = $data[$key[0]];
  1365. $list[] = $data[$key[1]];
  1366. $list[] = $data[$key[2]];
  1367. $list[] = $data[$key[3]];
  1368. }
  1369. $eList = isset($list)?$list:$data;
  1370. HelpHander::success($eList);
  1371. }
  1372. public function patrolRecordList(){
  1373. $dlist = [
  1374. date('Y-m-d',strtotime('-6 days')),
  1375. date('Y-m-d',strtotime('-5 days')),
  1376. date('Y-m-d',strtotime('-4 days')),
  1377. date('Y-m-d',strtotime('-3 days')),
  1378. date('Y-m-d',strtotime('-2 days')),
  1379. date('Y-m-d',strtotime('-1 days')),
  1380. date('Y-m-d'),
  1381. ];
  1382. $date = [];
  1383. $yCount = [];
  1384. $y2Count = [];
  1385. $y3Count = [];
  1386. $y4Count = [];
  1387. if($this->orgId == 3){
  1388. foreach ($dlist as $k=>$v){
  1389. $tt = date('Ymd',strtotime($v));
  1390. $count = gtspdb('patrol_record')
  1391. ->where('ORG_ID',$this->spOrgId)
  1392. ->where('CREATE_YYYYMMDD',$tt)
  1393. ->where('PATROL_MODE',1)
  1394. ->count();
  1395. $count2 = gtspdb('patrol_record')
  1396. ->where('ORG_ID',$this->spOrgId)
  1397. ->where('CREATE_YYYYMMDD',$tt)
  1398. ->where('PATROL_MODE',2)
  1399. ->count();
  1400. $count3 = gtspdb('patrol_record')
  1401. ->where('ORG_ID',$this->spOrgId)
  1402. ->where('CREATE_YYYYMMDD',$tt)
  1403. ->where('PATROL_MODE',3)
  1404. ->count();
  1405. $count4 = gtspdb('patrol_record')
  1406. ->where('ORG_ID',$this->spOrgId)
  1407. ->where('CREATE_YYYYMMDD',$tt)
  1408. ->where('PATROL_MODE',4)
  1409. ->count();
  1410. $date[] = date('m-d',strtotime($v));
  1411. $yCount[] = $count;
  1412. $y2Count[] = $count2;
  1413. $y3Count[] = $count3;
  1414. $y4Count[] = $count4;
  1415. }
  1416. }elseif($this->orgId == 24||$this->orgId == 26){
  1417. foreach ($dlist as $k=>$v){
  1418. $tt = date('Ymd',strtotime($v));
  1419. $count = bjydb('patrol_record')
  1420. ->where('org_id',$this->bjOrgId)
  1421. ->where('create_yyyymmdd',$tt)
  1422. ->where('patrol_mode',1)
  1423. ->count();
  1424. $count2 = bjydb('patrol_record')
  1425. ->where('org_id',$this->bjOrgId)
  1426. ->where('create_yyyymmdd',$tt)
  1427. ->where('patrol_mode',2)
  1428. ->count();
  1429. $count3 = bjydb('patrol_record')
  1430. ->where('org_id',$this->bjOrgId)
  1431. ->where('create_yyyymmdd',$tt)
  1432. ->where('patrol_mode',3)
  1433. ->count();
  1434. $count4 = bjydb('patrol_record')
  1435. ->where('org_id',$this->bjOrgId)
  1436. ->where('create_yyyymmdd',$tt)
  1437. ->where('patrol_mode',4)
  1438. ->count();
  1439. $date[] = date('m-d',strtotime($v));
  1440. $yCount[] = $count;
  1441. $y2Count[] = $count2;
  1442. $y3Count[] = $count3;
  1443. $y4Count[] = $count4;
  1444. }
  1445. }else{
  1446. foreach ($dlist as $k=>$v){
  1447. $tt = date('Ymd',strtotime($v));
  1448. $count = Db::name('patrol_record')
  1449. ->where('org_id',$this->orgId)
  1450. ->where('create_yyyymmdd',$tt)
  1451. ->where('patrol_mode',1)
  1452. ->count();
  1453. $count2 =Db::name('patrol_record')
  1454. ->where('org_id',$this->orgId)
  1455. ->where('create_yyyymmdd',$tt)
  1456. ->where('patrol_mode',2)
  1457. ->count();
  1458. $count3 =Db::name('patrol_record')
  1459. ->where('org_id',$this->orgId)
  1460. ->where('create_yyyymmdd',$tt)
  1461. ->where('patrol_mode',3)
  1462. ->count();
  1463. $count4 =Db::name('patrol_record')
  1464. ->where('org_id',$this->orgId)
  1465. ->where('create_yyyymmdd',$tt)
  1466. ->where('patrol_mode',4)
  1467. ->count();
  1468. $date[] = date('m-d',strtotime($v));
  1469. $yCount[] = $count;
  1470. $y2Count[] = $count2;
  1471. $y3Count[] = $count3;
  1472. $y4Count[] = $count4;
  1473. }
  1474. }
  1475. $data = [
  1476. 'date'=>$date,
  1477. 'count1'=>$yCount,
  1478. 'count2'=>$y2Count,
  1479. 'count3'=>$y3Count,
  1480. 'count4'=>$y4Count,
  1481. ];
  1482. HelpHander::success($data);
  1483. }
  1484. public function deviceNhImg(){
  1485. $host = request()->domain(true);
  1486. $img = [
  1487. $host.'/screen/images/nh1.png',
  1488. $host.'/screen/images/nh2.png',
  1489. $host.'/screen/images/nh3.png',
  1490. $host.'/screen/images/nh4.png',
  1491. $host.'/screen/images/nh5.png',
  1492. $host.'/screen/images/nh6.png',
  1493. ];
  1494. if(count($img)>5){
  1495. $key = array_rand($img,6);
  1496. $list[] = $img[$key[0]];
  1497. $list[] = $img[$key[1]];
  1498. $list[] = $img[$key[2]];
  1499. $list[] = $img[$key[3]];
  1500. $list[] = $img[$key[4]];
  1501. $list[] = $img[$key[5]];
  1502. }
  1503. $eList = isset($list)?$list:$img;
  1504. HelpHander::success($eList);
  1505. }
  1506. public function energyList(){
  1507. // $day = date('d');
  1508. // $dayList = [];
  1509. // for ($i=1;$i<=$day;$i++){
  1510. // $dayList[] = $i;
  1511. // }
  1512. // $count1 = $count2 = [];
  1513. // foreach ($dayList as $k=>$v){
  1514. //
  1515. // $count1[] = 0;
  1516. // $count2[] = 0;
  1517. // }
  1518. $dlist = [
  1519. date('Y-m-d',strtotime('-6 days')),
  1520. date('Y-m-d',strtotime('-5 days')),
  1521. date('Y-m-d',strtotime('-4 days')),
  1522. date('Y-m-d',strtotime('-3 days')),
  1523. date('Y-m-d',strtotime('-2 days')),
  1524. date('Y-m-d',strtotime('-1 days')),
  1525. date('Y-m-d'),
  1526. ];
  1527. $title = [];
  1528. foreach ($dlist as $k=>$v){
  1529. $title[] = date('m-d',strtotime($v));
  1530. }
  1531. $data = [
  1532. 'date'=>$title,
  1533. 'count1'=>[5,7,8,6,4,9,3],
  1534. 'count2'=>[7,4,4,7,4,5,7],
  1535. ];
  1536. HelpHander::success($data);
  1537. }
  1538. // 获取所有下级的id集合
  1539. public function getAllNextId($id,$data=[]){
  1540. $pids = DB::name('org')->where('parent_id',$id)->column('id');
  1541. if(count($pids)>0){
  1542. foreach($pids as $v){
  1543. $data[] = $v;
  1544. $data = $this->getAllNextId($v,$data); //注意写$data 返回给上级
  1545. }
  1546. }
  1547. if(count($data)>0){
  1548. return $data;
  1549. }else{
  1550. return [];
  1551. }
  1552. }
  1553. public function patrolList(){
  1554. $orgId = $this->orgId;
  1555. // $orgId = 23;
  1556. $lists = Db::name('patrol_task')
  1557. ->where('org_id',$orgId)
  1558. ->where('del',0)
  1559. ->where('start_time','<=',date('Y-m-d H:i:s',time()+12*60*60))
  1560. ->field('id,title,status')
  1561. ->order('start_time desc,id desc')
  1562. ->limit(20)
  1563. ->select();
  1564. $lists = $lists?$lists:[];
  1565. $data = [];
  1566. foreach ($lists as $k=>$v){
  1567. if($v['status'] == 0){ //0=未执行 1=执行中 2=已完成 3=未完成 5=中断 6=已关闭
  1568. $status = "未执行";
  1569. }else if($v['status'] == 1){
  1570. $status = "执行中";
  1571. }else if($v['status'] == 2){
  1572. $status = "已完成";
  1573. }else if($v['status'] == 3){
  1574. $status = "未完成";
  1575. }else if($v['status'] == 5){
  1576. $status = "中断";
  1577. }else{
  1578. $status = "已关闭";
  1579. }
  1580. $users = Db::name('patrol_task_user')
  1581. ->alias('a')
  1582. ->join('user u','u.id = a.user_id')
  1583. ->where('a.patrol_task_id',$v['id'])
  1584. ->column('real_name');
  1585. $arr = [$v['title'],$status,$users?implode(',',$users):''];
  1586. $data[] = $arr;
  1587. }
  1588. HelpHander::success($data);
  1589. }
  1590. public function reservedList(){
  1591. $lists = Db::name('dinner_reserved')
  1592. ->where('org_id',$this->orgId)
  1593. ->where('del',0)
  1594. ->field('type,title,start_time')
  1595. ->order('start_time desc,id desc')
  1596. ->limit(20)
  1597. ->select();
  1598. $lists = $lists?$lists:[];
  1599. $data = [];
  1600. foreach ($lists as $k=>$v){
  1601. $status = "";
  1602. if($v['type'] == 1){ //1=早餐 2=午餐 3=晚餐
  1603. $status = "早餐";
  1604. }else if($v['type'] == 2){
  1605. $status = "午餐";
  1606. }else if($v['type'] == 3){
  1607. $status = "晚餐";
  1608. }
  1609. $arr = [$status,$v['title'],$v['start_time']];
  1610. $data[] = $arr;
  1611. }
  1612. HelpHander::success($data);
  1613. }
  1614. public function visitorList(){
  1615. $lists = Db::name('visitor_order')
  1616. ->where('org_id',$this->orgId)
  1617. ->where('del',0)
  1618. ->where('type',2)
  1619. ->field('name,access,create_time')
  1620. ->order('id desc')
  1621. ->limit(20)
  1622. ->select();
  1623. $lists = $lists?$lists:[];
  1624. $data = [];
  1625. foreach ($lists as $k=>$v){
  1626. $arr = [$v['name'],$v['access'],$v['create_time']];
  1627. $data[] = $arr;
  1628. }
  1629. HelpHander::success($data);
  1630. }
  1631. public function dailyList(){
  1632. // $zdid = -30;
  1633. // $orgId = 23;
  1634. // if($this->orgId == $zdid){
  1635. // $orgId = $this->orgId;
  1636. // }
  1637. $orgId = $this->orgId;
  1638. $map[] = ['enable', '=', 1];
  1639. $map[] = ['org_id', '=', $orgId];
  1640. $map[] = ['del', '=', 0];
  1641. $lists = Db::name('daily')->where($map)->field('id,title')->order('id desc')->select();
  1642. // if($this->orgId == $zdid){
  1643. // $lists = Db::name('daily')->where($map)->field('id,title')->order('id desc')->select();
  1644. // }else{
  1645. // $lists = xcydb('daily')->where($map)->field('id,title')->order('id desc')->select();
  1646. // }
  1647. $hours = model('Daily')->getTimeDaily($this->orgId);
  1648. foreach ($lists as $k=>$v){
  1649. $m = [];
  1650. $m[] = ['org_id','=',$orgId];
  1651. $m[] = ['daily_id','=',$v['id']];
  1652. $m[] = ['create_time','>=',$hours['start']];
  1653. $m[] = ['create_time','<',$hours['end']];
  1654. $count = Db::name('daily_record')->where($m)->count();
  1655. // if($this->orgId == $zdid){
  1656. // $count = Db::name('daily_record')->where($m)->count();
  1657. // }else{
  1658. // $count = xcydb('daily_record')->where($m)->count();
  1659. // }
  1660. $lists[$k]['count'] = $count;
  1661. }
  1662. $lists = list_sort_by($lists,'count','desc');
  1663. if(count($lists) > 12){
  1664. $nlist = [];
  1665. foreach ($lists as $k=>$v){
  1666. if(count($nlist) < 12){
  1667. $nlist[] = $v;
  1668. }
  1669. }
  1670. HelpHander::success($nlist);
  1671. }else{
  1672. HelpHander::success($lists);
  1673. }
  1674. }
  1675. public function elevatorList(){
  1676. $this->orgId = 3;
  1677. $info = Db::name('elevator_record')->where('org_id',$this->orgId)->field('id,img,type,eid,create_time')->order('id desc')->find();
  1678. if($info){
  1679. $title = Db::name('elevator')->where('id',$info['eid'])->value('title');
  1680. $info['title'] = $title;
  1681. }else{
  1682. $info = [
  1683. 'title' => '',
  1684. 'type' => '',
  1685. 'createTime' => '',
  1686. 'img' => ''
  1687. ];
  1688. }
  1689. HelpHander::success($info);
  1690. }
  1691. public function tossList(){
  1692. $this->orgId = 3;
  1693. $info = Db::name('toss')->where('org_id',$this->orgId)->field('id,img,type,address as title,create_time')->order('id desc')->find();
  1694. if(!$info){
  1695. $info = [
  1696. 'title' => '',
  1697. 'type' => '',
  1698. 'createTime' => '',
  1699. 'img' => ''
  1700. ];
  1701. }
  1702. HelpHander::success($info);
  1703. }
  1704. public function parkList(){
  1705. $this->orgId = 3;
  1706. $info = Db::name('park_ill')->where('org_id',$this->orgId)->field('id,img,plate_sn as sn,address,create_time,video,order_id')->order('id desc')->find();
  1707. if(!$info){
  1708. $info = [
  1709. 'sn' => '',
  1710. 'address' => '',
  1711. 'createTime' => '',
  1712. 'img' => '',
  1713. 'video' => '',
  1714. 'orderId' => 0
  1715. ];
  1716. }
  1717. HelpHander::success($info);
  1718. }
  1719. public function getIcons(){
  1720. $icons1 = [
  1721. [
  1722. 'title' => '工程 <br> 报修',
  1723. 'url' => config('app.screen_url').'/home?token='.think_encrypt('6|'.$this->orgId.'|'.time()),
  1724. 'count' => 1,
  1725. ],
  1726. [
  1727. 'title' => '投诉 <br> 处理',
  1728. 'url' => '',
  1729. 'count' => 1,
  1730. ],
  1731. [
  1732. 'title' => '日常 <br> 工作',
  1733. 'url' => config('app.screen_url').'/home?token='.think_encrypt('2|'.$this->orgId.'|'.time()),
  1734. 'count' => 1,
  1735. ],
  1736. [
  1737. 'title' => '中央 <br> 运送',
  1738. 'url' => config('app.screen_url').'/home?token='.think_encrypt('3|'.$this->orgId.'|'.time()),
  1739. 'count' => 1,
  1740. ],
  1741. [
  1742. 'title' => '订单 <br> 管理',
  1743. 'url' => '',
  1744. 'count' => 1,
  1745. ],
  1746. [
  1747. 'title' => '隐患 <br> 上报',
  1748. 'url' => '',
  1749. 'count' => 1,
  1750. ],
  1751. [
  1752. 'title' => '会议室 <br> 预订',
  1753. 'url' => '',
  1754. 'count' => 2,
  1755. ],
  1756. [
  1757. 'title' => '绿化 <br> 养护',
  1758. 'url' => '',
  1759. 'count' => 1,
  1760. ],
  1761. ];
  1762. $icons2 = [
  1763. [
  1764. 'title' => '设备 <br> 台账',
  1765. 'url' => '',
  1766. 'count' => 1,
  1767. ],
  1768. [
  1769. 'title' => '品质 <br> 检查',
  1770. 'url' => '',
  1771. 'count' => 1,
  1772. ],
  1773. [
  1774. 'title' => '巡更 <br> 巡检',
  1775. 'url' => config('app.screen_url').'/home?token='.think_encrypt('2|'.$this->orgId.'|'.time()),
  1776. 'count' => 1,
  1777. ],
  1778. [
  1779. 'title' => '专项 <br> 保洁',
  1780. 'url' => '',
  1781. 'count' => 1,
  1782. ],
  1783. [
  1784. 'title' => '人员 <br> 考勤',
  1785. 'url' => '',
  1786. 'count' => 1,
  1787. ],
  1788. [
  1789. 'title' => '满意度 <br> 调查',
  1790. 'url' => '',
  1791. 'count' => 2,
  1792. ],
  1793. [
  1794. 'title' => '安全 <br> 保卫',
  1795. 'url' => '',
  1796. 'count' => 1,
  1797. ],
  1798. [
  1799. 'title' => '智慧 <br> 抢单',
  1800. 'url' => '',
  1801. 'count' => 1,
  1802. ],
  1803. [
  1804. 'title' => '垃圾 <br> 分类',
  1805. 'url' => '',
  1806. 'count' => 1,
  1807. ],
  1808. ];
  1809. $icons3 = [
  1810. [
  1811. 'title' => '医废 <br> 管理',
  1812. 'url' => config('app.screen_url').'/home?token='.think_encrypt('4|'.$this->orgId.'|'.time()),
  1813. 'count' => 1,
  1814. ],
  1815. [
  1816. 'title' => '医疗 <br> 陪护',
  1817. 'url' => '',
  1818. 'count' => 1,
  1819. ],
  1820. [
  1821. 'title' => ' 线上 <br> 订餐',
  1822. 'url' => '',
  1823. 'count' => 1,
  1824. ],
  1825. [
  1826. 'title' => '设备 <br> 监控',
  1827. 'url' => '',
  1828. 'count' => 1,
  1829. ],
  1830. [
  1831. 'title' => '耗材 <br> 管理',
  1832. 'url' => '',
  1833. 'count' => 1,
  1834. ],
  1835. [
  1836. 'title' => '中央运送 <br> HIS/LIS对接',
  1837. 'url' => '',
  1838. 'count' => 3,
  1839. ],
  1840. [
  1841. 'title' => '医废监管 <br> 平台对接',
  1842. 'url' => '',
  1843. 'count' => 4,
  1844. ],
  1845. ];
  1846. HelpHander::success(['icons1'=>$icons1,'icons2'=>$icons2,'icons3'=>$icons3]);
  1847. }
  1848. public function canteen(){
  1849. // $weeks = [['product', '进场人次', '出场人次']];
  1850. // for ($i=7;$i>0;$i--){
  1851. // $day = date('Y-m-d',time() - $i*24*60*60);
  1852. // $weeks[] = [$day,mt_rand(200,1000),mt_rand(300,1000)];
  1853. // }
  1854. // $data = [
  1855. // 'in' => 413,
  1856. // 'out' => 489,
  1857. // 'source' => $weeks
  1858. // ];
  1859. $weeks = [['product', '留样数']];
  1860. for ($i=7;$i>0;$i--){
  1861. $day = date('Y-m-d',time() - ($i-1)*24*60*60);
  1862. $kin = Db::name('dinner_reserved')->where('org_id',$this->orgId)->where('del',0)->where('start_time',$day)->count();
  1863. $weeks[] = [$day,$kin];
  1864. }
  1865. $in = Db::name('dinner_reserved')->where('org_id',$this->orgId)->where('del',0)->count();
  1866. $out = Db::name('dinner_health')->where('org_id',$this->orgId)->where('del',0)->where('enable',0)->where('end_time','<',date('Y-m-d'))->count();
  1867. $data = [
  1868. 'in' => $in,
  1869. 'out' => $out,
  1870. 'source' => $weeks
  1871. ];
  1872. HelpHander::success($data);
  1873. }
  1874. /**
  1875. * 任务列表
  1876. */
  1877. public function threejsdata(){
  1878. $map[] = ['type','in',[1,2]];
  1879. $map[] = ['org_id','=',$this->orgId];
  1880. $lists = Db::name('task')->where($map)->order('start_time desc')->select();
  1881. $lists = $lists?$lists:[];
  1882. $news = [];
  1883. foreach ($lists as $k=>$v){
  1884. $arr = [
  1885. 'id' => $v['id'],
  1886. 'start_time' => $v['start_time'],
  1887. 'cate' => 0,
  1888. 'content' => '',
  1889. 'cate_title' => '',
  1890. 'user_name' => '',
  1891. ];
  1892. $arr['user_name'] = Db::name('user')->where('id',$v['user_id'])->value('real_name');
  1893. if($v['type'] == 1){ // 订单
  1894. $order = Db::name('todo')->where('todo_mode','in',[1,2])->where('del',0)->where('id',$v['bus_id'])->find();
  1895. if(!$order || $order['work_type_mode'] == 2 || $order['work_type_mode'] == 4){
  1896. continue;
  1897. }
  1898. $arr['status'] = $order['todo_mode'] == 1?0:1;
  1899. if($order['work_type_mode'] == 1){ // 报修,检查是否有报修地点
  1900. $addressId = Db::name('order_repair')->where('order_id',$order['order_id'])->value('address_id');
  1901. $address = Db::name('address')->where('id',$addressId)->field('id,title,xyz')->find();
  1902. if(!$address){
  1903. continue;
  1904. }
  1905. $xyz = $address['xyz']?explode(',',$address['xyz']):[];
  1906. if(empty($xyz) || $xyz[0] == ''){
  1907. $address['xyz'] = [];
  1908. }else{
  1909. $address['xyz'] = $xyz;
  1910. }
  1911. $arr['cate'] = 1; // 报修
  1912. $arr['cate_title'] = '报修';
  1913. $arr['address'] = $address;
  1914. $arr['content'] = Db::name('orders')->where('id',$order['order_id'])->value('content');
  1915. }
  1916. if($order['work_type_mode'] == 3){ // 运送
  1917. $addr = Db::name('order_convey')->where('order_id',$order['order_id'])->find();
  1918. if(!$addr){
  1919. continue;
  1920. }
  1921. $start = Db::name('address')->where('id',$addr['start'])->field('id,title,xyz')->find();
  1922. $xyz = $start['xyz']?explode(',',$start['xyz']):[];
  1923. if(empty($xyz) || $xyz[0] == ''){
  1924. $start['xyz'] = [];
  1925. }else{
  1926. $start['xyz'] = $xyz;
  1927. }
  1928. $end = Db::name('address')->where('id',$addr['end'])->field('id,title,xyz')->find();
  1929. $xyz = $end['xyz']?explode(',',$end['xyz']):[];
  1930. if(empty($xyz) || $xyz[0] == ''){
  1931. $end['xyz'] = [];
  1932. }else{
  1933. $end['xyz'] = $xyz;
  1934. }
  1935. $cateTitle = Db::name('convey_cate')->where('id',$addr['type'])->value('title');
  1936. $arr['cate'] = 2; // 运送
  1937. $arr['cate_title'] = '运送';
  1938. $arr['start'] = $start;
  1939. $arr['end'] = $end;
  1940. $arr['content'] = '从'.$start['title'].'至'.$end['title'].'执行'.$cateTitle.'任务';
  1941. }
  1942. }else{ // 巡更
  1943. $ptask = Db::name('patrol_task')->where('status','in',[0,1])->where('del',0)->where('id',$v['bus_id'])->find();
  1944. if(!$ptask){
  1945. continue;
  1946. }
  1947. $arr['content'] = $ptask['title'];
  1948. $arr['status'] = $ptask['status'];
  1949. if($ptask['patrol_mode'] == 1){ // 巡更
  1950. $arr['cate'] = 3;
  1951. $arr['cate_title'] = '巡更';
  1952. }else if($ptask['patrol_mode'] == 2){ //巡视
  1953. $arr['cate'] = 4;
  1954. $arr['cate_title'] = '巡视';
  1955. }else if($ptask['patrol_mode'] == 3){ //巡查
  1956. $arr['cate'] = 5;
  1957. $arr['cate_title'] = '巡查';
  1958. }else{ // 巡检
  1959. $arr['cate'] = 6;
  1960. $arr['cate_title'] = '巡检';
  1961. }
  1962. $addrids = Db::name('patrol_task_addr')
  1963. ->where('patrol_task_id',$ptask['id'])
  1964. ->column('address_id');
  1965. $addrs = Db::name('address')->where('id','in',$addrids)->field('id,title,xyz')->select();
  1966. $addrs = $addrs?$addrs:[];
  1967. foreach ($addrs as $kk=>$vv){
  1968. $xyz = $vv['xyz']?explode(',',$vv['xyz']):[];
  1969. if(empty($xyz) || $xyz[0] == ''){
  1970. $addrs[$kk]['xyz'] = [];
  1971. }else{
  1972. $addrs[$kk]['xyz'] = $xyz;
  1973. }
  1974. }
  1975. $arr['addrs'] = $addrs;
  1976. }
  1977. $news[] = $arr;
  1978. }
  1979. $addrList = Db::name('convey_plan_record')->where('org_id',$this->orgId)->field('addr_id,count(*) as count')->group('addr_id')->distinct(true)->select();
  1980. $addrList = $addrList?$addrList:[];
  1981. $newaddrs = [];
  1982. foreach ($addrList as $k=>$v){
  1983. $title = Db::name('address')->where('id',$v['addr_id'])->value('title');
  1984. $newaddrs[] = [$title,$v['count']];
  1985. }
  1986. $data = [
  1987. 'task' => $news,
  1988. 'addrs' => $newaddrs
  1989. ];
  1990. HelpHander::success($data);
  1991. }
  1992. }