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
136 lines • 20.1 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, Input } from '@angular/core';
import { AuthorizatorService } from '../../services/authorizator.service';
import { BehaviorSubject } from 'rxjs';
import { DataSource } from '@angular/cdk/table';
import { MatDialog } from '@angular/material/dialog';
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
import { UpsertUserComponent } from './upsert-user/upsert-user.component';
import { DeleteUserWarningComponent } from './delete-user-warning/delete-user-warning.component';
import { PermissionManagerComponent } from '../permission-manager/permission-manager.component';
import { ProgressbarService } from '../../services/progressbar.service';
export class UsersDatabase {
constructor() {
this.dataChange = new BehaviorSubject([]);
}
get data() { return this.dataChange.value; }
}
export class UsersDataSource extends DataSource {
constructor(usersDatabase) {
super();
this.usersDatabase = usersDatabase;
}
connect() {
return this.usersDatabase.dataChange;
}
disconnect() { }
}
let UsersComponent = class UsersComponent {
constructor(authorizatorservice, dialog, snackbar, progressbarservice) {
this.authorizatorservice = authorizatorservice;
this.dialog = dialog;
this.snackbar = snackbar;
this.progressbarservice = progressbarservice;
this.displayedColumns = ['remove', 'user', 'permissions'];
this.usersDatabase = new UsersDatabase();
this.users = [];
}
ngOnInit() {
this.progressbarservice.showUsersWaitBar(true);
this.authorizatorservice.getUsers(this.rootFirebasePath).then(users => {
this.progressbarservice.showUsersWaitBar(false);
if (users) {
this.users = users.sort((prev, curr) => {
if (prev.data.name > curr.data.name) {
return 1;
}
if (prev.data.name < curr.data.name) {
return -1;
}
return 0;
});
this.usersDataSource = new UsersDataSource(this.usersDatabase);
this.usersDatabase.dataChange.next(users);
}
});
}
addUser() {
const dialogRef = this.dialog.open(UpsertUserComponent, {
width: '300px',
data: { type: 'add', user: null, rootFirebasePath: this.rootFirebasePath }
});
dialogRef.afterClosed().subscribe(userAdded => {
if (userAdded) {
this.users.push(userAdded);
this.users = this.users.sort((prev, curr) => {
if (prev.data.name > curr.data.name) {
return 1;
}
if (prev.data.name < curr.data.name) {
return -1;
}
return 0;
});
this.usersDatabase.dataChange.next(this.users);
const config = new MatSnackBarConfig();
config.duration = 3000;
config.panelClass = ['success-bar'];
this.snackbar.open('User added successfully', null, config);
}
});
}
removeUser(user) {
const dialogRef = this.dialog.open(DeleteUserWarningComponent, {
width: '300px',
data: user
});
dialogRef.afterClosed().subscribe(response => {
if (response) {
this.progressbarservice.showUsersWaitBar(true);
this.authorizatorservice.removeUser(this.rootFirebasePath, user.id).then(() => {
this.progressbarservice.showUsersWaitBar(false);
this.users.splice(this.users.findIndex(userArr => userArr.id === user.id), 1);
this.usersDatabase.dataChange.next(this.users);
const config = new MatSnackBarConfig();
config.duration = 3000;
config.panelClass = ['success-bar'];
this.snackbar.open('User removed successfully', null, config);
}).catch(error => {
const config = new MatSnackBarConfig();
config.duration = 3000;
config.panelClass = ['error-bar'];
this.snackbar.open(error.message, null, config);
});
}
});
}
setPermissions(userInput) {
const dialogRef = this.dialog.open(PermissionManagerComponent, {
width: '95%',
maxWidth: '600px',
data: { rootFirebasePath: this.rootFirebasePath, user: userInput }
});
}
};
UsersComponent.ctorParameters = () => [
{ type: AuthorizatorService },
{ type: MatDialog },
{ type: MatSnackBar },
{ type: ProgressbarService }
];
__decorate([
Input(),
__metadata("design:type", String)
], UsersComponent.prototype, "rootFirebasePath", void 0);
UsersComponent = __decorate([
Component({
selector: 'lib-users',
template: "<div class=\"users-container\">\n <button mat-raised-button (click)=\"addUser()\"><mat-icon color=\"primary\">person_add</mat-icon> Add User</button>\n <table mat-table [dataSource]=\"usersDataSource\" 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 user\" [ngClass]=\"'icon-column'\">\n <button mat-icon-button (click)=\"removeUser(user)\">\n <mat-icon color=\"primary\" aria-label=\"Remove user\">delete</mat-icon>\n </button>\n </td>\n </ng-container>\n \n <!-- User Column -->\n <ng-container matColumnDef=\"user\">\n <th mat-header-cell *matHeaderCellDef [ngClass]=\"'users-column'\"> User </th>\n <td mat-cell *matCellDef=\"let user\" [ngClass]=\"'users-column'\">\n <div>{{user.data.name}}</div>\n <div>{{user.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 user\" [ngClass]=\"'permissions-column'\">\n <button mat-button (click)=\"setPermissions(user)\">\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}.users-column{-webkit-box-flex:0;flex:0 0 300px}.users-container{width:470px;margin:auto;padding:20px}"]
}),
__metadata("design:paramtypes", [AuthorizatorService, MatDialog,
MatSnackBar,
ProgressbarService])
], UsersComponent);
export { UsersComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users.component.js","sourceRoot":"ng://angular-firebase-authorizator/","sources":["lib/components/users/users.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\nimport { AuthorizatorService } from '../../services/authorizator.service';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { DataSource } from '@angular/cdk/table';\nimport { UserObj } from '../../classes/user-obj';\nimport { MatDialog } from '@angular/material/dialog';\nimport { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';\nimport { UpsertUserComponent, DialogData } from './upsert-user/upsert-user.component';\nimport { DeleteUserWarningComponent } from './delete-user-warning/delete-user-warning.component';\nimport { PermissionManagerComponent, PermissionData } from '../permission-manager/permission-manager.component';\nimport { ProgressbarService } from '../../services/progressbar.service';\n\nexport class UsersDatabase {\n  dataChange: BehaviorSubject<UserObj[]> = new BehaviorSubject<UserObj[]>([]);\n  get data(): UserObj[] { return this.dataChange.value; }\n\n  constructor() { }\n}\n\nexport class UsersDataSource extends DataSource<any> {\n  constructor(private usersDatabase: UsersDatabase) {\n    super();\n  }\n\n  connect(): Observable<UserObj[]> {\n    return this.usersDatabase.dataChange;\n  }\n\n  disconnect() {}\n}\n\n\n@Component({\n  selector: 'lib-users',\n  templateUrl: './users.component.html',\n  styleUrls: ['./users.component.scss']\n})\nexport class UsersComponent implements OnInit {\n  @Input() rootFirebasePath: string;\n  public displayedColumns = ['remove', 'user', 'permissions'];\n  private usersDatabase = new UsersDatabase();\n  public usersDataSource: UsersDataSource | null;\n  public users: UserObj[] = [];\n  constructor(\n    private authorizatorservice: AuthorizatorService, public dialog: MatDialog,\n    private snackbar: MatSnackBar,\n    private progressbarservice: ProgressbarService\n  ) { }\n\n  ngOnInit() {\n    this.progressbarservice.showUsersWaitBar(true);\n    this.authorizatorservice.getUsers(this.rootFirebasePath).then(users => {\n      this.progressbarservice.showUsersWaitBar(false);\n      if (users) {\n        this.users = users.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.usersDataSource = new UsersDataSource(this.usersDatabase);\n        this.usersDatabase.dataChange.next(users);\n      }\n    });\n  }\n\n  addUser() {\n    const dialogRef = this.dialog.open(UpsertUserComponent, {\n      width: '300px',\n      data: { type: 'add', user: null, rootFirebasePath: this.rootFirebasePath } as DialogData\n    });\n\n    dialogRef.afterClosed().subscribe(userAdded => {\n      if (userAdded) {\n        this.users.push(userAdded);\n        this.users = this.users.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.usersDatabase.dataChange.next(this.users);\n        const config: MatSnackBarConfig = new MatSnackBarConfig();\n        config.duration = 3000;\n        config.panelClass = ['success-bar'];\n        this.snackbar.open('User added successfully', null, config);\n      }\n    });\n  }\n\n  removeUser(user: UserObj) {\n    const dialogRef = this.dialog.open(DeleteUserWarningComponent, {\n      width: '300px',\n      data: user\n    });\n\n    dialogRef.afterClosed().subscribe(response => {\n      if (response) {\n        this.progressbarservice.showUsersWaitBar(true);\n        this.authorizatorservice.removeUser(this.rootFirebasePath, user.id).then(() => {\n          this.progressbarservice.showUsersWaitBar(false);\n          this.users.splice(\n            this.users.findIndex(userArr => userArr.id === user.id), 1\n          );\n          this.usersDatabase.dataChange.next(this.users);\n          const config: MatSnackBarConfig = new MatSnackBarConfig();\n          config.duration = 3000;\n          config.panelClass = ['success-bar'];\n          this.snackbar.open('User removed successfully', null, config);\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(userInput: UserObj) {\n    const dialogRef = this.dialog.open(PermissionManagerComponent, {\n      width: '95%',\n      maxWidth: '600px',\n      data: { rootFirebasePath: this.rootFirebasePath, user: userInput } as PermissionData\n    });\n  }\n}\n"]}