tin-spa 2.3.6 → 2.3.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (25) hide show
  1. package/esm2020/lib/classes/TinCore.mjs +19 -19
  2. package/esm2020/lib/components/check/check.component.mjs +22 -8
  3. package/esm2020/lib/components/create-account/create-account.component.mjs +2 -4
  4. package/esm2020/lib/components/filter/filter.component.mjs +1 -2
  5. package/esm2020/lib/components/form/form.component.mjs +3 -15
  6. package/esm2020/lib/components/inventory/inventory.component.mjs +1 -2
  7. package/esm2020/lib/components/message/messageDialog.component.mjs +3 -3
  8. package/esm2020/lib/components/profile/profile.component.mjs +1 -3
  9. package/esm2020/lib/components/table/detailsDialog.component.mjs +1 -4
  10. package/esm2020/lib/components/table/table.component.mjs +1 -8
  11. package/esm2020/lib/components/table-internal/detailsDialog-internal.component.mjs +1 -4
  12. package/esm2020/lib/components/table-internal/table-internal.component.mjs +1 -8
  13. package/esm2020/lib/components/table-row/table-row.component.mjs +1 -1
  14. package/esm2020/lib/components/tenant-settings/tenant-settings.component.mjs +1 -2
  15. package/esm2020/lib/components/tiles/tiles.component.mjs +1 -2
  16. package/esm2020/lib/components/users/users.component.mjs +1 -2
  17. package/esm2020/lib/components/viewer/viewer.component.mjs +1 -3
  18. package/esm2020/lib/components/welcome/welcome.component.mjs +1 -1
  19. package/esm2020/lib/services/dialog.service.mjs +3 -3
  20. package/fesm2015/tin-spa.mjs +50 -83
  21. package/fesm2015/tin-spa.mjs.map +1 -1
  22. package/fesm2020/tin-spa.mjs +50 -83
  23. package/fesm2020/tin-spa.mjs.map +1 -1
  24. package/lib/components/check/check.component.d.ts +7 -2
  25. package/package.json +1 -1
@@ -32,7 +32,6 @@ export class UsersComponent {
32
32
  }
