@firestitch/app-acl 9.0.18 → 9.0.19

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 (80) hide show
  1. package/app/components/acl-entries/acl-entries.component.d.ts +27 -27
  2. package/app/components/acl-entry/acl-entry.component.d.ts +23 -23
  3. package/app/components/acl-entry/index.d.ts +1 -1
  4. package/app/components/acl-object-roles/acl-object-roles.component.d.ts +14 -14
  5. package/app/components/acl-permission-popover/acl-permission-popover.component.d.ts +9 -9
  6. package/app/components/acl-permission-popover/index.d.ts +1 -1
  7. package/app/components/acl-role/acl-role.component.d.ts +43 -42
  8. package/app/components/acl-role-popover/acl-role-popover.component.d.ts +10 -10
  9. package/app/components/acl-roles/acl-roles.component.d.ts +31 -31
  10. package/app/consts/acl-role-accesses.d.ts +5 -5
  11. package/app/enums/acl-role-access.d.ts +6 -6
  12. package/app/enums/index.d.ts +1 -1
  13. package/app/fs-app-acl.module.d.ts +4 -4
  14. package/app/injectors/app-acl-config.injector.d.ts +2 -2
  15. package/app/injectors/index.d.ts +1 -1
  16. package/app/interfaces/acl-entry-data.d.ts +11 -11
  17. package/app/interfaces/acl-entry.d.ts +18 -18
  18. package/app/interfaces/acl-level.d.ts +3 -3
  19. package/app/interfaces/acl-object-entry.d.ts +11 -11
  20. package/app/interfaces/acl-object-role.d.ts +6 -6
  21. package/app/interfaces/acl-object.d.ts +4 -4
  22. package/app/interfaces/acl-permission.d.ts +7 -7
  23. package/app/interfaces/acl-role.d.ts +15 -15
  24. package/app/interfaces/app-acl-config.d.ts +7 -7
  25. package/app/interfaces/index.d.ts +11 -11
  26. package/app/interfaces/name-value.d.ts +4 -4
  27. package/app/services/app-acl.service.d.ts +13 -13
  28. package/app/services/index.d.ts +1 -1
  29. package/bundles/firestitch-app-acl.umd.js +854 -850
  30. package/bundles/firestitch-app-acl.umd.js.map +1 -1
  31. package/bundles/firestitch-app-acl.umd.min.js +2 -2
  32. package/bundles/firestitch-app-acl.umd.min.js.map +1 -1
  33. package/esm2015/app/components/acl-entries/acl-entries.component.js +176 -176
  34. package/esm2015/app/components/acl-entry/acl-entry.component.js +87 -87
  35. package/esm2015/app/components/acl-entry/index.js +1 -1
  36. package/esm2015/app/components/acl-object-roles/acl-object-roles.component.js +62 -62
  37. package/esm2015/app/components/acl-permission-popover/acl-permission-popover.component.js +34 -34
  38. package/esm2015/app/components/acl-permission-popover/index.js +1 -1
  39. package/esm2015/app/components/acl-role/acl-role.component.js +191 -187
  40. package/esm2015/app/components/acl-role-popover/acl-role-popover.component.js +40 -40
  41. package/esm2015/app/components/acl-roles/acl-roles.component.js +157 -157
  42. package/esm2015/app/consts/acl-role-accesses.js +7 -7
  43. package/esm2015/app/enums/acl-role-access.js +7 -7
  44. package/esm2015/app/enums/index.js +3 -3
  45. package/esm2015/app/fs-app-acl.module.js +81 -81
  46. package/esm2015/app/injectors/app-acl-config.injector.js +2 -2
  47. package/esm2015/app/injectors/index.js +3 -3
  48. package/esm2015/app/interfaces/index.js +1 -1
  49. package/esm2015/app/services/app-acl.service.js +80 -80
  50. package/esm2015/app/services/index.js +1 -1
  51. package/esm2015/firestitch-app-acl.js +10 -10
  52. package/esm2015/public_api.js +5 -5
  53. package/esm5/app/components/acl-entries/acl-entries.component.js +179 -179
  54. package/esm5/app/components/acl-entry/acl-entry.component.js +92 -92
  55. package/esm5/app/components/acl-entry/index.js +1 -1
  56. package/esm5/app/components/acl-object-roles/acl-object-roles.component.js +63 -63
  57. package/esm5/app/components/acl-permission-popover/acl-permission-popover.component.js +36 -36
  58. package/esm5/app/components/acl-permission-popover/index.js +1 -1
  59. package/esm5/app/components/acl-role/acl-role.component.js +201 -197
  60. package/esm5/app/components/acl-role-popover/acl-role-popover.component.js +42 -42
  61. package/esm5/app/components/acl-roles/acl-roles.component.js +162 -162
  62. package/esm5/app/consts/acl-role-accesses.js +7 -7
  63. package/esm5/app/enums/acl-role-access.js +7 -7
  64. package/esm5/app/enums/index.js +3 -3
  65. package/esm5/app/fs-app-acl.module.js +85 -85
  66. package/esm5/app/injectors/app-acl-config.injector.js +2 -2
  67. package/esm5/app/injectors/index.js +3 -3
  68. package/esm5/app/interfaces/index.js +1 -1
  69. package/esm5/app/services/app-acl.service.js +85 -85
  70. package/esm5/app/services/index.js +1 -1
  71. package/esm5/firestitch-app-acl.js +10 -10
  72. package/esm5/public_api.js +5 -5
  73. package/fesm2015/firestitch-app-acl.js +821 -817
  74. package/fesm2015/firestitch-app-acl.js.map +1 -1
  75. package/fesm5/firestitch-app-acl.js +858 -854
  76. package/fesm5/firestitch-app-acl.js.map +1 -1
  77. package/firestitch-app-acl.d.ts +11 -11
  78. package/firestitch-app-acl.metadata.json +1 -1
  79. package/package.json +1 -1
  80. package/public_api.d.ts +6 -6
