main
tamguo 7 years ago
parent 0ac287738d
commit c7f0bda24f

@ -2,12 +2,17 @@ package com.tamguo.modules.sys.service;
import java.util.List;
import com.alibaba.fastjson.JSONArray;
import com.baomidou.mybatisplus.service.IService;
import com.tamguo.modules.sys.model.SysMenuEntity;
import com.tamguo.modules.sys.model.condition.SysMenuCondition;
public interface ISysMenuService extends IService<SysMenuEntity>{
/** 列表数据*/
List<SysMenuEntity> listData(SysMenuCondition condition);
/** 树形结构*/
JSONArray treeData(String excludeId);
}

@ -3,7 +3,12 @@ package com.tamguo.modules.sys.service.impl;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.StringUtils;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.mapper.Condition;
import com.baomidou.mybatisplus.service.impl.ServiceImpl;
import com.tamguo.modules.sys.dao.SysMenuMapper;
import com.tamguo.modules.sys.model.SysMenuEntity;
@ -21,4 +26,35 @@ public class SysMenuServiceImpl extends ServiceImpl<SysMenuMapper, SysMenuEntity
return sysMenuMapper.listData(condition);
}
@Transactional(readOnly=true)
@SuppressWarnings("unchecked")
@Override
public JSONArray treeData(String excludeId) {
List<SysMenuEntity> menus = null;
if(StringUtils.isEmpty(excludeId)) {
menus = sysMenuMapper.selectList(Condition.EMPTY);
}else {
menus = sysMenuMapper.selectList(Condition.create().notLike("parent_codes", excludeId).ne("menu_code", excludeId));
}
return turnZTreeData(menus);
}
private JSONArray turnZTreeData(List<SysMenuEntity> menus) {
if(menus != null) {
JSONArray nodes = new JSONArray();
for(int i=0 ; i<menus.size() ; i++) {
JSONObject node = new JSONObject();
SysMenuEntity menu = menus.get(i);
node.put("name", menu.getMenuName());
node.put("id", menu.getId());
node.put("pId", menu.getParentCode());
node.put("title", menu.getMenuName());
nodes.add(node);
}
return nodes;
}
return null;
}
}

@ -7,6 +7,7 @@ import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import com.alibaba.fastjson.JSONArray;
import com.tamguo.modules.sys.model.SysMenuEntity;
import com.tamguo.modules.sys.model.condition.SysMenuCondition;
import com.tamguo.modules.sys.service.ISysMenuService;
@ -31,4 +32,11 @@ public class SysMenuController {
List<SysMenuEntity> list = iSysMenuService.listData(condition);
return list;
}
@RequestMapping(path="treeData")
@ResponseBody
public JSONArray treeData(String excludeId , String sysCode , String isShowNameOrig) {
return iSysMenuService.treeData(excludeId);
}
}

