| <div class="layui-fluid layui-anim febs-anim" id="febs-role" lay-title="角色管理"> | 
|     <div class="layui-row layui-col-space8 febs-container"> | 
|         <div class="layui-col-md7 layui-col-sm6 layui-col-xs12"> | 
|             <div class="layui-card"> | 
|                 <div class="layui-card-body febs-table-full"> | 
|                     <form class="layui-form layui-table-form" lay-filter="role-table-form" id="role-table-form"> | 
|                         <div class="layui-row"> | 
|                             <div class="layui-col-md9 layui-col-sm9 layui-col-xs9"> | 
|                                 <div class="layui-form-item"> | 
|                                     <div class="layui-inline"> | 
|                                         <label class="layui-form-label layui-form-label-sm">角色名称</label> | 
|                                         <div class="layui-input-inline"> | 
|                                             <input type="text" name="roleName" autocomplete="off" class="layui-input"> | 
|                                         </div> | 
|                                     </div> | 
|                                 </div> | 
|                             </div> | 
|                             <div class="layui-col-md3 layui-col-sm12 layui-col-xs12 table-action-area"> | 
|                                 <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain  table-action" id="query"> | 
|                                     <i class="layui-icon"></i> | 
|                                 </div> | 
|                                 <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-green-plain  table-action" id="reset"> | 
|                                     <i class="layui-icon"></i> | 
|                                 </div> | 
|                                 <div class="layui-btn layui-btn-sm layui-btn-primary table-action action-more" | 
|                                      shiro:hasAnyPermissions="role:add,user:delete,role:export"> | 
|                                     <i class="layui-icon"></i> | 
|                                 </div> | 
|                             </div> | 
|                         </div> | 
|                     </form> | 
|                     <table lay-filter="roleTable" lay-data="{id: 'roleTable'}"></table> | 
|                 </div> | 
|             </div> | 
|         </div> | 
|         <div class="layui-col-md5 layui-col-sm6 layui-col-xs12"> | 
|             <div class="layui-card"> | 
|                 <div class="layui-card-header" id="form-header">新增角色</div> | 
|                 <div class="layui-card-body febs-table-full"> | 
|                     <form class="layui-form layui-table-form" action="" lay-filter="role-form"> | 
|                         <div class="layui-form-item febs-hide"> | 
|                             <label class="layui-form-label febs-form-item-require">角色ID:</label> | 
|                             <div class="layui-input-block"> | 
|                                 <input type="text" name="roleId" class="layui-input"> | 
|                             </div> | 
|                         </div> | 
|                         <div class="layui-form-item"> | 
|                             <label class="layui-form-label febs-form-item-require">角色名称:</label> | 
|                             <div class="layui-input-block"> | 
|                                 <input type="text" name="roleName" autocomplete="off" class="layui-input" minlength="2" | 
|                                        maxlength="10" lay-verify="range"> | 
|                             </div> | 
|                         </div> | 
|                         <div class="layui-form-item"> | 
|                             <label class="layui-form-label">角色描述:</label> | 
|                             <div class="layui-input-block"> | 
|                                 <textarea name="remark" maxlength="50" class="layui-textarea"></textarea> | 
|                             </div> | 
|                         </div> | 
|                         <div class="layui-form-item"> | 
|                             <label class="layui-form-label">角色权限:</label> | 
|                             <div class="layui-input-block menu-tree" style="margin-top: .8rem;"></div> | 
|                         </div> | 
|                         <div class="layui-form-item febs-hide"> | 
|                             <button type="reset" class="layui-btn" id="reset-form"></button> | 
|                             <button class="layui-btn" lay-submit="" lay-filter="role-form-submit" | 
|                                     id="submit-form"></button> | 
|                         </div> | 
|                     </form> | 
|                 </div> | 
|                 <div class="layui-card-footer"> | 
|                     <button class="layui-btn" id="submit">保存</button> | 
|                 </div> | 
|             </div> | 
|         </div> | 
|     </div> | 
| </div> | 
| <script type="text/html" id="role-option"> | 
|     <span shiro:lacksPermission="role:update,role:delete"> | 
|         <span class="layui-badge-dot febs-bg-orange"></span> 无权限 | 
|     </span> | 
|     <a lay-event="edit" shiro:hasPermission="role:update"><i class="layui-icon febs-edit-area febs-blue"></i></a> | 
|     <a lay-event="del" shiro:hasPermission="role:delete"><i class="layui-icon febs-edit-area febs-red"></i></a> | 
| </script> | 
| <script data-th-inline="none" type="text/javascript"> | 
|     layui.use(['dropdown', 'jquery', 'laydate', 'febs', 'form', 'eleTree', 'table', 'validate'], function () { | 
|         var $ = layui.jquery, | 
|             laydate = layui.laydate, | 
|             febs = layui.febs, | 
|             form = layui.form, | 
|             table = layui.table, | 
|             eleTree = layui.eleTree, | 
|             dropdown = layui.dropdown, | 
|             validate = layui.validate, | 
|             $view = $('#febs-role'), | 
|             $query = $view.find('#query'), | 
|             $reset = $view.find('#reset'), | 
|             $submit = $view.find('#submit'), | 
|             $searchForm = $view.find('#role-table-form'), | 
|             $header = $view.find('#form-header'), | 
|             tableIns; | 
|   | 
|         form.verify(validate); | 
|         form.render(); | 
|   | 
|         initTable(); | 
|   | 
|         laydate.render({ | 
|             elem: '#createTime', | 
|             range: true | 
|         }); | 
|   | 
|         var menuTree = eleTree.render({ | 
|             elem: '.menu-tree', | 
|             url: ctx + 'menu/tree', | 
|             showCheckbox: true, | 
|             where: { | 
|                 "invalidate_ie_cache": new Date() | 
|             }, | 
|             accordion: true, | 
|             checkStrictly: true, | 
|             renderAfterExpand: false, | 
|             request: { | 
|                 name: "title", | 
|                 key: "id", | 
|                 children: "childs", | 
|                 checked: "checked", | 
|                 data: "data" | 
|             }, | 
|             response: { | 
|                 statusName: "code", | 
|                 statusCode: 200, | 
|                 dataName: "data" | 
|             } | 
|         }); | 
|   | 
|         dropdown.render({ | 
|             elem: $view.find('.action-more'), | 
|             click: function (name, elem, event) { | 
|                 var checkStatus = table.checkStatus('roleTable'); | 
|                 if (name === 'add') { | 
|                     resetRoleForm(); | 
|                 } | 
|                 if (name === 'delete') { | 
|                     if (!checkStatus.data.length) { | 
|                         febs.alert.warn('请选择需要删除的角色'); | 
|                     } else { | 
|                         febs.modal.confirm('删除角色', '确定删除所选角色?', function () { | 
|                             var roleIds = []; | 
|                             layui.each(checkStatus.data, function (key, item) { | 
|                                 roleIds.push(item.roleId); | 
|                             }); | 
|                             deleteRoles(roleIds.join(',')); | 
|                         }); | 
|                     } | 
|                 } | 
|                 if (name === 'export') { | 
|                     var params = getQueryParams(); | 
|                     params.pageSize = $view.find(".layui-laypage-limits option:selected").val(); | 
|                     params.pageNum = $view.find(".layui-laypage-em").next().html(); | 
|                     febs.download(ctx + 'role/excel', params, '角色信息表.xlsx'); | 
|                 } | 
|             }, | 
|             options: [{ | 
|                 name: 'add', | 
|                 title: '新增角色', | 
|                 perms: 'role:add' | 
|             }, { | 
|                 name: 'delete', | 
|                 title: '删除角色', | 
|                 perms: 'role:delete' | 
|             }, { | 
|                 name: 'export', | 
|                 title: '导出Excel', | 
|                 perms: 'role:export' | 
|             }] | 
|         }); | 
|   | 
|         table.on('tool(roleTable)', function (obj) { | 
|             var data = obj.data, | 
|                 layEvent = obj.event; | 
|             if (layEvent === 'edit') { | 
|                 $header.text('修改角色'); | 
|                 form.val("role-form", { | 
|                     "roleId": data.roleId, | 
|                     "roleName": data.roleName, | 
|                     "remark": data.remark | 
|                 }); | 
|                 if (data.menuIds) { | 
|                     menuTree.setChecked(data.menuIds.split(','), true); | 
|                 } else { | 
|                     menuTree.setChecked([], true); | 
|                 } | 
|             } | 
|             if (layEvent === 'del') { | 
|                 febs.modal.confirm('删除角色', '确定删除该角色?', function () { | 
|                     deleteRoles(data.roleId); | 
|                 }); | 
|             } | 
|         }); | 
|   | 
|         $query.on('click', function () { | 
|             resetRoleForm(); | 
|             tableIns.reload({where: getQueryParams(), page: {curr: 1}}); | 
|         }); | 
|   | 
|         $reset.on('click', function () { | 
|             resetRoleForm(); | 
|             $searchForm[0].reset(); | 
|             tableIns.reload({where: getQueryParams(), page: {curr: 1}}); | 
|         }); | 
|   | 
|         $submit.on('click', function () { | 
|             $view.find('#submit-form').trigger('click'); | 
|         }); | 
|   | 
|         function initTable() { | 
|             tableIns = febs.table.init({ | 
|                 elem: $view.find('table'), | 
|                 id: 'roleTable', | 
|                 url: ctx + 'role/list', | 
|                 cols: [[ | 
|                     {type: 'checkbox'}, | 
|                     {field: 'roleName', title: '角色名称', minWidth: 120}, | 
|                     {field: 'remark', title: '角色描述'}, | 
|                     {field: 'createTime', title: '创建时间', minWidth: 180}, | 
|                     {title: '操作', toolbar: '#role-option', width: 100} | 
|                 ]] | 
|             }); | 
|         } | 
|   | 
|         function getQueryParams() { | 
|             return { | 
|                 roleName: $searchForm.find('input[name="roleName"]').val().trim(), | 
|                 invalidate_ie_cache: new Date() | 
|             }; | 
|         } | 
|   | 
|         function resetRoleForm() { | 
|             $view.find('#reset-form').trigger('click'); | 
|             $header.text('新增角色'); | 
|             menuTree.setChecked([], true); | 
|             menuTree.unExpandAll(); | 
|         } | 
|   | 
|         form.on('submit(role-form-submit)', function (data) { | 
|             var selected = menuTree.getChecked(false, true); | 
|             var menuIds = []; | 
|             layui.each(selected, function (key, item) { | 
|                 menuIds.push(item.id) | 
|             }); | 
|             data.field.menuIds = menuIds.join(','); | 
|             if (!menuIds.length) { | 
|                 febs.modal.confirm('提示', '当前角色未授予任何权限,是否继续?', function () { | 
|                     addOrUpdateRole(data.field); | 
|                 }); | 
|             } else { | 
|                 addOrUpdateRole(data.field); | 
|             } | 
|             return false; | 
|         }); | 
|   | 
|         function deleteRoles(roleIds) { | 
|             febs.get(ctx + 'role/delete/' + roleIds, null, function () { | 
|                 febs.alert.success('删除角色成功'); | 
|                 $query.trigger('click'); | 
|             }) | 
|         } | 
|   | 
|         var addOrUpdateRole = function (data) { | 
|             if (data.roleId && $header.text() === '修改角色') { | 
|                 febs.post(ctx + 'role/update', data, function () { | 
|                     febs.alert.success('修改角色成功'); | 
|                     $query.trigger('click'); | 
|                 }); | 
|             } else { | 
|                 febs.post(ctx + 'role', data, function () { | 
|                     febs.alert.success('新增角色成功'); | 
|                     $query.trigger('click'); | 
|                 }); | 
|             } | 
|         } | 
|     }); | 
| </script> |