system-inform.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342
  1. var pageNo = 1;
  2. var totalPages = 0;
  3. //单位列表
  4. getSystemListDataAjax();
  5. //获取单位列表 ajax请求
  6. function getSystemListDataAjax(queryParam = {}, pageNo = 1) {
  7. queryParam.pageNo = pageNo;
  8. // queryParam.pageSize = 4;
  9. ajaxRequest(UNIT_LIST, "POST", queryParam, function(result) {
  10. let data = result.pageList;
  11. let items = '';
  12. data.forEach(function(item, key) {
  13. let perms = item.parm;
  14. let permSave = JSON.stringify(perms)
  15. delete(item.parm)
  16. var systemStatus = item.status == "1" ? '启动' : '未启动';
  17. items += "<tr>" +
  18. "<td class='status' data-system='" + JSON.stringify(item) + "' data-perm=" + permSave + " data-id=" + item.id + " ></td>" +
  19. "<td>" + item.systemName + "</td>" +
  20. "<td><i class='logo-img' style='background-image:url(" + item.systemLogo + ")'></i></td>" +
  21. "<td>" + item.fullName + "</td>" +
  22. "<td>" + item.forShort + "</td>" +
  23. "<td>" + item.url + "</td>" +
  24. "<td>" + systemStatus + "</td>" +
  25. "<td>" + item.creatMan + "</td>" +
  26. "<td>" + getFormatDate(item.creatTime) + "</td>" +
  27. // "<td>" + item.parm + "</td>" +
  28. "</tr>"
  29. })
  30. $('#systemList').html(items);
  31. totalPages = result.totalPages;
  32. $('#totalPage').html(totalPages); //总共多少页
  33. $('#dataTotal').html(result.totalCount); //总共多少条数据
  34. $('#currentPage').val(pageNo); //当前页面
  35. let pageFrom = (pageNo - 1) * result.pageSize + 1; //开始
  36. let pageTo = result.pageNo * result.pageSize; //结束
  37. pageTo = pageTo > result.totalCount ? result.totalCount : pageTo;
  38. $('#pageFrom').html(pageFrom);
  39. $('#pageTo').html(pageTo);
  40. // 无数据时
  41. if (!data.length) {
  42. $('.pager.has-data').hide()
  43. $('.pager.no-data').show()
  44. } else {
  45. $('.pager.has-data').show()
  46. $('.pager.no-data').hide()
  47. }
  48. if (pageNo < totalPages) {
  49. $('#nextPageButton,#lastPageButton').removeClass('disabled');
  50. } else {
  51. $('#nextPageButton,#lastPageButton').addClass('disabled');
  52. }
  53. if (pageNo === 1) {
  54. $('#firstPageButton,#prevPageButton').addClass('disabled');
  55. } else {
  56. $('#firstPageButton,#prevPageButton').removeClass('disabled');
  57. }
  58. }, function(errorMsg) {
  59. alert("请求数据失败!");
  60. })
  61. }
  62. // /分页刷新按钮
  63. $('.pg-refresh').click(resetForm)
  64. //重置表单
  65. function resetForm() {
  66. pageNo = 1;
  67. getSystemListDataAjax();
  68. }
  69. //分页操作
  70. $('#firstPageButton').on('click', function() {
  71. pageNo = 1;
  72. getSystemListDataAjax(getSearchParamObj(), 1);
  73. })
  74. $('#lastPageButton').on('click', function() {
  75. pageNo = totalPages;
  76. getSystemListDataAjax(getSearchParamObj(), pageNo);
  77. })
  78. $('#prevPageButton').on('click', function() {
  79. pageNo -= 1;
  80. getSystemListDataAjax(getSearchParamObj(), pageNo);
  81. })
  82. $('#nextPageButton').on('click', function() {
  83. pageNo += 1;
  84. getSystemListDataAjax(getSearchParamObj(), pageNo);
  85. })
  86. //拼接搜索条件
  87. function getSearchParamObj() {
  88. let queryParam = {};
  89. return queryParam;
  90. }
  91. /*新增 修改 关闭 弹框*/
  92. var layer = layui.layer;
  93. var layerCreateIndex = '';
  94. var layerUpdateIndex = ''
  95. layui.use('layer', function() {
  96. var layer = layui.layer;
  97. //新增弹框
  98. $('.add').click(function() {
  99. layerCreateIndex = layer.open({
  100. type: 1,
  101. title: false,
  102. closeBtn: 0,
  103. skin: 'yourclass',
  104. area: ['400px', '300px'],
  105. content: $(".addUnitOut"),
  106. success: function() {
  107. $('.clsBtn,.cancel').click(function() {
  108. layer.close(layerCreateIndex);
  109. })
  110. }
  111. })
  112. })
  113. //修改弹框信息
  114. $('.edit').click(function() {
  115. if (!$('.pure-table tr').has('.checked').length) {
  116. layer.msg('请选择一条需要修改的信息!', { icon: 5 });
  117. } else {
  118. let dataId = $('.pure-table tr').find('.checked').data('id');
  119. let systemInfo = $('.pure-table tr').find('.checked').data('system');
  120. let perm = $('.pure-table tr').find('.checked').data('perm');
  121. $('.editSystemOut input[name=systemName]').val(systemInfo.systemName)
  122. $('.editSystemOut input[name=fullName]').val(systemInfo.fullName)
  123. $('.editSystemOut input[name=forShort').val(systemInfo.forShort)
  124. $('.editSystemOut input[name=url').val(systemInfo.url)
  125. $('.editSystemOut input[name=parm').val(perm)
  126. $('.editSystemOut input[name=id]').val(systemInfo.id)
  127. $('.editSystemOut input[name=creatMan').val(systemInfo.creatMan)
  128. $('.editSystemOut select[name=status').val(systemInfo.status)
  129. if (systemInfo.systemLogo) {
  130. $('#systemLogoShow').attr('src', systemInfo.systemLogo)
  131. $('#systemLogoShow').css('display', 'block')
  132. }
  133. layerUpdateIndex = layer.open({
  134. type: 1,
  135. title: false,
  136. closeBtn: 0,
  137. skin: 'yourclass',
  138. area: ['410px', '420px'],
  139. content: $(".editSystemOut"),
  140. success: function() {
  141. $('.clsBtn,.cancel').click(function() {
  142. layer.close(layerUpdateIndex);
  143. })
  144. }
  145. });
  146. $('#editystemFormBox input[name=systemLogoFile]').off('change').on('change', function() {
  147. // 先获取用户上传的文件对象
  148. let fileObj = this.files[0];
  149. // 生成一个文件读取的内置对象
  150. let fileReader = new FileReader();
  151. // 将文件对象传递给内置对象
  152. fileReader.readAsDataURL(fileObj); //这是一个异步执行的过程,所以需要onload回调函数执行读取数据后的操作
  153. // 将读取出文件对象替换到img标签
  154. fileReader.onload = function() { // 等待文件阅读器读取完毕再渲染图片
  155. $('#systemLogoShow').attr('src', fileReader.result)
  156. $('#systemLogoShow').css('display', 'block')
  157. }
  158. uploadImg('systemLogoEdit', function(result) {
  159. result = JSON.parse(result);
  160. if (!result.flag) {
  161. alert('上传图片失败')
  162. return;
  163. }
  164. $('#editystemFormBox input[name=systemLogo]').val(result.data)
  165. });
  166. });
  167. }
  168. })
  169. //删除信息
  170. $('.delete').click(function() {
  171. if (!$('.pure-table tr').has('.checked').length) {
  172. layer.msg('请选择一条需要删除的信息!', { icon: 5 });
  173. } else {
  174. let dataId = $('.pure-table tr').find('.checked').data('id');
  175. ajaxRequest(SYSTEM_DELETE, "POST", { "id": dataId }, function(result) {
  176. $(".pure-table tbody tr.selected").remove()
  177. layer.close(layer.layerCreateIndex);
  178. layer.msg('删除成功!', { icon: 6 });
  179. getSystemListDataAjax()
  180. }, function(errorMsg) {
  181. alert("用户删除失败!");
  182. })
  183. }
  184. })
  185. });
  186. /* 新增发送请求 */
  187. $('#addSystem').click(function() {
  188. //获取表单的值 并转换成对象
  189. let allParam = serializeArrayToObj($("#addSystemFormBox").serializeArray());
  190. //验证数据是否为空
  191. let res = validParamIsEmpty(allParam, {
  192. "systemName": "请填写系统名称",
  193. "fullName": "请填写系统全称",
  194. "forShort": "请填写系统简称",
  195. "url": "请填写官网地址",
  196. "parm": "请填写参数",
  197. });
  198. if (res.code == -1) {
  199. alert(res.msg);
  200. return;
  201. }
  202. //验证文件
  203. // 判断文件是否为空
  204. var file = $("input[name='systemLogo']").val(); //用户文件内容(文件)
  205. if (file == "") {
  206. alert("请选择上传的目标文件! ")
  207. return false;
  208. }
  209. //判断文件类型
  210. var fileExtension = file.substring(file.lastIndexOf(".") + 1).toLowerCase();
  211. let allowExtension = ['jpg', 'jpeg', 'png', 'gif'];
  212. if (allowExtension.indexOf(fileExtension.toLowerCase()) < 0) {
  213. alert("请选择图片文件!");
  214. return false;
  215. }
  216. //上传文件
  217. uploadImg('systemLogoAdd', function(data) {
  218. data = JSON.parse(data); //aa json字符串转对象
  219. //console.log(data.flag + 'flag')
  220. if (data.flag) {
  221. //将返回的路径 拼接到提交的数据对象里
  222. allParam['systemLogo'] = data.data;
  223. ajaxRequest(SYSTEM_ADD, "POST", allParam, function(result) {
  224. layer.close(layer.index);
  225. layer.msg('添加成功!', { icon: 6 });
  226. getSystemListDataAjax();
  227. $('#addSystemFormBox')[0].reset();
  228. }, function(errorMsg) {
  229. alert("系统信息添加失败!");
  230. })
  231. } else {
  232. //这里应该弹出删除失败的 后台返回的原因
  233. alert('上传图片失败');
  234. return;
  235. }
  236. });
  237. })
  238. /* 修改发送请求 */
  239. $('#dataUpdate').click(function() {
  240. //获取表单的值 并转换成对象
  241. let allParam = serializeArrayToObj($("#editystemFormBox").serializeArray());
  242. //验证数据是否为空
  243. let res = validParamIsEmpty(allParam, {
  244. "systemName": "请填写系统名称",
  245. "fullName": "请填写系统全称",
  246. "forShort": "请填写系统简称",
  247. "url": "请填写官网地址",
  248. "parm": "请填写参数",
  249. });
  250. if (res.code == -1) {
  251. alert(res.msg);
  252. return;
  253. }
  254. //验证文件
  255. // 判断文件是否为空
  256. if ($("input[name='systemLogoFile']").val()) {
  257. var file = $("input[name='systemLogoFile']").val(); //用户文件内容(文件)
  258. //判断文件类型
  259. var fileExtension = file.substring(file.lastIndexOf(".") + 1).toLowerCase();
  260. let allowExtension = ['jpg', 'jpeg', 'png', 'gif'];
  261. if (allowExtension.indexOf(fileExtension.toLowerCase()) < 0) {
  262. alert("请选择图片文件!");
  263. return false;
  264. }
  265. }
  266. ajaxRequest(SYSTEM_UPDATE, "POST", allParam, function(result) {
  267. if (result.flag) {
  268. layer.close(layerUpdateIndex);
  269. layer.msg('修改成功!', { icon: 6 });
  270. getSystemListDataAjax();
  271. //将返回的路径 拼接到提交的数据对象里
  272. // layer.close(layer.index);
  273. } else {
  274. //这里应该弹出删除失败的 后台返回的原因
  275. alert("系统信息添加失败!");
  276. alert(result.msg);
  277. return;
  278. }
  279. }, function(errorMsg) {
  280. alert("系统错误!");
  281. return;
  282. })
  283. })