mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
dashfolders: fix user group picker + cleanup
This commit is contained in:
@@ -5,44 +5,45 @@
|
||||
<h1>Edit User Group</h1>
|
||||
</div>
|
||||
|
||||
<form name="userGroupDetailsForm" class="gf-form-group">
|
||||
<form name="userGroupDetailsForm" class="gf-form-group gf-form-inline">
|
||||
<div class="gf-form">
|
||||
<span class="gf-form-label width-10">Name</span>
|
||||
<input type="text" required ng-model="ctrl.userGroup.name" class="gf-form-input max-width-14" >
|
||||
</div>
|
||||
|
||||
<div class="gf-form-button-row">
|
||||
<div class="gf-form">
|
||||
<button type="submit" class="btn btn-success" ng-click="ctrl.update()">Update</button>
|
||||
</div>
|
||||
</form>
|
||||
|
||||
<h3 class="page-heading">User Group Members</h3>
|
||||
<div class="gf-form-group">
|
||||
<h3 class="page-heading">User Group Members</h3>
|
||||
|
||||
<form name="ctrl.addMemberForm" class="gf-form-group">
|
||||
<div class="gf-form">
|
||||
<span class="gf-form-label width-10">Name</span>
|
||||
<user-picker user-id="ctrl.userId"></user-picker>
|
||||
</div>
|
||||
<form name="ctrl.addMemberForm" class="gf-form-group">
|
||||
<div class="gf-form">
|
||||
<span class="gf-form-label width-10">User</span>
|
||||
<user-picker user-picked="ctrl.userPicked($user)"></user-picker>
|
||||
</div>
|
||||
</form>
|
||||
|
||||
<div class="gf-form-button-row">
|
||||
<button type="submit" class="btn btn-success" ng-click="ctrl.addMember()">Add</button>
|
||||
</div>
|
||||
</form>
|
||||
|
||||
<table class="grafana-options-table">
|
||||
<tr>
|
||||
<th>Username</th>
|
||||
<th>Email</th>
|
||||
<th></th>
|
||||
</tr>
|
||||
<tr ng-repeat="userGroup in ctrl.userGroupMembers">
|
||||
<td>{{userGroup.login}}</td>
|
||||
<td>{{userGroup.email}}</td>
|
||||
<td style="width: 1%">
|
||||
<a ng-click="ctrl.removeUserGroupMember(userGroup)" class="btn btn-danger btn-mini">
|
||||
<i class="fa fa-remove"></i>
|
||||
</a>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
<table class="grafana-options-table" ng-show="ctrl.userGroupMembers.length > 0">
|
||||
<tr>
|
||||
<th>Username</th>
|
||||
<th>Email</th>
|
||||
<th></th>
|
||||
</tr>
|
||||
<tr ng-repeat="member in ctrl.userGroupMembers">
|
||||
<td>{{member.login}}</td>
|
||||
<td>{{member.email}}</td>
|
||||
<td style="width: 1%">
|
||||
<a ng-click="ctrl.removeUserGroupMember(member)" class="btn btn-danger btn-mini">
|
||||
<i class="fa fa-remove"></i>
|
||||
</a>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
<div>
|
||||
<em class="muted" ng-hide="ctrl.userGroupMembers.length > 0">
|
||||
This user group has no members yet.
|
||||
</em>
|
||||
</div>
|
||||
|
||||
@@ -16,7 +16,7 @@
|
||||
</span>
|
||||
</div>
|
||||
<div class="admin-list-table">
|
||||
<table class="filter-table form-inline">
|
||||
<table class="filter-table form-inline" ng-show="ctrl.userGroups.length > 0">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Id</th>
|
||||
@@ -54,4 +54,8 @@
|
||||
</li>
|
||||
</ol>
|
||||
</div>
|
||||
|
||||
<em class="muted" ng-hide="ctrl.userGroups.length > 0">
|
||||
No User Groups found.
|
||||
</em>
|
||||
</div>
|
||||
|
||||
@@ -21,18 +21,20 @@ var backendSrv = {
|
||||
backendSrv: backendSrv,
|
||||
$routeParams: {id: 1}
|
||||
});
|
||||
ctx.ctrl.userId = 1;
|
||||
}));
|
||||
|
||||
describe('when user is chosen to be added to user group', () => {
|
||||
beforeEach(() => {
|
||||
ctx.ctrl.addMemberForm = {$valid: true};
|
||||
ctx.ctrl.addMember();
|
||||
const userItem = {
|
||||
id: 2,
|
||||
login: 'user2',
|
||||
};
|
||||
ctx.ctrl.userPicked(userItem);
|
||||
});
|
||||
|
||||
it('should parse the result and save to db', () => {
|
||||
expect(backendSrv.post.getCall(0).args[0]).to.eql('/api/user-groups/1/members');
|
||||
expect(backendSrv.post.getCall(0).args[1].userId).to.eql(1);
|
||||
expect(backendSrv.post.getCall(0).args[1].userId).to.eql(2);
|
||||
});
|
||||
|
||||
it('should refresh the list after saving.', () => {
|
||||
|
||||
@@ -6,9 +6,7 @@ import _ from 'lodash';
|
||||
export default class UserGroupDetailsCtrl {
|
||||
userGroup: UserGroup;
|
||||
userGroupMembers: User[] = [];
|
||||
userId: number;
|
||||
navModel: any;
|
||||
addMemberForm: any;
|
||||
|
||||
constructor(private $scope, private $http, private backendSrv, private $routeParams, navModelSrv) {
|
||||
this.navModel = navModelSrv.getOrgNav(3);
|
||||
@@ -51,11 +49,9 @@ export default class UserGroupDetailsCtrl {
|
||||
this.backendSrv.put('/api/user-groups/' + this.userGroup.id, {name: this.userGroup.name});
|
||||
}
|
||||
|
||||
addMember() {
|
||||
if (!this.addMemberForm.$valid) { return; }
|
||||
|
||||
this.backendSrv.post(`/api/user-groups/${this.$routeParams.id}/members`, {userId: this.userId}).then(() => {
|
||||
this.userId = null;
|
||||
userPicked(user) {
|
||||
this.backendSrv.post(`/api/user-groups/${this.$routeParams.id}/members`, {userId: user.id}).then(() => {
|
||||
this.$scope.$broadcast('user-picker-reset');
|
||||
this.get();
|
||||
});
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user