$(function () { var $dialog = $('#dialogNew'); var $pickIcon = $('#pickIcon'); var $dialogNew = $dialog.find('div.modal-dialog'); var $dialogIcon = $('#dialogIcon'); var $dialogMenu = $('#dialogSubMenu').find('.modal-content'); 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.find('label:first').hide(); } var bsa = new BootstrapAdmin({ url: Menu.url, dataEntity: new DataEntity({ map: { ID: "menuID", ParentId: "parentId", ParentName: "parentName", Name: "name", Order: "order", Icon: "icon", Url: "url", Category: "category", Target: "target" } }), click: { assign: [{ id: 'btn_assignRole', click: function (row) { $.bc({ Id: row.ID, url: Role.url, data: { type: "menu" }, swal: false, 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); }).join('') $dialogRoleHeader.text($.format('{0}-角色授权窗口', row.Name)); $dialogRoleForm.html(html).find('[role="tooltip"]').each(function (index, label) { if (label.title == "") label.title = "未设置"; }).tooltip({ container: 'body', delay: { "show": 500, "hide": 100 } }); $dialogRole.modal('show'); } }); } }, { id: 'btnSubmitRole', click: function (row) { var menuId = row.ID; var roleIds = $dialogRole.find('input:checked').map(function (index, element) { return $(element).val(); }).toArray().join(','); $.bc({ Id: menuId, url: Role.url, method: "PUT", data: { type: "menu", roleIds: roleIds }, title: Role.title, modal: 'dialogRole' }); } }] }, callback: function (result) { if (!result.success) return; if ((result.oper == "save") || result.oper == "del") { $nestMenu.nestMenu(initNestMenu); } } }); $('table').smartTable({ url: Menu.url, //请求后台的URL(*) sortName: 'Order', queryParams: function (params) { return $.extend(params, { parentName: $('#txt_parent_menus_name').val(), name: $("#txt_menus_name").val(), category: $('#sel_menus_category').selectval() }); }, //传递参数(*) columns: [{ checkbox: true }, { title: "Id", field: "ID", events: bsa.idEvents(), formatter: BootstrapAdmin.idFormatter }, { title: "父级菜单", field: "ParentName", sortable: true }, { 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('', value); } return ""; } }, { 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; } } ] }); // validate $('#dataForm').autoValidate({ name: { required: true, maxlength: 50 }, order: { digits: true }, url: { required: true }, category: { required: true, maxlength: 50 } }); $btnPickIcon.on('click', function () { $dialogIcon.show(); }); $dialogIcon.find('div.modal-header, div.modal-footer').on('click', 'button', function () { $dialogIcon.hide(); }); $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 () { $dialogNew.hide(); $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.selectval() + '"]').show(); // handler new menu var did = $('#menuID').val(); if (did == "") did = 0; if (did == 0) { var menuName = $('#name').val(); var menuCate = $category.selectval(); if (menuName == "") menuName = "新建菜单-未命名"; $nestMenu.find('ol.dd-list:first').append($.format('