@ -0,0 +1,380 @@
<!DOCTYPE html><html><head><meta charset="utf-8"><meta content="webkit" name="renderer"/><meta http-equiv="X-UA-Compatible"
content="IE=edge"><meta name="keywords" content="PoweredByJeeSiteV4.0"/><meta http-equiv="Cache-Control"
content="no-cache, no-store, must-revalidate"/><meta name="description" content="PoweredByJeeSiteV4.0"/><meta
content="no-cache" http-equiv="Pragma"/><meta http-equiv="Expires" content="0"/><meta
content="width=device-width, initial-scale=1, user-scalable=1" name="viewport"/>
<title>菜单管理 - JeeSite Demo</title>
<script th:src="${setting.domain + 'global.min.js'}"></script>
<script th:src="${setting.domain + 'jquery/jquery-1.12.4.min.js'}"></script>
<script th:src="${setting.domain + 'jquery/jquery-migrate-1.4.1.min.js'}"></script>
<!--[if lt IE 9]><script src="/js/static/common/h5fix.min.js"></script><![endif]-->
<link rel="stylesheet" th:href="${setting.domain + 'fonts/font-icons.min.css'}">
<link rel="stylesheet" th:href="${setting.domain + 'bootstrap/css/bootstrap.min.css'}">
<link rel="stylesheet" th:href="${setting.domain + 'select2/4.0/select2.css'}">
<link rel="stylesheet" th:href="${setting.domain + 'icheck/1.0/minimal/grey.css'}">
<link rel="stylesheet" th:href="${setting.domain + 'adminlte/css/AdminLTE.min.css'}">
<link rel="stylesheet" th:href="${setting.domain + 'common/jeesite.css'}">
<link rel="stylesheet" th:href="${setting.domain + 'common/common.css'}">
</head><body class="hold-transition ">
<div class="wrapper"><link rel="stylesheet" th:href="${setting.domain + 'colorpicker/bootstrap-colorpicker.css'}"/>
<div class="main-content">
<div class="box box-main">
<div class="box-header">
<div class="box-title">
<i class="fa icon-book-open"></i> 新增菜单(
</div>
<div class="box-title dropdown input-inline">
<div class="dropdown-toggle" data-toggle="dropdown">
<span id="sysCodeName">主导航菜单</span><b class="caret"></b>
</div>
<ul class="dropdown-menu">
<li><a href="javascript:" onclick="
$('#sysCode').val('default');
$('#sysCodeName').text('主导航菜单');
$('#parentDiv').attr('data-url','/js/a/sys/menu/treeData?excludeCode=&sysCode=default');
$('#parentCode,#parentName').val('');
"><i class="fa fa-angle-right"></i> 主导航菜单</a></li>
</ul>
</div>
<div class="box-title"></div>
<div class="box-tools pull-right">
<button type="button" class="btn btn-box-tool" data-widget="collapse"><i class="fa fa-minus"></i></button>
</div>
</div>
<form id="inputForm" th:action="${setting.domain + 'sys/menu/save'}" method="post" class="form-horizontal">
<input type="hidden" id="sysCode" name="sysCode" value="default"/>
<input type="hidden" id="menuCode" name="menuCode" value=""/>
<div class="box-body">
<div class="form-unit">基本信息</div>
<div class="row">
<div class="col-xs-6">
<div class="form-group">
<label class="control-label col-sm-4">上级菜单:</label>
<div class="col-sm-8">
<div class="input-group treeselect" id="parentDiv" data-url="sys/menu/treeData?excludeCode=&sysCode=default&isShowNameOrig=true">
<input id="parentCode" type="hidden" name="parent.id" value="" class="isReset"/>
<input id="parentName" type="text" name="parent.menuNameOrig" value=""
class="form-control " readonly="readonly"
/><span class="input-group-btn"><a id="parentButton" href="javascript:"
class="btn btn-default "><i class="fa fa-search"></i></a>
</span>
</div>
<script>
$("#parentButton,#parentName").click(function(){
if ($("#parentButton").hasClass("disabled")){
return true;
}
var options = {
type: 2,
maxmin: true,
shadeClose: true,
title: '上级菜单',
area: ['300px', '400px'],
content: 'sys/treeselect',
contentFormData: {
url: $('#parentDiv').attr('data-url'),
checkbox: 'false',
expandLevel: '-1',
selectCodes: $("#parentCode").val(),
isReturnValue: 'false'
},
success: function(layero, index){
if ($(js.layer.window).width() < 300
|| $(js.layer.window).height() < 400){
js.layer.full(index);
}
},
btn: ['<i class="fa fa-check"></i> 确定'],
btn1: function(index, layero){
var win = js.layer.iframeWindow(index);
win.$('#keyword').val('').change(); var codes = [], names = [], nodes;
if ("false" == "true"){
nodes = win.tree.getCheckedNodes(true);
}else{
nodes = win.tree.getSelectedNodes();
}
for(var i=0; i<nodes.length; i++) {
var code = nodes[i]['false'=='true'?'value':'id'], name = nodes[i]['name'];
codes.push(code.replace(/^u_/g,''));
names.push(name.replace(/\([0-9]*\)/g,''));
break;
}
if(typeof treeselectCheck == 'function'){
if (!treeselectCheck('parent', nodes)){
return false;
}
}
$("#parentCode").val(codes.join(',')).change();
$("#parentName").val(names.join(',')).change();
try { $('#parentCode,#parentName').valid(); }catch(e){}
if(typeof treeselectCallback == 'function'){
treeselectCallback('parent', 'ok', index, layero, nodes);
}
}
};
options.btn.push('<i class="fa fa-eraser"></i> 清除');
options['btn'+options.btn.length] = function(index, layero){
$("#parentCode").val('').change();
$("#parentName").val('').change();
if(typeof treeselectCallback == 'function'){
treeselectCallback('parent', 'clear', index, layero);
}
};
options.btn.push('<i class="fa fa-close"></i> 关闭');
options['btn'+options.btn.length] = function(index, layero){
if(typeof treeselectCallback == 'function'){
treeselectCallback('parent', 'cancel', index, layero);
}
};
js.layer.open(options);
});
</script> </div>
</div>
</div>
</div>
<div class="row">
<div class="col-xs-6">
<div class="form-group">
<label class="control-label col-sm-4">菜单名称:</label>
<div class="col-sm-8">
<input type="text" id="menuNameOrig" name="menuNameOrig" value="" maxlength="50" class="form-control required"/>
</div>
</div>
</div>
<div class="col-xs-6">
<div class="form-group">
<label class="control-label col-sm-4" title="标识当前是否是个菜单,还是只是设置权限">
<span class="required">*</span> 菜单类型:<i class="fa icon-question"></i></label>
<div class="col-sm-8">
<span id="menuType" class="icheck">
<label><input type="radio" id="menuType1" name="menuType"
value="1" class="form-control required" checked> 菜单</label><label><input type="radio" id="menuType2" name="menuType"
value="2" class="form-control required"> 权限</label></span>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-xs-6">
<div class="form-group">
<label class="control-label col-sm-4" title="超级链接的URL地址跟路径在管理路径下外部链接需加“http://”;
1、以 /// 开头则代表是网站根路径结果http://localhost/{href}
2、以 // 开头则代表是工程根路径结果http://localhost/{ctxPath}/{href}
3、以 / 开头则代表是管理根路径结果http://localhost/{ctxPath}{adminPath}/{href}
可带变量,变量格式 {变量名}
1、jeesite.yml中的key可作为变量设置
2、{ssoToken} : 单点登录的token编码url参数中的参数分隔符请使用“%26”进行转义
例如:{projectUrl}/sso/{ssoToken}?url=/sys/user/list?p1=v1%26p2=v2&relogin=true
3、{userCode} : 当前用户编码
4、{userName} : 当前用户名称
5、{userType} : 当前用户类型 ">
链接(Href)<i class="fa icon-question"></i></label>
<div class="col-sm-8">
<input type="text" id="menuHref" name="menuHref" value="" maxlength="2000" class="form-control"/>
</div>
</div>
</div>
<div class="col-xs-6">
<div class="form-group">
<label class="control-label col-sm-4" title="链接打开的目标默认addTabPage方式新窗口中打开如_blank">
目标(Target)<i class="fa icon-question"></i></label>
<div class="col-sm-8">
<input type="text" id="menuTarget" name="menuTarget" value="" maxlength="10" class="form-control"/>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-xs-6">
<div class="form-group">
<label class="control-label col-sm-4">排序(升序)</label>
<div class="col-sm-8">
<input type="text" id="treeSort" name="treeSort" value="9030" maxlength="50" class="form-control required"/>
</div>
</div>
</div>
<div class="col-xs-6 isPerm2">
<div class="form-group">
<label class="control-label col-sm-4" title="控制器中定义的权限标识,如:@RequiresPermissions('权限标识')">
权限标识:<i class="fa icon-question"></i></label>
<div class="col-sm-8">
<input type="text" id="permission" name="permission" value="" maxlength="100" class="form-control"/>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-xs-6 isMenu">
<div class="form-group">
<label class="control-label col-sm-4">菜单图标:</label>
<div class="col-sm-8">
<div class="input-group">
<span class="input-group-addon"><i id="menuIconIcon" class="fa fa-fw"></i></span>
<input id="menuIcon" name="menuIcon" type="text" value="" class="form-control ">
<span class="input-group-btn"><a id="menuIconButton" href="javascript:" class="btn btn-default"
><i class="fa fa-search"></i></a></span>
</div>
<script>
$("#menuIconButton").click(function(){
js.layer.open({
type: 2,
maxmin: true,
shadeClose: true,
title: '图标选择',
area: [(js.layer.$(js.layer.window).width() - 100) + 'px',
(js.layer.$(js.layer.window).height() - 100) + 'px'],
content: '/js/tags/iconselect?value='+$("#menuIcon").val(),
success: function(layero, index){
var info = '<font color="red" class="pull-left mt10">提示:双击选择图标。</font>';
layero.find('.layui-layer-btn').append(info);
},
btn: ['<i class="fa fa-close"></i> 关闭',
'<i class="fa fa-eraser"></i> 清除'],
btn1: function(index, layero){
var win = js.layer.iframeWindow(index);
var icon = win.$("#icon").val();
$("#menuIconIcon").attr("class", 'fa fa-fw ' + icon);
$("#menuIcon").val(icon).change();
try { $('#menuIcon').valid(); }catch(e){}
},
btn2: function(index, layero){
$("#menuIconIcon").attr("class", "fa fa-fw");
$("#menuIcon").val("").change();
}
});
});
</script> </div>
</div>
</div>
<div class="col-xs-6 isMenu">
<div class="form-group">
<label class="control-label col-sm-4">字体颜色:</label>
<div class="col-sm-8">
<div class="input-group input-color" data-color-format="hex">
<input type="text" id="menuColor" name="menuColor" value="" maxlength="50" class="form-control"/>
<span class="input-group-addon">
<i style="background-color:#ddd;"></i>
</span>
</div>
</div>
</div>
</div>
</div>
<div class="row isMenu2">
<div class="col-xs-6">
<div class="form-group">
<label class="control-label col-sm-4">可见:</label>
<div class="col-sm-8">
<span id="isShow" class="icheck">
<label><input type="radio" id="isShow1" name="isShow"
value="1" class="form-control required" checked> 显示</label><label><input type="radio" id="isShow2" name="isShow"
value="0" class="form-control required"> 隐藏</label></span>
</div>
</div>
</div>
<div class="col-xs-6">
<div class="form-group">
<label class="control-label col-sm-4" title="菜单权重默认20>=40一般管理员>=60系统管理员>=80超级管理员">
菜单权重:<i class="fa icon-question"></i></label>
<div class="col-sm-8">
<select id="weight" name="weight" class="form-control required">
<option value="20">默认权重</option><option value="40">二级管理员</option><option value="60">系统管理员</option><option value="80">超级管理员</option></select> </div>
</div>
</div>
</div>
<div class="form-unit">其它信息</div>
<div class="row">
<div class="col-xs-12">
<div class="form-group">
<label class="control-label col-sm-2">备注:</label>
<div class="col-sm-10">
<textarea id="remarks" name="remarks" rows="3" maxlength="200" class="form-control"></textarea>
</div>
</div>
</div>
</div>
</div>
<div class="box-footer">
<div class="row">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-sm btn-primary" id="btnSubmit"><i class="fa fa-check"></i> 保 存</button>&nbsp;
<button type="button" class="btn btn-sm btn-default" id="btnCancel" onclick="js.closeCurrentTabPage()"><i class="fa fa-reply-all"></i> 关 闭</button>
</div>
</div>
</div>
</form>
</div>
</div>
</div>
<a id="scroll-up" href="#" class="btn btn-sm"><i class="fa fa-angle-double-up"></i></a>
<script th:src="${setting.domain + 'bootstrap/js/bootstrap.min.js'}"></script>
<script th:src="${setting.domain + 'select2/4.0/select2.js'}"></script>
<script th:src="${setting.domain + 'select2/4.0/i18n/zh_CN.js'}"></script>
<script th:src="${setting.domain + 'layer/3.1/layer.js'}"></script>
<script th:src="${setting.domain + 'my97/WdatePicker.js'}"></script>
<script th:src="${setting.domain + 'jquery-validation/1.16/jquery.validate.js'}"></script>
<script th:src="${setting.domain + 'jquery-validation/1.16/localization/messages_zh_CN.js'}"></script>
<script th:src="${setting.domain + 'jquery-validation/1.16/jquery.validate.extend.js'}"></script>
<script th:src="${setting.domain + 'common/jeesite.js'}"></script>
<script th:src="${setting.domain + 'common/i18n/jeesite_zh_CN.js'}"></script>
<script th:src="${setting.domain + 'common/common.js'}"></script>
<script th:src="${setting.domain + 'colorpicker/bootstrap-colorpicker.js'}"></script>
<script>
$("#inputForm").validate({
submitHandler: function(form){
if ($('#moduleCodes').val() == null){
js.showMessage('请选择归属模块!');
return;
}
js.ajaxSubmitForm($(form), function(data){
js.showMessage(data.message);
if(data.result == Global.TRUE){
js.closeCurrentTabPage(function(contentWindow){
contentWindow.$('#dataGrid').dataGrid('refreshTreeChildren',
$('#parentCode').val(), '');
});
}
}, "json");
}
});
// 颜色控件初始化
$('#inputForm .input-color').colorpicker();
// 根据类型显示不同的元素
$('#menuType input').on('ifCreated ifChecked', function(){
if ($(this).is(':checked')){
// 1菜单2权限
if ($(this).val() == '1'){
$('.isPerm').hide();
$('.isMenu').show();
}else{
$('.isMenu').hide();
$('.isPerm').show();
}
}
});
// 选择父级菜单回调方法
function treeselectCallback(id, act, index, layero){
if (id == 'parent' && (act == 'ok' || act == 'clear')){
// 创建并初始化下一个节点信息,如:排序号、默认值
$.get('/js/a/sys/menu/createNextNode?parentCode='
+$('#parentCode').val(), function(data){
$('#treeSort').val(data.treeSort);
$('#menuType input[value="'+data.menuType+'"]').iCheck('check');
if (data.moduleCodes){
$('#moduleCodes input').iCheck('uncheck');
$.each(data.moduleCodes.split(','), function(i, v){
$('#moduleCodes input[value="'+v+'"]').iCheck('check');
});
}
});
}
}
</script>

@ -40,7 +40,7 @@ content="width=device-width, initial-scale=1, user-scalable=1" name="viewport"/>
<a href="#" class="btn btn-default" id="btnRefreshTree" title="刷新"><i class="fa fa-refresh"></i> 刷新</a>
<a href="#" class="btn btn-default" id="btnExpandTreeNode" title="展开一级"><i class="fa fa-angle-double-down"></i> 展开</a>
<a href="#" class="btn btn-default" id="btnCollapseTreeNode" title="折叠全部"><i class="fa fa-angle-double-up"></i> 折叠</a>
<a href="/js/a/sys/menu/form?sysCode=default" class="btn btn-default btnTool" title="新增菜单"><i class="fa fa-plus"></i> 新增</a>
<a th:href="${setting.domain + 'sys/menu/add?sysCode=default'}" class="btn btn-default btnTool" title="新增菜单"><i class="fa fa-plus"></i> 新增</a>
<a href="#" class="btn btn-default" id="btnUpdateSort" title="保存排序"><i class="fa fa-sort-amount-asc"></i> 保存排序</a>
</div>
</div>

Loading…
Cancel
Save