index.html 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305
  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-form-item {
  12. float: right;
  13. width: 68%;
  14. }
  15. .layui-tab {
  16. width: 32%;
  17. }
  18. </style>
  19. </head>
  20. <body>
  21. <!-- 页面加载loading -->
  22. <div class="page-loading">
  23. <div class="ball-loader">
  24. <span></span><span></span><span></span><span></span>
  25. </div>
  26. </div>
  27. <!-- 正文开始 -->
  28. <div class="layui-fluid">
  29. <div class="layui-card">
  30. <div class="layui-card-header">
  31. 问题反馈
  32. </div>
  33. <div class="layui-card-body">
  34. <form class="layui-form" lay-filter="filterForm" id="filterForm">
  35. <div class="layui-form toolbar" lay-filter="filterForm">
  36. <div class="layui-form-item">
  37. <div class="layui-row">
  38. <div class="layui-inline text-left">
  39. <label class="layui-form-label width">部门</label>
  40. <div class="layui-input-inline mr0">
  41. <input type="text" id="groupName" name="groupName" value=""
  42. placeholder="点击选择"
  43. class="layui-input" readonly>
  44. <input type="hidden" id="groupId" name="groupId">
  45. <div id="menuContent" class="menuContent">
  46. <ul id="groupTree" class="ztree" style="margin-top:0;"></ul>
  47. </div>
  48. </div>
  49. </div>
  50. <div class="layui-inline text-left ">
  51. <label class="layui-form-label width">日期</label>
  52. <div class="layui-input-inline mr0">
  53. <input type="text" name="dateRange" id="dateRange" placeholder="开始 至 结束"
  54. autocomplete="off" class="layui-input">
  55. </div>
  56. </div>
  57. <div class="layui-inline text-left">
  58. <label class="layui-form-label width">关键字</label>
  59. <div class="layui-input-inline mr0">
  60. <input name="keyword" id="keyword" class="layui-input" type="text"
  61. placeholder="输入关键字"/>
  62. </div>
  63. </div>
  64. <button type="button" lay-filter="formSubSearch" lay-submit
  65. class="layui-btn layui-btn-normal layui-btn-sm"
  66. style="height: 36px;margin-top: -6px">
  67. <i class="layui-icon layui-icon-search"></i>搜索
  68. </button>
  69. <button type="button" id="export_feedback"
  70. class="layui-btn layui-btn-sm layui-btn-normal"
  71. style="height: 36px;margin-top: -6px">
  72. <i class="layui-icon layui-icon-export"></i>导出
  73. </button>
  74. <!-- <a href="javascript:;" id="export_feedback"-->
  75. <!-- class="layui-btn layui-btn-sm layui-btn-normal"><i-->
  76. <!-- class="layui-icon layui-icon-export"></i>Excel 导出</a>-->
  77. </div>
  78. </div>
  79. </div>
  80. </form>
  81. <div class="layui-tab" lay-filter="tabChange">
  82. <ul class="layui-tab-title">
  83. <li class="layui-this">未处理</li>
  84. <li>已处理</li>
  85. </ul>
  86. </div>
  87. <div class="layui-tab-content">
  88. <table class="layui-table" id="datatable" lay-filter="datatable"></table>
  89. </div>
  90. </div>
  91. </div>
  92. </div>
  93. <!-- 表单弹窗 -->
  94. <script type="text/html" id="modelTpl">
  95. <form id="modelForm" lay-filter="modelForm" class="layui-form model-form">
  96. <input hidden name="checkItemDefId" id="checkItemDefId"/>
  97. <input hidden name="checkItemContentDefId"/>
  98. <div class="layui-form-item">
  99. <label class="layui-form-label">标题</label>
  100. <div class="layui-input-block">
  101. <input type="text" class="layui-input" id="checkItemContentDefName" name="checkItemContentDefName"
  102. placeholder="请输入标题" maxlength="128"
  103. lay-verType="tips" lay-verify="required" required/>
  104. </div>
  105. </div>
  106. <div class="layui-form-item">
  107. <label class="layui-form-label">内容</label>
  108. <div class="layui-input-block">
  109. <textarea id="checkItemContentDefDesc" name="checkItemContentDefDesc"
  110. placeholder="最多输入1000个汉字"
  111. class="layui-textarea" maxlength="1000" style="min-height: 200px"></textarea>
  112. </div>
  113. </div>
  114. <div class="layui-form-item text-right">
  115. <button type="button" class="layui-btn" lay-filter="modelSubmit" lay-submit>保存</button>
  116. <button type="button" class="layui-btn layui-btn-primary" ew-event="closePageDialog">取消</button>
  117. </div>
  118. </form>
  119. </script>
  120. <!-- js部分 -->
  121. <script type="text/javascript" src="../../../assets/libs/layui/layui.js"></script>
  122. <script type="text/javascript" src="../../../assets/js/common.js?v=312"></script>
  123. <script>
  124. layui.use(['layer', 'form', 'table', 'admin', 'uParas', '_groupTree', 'laydate', 'element'], function () {
  125. var $ = layui.jquery;
  126. var layer = layui.layer;
  127. var form = layui.form;
  128. var table = layui.table;
  129. var admin = layui.admin;
  130. var uParas = layui.uParas;
  131. var element = layui.element;
  132. var _groupTree = layui._groupTree;
  133. var laydate = layui.laydate;
  134. var resultValue = 0;
  135. laydate.render({
  136. elem: '#dateRange',
  137. format: 'yyyy-MM-dd',
  138. range: true,
  139. type: 'date',
  140. change: function (value, date) { //监听日期被切换
  141. $("#dateRange").val(value);
  142. }
  143. });
  144. // 渲染表格
  145. var insTb = table.render({
  146. elem: '#datatable',
  147. url: uParas.baseUrl + '/ent/feedback/queryPage',
  148. page: true,
  149. height: 610,
  150. method: 'get',
  151. where: {"resultValue": resultValue},
  152. cellMinWidth: 100,
  153. cols: [[
  154. {type: 'numbers', title: '序号', width: 80},
  155. {field: 'spotRemark', sort: false, title: '问题描述'},
  156. {
  157. field: 'attachPath', sort: false, title: '现场照片', templet: function (item) {
  158. return '<img onclick="openImage(\'' + item.attachPath + '\')" style="width: 150px;height: 100px;border-radius: 6px !important;padding-right: 10px;" src="' + item.attachPath + '"/>';
  159. }
  160. },
  161. {field: 'executorGroupName', sort: false, title: '问题所在部门'},
  162. {
  163. field: 'resultValue', sort: false, title: '处理结果', width: 100,
  164. templet: function (d) {
  165. return setResultValue(d);
  166. }
  167. },
  168. {field: 'disposeName', sort: false, width: 110, title: '处理人员'},
  169. {field: 'executorName', sort: false, width: 110, title: '反馈人员'},
  170. {field: 'createdTime', sort: false, width: 150, title: '提交时间'},
  171. {
  172. align: 'center', title: '操作', width: 150,
  173. templet: function (d) {
  174. return setOperation(d);
  175. }
  176. }
  177. ]]
  178. });
  179. /***部门*/
  180. _groupTree.init(insTb);
  181. //tab切换监听
  182. element.on('tab(tabChange)', function (data) {
  183. if (data.index == 0) {
  184. resultValue = 0;
  185. } else if (data.index == 1) {
  186. resultValue = 1;
  187. }
  188. console.log(resultValue);
  189. insTb.reload({where: {"action": resultValue, "resultValue": resultValue}}, 'data');
  190. layer.closeAll('loading');
  191. });
  192. //状态
  193. function setResultValue(row) {
  194. if (row.resultValue == 0) {
  195. return "未处理";
  196. } else {
  197. return "已处理";
  198. }
  199. }
  200. //操作
  201. function setOperation(row) {
  202. var html = '';
  203. if (row.resultValue == 0) {
  204. html += '<a class="layui-btn layui-btn-xs bg-c-orange" lay-event="handle">处理</a>';
  205. html += '<a class="layui-btn layui-btn-xs layui-btn-danger" lay-event="delete">删除</a>';
  206. } else {
  207. html += '<a class="layui-btn layui-btn-xs bg-c-add" lay-event="detail" >详情</a>';
  208. html += '<a class="layui-btn layui-btn-xs bg-c-add" lay-event="hdDetail" >隐患追踪</a>';
  209. }
  210. return html;
  211. }
  212. // 工具条点击事件
  213. table.on('tool(datatable)', function (obj) {
  214. var data = obj.data;
  215. var layEvent = obj.event;
  216. if (layEvent == 'handle') { // 处理
  217. goDetail(data);
  218. } else if (layEvent == 'detail') { // 详情
  219. goDetail(data);
  220. } else if (layEvent == 'hdDetail') { //隐患追踪
  221. detail(data);
  222. } else if (layEvent == 'delete') { //隐患追踪
  223. doDel(data);
  224. }
  225. });
  226. //详情
  227. function detail(data) {
  228. location.href = "./details_hd.html?hdangerId=" + data.feedbackId;
  229. }
  230. function goDetail(data) {
  231. location.href = "./detail.html?feedbackId=" + data.feedbackId;
  232. }
  233. // 搜索
  234. form.on('submit(formSubSearch)', function (data) {
  235. if (($("#keyword").val() != null && $("#keyword").val() != '') || ($("#dateRange").val() != null && $("#dateRange").val() != '')) {
  236. insTb.reload({where: {"keyword": $("#keyword").val(), "dateRange": $("#dateRange").val()}}, 'data');
  237. }
  238. });
  239. // 删除
  240. function doDel(data) {
  241. layer.confirm('确定要删除“' + data.spotRemark + '”吗?', {
  242. skin: 'layui-layer-admin',
  243. shade: .1
  244. }
  245. , function (i) {
  246. layer.close(i);
  247. layer.load();
  248. var url = uParas.baseUrl + '/ent/feedback/delete/' + data.feedbackId;
  249. admin.req(url, {}, function (resp) {
  250. layer.closeAll('loading');
  251. if (resp.code == 1) {
  252. layer.msg(resp.msg);
  253. insTb.reload({where: {"action": resultValue}}, 'data');
  254. } else {
  255. layer.msg(resp.msg);
  256. }
  257. }, 'GET');
  258. });
  259. }
  260. insTb.reload({where: {"action": resultValue}}, 'data');
  261. $('#export_feedback').click(function () {
  262. var index = layer.confirm('确定要导出所有问题反馈内容吗?', {
  263. skin: 'layui-layer-admin',
  264. shade: .1
  265. }, function () {
  266. var cacheUser = layui.data(uParas.tableName);
  267. var groupId = $('#groupId').val();
  268. var keyword = $('#keyword').val();
  269. var dateRange = $('#dateRange').val();
  270. var url = uParas.baseUrl + '/ent/feedback/exportFeedback?resultValue=' + resultValue + '&aId=' + cacheUser.user.aId + '&cId=' + cacheUser.user.cId + '&action=' + resultValue + "&keyword=" + keyword + "&dateRange=" + dateRange;
  271. if (groupId != -1 & groupId != "" && groupId != undefined) {
  272. url += "&gId=" + groupId;
  273. } else {
  274. url += "&gId=" + cacheUser.user.gId;
  275. }
  276. location.href = url;
  277. setTimeout(function () {
  278. layer.close(index);
  279. }, 1000);
  280. })
  281. });
  282. });
  283. </script>
  284. </body>
  285. </html>