| <div class="layui-fluid layui-anim febs-anim" id="febs-menu" lay-title="菜单管理"> | 
|     <div class="layui-row layui-col-space8 febs-container"> | 
|         <div class="layui-col-md6 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="menu-table-form" id="menu-table-form"> | 
|                         <div class="layui-row"> | 
|                             <div class="layui-col-md8 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="menuName" autocomplete="off" class="layui-input"> | 
|                                         </div> | 
|                                     </div> | 
|                                 </div> | 
|                             </div> | 
|                             <div class="layui-col-md4 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="menu:add,menu:delete,menu:export"> | 
|                                     <i class="layui-icon"></i> | 
|                                 </div> | 
|                             </div> | 
|                         </div> | 
|                     </form> | 
|                     <div class="eleTree menuTree" lay-filter="menuTree" style="margin-left: 1rem"></div> | 
|                 </div> | 
|             </div> | 
|         </div> | 
|         <div class="layui-col-md6 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="menu-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="menuId" class="layui-input"> | 
|                             </div> | 
|                         </div> | 
|                         <div class="layui-form-item"> | 
|                             <label class="layui-form-label">上级ID:</label> | 
|                             <div class="layui-input-block"> | 
|                                 <input type="text" value="" name="parentId" readonly 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="menuName" autocomplete="off" class="layui-input" | 
|                                        minlength="2" maxlength="10" lay-verify="range"> | 
|                             </div> | 
|                         </div> | 
|                         <div class="layui-form-item"> | 
|                             <label class="layui-form-label febs-form-item-require">类型:</label> | 
|                             <div class="layui-input-block"> | 
|                                 <input type="radio" name="type" lay-filter="menu-type" value="0" title="菜单" checked=""> | 
|                                 <input type="radio" name="type" lay-filter="menu-type" value="1" title="按钮"> | 
|                             </div> | 
|                         </div> | 
|                         <div class="layui-form-item"> | 
|                             <label class="layui-form-label">图标:</label> | 
|                             <div class="layui-input-block"> | 
|                                 <input type="text" name="icon" autocomplete="off" class="layui-input" | 
|                                        maxlength="50" lay-verify="range"> | 
|                             </div> | 
|                         </div> | 
|                         <div class="layui-form-item"> | 
|                             <label class="layui-form-label">URL:</label> | 
|                             <div class="layui-input-block"> | 
|                                 <input type="text" name="url" autocomplete="off" class="layui-input" | 
|                                        maxlength="50" lay-verify="range"> | 
|                             </div> | 
|                         </div> | 
|                         <div class="layui-form-item"> | 
|                             <label class="layui-form-label">权限:</label> | 
|                             <div class="layui-input-block"> | 
|                                 <input type="text" name="perms" autocomplete="off" class="layui-input" | 
|                                        maxlength="50" lay-verify="range"> | 
|                             </div> | 
|                         </div> | 
|                         <div class="layui-form-item"> | 
|                             <label class="layui-form-label">排序:</label> | 
|                             <div class="layui-input-block"> | 
|                                 <input type="text" name="orderNum" autocomplete="off" class="layui-input" | 
|                                        lay-verify="number"> | 
|                             </div> | 
|                         </div> | 
|                         <button type="reset" class="layui-btn febs-hide" id="reset-form"></button> | 
|                         <button class="layui-btn febs-hide" lay-submit="" lay-filter="menu-form-submit" | 
|                                 id="submit-form"></button> | 
|                     </form> | 
|                 </div> | 
|                 <div class="layui-card-footer"> | 
|                     <button class="layui-btn" id="submit">保存</button> | 
|                 </div> | 
|             </div> | 
|         </div> | 
|     </div> | 
| </div> | 
| <script data-th-inline="none" type="text/javascript"> | 
|     layui.use(['dropdown', 'jquery', 'laydate', 'febs', 'form', 'eleTree', 'validate'], function () { | 
|         var $ = layui.jquery, | 
|             laydate = layui.laydate, | 
|             febs = layui.febs, | 
|             form = layui.form, | 
|             validate = layui.validate, | 
|             eleTree = layui.eleTree, | 
|             dropdown = layui.dropdown, | 
|             $view = $('#febs-menu'), | 
|             $query = $view.find('#query'), | 
|             $reset = $view.find('#reset'), | 
|             $submit = $view.find('#submit'), | 
|             $searchForm = $view.find('#menu-table-form'), | 
|             $menuName = $searchForm.find('input[name="menuName"]'), | 
|             $type = $view.find('input[type="radio"][name="type"]'), | 
|             $icon = $view.find('input[name="icon"]'), | 
|             $icon_parent = $icon.parents('.layui-form-item'), | 
|             $url = $view.find('input[name="url"]'), | 
|             $url_parent = $url.parents('.layui-form-item'), | 
|             $order = $view.find('input[name="orderNum"]'), | 
|             $order_parent = $order.parents('.layui-form-item'), | 
|             $header = $view.find('#form-header'), | 
|             _currentMenuData, | 
|             _selectNode, | 
|             _menuTree, | 
|             tableIns; | 
|   | 
|         form.verify(validate); | 
|         form.render(); | 
|   | 
|         dropdown.render({ | 
|             elem: $view.find('.action-more'), | 
|             click: function (name, elem, event) { | 
|                 if (name === 'add') { | 
|                     reset(); | 
|                     var selected = _menuTree.getChecked(false, true); | 
|                     if (selected.length > 1) { | 
|                         febs.alert.warn('只能选择一个节点作为父级!'); | 
|                         return; | 
|                     } | 
|                     if (selected[0] && selected[0].type === '1') { | 
|                         febs.alert.warn('不能选择按钮作为父级!'); | 
|                         return; | 
|                     } | 
|                     form.val("menu-form", { | 
|                         "parentId": selected[0] ? selected[0].id : '' | 
|                     }); | 
|                 } | 
|                 if (name === 'delete') { | 
|                     var checked = _menuTree.getChecked(false, true); | 
|                     if (checked.length < 1) { | 
|                         febs.alert.warn('请勾选需要删除的菜单或按钮'); | 
|                         return; | 
|                     } | 
|                     var menuIds = []; | 
|                     layui.each(checked, function (key, item) { | 
|                         menuIds.push(item.id) | 
|                     }); | 
|                     febs.modal.confirm('提示', '当您点击确定按钮后,这些记录将会被彻底删除,如果其包含子记录,也将一并删除!', function () { | 
|                         febs.get(ctx + 'menu/delete/' + menuIds.join(','), null, function () { | 
|                             febs.alert.success('删除成功!'); | 
|                             reloadMenuTree(); | 
|                             reset(); | 
|                         }) | 
|                     }); | 
|                 } | 
|                 if (name === 'export') { | 
|                     febs.download(ctx + 'menu/excel', { | 
|                         "menuName": $menuName.val().trim() | 
|                     }, '菜单信息表.xlsx'); | 
|                 } | 
|             }, | 
|             options: [{ | 
|                 name: 'add', | 
|                 title: '新增', | 
|                 perms: 'menu:add' | 
|             }, { | 
|                 name: 'delete', | 
|                 title: '删除', | 
|                 perms: 'menu:delete' | 
|             }, { | 
|                 name: 'export', | 
|                 title: '导出Excel', | 
|                 perms: 'menu:export' | 
|             }] | 
|         }); | 
|   | 
|         _menuTree = renderMenuTree(); | 
|   | 
|         eleTree.on("nodeClick(menuTree)", function (d) { | 
|             var data = d.data.currentData.data; | 
|             _currentMenuData = data; | 
|             $type.attr("disabled", true); | 
|             var type = data.type; | 
|             handleTypeChange(type); | 
|             if (type === '0') { // 菜单 | 
|                 $header.text('修改菜单'); | 
|             } else { // 按钮 | 
|                 $header.text('修改按钮'); | 
|             } | 
|             form.val("menu-form", { | 
|                 "icon": data.icon, | 
|                 "url": data.url, | 
|                 "orderNum": data.orderNum, | 
|                 "type": data.type, | 
|                 "menuName": data.menuName, | 
|                 "perms": data.perms, | 
|                 "parentId": data.parentId, | 
|                 "menuId": data.menuId | 
|             }); | 
|         }); | 
|   | 
|         form.on("radio(menu-type)", function (data) { | 
|             handleTypeChange(data.value); | 
|         }); | 
|   | 
|         $reset.on('click', function () { | 
|             $menuName.val(''); | 
|             reloadMenuTree(); | 
|             reset(); | 
|         }); | 
|   | 
|         $query.on('click', function () { | 
|             reloadMenuTree(); | 
|             reset(); | 
|         }); | 
|   | 
|         $submit.on('click', function () { | 
|             $view.find('#submit-form').trigger('click'); | 
|         }); | 
|   | 
|         $icon.focus(function () { | 
|             febs.modal.open('图标选择', 'others/febs/icon', { | 
|                 btn: ['确定'], | 
|                 yes: function () { | 
|                     var icon = $('#febs-icon').find('.icon-active .icon-name').text(); | 
|                     if (icon) { | 
|                         form.val("menu-form", { | 
|                             "icon": 'layui-icon-' + icon | 
|                         }); | 
|                     } else { | 
|                         form.val("menu-form", { | 
|                             "icon": '' | 
|                         }); | 
|                     } | 
|                     layer.closeAll(); | 
|                 } | 
|             }); | 
|         }); | 
|   | 
|         function reset() { | 
|             $view.find('#reset-form').trigger('click'); | 
|             handleTypeChange('0'); | 
|             $type.removeAttr("disabled"); | 
|         } | 
|   | 
|         function renderMenuTree() { | 
|             _menuTree = eleTree.render({ | 
|                 elem: '.menuTree', | 
|                 url: ctx + 'menu/tree', | 
|                 where: { | 
|                     "menuName": $menuName.val().trim(), | 
|                     "invalidate_ie_cache": new Date() | 
|                 }, | 
|                 accordion: true, | 
|                 highlightCurrent: true, | 
|                 showCheckbox: true, | 
|                 checkStrictly: true, | 
|                 renderAfterExpand: false, | 
|                 request: { | 
|                     name: "title", | 
|                     key: "id", | 
|                     children: "childs", | 
|                     checked: "checked", | 
|                     data: "data" | 
|                 }, | 
|                 response: { | 
|                     statusName: "code", | 
|                     statusCode: 200, | 
|                     dataName: "data" | 
|                 } | 
|             }); | 
|             return _menuTree; | 
|         } | 
|   | 
|         function reloadMenuTree() { | 
|             _menuTree = renderMenuTree(); | 
|         } | 
|   | 
|         var handleTypeChange = function (type) { | 
|             form.val("menu-form", { | 
|                 "icon": '', | 
|                 "url": '', | 
|                 "orderNum": '' | 
|             }); | 
|             if (type === '1') { | 
|                 $header.text('新增按钮'); | 
|                 $icon_parent.hide(); | 
|                 $url_parent.hide(); | 
|                 $order_parent.hide(); | 
|             } else { | 
|                 $header.text('新增菜单'); | 
|                 $icon_parent.show(); | 
|                 $url_parent.show(); | 
|                 $order_parent.show(); | 
|             } | 
|         }; | 
|   | 
|         form.on('submit(menu-form-submit)', function (data) { | 
|             if (data.field.menuId && $header.text().indexOf('修改') !== -1) { | 
|                 if (febs.nativeEqual(data.field, _currentMenuData)) { | 
|                     febs.alert.warn('数据未作任何修改!'); | 
|                     return false; | 
|                 } | 
|                 febs.post(ctx + 'menu/update', data.field, function () { | 
|                     febs.alert.success('修改成功'); | 
|                     reloadMenuTree(); | 
|                     reset(); | 
|                 }) | 
|             } else { | 
|                 febs.post(ctx + 'menu', data.field, function () { | 
|                     febs.alert.success('新增成功'); | 
|                     reloadMenuTree(); | 
|                     reset(); | 
|                 }) | 
|             } | 
|             return false; | 
|         }); | 
|     }); | 
| </script> |