Digital Office Automation System Backend
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

user.index.1.js 10KB

1 day ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328
  1. $(function() {
  2. // init date tables
  3. var userListTable = $("#user_list").dataTable({
  4. "deferRender": true,
  5. "processing" : true,
  6. "serverSide": true,
  7. "ajax": {
  8. url: base_url + "/user/pageList",
  9. type:"post",
  10. data : function ( d ) {
  11. var obj = {};
  12. obj.username = $('#username').val();
  13. obj.role = $('#role').val();
  14. obj.start = d.start;
  15. obj.length = d.length;
  16. return obj;
  17. }
  18. },
  19. "searching": false,
  20. "ordering": false,
  21. //"scrollX": true, // scroll x,close self-adaption
  22. "columns": [
  23. {
  24. "data": 'id',
  25. "visible" : false,
  26. "width":'10%'
  27. },
  28. {
  29. "data": 'username',
  30. "visible" : true,
  31. "width":'20%'
  32. },
  33. {
  34. "data": 'password',
  35. "visible" : false,
  36. "width":'20%',
  37. "render": function ( data, type, row ) {
  38. return '*********';
  39. }
  40. },
  41. {
  42. "data": 'role',
  43. "visible" : true,
  44. "width":'10%',
  45. "render": function ( data, type, row ) {
  46. if (data == 1) {
  47. return I18n.user_role_admin
  48. } else {
  49. return I18n.user_role_normal
  50. }
  51. }
  52. },
  53. {
  54. "data": 'permission',
  55. "width":'10%',
  56. "visible" : false
  57. },
  58. {
  59. "data": I18n.system_opt ,
  60. "width":'15%',
  61. "render": function ( data, type, row ) {
  62. return function(){
  63. // html
  64. tableData['key'+row.id] = row;
  65. var html = '<p id="'+ row.id +'" >'+
  66. '<button class="btn btn-warning btn-xs update" type="button">'+ I18n.system_opt_edit +'</button> '+
  67. '<button class="btn btn-danger btn-xs delete" type="button">'+ I18n.system_opt_del +'</button> '+
  68. '</p>';
  69. return html;
  70. };
  71. }
  72. }
  73. ],
  74. "language" : {
  75. "sProcessing" : I18n.dataTable_sProcessing ,
  76. "sLengthMenu" : I18n.dataTable_sLengthMenu ,
  77. "sZeroRecords" : I18n.dataTable_sZeroRecords ,
  78. "sInfo" : I18n.dataTable_sInfo ,
  79. "sInfoEmpty" : I18n.dataTable_sInfoEmpty ,
  80. "sInfoFiltered" : I18n.dataTable_sInfoFiltered ,
  81. "sInfoPostFix" : "",
  82. "sSearch" : I18n.dataTable_sSearch ,
  83. "sUrl" : "",
  84. "sEmptyTable" : I18n.dataTable_sEmptyTable ,
  85. "sLoadingRecords" : I18n.dataTable_sLoadingRecords ,
  86. "sInfoThousands" : ",",
  87. "oPaginate" : {
  88. "sFirst" : I18n.dataTable_sFirst ,
  89. "sPrevious" : I18n.dataTable_sPrevious ,
  90. "sNext" : I18n.dataTable_sNext ,
  91. "sLast" : I18n.dataTable_sLast
  92. },
  93. "oAria" : {
  94. "sSortAscending" : I18n.dataTable_sSortAscending ,
  95. "sSortDescending" : I18n.dataTable_sSortDescending
  96. }
  97. }
  98. });
  99. // table data
  100. var tableData = {};
  101. // search btn
  102. $('#searchBtn').on('click', function(){
  103. userListTable.fnDraw();
  104. });
  105. // job operate
  106. $("#user_list").on('click', '.delete',function() {
  107. var id = $(this).parent('p').attr("id");
  108. layer.confirm( I18n.system_ok + I18n.system_opt_del + '?', {
  109. icon: 3,
  110. title: I18n.system_tips ,
  111. btn: [ I18n.system_ok, I18n.system_cancel ]
  112. }, function(index){
  113. layer.close(index);
  114. $.ajax({
  115. type : 'POST',
  116. url : base_url + "/user/remove",
  117. data : {
  118. "id" : id
  119. },
  120. dataType : "json",
  121. success : function(data){
  122. if (data.code == 200) {
  123. layer.msg( I18n.system_success );
  124. userListTable.fnDraw(false);
  125. } else {
  126. layer.msg( data.msg || I18n.system_opt_del + I18n.system_fail );
  127. }
  128. }
  129. });
  130. });
  131. });
  132. // add role
  133. $("#addModal .form input[name=role]").change(function () {
  134. var role = $(this).val();
  135. if (role == 1) {
  136. $("#addModal .form input[name=permission]").parents('.form-group').hide();
  137. } else {
  138. $("#addModal .form input[name=permission]").parents('.form-group').show();
  139. }
  140. $("#addModal .form input[name='permission']").prop("checked",false);
  141. });
  142. jQuery.validator.addMethod("myValid01", function(value, element) {
  143. var length = value.length;
  144. var valid = /^[a-z][a-z0-9]*$/;
  145. return this.optional(element) || valid.test(value);
  146. }, I18n.user_username_valid );
  147. // add
  148. $(".add").click(function(){
  149. $('#addModal').modal({backdrop: false, keyboard: false}).modal('show');
  150. });
  151. var addModalValidate = $("#addModal .form").validate({
  152. errorElement : 'span',
  153. errorClass : 'help-block',
  154. focusInvalid : true,
  155. rules : {
  156. username : {
  157. required : true,
  158. rangelength:[4, 20],
  159. myValid01: true
  160. },
  161. password : {
  162. required : true,
  163. rangelength:[4, 20]
  164. }
  165. },
  166. messages : {
  167. username : {
  168. required : I18n.system_please_input + I18n.user_username,
  169. rangelength: I18n.system_lengh_limit + "[4-20]"
  170. },
  171. password : {
  172. required : I18n.system_please_input + I18n.user_password,
  173. rangelength: I18n.system_lengh_limit + "[4-20]"
  174. }
  175. },
  176. highlight : function(element) {
  177. $(element).closest('.form-group').addClass('has-error');
  178. },
  179. success : function(label) {
  180. label.closest('.form-group').removeClass('has-error');
  181. label.remove();
  182. },
  183. errorPlacement : function(error, element) {
  184. element.parent('div').append(error);
  185. },
  186. submitHandler : function(form) {
  187. var permissionArr = [];
  188. $("#addModal .form input[name=permission]:checked").each(function(){
  189. permissionArr.push($(this).val());
  190. });
  191. var paramData = {
  192. "username": $("#addModal .form input[name=username]").val(),
  193. "password": $("#addModal .form input[name=password]").val(),
  194. "role": $("#addModal .form input[name=role]:checked").val(),
  195. "permission": permissionArr.join(',')
  196. };
  197. $.post(base_url + "/user/add", paramData, function(data, status) {
  198. if (data.code == "200") {
  199. $('#addModal').modal('hide');
  200. layer.msg( I18n.system_add_suc );
  201. userListTable.fnDraw();
  202. } else {
  203. layer.open({
  204. title: I18n.system_tips ,
  205. btn: [ I18n.system_ok ],
  206. content: (data.msg || I18n.system_add_fail),
  207. icon: '2'
  208. });
  209. }
  210. });
  211. }
  212. });
  213. $("#addModal").on('hide.bs.modal', function () {
  214. $("#addModal .form")[0].reset();
  215. addModalValidate.resetForm();
  216. $("#addModal .form .form-group").removeClass("has-error");
  217. $(".remote_panel").show(); // remote
  218. $("#addModal .form input[name=permission]").parents('.form-group').show();
  219. });
  220. // update role
  221. $("#updateModal .form input[name=role]").change(function () {
  222. var role = $(this).val();
  223. if (role == 1) {
  224. $("#updateModal .form input[name=permission]").parents('.form-group').hide();
  225. } else {
  226. $("#updateModal .form input[name=permission]").parents('.form-group').show();
  227. }
  228. $("#updateModal .form input[name='permission']").prop("checked",false);
  229. });
  230. // update
  231. $("#user_list").on('click', '.update',function() {
  232. var id = $(this).parent('p').attr("id");
  233. var row = tableData['key'+id];
  234. // base data
  235. $("#updateModal .form input[name='id']").val( row.id );
  236. $("#updateModal .form input[name='username']").val( row.username );
  237. $("#updateModal .form input[name='password']").val( '' );
  238. $("#updateModal .form input[name='role'][value='"+ row.role +"']").click();
  239. var permissionArr = [];
  240. if (row.permission) {
  241. permissionArr = row.permission.split(",");
  242. }
  243. $("#updateModal .form input[name='permission']").each(function () {
  244. if($.inArray($(this).val(), permissionArr) > -1) {
  245. $(this).prop("checked",true);
  246. } else {
  247. $(this).prop("checked",false);
  248. }
  249. });
  250. // show
  251. $('#updateModal').modal({backdrop: false, keyboard: false}).modal('show');
  252. });
  253. var updateModalValidate = $("#updateModal .form").validate({
  254. errorElement : 'span',
  255. errorClass : 'help-block',
  256. focusInvalid : true,
  257. highlight : function(element) {
  258. $(element).closest('.form-group').addClass('has-error');
  259. },
  260. success : function(label) {
  261. label.closest('.form-group').removeClass('has-error');
  262. label.remove();
  263. },
  264. errorPlacement : function(error, element) {
  265. element.parent('div').append(error);
  266. },
  267. submitHandler : function(form) {
  268. var permissionArr =[];
  269. $("#updateModal .form input[name=permission]:checked").each(function(){
  270. permissionArr.push($(this).val());
  271. });
  272. var paramData = {
  273. "id": $("#updateModal .form input[name=id]").val(),
  274. "username": $("#updateModal .form input[name=username]").val(),
  275. "password": $("#updateModal .form input[name=password]").val(),
  276. "role": $("#updateModal .form input[name=role]:checked").val(),
  277. "permission": permissionArr.join(',')
  278. };
  279. $.post(base_url + "/user/update", paramData, function(data, status) {
  280. if (data.code == "200") {
  281. $('#updateModal').modal('hide');
  282. layer.msg( I18n.system_update_suc );
  283. userListTable.fnDraw();
  284. } else {
  285. layer.open({
  286. title: I18n.system_tips ,
  287. btn: [ I18n.system_ok ],
  288. content: (data.msg || I18n.system_update_fail),
  289. icon: '2'
  290. });
  291. }
  292. });
  293. }
  294. });
  295. $("#updateModal").on('hide.bs.modal', function () {
  296. $("#updateModal .form")[0].reset();
  297. updateModalValidate.resetForm();
  298. $("#updateModal .form .form-group").removeClass("has-error");
  299. $(".remote_panel").show(); // remote
  300. $("#updateModal .form input[name=permission]").parents('.form-group').show();
  301. });
  302. });