@tangential/admin-console
Version:
A basic administration console
119 lines • 24.3 kB
JavaScript
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
import { AuthUser } from '@tangential/authorization-service';
import { Observable } from 'rxjs';
import { debounceTime, distinctUntilChanged, filter, map } from 'rxjs/operators';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@angular/forms";
import * as i3 from "@angular/material/button";
import * as i4 from "@angular/material/icon";
import * as i5 from "@angular/material/form-field";
import * as i6 from "@angular/material/input";
export class UserComponent {
constructor() {
this.userRoles = [];
this.userGrantedPermissions = [];
this.userRolePermissions = [];
this.showSelector = true;
this.selected = false;
this.expanded = false;
this.selectionChange = new EventEmitter(false);
this.removeUser = new EventEmitter(false);
this.addUserRole = new EventEmitter(false);
this.removeUserRole = new EventEmitter(false);
this.addUserPermission = new EventEmitter(false);
this.removeUserPermission = new EventEmitter(false);
this._focusDebouncer = new EventEmitter(false);
this.submitted = false;
let distinct = this._focusDebouncer.asObservable();
distinct = distinct.pipe(debounceTime(10), distinctUntilChanged());
this.focus = distinct.pipe(filter((focused) => focused === true), map(() => {
this.expanded = true;
return new Event('focus');
}));
this.change = distinct.pipe(filter((focused) => focused === false && this._changed), map(() => this.user));
this.blur = distinct.pipe(filter((focused) => focused === false), map(() => new Event('blur')));
}
ngOnChanges(change) {
if (change.user_roles) {
// console.log('UserListItemComponent', 'ngOnChanges', this.roles)
// debugger
}
}
fireRemoveUser() {
this.removeUser.emit(this.user);
}
doToggleRole(role, enabled) {
if (enabled) {
this.addUserRole.emit({ user: this.user, role: role });
}
else {
this.removeUserRole.emit({ user: this.user, role: role });
}
}
doTogglePermission(permission) {
const event = { user: this.user, permission: permission };
if (this.userGrantedPermissions.some((item) => item.$key === permission.$key)) {
this.removeUserPermission.emit(event);
}
else {
this.addUserPermission.emit(event);
}
}
doToggleSelected() {
this.selected = !this.selected;
this.selectionChange.emit(this.selected);
}
onChange() {
this._changed = true;
}
onBlur() {
this._focusDebouncer.emit(false);
}
onFocus() {
this._focusDebouncer.emit(true);
}
onSubmit() {
console.log('UserComponent', 'onSubmit');
this.submitted = true;
}
}
UserComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: UserComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
UserComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: UserComponent, selector: "tanj-user", inputs: { user: "user", userRoles: "userRoles", userGrantedPermissions: "userGrantedPermissions", userRolePermissions: "userRolePermissions", showSelector: "showSelector", selected: "selected", expanded: "expanded" }, outputs: { change: "change", selectionChange: "selectionChange", removeUser: "removeUser", addUserRole: "addUserRole", removeUserRole: "removeUserRole", addUserPermission: "addUserPermission", removeUserPermission: "removeUserPermission", focus: "focus", blur: "blur" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"tanj-user-form-wrapper\" flex layout=\"column\" layout-align=\"start\">\n <form *ngIf=\"user != null\" (ngSubmit)=\"onSubmit($event)\" #theForm=\"ngForm\" flex layout=\"row\"\n layout-align=\"space-between\">\n\n <div class=\"tanj-user-inputs-wrapper\" layout=\"row\" flex=\"80\" layout-align=\"space-between start\">\n <mat-form-field flex=\"40\">\n <input matInput [(ngModel)]=\"user.email\" name=\"email\" #fName=\"ngModel\"\n class=\"tanj-input\"\n dividerColor=\"accent\"\n [type]=\"'email'\"\n required minlength=\"2\"\n value=\"{{user.email}}\"\n (change)=\"$event.stopPropagation(); onChange()\"\n (focus)=\"$event.stopPropagation(); onFocus()\"\n (blur)=\"$event.stopPropagation(); onBlur()\"\n placeholder=\"email\"\n /></mat-form-field>\n <mat-form-field flex=\"60\">\n <input matInput [(ngModel)]=\"user.displayName\" name=\"displayName\" #fDescription=\"ngModel\"\n class=\"tanj-description tanj-input\"\n dividerColor=\"accent\"\n [type]=\"'text'\"\n value=\"{{user.displayName}}\"\n (change)=\"$event.stopPropagation(); onChange()\"\n (focus)=\"$event.stopPropagation(); onFocus()\"\n (blur)=\"$event.stopPropagation(); onBlur()\"\n placeholder=\"Display Name\"/>\n </mat-form-field>\n </div>\n <div class=\"tanj-delete-button\" flex layout=\"row\" layout-align=\"end center\">\n <button mat-mini-fab\n type=\"button\"\n aria-label=\"Delete User\"\n (focus)=\"$event.stopPropagation(); onFocus()\"\n (blur)=\"$event.stopPropagation(); onBlur()\"\n (click)=\"fireRemoveUser()\"\n [disabled]=\"false\">\n <mat-icon class=\"mat-24\">delete</mat-icon>\n </button>\n </div>\n </form>\n</div>\n\n\n\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: UserComponent, decorators: [{
type: Component,
args: [{ selector: 'tanj-user', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div class=\"tanj-user-form-wrapper\" flex layout=\"column\" layout-align=\"start\">\n <form *ngIf=\"user != null\" (ngSubmit)=\"onSubmit($event)\" #theForm=\"ngForm\" flex layout=\"row\"\n layout-align=\"space-between\">\n\n <div class=\"tanj-user-inputs-wrapper\" layout=\"row\" flex=\"80\" layout-align=\"space-between start\">\n <mat-form-field flex=\"40\">\n <input matInput [(ngModel)]=\"user.email\" name=\"email\" #fName=\"ngModel\"\n class=\"tanj-input\"\n dividerColor=\"accent\"\n [type]=\"'email'\"\n required minlength=\"2\"\n value=\"{{user.email}}\"\n (change)=\"$event.stopPropagation(); onChange()\"\n (focus)=\"$event.stopPropagation(); onFocus()\"\n (blur)=\"$event.stopPropagation(); onBlur()\"\n placeholder=\"email\"\n /></mat-form-field>\n <mat-form-field flex=\"60\">\n <input matInput [(ngModel)]=\"user.displayName\" name=\"displayName\" #fDescription=\"ngModel\"\n class=\"tanj-description tanj-input\"\n dividerColor=\"accent\"\n [type]=\"'text'\"\n value=\"{{user.displayName}}\"\n (change)=\"$event.stopPropagation(); onChange()\"\n (focus)=\"$event.stopPropagation(); onFocus()\"\n (blur)=\"$event.stopPropagation(); onBlur()\"\n placeholder=\"Display Name\"/>\n </mat-form-field>\n </div>\n <div class=\"tanj-delete-button\" flex layout=\"row\" layout-align=\"end center\">\n <button mat-mini-fab\n type=\"button\"\n aria-label=\"Delete User\"\n (focus)=\"$event.stopPropagation(); onFocus()\"\n (blur)=\"$event.stopPropagation(); onBlur()\"\n (click)=\"fireRemoveUser()\"\n [disabled]=\"false\">\n <mat-icon class=\"mat-24\">delete</mat-icon>\n </button>\n </div>\n </form>\n</div>\n\n\n\n" }]
}], ctorParameters: function () { return []; }, propDecorators: { user: [{
type: Input
}], userRoles: [{
type: Input
}], userGrantedPermissions: [{
type: Input
}], userRolePermissions: [{
type: Input
}], showSelector: [{
type: Input
}], selected: [{
type: Input
}], expanded: [{
type: Input
}], change: [{
type: Output
}], selectionChange: [{
type: Output
}], removeUser: [{
type: Output
}], addUserRole: [{
type: Output
}], removeUserRole: [{
type: Output
}], addUserPermission: [{
type: Output
}], removeUserPermission: [{
type: Output
}], focus: [{
type: Output
}], blur: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.component.js","sourceRoot":"","sources":["../../../../../../../projects/tangential/admin-console/src/lib/pages/users/user.component.ts","../../../../../../../projects/tangential/admin-console/src/lib/pages/users/user.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, Output, ViewEncapsulation} from '@angular/core'\nimport {AuthPermission, AuthRole, AuthUser} from '@tangential/authorization-service'\nimport {Observable} from 'rxjs'\nimport {debounceTime, distinctUntilChanged, filter, map} from 'rxjs/operators'\n\n@Component({\n  selector:        'tanj-user',\n  templateUrl:     './user.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation:   ViewEncapsulation.None\n})\nexport class UserComponent implements OnChanges {\n\n  @Input() user: AuthUser\n  @Input() userRoles: AuthRole[] = []\n  @Input() userGrantedPermissions: AuthPermission[] = []\n  @Input() userRolePermissions: AuthPermission[] = []\n\n  @Input() showSelector: boolean = true\n  @Input() selected: boolean = false\n  @Input() expanded: boolean = false\n\n  @Output() change: Observable<AuthUser>;\n  @Output() selectionChange: EventEmitter<boolean> = new EventEmitter<boolean>(false)\n  @Output() removeUser: EventEmitter<AuthUser> = new EventEmitter<AuthUser>(false)\n  @Output() addUserRole: EventEmitter<{ user: AuthUser, role: AuthRole }> = new EventEmitter<{ user: AuthUser, role: AuthRole }>(false)\n  @Output() removeUserRole: EventEmitter<{ user: AuthUser, role: AuthRole }> = new EventEmitter<{ user: AuthUser, role: AuthRole }>(false)\n  @Output() addUserPermission: EventEmitter<{ user: AuthUser, permission: AuthPermission }> =\n    new EventEmitter<{ user: AuthUser, permission: AuthPermission }>(false)\n  @Output() removeUserPermission: EventEmitter<{ user: AuthUser, permission: AuthPermission }> =\n    new EventEmitter<{ user: AuthUser, permission: AuthPermission }>(false)\n\n\n  private _focusDebouncer: EventEmitter<boolean> = new EventEmitter<boolean>(false);\n\n  @Output() focus: Observable<Event>\n  @Output() blur: Observable<Event>\n\n  submitted = false;\n  private _changed: boolean\n\n  constructor() {\n    let distinct: Observable<boolean> = this._focusDebouncer.asObservable()\n    distinct = distinct.pipe(debounceTime(10),distinctUntilChanged())\n\n    this.focus = distinct.pipe(\n      filter((focused) => focused === true),\n      map(() => {\n        this.expanded = true\n        return new Event('focus')\n      }))\n\n    this.change = distinct.pipe(\n      filter((focused) => focused === false && this._changed),\n      map(() => this.user))\n\n    this.blur = distinct.pipe(\n      filter((focused) => focused === false),\n      map(() => new Event('blur')))\n  }\n\n  ngOnChanges(change: any) {\n    if (change.user_roles) {\n      // console.log('UserListItemComponent', 'ngOnChanges', this.roles)\n      // debugger\n    }\n  }\n\n  fireRemoveUser() {\n    this.removeUser.emit(this.user)\n  }\n\n  doToggleRole(role: AuthRole, enabled: boolean) {\n    if (enabled) {\n      this.addUserRole.emit({user: this.user, role: role})\n    } else {\n      this.removeUserRole.emit({user: this.user, role: role})\n    }\n  }\n\n  doTogglePermission(permission: AuthPermission) {\n    const event = {user: this.user, permission: permission};\n    if (this.userGrantedPermissions.some((item) => item.$key === permission.$key)) {\n      this.removeUserPermission.emit(event)\n    } else {\n      this.addUserPermission.emit(event)\n    }\n  }\n\n  doToggleSelected() {\n    this.selected = !this.selected\n    this.selectionChange.emit(this.selected)\n  }\n\n\n  onChange() {\n    this._changed = true\n  }\n\n  onBlur() {\n    this._focusDebouncer.emit(false)\n  }\n\n  onFocus() {\n    this._focusDebouncer.emit(true)\n\n  }\n\n  onSubmit() {\n    console.log('UserComponent', 'onSubmit')\n    this.submitted = true;\n  }\n}\n","<div class=\"tanj-user-form-wrapper\" flex layout=\"column\" layout-align=\"start\">\n  <form *ngIf=\"user != null\" (ngSubmit)=\"onSubmit($event)\" #theForm=\"ngForm\" flex layout=\"row\"\n        layout-align=\"space-between\">\n\n    <div class=\"tanj-user-inputs-wrapper\" layout=\"row\" flex=\"80\" layout-align=\"space-between start\">\n      <mat-form-field flex=\"40\">\n        <input matInput [(ngModel)]=\"user.email\" name=\"email\" #fName=\"ngModel\"\n               class=\"tanj-input\"\n               dividerColor=\"accent\"\n               [type]=\"'email'\"\n               required minlength=\"2\"\n               value=\"{{user.email}}\"\n               (change)=\"$event.stopPropagation(); onChange()\"\n               (focus)=\"$event.stopPropagation(); onFocus()\"\n               (blur)=\"$event.stopPropagation(); onBlur()\"\n               placeholder=\"email\"\n        /></mat-form-field>\n      <mat-form-field flex=\"60\">\n        <input matInput [(ngModel)]=\"user.displayName\" name=\"displayName\" #fDescription=\"ngModel\"\n               class=\"tanj-description tanj-input\"\n               dividerColor=\"accent\"\n               [type]=\"'text'\"\n               value=\"{{user.displayName}}\"\n               (change)=\"$event.stopPropagation(); onChange()\"\n               (focus)=\"$event.stopPropagation(); onFocus()\"\n               (blur)=\"$event.stopPropagation(); onBlur()\"\n               placeholder=\"Display Name\"/>\n      </mat-form-field>\n    </div>\n    <div class=\"tanj-delete-button\" flex layout=\"row\" layout-align=\"end center\">\n      <button mat-mini-fab\n              type=\"button\"\n              aria-label=\"Delete User\"\n              (focus)=\"$event.stopPropagation(); onFocus()\"\n              (blur)=\"$event.stopPropagation(); onBlur()\"\n              (click)=\"fireRemoveUser()\"\n              [disabled]=\"false\">\n        <mat-icon class=\"mat-24\">delete</mat-icon>\n      </button>\n    </div>\n  </form>\n</div>\n\n\n\n"]}