edit.html 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. <!DOCTYPE html>
  2. <html lang="zh" xmlns:th="http://www.thymeleaf.org" >
  3. <head>
  4. <th:block th:include="include :: header('修改角色')" />
  5. <th:block th:include="include :: ztree-css" />
  6. </head>
  7. <body class="white-bg">
  8. <div class="wrapper wrapper-content animated fadeInRight ibox-content">
  9. <form class="form-horizontal m" id="form-role-edit" th:object="${role}">
  10. <input id="roleId" name="roleId" type="hidden" th:field="*{roleId}"/>
  11. <div class="form-group">
  12. <label class="col-sm-3 control-label ">角色名称:</label>
  13. <div class="col-sm-8">
  14. <input class="form-control" type="text" name="roleName" id="roleName" th:field="*{roleName}" required>
  15. </div>
  16. </div>
  17. <div class="form-group">
  18. <label class="col-sm-3 control-label">权限字符:</label>
  19. <div class="col-sm-8">
  20. <input class="form-control" type="text" name="roleKey" id="roleKey" th:field="*{roleKey}" required>
  21. </div>
  22. </div>
  23. <div class="form-group">
  24. <label class="col-sm-3 control-label">显示顺序:</label>
  25. <div class="col-sm-8">
  26. <input class="form-control" type="text" name="roleSort" id="roleSort" th:field="*{roleSort}" required>
  27. </div>
  28. </div>
  29. <div class="form-group">
  30. <label class="col-sm-3 control-label">状态:</label>
  31. <div class="col-sm-8">
  32. <div class="onoffswitch">
  33. <input type="checkbox" th:checked="${role.status == '0' ? true : false}" class="onoffswitch-checkbox" id="status" name="status">
  34. <label class="onoffswitch-label" for="status">
  35. <span class="onoffswitch-inner"></span>
  36. <span class="onoffswitch-switch"></span>
  37. </label>
  38. </div>
  39. </div>
  40. </div>
  41. <div class="form-group">
  42. <label class="col-sm-3 control-label">备注:</label>
  43. <div class="col-sm-8">
  44. <input id="remark" name="remark" class="form-control" type="text" th:field="*{remark}">
  45. </div>
  46. </div>
  47. <div class="form-group">
  48. <label class="col-sm-3 control-label">菜单权限</label>
  49. <div class="col-sm-8">
  50. <div id="menuTrees" class="ztree"></div>
  51. </div>
  52. </div>
  53. </form>
  54. </div>
  55. <th:block th:include="include :: footer" />
  56. <th:block th:include="include :: ztree-js" />
  57. <script type="text/javascript">
  58. $(function() {
  59. var url = ctx + "system/menu/roleMenuTreeData?roleId=" + $("#roleId").val();
  60. var options = {
  61. id: "menuTrees",
  62. url: url,
  63. check: { enable: true },
  64. expandLevel: 0
  65. };
  66. $.tree.init(options);
  67. });
  68. $("#form-role-edit").validate({
  69. onkeyup: false,
  70. rules:{
  71. roleName:{
  72. remote: {
  73. url: ctx + "system/role/checkRoleNameUnique",
  74. type: "post",
  75. dataType: "json",
  76. data: {
  77. "roleId": function() {
  78. return $("#roleId").val();
  79. },
  80. "roleName": function() {
  81. return $.common.trim($("#roleName").val());
  82. }
  83. },
  84. dataFilter: function(data, type) {
  85. return $.validate.unique(data);
  86. }
  87. }
  88. },
  89. roleKey:{
  90. remote: {
  91. url: ctx + "system/role/checkRoleKeyUnique",
  92. type: "post",
  93. dataType: "json",
  94. data: {
  95. "roleId": function() {
  96. return $("#roleId").val();
  97. },
  98. "roleKey": function() {
  99. return $.common.trim($("#roleKey").val());
  100. }
  101. },
  102. dataFilter: function(data, type) {
  103. return $.validate.unique(data);
  104. }
  105. }
  106. },
  107. roleSort:{
  108. digits:true
  109. },
  110. },
  111. messages: {
  112. "roleName": {
  113. remote: "角色名称已经存在"
  114. },
  115. "roleKey": {
  116. remote: "角色权限已经存在"
  117. }
  118. },
  119. focusCleanup: true
  120. });
  121. function edit() {
  122. var roleId = $("input[name='roleId']").val();
  123. var roleName = $("input[name='roleName']").val();
  124. var roleKey = $("input[name='roleKey']").val();
  125. var roleSort = $("input[name='roleSort']").val();
  126. var status = $("input[name='status']").is(':checked') == true ? 0 : 1;
  127. var remark = $("input[name='remark']").val();
  128. var menuIds = $.tree.getCheckedNodes();
  129. $.ajax({
  130. cache : true,
  131. type : "POST",
  132. url : ctx + "system/role/edit",
  133. data : {
  134. "roleId": roleId,
  135. "roleName": roleName,
  136. "roleKey": roleKey,
  137. "roleSort": roleSort,
  138. "status": status,
  139. "remark": remark,
  140. "menuIds": menuIds
  141. },
  142. async : false,
  143. error : function(request) {
  144. $.modal.alertError("系统错误");
  145. },
  146. success : function(data) {
  147. $.operate.successCallback(data);
  148. }
  149. });
  150. }
  151. function submitHandler() {
  152. if ($.validate.form()) {
  153. edit();
  154. }
  155. }
  156. </script>
  157. </body>
  158. </html>