@@ -1,187 +1,191 @@
1
- import { __decorate, __metadata, __param } from "tslib";
2
- import { Component, Inject, ViewChild } from '@angular/core';
3
- import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
4
- import { AclRoleAccesses } from './../../consts/acl-role-accesses';
5
- import { tap, takeUntil, map } from 'rxjs/operators';
6
- import { FsMessage } from '@firestitch/message';
7
- import { list } from '@firestitch/common';
8
- import { FsListComponent } from '@firestitch/list';
9
- import { of, forkJoin, Subject } from 'rxjs';
10
- import { FsAppAclService } from './../../services';
11
- let FsAclRoleComponent = class FsAclRoleComponent {
12
- constructor(_appAclService, _dialogRef, _message, _data) {
13
- this._appAclService = _appAclService;
14
- this._dialogRef = _dialogRef;
15
- this._message = _message;
16
- this._data = _data;
17
- this.aclRole = null;
18
- this.permissions = [];
19
- this.levelPermissions = [];
20
- this.AclRoleAccesses = AclRoleAccesses;
21
- this.indexedAccesses = {};
22
- this.aclLevels = [];
23
- this.indexedAclLevels = {};
24
- this.onlyFullAccess = false;
25
- this.AclLevels = {};
26
- this.aclRoleConfigs = [];
27
- this.levelAclRoleConfigs = [];
28
- this._destroy$ = new Subject();
29
- this.save = () => {
30
- const aclRole = Object.assign(Object.assign({}, this.aclRole), { permissions: this.levelPermissions.map((permission) => {
31
- return {
32
- value: permission.value,
33
- access: this.aclRole.permissions[permission.value] || 0,
34
- };
35
- }), aclRoleConfigs: this.levelAclRoleConfigs.map((item) => {
36
- return {
37
- id: item.id,
38
- value: item.value,
39
- data: item.data,
40
- };
41
- }) });
42
- return this._data.saveAclRole(this._appAclService.output(aclRole))
43
- .pipe(tap((response) => {
44
- this._message.success('Saved Changes');
45
- this.close(response);
46
- }));
47
- };
48
- }
49
- ngOnInit() {
50
- forkJoin(this.getRole(), this._appAclService.getPermissions())
51
- .pipe(takeUntil(this._destroy$))
52
- .subscribe(([aclRole, aclPermissions,]) => {
53
- this.permissions = aclPermissions;
54
- this.aclLevels = this._data.aclLevels;
55
- this.indexedAclLevels = list(this.aclLevels, 'name', 'value');
56
- this.indexedAccesses = list(AclRoleAccesses, 'name', 'value');
57
- this.aclRole = Object.assign({
58
- aclPermissions: [],
59
- allPermissions: true,
60
- aclRoleConfigs: [],
61
- permissions: {},
62
- level: this.aclLevels[0].value,
63
- }, aclRole);
64
- if (this.aclRole.id) {
65
- this.permissions.forEach((permission) => {
66
- let access = 0;
67
- const aclPermission = this.aclRole.aclPermissions.find((item) => {
68
- return item.permission === permission.value;
69
- });
70
- if (aclPermission) {
71
- access = aclPermission.access;
72
- }
73
- this.aclRole.permissions[permission.value] = access;
74
- });
75
- }
76
- if (this.aclRole.allPermissions) {
77
- this._applyMaxPermissionAccess();
78
- }
79
- this._updatePermissions();
80
- this._updateAclRoleConfigs();
81
- });
82
- this.listConfig = {
83
- status: false,
84
- paging: false,
85
- noResults: {
86
- message: '',
87
- },
88
- group: {
89
- initialExpand: true,
90
- groupBy: (data) => {
91
- return data;
92
- },
93
- compareBy: (data) => {
94
- return data.category || 'General';
95
- },
96
- },
97
- fetch: () => {
98
- return of({
99
- data: this.levelPermissions.sort((a, b) => {
100
- a = a.name.toUpperCase();
101
- b = b.name.toUpperCase();
102
- if (a < b) {
103
- return -1;
104
- }
105
- else if (a > b) {
106
- return 1;
107
- }
108
- return 0;
109
- }),
110
- });
111
- },
112
- };
113
- }
114
- levelChange() {
115
- this._updatePermissions();
116
- this._updateAclRoleConfigs();
117
- setTimeout(() => {
118
- this.list.reload();
119
- });
120
- }
121
- getRole() {
122
- if (!this._data.aclRole.id) {
123
- return of(this._data.aclRole);
124
- }
125
- const query = {
126
- aclPermissions: true,
127
- aclRoleConfigs: true,
128
- };
129
- if (!this.environment) {
130
- query.environmentId = null;
131
- }
132
- return this._data.loadAclRole(this._data.aclRole, query)
133
- .pipe(map((data) => this._appAclService.input(data)));
134
- }
135
- close(data = null) {
136
- this._dialogRef.close(data);
137
- }
138
- allPermissionsChange(all) {
139
- this._updatePermissions();
140
- if (all) {
141
- this._applyMaxPermissionAccess();
142
- }
143
- }
144
- ngOnDestroy() {
145
- this._destroy$.next();
146
- this._destroy$.complete();
147
- }
148
- _updatePermissions() {
149
- this.levelPermissions = this.permissions.filter((permission) => {
150
- return permission.levels.some((item) => {
151
- return item === this.aclRole.level;
152
- });
153
- });
154
- }
155
- _updateAclRoleConfigs() {
156
- this.levelAclRoleConfigs = this.aclRoleConfigs.filter((item) => {
157
- return this.aclRole.level === item.level;
158
- });
159
- }
160
- _applyMaxPermissionAccess() {
161
- this.permissions.forEach((permission) => {
162
- this.aclRole.permissions[permission.value] = Math.max(...permission.accesses);
163
- });
164
- }
165
- };
166
- FsAclRoleComponent.ctorParameters = () => [
167
- { type: FsAppAclService },
168
- { type: MatDialogRef },
169
- { type: FsMessage },
170
- { type: undefined, decorators: [{ type: Inject, args: [MAT_DIALOG_DATA,] }] }
171
- ];
172
- __decorate([
173
- ViewChild(FsListComponent),
174
- __metadata("design:type", FsListComponent)
175
- ], FsAclRoleComponent.prototype, "list", void 0);
176
- FsAclRoleComponent = __decorate([
177
- Component({
178
- template: "<form fsForm [submit]=\"save\">\n <fs-dialog>\n <ng-container *ngIf=\"aclRole\">\n <div mat-dialog-title>{{ aclRole.id ? 'Edit' : 'Create' }} Role</div>\n <mat-dialog-content>\n <div fxLayout=\"row\" fxLayout.lt-md=\"column\" fxLayoutGap=\"40px\" fxLayoutGap.lt-md=\"0\">\n <div fxLayout=\"column\" fxFlex fxFlex.lt-md=\"0\">\n <mat-form-field>\n <input matInput placeholder=\"Name\" [(ngModel)]=\"aclRole.name\" name=\"name\" fsFormRequired>\n </mat-form-field>\n\n <fs-label-field *ngIf=\"aclRole.id || aclLevels.length === 1; else levels\">\n <fs-label>Level</fs-label>\n {{indexedAclLevels[aclRole.level]}}\n </fs-label-field>\n\n <ng-template #levels>\n <div class=\"level\">\n <fs-radio-group\n [(ngModel)]=\"aclRole.level\"\n (ngModelChange)=\"levelChange()\"\n fsFormRequired\n label=\"Level\"\n orientation=\"vertical\"\n name=\"level\">\n <mat-radio-button\n *ngFor=\"let item of aclLevels\"\n [value]=\"item.value\"\n [disabled]=\"!!aclRole.protected\">\n {{ item.name }}\n </mat-radio-button>\n </fs-radio-group>\n </div>\n </ng-template>\n\n <fs-label-field *ngIf=\"levelPermissions.length\">\n <fs-label>All Permissions</fs-label>\n <mat-checkbox\n [(ngModel)]=\"aclRole.allPermissions\"\n (ngModelChange)=\"allPermissionsChange($event)\"\n [disabled]=\"!!aclRole.protected\"\n name=\"allPermissions\">\n </mat-checkbox>\n </fs-label-field>\n\n <div fxLayout=\"column\" *ngFor=\"let config of levelAclRoleConfigs\">\n <fs-label-field *ngIf=\"config.interface === 'checkbox'\">\n <fs-label>{{config.name}}</fs-label>\n <mat-checkbox\n [(ngModel)]=\"config.data\"\n [name]=\"config.name\">\n </mat-checkbox>\n <fs-label-message>\n <mat-hint>{{config.description}}</mat-hint>\n </fs-label-message>\n </fs-label-field>\n\n <mat-form-field *ngIf=\"config.interface === 'select'\">\n <mat-select\n [(ngModel)]=\"config.data\"\n [name]=\"config.value\"\n [required]=\"config.required\"\n [placeholder]=\"config.name\">\n <mat-option\n *ngFor=\"let item of config.values\"\n [value]=\"item.value\">\n {{ item.name }}\n </mat-option>\n </mat-select>\n <mat-hint>{{config.description}}</mat-hint>\n </mat-form-field>\n </div>\n </div>\n\n <div fxLayout=\"column\" fxFlex=\"65\" fxFlex.lt-md=\"0\" *ngIf=\"aclRole.level\" [hidden]=\"!levelPermissions.length\" class=\"permissions\">\n\n <fs-list [config]=\"listConfig\">\n <fs-list-column title=\"Permissions\">\n <ng-template colspan=\"2\" fs-list-group-cell let-row=\"row\" class=\"permission-group\">\n <small><b>{{row.category || 'General'}}</b></small>\n </ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n <div class=\"permission\">{{ row.name }}</div>\n <div class=\"description small\">{{ row.description }}</div>\n </ng-template>\n </fs-list-column>\n <fs-list-column title=\"Access\" width=\"1%\" class=\"access\">\n <ng-template fs-list-cell let-row=\"permission\" let-permission=\"row\">\n <span *ngIf=\"aclRole.allPermissions; else elseAll\">\n {{ indexedAccesses[aclRole.permissions[permission.value]] }}\n </span>\n <ng-template #elseAll>\n <mat-form-field>\n <mat-select\n [(ngModel)]=\"aclRole.permissions[permission.value]\"\n [disabled]=\"!!aclRole.protected\"\n fsFormRequired\n name=\"access-{{ permission.value }}\">\n <ng-container *ngFor=\"let access of AclRoleAccesses\">\n <mat-option\n *ngIf=\"access.value === 0 || permission.accesses.indexOf(access.value) !== -1\"\n [value]=\"access.value\">\n {{ access.name }}\n </mat-option>\n </ng-container>\n </mat-select>\n </mat-form-field>\n </ng-template>\n </ng-template>\n </fs-list-column>\n </fs-list>\n </div>\n </div>\n </mat-dialog-content>\n <mat-dialog-actions>\n <button mat-button type=\"submit\" color=\"primary\">{{ aclRole.id ? 'Save' : 'Create' }}</button>\n <button mat-button [mat-dialog-close]=\"null\" type=\"button\">Cancel</button>\n </mat-dialog-actions>\n </ng-container>\n </fs-dialog>\n</form>\n",
179
- styles: [":host .permissions ::ng-deep .fs-list-row-group{background-color:#f6f6f6}:host .permissions ::ng-deep fs-list .access{white-space:nowrap}:host .permissions ::ng-deep .mat-form-field{width:100px}:host .permissions ::ng-deep .mat-form-field .mat-form-field-wrapper{padding-bottom:0}:host .permissions ::ng-deep .mat-form-field .mat-form-field-infix{border-top:0}:host .permissions ::ng-deep .mat-form-field .mat-form-field-underline{bottom:0}:host ::ng-deep fs-radio-group{width:100%}:host ::ng-deep fs-label-field{width:100%}:host .level{width:100%}"]
180
- }),
181
- __param(3, Inject(MAT_DIALOG_DATA)),
182
- __metadata("design:paramtypes", [FsAppAclService,
183
- MatDialogRef,
184
- FsMessage, Object])
185
- ], FsAclRoleComponent);
186
- export { FsAclRoleComponent };
187
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"acl-role.component.js","sourceRoot":"ng://@firestitch/app-acl/","sources":["app/components/acl-role/acl-role.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, OnInit, ViewChild, OnDestroy } from '@angular/core';\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\n\nimport { AclRoleAccesses } from './../../consts/acl-role-accesses';\nimport { AclRole } from './../../interfaces';\nimport { tap, takeUntil, map } from 'rxjs/operators';\n\nimport { FsMessage } from '@firestitch/message';\nimport { list } from '@firestitch/common';\nimport { FsListConfig, FsListComponent } from '@firestitch/list';\n\nimport { of, Observable, forkJoin, Subject } from 'rxjs';\nimport { FsAppAclService } from './../../services';\n\n\n@Component({\n  templateUrl: './acl-role.component.html',\n  styleUrls: ['./acl-role.component.scss']\n})\nexport class FsAclRoleComponent implements OnInit, OnDestroy {\n\n  @ViewChild(FsListComponent) public list: FsListComponent;\n\n  public aclRole: AclRole = null;\n  public environment;\n  public permissions: any[] = [];\n  public listConfig: FsListConfig;\n  public levelPermissions = [];\n  public AclRoleAccesses = AclRoleAccesses;\n  public indexedAccesses = {};\n  public aclLevels: any[] = [];\n  public indexedAclLevels = {};\n  public onlyFullAccess = false;\n  public AclLevels = {};\n  public aclRoleConfigs = [];\n  public levelAclRoleConfigs = [];\n\n  private _destroy$ = new Subject();\n\n  constructor(\n    private readonly _appAclService: FsAppAclService,\n    private readonly _dialogRef: MatDialogRef<FsAclRoleComponent>,\n    private readonly _message: FsMessage,\n    @Inject(MAT_DIALOG_DATA) private readonly _data: any,\n  ) {}\n\n  public ngOnInit(): void {\n    forkJoin(\n      this.getRole(),\n      this._appAclService.getPermissions(),\n    )\n      .pipe(takeUntil(this._destroy$))\n      .subscribe(([\n        aclRole,\n        aclPermissions,\n      ]) => {\n\n        this.permissions = aclPermissions;\n        this.aclLevels = this._data.aclLevels;\n\n        this.indexedAclLevels = list(this.aclLevels, 'name', 'value');\n        this.indexedAccesses = list(AclRoleAccesses, 'name', 'value');\n\n        this.aclRole = {\n          ...{\n            aclPermissions: [],\n            allPermissions: true,\n            aclRoleConfigs: [],\n            permissions: {},\n            level: this.aclLevels[0].value,\n          },\n          ...aclRole,\n        };\n\n        if (this.aclRole.id) {\n          this.permissions.forEach((permission) => {\n            let access = 0;\n\n            const aclPermission = this.aclRole.aclPermissions.find((item) => {\n              return item.permission === permission.value;\n            });\n\n            if (aclPermission) {\n              access = aclPermission.access;\n            }\n\n            this.aclRole.permissions[permission.value] = access;\n          });\n        }\n\n        if (this.aclRole.allPermissions) {\n          this._applyMaxPermissionAccess();\n        }\n\n        this._updatePermissions();\n        this._updateAclRoleConfigs();\n      });\n\n    this.listConfig = {\n      status: false,\n      paging: false,\n      noResults: {\n        message: '',\n      },\n      group: {\n        initialExpand: true,\n        groupBy: (data) => {\n          return data;\n        },\n        compareBy: (data) => {\n          return data.category || 'General';\n        },\n      },\n      fetch: () => {\n        return of({\n          data: this.levelPermissions.sort((a, b) => {\n            a = a.name.toUpperCase();\n            b = b.name.toUpperCase();\n            if (a < b) {\n              return -1;\n            } else if (a > b) {\n              return 1;\n            }\n\n            return 0;\n          }),\n        });\n      },\n    };\n  }\n\n  public levelChange(): void {\n    this._updatePermissions();\n    this._updateAclRoleConfigs();\n    setTimeout(() => {\n      this.list.reload();\n    });\n  }\n\n  public getRole(): Observable<any> {\n    if (!this._data.aclRole.id) {\n      return of(this._data.aclRole);\n    }\n\n    const query: any = {\n      aclPermissions: true,\n      aclRoleConfigs: true,\n    };\n\n    if (!this.environment) {\n      query.environmentId = null;\n    }\n\n    return this._data.loadAclRole(this._data.aclRole, query)\n      .pipe(\n        map((data) => this._appAclService.input(data)),\n      );\n  }\n\n  public save = (): Observable<any> => {\n    const aclRole = {\n      ...this.aclRole,\n      permissions: this.levelPermissions.map((permission) => {\n        return {\n          value: permission.value,\n          access: this.aclRole.permissions[permission.value] || 0,\n        };\n      }),\n      aclRoleConfigs: this.levelAclRoleConfigs.map((item) => {\n        return {\n          id: item.id,\n          value: item.value,\n          data: item.data,\n        };\n      }),\n    };\n\n    return this._data.saveAclRole(this._appAclService.output(aclRole))\n      .pipe(\n        tap((response) => {\n          this._message.success('Saved Changes');\n          this.close(response);\n        }),\n      );\n  }\n\n  public close(data: any = null): void {\n    this._dialogRef.close(data);\n  }\n\n  public allPermissionsChange(all: boolean): void {\n    this._updatePermissions();\n    if (all) {\n      this._applyMaxPermissionAccess();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  private _updatePermissions(): void {\n    this.levelPermissions = this.permissions.filter((permission) => {\n      return permission.levels.some((item) => {\n        return item === this.aclRole.level;\n      });\n    });\n  }\n\n  private _updateAclRoleConfigs(): void {\n    this.levelAclRoleConfigs = this.aclRoleConfigs.filter((item) => {\n      return this.aclRole.level === item.level;\n    });\n  }\n\n  private _applyMaxPermissionAccess(): void {\n    this.permissions.forEach((permission) => {\n      this.aclRole.permissions[permission.value] = Math.max(...permission.accesses);\n    });\n  }\n\n}\n"]}
1
+ import { __decorate, __metadata, __param } from "tslib";
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, OnDestroy, OnInit, ViewChild } from '@angular/core';
3
+ import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';
4
+ import { AclRoleAccesses } from './../../consts/acl-role-accesses';
5
+ import { map, takeUntil, tap } from 'rxjs/operators';
6
+ import { FsMessage } from '@firestitch/message';
7
+ import { list } from '@firestitch/common';
8
+ import { FsListComponent } from '@firestitch/list';
9
+ import { forkJoin, of, Subject } from 'rxjs';
10
+ import { FsAppAclService } from './../../services';
11
+ let FsAclRoleComponent = class FsAclRoleComponent {
12
+ constructor(_appAclService, _dialogRef, _message, _data, _cdRef) {
13
+ this._appAclService = _appAclService;
14
+ this._dialogRef = _dialogRef;
15
+ this._message = _message;
16
+ this._data = _data;
17
+ this._cdRef = _cdRef;
18
+ this.aclRole = null;
19
+ this.permissions = [];
20
+ this.levelPermissions = [];
21
+ this.AclRoleAccesses = AclRoleAccesses;
22
+ this.indexedAccesses = {};
23
+ this.aclLevels = [];
24
+ this.indexedAclLevels = {};
25
+ this.onlyFullAccess = false;
26
+ this.AclLevels = {};
27
+ this.aclRoleConfigs = [];
28
+ this.levelAclRoleConfigs = [];
29
+ this._destroy$ = new Subject();
30
+ this.save = () => {
31
+ const aclRole = Object.assign(Object.assign({}, this.aclRole), { permissions: this.levelPermissions.map((permission) => {
32
+ return {
33
+ value: permission.value,
34
+ access: this.aclRole.permissions[permission.value] || 0,
35
+ };
36
+ }), aclRoleConfigs: this.levelAclRoleConfigs.map((item) => {
37
+ return {
38
+ id: item.id,
39
+ value: item.value,
40
+ data: item.data,
41
+ };
42
+ }) });
43
+ return this._data.saveAclRole(this._appAclService.output(aclRole))
44
+ .pipe(tap((response) => {
45
+ this._message.success('Saved Changes');
46
+ this.close(response);
47
+ }));
48
+ };
49
+ }
50
+ ngOnInit() {
51
+ forkJoin(this.getRole(), this._appAclService.getPermissions())
52
+ .pipe(takeUntil(this._destroy$))
53
+ .subscribe(([aclRole, aclPermissions,]) => {
54
+ this.permissions = aclPermissions;
55
+ this.aclLevels = this._data.aclLevels;
56
+ this.indexedAclLevels = list(this.aclLevels, 'name', 'value');
57
+ this.indexedAccesses = list(AclRoleAccesses, 'name', 'value');
58
+ this.aclRole = Object.assign({
59
+ aclPermissions: [],
60
+ allPermissions: true,
61
+ aclRoleConfigs: [],
62
+ permissions: {},
63
+ level: this.aclLevels[0].value,
64
+ }, aclRole);
65
+ if (this.aclRole.id) {
66
+ this.permissions.forEach((permission) => {
67
+ let access = 0;
68
+ const aclPermission = this.aclRole.aclPermissions.find((item) => {
69
+ return item.permission === permission.value;
70
+ });
71
+ if (aclPermission) {
72
+ access = aclPermission.access;
73
+ }
74
+ this.aclRole.permissions[permission.value] = access;
75
+ });
76
+ }
77
+ if (this.aclRole.allPermissions) {
78
+ this._applyMaxPermissionAccess();
79
+ }
80
+ this._updatePermissions();
81
+ this._updateAclRoleConfigs();
82
+ this._cdRef.markForCheck();
83
+ });
84
+ this.listConfig = {
85
+ status: false,
86
+ paging: false,
87
+ noResults: {
88
+ message: '',
89
+ },
90
+ group: {
91
+ initialExpand: true,
92
+ groupBy: (data) => {
93
+ return data;
94
+ },
95
+ compareBy: (data) => {
96
+ return data.category || 'General';
97
+ },
98
+ },
99
+ fetch: () => {
100
+ return of({
101
+ data: this.levelPermissions.sort((a, b) => {
102
+ a = a.name.toUpperCase();
103
+ b = b.name.toUpperCase();
104
+ if (a < b) {
105
+ return -1;
106
+ }
107
+ else if (a > b) {
108
+ return 1;
109
+ }
110
+ return 0;
111
+ }),
112
+ });
113
+ },
114
+ };
115
+ }
116
+ levelChange() {
117
+ this._updatePermissions();
118
+ this._updateAclRoleConfigs();
119
+ setTimeout(() => {
120
+ this.list.reload();
121
+ });
122
+ }
123
+ getRole() {
124
+ if (!this._data.aclRole.id) {
125
+ return of(this._data.aclRole);
126
+ }
127
+ const query = {
128
+ aclPermissions: true,
129
+ aclRoleConfigs: true,
130
+ };
131
+ if (!this.environment) {
132
+ query.environmentId = null;
133
+ }
134
+ return this._data.loadAclRole(this._data.aclRole, query)
135
+ .pipe(map((data) => this._appAclService.input(data)));
136
+ }
137
+ close(data = null) {
138
+ this._dialogRef.close(data);
139
+ }
140
+ allPermissionsChange(all) {
141
+ this._updatePermissions();
142
+ if (all) {
143
+ this._applyMaxPermissionAccess();
144
+ }
145
+ }
146
+ ngOnDestroy() {
147
+ this._destroy$.next();
148
+ this._destroy$.complete();
149
+ }
150
+ _updatePermissions() {
151
+ this.levelPermissions = this.permissions.filter((permission) => {
152
+ return permission.levels.some((item) => {
153
+ return item === this.aclRole.level;
154
+ });
155
+ });
156
+ }
157
+ _updateAclRoleConfigs() {
158
+ this.levelAclRoleConfigs = this.aclRoleConfigs.filter((item) => {
159
+ return this.aclRole.level === item.level;
160
+ });
161
+ }
162
+ _applyMaxPermissionAccess() {
163
+ this.permissions.forEach((permission) => {
164
+ this.aclRole.permissions[permission.value] = Math.max(...permission.accesses);
165
+ });
166
+ }
167
+ };
168
+ FsAclRoleComponent.ctorParameters = () => [
169
+ { type: FsAppAclService },
170
+ { type: MatDialogRef },
171
+ { type: FsMessage },
172
+ { type: undefined, decorators: [{ type: Inject, args: [MAT_DIALOG_DATA,] }] },
173
+ { type: ChangeDetectorRef }
174
+ ];
175
+ __decorate([
176
+ ViewChild(FsListComponent),
177
+ __metadata("design:type", FsListComponent)
178
+ ], FsAclRoleComponent.prototype, "list", void 0);
179
+ FsAclRoleComponent = __decorate([
180
+ Component({
181
+ template: "<form fsForm [submit]=\"save\">\n <fs-dialog>\n <ng-container *ngIf=\"aclRole\">\n <div mat-dialog-title>{{ aclRole.id ? 'Edit' : 'Create' }} Role</div>\n <mat-dialog-content>\n <div fxLayout=\"row\" fxLayout.lt-md=\"column\" fxLayoutGap=\"40px\" fxLayoutGap.lt-md=\"0\">\n <div fxLayout=\"column\" fxFlex fxFlex.lt-md=\"0\">\n <mat-form-field>\n <input matInput placeholder=\"Name\" [(ngModel)]=\"aclRole.name\" name=\"name\" fsFormRequired>\n </mat-form-field>\n\n <fs-label-field *ngIf=\"aclRole.id || aclLevels.length === 1; else levels\">\n <fs-label>Level</fs-label>\n {{indexedAclLevels[aclRole.level]}}\n </fs-label-field>\n\n <ng-template #levels>\n <div class=\"level\">\n <fs-radio-group\n [(ngModel)]=\"aclRole.level\"\n (ngModelChange)=\"levelChange()\"\n fsFormRequired\n label=\"Level\"\n orientation=\"vertical\"\n name=\"level\">\n <mat-radio-button\n *ngFor=\"let item of aclLevels\"\n [value]=\"item.value\"\n [disabled]=\"!!aclRole.protected\">\n {{ item.name }}\n </mat-radio-button>\n </fs-radio-group>\n </div>\n </ng-template>\n\n <fs-label-field *ngIf=\"levelPermissions.length\">\n <fs-label>All Permissions</fs-label>\n <mat-checkbox\n [(ngModel)]=\"aclRole.allPermissions\"\n (ngModelChange)=\"allPermissionsChange($event)\"\n [disabled]=\"!!aclRole.protected\"\n name=\"allPermissions\">\n </mat-checkbox>\n </fs-label-field>\n\n <div fxLayout=\"column\" *ngFor=\"let config of levelAclRoleConfigs\">\n <fs-label-field *ngIf=\"config.interface === 'checkbox'\">\n <fs-label>{{config.name}}</fs-label>\n <mat-checkbox\n [(ngModel)]=\"config.data\"\n [name]=\"config.name\">\n </mat-checkbox>\n <fs-label-message>\n <mat-hint>{{config.description}}</mat-hint>\n </fs-label-message>\n </fs-label-field>\n\n <mat-form-field *ngIf=\"config.interface === 'select'\">\n <mat-select\n [(ngModel)]=\"config.data\"\n [name]=\"config.value\"\n [required]=\"config.required\"\n [placeholder]=\"config.name\">\n <mat-option\n *ngFor=\"let item of config.values\"\n [value]=\"item.value\">\n {{ item.name }}\n </mat-option>\n </mat-select>\n <mat-hint>{{config.description}}</mat-hint>\n </mat-form-field>\n </div>\n </div>\n\n <div fxLayout=\"column\" fxFlex=\"65\" fxFlex.lt-md=\"0\" *ngIf=\"aclRole.level\" [hidden]=\"!levelPermissions.length\" class=\"permissions\">\n\n <fs-list [config]=\"listConfig\">\n <fs-list-column title=\"Permissions\">\n <ng-template colspan=\"2\" fs-list-group-cell let-row=\"row\" class=\"permission-group\">\n <small><b>{{row.category || 'General'}}</b></small>\n </ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n <div class=\"permission\">{{ row.name }}</div>\n <div class=\"description small\">{{ row.description }}</div>\n </ng-template>\n </fs-list-column>\n <fs-list-column title=\"Access\" width=\"1%\" class=\"access\">\n <ng-template fs-list-cell let-row=\"permission\" let-permission=\"row\">\n <span *ngIf=\"aclRole.allPermissions; else elseAll\">\n {{ indexedAccesses[aclRole.permissions[permission.value]] }}\n </span>\n <ng-template #elseAll>\n <mat-form-field>\n <mat-select\n [(ngModel)]=\"aclRole.permissions[permission.value]\"\n [disabled]=\"!!aclRole.protected\"\n fsFormRequired\n name=\"access-{{ permission.value }}\">\n <ng-container *ngFor=\"let access of AclRoleAccesses\">\n <mat-option\n *ngIf=\"access.value === 0 || permission.accesses.indexOf(access.value) !== -1\"\n [value]=\"access.value\">\n {{ access.name }}\n </mat-option>\n </ng-container>\n </mat-select>\n </mat-form-field>\n </ng-template>\n </ng-template>\n </fs-list-column>\n </fs-list>\n </div>\n </div>\n </mat-dialog-content>\n <mat-dialog-actions>\n <button mat-button type=\"submit\" color=\"primary\">{{ aclRole.id ? 'Save' : 'Create' }}</button>\n <button mat-button [mat-dialog-close]=\"null\" type=\"button\">Cancel</button>\n </mat-dialog-actions>\n </ng-container>\n </fs-dialog>\n</form>\n",
182
+ changeDetection: ChangeDetectionStrategy.OnPush,
183
+ styles: [":host .permissions ::ng-deep .fs-list-row-group{background-color:#f6f6f6}:host .permissions ::ng-deep fs-list .access{white-space:nowrap}:host .permissions ::ng-deep .mat-form-field{width:100px}:host .permissions ::ng-deep .mat-form-field .mat-form-field-wrapper{padding-bottom:0}:host .permissions ::ng-deep .mat-form-field .mat-form-field-infix{border-top:0}:host .permissions ::ng-deep .mat-form-field .mat-form-field-underline{bottom:0}:host ::ng-deep fs-radio-group{width:100%}:host ::ng-deep fs-label-field{width:100%}:host .level{width:100%}"]
184
+ }),
185
+ __param(3, Inject(MAT_DIALOG_DATA)),
186
+ __metadata("design:paramtypes", [FsAppAclService,
187
+ MatDialogRef,
188
+ FsMessage, Object, ChangeDetectorRef])
189
+ ], FsAclRoleComponent);
190
+ export { FsAclRoleComponent };
191
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"acl-role.component.js","sourceRoot":"ng://@firestitch/app-acl/","sources":["app/components/acl-role/acl-role.component.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,MAAM,EACN,SAAS,EACT,MAAM,EACN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAEzE,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AAEnE,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAErD,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAgB,MAAM,kBAAkB,CAAC;AAEjE,OAAO,EAAE,QAAQ,EAAc,EAAE,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAQnD,IAAa,kBAAkB,GAA/B,MAAa,kBAAkB;IAoB7B,YACmB,cAA+B,EAC/B,UAA4C,EAC5C,QAAmB,EACM,KAAU,EAC5C,MAAyB;QAJhB,mBAAc,GAAd,cAAc,CAAiB;QAC/B,eAAU,GAAV,UAAU,CAAkC;QAC5C,aAAQ,GAAR,QAAQ,CAAW;QACM,UAAK,GAAL,KAAK,CAAK;QAC5C,WAAM,GAAN,MAAM,CAAmB;QArB5B,YAAO,GAAY,IAAI,CAAC;QAExB,gBAAW,GAAU,EAAE,CAAC;QAExB,qBAAgB,GAAG,EAAE,CAAC;QACtB,oBAAe,GAAG,eAAe,CAAC;QAClC,oBAAe,GAAG,EAAE,CAAC;QACrB,cAAS,GAAU,EAAE,CAAC;QACtB,qBAAgB,GAAG,EAAE,CAAC;QACtB,mBAAc,GAAG,KAAK,CAAC;QACvB,cAAS,GAAG,EAAE,CAAC;QACf,mBAAc,GAAG,EAAE,CAAC;QACpB,wBAAmB,GAAG,EAAE,CAAC;QAExB,cAAS,GAAG,IAAI,OAAO,EAAE,CAAC;QA6H3B,SAAI,GAAG,GAAoB,EAAE;YAClC,MAAM,OAAO,mCACR,IAAI,CAAC,OAAO,KACf,WAAW,EAAE,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE;oBACpD,OAAO;wBACL,KAAK,EAAE,UAAU,CAAC,KAAK;wBACvB,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC;qBACxD,CAAC;gBACJ,CAAC,CAAC,EACF,cAAc,EAAE,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;oBACpD,OAAO;wBACL,EAAE,EAAE,IAAI,CAAC,EAAE;wBACX,KAAK,EAAE,IAAI,CAAC,KAAK;wBACjB,IAAI,EAAE,IAAI,CAAC,IAAI;qBAChB,CAAC;gBACJ,CAAC,CAAC,GACH,CAAC;YAEF,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;iBAC/D,IAAI,CACH,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;gBACf,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;gBACvC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YACvB,CAAC,CAAC,CACH,CAAC;QACN,CAAC,CAAA;IA9IE,CAAC;IAEG,QAAQ;QACb,QAAQ,CACN,IAAI,CAAC,OAAO,EAAE,EACd,IAAI,CAAC,cAAc,CAAC,cAAc,EAAE,CACrC;aACE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,CAAC,CACV,OAAO,EACP,cAAc,EACf,EAAE,EAAE;YAEH,IAAI,CAAC,WAAW,GAAG,cAAc,CAAC;YAClC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;YAEtC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;YAC9D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;YAE9D,IAAI,CAAC,OAAO,iBACP;gBACD,cAAc,EAAE,EAAE;gBAClB,cAAc,EAAE,IAAI;gBACpB,cAAc,EAAE,EAAE;gBAClB,WAAW,EAAE,EAAE;gBACf,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK;aAC/B,EACE,OAAO,CACX,CAAC;YAEF,IAAI,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE;gBACnB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE;oBACtC,IAAI,MAAM,GAAG,CAAC,CAAC;oBAEf,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;wBAC9D,OAAO,IAAI,CAAC,UAAU,KAAK,UAAU,CAAC,KAAK,CAAC;oBAC9C,CAAC,CAAC,CAAC;oBAEH,IAAI,aAAa,EAAE;wBACjB,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC;qBAC/B;oBAED,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC;gBACtD,CAAC,CAAC,CAAC;aACJ;YAED,IAAI,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE;gBAC/B,IAAI,CAAC,yBAAyB,EAAE,CAAC;aAClC;YAED,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAE7B,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,UAAU,GAAG;YAChB,MAAM,EAAE,KAAK;YACb,MAAM,EAAE,KAAK;YACb,SAAS,EAAE;gBACT,OAAO,EAAE,EAAE;aACZ;YACD,KAAK,EAAE;gBACL,aAAa,EAAE,IAAI;gBACnB,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE;oBAChB,OAAO,IAAI,CAAC;gBACd,CAAC;gBACD,SAAS,EAAE,CAAC,IAAI,EAAE,EAAE;oBAClB,OAAO,IAAI,CAAC,QAAQ,IAAI,SAAS,CAAC;gBACpC,CAAC;aACF;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,OAAO,EAAE,CAAC;oBACR,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;wBACxC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;wBACzB,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;wBACzB,IAAI,CAAC,GAAG,CAAC,EAAE;4BACT,OAAO,CAAC,CAAC,CAAC;yBACX;6BAAM,IAAI,CAAC,GAAG,CAAC,EAAE;4BAChB,OAAO,CAAC,CAAC;yBACV;wBAED,OAAO,CAAC,CAAC;oBACX,CAAC,CAAC;iBACH,CAAC,CAAC;YACL,CAAC;SACF,CAAC;IACJ,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,OAAO;QACZ,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,EAAE;YAC1B,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;SAC/B;QAED,MAAM,KAAK,GAAQ;YACjB,cAAc,EAAE,IAAI;YACpB,cAAc,EAAE,IAAI;SACrB,CAAC;QAEF,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACrB,KAAK,CAAC,aAAa,GAAG,IAAI,CAAC;SAC5B;QAED,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC;aACrD,IAAI,CACH,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAC/C,CAAC;IACN,CAAC;IA6BM,KAAK,CAAC,OAAY,IAAI;QAC3B,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAEM,oBAAoB,CAAC,GAAY;QACtC,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,GAAG,EAAE;YACP,IAAI,CAAC,yBAAyB,EAAE,CAAC;SAClC;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,UAAU,EAAE,EAAE;YAC7D,OAAO,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;gBACrC,OAAO,IAAI,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;YACrC,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;YAC7D,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC;QAC3C,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,yBAAyB;QAC/B,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE;YACtC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAC;QAChF,CAAC,CAAC,CAAC;IACL,CAAC;CAEF,CAAA;;YAzLoC,eAAe;YACnB,YAAY;YACd,SAAS;4CACnC,MAAM,SAAC,eAAe;YACP,iBAAiB;;AAvBP;IAA3B,SAAS,CAAC,eAAe,CAAC;8BAAc,eAAe;gDAAC;AAF9C,kBAAkB;IAL9B,SAAS,CAAC;QACT,05KAAwC;QAExC,eAAe,EAAE,uBAAuB,CAAC,MAAM;;KAChD,CAAC;IAyBG,WAAA,MAAM,CAAC,eAAe,CAAC,CAAA;qCAHS,eAAe;QACnB,YAAY;QACd,SAAS,UAEpB,iBAAiB;GAzBxB,kBAAkB,CA8M9B;SA9MY,kBAAkB","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  OnDestroy,\n  OnInit,\n  ViewChild\n} from '@angular/core';\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\n\nimport { AclRoleAccesses } from './../../consts/acl-role-accesses';\nimport { AclRole } from './../../interfaces';\nimport { map, takeUntil, tap } from 'rxjs/operators';\n\nimport { FsMessage } from '@firestitch/message';\nimport { list } from '@firestitch/common';\nimport { FsListComponent, FsListConfig } from '@firestitch/list';\n\nimport { forkJoin, Observable, of, Subject } from 'rxjs';\nimport { FsAppAclService } from './../../services';\n\n\n@Component({\n  templateUrl: './acl-role.component.html',\n  styleUrls: ['./acl-role.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FsAclRoleComponent implements OnInit, OnDestroy {\n\n  @ViewChild(FsListComponent) public list: FsListComponent;\n\n  public aclRole: AclRole = null;\n  public environment;\n  public permissions: any[] = [];\n  public listConfig: FsListConfig;\n  public levelPermissions = [];\n  public AclRoleAccesses = AclRoleAccesses;\n  public indexedAccesses = {};\n  public aclLevels: any[] = [];\n  public indexedAclLevels = {};\n  public onlyFullAccess = false;\n  public AclLevels = {};\n  public aclRoleConfigs = [];\n  public levelAclRoleConfigs = [];\n\n  private _destroy$ = new Subject();\n\n  constructor(\n    private readonly _appAclService: FsAppAclService,\n    private readonly _dialogRef: MatDialogRef<FsAclRoleComponent>,\n    private readonly _message: FsMessage,\n    @Inject(MAT_DIALOG_DATA) private readonly _data: any,\n    private _cdRef: ChangeDetectorRef,\n  ) {}\n\n  public ngOnInit(): void {\n    forkJoin(\n      this.getRole(),\n      this._appAclService.getPermissions(),\n    )\n      .pipe(takeUntil(this._destroy$))\n      .subscribe(([\n        aclRole,\n        aclPermissions,\n      ]) => {\n\n        this.permissions = aclPermissions;\n        this.aclLevels = this._data.aclLevels;\n\n        this.indexedAclLevels = list(this.aclLevels, 'name', 'value');\n        this.indexedAccesses = list(AclRoleAccesses, 'name', 'value');\n\n        this.aclRole = {\n          ...{\n            aclPermissions: [],\n            allPermissions: true,\n            aclRoleConfigs: [],\n            permissions: {},\n            level: this.aclLevels[0].value,\n          },\n          ...aclRole,\n        };\n\n        if (this.aclRole.id) {\n          this.permissions.forEach((permission) => {\n            let access = 0;\n\n            const aclPermission = this.aclRole.aclPermissions.find((item) => {\n              return item.permission === permission.value;\n            });\n\n            if (aclPermission) {\n              access = aclPermission.access;\n            }\n\n            this.aclRole.permissions[permission.value] = access;\n          });\n        }\n\n        if (this.aclRole.allPermissions) {\n          this._applyMaxPermissionAccess();\n        }\n\n        this._updatePermissions();\n        this._updateAclRoleConfigs();\n\n        this._cdRef.markForCheck();\n      });\n\n    this.listConfig = {\n      status: false,\n      paging: false,\n      noResults: {\n        message: '',\n      },\n      group: {\n        initialExpand: true,\n        groupBy: (data) => {\n          return data;\n        },\n        compareBy: (data) => {\n          return data.category || 'General';\n        },\n      },\n      fetch: () => {\n        return of({\n          data: this.levelPermissions.sort((a, b) => {\n            a = a.name.toUpperCase();\n            b = b.name.toUpperCase();\n            if (a < b) {\n              return -1;\n            } else if (a > b) {\n              return 1;\n            }\n\n            return 0;\n          }),\n        });\n      },\n    };\n  }\n\n  public levelChange(): void {\n    this._updatePermissions();\n    this._updateAclRoleConfigs();\n    setTimeout(() => {\n      this.list.reload();\n    });\n  }\n\n  public getRole(): Observable<any> {\n    if (!this._data.aclRole.id) {\n      return of(this._data.aclRole);\n    }\n\n    const query: any = {\n      aclPermissions: true,\n      aclRoleConfigs: true,\n    };\n\n    if (!this.environment) {\n      query.environmentId = null;\n    }\n\n    return this._data.loadAclRole(this._data.aclRole, query)\n      .pipe(\n        map((data) => this._appAclService.input(data)),\n      );\n  }\n\n  public save = (): Observable<any> => {\n    const aclRole = {\n      ...this.aclRole,\n      permissions: this.levelPermissions.map((permission) => {\n        return {\n          value: permission.value,\n          access: this.aclRole.permissions[permission.value] || 0,\n        };\n      }),\n      aclRoleConfigs: this.levelAclRoleConfigs.map((item) => {\n        return {\n          id: item.id,\n          value: item.value,\n          data: item.data,\n        };\n      }),\n    };\n\n    return this._data.saveAclRole(this._appAclService.output(aclRole))\n      .pipe(\n        tap((response) => {\n          this._message.success('Saved Changes');\n          this.close(response);\n        }),\n      );\n  }\n\n  public close(data: any = null): void {\n    this._dialogRef.close(data);\n  }\n\n  public allPermissionsChange(all: boolean): void {\n    this._updatePermissions();\n    if (all) {\n      this._applyMaxPermissionAccess();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  private _updatePermissions(): void {\n    this.levelPermissions = this.permissions.filter((permission) => {\n      return permission.levels.some((item) => {\n        return item === this.aclRole.level;\n      });\n    });\n  }\n\n  private _updateAclRoleConfigs(): void {\n    this.levelAclRoleConfigs = this.aclRoleConfigs.filter((item) => {\n      return this.aclRole.level === item.level;\n    });\n  }\n\n  private _applyMaxPermissionAccess(): void {\n    this.permissions.forEach((permission) => {\n      this.aclRole.permissions[permission.value] = Math.max(...permission.accesses);\n    });\n  }\n\n}\n"]}
@@ -1,41 +1,41 @@
1
- import { __decorate, __metadata } from "tslib";
2
- import { Component, Input } from '@angular/core';
3
- import { FsAppAclService } from './../../services';
4
- let FsAclRolePopoverComponent = class FsAclRolePopoverComponent {
5
- constructor(_appAclService) {
6
- this._appAclService = _appAclService;
7
- this.permissions = [];
8
- }
9
- ngOnInit() {
10
- const aclRolePermissions = this.aclRole.permissions || [];
11
- this._appAclService.getPermissions()
12
- .subscribe((response) => {
13
- this.permissions = response.filter(item => {
14
- return aclRolePermissions.some(permission => {
15
- return item.value === permission.value;
16
- });
17
- });
18
- });
19
- }
20
- };
21
- FsAclRolePopoverComponent.ctorParameters = () => [
22
- { type: FsAppAclService }
23
- ];
24
- __decorate([
25
- Input(),
26
- __metadata("design:type", Object)
27
- ], FsAclRolePopoverComponent.prototype, "aclRole", void 0);
28
- __decorate([
29
- Input(),
30
- __metadata("design:type", Object)
31
- ], FsAclRolePopoverComponent.prototype, "objectName", void 0);
32
- FsAclRolePopoverComponent = __decorate([
33
- Component({
34
- selector: 'fs-acl-role-popover',
35
- template: "\n<fs-popover [template]=\"popover\" maxWidth=\"400\">\n <ng-content></ng-content>\n</fs-popover>\n\n<ng-template #popover>\n <div class=\"name small\">{{aclRole.name}}<span *ngIf=\"objectName\">: {{objectName}}</span></div>\n\n <ng-container *ngIf=\"permissions.length; else nonePermission\">\n <div *ngFor=\"let permission of permissions\" class=\"permission\">\n <div>{{permission.name}}</div>\n <div class=\"small\">{{permission.description}}</div>\n </div>\n </ng-container>\n\n <ng-template #nonePermission>\n None\n </ng-template>\n</ng-template>\n",
36
- styles: [".name{padding-bottom:10px}.permission+.permission{padding-top:5px}:host{cursor:pointer}"]
37
- }),
38
- __metadata("design:paramtypes", [FsAppAclService])
39
- ], FsAclRolePopoverComponent);
40
- export { FsAclRolePopoverComponent };
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { Component, Input } from '@angular/core';
3
+ import { FsAppAclService } from './../../services';
4
+ let FsAclRolePopoverComponent = class FsAclRolePopoverComponent {
5
+ constructor(_appAclService) {
6
+ this._appAclService = _appAclService;
7
+ this.permissions = [];
8
+ }
9
+ ngOnInit() {
10
+ const aclRolePermissions = this.aclRole.permissions || [];
11
+ this._appAclService.getPermissions()
12
+ .subscribe((response) => {
13
+ this.permissions = response.filter(item => {
14
+ return aclRolePermissions.some(permission => {
15
+ return item.value === permission.value;
16
+ });
17
+ });
18
+ });
19
+ }
20
+ };
21
+ FsAclRolePopoverComponent.ctorParameters = () => [
22
+ { type: FsAppAclService }
23
+ ];
24
+ __decorate([
25
+ Input(),
26
+ __metadata("design:type", Object)
27
+ ], FsAclRolePopoverComponent.prototype, "aclRole", void 0);
28
+ __decorate([
29
+ Input(),
30
+ __metadata("design:type", Object)
31
+ ], FsAclRolePopoverComponent.prototype, "objectName", void 0);
32
+ FsAclRolePopoverComponent = __decorate([
33
+ Component({
34
+ selector: 'fs-acl-role-popover',
35
+ template: "\n<fs-popover [template]=\"popover\" maxWidth=\"400\">\n <ng-content></ng-content>\n</fs-popover>\n\n<ng-template #popover>\n <div class=\"name small\">{{aclRole.name}}<span *ngIf=\"objectName\">: {{objectName}}</span></div>\n\n <ng-container *ngIf=\"permissions.length; else nonePermission\">\n <div *ngFor=\"let permission of permissions\" class=\"permission\">\n <div>{{permission.name}}</div>\n <div class=\"small\">{{permission.description}}</div>\n </div>\n </ng-container>\n\n <ng-template #nonePermission>\n None\n </ng-template>\n</ng-template>\n",
36
+ styles: [".name{padding-bottom:10px}.permission+.permission{padding-top:5px}:host{cursor:pointer}"]
37
+ }),
38
+ __metadata("design:paramtypes", [FsAppAclService])
39
+ ], FsAclRolePopoverComponent);
40
+ export { FsAclRolePopoverComponent };
41
41
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNsLXJvbGUtcG9wb3Zlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AZmlyZXN0aXRjaC9hcHAtYWNsLyIsInNvdXJjZXMiOlsiYXBwL2NvbXBvbmVudHMvYWNsLXJvbGUtcG9wb3Zlci9hY2wtcm9sZS1wb3BvdmVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBT25ELElBQWEseUJBQXlCLEdBQXRDLE1BQWEseUJBQXlCO0lBT3BDLFlBQ21CLGNBQStCO1FBQS9CLG1CQUFjLEdBQWQsY0FBYyxDQUFpQjtRQUgzQyxnQkFBVyxHQUFHLEVBQUUsQ0FBQztJQUlyQixDQUFDO0lBRUcsUUFBUTtRQUNiLE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLElBQUksRUFBRSxDQUFDO1FBRTFELElBQUksQ0FBQyxjQUFjLENBQUMsY0FBYyxFQUFFO2FBQ2pDLFNBQVMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxFQUFFO1lBQ3RCLElBQUksQ0FBQyxXQUFXLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRTtnQkFDeEMsT0FBTyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUU7b0JBQzFDLE9BQU8sSUFBSSxDQUFDLEtBQUssS0FBSyxVQUFVLENBQUMsS0FBSyxDQUFDO2dCQUN6QyxDQUFDLENBQUMsQ0FBQztZQUNQLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0YsQ0FBQTs7WUFmb0MsZUFBZTs7QUFOekM7SUFBUixLQUFLLEVBQUU7OzBEQUFTO0FBQ1I7SUFBUixLQUFLLEVBQUU7OzZEQUFZO0FBSFQseUJBQXlCO0lBTHJDLFNBQVMsQ0FBQztRQUNULFFBQVEsRUFBRSxxQkFBcUI7UUFDL0IsZ2xCQUFnRDs7S0FFakQsQ0FBQztxQ0FTbUMsZUFBZTtHQVJ2Qyx5QkFBeUIsQ0F1QnJDO1NBdkJZLHlCQUF5QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRnNBcHBBY2xTZXJ2aWNlIH0gZnJvbSAnLi8uLi8uLi9zZXJ2aWNlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2ZzLWFjbC1yb2xlLXBvcG92ZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vYWNsLXJvbGUtcG9wb3Zlci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2FjbC1yb2xlLXBvcG92ZXIuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBGc0FjbFJvbGVQb3BvdmVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBASW5wdXQoKSBhY2xSb2xlO1xuICBASW5wdXQoKSBvYmplY3ROYW1lO1xuXG4gIHB1YmxpYyBwZXJtaXNzaW9ucyA9IFtdO1xuXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IF9hcHBBY2xTZXJ2aWNlOiBGc0FwcEFjbFNlcnZpY2UsXG4gICkge31cblxuICBwdWJsaWMgbmdPbkluaXQoKSB7XG4gICAgY29uc3QgYWNsUm9sZVBlcm1pc3Npb25zID0gdGhpcy5hY2xSb2xlLnBlcm1pc3Npb25zIHx8IFtdO1xuXG4gICAgdGhpcy5fYXBwQWNsU2VydmljZS5nZXRQZXJtaXNzaW9ucygpXG4gICAgICAuc3Vic2NyaWJlKChyZXNwb25zZSkgPT4ge1xuICAgICAgICB0aGlzLnBlcm1pc3Npb25zID0gcmVzcG9uc2UuZmlsdGVyKGl0ZW0gPT4ge1xuICAgICAgICAgIHJldHVybiBhY2xSb2xlUGVybWlzc2lvbnMuc29tZShwZXJtaXNzaW9uID0+IHtcbiAgICAgICAgICAgIHJldHVybiBpdGVtLnZhbHVlID09PSBwZXJtaXNzaW9uLnZhbHVlO1xuICAgICAgICAgIH0pO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==