BootstrapAdmin/Bootstrap.Admin/wwwroot/js/users.js

127 lines
6.8 KiB
JavaScript
Raw Normal View History

2018-06-07 00:45:47 +08:00
$(function () {
var $dialogRole = $('#dialogRole');
var $dialogRoleHeader = $('#myRoleModalLabel');
var $dialogRoleForm = $('#roleForm');
var $dialogGroup = $("#dialogGroup");
var $dialogGroupHeader = $('#myGroupModalLabel');
var $dialogGroupForm = $('#groupForm');
var $dialogReset = $('#dialogReset');
var $dialogResetHeader = $('#myResetModalLabel');
var $resetReason = $('#resetReason');
var $table = $('table');
2018-06-07 00:45:47 +08:00
$table.lgbTable({
2018-06-07 00:45:47 +08:00
url: User.url,
dataBinder: {
2018-06-07 00:45:47 +08:00
map: {
Id: "#userID",
UserName: "#userName",
Password: "#password",
DisplayName: "#displayName",
NewPassword: "#confirm"
},
events: {
'#btn_assignRole': function (row) {
2018-06-07 00:45:47 +08:00
$.bc({
id: row.Id, url: Role.url, query: { type: "user" }, 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);
}).join('');
2018-06-07 00:45:47 +08:00
$dialogRoleHeader.text($.format('{0}-角色授权窗口', row.DisplayName));
$dialogRoleForm.html(html).find('[data-toggle="tooltip"]').each(function (index, label) {
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');
}
});
},
'#btn_assignGroup': function (row) {
2018-06-07 00:45:47 +08:00
$.bc({
id: row.Id, url: Group.url, query: { type: "user" }, 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.GroupName, element.Checked, element.Description);
}).join('');
$dialogGroupHeader.text($.format('{0}-部门授权窗口', row.DisplayName));
$dialogGroupForm.html(html).find('[data-toggle="tooltip"]').each(function (index, label) {
if (label.title === "") label.title = "未设置";
2018-08-03 18:12:35 +08:00
}).tooltip();
2018-06-07 00:45:47 +08:00
$dialogGroup.modal('show');
}
});
},
'#btnSubmitRole': function (row) {
2018-06-07 00:45:47 +08:00
var userId = row.Id;
var roleIds = $dialogRole.find(':checked').map(function (index, element) {
return $(element).val();
}).toArray();
$.bc({ id: userId, url: Role.url, method: 'put', data: roleIds, query: { type: "user" }, title: Role.title, modal: '#dialogRole' });
},
'#btnSubmitGroup': function (row) {
2018-06-07 00:45:47 +08:00
var userId = row.Id;
var groupIds = $dialogGroup.find(':checked').map(function (index, element) {
return $(element).val();
}).toArray();
$.bc({ id: userId, url: Group.url, method: 'put', data: groupIds, query: { type: "user" }, title: Group.title, modal: '#dialogGroup' });
},
'#btnReset': function (row) {
$.bc({ id: row.UserName, url: 'api/Register', method: 'put', data: { password: $('#resetPassword').val() }, modal: "#dialogReset", title: "重置密码", callback: function (result) { if (result) $table.bootstrapTable('refresh'); } });
2018-06-07 00:45:47 +08:00
}
},
callback: function (data) {
if (data && data.success && data.oper === 'save' && data.data.UserName === $('#userDisplayName').attr('data-userName')) {
$('#userDisplayName').text(data.data.DisplayName);
}
if (data && data.oper === 'create') {
$('#userName').prop('readonly', false).removeClass("ignore");
}
else if (data && data.oper === 'edit') {
$('#userName').prop('readonly', true).addClass("ignore");
}
2018-06-07 00:45:47 +08:00
}
},
smartTable: {
sortName: 'DisplayName',
sortOrder: "asc",
queryParams: function (params) { return $.extend(params, { name: $("#txt_search_name").val(), displayName: $('#txt_display_name').val() }); }, //传递参数(*
columns: [
{ title: "登陆名称", field: "UserName", sortable: true },
{ title: "显示名称", field: "DisplayName", sortable: true },
{ title: "注册时间", field: "RegisterTime", sortable: true },
{ title: "授权时间", field: "ApprovedTime", sortable: true },
{ title: "授权人", field: "ApprovedBy", sortable: true },
{ title: "说明", field: "Description", sortable: false },
{
title: "操作", field: "IsReset", formatter: function (value, row, index) {
return value === 1 ? '<button class="reset btn btn-danger"><i class="fa fa-remove"></i><span>重置</span></button>' : '';
},
events: {
'click .reset': function (e, value, row, index) {
$table.bootstrapTable('uncheckAll');
$table.bootstrapTable('check', index);
$dialogResetHeader.text($.format("{0} - 重置密码窗口", row.UserName));
$.bc({
id: row.UserName, url: User.url, method: 'post', query: { type: "reset" }, callback: function (result) {
if ($.isArray(result)) {
var reason = result.map(function (v, index) {
return $.format("{0}: {1}", v.Key, v.Value);
}).join('\n');
$resetReason.text(reason);
$dialogReset.modal('show');
}
}
});
}
}
}
],
exportOptions: {
fileName: "用户数据",
ignoreColumn: [0, 1]
}
2018-06-07 00:45:47 +08:00
}
});
});