33
33
  UpdateData() {
34
34
  this.dataService.GetUser().subscribe((apiResponse) => {
35
- // console.log(apiResponse)
36
35
  this.usersRaw = apiResponse.data;
37
36
  this.users = new MatTableDataSource(apiResponse.data);
38
37
  this.users.paginator = this.usersPaginator;
@@ -116,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
116
115
  type: ViewChild,
117
116
  args: ["usersPaginator"]
118
117
  }] } });
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/users/users.component.ts","../../../../../../projects/tin-spa/src/lib/components/users/users.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Inject, ViewChild } from \"@angular/core\";\r\nimport { MatTableDataSource } from \"@angular/material/table\";\r\nimport { MatPaginator } from \"@angular/material/paginator\";\r\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from \"@angular/material/dialog\";\r\nimport { DataServiceLib } from \"../../services/datalib.service\";\r\nimport { Router } from \"@angular/router\";\r\nimport { MessageService } from \"../../services/message.service\";\r\nimport { AuthService } from \"../../services/auth.service\";\r\nimport { TableConfig, User, ApiResponse } from '../../classes/Classes';\r\nimport { HttpService } from \"../../services/http.service\";\r\n\r\n@Component({\r\n  selector: \"spa-users\",\r\n  templateUrl: \"./users.component.html\",\r\n  styleUrls: [\"./users.component.css\"],\r\n})\r\nexport class UsersComponent implements OnInit {\r\n  constructor(private httpService: HttpService, public router: Router, private authService: AuthService, private dataService: DataServiceLib, public dialog: MatDialog, private messageService: MessageService) { }\r\n\r\n  ngOnInit() {\r\n    this.authService.isAuthorised(this.dataService.capUsers.name);\r\n    this.UpdateData();\r\n  }\r\n\r\n  isProcessing: boolean = false;\r\n  @ViewChild(\"usersPaginator\") usersPaginator: MatPaginator;\r\n\r\n  _filterText = \"\";\r\n\r\n  users;\r\n  usersRaw;\r\n  displayedColumns: string[] = [\"userName\", \"fullName\", \"roleName\", \"locked\", \"dateCreated\", \"Action\"];\r\n\r\n  public UpdateData() {\r\n    this.dataService.GetUser().subscribe(\r\n      (apiResponse) => {\r\n\r\n        // console.log(apiResponse)\r\n\r\n\r\n        this.usersRaw = apiResponse.data;\r\n        this.users = new MatTableDataSource(apiResponse.data);\r\n        this.users.paginator = this.usersPaginator;\r\n        this.applyFilter(this._filterText);\r\n\r\n      },\r\n      (error) => {\r\n        this.isProcessing = false;\r\n        this.messageService.toast(this.httpService.Error(error));\r\n      }\r\n    );\r\n  }\r\n\r\n  applyFilter(filterValue: string) {\r\n    this.users.filter = filterValue.trim().toLowerCase();\r\n  }\r\n\r\n  createAccount() {\r\n    this.router.navigate([\"home/admin/create-account\"]);\r\n  }\r\n\r\n  viewProfile(user: User) {\r\n\r\n    this.dataService.tmpProfileuserName = user.userName;\r\n    this.router.navigate([\"home/user/profile\"]);\r\n\r\n  }\r\n\r\n  lock(u) {\r\n    let login = { userName: u.userName, password: \"Abcdef@123\" }\r\n\r\n    this.dataService.LockUser(login).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.messageService.toast(\"User Locked\");\r\n        this.UpdateData();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    });\r\n  }\r\n\r\n  unlock(u) {\r\n    let login = { userName: u.userName, password: \"Abcdef@123\" }\r\n\r\n    this.dataService.UnlockUser(login).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.messageService.toast(\"User Unlocked\");\r\n        this.UpdateData();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    });\r\n  }\r\n\r\n  recover(u: User) {\r\n    this.dataService.SelfReset(u).subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.message == \"success\") {\r\n        this.messageService.toast(\"The password has been sent on email\");\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  deleteUser(user: User) {\r\n\r\n\r\n\r\n    this.messageService.confirm(`Delete ${user.userName} ?`).subscribe((result) => {\r\n\r\n      if (result == \"yes\") {\r\n\r\n        this.isProcessing = true;\r\n        this.dataService.DeleteUser(user).subscribe(\r\n          (apiResponse: ApiResponse) => {\r\n            this.isProcessing = false;\r\n\r\n            if (apiResponse.message == \"success\") {\r\n              this.messageService.toast(\"User Deleted\");\r\n\r\n              this.UpdateData();\r\n\r\n            } else {\r\n              this.messageService.toast(\"Error: \" + apiResponse.message);\r\n            }\r\n          },\r\n          (error) => {\r\n            this.messageService.toast(\"Connection failed \");\r\n            this.isProcessing = false;\r\n          }\r\n        );\r\n\r\n      }\r\n    })\r\n  }\r\n\r\n\r\n\r\n  //----------------------------------------\r\n\r\n  // config: TableConfig = {\r\n  //   showFilter: true,\r\n  //   newText: \"Create Account\",\r\n  //   minColumns: ['firstName', 'lastName', 'roleID'],\r\n\r\n  //   columns: [\r\n  //     { name: 'userName', type: 'text', icon: { name: 'person', color: 'green', tip: 'name desc' } },\r\n  //     { name: 'firstName', type: 'text',},\r\n  //     { name: 'lastName', type: 'text' },\r\n  //     { name: 'roleID', type: 'text' },\r\n  //     { name: 'locked', type: 'checkbox' },\r\n  //     { name: 'createdDate', type: 'date' },\r\n  //   ],\r\n\r\n  //   buttons: [\r\n  //     { name:'create', display:'Create Account', dialog: true },\r\n  //     { name: 'view', dialog: true, icon: { name: 'account_circle'} },\r\n  //     { name: 'custom1', action: { method: 'post', url: 'User/lock', successMessage: \"User locked\" }, color:'red', tip:'lock', icon: { name: 'lock'}, visible: (value) => value.locked == 0},\r\n  //     { name: 'custom2', action: { method: 'post', url: 'User/unlock', successMessage: \"User Unlocked\" }, color: 'green', tip: 'unlock', icon: { name: 'lock_open' }, visible: (value) => value.locked == 1 },\r\n  //     { name: 'delete' },\r\n  //   ],\r\n\r\n  //   loadAction: { url: 'User/all/x' }\r\n\r\n  // }\r\n\r\n}\r\n\r\n\r\n\r\n","\r\n<h4>Users</h4>\r\n<hr />\r\n\r\n<div class=\"container-fluid\" style=\"font-size: 14px;\">\r\n\r\n  <div class=\"row justify-content-between\" style=\"padding-bottom: 10px\">\r\n    <div class=\"col-2\">\r\n      <button id=\"btnCreateAccount\" mat-raised-button color=\"primary\" (click)=\"createAccount()\">Create User</button>\r\n    </div>\r\n\r\n    <div class=\"d-flex justify-content-end\">\r\n      <spa-filter [data]=\"users\" (refreshClick)=\"UpdateData()\"></spa-filter>\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <p *ngIf=\"!users\"><em>Loading...</em></p>\r\n\r\n\r\n  <div class=\"mat-elevation-z8\" *ngIf=\"users\">\r\n\r\n    <table id=\"tblTable\" mat-table [dataSource]=\"users\">\r\n\r\n      <ng-container matColumnDef=\"userName\">\r\n        <th mat-header-cell *matHeaderCellDef> UserName </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.userName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"locked\">\r\n        <th mat-header-cell *matHeaderCellDef> Locked </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.locked}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"fullName\">\r\n        <th mat-header-cell *matHeaderCellDef> Name </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.firstName}} {{user.lastName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"roleName\">\r\n        <th mat-header-cell *matHeaderCellDef> Role </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.role.roleName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"disabled\">\r\n        <th mat-header-cell *matHeaderCellDef> Disabled </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.disabled}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"dateCreated\">\r\n        <th mat-header-cell *matHeaderCellDef> Created </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.createdDate | date: 'dd/MM/yyyy'}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"dateUpdated\">\r\n        <th mat-header-cell *matHeaderCellDef> Updated </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.updatedDate | date: 'dd/MM/yyyy'}} </td>\r\n      </ng-container>\r\n\r\n\r\n      <ng-container matColumnDef=\"Action\">\r\n        <th mat-header-cell *matHeaderCellDef> Action </th>\r\n        <td mat-cell *matCellDef=\"let user\" style=\"width: 250px;\">\r\n\r\n          <button mat-mini-fab color=\"primary\" (click)=\"viewProfile(user)\" style=\"margin-right:30px\" matTooltip=\"View Profile\" matTooltipPosition=\"above\"> <mat-icon>account_circle</mat-icon></button>\r\n\r\n          <button *ngIf=\"user.locked=='0'\" mat-mini-fab color=\"warn\" (click)=\"lock(user)\" style=\"margin-right:10px\" matTooltip=\"Lock\" matTooltipPosition=\"above\"> <mat-icon>lock</mat-icon></button>\r\n          <button *ngIf=\"user.locked=='1'\" mat-mini-fab  (click)=\"unlock(user)\" style=\"margin-right:10px; background-color: green;\" matTooltip=\"Unlock\" matTooltipPosition=\"above\"> <mat-icon >lock_open</mat-icon></button>\r\n\r\n          <!-- <button *ngIf=\"user.disabled=='0'\" mat-mini-fab color=\"warn\" (click)=\"disable(user)\" style=\"margin-right:10px\" matTooltip=\"Disable\" matTooltipPosition=\"above\"> <mat-icon>block</mat-icon></button>\r\n          <button *ngIf=\"user.disabled=='1'\" mat-mini-fab (click)=\"enable(user)\" style=\"margin-right:10px; background-color: green\" matTooltip=\"Enable\" matTooltipPosition=\"above\"> <mat-icon>done</mat-icon></button> -->\r\n\r\n          <button mat-mini-fab color=\"warn\" (click)=\"deleteUser(user)\" style=\"margin-right:10px\" matTooltip=\"Delete\" matTooltipPosition=\"above\"> <mat-icon>delete</mat-icon></button>\r\n          <!-- <button mat-mini-fab color=\"primary\" (click)=\"recover(user)\" style=\"margin-right:10px\" matTooltip=\"Reset Password\" matTooltipPosition=\"above\"> <mat-icon>vpn_key</mat-icon></button> -->\r\n\r\n\r\n\r\n        </td>\r\n      </ng-container>\r\n\r\n\r\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\r\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': row.disabled =='1'}\"></tr>\r\n\r\n    </table>\r\n\r\n  </div>\r\n\r\n  <mat-paginator #usersPaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n</div>\r\n\r\n<!-- ------------------ -->\r\n\r\n<!-- <div class=\"container mt-5\" style=\" font-size: 14px;\">\r\n<spa-table  [data]=\"usersRaw\" [config]=\"config\" (refreshClick)=\"UpdateData()\" (viewClick)=\"viewProfile($event)\" (createClick)=\"createAccount()\" (deleteClick)=\"deleteUser($event)\"></spa-table>\r\n</div> -->\r\n\r\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/users/users.component.ts","../../../../../../projects/tin-spa/src/lib/components/users/users.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Inject, ViewChild } from \"@angular/core\";\r\nimport { MatTableDataSource } from \"@angular/material/table\";\r\nimport { MatPaginator } from \"@angular/material/paginator\";\r\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from \"@angular/material/dialog\";\r\nimport { DataServiceLib } from \"../../services/datalib.service\";\r\nimport { Router } from \"@angular/router\";\r\nimport { MessageService } from \"../../services/message.service\";\r\nimport { AuthService } from \"../../services/auth.service\";\r\nimport { TableConfig, User, ApiResponse } from '../../classes/Classes';\r\nimport { HttpService } from \"../../services/http.service\";\r\n\r\n@Component({\r\n  selector: \"spa-users\",\r\n  templateUrl: \"./users.component.html\",\r\n  styleUrls: [\"./users.component.css\"],\r\n})\r\nexport class UsersComponent implements OnInit {\r\n  constructor(private httpService: HttpService, public router: Router, private authService: AuthService, private dataService: DataServiceLib, public dialog: MatDialog, private messageService: MessageService) { }\r\n\r\n  ngOnInit() {\r\n    this.authService.isAuthorised(this.dataService.capUsers.name);\r\n    this.UpdateData();\r\n  }\r\n\r\n  isProcessing: boolean = false;\r\n  @ViewChild(\"usersPaginator\") usersPaginator: MatPaginator;\r\n\r\n  _filterText = \"\";\r\n\r\n  users;\r\n  usersRaw;\r\n  displayedColumns: string[] = [\"userName\", \"fullName\", \"roleName\", \"locked\", \"dateCreated\", \"Action\"];\r\n\r\n  public UpdateData() {\r\n    this.dataService.GetUser().subscribe(\r\n      (apiResponse) => {\r\n\r\n        this.usersRaw = apiResponse.data;\r\n        this.users = new MatTableDataSource(apiResponse.data);\r\n        this.users.paginator = this.usersPaginator;\r\n        this.applyFilter(this._filterText);\r\n\r\n      },\r\n      (error) => {\r\n        this.isProcessing = false;\r\n        this.messageService.toast(this.httpService.Error(error));\r\n      }\r\n    );\r\n  }\r\n\r\n  applyFilter(filterValue: string) {\r\n    this.users.filter = filterValue.trim().toLowerCase();\r\n  }\r\n\r\n  createAccount() {\r\n    this.router.navigate([\"home/admin/create-account\"]);\r\n  }\r\n\r\n  viewProfile(user: User) {\r\n\r\n    this.dataService.tmpProfileuserName = user.userName;\r\n    this.router.navigate([\"home/user/profile\"]);\r\n\r\n  }\r\n\r\n  lock(u) {\r\n    let login = { userName: u.userName, password: \"Abcdef@123\" }\r\n\r\n    this.dataService.LockUser(login).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.messageService.toast(\"User Locked\");\r\n        this.UpdateData();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    });\r\n  }\r\n\r\n  unlock(u) {\r\n    let login = { userName: u.userName, password: \"Abcdef@123\" }\r\n\r\n    this.dataService.UnlockUser(login).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.messageService.toast(\"User Unlocked\");\r\n        this.UpdateData();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    });\r\n  }\r\n\r\n  recover(u: User) {\r\n    this.dataService.SelfReset(u).subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.message == \"success\") {\r\n        this.messageService.toast(\"The password has been sent on email\");\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  deleteUser(user: User) {\r\n\r\n\r\n\r\n    this.messageService.confirm(`Delete ${user.userName} ?`).subscribe((result) => {\r\n\r\n      if (result == \"yes\") {\r\n\r\n        this.isProcessing = true;\r\n        this.dataService.DeleteUser(user).subscribe(\r\n          (apiResponse: ApiResponse) => {\r\n            this.isProcessing = false;\r\n\r\n            if (apiResponse.message == \"success\") {\r\n              this.messageService.toast(\"User Deleted\");\r\n\r\n              this.UpdateData();\r\n\r\n            } else {\r\n              this.messageService.toast(\"Error: \" + apiResponse.message);\r\n            }\r\n          },\r\n          (error) => {\r\n            this.messageService.toast(\"Connection failed \");\r\n            this.isProcessing = false;\r\n          }\r\n        );\r\n\r\n      }\r\n    })\r\n  }\r\n\r\n\r\n\r\n  //----------------------------------------\r\n\r\n  // config: TableConfig = {\r\n  //   showFilter: true,\r\n  //   newText: \"Create Account\",\r\n  //   minColumns: ['firstName', 'lastName', 'roleID'],\r\n\r\n  //   columns: [\r\n  //     { name: 'userName', type: 'text', icon: { name: 'person', color: 'green', tip: 'name desc' } },\r\n  //     { name: 'firstName', type: 'text',},\r\n  //     { name: 'lastName', type: 'text' },\r\n  //     { name: 'roleID', type: 'text' },\r\n  //     { name: 'locked', type: 'checkbox' },\r\n  //     { name: 'createdDate', type: 'date' },\r\n  //   ],\r\n\r\n  //   buttons: [\r\n  //     { name:'create', display:'Create Account', dialog: true },\r\n  //     { name: 'view', dialog: true, icon: { name: 'account_circle'} },\r\n  //     { name: 'custom1', action: { method: 'post', url: 'User/lock', successMessage: \"User locked\" }, color:'red', tip:'lock', icon: { name: 'lock'}, visible: (value) => value.locked == 0},\r\n  //     { name: 'custom2', action: { method: 'post', url: 'User/unlock', successMessage: \"User Unlocked\" }, color: 'green', tip: 'unlock', icon: { name: 'lock_open' }, visible: (value) => value.locked == 1 },\r\n  //     { name: 'delete' },\r\n  //   ],\r\n\r\n  //   loadAction: { url: 'User/all/x' }\r\n\r\n  // }\r\n\r\n}\r\n\r\n\r\n\r\n","\r\n<h4>Users</h4>\r\n<hr />\r\n\r\n<div class=\"container-fluid\" style=\"font-size: 14px;\">\r\n\r\n  <div class=\"row justify-content-between\" style=\"padding-bottom: 10px\">\r\n    <div class=\"col-2\">\r\n      <button id=\"btnCreateAccount\" mat-raised-button color=\"primary\" (click)=\"createAccount()\">Create User</button>\r\n    </div>\r\n\r\n    <div class=\"d-flex justify-content-end\">\r\n      <spa-filter [data]=\"users\" (refreshClick)=\"UpdateData()\"></spa-filter>\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <p *ngIf=\"!users\"><em>Loading...</em></p>\r\n\r\n\r\n  <div class=\"mat-elevation-z8\" *ngIf=\"users\">\r\n\r\n    <table id=\"tblTable\" mat-table [dataSource]=\"users\">\r\n\r\n      <ng-container matColumnDef=\"userName\">\r\n        <th mat-header-cell *matHeaderCellDef> UserName </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.userName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"locked\">\r\n        <th mat-header-cell *matHeaderCellDef> Locked </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.locked}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"fullName\">\r\n        <th mat-header-cell *matHeaderCellDef> Name </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.firstName}} {{user.lastName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"roleName\">\r\n        <th mat-header-cell *matHeaderCellDef> Role </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.role.roleName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"disabled\">\r\n        <th mat-header-cell *matHeaderCellDef> Disabled </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.disabled}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"dateCreated\">\r\n        <th mat-header-cell *matHeaderCellDef> Created </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.createdDate | date: 'dd/MM/yyyy'}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"dateUpdated\">\r\n        <th mat-header-cell *matHeaderCellDef> Updated </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.updatedDate | date: 'dd/MM/yyyy'}} </td>\r\n      </ng-container>\r\n\r\n\r\n      <ng-container matColumnDef=\"Action\">\r\n        <th mat-header-cell *matHeaderCellDef> Action </th>\r\n        <td mat-cell *matCellDef=\"let user\" style=\"width: 250px;\">\r\n\r\n          <button mat-mini-fab color=\"primary\" (click)=\"viewProfile(user)\" style=\"margin-right:30px\" matTooltip=\"View Profile\" matTooltipPosition=\"above\"> <mat-icon>account_circle</mat-icon></button>\r\n\r\n          <button *ngIf=\"user.locked=='0'\" mat-mini-fab color=\"warn\" (click)=\"lock(user)\" style=\"margin-right:10px\" matTooltip=\"Lock\" matTooltipPosition=\"above\"> <mat-icon>lock</mat-icon></button>\r\n          <button *ngIf=\"user.locked=='1'\" mat-mini-fab  (click)=\"unlock(user)\" style=\"margin-right:10px; background-color: green;\" matTooltip=\"Unlock\" matTooltipPosition=\"above\"> <mat-icon >lock_open</mat-icon></button>\r\n\r\n          <!-- <button *ngIf=\"user.disabled=='0'\" mat-mini-fab color=\"warn\" (click)=\"disable(user)\" style=\"margin-right:10px\" matTooltip=\"Disable\" matTooltipPosition=\"above\"> <mat-icon>block</mat-icon></button>\r\n          <button *ngIf=\"user.disabled=='1'\" mat-mini-fab (click)=\"enable(user)\" style=\"margin-right:10px; background-color: green\" matTooltip=\"Enable\" matTooltipPosition=\"above\"> <mat-icon>done</mat-icon></button> -->\r\n\r\n          <button mat-mini-fab color=\"warn\" (click)=\"deleteUser(user)\" style=\"margin-right:10px\" matTooltip=\"Delete\" matTooltipPosition=\"above\"> <mat-icon>delete</mat-icon></button>\r\n          <!-- <button mat-mini-fab color=\"primary\" (click)=\"recover(user)\" style=\"margin-right:10px\" matTooltip=\"Reset Password\" matTooltipPosition=\"above\"> <mat-icon>vpn_key</mat-icon></button> -->\r\n\r\n\r\n\r\n        </td>\r\n      </ng-container>\r\n\r\n\r\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\r\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': row.disabled =='1'}\"></tr>\r\n\r\n    </table>\r\n\r\n  </div>\r\n\r\n  <mat-paginator #usersPaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n</div>\r\n\r\n<!-- ------------------ -->\r\n\r\n<!-- <div class=\"container mt-5\" style=\" font-size: 14px;\">\r\n<spa-table  [data]=\"usersRaw\" [config]=\"config\" (refreshClick)=\"UpdateData()\" (viewClick)=\"viewProfile($event)\" (createClick)=\"createAccount()\" (deleteClick)=\"deleteUser($event)\"></spa-table>\r\n</div> -->\r\n\r\n"]}
@@ -18,8 +18,6 @@ export class ViewerComponent {
18
18
  this.title = "Documents";
19
19
  }
