UNPKG

apt-maintenance-account

Version:

Apartment Maintenance Account Tracking Application - Client Side in Angular

83 lines (70 loc) 2.47 kB
import { Component, OnInit } from '@angular/core'; import { Router, ActivatedRoute, Params } from '@angular/router'; import { Observable } from 'rxjs/Observable'; import 'rxjs/add/operator/switchMap'; import { Role } from './model'; import { Authorization } from '../authorization/model'; import { environment } from '../../environments/environment'; import { RoleService } from './service'; import { Logger } from '../logger/default-log.service'; @Component({ selector: 'role-list', templateUrl: './list.component.html', styleUrls: ['./list.component.css'] }) export class RoleListComponent implements OnInit { models: Observable<Role[]>; authzn: Authorization; addAllowed: boolean = false; deleteAllowed: boolean = false; viewAllowed: boolean = false; editAllowed: boolean = false; totalRecords: number = 0; private selectedId: number; caption: string = 'Role List of ' + environment.brand; constructor( private service: RoleService, private route: ActivatedRoute, private router: Router, private logger: Logger ) { } ngOnInit(): void { this.authzn = this.service.getAuthzn(); this.logger.info('Inside role list component...'); this.logger.info(this.authzn); if (this.authzn.permissions.length < 1) return; // just return if permission list is empty this.addAllowed = this.authzn.allowsAdd(); this.deleteAllowed = this.authzn.allowsDelete(); this.viewAllowed = this.authzn.allowsView(); this.editAllowed = this.authzn.allowsEdit(); this.getList(); } onSelect(model: Role): void { this.router.navigate(['/roles', model.id]); } isSelected(model: Role) { return model ? model.id === this.selectedId : false; } add(): void { this.router.navigate(['/roles', 0]); // 0 represent new role } delete(model: Role): void { this.service .delete(model.id) .then(() => { // filter out the deleted Role model from role models this.models = this.models.filter((models, i) => { return models[i] !== model; }); this.totalRecords--; }); } private getList() { this.models = this.route.params .switchMap((params: Params) => { this.selectedId = +params['id']; return this.service.getList(); }); this.models.subscribe(models => { this.totalRecords = models.length; }); } }