system-inform.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  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. $('#firstPageButton').on('click', function() {
  64. pageNo = 1;
  65. getSystemListDataAjax(getSearchParamObj(), 1);
  66. })
  67. $('#lastPageButton').on('click', function() {
  68. pageNo = totalPages;
  69. getSystemListDataAjax(getSearchParamObj(), pageNo);
  70. })
  71. $('#prevPageButton').on('click', function() {
  72. pageNo -= 1;
  73. getSystemListDataAjax(getSearchParamObj(), pageNo);
  74. })
  75. $('#nextPageButton').on('click', function() {
  76. pageNo += 1;
  77. getSystemListDataAjax(getSearchParamObj(), pageNo);
  78. })
  79. //拼接搜索条件
  80. function getSearchParamObj() {
  81. let queryParam = {};
  82. return queryParam;
  83. }
  84. /*新增 修改 关闭 弹框*/
  85. var layer = layui.layer;
  86. var layerCreateIndex = '';
  87. var layerUpdateIndex = ''
  88. layui.use('layer', function() {
  89. var layer = layui.layer;
  90. //新增弹框
  91. $('.add').click(function() {
  92. layerCreateIndex = layer.open({
  93. type: 1,
  94. title: false,
  95. closeBtn: 0,
  96. shadeClose: true,
  97. skin: 'yourclass',
  98. area: ['400px', '300px'],
  99. content: $(".addUnitOut"),
  100. success: function() {
  101. $('.clsBtn,.cancel').click(function() {
  102. layer.close(layerCreateIndex);
  103. })
  104. }
  105. })
  106. })
  107. //修改弹框信息
  108. $('.edit').click(function() {
  109. if (!$('.pure-table tr').has('.checked').length) {
  110. layer.msg('请选择一条需要修改的信息!', { icon: 5 });
  111. } else {
  112. let dataId = $('.pure-table tr').find('.checked').data('id');
  113. let systemInfo = $('.pure-table tr').find('.checked').data('system');
  114. let perm = $('.pure-table tr').find('.checked').data('perm');
  115. $('.editSystemOut input[name=systemName]').val(systemInfo.systemName)
  116. $('.editSystemOut input[name=fullName]').val(systemInfo.fullName)
  117. $('.editSystemOut input[name=forShort').val(systemInfo.forShort)
  118. $('.editSystemOut input[name=url').val(systemInfo.url)
  119. $('.editSystemOut input[name=parm').val(perm)
  120. $('.editSystemOut input[name=id]').val(systemInfo.id)
  121. $('.editSystemOut input[name=creatMan').val(systemInfo.creatMan)
  122. $('.editSystemOut select[name=status').val(systemInfo.status)
  123. if (systemInfo.systemLogo) {
  124. $('#systemLogoShow').attr('src', systemInfo.systemLogo)
  125. $('#systemLogoShow').css('display', 'block')
  126. }
  127. layerUpdateIndex = layer.open({
  128. type: 1,
  129. title: false,
  130. closeBtn: 0,
  131. shadeClose: true,
  132. skin: 'yourclass',
  133. area: ['410px', '420px'],
  134. content: $(".editSystemOut"),
  135. success: function() {
  136. $('.clsBtn,.cancel').click(function() {
  137. layer.close(layerUpdateIndex);
  138. })
  139. }
  140. });
  141. $('#editystemFormBox input[name=systemLogoFile]').off('change').on('change', function() {
  142. // 先获取用户上传的文件对象
  143. let fileObj = this.files[0];
  144. // 生成一个文件读取的内置对象
  145. let fileReader = new FileReader();
  146. // 将文件对象传递给内置对象
  147. fileReader.readAsDataURL(fileObj); //这是一个异步执行的过程,所以需要onload回调函数执行读取数据后的操作
  148. // 将读取出文件对象替换到img标签
  149. fileReader.onload = function() { // 等待文件阅读器读取完毕再渲染图片
  150. $('#systemLogoShow').attr('src', fileReader.result)
  151. $('#systemLogoShow').css('display', 'block')
  152. }
  153. uploadImg('systemLogoEdit', function(result) {
  154. result = JSON.parse(result);
  155. if (!result.flag) {
  156. alert('上传图片失败')
  157. return;
  158. }
  159. $('#editystemFormBox input[name=systemLogo]').val(result.data)
  160. });
  161. });
  162. }
  163. })
  164. //删除信息
  165. $('.delete').click(function() {
  166. if (!$('.pure-table tr').has('.checked').length) {
  167. layer.msg('请选择一条需要删除的信息!', { icon: 5 });
  168. } else {
  169. let dataId = $('.pure-table tr').find('.checked').data('id');
  170. ajaxRequest(SYSTEM_DELETE, "POST", { "id": dataId }, function(result) {
  171. $(".pure-table tbody tr.selected").remove()
  172. layer.close(layer.layerCreateIndex);
  173. layer.msg('删除成功!', { icon: 6 });
  174. getSystemListDataAjax()
  175. }, function(errorMsg) {
  176. alert("用户删除失败!");
  177. })
  178. }
  179. })
  180. });
  181. /* 新增发送请求 */
  182. $('#addSystem').click(function() {
  183. //获取表单的值 并转换成对象
  184. let allParam = serializeArrayToObj($("#addSystemFormBox").serializeArray());
  185. //验证数据是否为空
  186. let res = validParamIsEmpty(allParam, {
  187. "systemName": "请填写系统名称",
  188. "fullName": "请填写系统全称",
  189. "forShort": "请填写系统简称",
  190. "url": "请填写官网地址",
  191. "parm": "请填写参数",
  192. });
  193. if (res.code == -1) {
  194. alert(res.msg);
  195. return;
  196. }
  197. //验证文件
  198. // 判断文件是否为空
  199. var file = $("input[name='systemLogo']").val(); //用户文件内容(文件)
  200. if (file == "") {
  201. alert("请选择上传的目标文件! ")
  202. return false;
  203. }
  204. //判断文件类型
  205. var fileExtension = file.substring(file.lastIndexOf(".") + 1).toLowerCase();
  206. let allowExtension = ['jpg', 'jpeg', 'png', 'gif'];
  207. if (allowExtension.indexOf(fileExtension.toLowerCase()) < 0) {
  208. alert("请选择图片文件!");
  209. return false;
  210. }
  211. //上传文件
  212. uploadImg('systemLogoAdd', function(data) {
  213. data = JSON.parse(data); //aa json字符串转对象
  214. //console.log(data.flag + 'flag')
  215. if (data.flag) {
  216. //将返回的路径 拼接到提交的数据对象里
  217. allParam['systemLogo'] = data.data;
  218. ajaxRequest(SYSTEM_ADD, "POST", allParam, function(result) {
  219. let data = result.data;
  220. layer.close(layer.index);
  221. layer.msg('添加成功!', { icon: 6 });
  222. getSystemListDataAjax();
  223. }, function(errorMsg) {
  224. alert("系统信息添加失败!");
  225. })
  226. } else {
  227. //这里应该弹出删除失败的 后台返回的原因
  228. alert('上传图片失败');
  229. return;
  230. }
  231. });
  232. // document.getElementById("addSystemFormBox").reset();
  233. $('#addSystemFormBox')[0].reset();
  234. })
  235. /* 修改发送请求 */
  236. $('#dataUpdate').click(function() {
  237. //获取表单的值 并转换成对象
  238. let allParam = serializeArrayToObj($("#editystemFormBox").serializeArray());
  239. //验证数据是否为空
  240. let res = validParamIsEmpty(allParam, {
  241. "systemName": "请填写系统名称",
  242. "fullName": "请填写系统全称",
  243. "forShort": "请填写系统简称",
  244. "url": "请填写官网地址",
  245. "parm": "请填写参数",
  246. });
  247. if (res.code == -1) {
  248. alert(res.msg);
  249. return;
  250. }
  251. //验证文件
  252. // 判断文件是否为空
  253. if ($("input[name='systemLogoFile']").val()) {
  254. var file = $("input[name='systemLogoFile']").val(); //用户文件内容(文件)
  255. //判断文件类型
  256. var fileExtension = file.substring(file.lastIndexOf(".") + 1).toLowerCase();
  257. let allowExtension = ['jpg', 'jpeg', 'png', 'gif'];
  258. if (allowExtension.indexOf(fileExtension.toLowerCase()) < 0) {
  259. alert("请选择图片文件!");
  260. return false;
  261. }
  262. }
  263. ajaxRequest(SYSTEM_UPDATE, "POST", allParam, function(result) {
  264. if (result.flag) {
  265. layer.close(layerUpdateIndex);
  266. layer.msg('修改成功!', { icon: 6 });
  267. getSystemListDataAjax();
  268. //将返回的路径 拼接到提交的数据对象里
  269. // layer.close(layer.index);
  270. } else {
  271. //这里应该弹出删除失败的 后台返回的原因
  272. alert("系统信息添加失败!");
  273. alert(result.msg);
  274. return;
  275. }
  276. }, function(errorMsg) {
  277. alert("系统错误!");
  278. return;
  279. })
  280. })