20
20
  ngOnInit() {
21
- // this.fileNames = 'tinashe.jpg'
22
- console.log("Viewer Init");
23
21
  if (this.fileAction) {
24
22
  this.loadData();
25
23
  }
@@ -78,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
78
76
  }], title: [{
79
77
  type: Input
80
78
  }] } });
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rpbi1zcGEvc3JjL2xpYi9jb21wb25lbnRzL3ZpZXdlci92aWV3ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvdmlld2VyL3ZpZXdlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7Ozs7OztBQVN4RCxNQUFNLE9BQU8sZUFBZTtJQUUxQixZQUFvQixXQUEyQixFQUFRLE1BQWlCO1FBQXBELGdCQUFXLEdBQVgsV0FBVyxDQUFnQjtRQUFRLFdBQU0sR0FBTixNQUFNLENBQVc7UUFnQi9ELFNBQUksR0FBRyxFQUFFLENBQUM7UUFDVixlQUFVLEdBQUMsRUFBRSxDQUFDO1FBRWQsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNqQixXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUM3QixZQUFPLEdBQUcsV0FBVyxDQUFDO1FBQ3RCLFVBQUssR0FBRyxXQUFXLENBQUM7SUF0QitDLENBQUM7SUFFN0UsUUFBUTtRQUVOLGlDQUFpQztRQUNqQyxPQUFPLENBQUMsR0FBRyxDQUFDLGFBQWEsQ0FBQyxDQUFBO1FBQzFCLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBQztZQUNsQixJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7U0FDakI7YUFBSTtZQUNILElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztTQUNoQjtJQUNILENBQUM7SUFhRCxzQkFBc0I7SUFFdEIsUUFBUTtRQUVOLE9BQU8sQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLENBQUE7UUFDNUIsSUFBSSxHQUFHLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxHQUFHLEdBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFBO1FBQ2hFLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLEVBQUMsR0FBRyxFQUFFLEdBQUcsRUFBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLFdBQXdCLEVBQUUsRUFBRTtZQUM5RSxJQUFJLENBQUMsU0FBUyxHQUFHLFdBQVcsQ0FBQyxJQUFJLENBQUM7WUFDbEMsOEJBQThCO1lBQzlCLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNqQixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxPQUFPLElBQUksQ0FBQyxTQUFTLElBQUksUUFBUSxFQUFFO1lBQ3JDLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUE7U0FDM0M7SUFDSCxDQUFDO0lBRUQsUUFBUSxDQUFDLFFBQWdCO1FBRXZCLElBQUksT0FBTyxRQUFRLElBQUksUUFBUSxFQUFFO1lBQy9CLE9BQU87U0FDUjtRQUlELE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRTtZQUMvQyxRQUFRLEVBQUUsS0FBSztZQUNmLFFBQVEsRUFBRSxNQUFNO1lBRWhCLElBQUksRUFBRSxFQUFFLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLEdBQUcsSUFBSSxDQUFDLElBQUksSUFBSSxFQUFFLElBQUksSUFBSSxDQUFDLFVBQVUsSUFBSSxFQUFFLEVBQUUsRUFBRTtTQUM3RyxDQUFDLENBQUM7SUFFTCxDQUFDO0lBRUQsT0FBTyxDQUFDLENBQUM7UUFDUCxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN0QixDQUFDOzs0R0FoRVUsZUFBZTtnR0FBZixlQUFlLG1QQ1g1QixxZ0JBYUE7MkZERmEsZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxZQUFZOzZIQXFCYixVQUFVO3NCQUFsQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDSSxNQUFNO3NCQUFmLE1BQU07Z0JBQ0UsT0FBTztzQkFBZixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWF0RGlhbG9nLCBNYXREaWFsb2dSZWYgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5pbXBvcnQgeyB2aWV3ZXJEaWFsb2cgfSBmcm9tICcuL3ZpZXdlckRpYWxvZy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBEYXRhU2VydmljZUxpYiB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2RhdGFsaWIuc2VydmljZSc7XHJcbmltcG9ydCB7IEFjdGlvbiwgQXBpUmVzcG9uc2UgfSBmcm9tICcuLi8uLi9jbGFzc2VzL0NsYXNzZXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdzcGEtdmlld2VyJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdmlld2VyLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi92aWV3ZXIuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBWaWV3ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGRhdGFTZXJ2aWNlOiBEYXRhU2VydmljZUxpYixwdWJsaWMgZGlhbG9nOiBNYXREaWFsb2cpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuXHJcbiAgICAvLyB0aGlzLmZpbGVOYW1lcyA9ICd0aW5hc2hlLmpwZydcclxuICAgIGNvbnNvbGUubG9nKFwiVmlld2VyIEluaXRcIilcclxuICAgIGlmICh0aGlzLmZpbGVBY3Rpb24pe1xyXG4gICAgICB0aGlzLmxvYWREYXRhKCk7XHJcbiAgICB9ZWxzZXtcclxuICAgICAgdGhpcy5jb252ZXJ0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuXHJcblxyXG4gIEBJbnB1dCgpIGZpbGVBY3Rpb24gOiBBY3Rpb247XHJcbiAgQElucHV0KCkgcGF0aCA9IFwiXCI7XHJcbiAgQElucHV0KCkgZm9sZGVyTmFtZT1cIlwiO1xyXG4gIEBJbnB1dCgpIGZpbGVOYW1lczsvLyBuZXcgQXJyYXkoKVxyXG4gIEBJbnB1dCgpIHJlbW92YWJsZSA9IGZhbHNlO1xyXG4gIEBPdXRwdXQoKSByZW1vdmUgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcbiAgQElucHV0KCkgZGlzcGxheSA9IFwiRG9jdW1lbnRzXCI7XHJcbiAgQElucHV0KCkgdGl0bGUgPSBcIkRvY3VtZW50c1wiO1xyXG5cclxuICAvLyBmaWxlTGlzdDogc3RyaW5nW107XHJcblxyXG4gIGxvYWREYXRhKCkge1xyXG5cclxuICAgIGNvbnNvbGUubG9nKFwiQ2FsbGluZyBmaWxlc1wiKVxyXG4gICAgbGV0IHVybCA9IHRoaXMuZmlsZUFjdGlvbi51cmwucmVwbGFjZShcIi94XCIsICcvJyt0aGlzLmZvbGRlck5hbWUpXHJcbiAgICB0aGlzLmRhdGFTZXJ2aWNlLkNhbGxBcGkoe3VybDogdXJsfSwgXCJcIikuc3Vic2NyaWJlKChhcGlSZXNwb25zZTogQXBpUmVzcG9uc2UpID0+IHtcclxuICAgICAgdGhpcy5maWxlTmFtZXMgPSBhcGlSZXNwb25zZS5kYXRhO1xyXG4gICAgICAvLyBjb25zb2xlLmxvZyh0aGlzLmZpbGVOYW1lcylcclxuICAgICAgdGhpcy5jb252ZXJ0KCk7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIGNvbnZlcnQoKXtcclxuICAgIGlmICh0eXBlb2YgdGhpcy5maWxlTmFtZXMgPT0gJ3N0cmluZycpIHtcclxuICAgICAgdGhpcy5maWxlTmFtZXMgPSB0aGlzLmZpbGVOYW1lcy5zcGxpdChcInxcIilcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHZpZXdEb2NzKGZpbGVOYW1lOiBzdHJpbmcpIHtcclxuXHJcbiAgICBpZiAodHlwZW9mIGZpbGVOYW1lICE9ICdzdHJpbmcnKSB7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuXHJcblxyXG5cclxuICAgIGNvbnN0IGRpYWxvZ1JlZiA9IHRoaXMuZGlhbG9nLm9wZW4odmlld2VyRGlhbG9nLCB7XHJcbiAgICAgIG1pbldpZHRoOiAnOTUlJyxcclxuICAgICAgbWF4V2lkdGg6ICc4MHZ3JyxcclxuXHJcbiAgICAgIGRhdGE6IHsgZmlsZU5hbWVzOiB0aGlzLmZpbGVOYW1lcywgZmlsZU5hbWU6IGZpbGVOYW1lLCBwYXRoOiBgJHt0aGlzLnBhdGggPz8gJyd9LyR7dGhpcy5mb2xkZXJOYW1lID8/ICcnfWAgfVxyXG4gICAgfSk7XHJcblxyXG4gIH1cclxuXHJcbiAgcmVtb3ZlZChpKXtcclxuICAgIHRoaXMucmVtb3ZlLmVtaXQoaSk7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwidGluLWlucHV0LXJvdyBtdC0zXCIgKm5nSWY9XCJ0aXRsZSAhPSAnJ1wiPlxyXG4gIDxtYXQtbGFiZWwgc3R5bGU9XCJmb250LXNpemU6IDIwcHg7IGZvbnQtd2VpZ2h0OiAzMDBcIiA+ICB7e3RpdGxlfX08L21hdC1sYWJlbCA+XHJcbjwvZGl2PlxyXG5cclxuPHNwYS1jaGlwcyBbY2hpcHNdPVwiZmlsZU5hbWVzXCIgW3RpdGxlXT1cInRpdGxlXCIgIFtyZW1vdmFibGVdPVwicmVtb3ZhYmxlXCIgaWNvbj1cImRlc2NyaXB0aW9uXCIgKGNsaWNrKT1cInZpZXdEb2NzKCRldmVudClcIiAocmVtb3ZlKT1cInJlbW92ZWQoJGV2ZW50KVwiPjwvc3BhLWNoaXBzPlxyXG5cclxuXHJcblxyXG48ZGl2ICpuZ0lmPVwiIWZpbGVOYW1lc1wiIGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1jZW50ZXIgcm93IGFsaWduLWl0ZW1zLWNlbnRlclwiIHN0eWxlPVwibWF4LWhlaWdodDoyMDBweFwiPlxyXG5cclxuICBObyB7e3RpdGxlLnRvTG93ZXJDYXNlKCl9fVxyXG5cclxuPC9kaXY+XHJcbiJdfQ==
79
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rpbi1zcGEvc3JjL2xpYi9jb21wb25lbnRzL3ZpZXdlci92aWV3ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvdmlld2VyL3ZpZXdlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7Ozs7OztBQVN4RCxNQUFNLE9BQU8sZUFBZTtJQUUxQixZQUFvQixXQUEyQixFQUFRLE1BQWlCO1FBQXBELGdCQUFXLEdBQVgsV0FBVyxDQUFnQjtRQUFRLFdBQU0sR0FBTixNQUFNLENBQVc7UUFjL0QsU0FBSSxHQUFHLEVBQUUsQ0FBQztRQUNWLGVBQVUsR0FBQyxFQUFFLENBQUM7UUFFZCxjQUFTLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLFdBQU0sR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBQzdCLFlBQU8sR0FBRyxXQUFXLENBQUM7UUFDdEIsVUFBSyxHQUFHLFdBQVcsQ0FBQztJQXBCK0MsQ0FBQztJQUU3RSxRQUFRO1FBRU4sSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFDO1lBQ2xCLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztTQUNqQjthQUFJO1lBQ0gsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1NBQ2hCO0lBQ0gsQ0FBQztJQWFELHNCQUFzQjtJQUV0QixRQUFRO1FBRU4sT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsQ0FBQTtRQUM1QixJQUFJLEdBQUcsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEdBQUcsR0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUE7UUFDaEUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsRUFBQyxHQUFHLEVBQUUsR0FBRyxFQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsV0FBd0IsRUFBRSxFQUFFO1lBQzlFLElBQUksQ0FBQyxTQUFTLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQztZQUNsQyw4QkFBOEI7WUFDOUIsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2pCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELE9BQU87UUFDTCxJQUFJLE9BQU8sSUFBSSxDQUFDLFNBQVMsSUFBSSxRQUFRLEVBQUU7WUFDckMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQTtTQUMzQztJQUNILENBQUM7SUFFRCxRQUFRLENBQUMsUUFBZ0I7UUFFdkIsSUFBSSxPQUFPLFFBQVEsSUFBSSxRQUFRLEVBQUU7WUFDL0IsT0FBTztTQUNSO1FBSUQsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQy9DLFFBQVEsRUFBRSxLQUFLO1lBQ2YsUUFBUSxFQUFFLE1BQU07WUFFaEIsSUFBSSxFQUFFLEVBQUUsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUMsSUFBSSxJQUFJLEVBQUUsSUFBSSxJQUFJLENBQUMsVUFBVSxJQUFJLEVBQUUsRUFBRSxFQUFFO1NBQzdHLENBQUMsQ0FBQztJQUVMLENBQUM7SUFFRCxPQUFPLENBQUMsQ0FBQztRQUNQLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3RCLENBQUM7OzRHQTlEVSxlQUFlO2dHQUFmLGVBQWUsbVBDWDVCLHFnQkFhQTsyRkRGYSxlQUFlO2tCQUwzQixTQUFTOytCQUNFLFlBQVk7NkhBbUJiLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNJLE1BQU07c0JBQWYsTUFBTTtnQkFDRSxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNYXREaWFsb2csIE1hdERpYWxvZ1JlZiB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7IHZpZXdlckRpYWxvZyB9IGZyb20gJy4vdmlld2VyRGlhbG9nLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IERhdGFTZXJ2aWNlTGliIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvZGF0YWxpYi5zZXJ2aWNlJztcclxuaW1wb3J0IHsgQWN0aW9uLCBBcGlSZXNwb25zZSB9IGZyb20gJy4uLy4uL2NsYXNzZXMvQ2xhc3Nlcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3NwYS12aWV3ZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi92aWV3ZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3ZpZXdlci5jb21wb25lbnQuY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFZpZXdlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZGF0YVNlcnZpY2U6IERhdGFTZXJ2aWNlTGliLHB1YmxpYyBkaWFsb2c6IE1hdERpYWxvZykgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG5cclxuICAgIGlmICh0aGlzLmZpbGVBY3Rpb24pe1xyXG4gICAgICB0aGlzLmxvYWREYXRhKCk7XHJcbiAgICB9ZWxzZXtcclxuICAgICAgdGhpcy5jb252ZXJ0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuXHJcblxyXG4gIEBJbnB1dCgpIGZpbGVBY3Rpb24gOiBBY3Rpb247XHJcbiAgQElucHV0KCkgcGF0aCA9IFwiXCI7XHJcbiAgQElucHV0KCkgZm9sZGVyTmFtZT1cIlwiO1xyXG4gIEBJbnB1dCgpIGZpbGVOYW1lczsvLyBuZXcgQXJyYXkoKVxyXG4gIEBJbnB1dCgpIHJlbW92YWJsZSA9IGZhbHNlO1xyXG4gIEBPdXRwdXQoKSByZW1vdmUgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcbiAgQElucHV0KCkgZGlzcGxheSA9IFwiRG9jdW1lbnRzXCI7XHJcbiAgQElucHV0KCkgdGl0bGUgPSBcIkRvY3VtZW50c1wiO1xyXG5cclxuICAvLyBmaWxlTGlzdDogc3RyaW5nW107XHJcblxyXG4gIGxvYWREYXRhKCkge1xyXG5cclxuICAgIGNvbnNvbGUubG9nKFwiQ2FsbGluZyBmaWxlc1wiKVxyXG4gICAgbGV0IHVybCA9IHRoaXMuZmlsZUFjdGlvbi51cmwucmVwbGFjZShcIi94XCIsICcvJyt0aGlzLmZvbGRlck5hbWUpXHJcbiAgICB0aGlzLmRhdGFTZXJ2aWNlLkNhbGxBcGkoe3VybDogdXJsfSwgXCJcIikuc3Vic2NyaWJlKChhcGlSZXNwb25zZTogQXBpUmVzcG9uc2UpID0+IHtcclxuICAgICAgdGhpcy5maWxlTmFtZXMgPSBhcGlSZXNwb25zZS5kYXRhO1xyXG4gICAgICAvLyBjb25zb2xlLmxvZyh0aGlzLmZpbGVOYW1lcylcclxuICAgICAgdGhpcy5jb252ZXJ0KCk7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIGNvbnZlcnQoKXtcclxuICAgIGlmICh0eXBlb2YgdGhpcy5maWxlTmFtZXMgPT0gJ3N0cmluZycpIHtcclxuICAgICAgdGhpcy5maWxlTmFtZXMgPSB0aGlzLmZpbGVOYW1lcy5zcGxpdChcInxcIilcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHZpZXdEb2NzKGZpbGVOYW1lOiBzdHJpbmcpIHtcclxuXHJcbiAgICBpZiAodHlwZW9mIGZpbGVOYW1lICE9ICdzdHJpbmcnKSB7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuXHJcblxyXG5cclxuICAgIGNvbnN0IGRpYWxvZ1JlZiA9IHRoaXMuZGlhbG9nLm9wZW4odmlld2VyRGlhbG9nLCB7XHJcbiAgICAgIG1pbldpZHRoOiAnOTUlJyxcclxuICAgICAgbWF4V2lkdGg6ICc4MHZ3JyxcclxuXHJcbiAgICAgIGRhdGE6IHsgZmlsZU5hbWVzOiB0aGlzLmZpbGVOYW1lcywgZmlsZU5hbWU6IGZpbGVOYW1lLCBwYXRoOiBgJHt0aGlzLnBhdGggPz8gJyd9LyR7dGhpcy5mb2xkZXJOYW1lID8/ICcnfWAgfVxyXG4gICAgfSk7XHJcblxyXG4gIH1cclxuXHJcbiAgcmVtb3ZlZChpKXtcclxuICAgIHRoaXMucmVtb3ZlLmVtaXQoaSk7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwidGluLWlucHV0LXJvdyBtdC0zXCIgKm5nSWY9XCJ0aXRsZSAhPSAnJ1wiPlxyXG4gIDxtYXQtbGFiZWwgc3R5bGU9XCJmb250LXNpemU6IDIwcHg7IGZvbnQtd2VpZ2h0OiAzMDBcIiA+ICB7e3RpdGxlfX08L21hdC1sYWJlbCA+XHJcbjwvZGl2PlxyXG5cclxuPHNwYS1jaGlwcyBbY2hpcHNdPVwiZmlsZU5hbWVzXCIgW3RpdGxlXT1cInRpdGxlXCIgIFtyZW1vdmFibGVdPVwicmVtb3ZhYmxlXCIgaWNvbj1cImRlc2NyaXB0aW9uXCIgKGNsaWNrKT1cInZpZXdEb2NzKCRldmVudClcIiAocmVtb3ZlKT1cInJlbW92ZWQoJGV2ZW50KVwiPjwvc3BhLWNoaXBzPlxyXG5cclxuXHJcblxyXG48ZGl2ICpuZ0lmPVwiIWZpbGVOYW1lc1wiIGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1jZW50ZXIgcm93IGFsaWduLWl0ZW1zLWNlbnRlclwiIHN0eWxlPVwibWF4LWhlaWdodDoyMDBweFwiPlxyXG5cclxuICBObyB7e3RpdGxlLnRvTG93ZXJDYXNlKCl9fVxyXG5cclxuPC9kaXY+XHJcbiJdfQ==
@@ -78,7 +78,7 @@ export class WelcomeComponent {
78
78
  }
