aboutsummaryrefslogblamecommitdiffhomepage
path: root/client/src/app/+admin/users/user-list/user-list.component.ts
blob: 2cc4d4349eae118cc6194481348fb43ed5d30fe5 (plain) (tree)
1
2
3
4
5
6
7
8
                                                 
 
                                                             
                                                             
 
                                              
                                                                 
                                       


                           

                                             
  
                                                                    


                    
                                                   
                                                                    
 
               
                                                       
                                           
                                    
     
           

   



                   
                                 
                                   

                                                                         
     
 

                                                                                                      
 




                                                                                      
 
                                                                  
     
   

                                      
                                                   









                                                            
                                                                                  

                     
 
import { Component, OnInit } from '@angular/core'

import { NotificationsService } from 'angular2-notifications'
import { SortMeta } from 'primeng/components/common/sortmeta'

import { ConfirmService } from '../../../core'
import { RestPagination, RestTable, User } from '../../../shared'
import { UserService } from '../shared'

@Component({
  selector: 'my-user-list',
  templateUrl: './user-list.component.html',
  styleUrls: [ './user-list.component.scss' ]
})
export class UserListComponent extends RestTable implements OnInit {
  users: User[] = []
  totalRecords = 0
  rowsPerPage = 10
  sort: SortMeta = { field: 'createdAt', order: 1 }
  pagination: RestPagination = { count: this.rowsPerPage, start: 0 }

  constructor (
    private notificationsService: NotificationsService,
    private confirmService: ConfirmService,
    private userService: UserService
  ) {
    super()
  }

  ngOnInit () {
    this.loadSort()
  }

  async removeUser (user: User) {
    if (user.username === 'root') {
      this.notificationsService.error('Error', 'You cannot delete root.')
      return
    }

    const res = await this.confirmService.confirm('Do you really want to delete this user?', 'Delete')
    if (res === false) return

    this.userService.removeUser(user).subscribe(
      () => {
        this.notificationsService.success('Success', `User ${user.username} deleted.`)
        this.loadData()
      },

      err => this.notificationsService.error('Error', err.message)
    )
  }

  getRouterUserEditLink (user: User) {
    return [ '/admin', 'users', 'update', user.id ]
  }

  protected loadData () {
    this.userService.getUsers(this.pagination, this.sort)
                    .subscribe(
                      resultList => {
                        this.users = resultList.data
                        this.totalRecords = resultList.total
                      },

                      err => this.notificationsService.error('Error', err.message)
                    )
  }
}