Add roles UI creating and editing a group

This commit is contained in:
Girish Ramakrishnan
2018-06-18 17:45:09 -07:00
parent 5bd57b6dbd
commit 12b1909c7a
3 changed files with 156 additions and 6 deletions

View File

@@ -226,6 +226,11 @@ angular.module('Application').controller('UsersController', ['$scope', '$locatio
busy: false,
error: {},
name: '',
roles: {
canManageUsers: false,
canManageApps: false,
canManageDomains: false,
},
show: function () {
$scope.groupAdd.busy = false;
@@ -243,7 +248,12 @@ angular.module('Application').controller('UsersController', ['$scope', '$locatio
$scope.groupAdd.busy = true;
$scope.groupAdd.error = {};
Client.createGroup($scope.groupAdd.name, function (error) {
var roles = [ ];
if ($scope.groupAdd.roles.canManageApps) roles.push('manage_apps');
if ($scope.groupAdd.roles.canManageUsers) roles.push('manage_users');
if ($scope.groupAdd.roles.canManageDomains) roles.push('manage_domains');
Client.createGroup($scope.groupAdd.name, roles, function (error) {
$scope.groupAdd.busy = false;
if (error && error.statusCode === 409) {
@@ -266,6 +276,69 @@ angular.module('Application').controller('UsersController', ['$scope', '$locatio
}
};
$scope.groupEdit = {
busy: false,
error: {},
groupInfo: {},
name: '',
roles: {
canManageUsers: false,
canManageApps: false,
canManageDomains: false,
},
show: function (groupInfo) {
$scope.groupEdit.error = {};
$scope.groupEdit.groupInfo = groupInfo;
$scope.groupEdit.name = groupInfo.name;
for (var i = 0; i < groupInfo.roles.length; i++) {
switch (groupInfo.roles[i]) {
case 'manage_apps': $scope.groupEdit.roles.canManageApps = true; break;
case 'manage_users': $scope.groupEdit.roles.canManageUsers = true; break;
case 'manage_domains': $scope.groupEdit.roles.canManageDomains = true; break;
default: break;
}
}
$scope.groupEdit_form.$setPristine();
$scope.groupEdit_form.$setUntouched();
$('#groupEditModal').modal('show');
},
submit: function () {
$scope.groupEdit.busy = true;
$scope.groupEdit.error = {};
var roles = [ ];
if ($scope.groupEdit.roles.canManageApps) roles.push('manage_apps');
if ($scope.groupEdit.roles.canManageUsers) roles.push('manage_users');
if ($scope.groupEdit.roles.canManageDomains) roles.push('manage_domains');
Client.updateGroup($scope.groupEdit.groupInfo.id, $scope.groupEdit.name, roles, function (error) {
$scope.groupEdit.busy = false;
if (error && error.statusCode === 409) {
$scope.groupEdit.error.name = 'Name already taken';
$scope.groupEditForm.name.$setPristine();
$('#groupEditName').focus();
return;
} else if (error && error.statusCode === 400) {
$scope.groupEdit.error.name = error.message;
$scope.groupEditForm.name.$setPristine();
$('#groupEditName').focus();
return;
}
if (error) return console.error('Unable to edit group.', error.statusCode, error.message);
refresh();
$('#groupEditModal').modal('hide');
});
}
};
$scope.inviteSent = {
email: '',
setupLink: ''
@@ -365,7 +438,7 @@ angular.module('Application').controller('UsersController', ['$scope', '$locatio
Client.onReady(refresh);
// setup all the dialog focus handling
['userAddModal', 'userRemoveModal', 'userEditModal', 'groupAddModal', 'groupRemoveModal'].forEach(function (id) {
['userAddModal', 'userRemoveModal', 'userEditModal', 'groupAddModal', 'groupEditModal', 'groupRemoveModal'].forEach(function (id) {
$('#' + id).on('shown.bs.modal', function () {
$(this).find("[autofocus]:first").focus();
});