index.html 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  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. <script>
  69. layui.use(['layer', 'form', 'table', 'admin', 'jquery', 'uParas', 'util', 'laydate', 'xmSelect'], function () {
  70. var $ = layui.jquery;
  71. var layer = layui.layer;
  72. var form = layui.form;
  73. var table = layui.table;
  74. var admin = layui.admin;
  75. var laydate = layui.laydate;
  76. var uParas = layui.uParas;
  77. var util = layui.util;
  78. var {cId, aId} = layui.data(uParas.tableName).user;
  79. var xmSelect = layui.xmSelect;
  80. // var _groupTree = layui._groupTree;
  81. var sourceVal = uParas.getUrlParam("sourceVal");
  82. var url1 = uParas.baseUrl + '/ent/plus/conf/list?sourceVal=' + sourceVal;
  83. function toTree(data) {
  84. data.forEach(function (item) {
  85. delete item.children
  86. item.name = item.name
  87. item.value = item.confId
  88. })
  89. var map = {}
  90. data.forEach(function (item) {
  91. map[item.confId] = item
  92. })
  93. var val = []
  94. data.forEach(function (item) {
  95. var parent = map[item.parentId]
  96. if (parent) {
  97. (parent.children || (parent.children = [])).push(item)
  98. } else {
  99. val.push(item)
  100. }
  101. })
  102. return val
  103. }
  104. var gridSelect, siteSelect;
  105. var treeData = [];
  106. admin.req(url1, {}, function (resp) {
  107. if (resp.code == 1) {
  108. resp.data.forEach(function (item) {
  109. item.name = item.name
  110. item.value = item.confId
  111. })
  112. var temp = JSON.parse(JSON.stringify(resp.data))
  113. var tempData = resp.data.filter(function (item) {
  114. return item.type === 1;
  115. })
  116. var treeData = toTree(temp);
  117. gridSelect = xmSelect.render({
  118. el: '#grid',
  119. radio: true,
  120. toolbar: {show: true},
  121. on: function (data) {
  122. //arr: 当前多选已选中的数据
  123. var arr = data.arr;
  124. if (arr.length > 0) {
  125. $('#gridId').val(arr[0].value);
  126. var childrenData = [];
  127. for (var i = 0; i < treeData.length; i++) {
  128. if (treeData[i].value === arr[0].value) {
  129. childrenData = treeData[i].children;
  130. }
  131. }
  132. initSiteSelect(childrenData);
  133. } else {
  134. $('#gridId').val("");
  135. initSiteSelect();
  136. }
  137. },
  138. data: tempData
  139. })
  140. }
  141. }, 'GET');
  142. function initSiteSelect(data = []) {
  143. siteSelect = xmSelect.render({
  144. el: '#site',
  145. radio: true,
  146. toolbar: {show: true},
  147. on: function (data) {
  148. //arr: 当前多选已选中的数据
  149. var arr = data.arr;
  150. if (arr.length > 0) {
  151. $('#parkId').val(arr[0].value);
  152. } else {
  153. $('#parkId').val("");
  154. }
  155. },
  156. data: data
  157. })
  158. }
  159. initSiteSelect();
  160. /*日期*/
  161. laydate.render({
  162. elem: '#hiddenTime',
  163. format: 'yyyy-MM-dd',
  164. range: '至',
  165. type: 'date',
  166. });
  167. // 搜索
  168. form.on('submit(formSubSearch)', function (data) {
  169. /*更新数据表*/
  170. // var data = {"hiddenTime":$("#hiddenTime").val(),"groupId":$("#selectedGroup").val()};
  171. var {field} = data;
  172. var timeArr = null;
  173. var timeArr = field.hiddenTime != "" ? field.hiddenTime.split("至") : null;
  174. var reqData = {
  175. parentId: field.gridId,
  176. startTime: timeArr ? timeArr[0].trim() : "",
  177. endTime: timeArr ? timeArr[1].trim() : "",
  178. confId: field.parkId
  179. }
  180. insTb.reload({where: reqData}, 'data');
  181. });
  182. // 渲染表格数据
  183. var insTb = table.render({
  184. elem: '#datatable',
  185. url: uParas.baseUrl + '/ent/plus/qrHiddenDanger/query',
  186. height: 687,
  187. even: true,
  188. page: true,
  189. toolbar: true,
  190. title: '隐患治理',
  191. cellMinWidth: 100,
  192. where: {
  193. cId: cId,
  194. sourceVal: sourceVal
  195. },
  196. cols: [[
  197. {type: 'numbers', title: '序号'},
  198. {
  199. field: 'hiddenDangerImg', align: 'center', sort: false, title: '图片', width: 70,
  200. templet: function (d) {
  201. return setHdangerImg(d.hiddenDangerImg);
  202. }
  203. },
  204. {field: 'confParentName', sort: false, title: '网格'},
  205. {field: 'confName', sort: false, title: '站点'},
  206. {field: 'createdTime', sort: false, title: '问题发现时间'},
  207. {field: 'hiddenDangerName', sort: false, title: '问题名称'},
  208. {field: 'address', sort: false, title: '管养问题地址'},
  209. {field: 'hdType', sort: false, title: '问题类型'},
  210. {field: 'accountName', align: 'left', sort: false, title: '巡查人'},
  211. ]]
  212. });
  213. /*隐患附件*/
  214. function setHdangerImg(imgUrl) {
  215. var imgSrc = '/assets/images/error.jpg';
  216. if (imgUrl != null && imgUrl != '') {
  217. var hdImg = imgUrl.split(',');
  218. imgSrc = hdImg[0];
  219. }
  220. return '<a lay-event="showImg"><img style="display: inline-block;width: 40px;height: 40px;" src="' + imgSrc + '" ></a>'
  221. }
  222. // 工具条点击事件
  223. table.on('tool(datatable)', function (obj) {
  224. //debugger
  225. var data = obj.data;
  226. var layEvent = obj.event;
  227. if (layEvent == 'showImg') { // 展示附件
  228. var hdImg = data.hiddenDangerImg.split(',');
  229. showImg(hdImg[0]);
  230. }
  231. });
  232. function showImg(src) {
  233. openImage(src);
  234. }
  235. });
  236. </script>
  237. </body>
  238. </html>