79
79
  }
80
80
  WelcomeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: WelcomeComponent, deps: [{ token: i1.DataServiceLib }, { token: i2.AuthService }], target: i0.ɵɵFactoryTarget.Component });
81
- WelcomeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: WelcomeComponent, selector: "spa-welcome", ngImport: i0, template: "<label class=\"title\">Welcome, {{username}}</label>\n\n\n\n<!-- terms -->\n<div class=\"mt-3\" *ngIf=\"step=='terms'\">\n\n <label class=\"subtitle text-muted mb-2\" >We care about our users and are dedicated to protecting your data and privacy -\n thats why we want to be clear about what data we collect and how we use it to improve your experience.</label>\n\n <br>\n <spa-check display=\"I agree to the Terms and Privacy Policy\" [(value)]=\"agree\"></spa-check>\n</div>\n\n<!-- owner -->\n<div class=\"mt-3\" *ngIf=\"step=='name' && own\">\n\n <label class=\"subtitle text-muted\" style=\" margin-bottom: 20px;\">The follow steps will guide you to customise your application.</label>\n\n <div style=\"max-width: 400px;\">\n <spa-text display=\"Organisation Name\" [(value)]=\"myTenant.name\" ></spa-text>\n </div>\n\n <label class=\"text-muted\" style=\" font-size: 12px;\">You can change the Organisation's name to your team or company name.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">The name can be changed later.</label>\n\n</div>\n\n<!-- guest -->\n<div *ngIf=\"step=='hi' && !own\">\n <label class=\"subtitle text-muted\">You are now signed in to {{myTenant.name}}.</label>\n</div>\n\n\n<!-- invitations -->\n<div class=\"mt-3\" *ngIf=\"step=='invitations' && own\">\n\n <label class=\"subtitle text-muted\">You have been requested to join the following organisations. If you accept, you have the option to switch to that org now or stay in you org.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">You will be able to switch later.</label>\n <spa-invitations-table></spa-invitations-table>\n\n</div>\n\n\n<!-- Actions -->\n<div class=\"mt-3\">\n <button mat-stroked-button color=\"primary\" [disabled]=\"!agree\" (click)=\"next()\">Next <mat-icon>arrow_right_alt</mat-icon></button>\n</div>\n", styles: [".title{margin-top:1em;font-size:28px;font-weight:300}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.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: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.TextComponent, selector: "spa-text", inputs: ["readonly", "hint", "display", "placeholder", "value", "format", "type", "rows", "width", "options", "optionValue", "required", "min", "max", "regex", "suffix", "infoMessage"], outputs: ["valueChange", "leave", "enterPress", "infoClick"] }, { kind: "component", type: i7.CheckComponent, selector: "spa-check", inputs: ["readonly", "display", "value"], outputs: ["valueChange", "click", "check", "uncheck"] }, { kind: "component", type: i8.InvitationsTableComponent, selector: "spa-invitations-table" }] });
81
+ WelcomeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: WelcomeComponent, selector: "spa-welcome", ngImport: i0, template: "<label class=\"title\">Welcome, {{username}}</label>\n\n\n\n<!-- terms -->\n<div class=\"mt-3\" *ngIf=\"step=='terms'\">\n\n <label class=\"subtitle text-muted mb-2\" >We care about our users and are dedicated to protecting your data and privacy -\n thats why we want to be clear about what data we collect and how we use it to improve your experience.</label>\n\n <br>\n <spa-check display=\"I agree to the Terms and Privacy Policy\" [(value)]=\"agree\"></spa-check>\n</div>\n\n<!-- owner -->\n<div class=\"mt-3\" *ngIf=\"step=='name' && own\">\n\n <label class=\"subtitle text-muted\" style=\" margin-bottom: 20px;\">The follow steps will guide you to customise your application.</label>\n\n <div style=\"max-width: 400px;\">\n <spa-text display=\"Organisation Name\" [(value)]=\"myTenant.name\" ></spa-text>\n </div>\n\n <label class=\"text-muted\" style=\" font-size: 12px;\">You can change the Organisation's name to your team or company name.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">The name can be changed later.</label>\n\n</div>\n\n<!-- guest -->\n<div *ngIf=\"step=='hi' && !own\">\n <label class=\"subtitle text-muted\">You are now signed in to {{myTenant.name}}.</label>\n</div>\n\n\n<!-- invitations -->\n<div class=\"mt-3\" *ngIf=\"step=='invitations' && own\">\n\n <label class=\"subtitle text-muted\">You have been requested to join the following organisations. If you accept, you have the option to switch to that org now or stay in you org.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">You will be able to switch later.</label>\n <spa-invitations-table></spa-invitations-table>\n\n</div>\n\n\n<!-- Actions -->\n<div class=\"mt-3\">\n <button mat-stroked-button color=\"primary\" [disabled]=\"!agree\" (click)=\"next()\">Next <mat-icon>arrow_right_alt</mat-icon></button>\n</div>\n", styles: [".title{margin-top:1em;font-size:28px;font-weight:300}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.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: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.TextComponent, selector: "spa-text", inputs: ["readonly", "hint", "display", "placeholder", "value", "format", "type", "rows", "width", "options", "optionValue", "required", "min", "max", "regex", "suffix", "infoMessage"], outputs: ["valueChange", "leave", "enterPress", "infoClick"] }, { kind: "component", type: i7.CheckComponent, selector: "spa-check", inputs: ["readonly", "display", "value", "infoMessage"], outputs: ["valueChange", "click", "check", "uncheck", "infoClick"] }, { kind: "component", type: i8.InvitationsTableComponent, selector: "spa-invitations-table" }] });
82
82
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: WelcomeComponent, decorators: [{
83
83
  type: Component,
84
84
  args: [{ selector: 'spa-welcome', template: "<label class=\"title\">Welcome, {{username}}</label>\n\n\n\n<!-- terms -->\n<div class=\"mt-3\" *ngIf=\"step=='terms'\">\n\n <label class=\"subtitle text-muted mb-2\" >We care about our users and are dedicated to protecting your data and privacy -\n thats why we want to be clear about what data we collect and how we use it to improve your experience.</label>\n\n <br>\n <spa-check display=\"I agree to the Terms and Privacy Policy\" [(value)]=\"agree\"></spa-check>\n</div>\n\n<!-- owner -->\n<div class=\"mt-3\" *ngIf=\"step=='name' && own\">\n\n <label class=\"subtitle text-muted\" style=\" margin-bottom: 20px;\">The follow steps will guide you to customise your application.</label>\n\n <div style=\"max-width: 400px;\">\n <spa-text display=\"Organisation Name\" [(value)]=\"myTenant.name\" ></spa-text>\n </div>\n\n <label class=\"text-muted\" style=\" font-size: 12px;\">You can change the Organisation's name to your team or company name.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">The name can be changed later.</label>\n\n</div>\n\n<!-- guest -->\n<div *ngIf=\"step=='hi' && !own\">\n <label class=\"subtitle text-muted\">You are now signed in to {{myTenant.name}}.</label>\n</div>\n\n\n<!-- invitations -->\n<div class=\"mt-3\" *ngIf=\"step=='invitations' && own\">\n\n <label class=\"subtitle text-muted\">You have been requested to join the following organisations. If you accept, you have the option to switch to that org now or stay in you org.</label><br>\n <label class=\"text-muted\" style=\" font-size: 12px;margin-top: 10px;\">You will be able to switch later.</label>\n <spa-invitations-table></spa-invitations-table>\n\n</div>\n\n\n<!-- Actions -->\n<div class=\"mt-3\">\n <button mat-stroked-button color=\"primary\" [disabled]=\"!agree\" (click)=\"next()\">Next <mat-icon>arrow_right_alt</mat-icon></button>\n</div>\n", styles: [".title{margin-top:1em;font-size:28px;font-weight:300}\n"] }]
@@ -40,13 +40,13 @@ export class DialogService {
40
40
  formConfig: config.formConfig,
41
41
  buttons: config.buttons,
42
42
  details: row,
43
- heroField: config.heroField,
43
+ // heroField : config.heroField,
44
44
  };
45
45
  if (button.detailsConfig) {
46
46
  dialogConfig = buttonName === 'create' ? button.detailsConfig : DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row);
47
47
  }
48
48
  else {
49
- dialogConfig = DetailsDialogProcessor.processDetailsConfig(dialogConfig, row);
49
+ dialogConfig = DetailsDialogProcessor.processDetailsConfig({ ...dialogConfig }, row);
50
50
  }
51
51
  if (button.detailsConfig && button.detailsConfig.mode) {
52
52
  dialogConfig.formConfig.mode = button.detailsConfig.mode;
@@ -78,4 +78,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
78
78
  providedIn: 'root'
79
79
  }]
80
80
  }], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i2.BreakpointObserver }]; } });
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../projects/tin-spa/src/lib/services/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { Observable } from 'rxjs';\r\nimport { Column, DetailsDialogConfig, TableConfig } from '../classes/Classes';\r\n// import { DetailsDialog } from '../components/table/detailsDialog.component';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { DetailsDialogProcessor } from '../classes/TinCore';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class DialogService {\r\n  private smallScreen = false;\r\n\r\n  constructor(\r\n    private dialog: MatDialog,\r\n    private breakpointObserver: BreakpointObserver\r\n  ) {\r\n    // Detect screen size changes\r\n    this.breakpointObserver.observe([\"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n      this.smallScreen = result.matches;\r\n    });\r\n  }\r\n\r\n  openDetailsDialog<T>( config: DetailsDialogConfig, dialogComponent: new (...args: any[]) => T  ): {\r\n    afterClosed: Observable<any>,\r\n    inputChange: Observable<any>,\r\n    dialogRef: MatDialogRef<T>\r\n  } {\r\n    const hasTables = config.tableConfigs?.length > 0;\r\n\r\n    const dialogOptions = {\r\n      width: this.smallScreen ? '900px' : (hasTables ? '90%' : '900px'),\r\n      height: hasTables ? '90%' : 'auto',\r\n      data: config\r\n    };\r\n\r\n    const dialogRef = this.dialog.open(dialogComponent, dialogOptions);\r\n\r\n    return {\r\n      afterClosed: dialogRef.afterClosed(),\r\n      inputChange: (dialogRef.componentInstance as any).inputChange,\r\n      dialogRef: dialogRef\r\n    };\r\n  }\r\n\r\n  openConfiguredDetailsDialog<T>( buttonName: string, row: any, config: TableConfig | DetailsDialogConfig, dialogComponent: new (...args: any[]) => T, column?: Column  ): Observable<any> {\r\n\r\n    const button = column ? { name: column.name, dialog: true, detailsConfig: column.detailsConfig } : config.buttons?.find(b => b.name === buttonName);\r\n\r\n    if (!button || !button.dialog) {\r\n      return new Observable(observer => {\r\n        observer.next({ action: 'doAction', name: buttonName, row: row });\r\n        observer.complete();\r\n      });\r\n    }\r\n\r\n\r\n    let dialogConfig: DetailsDialogConfig = {\r\n      formConfig: config.formConfig,\r\n      buttons: config.buttons,\r\n      details: row,\r\n      heroField : config.heroField,\r\n\r\n    };\r\n\r\n\r\n    if (button.detailsConfig) {\r\n      dialogConfig = buttonName === 'create' ? button.detailsConfig : DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row);\r\n    }else{\r\n      dialogConfig = DetailsDialogProcessor.processDetailsConfig(dialogConfig, row);\r\n    }\r\n\r\n\r\n\r\n    if (button.detailsConfig && button.detailsConfig.mode) {\r\n      dialogConfig.formConfig.mode = button.detailsConfig.mode;\r\n    } else {\r\n      dialogConfig.formConfig.mode = buttonName === 'create' ? 'create' : (buttonName === 'edit' ? 'edit' : 'view');\r\n    }\r\n\r\n    if (buttonName === 'create') {\r\n      dialogConfig.heroField = config.heroField;\r\n      dialogConfig.heroValue = config.heroValue;\r\n    }\r\n\r\n    const dialogResult = this.openDetailsDialog(dialogConfig, dialogComponent);\r\n\r\n    return new Observable(observer => {\r\n      dialogResult.afterClosed.subscribe(result => {\r\n        observer.next(result);\r\n        observer.complete();\r\n      });\r\n\r\n      dialogResult.inputChange.subscribe(change => {\r\n        observer.next({ action: 'inputChange', change: change });\r\n      });\r\n    });\r\n  }\r\n}\r\n"]}
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../projects/tin-spa/src/lib/services/dialog.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAIlC,OAAO,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;;;;AAK5D,MAAM,OAAO,aAAa;IAGxB,YACU,MAAiB,EACjB,kBAAsC;QADtC,WAAM,GAAN,MAAM,CAAW;QACjB,uBAAkB,GAAlB,kBAAkB,CAAoB;QAJxC,gBAAW,GAAG,KAAK,CAAC;QAM1B,6BAA6B;QAC7B,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAuB,EAAE,EAAE;YAC5F,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC;QACpC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB,CAAK,MAA2B,EAAE,eAA0C;QAK3F,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,MAAM,GAAG,CAAC,CAAC;QAElD,MAAM,aAAa,GAAG;YACpB,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC;YACjE,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM;YAClC,IAAI,EAAE,MAAM;SACb,CAAC;QAEF,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC;QAEnE,OAAO;YACL,WAAW,EAAE,SAAS,CAAC,WAAW,EAAE;YACpC,WAAW,EAAG,SAAS,CAAC,iBAAyB,CAAC,WAAW;YAC7D,SAAS,EAAE,SAAS;SACrB,CAAC;IACJ,CAAC;IAED,2BAA2B,CAAK,UAAkB,EAAE,GAAQ,EAAE,MAAyC,EAAE,eAA0C,EAAE,MAAe;QAElK,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC;QAEpJ,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YAC7B,OAAO,IAAI,UAAU,CAAC,QAAQ,CAAC,EAAE;gBAC/B,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;gBAClE,QAAQ,CAAC,QAAQ,EAAE,CAAC;YACtB,CAAC,CAAC,CAAC;SACJ;QAGD,IAAI,YAAY,GAAwB;YACtC,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,OAAO,EAAE,GAAG;YACZ,gCAAgC;SAEjC,CAAC;QAGF,IAAI,MAAM,CAAC,aAAa,EAAE;YACxB,YAAY,GAAG,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,sBAAsB,CAAC,oBAAoB,CAAC,MAAM,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;SACxI;aAAI;YACH,YAAY,GAAG,sBAAsB,CAAC,oBAAoB,CAAC,EAAC,GAAG,YAAY,EAAC,EAAE,GAAG,CAAC,CAAC;SACpF;QAID,IAAI,MAAM,CAAC,aAAa,IAAI,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE;YACrD,YAAY,CAAC,UAAU,CAAC,IAAI,GAAG,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC;SAC1D;aAAM;YACL,YAAY,CAAC,UAAU,CAAC,IAAI,GAAG,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;SAC/G;QAED,IAAI,UAAU,KAAK,QAAQ,EAAE;YAC3B,YAAY,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;YAC1C,YAAY,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;SAC3C;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,eAAe,CAAC,CAAC;QAE3E,OAAO,IAAI,UAAU,CAAC,QAAQ,CAAC,EAAE;YAC/B,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;gBAC1C,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBACtB,QAAQ,CAAC,QAAQ,EAAE,CAAC;YACtB,CAAC,CAAC,CAAC;YAEH,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;gBAC1C,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;YAC3D,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;;0GAvFU,aAAa;8GAAb,aAAa,cAFZ,MAAM;2FAEP,aAAa;kBAHzB,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { Observable } from 'rxjs';\r\nimport { Column, DetailsDialogConfig, TableConfig } from '../classes/Classes';\r\n// import { DetailsDialog } from '../components/table/detailsDialog.component';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { DetailsDialogProcessor } from '../classes/TinCore';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class DialogService {\r\n  private smallScreen = false;\r\n\r\n  constructor(\r\n    private dialog: MatDialog,\r\n    private breakpointObserver: BreakpointObserver\r\n  ) {\r\n    // Detect screen size changes\r\n    this.breakpointObserver.observe([\"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n      this.smallScreen = result.matches;\r\n    });\r\n  }\r\n\r\n  openDetailsDialog<T>( config: DetailsDialogConfig, dialogComponent: new (...args: any[]) => T  ): {\r\n    afterClosed: Observable<any>,\r\n    inputChange: Observable<any>,\r\n    dialogRef: MatDialogRef<T>\r\n  } {\r\n    const hasTables = config.tableConfigs?.length > 0;\r\n\r\n    const dialogOptions = {\r\n      width: this.smallScreen ? '900px' : (hasTables ? '90%' : '900px'),\r\n      height: hasTables ? '90%' : 'auto',\r\n      data: config\r\n    };\r\n\r\n    const dialogRef = this.dialog.open(dialogComponent, dialogOptions);\r\n\r\n    return {\r\n      afterClosed: dialogRef.afterClosed(),\r\n      inputChange: (dialogRef.componentInstance as any).inputChange,\r\n      dialogRef: dialogRef\r\n    };\r\n  }\r\n\r\n  openConfiguredDetailsDialog<T>( buttonName: string, row: any, config: TableConfig | DetailsDialogConfig, dialogComponent: new (...args: any[]) => T, column?: Column  ): Observable<any> {\r\n\r\n    const button = column ? { name: column.name, dialog: true, detailsConfig: column.detailsConfig } : config.buttons?.find(b => b.name === buttonName);\r\n\r\n    if (!button || !button.dialog) {\r\n      return new Observable(observer => {\r\n        observer.next({ action: 'doAction', name: buttonName, row: row });\r\n        observer.complete();\r\n      });\r\n    }\r\n\r\n\r\n    let dialogConfig: DetailsDialogConfig = {\r\n      formConfig: config.formConfig,\r\n      buttons: config.buttons,\r\n      details: row,\r\n      // heroField : config.heroField,\r\n\r\n    };\r\n\r\n\r\n    if (button.detailsConfig) {\r\n      dialogConfig = buttonName === 'create' ? button.detailsConfig : DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row);\r\n    }else{\r\n      dialogConfig = DetailsDialogProcessor.processDetailsConfig({...dialogConfig}, row);\r\n    }\r\n\r\n\r\n\r\n    if (button.detailsConfig && button.detailsConfig.mode) {\r\n      dialogConfig.formConfig.mode = button.detailsConfig.mode;\r\n    } else {\r\n      dialogConfig.formConfig.mode = buttonName === 'create' ? 'create' : (buttonName === 'edit' ? 'edit' : 'view');\r\n    }\r\n\r\n    if (buttonName === 'create') {\r\n      dialogConfig.heroField = config.heroField;\r\n      dialogConfig.heroValue = config.heroValue;\r\n    }\r\n\r\n    const dialogResult = this.openDetailsDialog(dialogConfig, dialogComponent);\r\n\r\n    return new Observable(observer => {\r\n      dialogResult.afterClosed.subscribe(result => {\r\n        observer.next(result);\r\n        observer.complete();\r\n      });\r\n\r\n      dialogResult.inputChange.subscribe(change => {\r\n        observer.next({ action: 'inputChange', change: change });\r\n      });\r\n    });\r\n  }\r\n}\r\n"]}