user.js 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  1. $(function() {
  2. var defaultPage = 0;
  3. var defaultSize = 10;
  4. var currentPage = defaultPage;
  5. var currentSize = defaultSize;
  6. var tableFirstLoad = true;
  7. layui.use(["form", "table", "laypage", "layer"], function() {
  8. var table = layui.table;
  9. var laypage = layui.laypage;
  10. var layer = layui.layer;
  11. var form = layui.form;
  12. var title = $("#realName");
  13. var searchTitleKey = "";
  14. function loadUserList(page, size, searchTitle) {
  15. if (page === null || page === undefined) page = defaultPage;
  16. if (size === null || size === undefined) size = defaultSize;
  17. var tableOption = {
  18. elem: "#userList",
  19. height: "full-81",
  20. limit: size,
  21. cols: [
  22. [{
  23. type: "checkbox"
  24. },
  25. {
  26. field: "userName",
  27. title: "账号",
  28. align: "center"
  29. },
  30. {
  31. field: "realName",
  32. title: "姓名",
  33. align: "center"
  34. },
  35. {
  36. field: "password",
  37. title: "密码",
  38. align: "center"
  39. },
  40. {
  41. field: "roleName",
  42. title: "角色名称",
  43. align: "center"
  44. },
  45. {
  46. field: "departmentName",
  47. title: "部门名称",
  48. align: "center"
  49. },
  50. // {
  51. // field: "sex",
  52. // title: "性别",
  53. // align: "center",
  54. // templet: function(d) {
  55. // return d.sex == 0 ? "男" : "女"
  56. // }
  57. // },
  58. {
  59. field: "isEnable",
  60. title: "启用状态",
  61. align: "center",
  62. templet: function(d) {
  63. return d.isEnable === 0 ? "启用": "禁用"
  64. }
  65. },
  66. // {
  67. // field: "img",
  68. // title: "头像",
  69. // align: "center"
  70. // },
  71. {
  72. field: "remark",
  73. title: "备注",
  74. align: "center"
  75. },
  76. {
  77. fixed: "right",
  78. title: "操作",
  79. width: 150,
  80. toolbar: "#operationToolbar",
  81. align: "center"
  82. }
  83. ]
  84. ]
  85. };
  86. if (searchTitle === null || searchTitle === undefined || searchTitle === "") {
  87. fetchJSON("api/user/listpage?departmentId=" + searchTitleKey + "&page=" + (page + 1) + "&size=" + size, {}, "get", function(data) {
  88. if (data.status === 0) {
  89. if (tableFirstLoad) {
  90. tableFirstLoad = false;
  91. laypage.render({
  92. curr: page + 1,
  93. elem: "pagination",
  94. count: data.data.total,
  95. layout: ["count", "prev", "page", "next", "limit", "refresh", "skip"],
  96. jump: function(obj, first) {
  97. if (first) return;
  98. // 分页控件index由1开始 后端分页index由0开始
  99. currentPage = obj.curr - 1;
  100. currentSize = obj.limit;
  101. loadUserList(currentPage, currentSize, searchTitle);
  102. }
  103. });
  104. }
  105. tableOption.data = data.data.list;
  106. table.render(tableOption);
  107. } else {
  108. showMsg(data.msg, 2, 2000);
  109. }
  110. });
  111. } else {
  112. fetchJSON("api/user/getByName?name=" + searchTitle, {}, "get", function(data) {
  113. if (data.status === 0) {
  114. if (tableFirstLoad) {
  115. tableFirstLoad = false;
  116. laypage.render({
  117. curr: page + 1,
  118. elem: "pagination",
  119. count: data.data.length,
  120. layout: ["count", "prev", "page", "next", "limit", "refresh", "skip"],
  121. jump: function(obj, first) {
  122. if (first) return;
  123. // 分页控件index由1开始 后端分页index由0开始
  124. currentPage = obj.curr - 1;
  125. currentSize = obj.limit;
  126. loadUserList(currentPage, currentSize, searchTitle);
  127. }
  128. });
  129. }
  130. tableOption.data = data.data;
  131. table.render(tableOption);
  132. } else {
  133. showMsg(data.msg, 2, 2000);
  134. }
  135. });
  136. }
  137. }
  138. // 首次载入页面 载入默认用户列表
  139. loadUserList();
  140. // 操作栏
  141. // 监听表内工具条
  142. table.on("tool(userList)", function(obj) {
  143. var data = obj.data;
  144. if (data.id === 1) {
  145. showMsg("默认用户不可操作!", 1, 2000);
  146. return;
  147. }
  148. if (obj.event === "edit") {
  149. // 打开编辑框 进行详细编辑
  150. x_admin_show("编辑用户", "../admin/user-edit.html?id=" + data.id, 800, 450, function() {
  151. loadUserList(currentPage, currentSize);
  152. });
  153. } else if (obj.event === "delete") {
  154. // 删除
  155. var ids = [];
  156. ids.push(data.id);
  157. layer.confirm("确认要删除吗?", function() {
  158. fetchJSON("api/user/delete", { ids: ids }, "post", function(data) {
  159. if (data.status === 0) {
  160. showMsg("已删除!");
  161. tableFirstLoad = true;
  162. loadUserList(currentPage, currentSize);
  163. } else {
  164. showMsg(data.msg, 2, 2000);
  165. }
  166. });
  167. });
  168. }
  169. });
  170. $("#searchArticle").on("click", function(e) {
  171. e.preventDefault();
  172. tableFirstLoad = true;
  173. searchTitleKey = title.val().trim();
  174. if (searchTitleKey === "")
  175. loadUserList(0, currentSize);
  176. else
  177. loadUserList(0, currentSize, searchTitleKey);
  178. });
  179. $("#keyword").on("keyup", function(e) {
  180. e.preventDefault();
  181. if (e.keyCode === 13) {
  182. $("#searchArticle").click();
  183. }
  184. });
  185. // 新建用户
  186. $("#addUser").on("click", function(e) {
  187. e.preventDefault();
  188. tableFirstLoad = true;
  189. x_admin_show("新建用户", "../admin/user-add.html?id=0", 800, 400, function() {
  190. loadUserList(currentPage, currentSize);
  191. });
  192. });
  193. // 批量删除
  194. $("#batchDelete").on("click", function(e) {
  195. e.preventDefault();
  196. var checkedData = table.checkStatus("userList").data;
  197. if (checkedData.length === 0) {
  198. showMsg("未选择需要删除的项目", 2, 2000);
  199. return;
  200. }
  201. layer.confirm("确认要删除吗?", function() {
  202. var ids = [];
  203. for (var i = 0; i < checkedData.length; i++) {
  204. if (checkedData[i].id === 1) {
  205. showMsg("默认用户不可操作!", 1, 2000);
  206. continue;
  207. }
  208. ids.push(checkedData[i].id);
  209. }
  210. if (ids.length < 1) return;
  211. fetchJSON("api/user/delete", { ids: ids }, "post", function(data) {
  212. if (data.status === 0) {
  213. showMsg("已删除!");
  214. tableFirstLoad = true;
  215. loadUserList(currentPage, currentSize);
  216. } else {
  217. showMsg(data.msg, 2, 2000);
  218. }
  219. });
  220. });
  221. });
  222. form.on('select(parentId)', function(e) {
  223. tableFirstLoad = true;
  224. searchTitleKey = $("#parentId").val();
  225. loadUserList();
  226. })
  227. });
  228. });