PeerTube/client/src/app/+admin/users/user-list/user-list.component.ts

57 lines
1.4 KiB
TypeScript
Raw Normal View History

2016-08-09 21:45:21 +02:00
import { Component, OnInit } from '@angular/core';
import { NotificationsService } from 'angular2-notifications';
import { ConfirmService } from '../../../core';
2016-08-09 21:45:21 +02:00
import { User } from '../../../shared';
import { UserService } from '../shared';
@Component({
selector: 'my-user-list',
templateUrl: './user-list.component.html',
styleUrls: [ './user-list.component.scss' ]
2016-08-09 21:45:21 +02:00
})
export class UserListComponent implements OnInit {
totalUsers: number;
users: User[];
constructor(
private notificationsService: NotificationsService,
private confirmService: ConfirmService,
private userService: UserService
) {}
2016-08-09 21:45:21 +02:00
ngOnInit() {
this.getUsers();
}
getUsers() {
this.userService.getUsers().subscribe(
({ users, totalUsers }) => {
this.users = users;
this.totalUsers = totalUsers;
},
err => this.notificationsService.error('Error', err.text)
2016-08-09 21:45:21 +02:00
);
}
removeUser(user: User) {
this.confirmService.confirm('Do you really want to delete this user?', 'Delete').subscribe(
res => {
if (res === false) return;
this.userService.removeUser(user).subscribe(
() => {
this.notificationsService.success('Success', `User ${user.username} deleted.`);
this.getUsers();
},
err => this.notificationsService.error('Error', err.text)
);
}
);
2016-08-09 21:45:21 +02:00
}
}