$(function () { var $dialogUser = $("#dialogUser"); var $dialogUserHeader = $('#myUserModalLabel'); var $dialogUserForm = $('#userForm'); var $dialogGroup = $("#dialogGroup"); var $dialogGroupHeader = $('#myGroupModalLabel'); var $dialogGroupForm = $('#groupForm'); var $dialogMenu = $('#dialogMenu'); var $dialogMenuHeader = $('#myMenuModalLabel'); var $dialogSubMenu = $('#dialogSubMenu').find('.modal-content'); var $btnSubmitMenu = $('#btnSubmitMenu'); var $nestMenu = $('#nestable_menu'); var $nestMenuInput = $nestMenu.find('div.dd3-content'); var bsa = new BootstrapAdmin({ url: Role.url, dataEntity: new DataEntity({ map: { ID: "roleID", RoleName: "roleName", Description: "roleDesc" } }), click: { assign: [{ id: 'btn_assignUser', click: function (row) { $.bc({ Id: row.ID, url: User.url, data: { type: "role" }, swal: false, callback: function (result) { var htmlTemplate = this.htmlTemplate; var html = $.map(result, function (element, index) { return $.format(htmlTemplate, element.ID, element.DisplayName, element.Checked, element.UserName); }).join(''); $dialogUserHeader.text($.format('{0}-用户授权窗口', row.RoleName)); $dialogUserForm.html(html); $dialogUser.modal('show'); } }); } }, { id: 'btn_assignGroup', click: function (row) { $.bc({ Id: row.ID, url: Group.url, data: { type: "role" }, swal: false, callback: function (result) { var htmlTemplate = this.htmlTemplate; var html = $.map(result, function (element, index) { return $.format(htmlTemplate, element.ID, element.GroupName, element.Checked, element.Description); }).join(''); $dialogGroupHeader.text($.format('{0}-部门授权窗口', row.RoleName)); $dialogGroupForm.html(html); $dialogGroup.modal('show'); } }); } }, { id: 'btn_assignMenu', click: function (row) { $.bc({ Id: row.ID, url: Menu.url, data: { type: "role" }, swal: false, callback: function (result) { $dialogMenuHeader.text($.format('{0}-菜单授权窗口', row.RoleName)); $btnSubmitMenu.data('type', 'menu'); // set checkbox status var menus = $nestMenu.find('input:checkbox'); menus.removeProp('checked'); $.each(result, function (index, item) { var selector = $.format('[value={0}]', item.ID); menus.filter(selector).prop('checked', 'checked'); }); $dialogSubMenu.show(); $dialogMenu.modal('show'); } }); } }, { id: 'btnSubmitUser', click: function (row) { var roleId = row.ID; var userIds = $dialogUser.find(':checked').map(function (index, element) { return $(element).val(); }).toArray().join(','); $.bc({ Id: roleId, url: User.url, method: "PUT", data: { type: "role", userIds: userIds }, modal: 'dialogUser', title: User.title }); } }, { id: 'btnSubmitGroup', click: function (row) { var roleId = row.ID; var groupIds = $dialogGroup.find(':checked').map(function (index, element) { return $(element).val(); }).toArray().join(','); $.bc({ Id: roleId, url: Group.url, method: "PUT", data: { type: "role", groupIds: groupIds }, modal: 'dialogGroup', title: Group.title }); } }, { id: 'btnSubmitMenu', click: function (row) { var roleId = row.ID; var type = $btnSubmitMenu.data('type'); switch (type) { case "menu": var menuIds = $nestMenuInput.find('input:checkbox:checked').map(function (index, element) { return $(element).val(); }).toArray().join(','); break; default: break; } $.bc({ Id: roleId, url: Menu.url, method: "PUT", data: { type: "role", menuIds: menuIds }, modal: 'dialogMenu', title: Menu.title }); } }] } }); $('table').smartTable({ url: Role.url, //请求后台的URL(*) sortName: 'RoleName', queryParams: function (params) { return $.extend(params, { roleName: $("#txt_search_name").val(), description: $("#txt_role_desc").val() }); }, //传递参数(*) columns: [{ checkbox: true }, { title: "Id", field: "ID", events: bsa.idEvents(), formatter: BootstrapAdmin.idFormatter }, { title: "角色名称", field: "RoleName", sortable: true }, { title: "角色描述", field: "Description", sortable: false } ] }); // validate $('#dataForm').autoValidate({ roleName: { required: true, maxlength: 50 } }); $nestMenu.nestMenu(function () { $nestMenuInput = $nestMenu.find('div.dd3-content'); $nestMenuInput.on('click', ':checkbox', function () { var val = $(this).prop('checked'); var child = $(this).parent().parent().next(); if (child.hasClass('dd-list')) { child.find(':checkbox').prop('checked', val); } }).find('label:last').hide(); }); });