parkPatrolRecord.html 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  6. <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  7. <title>管养问题随手拍列表</title>
  8. <link rel="stylesheet" href="../../../assets/libs/layui/css/layui.css"/>
  9. <link rel="stylesheet" href="../../../assets/module/admin.css?v=312"/>
  10. <style>
  11. .layui-table-cell {
  12. height: auto;
  13. }
  14. </style>
  15. </head>
  16. <body>
  17. <!-- 页面加载loading -->
  18. <div class="page-loading">
  19. <div class="ball-loader">
  20. <span></span><span></span><span></span><span></span>
  21. </div>
  22. </div>
  23. <!-- 正文开始 -->
  24. <div class="layui-fluid">
  25. <div class="layui-card">
  26. <div class="layui-card-body">
  27. <form class="layui-form m-top10px m-bottom10px" lay-filter="filterForm" id="filterForm">
  28. <div class="layui-form toolbar">
  29. <div class="layui-form-item">
  30. <div class="layui-inline">
  31. <label class="layui-form-label w-auto w-padding">网格:</label>
  32. <div class="layui-input-inline mr0">
  33. <div id="grid"></div>
  34. <input type="hidden" name="gridId" id="gridId">
  35. </div>
  36. </div>
  37. <div class="layui-inline">
  38. <label class="layui-form-label ">站点:</label>
  39. <div class="layui-input-inline mr0">
  40. <div id="site"></div>
  41. <input type="hidden" name="parkId" id="parkId">
  42. </div>
  43. </div>
  44. <div class="layui-inline ">
  45. <label class="layui-form-label">日期</label>
  46. <div class="layui-input-block">
  47. <input type="text" name="hiddenTime" id="hiddenTime" autocomplete="off"
  48. placeholder="开始日期 至 结束日期" class="layui-input">
  49. </div>
  50. </div>
  51. <button type="button" lay-filter="formSubSearch" lay-submit
  52. class="layui-btn layui-btn-normal layui-btn-sm"
  53. style="height: 36px;width:80px;margin-left:15px;margin-top: 0px;position: relative;top: -5px">
  54. <i class="layui-icon"></i>搜索
  55. </button>
  56. </div>
  57. </div>
  58. </form>
  59. <table class="layui-table" id="datatable" lay-filter="datatable"></table>
  60. </div>
  61. </div>
  62. </div>
  63. <!-- js部分 -->
  64. <script type="text/javascript" src="../../../assets/libs/layui/layui.js"></script>
  65. <script type="text/javascript" src="../../../assets/libs/jquery/jquery-3.2.1.min.js"></script>
  66. <script type="text/javascript" src="../../../assets/libs/leftTime/leftTime.js"></script>
  67. <script type="text/javascript" src="../../../assets/js/common.js?v=312"></script>
  68. <!-- 表单弹窗 -->
  69. <script type="text/html" id="distributionModelTpl">
  70. <form id="modelForm" lay-filter="modelForm" class="layui-form model-form">
  71. <input type="hidden" id="patrolId" name="patrolId">
  72. <div class="layui-form-item">
  73. <label class="layui-form-label">岗位</label>
  74. <div class="layui-input-block">
  75. <select id="patrolPId" name="patrolPId" lay-filter="patrolPId" lay-search="" lay-verify="required"
  76. required></select>
  77. </div>
  78. </div>
  79. <div class="layui-form-item">
  80. <label class="layui-form-label">责任人:</label>
  81. <div class="layui-input-block">
  82. <select id="patrolAId" name="patrolAId" lay-verType="tips" class="layui-input-block"
  83. xm-select="patrolAId"
  84. lay-verify="required" required
  85. xm-select-search>
  86. <option value="">直接选择责任人或搜索选择责任人</option>
  87. </select>
  88. </div>
  89. </div>
  90. <div class="layui-form-item text-right">
  91. <button class="layui-btn layui-btn-primary" type="button" ew-event="closePageDialog">取消</button>
  92. <button class="layui-btn" lay-filter="modelSubmit" lay-submit>保存</button>
  93. </div>
  94. </form>
  95. </script>
  96. <script>
  97. layui.use(['layer', 'form', 'table', 'admin', 'jquery', 'uParas', '_groupTree', 'util', 'laydate', 'xmSelect'], function () {
  98. var $ = layui.jquery;
  99. var layer = layui.layer;
  100. var form = layui.form;
  101. var table = layui.table;
  102. var admin = layui.admin;
  103. var laydate = layui.laydate;
  104. var uParas = layui.uParas;
  105. var util = layui.util;
  106. var _groupTree = layui._groupTree;
  107. var xmSelect = layui.xmSelect;
  108. var {cId, aId, gId, itIsAdmin} = layui.data(uParas.tableName).user;
  109. if (itIsAdmin) {
  110. console.log(itIsAdmin);
  111. }
  112. form.on('select(patrolPId)', function (data) {
  113. var patrolPIdVal = $('#patrolPId').val()
  114. // uParas.initFormSelects("patrolAId", "/admin/common/getAccountByGroupAndPId?groupId="+ gId +"&positionId=" + patrolPIdVal, "accountRealName", "aId");
  115. uParas.initSimpleSelect("patrolAId", 'modelForm', "/admin/common/getAccountByGroupAndPId?positionId=" + patrolPIdVal, "accountRealName", "aId");
  116. });
  117. var url1 = uParas.baseUrl + '/ent/parkConf/list';
  118. function toTree(data) {
  119. data.forEach(function (item) {
  120. delete item.children
  121. item.name = item.parkName
  122. item.value = item.parkId
  123. })
  124. var map = {}
  125. data.forEach(function (item) {
  126. map[item.parkId] = item
  127. })
  128. var val = []
  129. data.forEach(function (item) {
  130. var parent = map[item.parkParentId]
  131. if (parent) {
  132. (parent.children || (parent.children = [])).push(item)
  133. } else {
  134. val.push(item)
  135. }
  136. })
  137. return val
  138. }
  139. var gridSelect, siteSelect;
  140. var treeData = [];
  141. admin.req(url1, {}, function (resp) {
  142. if (resp.code == 1) {
  143. resp.data.forEach(function (item) {
  144. item.name = item.parkName
  145. item.value = item.parkId
  146. })
  147. var temp = JSON.parse(JSON.stringify(resp.data))
  148. var tempData = resp.data.filter(function (item) {
  149. return item.parkType === 1;
  150. })
  151. var treeData = toTree(temp);
  152. gridSelect = xmSelect.render({
  153. el: '#grid',
  154. radio: true,
  155. toolbar: {show: true},
  156. on: function (data) {
  157. //arr: 当前多选已选中的数据
  158. var arr = data.arr;
  159. if (arr.length > 0) {
  160. $('#gridId').val(arr[0].value);
  161. var childrenData = [];
  162. for (var i = 0; i < treeData.length; i++) {
  163. if (treeData[i].value === arr[0].value) {
  164. childrenData = treeData[i].children;
  165. }
  166. }
  167. initSiteSelect(childrenData);
  168. } else {
  169. $('#gridId').val("");
  170. initSiteSelect();
  171. }
  172. },
  173. data: tempData
  174. })
  175. }
  176. }, 'GET');
  177. function initSiteSelect(data = []) {
  178. siteSelect = xmSelect.render({
  179. el: '#site',
  180. radio: true,
  181. toolbar: {show: true},
  182. on: function (data) {
  183. //arr: 当前多选已选中的数据
  184. var arr = data.arr;
  185. if (arr.length > 0) {
  186. $('#parkId').val(arr[0].value);
  187. } else {
  188. $('#parkId').val("");
  189. }
  190. },
  191. data: data
  192. })
  193. }
  194. initSiteSelect();
  195. /*日期*/
  196. laydate.render({
  197. elem: '#hiddenTime',
  198. format: 'yyyy-MM-dd',
  199. range: '至',
  200. type: 'date',
  201. });
  202. // 搜索
  203. form.on('submit(formSubSearch)', function (data) {
  204. /*更新数据表*/
  205. // var data = {"hiddenTime":$("#hiddenTime").val(),"groupId":$("#selectedGroup").val()};
  206. var {field} = data;
  207. var timeArr = null;
  208. var timeArr = field.hiddenTime != "" ? field.hiddenTime.split("至") : null;
  209. var reqData = {
  210. gridId: field.gridId,
  211. startTime: timeArr ? timeArr[0].trim() : "",
  212. endTime: timeArr ? timeArr[1].trim() : "",
  213. parkId: field.parkId
  214. }
  215. insTb.reload({where: reqData}, 'data');
  216. });
  217. // 渲染表格数据
  218. var insTb = table.render({
  219. elem: '#datatable',
  220. url: uParas.baseUrl + '/ent/parkPatrolRecord/queryUp',
  221. height: 687,
  222. even: true,
  223. page: true,
  224. toolbar: true,
  225. title: '隐患治理',
  226. cellMinWidth: 100,
  227. cols: [[
  228. {type: 'numbers', title: '序号'},
  229. {
  230. field: 'hiddenDangerImg', align: 'center', sort: false, title: '图片', width: 70,
  231. templet: function (d) {
  232. return setHdangerImg(d.hiddenDangerImg);
  233. }
  234. },
  235. {field: 'parkName', sort: false, title: '网格'},
  236. {field: 'siteName', sort: false, title: '站点'},
  237. {field: 'createdTime', sort: false, title: '管养问题发现时间'},
  238. {field: 'hiddenDangerName', sort: false, title: '管养问题名称'},
  239. {field: 'hdType', sort: false, title: '问题类型'},
  240. // {field: 'hiddenDangerDesc' , sort:false , title:'隐患描述'},
  241. // {
  242. // field: 'patrolSource', sort: false, title: '隐患来源', templet: function (d) {
  243. // var result = "";
  244. // // 1 自己发现 2 上报 3 分发 4不合格
  245. // if (d.patrolSource === 1) {
  246. // result = "自行巡检"
  247. // } else if (d.patrolSource === 2) {
  248. // result = "上报"
  249. // } else if (d.patrolSource === 3) {
  250. // result = "分发"
  251. // } else if (d.patrolSource === 4) {
  252. // result = "不合格"
  253. // }
  254. // return result;
  255. // }
  256. // },
  257. {field: 'positionName', align: 'left', sort: false, title: '巡查岗位'},
  258. {field: 'accountName', align: 'left', sort: false, title: '巡查人'},
  259. {field: 'positionUpName', align: 'left', sort: false, title: '上报岗位'},
  260. {field: 'accountUpName', align: 'left', sort: false, title: '上报处理人'},
  261. // {
  262. // field: 'solveType', sort: false, title: '处理类型', templet: function (d) {
  263. // var result = "";
  264. // // 1 自行解决 2 上报
  265. // if(d.solveType === 1){
  266. // result = "自行解决"
  267. // }else if(d.solveType === 2){
  268. // result = "上报"
  269. // }
  270. // return result;
  271. // }
  272. // },
  273. //
  274. // {field: 'solveDesc' , sort:false , title:'解决办法'},
  275. // {field: 'solveImg' , align: 'center',sort:false , title:'解决完成拍照' , width:70,
  276. // templet: function (d) {
  277. // return setHdangerImg(d.solveImg);
  278. // }
  279. // },
  280. {
  281. field: 'status', sort: false, title: '状态', templet: function (d) {
  282. var result = "";
  283. // 1 未解决 2 撤销 3上报 4 解决
  284. if (d.status === 1) {
  285. result = "未解决"
  286. } else if (d.status === 2) {
  287. result = "已撤销"
  288. } else if (d.status === 3) {
  289. result = "已上报"
  290. } else if (d.status === 4) {
  291. result = "已解决"
  292. }
  293. return result;
  294. }
  295. },
  296. {
  297. align: 'left', title: '操作', width: 170,
  298. templet: function (d) {
  299. return setOperation(d);
  300. }
  301. }
  302. ]]
  303. });
  304. /*隐患附件*/
  305. function setHdangerImg(imgUrl) {
  306. var imgSrc = '/assets/images/error.jpg';
  307. if (imgUrl != null && imgUrl != '') {
  308. var hdImg = imgUrl.split(',');
  309. imgSrc = hdImg[0];
  310. }
  311. return '<a lay-event="showImg"><img style="display: inline-block;width: 40px;height: 40px;" src="' + imgSrc + '" ></a>'
  312. }
  313. /*操作*/
  314. function setOperation(data) {
  315. var html = '';
  316. var {status} = data;
  317. if (data.patrolPosition == null) {
  318. html += '<a class="layui-btn layui-btn-normal layui-btn-xs" lay-event="distribution">分配</a>';
  319. }
  320. html += `
  321. <a class="layui-btn layui-btn-primary layui-btn-xs" lay-event="detail" >详情</a>
  322. <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>
  323. `;
  324. return html;
  325. }
  326. // 工具条点击事件
  327. table.on('tool(datatable)', function (obj) {
  328. //debugger
  329. var data = obj.data;
  330. var layEvent = obj.event;
  331. if (layEvent == 'del') { // 删除
  332. doDel(data);
  333. } else if (layEvent == 'distribution') { // 分配
  334. showDistributionModel(data);
  335. } else if (layEvent == 'detail') { // 详情
  336. detail(data);
  337. } else if (layEvent == 'showImg') { // 展示附件
  338. var hdImg = data.hiddenDangerImg.split(',');
  339. showImg(hdImg[0]);
  340. }
  341. });
  342. // 显示分配隐患弹窗
  343. function showDistributionModel(data) {
  344. admin.open({
  345. type: 1,
  346. title: '分配问题',
  347. content: $('#distributionModelTpl').html(),
  348. success: function (layero, dIndex) {
  349. // admin/common/getAccountByGroupAndPId?groupId=20001418&positionId=
  350. //admin/common/getPositionByGroup?groupId=20001418
  351. //admin/common/getAccountByGroupAndPId?groupId=20001418&positionId=20000053
  352. if (itIsAdmin) {
  353. uParas.initSimpleSelect("patrolPId", 'modelForm', "/ent/position/getList", "positionTitle", "pId");
  354. } else {
  355. uParas.initSimpleSelect("patrolPId", 'modelForm', "/api/park/getDownPosition", "positionTitle", "pId");
  356. }
  357. // uParas.initSimpleSelect("patrolAId",'modelForm', "/ent/groupAccount/queryAccounts", "accountRealName", "aId");
  358. form.val('modelForm', {
  359. patrolId: data.patrolId,
  360. });
  361. var url = uParas.baseUrl + '/ent/parkPatrolRecord/distributeHd';
  362. // 保存处理
  363. form.on('submit(modelSubmit)', function (data) {
  364. layer.load();
  365. console.log(data);
  366. admin.req(url, data.field, function (resp) {
  367. layer.closeAll('loading');
  368. if (resp.code == 1) {
  369. layer.close(dIndex);
  370. layer.msg(resp.msg);
  371. insTb.reload({}, 'data');
  372. } else {
  373. layer.msg(resp.msg);
  374. }
  375. }, 'POST');
  376. return false;
  377. });
  378. }
  379. });
  380. }
  381. // 删除
  382. function doDel(data) {
  383. layer.confirm('确定要删除“' + data.hiddenDangerName + '”吗?', {
  384. skin: 'layui-layer-admin',
  385. shade: .1
  386. }
  387. , function (i) {
  388. layer.close(i);
  389. layer.load();
  390. admin.req(uParas.baseUrl + '/ent/parkPatrolRecord/delById', {
  391. id: data.patrolId
  392. }, function (res) {
  393. layer.closeAll('loading');
  394. if (res.code == 1) {
  395. layer.msg(res.msg);
  396. insTb.reload({}, 'data');
  397. } else {
  398. layer.msg(res.msg);
  399. }
  400. }, 'GET');
  401. });
  402. }
  403. // 编辑页面
  404. function goEditPage(data) {
  405. location.href = "./editHdanger.html?hdangerId=" + data.hdangerId;
  406. }
  407. //详情
  408. function detail(data) {
  409. location.href = "./details.html?patrolId=" + data.patrolId;
  410. }
  411. function showImg(src) {
  412. openImage(src);
  413. }
  414. });
  415. </script>
  416. </body>
  417. </html>