2018-06-07 00:45:47 +08:00
|
|
|
|
$(function () {
|
|
|
|
|
var $dialog = $('#dialogNew');
|
|
|
|
|
var $pickIcon = $('#pickIcon');
|
|
|
|
|
var $dialogNew = $dialog;
|
|
|
|
|
var $dialogIcon = $('#dialogIcon');
|
|
|
|
|
var $dialogMenu = $('#dialogMenu');
|
|
|
|
|
var $dialogRole = $('#dialogRole');
|
|
|
|
|
var $dialogRoleHeader = $('#myRoleModalLabel');
|
|
|
|
|
var $dialogRoleForm = $('#roleForm');
|
|
|
|
|
var $btnSubmitMenu = $('#btnSubmitMenu');
|
|
|
|
|
var $btnPickIcon = $('#btnIcon');
|
|
|
|
|
var $inputIcon = $('#icon');
|
|
|
|
|
var $nestMenu = $('#nestable_menu');
|
|
|
|
|
var $nestMenuInput = $nestMenu.find('div.dd3-content');
|
|
|
|
|
var $parentMenuID = $('#parentId');
|
|
|
|
|
var $parentMenuName = $('#parentName');
|
|
|
|
|
var $category = $('#category');
|
|
|
|
|
|
|
|
|
|
var initNestMenu = function () {
|
|
|
|
|
$nestMenuInput = $nestMenu.find('div.dd3-content');
|
|
|
|
|
$nestMenuInput.children('.checkbox').hide();
|
2018-09-02 00:50:13 +08:00
|
|
|
|
};
|
2018-06-07 00:45:47 +08:00
|
|
|
|
|
2018-08-03 21:19:01 +08:00
|
|
|
|
var state = [];
|
|
|
|
|
|
2018-09-02 00:50:13 +08:00
|
|
|
|
$('table').lgbTable({
|
2018-06-07 00:45:47 +08:00
|
|
|
|
url: Menu.url,
|
2018-09-02 00:50:13 +08:00
|
|
|
|
dataBinder: {
|
2018-06-07 00:45:47 +08:00
|
|
|
|
map: {
|
2018-09-02 00:50:13 +08:00
|
|
|
|
Id: "#menuID",
|
|
|
|
|
ParentId: "#parentId",
|
|
|
|
|
ParentName: "#parentName",
|
|
|
|
|
Name: "#name",
|
|
|
|
|
Order: "#order",
|
|
|
|
|
Icon: "#icon",
|
|
|
|
|
Url: "#url",
|
|
|
|
|
Category: "#category",
|
|
|
|
|
Target: "#target",
|
|
|
|
|
IsResource: "#isRes",
|
2019-01-11 23:20:28 +08:00
|
|
|
|
Application: "#app"
|
2018-09-02 00:50:13 +08:00
|
|
|
|
},
|
|
|
|
|
events: {
|
|
|
|
|
'#btn_assignRole': function (row) {
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$.bc({
|
2018-09-13 19:21:35 +08:00
|
|
|
|
id: row.Id, url: Role.url, query: { type: "menu" }, method: "post",
|
2018-06-07 00:45:47 +08:00
|
|
|
|
callback: function (result) {
|
|
|
|
|
var htmlTemplate = this.htmlTemplate;
|
|
|
|
|
var html = $.map(result, function (element, index) {
|
|
|
|
|
return $.format(htmlTemplate, element.Id, element.RoleName, element.Checked, element.Description);
|
2018-09-02 00:50:13 +08:00
|
|
|
|
}).join('');
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$dialogRoleHeader.text($.format('{0}-角色授权窗口', row.Name));
|
2018-08-03 19:40:01 +08:00
|
|
|
|
$dialogRoleForm.html(html).find('[data-toggle="tooltip"]').each(function (index, label) {
|
2018-09-02 00:50:13 +08:00
|
|
|
|
if (label.title === "") label.title = "未设置";
|
2018-08-03 18:12:35 +08:00
|
|
|
|
}).tooltip();
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$dialogRole.modal('show');
|
|
|
|
|
}
|
|
|
|
|
});
|
2018-09-02 00:50:13 +08:00
|
|
|
|
},
|
|
|
|
|
'#btnSubmitRole': function (row) {
|
2018-06-07 00:45:47 +08:00
|
|
|
|
var menuId = row.Id;
|
|
|
|
|
var roleIds = $dialogRole.find('input:checked').map(function (index, element) {
|
|
|
|
|
return $(element).val();
|
2018-09-13 19:21:35 +08:00
|
|
|
|
}).toArray();
|
|
|
|
|
$.bc({ id: menuId, url: Role.url, method: "put", data: roleIds, query: { type: "menu" }, title: Role.title, modal: '#dialogRole' });
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}
|
2018-09-02 00:50:13 +08:00
|
|
|
|
},
|
|
|
|
|
callback: function (result) {
|
|
|
|
|
if (!result.success) return;
|
|
|
|
|
if ((result.oper === "save") || result.oper === "del") {
|
|
|
|
|
$nestMenu.nestMenu(initNestMenu);
|
|
|
|
|
}
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}
|
2018-09-02 00:50:13 +08:00
|
|
|
|
},
|
|
|
|
|
smartTable: {
|
|
|
|
|
sortName: 'Order',
|
2019-03-08 13:23:48 +08:00
|
|
|
|
queryParams: function (params) { return $.extend(params, { parentName: $('#txt_parent_menus_name').val(), name: $("#txt_menus_name").val(), category: $('#sel_menus_category').val(), isresource: $('#sel_menus_res').val(), appCode: $('#sel_app').val() }); }, //传递参数(*)
|
2019-03-07 21:28:51 +08:00
|
|
|
|
exportOptions: {
|
|
|
|
|
fileName: "菜单数据",
|
|
|
|
|
ignoreColumn: [0, 1]
|
|
|
|
|
},
|
2018-09-02 00:50:13 +08:00
|
|
|
|
columns: [
|
2018-10-31 12:08:57 +08:00
|
|
|
|
{
|
|
|
|
|
title: "父级菜单", field: "ParentName", sortable: true, formatter: function (value, row, index) {
|
|
|
|
|
return (value === "0" || value === null) ? "" : value;
|
|
|
|
|
}
|
|
|
|
|
},
|
2018-09-02 00:50:13 +08:00
|
|
|
|
{ title: "菜单名称", field: "Name", sortable: true },
|
|
|
|
|
{ title: "菜单序号", field: "Order", sortable: true },
|
|
|
|
|
{
|
|
|
|
|
title: "菜单图标", field: "Icon", sortable: false, align: 'center', formatter: function (value, row, index) {
|
|
|
|
|
if (value) {
|
|
|
|
|
return $.format('<i class="text-info {0}"></i>', value);
|
|
|
|
|
}
|
|
|
|
|
return "";
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}
|
2018-09-02 00:50:13 +08:00
|
|
|
|
},
|
|
|
|
|
{ title: "菜单路径", field: "Url", sortable: false },
|
|
|
|
|
{ title: "菜单类别", field: "CategoryName", sortable: true },
|
|
|
|
|
{
|
|
|
|
|
title: "目标", field: "Target", sortable: true, formatter: function (value, row, index) {
|
|
|
|
|
var ret = value;
|
|
|
|
|
switch (value) {
|
|
|
|
|
case "_self":
|
|
|
|
|
ret = "本窗口";
|
|
|
|
|
break;
|
|
|
|
|
case "_blank":
|
|
|
|
|
ret = "新窗口";
|
|
|
|
|
break;
|
|
|
|
|
case "_parent":
|
|
|
|
|
ret = "父级窗口";
|
|
|
|
|
break;
|
|
|
|
|
case "_top":
|
|
|
|
|
ret = "顶级窗口";
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "菜单类型", field: "IsResource", sortable: true, formatter: function (value, row, index) {
|
|
|
|
|
return value === 0 ? "菜单" : "资源";
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
{
|
2019-01-11 23:20:28 +08:00
|
|
|
|
title: "所属应用", field: "Application", sortable: true, formatter: function (value, row, index) {
|
2018-09-02 00:50:13 +08:00
|
|
|
|
return $('#app').next().find('[data-val="' + value + '"]:first').text();
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2018-09-02 00:50:13 +08:00
|
|
|
|
]
|
|
|
|
|
}
|
2018-06-07 00:45:47 +08:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// validate
|
|
|
|
|
$('#dataForm').on('click', '[data-method]', function () {
|
|
|
|
|
var $this = $(this);
|
|
|
|
|
var $input = $this.parent().prev();
|
|
|
|
|
switch ($this.attr('data-method')) {
|
|
|
|
|
case 'clear':
|
|
|
|
|
$input.val("");
|
|
|
|
|
break;
|
|
|
|
|
case 'sel':
|
|
|
|
|
$input.select();
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$btnPickIcon.on('click', function () {
|
2018-08-13 14:53:18 +08:00
|
|
|
|
$dialogNew.find('[data-toggle="LgbValidate"] [aria-describedby]').tooltip('hide');
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$dialogNew.hide();
|
2018-08-14 01:11:29 +08:00
|
|
|
|
var icon = $inputIcon.val();
|
|
|
|
|
if (icon) $pickIcon.attr('class', icon);
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$dialogIcon.show();
|
2018-09-14 18:14:56 +08:00
|
|
|
|
$scroll.resize();
|
2018-06-07 00:45:47 +08:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$dialogIcon.find('div.modal-header, div.modal-footer').on('click', 'button', function () {
|
|
|
|
|
$dialogIcon.hide();
|
|
|
|
|
$dialogNew.show();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$dialogIcon.find('div.modal-footer').on('click', 'button:last', function () {
|
|
|
|
|
var icon = $pickIcon.attr('class');
|
|
|
|
|
$inputIcon.val(icon);
|
|
|
|
|
$btnPickIcon.find('i').attr('class', icon);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 排序按钮
|
|
|
|
|
$('#btnMenuOrder').on('click', function () {
|
|
|
|
|
$btnSubmitMenu.data('type', 'order');
|
|
|
|
|
$nestMenuInput.find('label:last').find('input').hide();
|
|
|
|
|
$nestMenu.find('li.dd-item').hide().remove('[data-id="0"]');
|
|
|
|
|
$nestMenu.find('li[data-category="' + $category.val() + '"]').show();
|
|
|
|
|
// handler new menu
|
|
|
|
|
var did = $('#menuID').val();
|
2018-09-02 00:50:13 +08:00
|
|
|
|
if (did === "") did = 0;
|
|
|
|
|
if (did === 0) {
|
2018-06-07 00:45:47 +08:00
|
|
|
|
var menuName = $('#name').val();
|
|
|
|
|
var menuCate = $category.val();
|
2018-09-02 00:50:13 +08:00
|
|
|
|
if (menuName === "") menuName = "新建菜单-未命名";
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$nestMenu.find('ol.dd-list:first').append($.format('<li class="dd-item dd3-item" data-id="0" data-order="10" data-category="{1}"><div class="dd-handle dd3-handle"></div><div class="dd3-content"><label><span>{0}</span></label></div></li>', menuName, menuCate));
|
|
|
|
|
}
|
|
|
|
|
$nestMenu.find('li[data-id="' + did + '"] > div.dd3-content span').addClass('active');
|
2018-08-03 21:19:01 +08:00
|
|
|
|
showDialog();
|
2018-06-07 00:45:47 +08:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 选择父节点按钮
|
|
|
|
|
$('#btnMenuParent').on('click', function () {
|
|
|
|
|
$btnSubmitMenu.data('type', 'parent');
|
|
|
|
|
$nestMenuInput.find('label:last').find('input').show();
|
|
|
|
|
$nestMenu.find('li.dd-item').hide().remove('[data-id="0"]');
|
|
|
|
|
$nestMenu.find('li[data-category="' + $category.val() + '"]').show();
|
2018-08-03 21:19:01 +08:00
|
|
|
|
showDialog();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
function showDialog() {
|
|
|
|
|
state.push({ css: $('body').attr("class"), style: $('body').attr("style") });
|
2018-08-13 14:53:18 +08:00
|
|
|
|
$dialogNew.find('[data-toggle="LgbValidate"] [aria-describedby]').tooltip('hide');
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$dialogNew.hide();
|
|
|
|
|
$dialogMenu.modal('show');
|
2018-09-14 18:14:56 +08:00
|
|
|
|
}
|
2018-06-07 00:45:47 +08:00
|
|
|
|
|
2018-08-03 21:19:01 +08:00
|
|
|
|
$dialogMenu.on('hidden.bs.modal', function () {
|
|
|
|
|
var sta = state.pop();
|
|
|
|
|
$('body').attr('class', sta.css);
|
|
|
|
|
$('body').attr('style', sta.style);
|
|
|
|
|
$dialogNew.show();
|
|
|
|
|
});
|
2018-06-07 00:45:47 +08:00
|
|
|
|
|
|
|
|
|
$btnSubmitMenu.on('click', function () {
|
|
|
|
|
$nestMenu.find('li span').removeClass('active');
|
|
|
|
|
var type = $(this).data('type');
|
|
|
|
|
switch (type) {
|
|
|
|
|
case "parent":
|
|
|
|
|
$parentMenuID.val($('.dd3-content :radio:checked').val());
|
|
|
|
|
$parentMenuName.val($('.dd3-content :radio:checked').next('span').text());
|
|
|
|
|
break;
|
|
|
|
|
case "order":
|
|
|
|
|
var data = $nestMenu.find('li:visible');
|
|
|
|
|
var mid = $('#menuID').val();
|
|
|
|
|
for (index in data) {
|
|
|
|
|
var $data = $(data[index]);
|
2018-09-02 00:50:13 +08:00
|
|
|
|
if ($data.attr('data-id') === mid || $data.attr('data-id') === 0) {
|
2018-06-07 00:45:47 +08:00
|
|
|
|
if (index > 0) index--;
|
|
|
|
|
$('#order').val($(data[index]).attr('data-order'));
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Dialog shown event
|
|
|
|
|
$dialog.on('show.bs.modal', function () {
|
|
|
|
|
var icon = $inputIcon.val();
|
2018-09-02 00:50:13 +08:00
|
|
|
|
if (icon === "") icon = "fa fa-dashboard";
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$btnPickIcon.find('i').attr('class', icon);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$nestMenu.nestMenu(initNestMenu);
|
|
|
|
|
|
2018-09-14 18:14:56 +08:00
|
|
|
|
var $scroll = null;
|
2018-06-07 00:45:47 +08:00
|
|
|
|
$.bc({
|
|
|
|
|
url: Menu.iconView,
|
2018-06-13 07:28:14 +08:00
|
|
|
|
contentType: 'text/html',
|
|
|
|
|
dataType: 'html',
|
2018-06-07 00:45:47 +08:00
|
|
|
|
callback: function (result) {
|
|
|
|
|
if (result) {
|
2018-09-14 18:14:56 +08:00
|
|
|
|
var $html = $dialogIcon.find('.modal-body').html(result);
|
2018-06-07 00:45:47 +08:00
|
|
|
|
var $iconList = $('div.fontawesome-icon-list').on('click', 'div.fa-hover a, ul li', function () {
|
|
|
|
|
$pickIcon.attr('class', $(this).find('i, span:first').attr('class'));
|
|
|
|
|
return false;
|
|
|
|
|
});
|
2018-08-03 21:47:32 +08:00
|
|
|
|
$iconList.find('ul li').addClass('col-xl-2 col-md-3 col-sm-4 col-6');
|
|
|
|
|
$iconList.find('div').addClass('col-xl-2 col-6');
|
2018-08-03 23:58:03 +08:00
|
|
|
|
$('[data-spy="scroll"]').each(function () {
|
|
|
|
|
$(this).scrollspy({ target: $(this).attr('data-target') });
|
|
|
|
|
});
|
2018-09-14 18:14:56 +08:00
|
|
|
|
|
2018-09-23 12:59:49 +08:00
|
|
|
|
if (!$.browser.versions.ios) $scroll = $html.find('.fa-nav .nav').mCustomScrollbar({ theme: 'minimal-dark' });
|
2018-06-07 00:45:47 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
2019-03-11 15:45:38 +08:00
|
|
|
|
|
|
|
|
|
// autocomplete
|
|
|
|
|
$.bc({
|
|
|
|
|
url: "api/Category/RetrieveMenus",
|
|
|
|
|
callback: function (result) {
|
|
|
|
|
$('#txt_menus_name').typeahead({
|
|
|
|
|
source: result,
|
|
|
|
|
showHintOnFocus: 'all',
|
|
|
|
|
fitToElement: true,
|
|
|
|
|
items: 'all'
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$.bc({
|
|
|
|
|
url: "api/Category/RetrieveParentMenus",
|
|
|
|
|
callback: function (result) {
|
|
|
|
|
$('#txt_parent_menus_name').typeahead({
|
|
|
|
|
source: result,
|
|
|
|
|
showHintOnFocus: 'all',
|
|
|
|
|
fitToElement: true,
|
|
|
|
|
items: 'all'
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
});
|
2016-10-25 18:54:20 +08:00
|
|
|
|
});
|