@tangential/admin-console
Version:
A basic administration console
142 lines • 30.6 kB
JavaScript
import { LiveAnnouncer } from '@angular/cdk/a11y';
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ViewChild, ViewEncapsulation } from '@angular/core';
import { AdminService, AuthUser } from '@tangential/authorization-service';
import { generatePushID } from '@tangential/core';
import { MatSort } from '@angular/material/sort';
import { SelectionModel } from '@angular/cdk/collections';
import { MatTableDataSource } from '@angular/material/table';
import { AdminConsoleParentPage } from '../_parent/admin-console-parent.page';
import * as i0 from "@angular/core";
import * as i1 from "@tangential/authorization-service";
import * as i2 from "../_parent/admin-console-parent.page";
import * as i3 from "@angular/cdk/a11y";
import * as i4 from "@angular/material/checkbox";
import * as i5 from "@tangential/components";
import * as i6 from "@angular/material/table";
import * as i7 from "@angular/material/sort";
import * as i8 from "@angular/common";
export class UserManagerPage {
constructor(adminService, parent, _liveAnnouncer, changeDetectorRef) {
this.adminService = adminService;
this.parent = parent;
this._liveAnnouncer = _liveAnnouncer;
this.changeDetectorRef = changeDetectorRef;
this.displayedColumns = ['select', '$key', 'displayName', 'email', 'lastSignInMils'];
this.dataSource = new MatTableDataSource();
this.selection = new SelectionModel(true, []);
this.rows = [];
this.selected = [];
this.columns = [
{ prop: '$key', name: 'Key', flexGrow: 1 },
{ prop: 'displayName', name: 'Display Name', flexGrow: 2 },
{ prop: 'email', name: 'Created', flexGrow: 2 },
{ prop: 'lastSignInMils', name: 'Last Sign In', flexGrow: 1 }
];
}
ngOnInit() {
this.parent.auth$.subscribe({
next: (v) => {
this.rows = v.users;
this.dataSource = new MatTableDataSource(v.users);
this.dataSource.sort = this.sort;
this.changeDetectorRef.markForCheck();
}
});
}
grantPermission(user, permission) {
this.adminService.grantPermissionOnUser(user, permission).catch((reason) => {
console.error('UserManagerComponent', 'could not grant permission', reason);
});
}
revokePermission(user, permission) {
console.log('UserManagerComponent', 'revokePermission');
this.adminService.revokePermissionOnUser(user, permission).catch((reason) => {
console.error('UserManagerComponent', 'could not revoke permission', reason);
});
}
grantRole(user, role) {
this.adminService.grantRoleOnUser(user, role).catch((reason) => {
console.error('UserManagerComponent', 'could not grant role', reason);
});
}
revokeRole(user, role) {
this.adminService.revokeRoleOnUser(user.$key, role.$key).catch((reason) => {
console.error('UserManagerComponent', 'could not revoke role', reason);
});
}
onAddItemAction() {
const user = new AuthUser(generatePushID());
user.displayName = 'New User ';
this.adminService.addUser(user).catch((reason) => {
console.error('UserManagerComponent', 'error adding user', reason);
throw new Error(reason);
});
}
onRemove(key) {
this.adminService.removeUser(key).catch((reason) => {
console.error('UserManagerComponent', 'error removing user', reason);
throw new Error(reason);
});
}
onRemoveSelectedAction(keys) {
keys.forEach((key) => {
this.adminService.removeUser(key).catch((reason) => {
console.error('UserManagerComponent', 'error removing user', reason);
throw new Error(reason);
});
});
}
onItemChange(user) {
this.adminService.updateUser(user).catch((reason) => {
console.error('UserManagerComponent', 'error updating user', reason);
throw new Error(reason);
});
}
/**
* Borrowed directly from Angular Material examples: https://material.angular.io/components/table/overview
*/
/** Whether the number of selected elements matches the total number of rows. */
isAllSelected() {
const numSelected = this.selection.selected.length;
const numRows = this.dataSource.data.length;
return numSelected === numRows;
}
/** Selects all rows if they are not all selected; otherwise clear selection. */
toggleAllRows() {
if (this.isAllSelected()) {
this.selection.clear();
return;
}
this.selection.select(...this.dataSource.data);
}
/** The label for the checkbox on the passed row */
checkboxLabel(row) {
if (!row) {
return `${this.isAllSelected() ? 'deselect' : 'select'} all`;
}
return `${this.selection.isSelected(row) ? 'deselect' : 'select'} ${row.displayName}`;
}
/** Announce the change in sort state for assistive technology. */
announceSortChange(sortState) {
// This example uses English messages. If your application supports
// multiple language, you would internationalize these strings.
// Furthermore, you can customize the message to add additional
// details about the values being sorted.
if (sortState.direction) {
this._liveAnnouncer.announce(`Sorted ${sortState.direction}ending`);
}
else {
this._liveAnnouncer.announce('Sorting cleared');
}
}
}
UserManagerPage.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: UserManagerPage, deps: [{ token: i1.AdminService }, { token: i2.AdminConsoleParentPage }, { token: i3.LiveAnnouncer }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
UserManagerPage.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: UserManagerPage, selector: "tanj-user-manager-page", viewQueries: [{ propertyName: "sort", first: true, predicate: MatSort, descendants: true }], ngImport: i0, template: "<tanj-page-body>\n <table mat-table matSort (matSortChange)=\"announceSortChange($event)\" [dataSource]=\"dataSource\" class=\"mat-elevation-z8 tng-user-mgr-table\">\n\n <!-- Checkbox Column -->\n <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef>\n <mat-checkbox (change)=\"$event ? toggleAllRows() : null\"\n [checked]=\"selection.hasValue() && isAllSelected()\"\n [indeterminate]=\"selection.hasValue() && !isAllSelected()\"\n [aria-label]=\"checkboxLabel()\">\n </mat-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let row\" >\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selection.toggle(row) : null\"\n [checked]=\"selection.isSelected(row)\"\n [aria-label]=\"checkboxLabel(row)\">\n </mat-checkbox>\n </td>\n </ng-container>\n\n <!-- UID Column -->\n <ng-container matColumnDef=\"$key\">\n <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by UID\"> User ID </th>\n <td mat-cell *matCellDef=\"let element\"> {{element.$key}} </td>\n </ng-container>\n\n <!-- User name Column -->\n <ng-container matColumnDef=\"displayName\">\n <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by name\"> User Name </th>\n <td mat-cell *matCellDef=\"let element\"> {{element.displayName}} </td>\n </ng-container>\n\n <!-- User Email Column -->\n <ng-container matColumnDef=\"email\" >\n <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by email\"> Email </th>\n <td mat-cell *matCellDef=\"let element\"> {{element.email}} </td>\n </ng-container>\n\n <!-- Last Sign in Column -->\n <ng-container matColumnDef=\"lastSignInMils\">\n <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by Last Sign In\"> Last Sign In </th>\n <td mat-cell *matCellDef=\"let element\"> {{element.lastSignInMils | date:'yyyy-MM~dd, HH:mm:ss' }} </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" (click)=\"selection.toggle(row)\"></tr>\n </table>\n</tanj-page-body>\n", dependencies: [{ kind: "component", type: i4.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i5.PageBodyComponent, selector: "tanj-page-body", inputs: ["suppressHeaderShim", "flex", "layout", "layoutAlign"] }, { kind: "component", type: i6.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i6.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i6.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i6.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i6.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i6.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i6.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i6.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i6.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i6.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i7.MatSort, selector: "[matSort]", inputs: ["matSortDisabled", "matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { kind: "component", type: i7.MatSortHeader, selector: "[mat-sort-header]", inputs: ["disabled", "mat-sort-header", "arrowPosition", "start", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { kind: "pipe", type: i8.DatePipe, name: "date" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: UserManagerPage, decorators: [{
type: Component,
args: [{ selector: 'tanj-user-manager-page', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<tanj-page-body>\n <table mat-table matSort (matSortChange)=\"announceSortChange($event)\" [dataSource]=\"dataSource\" class=\"mat-elevation-z8 tng-user-mgr-table\">\n\n <!-- Checkbox Column -->\n <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef>\n <mat-checkbox (change)=\"$event ? toggleAllRows() : null\"\n [checked]=\"selection.hasValue() && isAllSelected()\"\n [indeterminate]=\"selection.hasValue() && !isAllSelected()\"\n [aria-label]=\"checkboxLabel()\">\n </mat-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let row\" >\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selection.toggle(row) : null\"\n [checked]=\"selection.isSelected(row)\"\n [aria-label]=\"checkboxLabel(row)\">\n </mat-checkbox>\n </td>\n </ng-container>\n\n <!-- UID Column -->\n <ng-container matColumnDef=\"$key\">\n <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by UID\"> User ID </th>\n <td mat-cell *matCellDef=\"let element\"> {{element.$key}} </td>\n </ng-container>\n\n <!-- User name Column -->\n <ng-container matColumnDef=\"displayName\">\n <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by name\"> User Name </th>\n <td mat-cell *matCellDef=\"let element\"> {{element.displayName}} </td>\n </ng-container>\n\n <!-- User Email Column -->\n <ng-container matColumnDef=\"email\" >\n <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by email\"> Email </th>\n <td mat-cell *matCellDef=\"let element\"> {{element.email}} </td>\n </ng-container>\n\n <!-- Last Sign in Column -->\n <ng-container matColumnDef=\"lastSignInMils\">\n <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by Last Sign In\"> Last Sign In </th>\n <td mat-cell *matCellDef=\"let element\"> {{element.lastSignInMils | date:'yyyy-MM~dd, HH:mm:ss' }} </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" (click)=\"selection.toggle(row)\"></tr>\n </table>\n</tanj-page-body>\n" }]
}], ctorParameters: function () { return [{ type: i1.AdminService }, { type: i2.AdminConsoleParentPage }, { type: i3.LiveAnnouncer }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { sort: [{
type: ViewChild,
args: [MatSort]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-manager.page.js","sourceRoot":"","sources":["../../../../../../../projects/tangential/admin-console/src/lib/pages/users/user-manager.page.ts","../../../../../../../projects/tangential/admin-console/src/lib/pages/users/user-manager.page.html"],"names":[],"mappings":"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","sourcesContent":["import {LiveAnnouncer} from '@angular/cdk/a11y'\nimport {ChangeDetectionStrategy, ChangeDetectorRef, Component, OnInit, ViewChild, ViewEncapsulation} from '@angular/core'\nimport {AdminService, AuthPermission, AuthRole, AuthUser, UserService} from '@tangential/authorization-service'\nimport {generatePushID} from '@tangential/core'\nimport {MatSort, Sort} from '@angular/material/sort';\nimport {SelectionModel} from '@angular/cdk/collections';\nimport {MatTableDataSource} from '@angular/material/table';\nimport {AdminConsoleParentPage} from '../_parent/admin-console-parent.page'\n\n\n@Component({\n  selector:        'tanj-user-manager-page',\n  templateUrl:     './user-manager.page.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation:   ViewEncapsulation.None\n})\nexport class UserManagerPage implements OnInit {\n  displayedColumns: string[] = ['select', '$key', 'displayName', 'email', 'lastSignInMils'];\n  dataSource = new MatTableDataSource<AuthUser>();\n  selection = new SelectionModel<AuthUser>(true, []);\n\n  rows: AuthUser[] = []\n  selected = []\n  columns = [\n    {prop: '$key', name: 'Key', flexGrow: 1},\n    {prop: 'displayName', name: 'Display Name', flexGrow: 2},\n    {prop: 'email', name: 'Created', flexGrow: 2},\n    {prop: 'lastSignInMils', name: 'Last Sign In', flexGrow: 1}\n  ]\n\n\n  constructor(private adminService: AdminService,\n              private parent: AdminConsoleParentPage,\n              private _liveAnnouncer: LiveAnnouncer,\n              private changeDetectorRef: ChangeDetectorRef) {\n  }\n\n  @ViewChild(MatSort) sort: MatSort;\n\n  ngOnInit() {\n    this.parent.auth$.subscribe({\n      next: (v) => {\n        this.rows = v.users\n        this.dataSource = new MatTableDataSource<AuthUser>(v.users);\n        this.dataSource.sort = this.sort;\n        this.changeDetectorRef.markForCheck()\n      }\n    })\n  }\n\n\n  grantPermission(user: AuthUser, permission: AuthPermission) {\n    this.adminService.grantPermissionOnUser(user, permission).catch((reason) => {\n      console.error('UserManagerComponent', 'could not grant permission', reason)\n    })\n  }\n\n  revokePermission(user: AuthUser, permission: AuthPermission) {\n    console.log('UserManagerComponent', 'revokePermission')\n    this.adminService.revokePermissionOnUser(user, permission).catch((reason) => {\n      console.error('UserManagerComponent', 'could not revoke permission', reason)\n    })\n  }\n\n  grantRole(user: AuthUser, role: AuthRole) {\n    this.adminService.grantRoleOnUser(user, role).catch((reason) => {\n      console.error('UserManagerComponent', 'could not grant role', reason)\n    })\n  }\n\n  revokeRole(user: AuthUser, role: AuthRole) {\n    this.adminService.revokeRoleOnUser(user.$key, role.$key).catch((reason) => {\n      console.error('UserManagerComponent', 'could not revoke role', reason)\n    })\n  }\n\n\n  onAddItemAction() {\n    const user = new AuthUser(generatePushID())\n    user.displayName = 'New User '\n    this.adminService.addUser(user).catch((reason) => {\n      console.error('UserManagerComponent', 'error adding user', reason)\n      throw new Error(reason)\n    })\n  }\n\n  onRemove(key: string) {\n    this.adminService.removeUser(key).catch((reason) => {\n      console.error('UserManagerComponent', 'error removing user', reason)\n      throw new Error(reason)\n    })\n  }\n\n  onRemoveSelectedAction(keys: string[]) {\n    keys.forEach((key) => {\n      this.adminService.removeUser(key).catch((reason) => {\n        console.error('UserManagerComponent', 'error removing user', reason)\n        throw new Error(reason)\n      })\n    })\n  }\n\n\n  onItemChange(user: AuthUser) {\n    this.adminService.updateUser(user).catch((reason) => {\n      console.error('UserManagerComponent', 'error updating user', reason)\n      throw new Error(reason)\n    })\n\n  }\n\n  /**\n   * Borrowed directly from Angular Material examples: https://material.angular.io/components/table/overview\n   */\n  /** Whether the number of selected elements matches the total number of rows. */\n  isAllSelected() {\n    const numSelected = this.selection.selected.length;\n    const numRows = this.dataSource.data.length;\n    return numSelected === numRows;\n  }\n\n  /** Selects all rows if they are not all selected; otherwise clear selection. */\n  toggleAllRows() {\n    if (this.isAllSelected()) {\n      this.selection.clear();\n      return;\n    }\n    this.selection.select(...this.dataSource.data);\n  }\n\n  /** The label for the checkbox on the passed row */\n  checkboxLabel(row?: AuthUser): string {\n    if (!row) {\n      return `${this.isAllSelected() ? 'deselect' : 'select'} all`;\n    }\n    return `${this.selection.isSelected(row) ? 'deselect' : 'select'} ${row.displayName}`;\n  }\n\n  /** Announce the change in sort state for assistive technology. */\n  announceSortChange(sortState: Sort) {\n    // This example uses English messages. If your application supports\n    // multiple language, you would internationalize these strings.\n    // Furthermore, you can customize the message to add additional\n    // details about the values being sorted.\n    if (sortState.direction) {\n      this._liveAnnouncer.announce(`Sorted ${sortState.direction}ending`);\n    } else {\n      this._liveAnnouncer.announce('Sorting cleared');\n    }\n  }\n\n}\n","<tanj-page-body>\n  <table mat-table matSort (matSortChange)=\"announceSortChange($event)\"  [dataSource]=\"dataSource\" class=\"mat-elevation-z8 tng-user-mgr-table\">\n\n    <!-- Checkbox Column -->\n    <ng-container matColumnDef=\"select\">\n      <th mat-header-cell *matHeaderCellDef>\n        <mat-checkbox (change)=\"$event ? toggleAllRows() : null\"\n                      [checked]=\"selection.hasValue() && isAllSelected()\"\n                      [indeterminate]=\"selection.hasValue() && !isAllSelected()\"\n                      [aria-label]=\"checkboxLabel()\">\n        </mat-checkbox>\n      </th>\n      <td mat-cell *matCellDef=\"let row\" >\n        <mat-checkbox (click)=\"$event.stopPropagation()\"\n                      (change)=\"$event ? selection.toggle(row) : null\"\n                      [checked]=\"selection.isSelected(row)\"\n                      [aria-label]=\"checkboxLabel(row)\">\n        </mat-checkbox>\n      </td>\n    </ng-container>\n\n    <!-- UID Column -->\n    <ng-container matColumnDef=\"$key\">\n      <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by UID\"> User ID </th>\n      <td mat-cell *matCellDef=\"let element\"> {{element.$key}} </td>\n    </ng-container>\n\n    <!-- User name Column -->\n    <ng-container matColumnDef=\"displayName\">\n      <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by name\">  User Name </th>\n      <td mat-cell *matCellDef=\"let element\"> {{element.displayName}} </td>\n    </ng-container>\n\n    <!-- User Email Column -->\n    <ng-container matColumnDef=\"email\" >\n      <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by email\"> Email </th>\n      <td mat-cell *matCellDef=\"let element\"> {{element.email}} </td>\n    </ng-container>\n\n    <!-- Last Sign in Column -->\n    <ng-container matColumnDef=\"lastSignInMils\">\n      <th mat-header-cell *matHeaderCellDef mat-sort-header sortActionDescription=\"Sort by Last Sign In\"> Last Sign In </th>\n      <td mat-cell *matCellDef=\"let element\"> {{element.lastSignInMils | date:'yyyy-MM~dd, HH:mm:ss' }} </td>\n    </ng-container>\n\n    <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n    <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" (click)=\"selection.toggle(row)\"></tr>\n  </table>\n</tanj-page-body>\n"]}