@firestitch/app-acl 13.0.0 → 14.0.0

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 (65) hide show
  1. package/app/components/acl-entries/acl-entries.component.d.ts +33 -33
  2. package/app/components/acl-entry/acl-entry.component.d.ts +31 -31
  3. package/app/components/acl-object-roles/acl-object-roles.component.d.ts +18 -18
  4. package/app/components/acl-permission-popover/acl-permission-popover.component.d.ts +12 -12
  5. package/app/components/acl-role/acl-role.component.d.ts +56 -56
  6. package/app/components/acl-role-popover/acl-role-popover.component.d.ts +13 -13
  7. package/app/components/acl-roles/acl-roles.component.d.ts +38 -38
  8. package/app/consts/acl-role-accesses.d.ts +5 -5
  9. package/app/enums/acl-role-access.d.ts +6 -6
  10. package/app/fs-app-acl.module.d.ts +33 -33
  11. package/app/injectors/app-acl-config.injector.d.ts +2 -2
  12. package/app/interfaces/acl-entry-data.d.ts +11 -11
  13. package/app/interfaces/acl-entry.d.ts +18 -18
  14. package/app/interfaces/acl-level.d.ts +3 -3
  15. package/app/interfaces/acl-object-entry.d.ts +11 -11
  16. package/app/interfaces/acl-object-role.d.ts +6 -6
  17. package/app/interfaces/acl-object.d.ts +4 -4
  18. package/app/interfaces/acl-permission.d.ts +7 -7
  19. package/app/interfaces/acl-role-config.d.ts +5 -5
  20. package/app/interfaces/acl-role.d.ts +16 -16
  21. package/app/interfaces/app-acl-config.d.ts +7 -7
  22. package/app/interfaces/index.d.ts +2 -2
  23. package/app/interfaces/name-value.d.ts +4 -4
  24. package/app/interfaces/role-config.d.ts +12 -12
  25. package/app/pipes/acl-role-permission-available.pipe.d.ts +7 -7
  26. package/app/pipes/bulk-options-filter.pipe.d.ts +13 -13
  27. package/app/pipes/index.d.ts +2 -2
  28. package/app/services/app-acl.service.d.ts +16 -16
  29. package/esm2020/app/components/acl-entries/acl-entries.component.mjs +173 -173
  30. package/esm2020/app/components/acl-entry/acl-entry.component.mjs +92 -92
  31. package/esm2020/app/components/acl-object-roles/acl-object-roles.component.mjs +52 -52
  32. package/esm2020/app/components/acl-permission-popover/acl-permission-popover.component.mjs +28 -28
  33. package/esm2020/app/components/acl-role/acl-role.component.mjs +253 -253
  34. package/esm2020/app/components/acl-role-popover/acl-role-popover.component.mjs +33 -33
  35. package/esm2020/app/components/acl-roles/acl-roles.component.mjs +169 -169
  36. package/esm2020/app/consts/acl-role-accesses.mjs +7 -7
  37. package/esm2020/app/enums/acl-role-access.mjs +7 -7
  38. package/esm2020/app/fs-app-acl.module.mjs +127 -129
  39. package/esm2020/app/injectors/app-acl-config.injector.mjs +2 -2
  40. package/esm2020/app/interfaces/acl-entry-data.mjs +1 -1
  41. package/esm2020/app/interfaces/acl-entry.mjs +1 -1
  42. package/esm2020/app/interfaces/acl-level.mjs +1 -1
  43. package/esm2020/app/interfaces/acl-object-entry.mjs +1 -1
  44. package/esm2020/app/interfaces/acl-object-role.mjs +1 -1
  45. package/esm2020/app/interfaces/acl-object.mjs +1 -1
  46. package/esm2020/app/interfaces/acl-permission.mjs +1 -1
  47. package/esm2020/app/interfaces/acl-role-config.mjs +1 -1
  48. package/esm2020/app/interfaces/acl-role.mjs +1 -1
  49. package/esm2020/app/interfaces/app-acl-config.mjs +1 -1
  50. package/esm2020/app/interfaces/index.mjs +2 -2
  51. package/esm2020/app/interfaces/name-value.mjs +1 -1
  52. package/esm2020/app/interfaces/role-config.mjs +1 -1
  53. package/esm2020/app/pipes/acl-role-permission-available.pipe.mjs +20 -20
  54. package/esm2020/app/pipes/bulk-options-filter.pipe.mjs +26 -26
  55. package/esm2020/app/pipes/index.mjs +2 -2
  56. package/esm2020/app/services/app-acl.service.mjs +50 -50
  57. package/esm2020/firestitch-app-acl.mjs +4 -4
  58. package/esm2020/public_api.mjs +10 -10
  59. package/fesm2015/firestitch-app-acl.mjs +887 -889
  60. package/fesm2015/firestitch-app-acl.mjs.map +1 -1
  61. package/fesm2020/firestitch-app-acl.mjs +900 -902
  62. package/fesm2020/firestitch-app-acl.mjs.map +1 -1
  63. package/{firestitch-app-acl.d.ts → index.d.ts} +5 -5
  64. package/package.json +3 -3
  65. package/public_api.d.ts +20 -20
