user_list.html 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515
  1. {{include "com/inc.html"}}
  2. <!-- Main Header -->
  3. {{include "com/header.html"}}
  4. <!-- Left side column. 权限菜单 -->
  5. {{include "com/menu.html"}}
  6. <div class="content-wrapper">
  7. <section class="content-header">
  8. <h1><small></small></h1>
  9. <ol class="breadcrumb">
  10. {{if .T.stype}}
  11. <li><a href="/front/group"><i class="fa fa-dashboard"></i> 用户组列表</a></li>
  12. <li><a href="#"><i class="fa fa-dashboard"></i> 用户列表</a></li>
  13. {{else}}
  14. <li><a href="#"><i class="fa fa-dashboard"></i> 用户列表</a></li>
  15. {{end}}
  16. </ol>
  17. </section>
  18. <!-- Main content -->
  19. <section class="content">
  20. <div class="row">
  21. <div class="col-xs-12">
  22. <div class="box">
  23. <div class="box-body">
  24. <div class="form-horizontal">
  25. <div class="box-body">
  26. <div class="form-group">
  27. <a class="btn btn-sm btn-success margin" onclick="newMethod()"><i class="fa fa-fw fa-plus fa-lg"></i>新建用户</a>
  28. <a class="btn btn-sm btn-default margin" onclick="bulkSetup(true)">批量开启</a>
  29. <a class="btn btn-sm btn-default margin" onclick="bulkSetup(false)">批量关闭</a>
  30. </div>
  31. </div>
  32. </div>
  33. <table id="dataTable" class="table table-bordered table-hover">
  34. <thead>
  35. <tr>
  36. <th><input type="checkbox" onclick="allSelect(this)" id="allCheckbox"></th>
  37. <th>用户账号</th>
  38. <th>用户姓名</th>
  39. <th>联系方式</th>
  40. <th>用户权限</th>
  41. <th>状态</th>
  42. <th>创建时间</th>
  43. <th>更新时间</th>
  44. <th>操作</th>
  45. </tr>
  46. </thead>
  47. </table>
  48. </div>
  49. <!-- /.box-body -->
  50. </div>
  51. <!-- /.box -->
  52. </div>
  53. </div>
  54. </section>
  55. </div>
  56. {{include "com/footer.html"}}
  57. <div class="modal fade" id="modal-modify-user" tabindex="-1" role="dialog" aria-hidden="true">
  58. <div class="modal-dialog" style="width: 40%">
  59. <div class="modal-content">
  60. <div class="modal-header">
  61. <div class="modal-header">
  62. <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
  63. <div class="edit-info">
  64. <span class="glyphicon glyphicon-alert" aria-hidden="true"></span>
  65. <span class="h4">修改用户信息</span>
  66. </div>
  67. <div class="edit-form">
  68. <hr>
  69. <form class="form-horizontal">
  70. <div class="form-group margin-bottom">
  71. <input type="text" class="form-control" id="user-id" placeholder="用户账号" style="display: none">
  72. <label class="col-sm-3 control-label">用户账号</label>
  73. <div class="col-sm-8">
  74. <input type="text" class="form-control" id="user-login" placeholder="用户账号" readonly="readonly">
  75. </div>
  76. </div>
  77. <div class="form-group margin-bottom">
  78. <label class="col-sm-3 control-label">用户姓名</label>
  79. <div class="col-sm-8">
  80. <input type="text" class="form-control" id="user-name" placeholder="用户名称">
  81. </div>
  82. </div>
  83. <div class="form-group margin-bottom">
  84. <label class="col-sm-3 control-label">联系方式</label>
  85. <div class="col-sm-8">
  86. <input type="text" class="form-control" id="user-contract" placeholder="电话/邮箱">
  87. </div>
  88. </div>
  89. <div class="form-group">
  90. <label class="col-sm-3 control-label">登陆密码</label>
  91. <div class="col-sm-5">
  92. <input type="password" id="user-pwd" readonly="readonly" class="form-control">
  93. </div>
  94. <a id="look-btn" onclick="lookPwd()" style="line-height: 34px;word-break: keep-all;">查看密码</a>
  95. </div>
  96. </form>
  97. </div>
  98. </div>
  99. </div>
  100. <div class="modal-footer">
  101. <input type="button" onclick="modifySave()" class="btn btn-primary saveBtn" value="保存">
  102. <input type="button" onclick="cancelModel()" class="btn btn-default" value="取消">
  103. </div>
  104. </div>
  105. </div><!-- /.modal -->
  106. </div>
  107. <div class="modal fade" id="modal-new-user" tabindex="-1" role="dialog" aria-hidden="true">
  108. <div class="modal-dialog" style="width: 40%">
  109. <div class="modal-content">
  110. <div class="modal-header">
  111. <div class="modal-header">
  112. <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
  113. <div class="edit-info">
  114. <span class="glyphicon glyphicon-alert" aria-hidden="true"></span>
  115. <span class="h4">新增用户信息</span>
  116. </div>
  117. <div class="edit-form">
  118. <hr>
  119. <form class="form-horizontal">
  120. <div class="form-group margin-bottom">
  121. <label class="col-sm-3 control-label"><span style="color:red;">* </span>用户账号</label>
  122. <div class="col-sm-8">
  123. <input type="text" class="form-control" id="user-new-login" placeholder="质检员/普通用户" readonly>
  124. </div>
  125. </div>
  126. <div class="form-group margin-bottom" id="user-new-role">
  127. <label class="col-sm-3 control-label">用户权限</label>
  128. <div class="col-sm-8 radio">
  129. <label class="margin-r-5" id="jy-admin">
  130. <input type="radio" name="role" value="1">剑鱼管理员
  131. </label>
  132. <label class="margin-r-5">
  133. <input type="radio" name="role" value="3">质检员
  134. </label>
  135. <label>
  136. <input type="radio" name="role" value="4" checked>普通用户
  137. </label>
  138. </div>
  139. </div>
  140. <div class="form-group margin-bottom" id="jy-account">
  141. <label class="col-sm-3 control-label"><span style="color:red;">* </span>账号个数</label>
  142. <div class="col-sm-8">
  143. <input type="number" class="form-control" id="user-num" value="1"
  144. required oninput="if(value>50)value=50;if(value.length>2)value=value.slice(0,2);if(value<0)value=0">
  145. </div>
  146. </div>
  147. <div class="form-group margin-bottom">
  148. <label class="col-sm-3 control-label">用户名称</label>
  149. <div class="col-sm-8">
  150. <input type="text" class="form-control" id="user-new-name" placeholder="用户名称">
  151. </div>
  152. </div>
  153. <div class="form-group margin-bottom">
  154. <label class="col-sm-3 control-label">联系方式</label>
  155. <div class="col-sm-8">
  156. <input type="text" class="form-control" id="user-new-contract" placeholder="电话/邮箱">
  157. </div>
  158. </div>
  159. <div class="form-group">
  160. <label class="col-sm-3 control-label"><span style="color:red;">* </span>登陆密码</label>
  161. <div class="col-sm-8">
  162. <input type="password" id="user-new-pwd" readonly="readonly" class="form-control">
  163. </div>
  164. </div>
  165. </form>
  166. </div>
  167. </div>
  168. </div>
  169. <div class="modal-footer">
  170. <input type="button" onclick="newSave()" class="btn btn-primary saveBtn" value="保存">
  171. <input type="button" onclick="cancelModel()" class="btn btn-default" value="取消">
  172. </div>
  173. </div>
  174. </div><!-- /.modal -->
  175. </div>
  176. <script>
  177. let gid = {{ .T.gid }}
  178. let selectIndex = []; //选中的编号
  179. let keyTableChecked = false; //关键词表格数据是否有选中
  180. let keyTableAllChecked = true; //表单数据是否被全选中
  181. let stype = {{ .T.stype }} //页面入口 group: 组,
  182. if (stype === "group") {
  183. menuActive("group");
  184. }else {
  185. menuActive("/front/user");
  186. }
  187. $(function () {
  188. ttable = $('#dataTable').dataTable({
  189. "paging": true,
  190. "lengthChange": false,
  191. "searching": true,
  192. "ordering": false,
  193. "info": true,
  194. "autoWidth": false,
  195. "serverSide": true,
  196. "ajax": {
  197. "url": "/front/user",
  198. "type": "post",
  199. "data": {"gid": gid}
  200. },
  201. "language": {
  202. "url": "/dist/js/dataTables.chinese.lang"
  203. },
  204. "fnDrawCallback": function () {
  205. $("ul.pagination").prepend("&nbsp;&nbsp;&nbsp;转到第 <input type='text' id='changePage' style='width:20px;'> 页 <a type='text' href='javascript:void(0);' id='dataTable-btn' style='text-align:center'>GO</a>");
  206. $('#dataTable-btn').click(function (e) {
  207. var redirectpage = 0
  208. if ($("#changePage").val() && $("#changePage").val() > 0) {
  209. var redirectpage = $("#changePage").val() - 1;
  210. }
  211. ttable.api().page(redirectpage).draw(false);
  212. });
  213. // this.api().column(0).nodes().each(function(cell, i) {
  214. // cell.innerHTML = i + 1;
  215. // });
  216. },
  217. "columns": [
  218. {"data": "", width: "1%", render: function() {
  219. return `<input type="checkbox" name="ckb-keyid" onclick="singleSelect(this)" style="text-align: center">`
  220. }},
  221. {"data": "s_login", width: "9%"},
  222. {"data": "s_name", width: "7%"},
  223. {"data": "s_phone", width: "9%"},
  224. {"data": "i_role", width:"9%", render: function (val) {
  225. if (val === "0") {
  226. return "超级管理员"
  227. }else if (val === "1") {
  228. return "剑鱼管理员"
  229. }else if (val === "2") {
  230. return "管理员"
  231. }else if (val === "3") {
  232. return "质检员"
  233. }else {
  234. return "普通用户"
  235. }
  236. }},
  237. {"data": "i_state", render: function (val, a, row) {
  238. tmp = ""
  239. if(val){
  240. tmp="<a href='#' title='停用' onclick='setupState(\""+row._id+"\",false)'><i class='fa fa-fw fa-circle text-green'></i></a>已启用"
  241. }else{
  242. tmp="<a href='#' title='启用' onclick='setupState(\""+row._id+"\",true)'><i class='fa fa-fw fa-circle text-red'></i></a>未启用"
  243. }
  244. return tmp
  245. }, width: "10%" },
  246. {"data": "i_createtime",width:"9%", render: function (val) {
  247. var dt = new Date()
  248. dt.setTime(parseInt(val) * 1000);
  249. return dt.format("yyyy-MM-dd ")
  250. }},
  251. {"data": "i_updatetime",width:"9%", render: function (val) {
  252. var dt = new Date()
  253. dt.setTime(parseInt(val) * 1000);
  254. return dt.format("yyyy-MM-dd")
  255. }},
  256. {"data": "_id", width:"11%",render: function (val, a, row, pos) {
  257. tmp = '<div>' +
  258. '<a class="btn btn-sm btn-primary" onclick="modifyInfo(\''+pos.row+'\')">设置</a>&nbsp;&nbsp;'+
  259. // '<a class="btn btn-sm btn-danger" onclick="del(\''+val+'\')">删除</a>'+
  260. '</div>';
  261. return tmp
  262. }}
  263. ],
  264. "initComplete": function () {
  265. $("[type=search]").attr('placeholder', "用户账号")
  266. },
  267. });
  268. $("input[name=role]").click(function(){
  269. let v = $(this).val();
  270. if (v === "1") {
  271. $('#user-new-login').removeAttr('readonly').attr('placeholder', '用户账号')
  272. $('#user-new-pwd').removeAttr('readonly').val('')
  273. $('#jy-account').hide()
  274. }else {
  275. $('#user-new-login').attr('readonly', 'readonly').attr('placeholder', '质检员/普通用户')
  276. $('#user-new-pwd').attr('readonly', 'readonly').val('****')
  277. $('#jy-account').show()
  278. if (v === "3") {
  279. if ($('#user-num').val() > "30") {
  280. $('#user-num').val('30')
  281. }
  282. $('#user-num').attr('oninput', 'if(value>10)value=10;if(value.length>2)value=value.slice(0,2);if(value<0)value=0')
  283. }else {
  284. $('#user-num').attr('oninput', 'if(value>50)value=50;if(value.length>2)value=value.slice(0,2);if(value<0)value=0')
  285. }
  286. }
  287. });
  288. });
  289. function setupState(id, v) {
  290. showConfirm("确定修改当前状态?", function() {
  291. $.ajax({
  292. url: "/front/group/user/state",
  293. type: 'POST',
  294. data: {"id": id, "state": v},
  295. success: function (r) {
  296. if (r.rep) {
  297. ttable.api().ajax.reload();
  298. } else {
  299. showTip("状态修改失败");
  300. }
  301. }
  302. })
  303. })
  304. }
  305. //表格全选
  306. function allSelect(obj) {
  307. if ($(obj).is(':checked')) {
  308. selectIndex.length = 0;
  309. keyTableChecked = true;
  310. keyTableAllChecked = true;
  311. $('input[name="ckb-keyid"]').each(function () {
  312. this.checked = true;
  313. selectIndex.push(ttable.fnGetData()[$(this).parents("tr").index()]["_id"]);
  314. })
  315. } else {
  316. selectIndex.length = 0;
  317. keyTableChecked = false;
  318. keyTableAllChecked = false;
  319. $('input[name="ckb-keyid"]').each(function () {
  320. this.checked = false;
  321. })
  322. }
  323. }
  324. //表格单个选中
  325. function singleSelect(obj) {
  326. let tag = true;
  327. selectIndex.length = 0;
  328. $('input[name="ckb-keyid"]').each(function () {
  329. if (this.checked) {
  330. keyTableChecked = true;
  331. selectIndex.push(ttable.fnGetData()[$(this).parents("tr").index()]["_id"]);
  332. }else {
  333. tag = false
  334. }
  335. });
  336. if (tag) {
  337. keyTableAllChecked = true;
  338. $('#allCheckbox').prop("checked", true);
  339. } else {
  340. keyTableAllChecked = false;
  341. $('#allCheckbox').prop("checked", false);
  342. }
  343. }
  344. function modifyInfo(v) {
  345. let tmp = ttable.fnGetData()[v]
  346. $("#user-id").val(tmp["_id"])
  347. $("#user-login").val(tmp["s_login"])
  348. $("#user-pwd").val(tmp["s_password"])
  349. $("#user-name").val(tmp["s_name"])
  350. $("#user-contract").val(tmp["s_phone"])
  351. $('#modal-modify-user').modal("show")
  352. let r = {{(session "user").i_role}}
  353. console.log(r)
  354. if (r == 0 || r == 1 || r == 2){
  355. $("#look-btn").show()
  356. }else {
  357. $("#look-btn").hide()
  358. }
  359. }
  360. function modifySave() {
  361. let id = $("#user-id").val()
  362. let name = $("#user-name").val()
  363. let phone = $("#user-contract").val()
  364. if (name !== "" || phone !== "") {
  365. $.ajax({
  366. url: "/front/group/user/modify",
  367. type: 'POST',
  368. data: {"id": id, "s_name": name, "s_phone": phone},
  369. success: function (r) {
  370. if (r.rep) {
  371. $('#modal-modify-user').modal('hide')
  372. ttable.api().ajax.reload()
  373. } else {
  374. showTip("保存失败");
  375. }
  376. }
  377. })
  378. }
  379. }
  380. function del(id) {
  381. showConfirm("确定删除该用户?", function() {
  382. $.ajax({
  383. url: "/front/group/user/del",
  384. type: 'POST',
  385. data: {"id": id},
  386. success: function (r) {
  387. if (r.rep) {
  388. showTip("删除用户成功")
  389. ttable.api().ajax.reload();
  390. } else {
  391. showTip("删除用户失败");
  392. }
  393. }
  394. })
  395. })
  396. }
  397. function bulkSetup(val) {
  398. if (selectIndex.length > 0) {
  399. showConfirm("确定修改全部状态吗?", function (){
  400. $.ajax({
  401. url: "/front/user/bulks_setup",
  402. type: 'POST',
  403. data: {"ids": selectIndex.toString(), "state": val},
  404. success: function (r) {
  405. if (r.rep) {
  406. $("#allCheckbox").prop("checked", false)
  407. selectIndex.length = 0
  408. ttable.api().ajax.reload()
  409. } else {
  410. showTip("状态修改失败");
  411. }
  412. }
  413. })
  414. })
  415. }else {
  416. showTip("未选中任何用户");
  417. }
  418. }
  419. function cancelModel() {
  420. $('#modal-modify-user').modal('hide')
  421. $('#modal-new-user').modal('hide')
  422. }
  423. function newMethod() {
  424. $('#modal-new-user').modal('show')
  425. if (stype === "group") {
  426. // $('#user-new-role').show()
  427. $('#user-new-pwd').val('****')
  428. $('#jy-admin').hide()
  429. }else {
  430. let role = {{(session "user").i_role}}
  431. if (role === "0" || role === "1") {
  432. // $('#user-new-login').removeAttr('readonly').attr('placeholder', '用户账号')
  433. // $('#user-new-pwd').removeAttr('readonly')
  434. // $('#user-new-role').hide()
  435. $('#user-new-pwd').val('****')
  436. $('#jy-admin').show()
  437. }else {
  438. $('#jy-admin').hide()
  439. $('#user-new-pwd').val('****')
  440. }
  441. }
  442. }
  443. function newSave() {
  444. let login = $("#user-new-login").val()
  445. let name = $("#user-new-name").val()
  446. let phone = $("#user-new-contract").val()
  447. let pwd = $('#user-new-pwd').val()
  448. let size = $('#user-num').val()
  449. let s_role = $("input[name='role']:checked").val()
  450. if (stype === "group") {
  451. if (size === "") {
  452. showTip("账号数量不能为空")
  453. return;
  454. }
  455. }else {
  456. if (s_role === "1") {
  457. if (login === "" || pwd === "") {
  458. showTip("账号或密码不能为空")
  459. return
  460. }
  461. }
  462. }
  463. $.ajax({
  464. url: "/front/group/user/new",
  465. type: "POST",
  466. data: {"login": login,
  467. "gid": gid,
  468. "name": name,
  469. "phone": phone,
  470. "pwd": pwd,
  471. "i_role": s_role,
  472. "size": size,
  473. "stype": stype},
  474. success: function (r) {
  475. if (r.rep) {
  476. $('#modal-new-user').modal('hide')
  477. ttable.api().ajax.reload()
  478. }else {
  479. showMsg(r.msg)
  480. }
  481. }
  482. })
  483. }
  484. function lookPwd() {
  485. let tp = $("#user-pwd").attr('type')
  486. if (tp === "password") {
  487. $("#user-pwd").attr('type', 'text')
  488. }else {
  489. $("#user-pwd").attr('type', 'password')
  490. }
  491. }
  492. </script>