UNPKG

angular-firebase-authorizator

Version:

Beta version of authorizator for angular linked to firebase, it creates a model in firestore to assign permissions to users an roles, and creates a view to update this permissions

176 lines 25.5 kB
import { __decorate, __extends, __metadata } from "tslib"; import { Component, Input } from '@angular/core'; import { BehaviorSubject } from 'rxjs'; import { DataSource } from '@angular/cdk/table'; import { AuthorizatorService } from '../../services/authorizator.service'; import { MatDialog } from '@angular/material/dialog'; import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar'; import { UpsertRoleComponent } from './upsert-role/upsert-role.component'; import { DeleteRoleWarningComponent } from './delete-role-warning/delete-role-warning.component'; import { PermissionManagerComponent } from '../permission-manager/permission-manager.component'; import { ProgressbarService } from '../../services/progressbar.service'; var RolesDatabase = /** @class */ (function () { function RolesDatabase() { this.dataChange = new BehaviorSubject([]); } Object.defineProperty(RolesDatabase.prototype, "data", { get: function () { return this.dataChange.value; }, enumerable: true, configurable: true }); return RolesDatabase; }()); export { RolesDatabase }; var RolesDataSource = /** @class */ (function (_super) { __extends(RolesDataSource, _super); function RolesDataSource(rolesDatabase) { var _this = _super.call(this) || this; _this.rolesDatabase = rolesDatabase; return _this; } RolesDataSource.prototype.connect = function () { return this.rolesDatabase.dataChange; }; RolesDataSource.prototype.disconnect = function () { }; return RolesDataSource; }(DataSource)); export { RolesDataSource }; var RolesComponent = /** @class */ (function () { function RolesComponent(authorizatorservice, dialog, snackbar, progressbarservice) { this.authorizatorservice = authorizatorservice; this.dialog = dialog; this.snackbar = snackbar; this.progressbarservice = progressbarservice; this.displayedColumns = ['remove', 'edit', 'role', 'permissions']; this.rolesDatabase = new RolesDatabase(); this.roles = []; } RolesComponent.prototype.ngOnInit = function () { var _this = this; this.progressbarservice.showRolesWaitBar(true); this.authorizatorservice.getRoles(this.rootFirebasePath).then(function (roles) { if (roles) { _this.roles = roles.sort(function (prev, curr) { if (prev.data.name > curr.data.name) { return 1; } if (prev.data.name < curr.data.name) { return -1; } return 0; }); _this.rolesDataSource = new RolesDataSource(_this.rolesDatabase); _this.rolesDatabase.dataChange.next(roles); _this.progressbarservice.showRolesWaitBar(false); } }).catch(function (error) { console.error(error); }).finally(function () { _this.progressbarservice.showRolesWaitBar(false); }); }; RolesComponent.prototype.addRole = function () { var _this = this; var dialogRef = this.dialog.open(UpsertRoleComponent, { width: '95%', maxWidth: '500px', data: { role: null, rootFirebasePath: this.rootFirebasePath } }); dialogRef.afterClosed().subscribe(function (roleAdded) { if (roleAdded) { _this.roles.push(roleAdded); _this.roles = _this.roles.sort(function (prev, curr) { if (prev.data.name > curr.data.name) { return 1; } if (prev.data.name < curr.data.name) { return -1; } return 0; }); _this.rolesDatabase.dataChange.next(_this.roles); var config = new MatSnackBarConfig(); config.duration = 3000; config.panelClass = ['success-bar']; _this.snackbar.open('Role added successfully', null, config); } }); }; RolesComponent.prototype.editRole = function (inputRole) { var _this = this; var dialogRef = this.dialog.open(UpsertRoleComponent, { width: '95%', maxWidth: '500px', data: { role: inputRole, rootFirebasePath: this.rootFirebasePath } }); dialogRef.afterClosed().subscribe(function (roleUpdated) { if (roleUpdated) { var roleUpdatedIndex = _this.roles.findIndex(function (role) { return role.id === roleUpdated.id; }); if (roleUpdatedIndex > -1) { _this.roles[roleUpdatedIndex].data = roleUpdated.data; _this.rolesDatabase.dataChange.next(_this.roles); } var config = new MatSnackBarConfig(); config.duration = 3000; config.panelClass = ['success-bar']; _this.snackbar.open('Role updated successfully', null, config); } }); }; RolesComponent.prototype.removeRole = function (role) { var _this = this; var dialogRef = this.dialog.open(DeleteRoleWarningComponent, { width: '300px', data: role }); dialogRef.afterClosed().subscribe(function (response) { if (response) { _this.progressbarservice.showRolesWaitBar(true); _this.authorizatorservice.removeRole(_this.rootFirebasePath, role.id).then(function () { _this.roles.splice(_this.roles.findIndex(function (roleArr) { return roleArr.id === role.id; }), 1); _this.rolesDatabase.dataChange.next(_this.roles); var config = new MatSnackBarConfig(); config.duration = 3000; config.panelClass = ['success-bar']; _this.snackbar.open('Role removed successfully', null, config); _this.progressbarservice.showRolesWaitBar(false); }).catch(function (error) { var config = new MatSnackBarConfig(); config.duration = 3000; config.panelClass = ['error-bar']; _this.snackbar.open(error.message, null, config); }); } }); }; RolesComponent.prototype.setPermissions = function (roleInput) { var dialogRef = this.dialog.open(PermissionManagerComponent, { width: '95%', maxWidth: '600px', data: { rootFirebasePath: this.rootFirebasePath, role: roleInput } }); }; RolesComponent.ctorParameters = function () { return [ { type: AuthorizatorService }, { type: MatDialog }, { type: MatSnackBar }, { type: ProgressbarService } ]; }; __decorate([ Input(), __metadata("design:type", String) ], RolesComponent.prototype, "rootFirebasePath", void 0); RolesComponent = __decorate([ Component({ selector: 'lib-roles', template: "<div class=\"roles-container\">\n <button mat-raised-button (click)=\"addRole()\"><mat-icon color=\"primary\">group_add</mat-icon> Add Role</button>\n <table mat-table [dataSource]=\"rolesDataSource\" style=\"width: 100%;\">\n <!--- Note that these columns can be defined in any order.\n The actual rendered columns are set as a property on the row definition\" -->\n \n <!-- Remove Column -->\n <ng-container matColumnDef=\"remove\">\n <th mat-header-cell *matHeaderCellDef [ngClass]=\"'icon-column'\"></th>\n <td mat-cell *matCellDef=\"let role\" [ngClass]=\"'icon-column'\">\n <button mat-icon-button (click)=\"removeRole(role)\">\n <mat-icon color=\"primary\" aria-label=\"Remove role\">delete</mat-icon>\n </button>\n </td>\n </ng-container>\n\n <!-- Edit Column -->\n <ng-container matColumnDef=\"edit\">\n <th mat-header-cell *matHeaderCellDef [ngClass]=\"'icon-column'\"></th>\n <td mat-cell *matCellDef=\"let role\" [ngClass]=\"'icon-column'\">\n <button mat-icon-button (click)=\"editRole(role)\">\n <mat-icon color=\"primary\" aria-label=\"Edit role\">edit</mat-icon>\n </button>\n </td>\n </ng-container>\n \n <!-- Role Column -->\n <ng-container matColumnDef=\"role\">\n <th mat-header-cell *matHeaderCellDef [ngClass]=\"'roles-column'\"> User </th>\n <td mat-cell *matCellDef=\"let role\" [ngClass]=\"'roles-column'\">\n <div>{{role.data.name}}</div>\n <div>{{role.data.email}}</div>\n </td>\n </ng-container>\n \n <!-- Permissions Column -->\n <ng-container matColumnDef=\"permissions\">\n <th mat-header-cell *matHeaderCellDef [ngClass]=\"'permissions-column'\">Permissions</th>\n <td mat-cell *matCellDef=\"let role\" [ngClass]=\"'permissions-column'\">\n <button mat-button (click)=\"setPermissions(role)\">\n <mat-icon color=\"primary\" aria-label=\"Set permissions\">vpn_key</mat-icon>\n </button>\n </td>\n </ng-container>\n \n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n </table>\n</div>\n ", styles: [".icon-column{-webkit-box-flex:0;flex:0 0 50px}.permissions-column{-webkit-box-flex:0;flex:0 0 100px}.roles-column{-webkit-box-flex:0;flex:0 0 300px}.roles-container{width:470px;margin:auto;padding:20px}"] }), __metadata("design:paramtypes", [AuthorizatorService, MatDialog, MatSnackBar, ProgressbarService]) ], RolesComponent); return RolesComponent; }()); export { RolesComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"roles.component.js","sourceRoot":"ng://angular-firebase-authorizator/","sources":["lib/components/roles/roles.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { RoleObj } from '../../classes/role-obj';\nimport { DataSource } from '@angular/cdk/table';\nimport { AuthorizatorService } from '../../services/authorizator.service';\nimport { MatDialog } from '@angular/material/dialog';\nimport { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';\nimport { UpsertRoleComponent, DialogData } from './upsert-role/upsert-role.component';\nimport { DeleteRoleWarningComponent } from './delete-role-warning/delete-role-warning.component';\nimport { PermissionManagerComponent, PermissionData } from '../permission-manager/permission-manager.component';\nimport { ProgressbarService } from '../../services/progressbar.service';\n\nexport class RolesDatabase {\n  dataChange: BehaviorSubject<RoleObj[]> = new BehaviorSubject<RoleObj[]>([]);\n  get data(): RoleObj[] { return this.dataChange.value; }\n\n  constructor() { }\n}\n\nexport class RolesDataSource extends DataSource<any> {\n  constructor(private rolesDatabase: RolesDatabase) {\n    super();\n  }\n\n  connect(): Observable<RoleObj[]> {\n    return this.rolesDatabase.dataChange;\n  }\n\n  disconnect() {}\n}\n\n\n@Component({\n  selector: 'lib-roles',\n  templateUrl: './roles.component.html',\n  styleUrls: ['./roles.component.scss']\n})\nexport class RolesComponent implements OnInit {\n  @Input() rootFirebasePath: string;\n  public displayedColumns = ['remove', 'edit', 'role', 'permissions'];\n  private rolesDatabase = new RolesDatabase();\n  public rolesDataSource: RolesDataSource | null;\n  public roles: RoleObj[] = [];\n  constructor(\n    private authorizatorservice: AuthorizatorService, public dialog: MatDialog,\n    private snackbar: MatSnackBar,\n    private progressbarservice: ProgressbarService\n  ) { }\n\n  ngOnInit() {\n    this.progressbarservice.showRolesWaitBar(true);\n    this.authorizatorservice.getRoles(this.rootFirebasePath).then(roles => {\n      if (roles) {\n        this.roles = roles.sort((prev, curr) => {\n          if (prev.data.name > curr.data.name) {\n            return 1;\n          }\n          if (prev.data.name < curr.data.name) {\n            return -1;\n          }\n          return 0;\n        });\n        this.rolesDataSource = new RolesDataSource(this.rolesDatabase);\n        this.rolesDatabase.dataChange.next(roles);\n        this.progressbarservice.showRolesWaitBar(false);\n      }\n    }).catch(error => {\n      console.error(error);\n    }).finally(() => {\n      this.progressbarservice.showRolesWaitBar(false);\n    });\n  }\n\n  addRole() {\n    const dialogRef = this.dialog.open(UpsertRoleComponent, {\n      width: '95%',\n      maxWidth: '500px',\n      data: { role: null, rootFirebasePath: this.rootFirebasePath } as DialogData\n    });\n\n    dialogRef.afterClosed().subscribe(roleAdded => {\n      if (roleAdded) {\n        this.roles.push(roleAdded);\n        this.roles = this.roles.sort((prev, curr) => {\n          if (prev.data.name > curr.data.name) {\n            return 1;\n          }\n          if (prev.data.name < curr.data.name) {\n            return -1;\n          }\n          return 0;\n        });\n        this.rolesDatabase.dataChange.next(this.roles);\n        const config: MatSnackBarConfig = new MatSnackBarConfig();\n        config.duration = 3000;\n        config.panelClass = ['success-bar'];\n        this.snackbar.open('Role added successfully', null, config);\n      }\n    });\n  }\n\n  editRole(inputRole: RoleObj) {\n    const dialogRef = this.dialog.open(UpsertRoleComponent, {\n      width: '95%',\n      maxWidth: '500px',\n      data: { role: inputRole, rootFirebasePath: this.rootFirebasePath } as DialogData\n    });\n\n    dialogRef.afterClosed().subscribe(roleUpdated => {\n      if (roleUpdated) {\n        const roleUpdatedIndex = this.roles.findIndex(role => role.id === roleUpdated.id);\n        if (roleUpdatedIndex > -1) {\n          this.roles[roleUpdatedIndex].data = roleUpdated.data;\n          this.rolesDatabase.dataChange.next(this.roles);\n        }\n        const config: MatSnackBarConfig = new MatSnackBarConfig();\n        config.duration = 3000;\n        config.panelClass = ['success-bar'];\n        this.snackbar.open('Role updated successfully', null, config);\n      }\n    });\n  }\n\n  removeRole(role: RoleObj) {\n    const dialogRef = this.dialog.open(DeleteRoleWarningComponent, {\n      width: '300px',\n      data: role\n    });\n\n    dialogRef.afterClosed().subscribe(response => {\n      if (response) {\n        this.progressbarservice.showRolesWaitBar(true);\n        this.authorizatorservice.removeRole(this.rootFirebasePath, role.id).then(() => {\n          this.roles.splice(\n            this.roles.findIndex(roleArr => roleArr.id === role.id), 1\n          );\n          this.rolesDatabase.dataChange.next(this.roles);\n          const config: MatSnackBarConfig = new MatSnackBarConfig();\n          config.duration = 3000;\n          config.panelClass = ['success-bar'];\n          this.snackbar.open('Role removed successfully', null, config);\n          this.progressbarservice.showRolesWaitBar(false);\n        }).catch(error => {\n          const config: MatSnackBarConfig = new MatSnackBarConfig();\n          config.duration = 3000;\n          config.panelClass = ['error-bar'];\n          this.snackbar.open(error.message, null, config);\n        });\n      }\n    });\n  }\n\n  setPermissions(roleInput: RoleObj) {\n    const dialogRef = this.dialog.open(PermissionManagerComponent, {\n      width: '95%',\n      maxWidth: '600px',\n      data: { rootFirebasePath: this.rootFirebasePath, role: roleInput } as PermissionData\n    });\n  }\n}\n"]}