@@ -1,7 +1,7 @@
1
- export interface AclPermission {
2
- value: string;
3
- name: string;
4
- levels: string[];
5
- accesses: number[];
6
- description: string;
7
- }
1
+ export interface AclPermission {
2
+ value: string;
3
+ name: string;
4
+ levels: string[];
5
+ accesses: number[];
6
+ description: string;
7
+ }
@@ -1,5 +1,5 @@
1
- export interface AclRoleConfig {
2
- id?: number;
3
- name?: any;
4
- value?: any;
5
- }
1
+ export interface AclRoleConfig {
2
+ id?: number;
3
+ name?: any;
4
+ value?: any;
5
+ }
@@ -1,16 +1,16 @@
1
- import { AclRoleConfig } from './acl-role-config';
2
- export interface AclRole {
3
- id?: number;
4
- name?: string;
5
- description?: string;
6
- state?: string;
7
- reference?: string;
8
- allPermissions?: boolean;
9
- role?: string;
10
- level?: string;
11
- permissions?: any;
12
- access?: string;
13
- protected?: boolean;
14
- aclPermissions?: any;
15
- aclRoleConfigs?: AclRoleConfig[];
16
- }
1
+ import { AclRoleConfig } from './acl-role-config';
2
+ export interface AclRole {
3
+ id?: number;
4
+ name?: string;
5
+ description?: string;
6
+ state?: string;
7
+ reference?: string;
8
+ allPermissions?: boolean;
9
+ role?: string;
10
+ level?: string;
11
+ permissions?: any;
12
+ access?: string;
13
+ protected?: boolean;
14
+ aclPermissions?: any;
15
+ aclRoleConfigs?: AclRoleConfig[];
16
+ }
@@ -1,7 +1,7 @@
1
- import { Observable } from 'rxjs';
2
- import { AclLevel } from './acl-level';
3
- export interface AppAclConfig {
4
- permissions: Observable<any[]>;
5
- levels: Observable<AclLevel[]>;
6
- case: 'snake' | 'camel';
7
- }
1
+ import { Observable } from 'rxjs';
2
+ import { AclLevel } from './acl-level';
3
+ export interface AppAclConfig {
4
+ permissions: Observable<any[]>;
5
+ levels: Observable<AclLevel[]>;
6
+ case: 'snake' | 'camel';
7
+ }
@@ -1,2 +1,2 @@
1
- export * from './app-acl-config';
2
- export * from './role-config';
1
+ export * from './app-acl-config';
2
+ export * from './role-config';
@@ -1,4 +1,4 @@
1
- export interface NameValue {
2
- name: string;
3
- value: any;
4
- }
1
+ export interface NameValue {
2
+ name: string;
3
+ value: any;
4
+ }
@@ -1,12 +1,12 @@
1
- export interface RoleConfig {
2
- name?: string;
3
- description?: string;
4
- type?: 'checkbox' | 'select';
5
- values?: {
6
- name: string;
7
- value: string;
8
- }[];
9
- required?: boolean;
10
- level?: string;
11
- label?: string;
12
- }
1
+ export interface RoleConfig {
2
+ name?: string;
3
+ description?: string;
4
+ type?: 'checkbox' | 'select';
5
+ values?: {
6
+ name: string;
7
+ value: string;
8
+ }[];
9
+ required?: boolean;
10
+ level?: string;
11
+ label?: string;
12
+ }
@@ -1,7 +1,7 @@
1
- import { PipeTransform } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export declare class AclRolePermissionAvailablePipe implements PipeTransform {
4
- transform(permission: any, aclRolePermissions: any): boolean;
5
- static ɵfac: i0.ɵɵFactoryDeclaration<AclRolePermissionAvailablePipe, never>;
6
- static ɵpipe: i0.ɵɵPipeDeclaration<AclRolePermissionAvailablePipe, "aclRolePermissionAvailable">;
7
- }
1
+ import { PipeTransform } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class AclRolePermissionAvailablePipe implements PipeTransform {
4
+ transform(permission: any, aclRolePermissions: any): boolean;
5
+ static ɵfac: i0.ɵɵFactoryDeclaration<AclRolePermissionAvailablePipe, never>;
6
+ static ɵpipe: i0.ɵɵPipeDeclaration<AclRolePermissionAvailablePipe, "aclRolePermissionAvailable", false>;
7
+ }
@@ -1,13 +1,13 @@
1
- import { PipeTransform } from '@angular/core';
2
- import { AclRoleAccess } from '../enums/acl-role-access';
3
- import { AclPermission } from '../interfaces/acl-permission';
4
- import * as i0 from "@angular/core";
5
- export declare class BulkOptionsFilterPipe implements PipeTransform {
6
- transform(rolesList: {
7
- name: string;
8
- value: AclRoleAccess;
9
- }[], children: AclPermission[]): any;
10
- private _uniqListOfAccessLevels;
11
- static ɵfac: i0.ɵɵFactoryDeclaration<BulkOptionsFilterPipe, never>;
12
- static ɵpipe: i0.ɵɵPipeDeclaration<BulkOptionsFilterPipe, "builkOptionsFilter">;
13
- }
1
+ import { PipeTransform } from '@angular/core';
2
+ import { AclRoleAccess } from '../enums/acl-role-access';
3
+ import { AclPermission } from '../interfaces/acl-permission';
4
+ import * as i0 from "@angular/core";
5
+ export declare class BulkOptionsFilterPipe implements PipeTransform {
6
+ transform(rolesList: {
7
+ name: string;
8
+ value: AclRoleAccess;
9
+ }[], children: AclPermission[]): any;
10
+ private _uniqListOfAccessLevels;
11
+ static ɵfac: i0.ɵɵFactoryDeclaration<BulkOptionsFilterPipe, never>;
12
+ static ɵpipe: i0.ɵɵPipeDeclaration<BulkOptionsFilterPipe, "builkOptionsFilter", false>;
13
+ }
@@ -1,2 +1,2 @@
1
- export * from './acl-role-permission-available.pipe';
2
- export * from './bulk-options-filter.pipe';
1
+ export * from './acl-role-permission-available.pipe';
2
+ export * from './bulk-options-filter.pipe';
@@ -1,16 +1,16 @@
1
- import { ReplaySubject } from 'rxjs';
2
- import { AppAclConfig } from './../interfaces/app-acl-config';
3
- import { AclPermission } from './../interfaces/acl-permission';
4
- import { AclLevel } from './../interfaces/acl-level';
5
- import * as i0 from "@angular/core";
6
- export declare class FsAppAclService {
7
- private _appAclConfig;
8
- private _permissions$;
9
- private _levels$;
10
- constructor(_appAclConfig: AppAclConfig);
11
- getPermissions(): ReplaySubject<AclPermission[]>;
12
- getLevels(): ReplaySubject<AclLevel[]>;
13
- getIndexedLevels(): import("rxjs").Observable<any>;
14
- static ɵfac: i0.ɵɵFactoryDeclaration<FsAppAclService, never>;
15
- static ɵprov: i0.ɵɵInjectableDeclaration<FsAppAclService>;
16
- }
1
+ import { ReplaySubject } from 'rxjs';
2
+ import { AppAclConfig } from './../interfaces/app-acl-config';
3
+ import { AclPermission } from './../interfaces/acl-permission';
4
+ import { AclLevel } from './../interfaces/acl-level';
5
+ import * as i0 from "@angular/core";
6
+ export declare class FsAppAclService {
7
+ private _appAclConfig;
8
+ private _permissions$;
9
+ private _levels$;
10
+ constructor(_appAclConfig: AppAclConfig);
11
+ getPermissions(): ReplaySubject<AclPermission[]>;
12
+ getLevels(): ReplaySubject<AclLevel[]>;
13
+ getIndexedLevels(): import("rxjs").Observable<any>;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<FsAppAclService, never>;
15
+ static ɵprov: i0.ɵɵInjectableDeclaration<FsAppAclService>;
16
+ }
@@ -1,176 +1,176 @@
1
- import { takeUntil } from 'rxjs/operators';
2
- import { Component, ViewChild, Input } from '@angular/core';
3
- import { MatDialog } from '@angular/material/dialog';
4
- import { Subject, Observable } from 'rxjs';
5
- import { sortBy, groupBy } from 'lodash-es';
6
- import { FsListComponent } from '@firestitch/list';
7
- import { FsPrompt } from '@firestitch/prompt';
8
- import { FsAppAclService } from '../../services/app-acl.service';
9
- import { FsAclEntryComponent } from '../acl-entry/acl-entry.component';
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "../../services/app-acl.service";
12
- import * as i2 from "@angular/material/dialog";
13
- import * as i3 from "@firestitch/prompt";
14
- import * as i4 from "@firestitch/list";
15
- import * as i5 from "@firestitch/badge";
16
- import * as i6 from "../acl-role-popover/acl-role-popover.component";
17
- import * as i7 from "@angular/common";
18
- export class FsAclEntriesComponent {
19
- constructor(_appAclService, _dialog, _confirm) {
20
- this._appAclService = _appAclService;
21
- this._dialog = _dialog;
22
- this._confirm = _confirm;
23
- this.environmentShow = true;
24
- this.environmentLabel = 'Environment';
25
- this.environmentKey = 'environment';
26
- this.actions = [];
27
- this.aclEntriesList = null;
28
- this.aclEntriesConfig = null;
29
- this.permissions = [];
30
- this._destroy$ = new Subject();
31
- }
32
- ngOnInit() {
33
- this._appAclService.getPermissions()
34
- .subscribe(response => {
35
- this.permissions = response;
36
- });
37
- this.aclEntriesConfig = {
38
- status: false,
39
- paging: false,
40
- actions: this.actions,
41
- rowActions: [
42
- {
43
- label: 'Remove All Roles',
44
- click: (aclObjectEntry) => {
45
- this._confirm
46
- .confirm({
47
- title: 'Remove All Roles',
48
- commitLabel: 'Save',
1
+ import { takeUntil } from 'rxjs/operators';
2
+ import { Component, ViewChild, Input } from '@angular/core';
3
+ import { MatDialog } from '@angular/material/dialog';
4
+ import { Subject, Observable } from 'rxjs';
5
+ import { sortBy, groupBy } from 'lodash-es';
6
+ import { FsListComponent } from '@firestitch/list';
7
+ import { FsPrompt } from '@firestitch/prompt';
8
+ import { FsAppAclService } from '../../services/app-acl.service';
9
+ import { FsAclEntryComponent } from '../acl-entry/acl-entry.component';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "../../services/app-acl.service";
12
+ import * as i2 from "@angular/material/dialog";
13
+ import * as i3 from "@firestitch/prompt";
14
+ import * as i4 from "@angular/common";
15
+ import * as i5 from "@firestitch/list";
16
+ import * as i6 from "@firestitch/badge";
17
+ import * as i7 from "../acl-role-popover/acl-role-popover.component";
18
+ export class FsAclEntriesComponent {
19
+ constructor(_appAclService, _dialog, _confirm) {
20
+ this._appAclService = _appAclService;
21
+ this._dialog = _dialog;
22
+ this._confirm = _confirm;
23
+ this.environmentShow = true;
24
+ this.environmentLabel = 'Environment';
25
+ this.environmentKey = 'environment';
26
+ this.actions = [];
27
+ this.aclEntriesList = null;
28
+ this.aclEntriesConfig = null;
29
+ this.permissions = [];
30
+ this._destroy$ = new Subject();
31
+ }
32
+ ngOnInit() {
33
+ this._appAclService.getPermissions()
34
+ .subscribe(response => {
35
+ this.permissions = response;
36
+ });
37
+ this.aclEntriesConfig = {
38
+ status: false,
39
+ paging: false,
40
+ actions: this.actions,
41
+ rowActions: [
42
+ {
43
+ label: 'Remove All Roles',
44
+ click: (aclObjectEntry) => {
45
+ this._confirm
46
+ .confirm({
47
+ title: 'Remove All Roles',
48
+ commitLabel: 'Save',
49
49
  template: `Please note that removing roles may prevent users from being able to successfully login.<br>
50
50
  These changes are effective immediately.<br>
51
- Are you sure you would like to continue?`,
52
- }).subscribe(() => {
53
- const data = { ...aclObjectEntry, aclEntries: [] };
54
- this.saveAclObjectEntry(data)
55
- .subscribe(() => {
56
- this.aclEntriesList.reload();
57
- });
58
- });
59
- }
60
- }
61
- ],
62
- fetch: () => {
63
- return new Observable((observer) => {
64
- this.loadAclEntries({
65
- aclRoles: true,
66
- aclRolePermissions: true,
67
- objects: true,
68
- aclRoleState: 'active',
69
- })
70
- .subscribe((aclEntries) => {
71
- const objects = aclEntries
72
- .filter((aclEntry) => (!!aclEntry.object))
73
- .reduce((items, item) => {
74
- return {
75
- ...items,
76
- [item.object.id]: item.object,
77
- };
78
- }, {});
79
- const environments = aclEntries
80
- .filter((aclEntry) => (!!aclEntry[this.environmentKey]))
81
- .reduce((items, item) => {
82
- const environment = item[this.environmentKey];
83
- return {
84
- ...items,
85
- [environment.id]: environment,
86
- };
87
- }, {});
88
- const groupedAclEntries = groupBy(aclEntries, (item) => {
89
- const environmentId = (item[this.environmentKey])?.id;
90
- return [item.aclRole.level, environmentId, item.objectId];
91
- });
92
- let aclObjectEntries = Object.keys(groupedAclEntries)
93
- .reduce((accum, key) => {
94
- const parts = key.split(',');
95
- return [
96
- ...accum,
97
- {
98
- object: objects[parts[2]],
99
- level: parts[0],
100
- [`${this.environmentKey}Id`]: parts[1] ? parseInt(parts[1]) : null,
101
- [this.environmentKey]: environments[parts[1]],
102
- aclEntries: groupedAclEntries[key],
103
- }
104
- ];
105
- }, []);
106
- const hasApp = aclObjectEntries.some((item) => {
107
- return item.aclEntries.some((entry) => {
108
- return !entry.objectId;
109
- });
110
- });
111
- if (!hasApp) {
112
- aclObjectEntries.unshift({
113
- object: null,
114
- aclEntries: [],
115
- level: 'app',
116
- environmentId: null,
117
- });
118
- }
119
- aclObjectEntries = sortBy(aclObjectEntries, (item) => {
120
- return item.object ? item.level : '';
121
- });
122
- observer.next({ data: aclObjectEntries });
123
- observer.complete();
124
- });
125
- });
126
- },
127
- };
128
- }
129
- update(aclObjectEntry) {
130
- const data = {
131
- aclObjectEntry,
132
- required: false,
133
- loadAclRoles: this.loadAclRoles,
134
- saveAclObjectEntry: this.saveAclObjectEntry
135
- };
136
- this._dialog.open(FsAclEntryComponent, {
137
- data: data
138
- })
139
- .afterClosed()
140
- .pipe(takeUntil(this._destroy$))
141
- .subscribe(() => {
142
- this.aclEntriesList.reload();
143
- });
144
- }
145
- ngOnDestroy() {
146
- this._destroy$.next();
147
- this._destroy$.complete();
148
- }
149
- reload() {
150
- this.aclEntriesList.reload();
151
- }
152
- }
153
- FsAclEntriesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FsAclEntriesComponent, deps: [{ token: i1.FsAppAclService }, { token: i2.MatDialog }, { token: i3.FsPrompt }], target: i0.ɵɵFactoryTarget.Component });
154
- FsAclEntriesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FsAclEntriesComponent, selector: "fs-acl-entries", inputs: { loadAclEntries: "loadAclEntries", loadAclRoles: "loadAclRoles", saveAclObjectEntry: "saveAclObjectEntry", environmentShow: "environmentShow", environmentLabel: "environmentLabel", environmentKey: "environmentKey", actions: "actions" }, viewQueries: [{ propertyName: "aclEntriesList", first: true, predicate: FsListComponent, descendants: true }], ngImport: i0, template: "\n<fs-list [config]=\"aclEntriesConfig\">\n <fs-list-column>\n <ng-template fs-list-header>Context</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n <div\n *ngIf=\"row.object; else elseObject\"\n class=\"fs-row.gap-small\">\n <fs-badge *ngIf=\"row.object.imageUrl\" shape=\"circle\" image=\"{{ row.object.imageUrl }}\"></fs-badge>\n <span>\n <div><small>{{ row.object.className }}</small></div>\n <a (click)=\"update(row)\">{{ row.object.name }}</a>\n </span>\n </div>\n\n <ng-template #elseObject>\n <a (click)=\"update(row)\">App</a>\n </ng-template>\n </ng-template>\n </fs-list-column>\n\n <fs-list-column [show]=\"environmentShow\">\n <ng-template fs-list-header>{{environmentLabel}}</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n {{row.environment?.name}}\n </ng-template>\n </fs-list-column>\n\n <fs-list-column>\n <ng-template fs-list-header>Roles</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n <div class=\"fs-column\">\n <div div *ngFor=\"let aclEntry of row.aclEntries\">\n <ng-container [ngSwitch]=\"row.level\">\n <ng-container *ngSwitchCase=\"'app'\">\n <fs-acl-role-popover [aclRole]=\"aclEntry.aclRole\" objectName=\"App\">{{aclEntry.aclRole.name}}</fs-acl-role-popover>\n </ng-container>\n <ng-container *ngSwitchDefault>\n <ng-container *ngIf=\"row.object\">\n <fs-acl-role-popover [aclRole]=\"aclEntry.aclRole\">{{aclEntry.aclRole.name}}</fs-acl-role-popover>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-template>\n </fs-list-column>\n</fs-list>\n", styles: [""], components: [{ type: i4.FsListComponent, selector: "fs-list", inputs: ["config", "loaderLines"], outputs: ["filtersReady"] }, { type: i5.FsBadgeComponent, selector: "fs-badge", inputs: ["color", "text", "tooltip", "size", "shape", "image", "icon", "iconSize", "iconColor", "backgroundSize"] }, { type: i6.FsAclRolePopoverComponent, selector: "fs-acl-role-popover", inputs: ["aclRole", "objectName"] }], directives: [{ type: i4.FsListColumnDirective, selector: "fs-list-column", inputs: ["show", "title", "name", "customize", "sortable", "sortableDefault", "sortableDirection", "direction", "align", "width", "class"] }, { type: i4.FsListHeaderDirective, selector: "[fs-list-header]", inputs: ["colspan", "align", "class"] }, { type: i4.FsListCellDirective, selector: "[fs-list-cell]", inputs: ["colspan", "align", "class"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i7.NgSwitchDefault, selector: "[ngSwitchDefault]" }] });
155
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FsAclEntriesComponent, decorators: [{
156
- type: Component,
157
- args: [{ selector: 'fs-acl-entries', template: "\n<fs-list [config]=\"aclEntriesConfig\">\n <fs-list-column>\n <ng-template fs-list-header>Context</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n <div\n *ngIf=\"row.object; else elseObject\"\n class=\"fs-row.gap-small\">\n <fs-badge *ngIf=\"row.object.imageUrl\" shape=\"circle\" image=\"{{ row.object.imageUrl }}\"></fs-badge>\n <span>\n <div><small>{{ row.object.className }}</small></div>\n <a (click)=\"update(row)\">{{ row.object.name }}</a>\n </span>\n </div>\n\n <ng-template #elseObject>\n <a (click)=\"update(row)\">App</a>\n </ng-template>\n </ng-template>\n </fs-list-column>\n\n <fs-list-column [show]=\"environmentShow\">\n <ng-template fs-list-header>{{environmentLabel}}</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n {{row.environment?.name}}\n </ng-template>\n </fs-list-column>\n\n <fs-list-column>\n <ng-template fs-list-header>Roles</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n <div class=\"fs-column\">\n <div div *ngFor=\"let aclEntry of row.aclEntries\">\n <ng-container [ngSwitch]=\"row.level\">\n <ng-container *ngSwitchCase=\"'app'\">\n <fs-acl-role-popover [aclRole]=\"aclEntry.aclRole\" objectName=\"App\">{{aclEntry.aclRole.name}}</fs-acl-role-popover>\n </ng-container>\n <ng-container *ngSwitchDefault>\n <ng-container *ngIf=\"row.object\">\n <fs-acl-role-popover [aclRole]=\"aclEntry.aclRole\">{{aclEntry.aclRole.name}}</fs-acl-role-popover>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-template>\n </fs-list-column>\n</fs-list>\n", styles: [""] }]
158
- }], ctorParameters: function () { return [{ type: i1.FsAppAclService }, { type: i2.MatDialog }, { type: i3.FsPrompt }]; }, propDecorators: { loadAclEntries: [{
159
- type: Input
160
- }], loadAclRoles: [{
161
- type: Input
162
- }], saveAclObjectEntry: [{
163
- type: Input
164
- }], environmentShow: [{
165
- type: Input
166
- }], environmentLabel: [{
167
- type: Input
168
- }], environmentKey: [{
169
- type: Input
170
- }], actions: [{
171
- type: Input
172
- }], aclEntriesList: [{
173
- type: ViewChild,
174
- args: [FsListComponent]
175
- }] } });
51
+ Are you sure you would like to continue?`,
52
+ }).subscribe(() => {
53
+ const data = { ...aclObjectEntry, aclEntries: [] };
54
+ this.saveAclObjectEntry(data)
55
+ .subscribe(() => {
56
+ this.aclEntriesList.reload();
57
+ });
58
+ });
59
+ }
60
+ }
61
+ ],
62
+ fetch: () => {
63
+ return new Observable((observer) => {
64
+ this.loadAclEntries({
65
+ aclRoles: true,
66
+ aclRolePermissions: true,
67
+ objects: true,
68
+ aclRoleState: 'active',
69
+ })
70
+ .subscribe((aclEntries) => {
71
+ const objects = aclEntries
72
+ .filter((aclEntry) => (!!aclEntry.object))
73
+ .reduce((items, item) => {
74
+ return {
75
+ ...items,
76
+ [item.object.id]: item.object,
77
+ };
78
+ }, {});
79
+ const environments = aclEntries
80
+ .filter((aclEntry) => (!!aclEntry[this.environmentKey]))
81
+ .reduce((items, item) => {
82
+ const environment = item[this.environmentKey];
83
+ return {
84
+ ...items,
85
+ [environment.id]: environment,
86
+ };
87
+ }, {});
88
+ const groupedAclEntries = groupBy(aclEntries, (item) => {
89
+ const environmentId = (item[this.environmentKey])?.id;
90
+ return [item.aclRole.level, environmentId, item.objectId];
91
+ });
92
+ let aclObjectEntries = Object.keys(groupedAclEntries)
93
+ .reduce((accum, key) => {
94
+ const parts = key.split(',');
95
+ return [
96
+ ...accum,
97
+ {
98
+ object: objects[parts[2]],
99
+ level: parts[0],
100
+ [`${this.environmentKey}Id`]: parts[1] ? parseInt(parts[1]) : null,
101
+ [this.environmentKey]: environments[parts[1]],
102
+ aclEntries: groupedAclEntries[key],
103
+ }
104
+ ];
105
+ }, []);
106
+ const hasApp = aclObjectEntries.some((item) => {
107
+ return item.aclEntries.some((entry) => {
108
+ return !entry.objectId;
109
+ });
110
+ });
111
+ if (!hasApp) {
112
+ aclObjectEntries.unshift({
113
+ object: null,
114
+ aclEntries: [],
115
+ level: 'app',
116
+ environmentId: null,
117
+ });
118
+ }
119
+ aclObjectEntries = sortBy(aclObjectEntries, (item) => {
120
+ return item.object ? item.level : '';
121
+ });
122
+ observer.next({ data: aclObjectEntries });
123
+ observer.complete();
124
+ });
125
+ });
126
+ },
127
+ };
128
+ }
129
+ update(aclObjectEntry) {
130
+ const data = {
131
+ aclObjectEntry,
132
+ required: false,
133
+ loadAclRoles: this.loadAclRoles,
134
+ saveAclObjectEntry: this.saveAclObjectEntry
135
+ };
136
+ this._dialog.open(FsAclEntryComponent, {
137
+ data: data
138
+ })
139
+ .afterClosed()
140
+ .pipe(takeUntil(this._destroy$))
141
+ .subscribe(() => {
142
+ this.aclEntriesList.reload();
143
+ });
144
+ }
145
+ ngOnDestroy() {
146
+ this._destroy$.next();
147
+ this._destroy$.complete();
148
+ }
149
+ reload() {
150
+ this.aclEntriesList.reload();
151
+ }
152
+ }
153
+ FsAclEntriesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FsAclEntriesComponent, deps: [{ token: i1.FsAppAclService }, { token: i2.MatDialog }, { token: i3.FsPrompt }], target: i0.ɵɵFactoryTarget.Component });
154
+ FsAclEntriesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FsAclEntriesComponent, selector: "fs-acl-entries", inputs: { loadAclEntries: "loadAclEntries", loadAclRoles: "loadAclRoles", saveAclObjectEntry: "saveAclObjectEntry", environmentShow: "environmentShow", environmentLabel: "environmentLabel", environmentKey: "environmentKey", actions: "actions" }, viewQueries: [{ propertyName: "aclEntriesList", first: true, predicate: FsListComponent, descendants: true }], ngImport: i0, template: "\n<fs-list [config]=\"aclEntriesConfig\">\n <fs-list-column>\n <ng-template fs-list-header>Context</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n <div\n *ngIf=\"row.object; else elseObject\"\n class=\"fs-row.gap-small\">\n <fs-badge *ngIf=\"row.object.imageUrl\" shape=\"circle\" image=\"{{ row.object.imageUrl }}\"></fs-badge>\n <span>\n <div><small>{{ row.object.className }}</small></div>\n <a (click)=\"update(row)\">{{ row.object.name }}</a>\n </span>\n </div>\n\n <ng-template #elseObject>\n <a (click)=\"update(row)\">App</a>\n </ng-template>\n </ng-template>\n </fs-list-column>\n\n <fs-list-column [show]=\"environmentShow\">\n <ng-template fs-list-header>{{environmentLabel}}</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n {{row.environment?.name}}\n </ng-template>\n </fs-list-column>\n\n <fs-list-column>\n <ng-template fs-list-header>Roles</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n <div class=\"fs-column\">\n <div div *ngFor=\"let aclEntry of row.aclEntries\">\n <ng-container [ngSwitch]=\"row.level\">\n <ng-container *ngSwitchCase=\"'app'\">\n <fs-acl-role-popover [aclRole]=\"aclEntry.aclRole\" objectName=\"App\">{{aclEntry.aclRole.name}}</fs-acl-role-popover>\n </ng-container>\n <ng-container *ngSwitchDefault>\n <ng-container *ngIf=\"row.object\">\n <fs-acl-role-popover [aclRole]=\"aclEntry.aclRole\">{{aclEntry.aclRole.name}}</fs-acl-role-popover>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-template>\n </fs-list-column>\n</fs-list>\n", styles: [""], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i4.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i5.FsListComponent, selector: "fs-list", inputs: ["config", "loaderLines"], outputs: ["filtersReady"] }, { kind: "directive", type: i5.FsListColumnDirective, selector: "fs-list-column", inputs: ["show", "title", "name", "customize", "sortable", "sortableDefault", "sortableDirection", "direction", "align", "width", "class"] }, { kind: "directive", type: i5.FsListCellDirective, selector: "[fs-list-cell]", inputs: ["colspan", "align", "class"] }, { kind: "directive", type: i5.FsListHeaderDirective, selector: "[fs-list-header]", inputs: ["colspan", "align", "class"] }, { kind: "component", type: i6.FsBadgeComponent, selector: "fs-badge", inputs: ["color", "text", "tooltip", "size", "shape", "image", "icon", "iconSize", "iconColor", "backgroundSize"] }, { kind: "component", type: i7.FsAclRolePopoverComponent, selector: "fs-acl-role-popover", inputs: ["aclRole", "objectName"] }] });
155
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FsAclEntriesComponent, decorators: [{
156
+ type: Component,
157
+ args: [{ selector: 'fs-acl-entries', template: "\n<fs-list [config]=\"aclEntriesConfig\">\n <fs-list-column>\n <ng-template fs-list-header>Context</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n <div\n *ngIf=\"row.object; else elseObject\"\n class=\"fs-row.gap-small\">\n <fs-badge *ngIf=\"row.object.imageUrl\" shape=\"circle\" image=\"{{ row.object.imageUrl }}\"></fs-badge>\n <span>\n <div><small>{{ row.object.className }}</small></div>\n <a (click)=\"update(row)\">{{ row.object.name }}</a>\n </span>\n </div>\n\n <ng-template #elseObject>\n <a (click)=\"update(row)\">App</a>\n </ng-template>\n </ng-template>\n </fs-list-column>\n\n <fs-list-column [show]=\"environmentShow\">\n <ng-template fs-list-header>{{environmentLabel}}</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n {{row.environment?.name}}\n </ng-template>\n </fs-list-column>\n\n <fs-list-column>\n <ng-template fs-list-header>Roles</ng-template>\n <ng-template fs-list-cell let-row=\"row\">\n <div class=\"fs-column\">\n <div div *ngFor=\"let aclEntry of row.aclEntries\">\n <ng-container [ngSwitch]=\"row.level\">\n <ng-container *ngSwitchCase=\"'app'\">\n <fs-acl-role-popover [aclRole]=\"aclEntry.aclRole\" objectName=\"App\">{{aclEntry.aclRole.name}}</fs-acl-role-popover>\n </ng-container>\n <ng-container *ngSwitchDefault>\n <ng-container *ngIf=\"row.object\">\n <fs-acl-role-popover [aclRole]=\"aclEntry.aclRole\">{{aclEntry.aclRole.name}}</fs-acl-role-popover>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-template>\n </fs-list-column>\n</fs-list>\n" }]
158
+ }], ctorParameters: function () { return [{ type: i1.FsAppAclService }, { type: i2.MatDialog }, { type: i3.FsPrompt }]; }, propDecorators: { loadAclEntries: [{
159
+ type: Input
160
+ }], loadAclRoles: [{
161
+ type: Input
162
+ }], saveAclObjectEntry: [{
163
+ type: Input
164
+ }], environmentShow: [{
165
+ type: Input
166
+ }], environmentLabel: [{
167
+ type: Input
168
+ }], environmentKey: [{
169
+ type: Input
170
+ }], actions: [{
171
+ type: Input
172
+ }], aclEntriesList: [{
173
+ type: ViewChild,
174
+ args: [FsListComponent]
175
+ }] } });
176
176
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"acl-entries.component.js","sourceRoot":"","sources":["../../../../../src/app/components/acl-entries/acl-entries.component.ts","../../../../../src/app/components/acl-entries/acl-entries.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAO,MAAM,gBAAgB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAU,SAAS,EAAa,KAAK,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAErD,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAE3C,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAE5C,OAAO,EAAgB,eAAe,EAAgB,MAAM,kBAAkB,CAAC;AAC/E,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAE9C,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AAKjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;;;;;;;;;AAQvE,MAAM,OAAO,qBAAqB;IAkBhC,YACmB,cAA+B,EAC/B,OAAkB,EAC3B,QAAkB;QAFT,mBAAc,GAAd,cAAc,CAAiB;QAC/B,YAAO,GAAP,OAAO,CAAW;QAC3B,aAAQ,GAAR,QAAQ,CAAU;QAhBZ,oBAAe,GAAG,IAAI,CAAC;QACvB,qBAAgB,GAAG,aAAa,CAAC;QACjC,mBAAc,GAAG,aAAa,CAAC;QAC/B,YAAO,GAAmB,EAAE,CAAC;QAGtC,mBAAc,GAAoB,IAAI,CAAC;QAEvC,qBAAgB,GAAiB,IAAI,CAAC;QACtC,gBAAW,GAAU,EAAE,CAAC;QAEvB,cAAS,GAAG,IAAI,OAAO,EAAE,CAAC;IAM9B,CAAC;IAEE,QAAQ;QACb,IAAI,CAAC,cAAc,CAAC,cAAc,EAAE;aACjC,SAAS,CAAC,QAAQ,CAAC,EAAE;YACpB,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC;QAC9B,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,gBAAgB,GAAG;YACtB,MAAM,EAAE,KAAK;YACb,MAAM,EAAE,KAAK;YACb,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,UAAU,EAAE;gBACV;oBACE,KAAK,EAAE,kBAAkB;oBACzB,KAAK,EAAE,CAAC,cAA8B,EAAE,EAAE;wBACxC,IAAI,CAAC,QAAQ;6BACV,OAAO,CAAC;4BACP,KAAK,EAAE,kBAAkB;4BACzB,WAAW,EAAE,MAAM;4BACnB,QAAQ,EAAE;;2DAEiC;yBAC5C,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;4BAChB,MAAM,IAAI,GAAG,EAAE,GAAG,cAAc,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC;4BACnD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC;iCAC1B,SAAS,CAAC,GAAG,EAAE;gCACd,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC;4BAC/B,CAAC,CAAC,CAAC;wBACP,CAAC,CAAC,CAAC;oBACP,CAAC;iBACF;aACF;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,OAAO,IAAI,UAAU,CAAC,CAAC,QAAQ,EAAE,EAAE;oBACjC,IAAI,CAAC,cAAc,CAAC;wBAClB,QAAQ,EAAE,IAAI;wBACd,kBAAkB,EAAE,IAAI;wBACxB,OAAO,EAAE,IAAI;wBACb,YAAY,EAAE,QAAQ;qBACvB,CAAC;yBACC,SAAS,CAAC,CAAC,UAAsB,EAAE,EAAE;wBACpC,MAAM,OAAO,GAAG,UAAU;6BACvB,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;6BACzC,MAAM,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;4BACtB,OAAO;gCACL,GAAG,KAAK;gCACR,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,MAAM;6BAC9B,CAAC;wBACJ,CAAC,EAAE,EAAE,CAAC,CAAC;wBAET,MAAM,YAAY,GAAG,UAAU;6BAC5B,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;6BACvD,MAAM,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;4BACtB,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;4BAC9C,OAAO;gCACL,GAAG,KAAK;gCACR,CAAC,WAAW,CAAC,EAAE,CAAC,EAAE,WAAW;6BAC9B,CAAC;wBACJ,CAAC,EAAE,EAAE,CAAC,CAAC;wBAET,MAAM,iBAAiB,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC,IAAI,EAAE,EAAE;4BACrD,MAAM,aAAa,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,EAAE,EAAE,CAAC;4BACtD,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;wBAC5D,CAAC,CAAC,CAAC;wBAEH,IAAI,gBAAgB,GAAqB,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC;6BACpE,MAAM,CAAC,CAAC,KAAK,EAAE,GAAQ,EAAE,EAAE;4BAC1B,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;4BAC7B,OAAO;gCACL,GAAG,KAAK;gCACR;oCACE,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;oCACzB,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;oCACf,CAAC,GAAG,IAAI,CAAC,cAAc,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI;oCAClE,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;oCAC7C,UAAU,EAAE,iBAAiB,CAAC,GAAG,CAAC;iCACnC;6BACF,CAAC;wBACJ,CAAC,EAAE,EAAE,CAAC,CAAC;wBAET,MAAM,MAAM,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;4BAC5C,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;gCACpC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC;4BACzB,CAAC,CAAC,CAAC;wBACL,CAAC,CAAC,CAAC;wBAEH,IAAI,CAAC,MAAM,EAAE;4BACX,gBAAgB,CAAC,OAAO,CAAC;gCACvB,MAAM,EAAE,IAAI;gCACZ,UAAU,EAAE,EAAE;gCACd,KAAK,EAAE,KAAK;gCACZ,aAAa,EAAE,IAAI;6BACpB,CAAC,CAAC;yBACJ;wBAED,gBAAgB,GAAG,MAAM,CAAC,gBAAgB,EAAE,CAAC,IAAoB,EAAE,EAAE;4BACnE,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;wBACvC,CAAC,CAAC,CAAC;wBAEH,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,CAAC,CAAC;wBAC1C,QAAQ,CAAC,QAAQ,EAAE,CAAC;oBACtB,CAAC,CAAC,CAAC;gBACP,CAAC,CAAC,CAAC;YACL,CAAC;SACF,CAAC;IACJ,CAAC;IAEM,MAAM,CAAC,cAA8B;QAC1C,MAAM,IAAI,GAAiB;YACzB,cAAc;YACd,QAAQ,EAAE,KAAK;YACf,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;SAC5C,CAAA;QAED,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,mBAAmB,EAAE;YACrC,IAAI,EAAE,IAAI;SACX,CAAC;aACC,WAAW,EAAE;aACb,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC;QAC/B,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAEM,MAAM;QACX,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC;IAC/B,CAAC;;kHA7JU,qBAAqB;sGAArB,qBAAqB,4VAUrB,eAAe,gDClC5B,4wDAgDA;2FDxBa,qBAAqB;kBALjC,SAAS;+BACE,gBAAgB;qJAMV,cAAc;sBAA7B,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,kBAAkB;sBAAjC,KAAK;gBACU,eAAe;sBAA9B,KAAK;gBACU,gBAAgB;sBAA/B,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBACU,OAAO;sBAAtB,KAAK;gBAGC,cAAc;sBADpB,SAAS;uBAAC,eAAe","sourcesContent":["import { takeUntil, map } from 'rxjs/operators';\nimport { Component, OnInit, ViewChild, OnDestroy, Input } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\n\nimport { Subject, Observable } from 'rxjs';\n\nimport { sortBy, groupBy } from 'lodash-es';\n\nimport { FsListAction, FsListComponent, FsListConfig } from '@firestitch/list';\nimport { FsPrompt } from '@firestitch/prompt';\n\nimport { FsAppAclService } from '../../services/app-acl.service';\nimport { AclEntryData } from '../../interfaces/acl-entry-data';\nimport { AclEntry } from '../../interfaces/acl-entry';\nimport { AclRole } from '../../interfaces/acl-role';\nimport { AclObjectEntry } from '../../interfaces/acl-object-entry';\nimport { FsAclEntryComponent } from '../acl-entry/acl-entry.component';\n\n\n@Component({\n  selector: 'fs-acl-entries',\n  templateUrl: './acl-entries.component.html',\n  styleUrls: ['./acl-entries.component.scss']\n})\nexport class FsAclEntriesComponent implements OnInit, OnDestroy {\n\n  @Input() public loadAclEntries: (query: any) => Observable<AclEntry[]>;\n  @Input() public loadAclRoles: (query: any) => Observable<AclRole[]>;\n  @Input() public saveAclObjectEntry: (aclObjectEntry: AclObjectEntry) => Observable<any>;\n  @Input() public environmentShow = true;\n  @Input() public environmentLabel = 'Environment';\n  @Input() public environmentKey = 'environment';\n  @Input() public actions: FsListAction[] = [];\n\n  @ViewChild(FsListComponent)\n  public aclEntriesList: FsListComponent = null;\n\n  public aclEntriesConfig: FsListConfig = null;\n  public permissions: any[] = [];\n\n  private _destroy$ = new Subject();\n\n  constructor(\n    private readonly _appAclService: FsAppAclService,\n    private readonly _dialog: MatDialog,\n    private _confirm: FsPrompt,\n  ) { }\n\n  public ngOnInit(): void {\n    this._appAclService.getPermissions()\n      .subscribe(response => {\n        this.permissions = response;\n      });\n\n    this.aclEntriesConfig = {\n      status: false,\n      paging: false,\n      actions: this.actions,\n      rowActions: [\n        {\n          label: 'Remove All Roles',\n          click: (aclObjectEntry: AclObjectEntry) => {\n            this._confirm\n              .confirm({\n                title: 'Remove All Roles',\n                commitLabel: 'Save',\n                template: `Please note that removing roles may prevent users from being able to successfully login.<br>\n                  These changes are effective immediately.<br>\n                  Are you sure you would like to continue?`,\n              }).subscribe(() => {\n                const data = { ...aclObjectEntry, aclEntries: [] };\n                this.saveAclObjectEntry(data)\n                  .subscribe(() => {\n                    this.aclEntriesList.reload();\n                  });\n              });\n          }\n        }\n      ],\n      fetch: () => {\n        return new Observable((observer) => {\n          this.loadAclEntries({\n            aclRoles: true,\n            aclRolePermissions: true,\n            objects: true,\n            aclRoleState: 'active',\n          })\n            .subscribe((aclEntries: AclEntry[]) => {\n              const objects = aclEntries\n                .filter((aclEntry) => (!!aclEntry.object))\n                .reduce((items, item) => {\n                  return {\n                    ...items,\n                    [item.object.id]: item.object,\n                  };\n                }, {});\n\n              const environments = aclEntries\n                .filter((aclEntry) => (!!aclEntry[this.environmentKey]))\n                .reduce((items, item) => {\n                  const environment = item[this.environmentKey];\n                  return {\n                    ...items,\n                    [environment.id]: environment,\n                  };\n                }, {});\n\n              const groupedAclEntries = groupBy(aclEntries, (item) => {\n                const environmentId = (item[this.environmentKey])?.id;\n                return [item.aclRole.level, environmentId, item.objectId];\n              });\n\n              let aclObjectEntries: AclObjectEntry[] = Object.keys(groupedAclEntries)\n                .reduce((accum, key: any) => {\n                  const parts = key.split(',');\n                  return [\n                    ...accum,\n                    {\n                      object: objects[parts[2]],\n                      level: parts[0],\n                      [`${this.environmentKey}Id`]: parts[1] ? parseInt(parts[1]) : null,\n                      [this.environmentKey]: environments[parts[1]],\n                      aclEntries: groupedAclEntries[key],\n                    }\n                  ];\n                }, []);\n\n              const hasApp = aclObjectEntries.some((item) => {\n                return item.aclEntries.some((entry) => {\n                  return !entry.objectId;\n                });\n              });\n\n              if (!hasApp) {\n                aclObjectEntries.unshift({\n                  object: null,\n                  aclEntries: [],\n                  level: 'app',\n                  environmentId: null,\n                });\n              }\n\n              aclObjectEntries = sortBy(aclObjectEntries, (item: AclObjectEntry) => {\n                return item.object ? item.level : '';\n              });\n\n              observer.next({ data: aclObjectEntries });\n              observer.complete();\n            });\n        });\n      },\n    };\n  }\n\n  public update(aclObjectEntry: AclObjectEntry) {\n    const data: AclEntryData = {\n      aclObjectEntry,\n      required: false,\n      loadAclRoles: this.loadAclRoles,\n      saveAclObjectEntry: this.saveAclObjectEntry\n    }\n\n    this._dialog.open(FsAclEntryComponent, {\n      data: data\n    })\n      .afterClosed()\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe(() => {\n        this.aclEntriesList.reload();\n      });\n  }\n\n  public ngOnDestroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  public reload(): void {\n    this.aclEntriesList.reload();\n  }\n\n}\n","\n<fs-list [config]=\"aclEntriesConfig\">\n  <fs-list-column>\n    <ng-template fs-list-header>Context</ng-template>\n    <ng-template fs-list-cell let-row=\"row\">\n      <div\n          *ngIf=\"row.object; else elseObject\"\n          class=\"fs-row.gap-small\">\n        <fs-badge *ngIf=\"row.object.imageUrl\" shape=\"circle\" image=\"{{ row.object.imageUrl }}\"></fs-badge>\n        <span>\n          <div><small>{{ row.object.className }}</small></div>\n          <a (click)=\"update(row)\">{{ row.object.name }}</a>\n        </span>\n      </div>\n\n      <ng-template #elseObject>\n        <a (click)=\"update(row)\">App</a>\n      </ng-template>\n    </ng-template>\n  </fs-list-column>\n\n  <fs-list-column [show]=\"environmentShow\">\n    <ng-template fs-list-header>{{environmentLabel}}</ng-template>\n    <ng-template fs-list-cell let-row=\"row\">\n      {{row.environment?.name}}\n    </ng-template>\n  </fs-list-column>\n\n  <fs-list-column>\n    <ng-template fs-list-header>Roles</ng-template>\n    <ng-template fs-list-cell let-row=\"row\">\n      <div class=\"fs-column\">\n        <div div *ngFor=\"let aclEntry of row.aclEntries\">\n          <ng-container [ngSwitch]=\"row.level\">\n            <ng-container *ngSwitchCase=\"'app'\">\n              <fs-acl-role-popover [aclRole]=\"aclEntry.aclRole\" objectName=\"App\">{{aclEntry.aclRole.name}}</fs-acl-role-popover>\n            </ng-container>\n            <ng-container *ngSwitchDefault>\n              <ng-container *ngIf=\"row.object\">\n                <fs-acl-role-popover [aclRole]=\"aclEntry.aclRole\">{{aclEntry.aclRole.name}}</fs-acl-role-popover>\n              </ng-container>\n            </ng-container>\n          </ng-container>\n        </div>\n      </div>\n    </ng-template>\n  </fs-list-column>\n</fs-list>\n"]}