user_manage.js 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532
  1. //@ sourceURL=user_manage.js
  2. $(function () {
  3. $("input").each(function () {
  4. this.onkeydown = function (e) { // 监听键盘事件
  5. var theEvent = window.event || e;
  6. var code = theEvent.keyCode || theEvent.which;
  7. if (code == 13) {//回车事件
  8. $("#btn_search").click(); //触发搜索按钮点击事件
  9. }
  10. }
  11. });
  12. //新增按钮点击事件
  13. $("#btn_add").click(function (t) {
  14. $("#editModal").modal();
  15. $("#classTitle").text("新增");
  16. clearInput();
  17. });
  18. //角色保存按钮点击事件
  19. $("#btn_save").click(function (t) {
  20. var validatorResult = validator.checkAll($("#editUserForm"));
  21. if (validatorResult) {
  22. saveUser();
  23. }
  24. });
  25. //用户与科室关系保存按钮点击事件
  26. $("#btn_saveManagerDept").click(function (t) {
  27. var validatorResult = validator.checkAll($("#managerDeptForm"));
  28. if (validatorResult) {
  29. saveUserDepetNos();
  30. }
  31. });
  32. //工作照保存按钮点击事件
  33. $("#btn_save_client_image").click(function (t) {
  34. $.ajax({
  35. type: "POST",
  36. contentType: "application/json;charset=UTF-8",
  37. url: "/thmz/modify-user-for-other",
  38. dataType: 'json',
  39. data: JSON.stringify({"id": $("#userId").val(), "clientProfileImage": $("#fileIds").val()}),
  40. headers: {'Accept': 'application/json', 'Authorization': 'Bearer ' + localStorage.getItem("token")},
  41. success: function (result) {
  42. if (result == '401' || result == 401) {
  43. window.location.href = '/thmz/login/view'
  44. return;
  45. }
  46. if (result.code == 0) {
  47. successMesage(result);
  48. getAllUser();
  49. dropzoneDestroy();
  50. $("#clientImageModal").modal("hide");
  51. } else {
  52. errorMesage(result);
  53. }
  54. }
  55. });
  56. });
  57. //初始化表格数据
  58. getAllUser();
  59. getAllRole();
  60. initDeptSelect();
  61. initCommonFile();
  62. });
  63. //初始化角色下拉
  64. function getAllRole() {
  65. $.ajax({
  66. type: "POST",
  67. url: '/thmz/getAllRole',
  68. contentType: "application/json;charset=UTF-8",
  69. dataType: "json",
  70. headers: {'Accept': 'application/json', 'Authorization': 'Bearer ' + localStorage.getItem("token")},
  71. success: function (res) {
  72. if (res == '401' || res == 401) {
  73. window.location.href = '/thmz/login/view';
  74. return;
  75. }
  76. if (res.code == 0) {
  77. //初始化角色下拉
  78. var arr = res.data;
  79. if (arr != null && arr.length > 0) {
  80. var html = "";
  81. for (var i = 0; i < arr.length; i++) {
  82. html += "<option value='" + arr[i].id + "'>" + arr[i].roleName + "</option>";
  83. }
  84. $('#roleName').html(html);
  85. $('#roleName').selectpicker('refresh');
  86. } else {
  87. errorMesage(res);
  88. }
  89. }
  90. }
  91. });
  92. }
  93. //初始化科室下拉
  94. function initDeptSelect() {
  95. //科室列表
  96. $.ajax({
  97. type: "GET",
  98. url: '/thmz/allUnitCode',
  99. dataType: "json",
  100. headers: {'Accept': 'application/json', 'Authorization': 'Bearer ' + localStorage.getItem("token")},
  101. success: function (data) {
  102. if (data == '401' || data == 401) {
  103. window.location.href = '/thmz/login/view'
  104. return;
  105. }
  106. var html = '';
  107. $.each(data.data, function (commentIndex, comment) {
  108. html += '<option value="' + comment.code + '">' + comment.name + '(' + comment.pyCode + ')</option>';
  109. });
  110. $('#deptNoManagerDept').empty();
  111. $('#deptNoManagerDept').html(html);
  112. $('#deptNoManagerDept').selectpicker('refresh');
  113. }
  114. });
  115. }
  116. /**
  117. * 保存用户数据
  118. */
  119. function saveUser() {
  120. var id = $("#id").val();
  121. var roles = $("#roleName").val();
  122. var roleIds = null;
  123. if (roles.length > 0) {
  124. for (var i = 0; i < roles.length; i++) {
  125. if (roleIds == null) {
  126. roleIds = roles[i];
  127. } else {
  128. roleIds += "," + roles[i];
  129. }
  130. }
  131. }
  132. var data = null;
  133. //修改用户
  134. if (id != null) {
  135. data = JSON.stringify({
  136. user: {
  137. id: id
  138. },
  139. roleIds: roleIds
  140. });
  141. } else {
  142. //新增用户
  143. }
  144. console.log(data);
  145. $.ajax({
  146. type: "POST",
  147. url: '/thmz/saveUserRoleRelation',
  148. contentType: "application/json;charset=UTF-8",
  149. dataType: "json",
  150. headers: {'Accept': 'application/json', 'Authorization': 'Bearer ' + localStorage.getItem("token")},
  151. data: data,
  152. success: function (res) {
  153. if (res == '401' || res == 401) {
  154. window.location.href = '/thmz/login/view'
  155. return;
  156. }
  157. if (res.code == 0) {
  158. $("#editModal").modal("hide");
  159. clearInput();
  160. $('#tb_table').bootstrapTable('refresh');
  161. successMesage(res);
  162. } else {
  163. errorMesage(res);
  164. }
  165. }
  166. });
  167. }
  168. /**
  169. * 清空输入框
  170. */
  171. function clearInput() {
  172. $("#id").val(null);
  173. $("#roleName").attr("lang", '0');
  174. $("#roleName").selectpicker('refresh');
  175. $('#userCode').val(null);
  176. $('#userName').val(null);
  177. }
  178. /**
  179. * 查询角色列表
  180. */
  181. function getAllUser() {
  182. $('#tb_table').bootstrapTable("destroy");
  183. $('#tb_table').bootstrapTable({
  184. url: '/thmz/getUserPage', //请求后台的URL(*)
  185. method: 'post', //请求方式(*)
  186. toolbar: '#toolbar', //工具按钮用哪个容器
  187. striped: true, //是否显示行间隔色
  188. cache: false, //是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)
  189. pagination: true, //是否显示分页(*)
  190. sortable: true, //是否启用排序
  191. sortOrder: "asc", //排序方式
  192. queryParams: queryParams, //传递参数(*)
  193. sidePagination: "server", //分页方式:client客户端分页,server服务端分页(*)
  194. pageNumber: 1, //初始化加载第一页,默认第一页
  195. pageSize: 10, //每页的记录行数(*)
  196. pageList: [10, 25, 50, 100], //可供选择的每页的行数(*)
  197. search: false, //是否显示表格搜索,此搜索是客户端搜索,不会进服务端,所以,个人感觉意义不大
  198. strictSearch: true,
  199. showColumns: false, //是否显示所有的列
  200. showRefresh: false, //是否显示刷新按钮
  201. minimumCountColumns: 2, //最少允许的列数
  202. clickToSelect: true, //是否启用点击选中行
  203. uniqueId: "ID", //每一行的唯一标识,一般为主键列
  204. showToggle: false, //是否显示详细视图和列表视图的切换按钮
  205. cardView: false, //是否显示详细视图
  206. detailView: false,
  207. //rowStyle:rowStyle,//通过自定义函数设置行样式
  208. ajaxOptions: {
  209. headers: {
  210. 'Accept': 'application/json',
  211. 'Authorization': 'Bearer ' + localStorage.getItem("token")
  212. }
  213. },
  214. columns: [
  215. {
  216. title: '操作',
  217. align: "center",
  218. valign: 'middle',
  219. formatter: function (value, row, index) {
  220. var rowData = JSON.stringify(row);
  221. var str = '<button type="button" class="btn btn-primary btn-sm" onclick=editUser(' + rowData + ')>设置角色</button>';
  222. str += '<button type="button" class="btn btn-primary btn-sm" onclick=clientImageModal(' + rowData + ')>设置工作照</button>';
  223. if (row.user != undefined && row.user != null && row.user.clientProfileImage != null && row.user.clientProfileImage > 0) {
  224. str += '<button type="button" class="btn btn-primary btn-sm" onclick=showClientImageModal(' + rowData + ')>预览工作照</button>';
  225. }
  226. str += '<button type="button" class="btn btn-primary btn-sm" onclick=managerDeptNo(' + rowData + ')>设置科室</button>';
  227. str += '<button type="button" class="btn btn-primary btn-sm" onclick=initPassword(' + rowData + ')>初始化密码</button>';
  228. return [str].join('');
  229. }
  230. },
  231. {
  232. field: 'userIdCode',
  233. title: '员工编号',
  234. align: "center",
  235. valign: 'middle',
  236. formatter: function (value, row, index) {
  237. return row.user.userIdCode;
  238. }
  239. },
  240. {
  241. field: 'userCode',
  242. title: '工号',
  243. align: "center",
  244. valign: 'middle',
  245. formatter: function (value, row, index) {
  246. return row.user.userCode;
  247. }
  248. }, {
  249. field: 'userName',
  250. title: '姓名',
  251. align: "center",
  252. valign: 'middle',
  253. formatter: function (value, row, index) {
  254. return row.user.userName;
  255. }
  256. }, {
  257. field: 'roleName',
  258. title: '角色',
  259. align: "center",
  260. valign: 'middle',
  261. formatter: function (value, row, index) {
  262. return row.roleName;
  263. }
  264. }, {
  265. field: 'deptNames',
  266. title: '所属科室',
  267. align: "center",
  268. valign: 'middle',
  269. formatter: function (value, row, index) {
  270. return row.deptNames;
  271. }
  272. }, {
  273. field: 'createTime',
  274. title: '更新时间',
  275. align: "center",
  276. valign: 'middle',
  277. formatter: function (value, row, index) {
  278. return value == null ? "-" : format(value, "yyyy-MM-dd HH:mm:ss");
  279. }
  280. }, {
  281. field: 'createName',
  282. title: '更新人',
  283. align: "center",
  284. valign: 'middle'
  285. }
  286. ],
  287. responseHandler: function (res) {
  288. if (res == '401' || res == 401) {
  289. window.location.href = '/thmz/login/view'
  290. return;
  291. }
  292. var ress = eval(res);
  293. if (ress.code == -1) {
  294. if (ress.message != null && ress.message != '') {
  295. new PNotify({
  296. title: '错误提示',
  297. text: ress.message,
  298. type: 'error',
  299. hide: true,
  300. styling: 'bootstrap3'
  301. });
  302. }
  303. return {
  304. "total": 0,//总页数
  305. "rows": {} //数据
  306. };
  307. }
  308. return {
  309. "total": ress.total,//总页数
  310. "rows": ress.data //数据
  311. };
  312. },
  313. });
  314. }
  315. /**
  316. * 构建列表查询参数
  317. * @param params
  318. * @returns {{mzChargeDetail: {patientId: string | number | string[] | undefined | jQuery, warnDept: string | number | string[] | undefined | jQuery, doctorCode: string | number | string[] | undefined | jQuery, name: string | number | string[] | undefined | jQuery, payMark: number}, beginTime: Date, endTime: Date, pageSize: *, pageIndex: number}}
  319. */
  320. function queryParams(params) {
  321. var temp = {
  322. pageSize: params.limit,
  323. offset: params.offset,
  324. userCode: $("#userCodeSearch").val() == "" ? null : $("#userCodeSearch").val(),
  325. userName: $("#userNameSearch").val() == "" ? null : $("#userNameSearch").val()
  326. };
  327. return temp;
  328. };
  329. /**
  330. * 打开编辑窗口
  331. * @param row
  332. */
  333. function editUser(row) {
  334. console.log('进入editUser',row)
  335. clearInput();
  336. $("#classTitle").text("修改");
  337. $("#id").val(row.user.id);
  338. $("#userName").val(row.user.userName);
  339. $("#userCode").val(row.user.userCode);
  340. row.roleIds != null ? $("#roleName").val(row.roleIds.split(",")) : $("#roleName").val("");
  341. $("#roleName").selectpicker('refresh');
  342. $("#editModal").modal();
  343. }
  344. /**
  345. * 打开查看工作照窗口
  346. * @param row
  347. */
  348. function showClientImageModal(row) {
  349. $("#clientProfileImage").attr("src", null);
  350. if (row.user.clientProfileImage != null && row.user.clientProfileImage > 0) {
  351. $("#showClientImageModal").modal();
  352. imgFun("/thmz/download?id=" + row.user.clientProfileImage, "clientProfileImage");
  353. }
  354. }
  355. /**
  356. * 打开上传工作照窗口
  357. * @param row
  358. */
  359. function clientImageModal(row) {
  360. $("#userId").val(row.user.id);
  361. $("#clientImageModal").modal();
  362. }
  363. /**
  364. * 设置所属科室
  365. * @param row
  366. */
  367. function managerDeptNo(row) {
  368. clearInputManagerDept();
  369. $("#userNameManagerDept").val(row.user.userName);
  370. $("#userCodeManagerDept").val(row.user.userCode);
  371. $("#userIdCodeManagerDept").val(row.user.userIdCode);
  372. row.deptNos != null ? $("#deptNoManagerDept").val(row.deptNos) : $("#deptNoManagerDept").val("");
  373. $("#deptNoManagerDept").selectpicker('refresh');
  374. $("#managerDeptModal").modal();
  375. }
  376. //初始化密码
  377. function initPassword(row) {
  378. if(!stringNotBlank(row.user.userCode)){
  379. errorMesageSimaple('员工号不能为空!')
  380. }
  381. if (!confirm(`请确认是否要初始化密码,初始化后的密码为:thyy${row.user.userCode}`)) {
  382. return;
  383. }
  384. postAjaxJsonHttpRequst("/thmz/initAllPassWord",{userCode:row.user.userCode},true,function (res) {
  385. if (res == '401' || res == 401) {
  386. window.location.href = '/thmz/login/view'
  387. return;
  388. }
  389. if(res.code == 0){
  390. successMesageSimaple(res.message)
  391. }else {
  392. errorMesage(res)
  393. }
  394. })
  395. }
  396. /**
  397. * 清空输入框
  398. */
  399. function clearInputManagerDept() {
  400. $('#userCodeManagerDept').val(null);
  401. $('#userNameManagerDept').val(null);
  402. $('#userIdCodeManagerDept').val(null);
  403. $("#deptNoManagerDept").selectpicker("val", null);
  404. $("#deptNoManagerDept").selectpicker('refresh');
  405. }
  406. /**
  407. * 重置查询表单
  408. */
  409. function resetSearch() {
  410. $("#userCodeSearch").val(null);
  411. $("#userNameSearch").val(null);
  412. }
  413. /**
  414. * 初始化工作照上传框
  415. */
  416. function initCommonFile() {
  417. /**
  418. *初始化文件上传框
  419. */
  420. try {
  421. //设置文件类型 其他文件
  422. localStorage.setItem("fileType", "5");
  423. $("#commonFile").dropzone({
  424. url: "/thmz/upload",
  425. headers: {
  426. 'Accept': 'application/json',
  427. 'Authorization': 'Bearer ' + localStorage.getItem("token"),
  428. 'fileType': localStorage.getItem("fileType")
  429. },
  430. init: function () {
  431. this.on("success", function (file, data) {
  432. if (data == '401' || data == 401) {
  433. window.location.href = '/thmz/login/view'
  434. return;
  435. }
  436. if (data.code == 0) {
  437. var fileIds = data.fileIds;
  438. if (fileIds != null && fileIds.length > 0) {
  439. if (fileIds.indexOf(",") > 0) {
  440. errorMesageSimaple("工作照片不允许上传多张,请取消重新上传!");
  441. return;
  442. }
  443. }
  444. $("#fileIds").val(fileIds);
  445. }
  446. });
  447. },
  448. });
  449. } catch (e) {
  450. console.error("出现一些未知错误")
  451. }
  452. }
  453. /**
  454. * 清空文件上传框
  455. */
  456. function dropzoneDestroy() {
  457. var children = $("#commonFile").children();
  458. if (children != null && children.length > 1) {
  459. for (var i = 0; i < children.length; i++) {
  460. if (i > 0) {
  461. $(children[i]).remove();
  462. }
  463. }
  464. }
  465. $("#commonFile").removeClass("dz-started");
  466. $("#userId").val(null);
  467. $("#fileIds").val(null);
  468. }
  469. /**
  470. * 保存用户与科室关系数据
  471. */
  472. function saveUserDepetNos() {
  473. $.ajax({
  474. type: "POST",
  475. url: '/thmz/saveUserDeptRelation',
  476. contentType: "application/json;charset=UTF-8",
  477. dataType: "json",
  478. headers: {'Accept': 'application/json', 'Authorization': 'Bearer ' + localStorage.getItem("token")},
  479. data: JSON.stringify({
  480. userIdCode: $("#userIdCodeManagerDept").val(),
  481. deptNos: $("#deptNoManagerDept").val()
  482. }),
  483. success: function (res) {
  484. if (res == '401' || res == 401) {
  485. window.location.href = '/thmz/login/view'
  486. return;
  487. }
  488. if (res.code == 0) {
  489. $("#managerDeptModal").modal("hide");
  490. clearInputManagerDept();
  491. $('#tb_table').bootstrapTable('refresh');
  492. successMesage(res);
  493. } else {
  494. errorMesage(res);
  495. }
  496. }
  497. });
  498. }