@gravitee/ui-policy-studio-angular 12.14.0 → 12.15.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 (50) hide show
  1. package/esm2022/lib/components/filter-pipe/gio-flter-connectors-by-mode.pipe.mjs +3 -2
  2. package/esm2022/lib/components/flow-details/gio-ps-flow-details.component.mjs +21 -9
  3. package/esm2022/lib/components/flow-details-info-bar/gio-ps-flow-details-info-bar.component.mjs +6 -3
  4. package/esm2022/lib/components/flow-details-phase/gio-ps-flow-details-phase.component.mjs +10 -7
  5. package/esm2022/lib/components/flow-details-phase-step/gio-ps-flow-details-phase-step.component.mjs +10 -7
  6. package/esm2022/lib/components/flow-execution-form-dialog/gio-ps-flow-execution-form-dialog.component.mjs +24 -7
  7. package/esm2022/lib/components/flow-form-dialog/flow-message-form-dialog/gio-ps-flow-message-form-dialog.component.mjs +27 -8
  8. package/esm2022/lib/components/flow-form-dialog/flow-proxy-form-dialog/gio-ps-flow-proxy-form-dialog.component.mjs +28 -8
  9. package/esm2022/lib/components/flow-form-dialog/gio-ps-flow-form-dialog-result.model.mjs +1 -1
  10. package/esm2022/lib/components/flows-menu/gio-ps-flows-menu.component.mjs +11 -8
  11. package/esm2022/lib/components/policies-catalog-dialog/gio-ps-policies-catalog-dialog.component.mjs +26 -10
  12. package/esm2022/lib/components/step-edit-dialog/gio-ps-step-edit-dialog.component.mjs +8 -5
  13. package/esm2022/lib/components/step-form/gio-ps-step-form.component.mjs +20 -8
  14. package/esm2022/lib/policy-studio/gio-policy-studio.component.mjs +251 -0
  15. package/esm2022/lib/policy-studio/gio-policy-studio.model.mjs +17 -0
  16. package/esm2022/lib/policy-studio/gio-policy-studio.service.mjs +74 -0
  17. package/esm2022/public-api.mjs +2 -3
  18. package/esm2022/testing/lib/components/flow-details-phase/gio-ps-flow-details-phase.harness.mjs +4 -2
  19. package/esm2022/testing/lib/policy-studio/gio-policy-studio.harness.mjs +174 -0
  20. package/esm2022/testing/public-testing-api.mjs +2 -2
  21. package/fesm2022/gravitee-ui-policy-studio-angular-testing.mjs +3 -1
  22. package/fesm2022/gravitee-ui-policy-studio-angular-testing.mjs.map +1 -1
  23. package/fesm2022/gravitee-ui-policy-studio-angular.mjs +540 -578
  24. package/fesm2022/gravitee-ui-policy-studio-angular.mjs.map +1 -1
  25. package/lib/components/filter-pipe/gio-flter-connectors-by-mode.pipe.d.ts +1 -1
  26. package/lib/components/flow-details/gio-ps-flow-details.component.d.ts +2 -2
  27. package/lib/components/flow-details-info-bar/gio-ps-flow-details-info-bar.component.d.ts +2 -2
  28. package/lib/components/flow-details-phase/gio-ps-flow-details-phase.component.d.ts +1 -1
  29. package/lib/components/flow-details-phase-step/gio-ps-flow-details-phase-step.component.d.ts +1 -1
  30. package/lib/components/flow-execution-form-dialog/gio-ps-flow-execution-form-dialog.component.d.ts +1 -1
  31. package/lib/components/flow-form-dialog/flow-message-form-dialog/gio-ps-flow-message-form-dialog.component.d.ts +3 -3
  32. package/lib/components/flow-form-dialog/flow-proxy-form-dialog/gio-ps-flow-proxy-form-dialog.component.d.ts +3 -3
  33. package/lib/components/flow-form-dialog/gio-ps-flow-form-dialog-result.model.d.ts +1 -1
  34. package/lib/components/flows-menu/gio-ps-flows-menu.component.d.ts +2 -2
  35. package/lib/components/policies-catalog-dialog/gio-ps-policies-catalog-dialog.component.d.ts +2 -3
  36. package/lib/components/step-edit-dialog/gio-ps-step-edit-dialog.component.d.ts +1 -1
  37. package/lib/components/step-form/gio-ps-step-form.component.d.ts +2 -2
  38. package/lib/{gio-policy-studio.component.d.ts → policy-studio/gio-policy-studio.component.d.ts} +2 -2
  39. package/lib/{gio-policy-studio.model.d.ts → policy-studio/gio-policy-studio.model.d.ts} +1 -1
  40. package/lib/{gio-policy-studio.service.d.ts → policy-studio/gio-policy-studio.service.d.ts} +1 -1
  41. package/package.json +1 -1
  42. package/public-api.d.ts +1 -2
  43. package/testing/lib/{gio-policy-studio.harness.d.ts → policy-studio/gio-policy-studio.harness.d.ts} +2 -2
  44. package/testing/public-testing-api.d.ts +1 -1
  45. package/esm2022/lib/gio-policy-studio.component.mjs +0 -240
  46. package/esm2022/lib/gio-policy-studio.model.mjs +0 -17
  47. package/esm2022/lib/gio-policy-studio.module.mjs +0 -140
  48. package/esm2022/lib/gio-policy-studio.service.mjs +0 -74
  49. package/esm2022/testing/lib/gio-policy-studio.harness.mjs +0 -174
  50. package/lib/gio-policy-studio.module.d.ts +0 -33
@@ -4,5 +4,5 @@ import * as i0 from "@angular/core";
4
4
  export declare class GioFilterConnectorsByModePipe implements PipeTransform {
5
5
  transform(items: ConnectorInfo[], mode: ConnectorMode, activeModes?: ConnectorMode[]): ConnectorInfo[];
6
6
  static ɵfac: i0.ɵɵFactoryDeclaration<GioFilterConnectorsByModePipe, never>;
7
- static ɵpipe: i0.ɵɵPipeDeclaration<GioFilterConnectorsByModePipe, "gioFilterConnectorsByMode", false>;
7
+ static ɵpipe: i0.ɵɵPipeDeclaration<GioFilterConnectorsByModePipe, "gioFilterConnectorsByMode", true>;
8
8
  }
@@ -1,6 +1,6 @@
1
1
  import { EventEmitter, OnChanges, SimpleChanges } from '@angular/core';
2
2
  import { MatDialog } from '@angular/material/dialog';
3
- import { FlowVM } from '../../gio-policy-studio.model';
3
+ import { FlowVM } from '../../policy-studio/gio-policy-studio.model';
4
4
  import { ApiType, ConnectorInfo, Operation, Policy, Step } from '../../models';
5
5
  import * as i0 from "@angular/core";
6
6
  export declare class GioPolicyStudioDetailsComponent implements OnChanges {
@@ -23,5 +23,5 @@ export declare class GioPolicyStudioDetailsComponent implements OnChanges {
23
23
  onDeleteFlow(): void;
24
24
  onStepsChange(flowPhase: 'request' | 'response' | 'publish' | 'subscribe', steps: Step[]): void;
25
25
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioDetailsComponent, never>;
26
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioDetailsComponent, "gio-ps-flow-details", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "apiType": { "alias": "apiType"; "required": false; }; "flow": { "alias": "flow"; "required": false; }; "entrypointsInfo": { "alias": "entrypointsInfo"; "required": false; }; "endpointsInfo": { "alias": "endpointsInfo"; "required": false; }; "policies": { "alias": "policies"; "required": false; }; "trialUrl": { "alias": "trialUrl"; "required": false; }; }, { "flowChange": "flowChange"; "deleteFlow": "deleteFlow"; }, never, never, false, never>;
26
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioDetailsComponent, "gio-ps-flow-details", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "apiType": { "alias": "apiType"; "required": false; }; "flow": { "alias": "flow"; "required": false; }; "entrypointsInfo": { "alias": "entrypointsInfo"; "required": false; }; "endpointsInfo": { "alias": "endpointsInfo"; "required": false; }; "policies": { "alias": "policies"; "required": false; }; "trialUrl": { "alias": "trialUrl"; "required": false; }; }, { "flowChange": "flowChange"; "deleteFlow": "deleteFlow"; }, never, never, true, never>;
27
27
  }
@@ -1,5 +1,5 @@
1
- import { FlowVM } from '../../gio-policy-studio.model';
2
1
  import { ConnectorInfo } from '../../models';
2
+ import { FlowVM } from '../../policy-studio/gio-policy-studio.model';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class GioPolicyStudioDetailsInfoBarComponent {
5
5
  flow?: FlowVM;
@@ -16,5 +16,5 @@ export declare class GioPolicyStudioDetailsInfoBarComponent {
16
16
  class: string;
17
17
  }[] | undefined;
18
18
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioDetailsInfoBarComponent, never>;
19
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioDetailsInfoBarComponent, "gio-ps-flow-details-info-bar", never, { "flow": { "alias": "flow"; "required": false; }; "entrypointsInfo": { "alias": "entrypointsInfo"; "required": false; }; }, {}, never, never, false, never>;
19
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioDetailsInfoBarComponent, "gio-ps-flow-details-info-bar", never, { "flow": { "alias": "flow"; "required": false; }; "entrypointsInfo": { "alias": "entrypointsInfo"; "required": false; }; }, {}, never, never, true, never>;
20
20
  }
@@ -35,6 +35,6 @@ export declare class GioPolicyStudioDetailsPhaseComponent implements OnChanges {
35
35
  onStepDeleted(index: number): void;
36
36
  onStepDisabled(index: number): void;
37
37
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioDetailsPhaseComponent, never>;
38
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioDetailsPhaseComponent, "gio-ps-flow-details-phase", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "steps": { "alias": "steps"; "required": false; }; "name": { "alias": "name"; "required": false; }; "description": { "alias": "description"; "required": false; }; "startConnector": { "alias": "startConnector"; "required": false; }; "endConnector": { "alias": "endConnector"; "required": false; }; "apiType": { "alias": "apiType"; "required": false; }; "policies": { "alias": "policies"; "required": false; }; "policyExecutionPhase": { "alias": "policyExecutionPhase"; "required": false; }; "trialUrl": { "alias": "trialUrl"; "required": false; }; }, { "stepsChange": "stepsChange"; }, never, never, false, never>;
38
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioDetailsPhaseComponent, "gio-ps-flow-details-phase", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "steps": { "alias": "steps"; "required": false; }; "name": { "alias": "name"; "required": false; }; "description": { "alias": "description"; "required": false; }; "startConnector": { "alias": "startConnector"; "required": false; }; "endConnector": { "alias": "endConnector"; "required": false; }; "apiType": { "alias": "apiType"; "required": false; }; "policies": { "alias": "policies"; "required": false; }; "policyExecutionPhase": { "alias": "policyExecutionPhase"; "required": false; }; "trialUrl": { "alias": "trialUrl"; "required": false; }; }, { "stepsChange": "stepsChange"; }, never, never, true, never>;
39
39
  }
40
40
  export {};
@@ -18,5 +18,5 @@ export declare class GioPolicyStudioDetailsPhaseStepComponent implements OnChang
18
18
  onDisable(): void;
19
19
  onDelete(): void;
20
20
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioDetailsPhaseStepComponent, never>;
21
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioDetailsPhaseStepComponent, "gio-ps-flow-details-phase-step", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "step": { "alias": "step"; "required": false; }; "policies": { "alias": "policies"; "required": false; }; "executionPhase": { "alias": "executionPhase"; "required": true; }; }, { "stepChange": "stepChange"; "deleted": "deleted"; "disabled": "disabled"; }, never, never, false, never>;
21
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioDetailsPhaseStepComponent, "gio-ps-flow-details-phase-step", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "step": { "alias": "step"; "required": false; }; "policies": { "alias": "policies"; "required": false; }; "executionPhase": { "alias": "executionPhase"; "required": true; }; }, { "stepChange": "stepChange"; "deleted": "deleted"; "disabled": "disabled"; }, never, never, true, never>;
22
22
  }
@@ -14,5 +14,5 @@ export declare class GioPolicyStudioFlowExecutionFormDialogComponent {
14
14
  constructor(dialogRef: MatDialogRef<GioPolicyStudioFlowExecutionFormDialogComponent, FlowExecution | undefined>, flowDialogData: GioPolicyStudioFlowExecutionFormDialogData);
15
15
  onSubmit(): void;
16
16
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioFlowExecutionFormDialogComponent, never>;
17
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioFlowExecutionFormDialogComponent, "gio-ps-flow-execution-form-dialog", never, {}, {}, never, never, false, never>;
17
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioFlowExecutionFormDialogComponent, "gio-ps-flow-execution-form-dialog", never, {}, {}, never, never, true, never>;
18
18
  }
@@ -1,8 +1,8 @@
1
1
  import { MatDialogRef } from '@angular/material/dialog';
2
2
  import { UntypedFormGroup } from '@angular/forms';
3
- import { FlowVM } from '../../../gio-policy-studio.model';
4
- import { ConnectorInfo } from '../../../models';
5
3
  import { GioPolicyStudioFlowFormDialogResult } from '../gio-ps-flow-form-dialog-result.model';
4
+ import { ConnectorInfo } from '../../../models';
5
+ import { FlowVM } from '../../../policy-studio/gio-policy-studio.model';
6
6
  import * as i0 from "@angular/core";
7
7
  export type GioPolicyStudioFlowMessageFormDialogData = {
8
8
  flow?: FlowVM;
@@ -17,5 +17,5 @@ export declare class GioPolicyStudioFlowMessageFormDialogComponent {
17
17
  constructor(dialogRef: MatDialogRef<GioPolicyStudioFlowMessageFormDialogComponent, GioPolicyStudioFlowFormDialogResult>, flowDialogData: GioPolicyStudioFlowMessageFormDialogData);
18
18
  onSubmit(): void;
19
19
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioFlowMessageFormDialogComponent, never>;
20
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioFlowMessageFormDialogComponent, "gio-ps-flow-message-form-dialog", never, {}, {}, never, never, false, never>;
20
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioFlowMessageFormDialogComponent, "gio-ps-flow-message-form-dialog", never, {}, {}, never, never, true, never>;
21
21
  }
@@ -1,8 +1,8 @@
1
1
  import { MatDialogRef } from '@angular/material/dialog';
2
2
  import { UntypedFormGroup } from '@angular/forms';
3
- import { FlowVM } from '../../../gio-policy-studio.model';
4
- import { HttpMethod } from '../../../models';
5
3
  import { GioPolicyStudioFlowFormDialogResult } from '../gio-ps-flow-form-dialog-result.model';
4
+ import { HttpMethod } from '../../../models';
5
+ import { FlowVM } from '../../../policy-studio/gio-policy-studio.model';
6
6
  import * as i0 from "@angular/core";
7
7
  export type GioPolicyStudioFlowProxyFormDialogData = {
8
8
  flow?: FlowVM;
@@ -18,7 +18,7 @@ export declare class GioPolicyStudioFlowProxyFormDialogComponent {
18
18
  onSubmit(): void;
19
19
  tagValidationHook(tag: string, validationCb: (shouldAddTag: boolean) => void): void;
20
20
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioFlowProxyFormDialogComponent, never>;
21
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioFlowProxyFormDialogComponent, "gio-ps-flow-proxy-form-dialog", never, {}, {}, never, never, false, never>;
21
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioFlowProxyFormDialogComponent, "gio-ps-flow-proxy-form-dialog", never, {}, {}, never, never, true, never>;
22
22
  }
23
23
  export declare const sanitizePath: (path: string) => string;
24
24
  export {};
@@ -1,2 +1,2 @@
1
- import { FlowVM } from '../../gio-policy-studio.model';
1
+ import { FlowVM } from '../../policy-studio/gio-policy-studio.model';
2
2
  export type GioPolicyStudioFlowFormDialogResult = FlowVM | false;
@@ -1,6 +1,6 @@
1
1
  import { EventEmitter, OnChanges, SimpleChanges } from '@angular/core';
2
2
  import { MatDialog } from '@angular/material/dialog';
3
- import { FlowGroupVM, FlowVM } from '../../gio-policy-studio.model';
3
+ import { FlowGroupVM, FlowVM } from '../../policy-studio/gio-policy-studio.model';
4
4
  import { ApiType, ConnectorInfo, FlowExecution } from '../../models';
5
5
  import * as i0 from "@angular/core";
6
6
  interface FlowGroupMenuVM extends FlowGroupVM {
@@ -35,6 +35,6 @@ export declare class GioPolicyStudioFlowsMenuComponent implements OnChanges {
35
35
  onAddFlow(flowGroup: FlowGroupVM): void;
36
36
  onConfigureExecution(flowExecution: FlowExecution): void;
37
37
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioFlowsMenuComponent, never>;
38
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioFlowsMenuComponent, "gio-ps-flows-menu", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "apiType": { "alias": "apiType"; "required": false; }; "flowExecution": { "alias": "flowExecution"; "required": false; }; "flowsGroups": { "alias": "flowsGroups"; "required": false; }; "selectedFlow": { "alias": "selectedFlow"; "required": false; }; "entrypoints": { "alias": "entrypoints"; "required": false; }; }, { "selectedFlowChange": "selectedFlowChange"; "flowsGroupsChange": "flowsGroupsChange"; "flowExecutionChange": "flowExecutionChange"; }, never, never, false, never>;
38
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioFlowsMenuComponent, "gio-ps-flows-menu", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "apiType": { "alias": "apiType"; "required": false; }; "flowExecution": { "alias": "flowExecution"; "required": false; }; "flowsGroups": { "alias": "flowsGroups"; "required": false; }; "selectedFlow": { "alias": "selectedFlow"; "required": false; }; "entrypoints": { "alias": "entrypoints"; "required": false; }; }, { "selectedFlowChange": "selectedFlowChange"; "flowsGroupsChange": "flowsGroupsChange"; "flowExecutionChange": "flowExecutionChange"; }, never, never, true, never>;
39
39
  }
40
40
  export {};
@@ -1,6 +1,6 @@
1
1
  import { OnDestroy } from '@angular/core';
2
2
  import { MatDialogRef } from '@angular/material/dialog';
3
- import { UntypedFormControl, UntypedFormGroup } from '@angular/forms';
3
+ import { UntypedFormGroup } from '@angular/forms';
4
4
  import { ApiType, ExecutionPhase, Policy, Step } from '../../models';
5
5
  import * as i0 from "@angular/core";
6
6
  export type GioPolicyStudioPoliciesCatalogDialogData = {
@@ -22,7 +22,6 @@ export declare class GioPolicyStudioPoliciesCatalogDialogComponent implements On
22
22
  stepToAdd?: Step;
23
23
  categories: string[];
24
24
  isValid: boolean;
25
- selectedCategoriesControl?: UntypedFormControl;
26
25
  filtersForm: UntypedFormGroup;
27
26
  private allPolicies;
28
27
  private unsubscribe$;
@@ -36,6 +35,6 @@ export declare class GioPolicyStudioPoliciesCatalogDialogComponent implements On
36
35
  onAddPolicy(): void;
37
36
  onGoBack(): void;
38
37
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioPoliciesCatalogDialogComponent, never>;
39
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioPoliciesCatalogDialogComponent, "gio-ps-policies-catalog-dialog", never, {}, {}, never, never, false, never>;
38
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioPoliciesCatalogDialogComponent, "gio-ps-policies-catalog-dialog", never, {}, {}, never, never, true, never>;
40
39
  }
41
40
  export {};
@@ -18,5 +18,5 @@ export declare class GioPolicyStudioStepEditDialogComponent {
18
18
  constructor(dialogRef: MatDialogRef<GioPolicyStudioStepEditDialogComponent, GioPolicyStudioStepEditDialogResult>, flowDialogData: GioPolicyStudioStepEditDialogData);
19
19
  onSave(): void;
20
20
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioStepEditDialogComponent, never>;
21
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioStepEditDialogComponent, "gio-ps-step-edit-dialog", never, {}, {}, never, never, false, never>;
21
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioStepEditDialogComponent, "gio-ps-step-edit-dialog", never, {}, {}, never, never, true, never>;
22
22
  }
@@ -2,8 +2,8 @@ import { EventEmitter, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angu
2
2
  import { UntypedFormGroup } from '@angular/forms';
3
3
  import { Observable } from 'rxjs';
4
4
  import { GioJsonSchema, GioJsonSchemaContext } from '@gravitee/ui-particles-angular';
5
- import { GioPolicyStudioService } from '../../gio-policy-studio.service';
6
5
  import { ExecutionPhase, Policy, Step } from '../../models';
6
+ import { GioPolicyStudioService } from '../../policy-studio/gio-policy-studio.service';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class GioPolicyStudioStepFormComponent implements OnChanges, OnInit, OnDestroy {
9
9
  private readonly policyStudioService;
@@ -26,5 +26,5 @@ export declare class GioPolicyStudioStepFormComponent implements OnChanges, OnIn
26
26
  onJsonSchemaReady(isReady: boolean): void;
27
27
  emitStepChange(): void;
28
28
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioStepFormComponent, never>;
29
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioStepFormComponent, "gio-ps-step-form", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "step": { "alias": "step"; "required": false; }; "executionPhase": { "alias": "executionPhase"; "required": true; }; "policy": { "alias": "policy"; "required": false; }; }, { "stepChange": "stepChange"; "isValid": "isValid"; }, never, never, false, never>;
29
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioStepFormComponent, "gio-ps-step-form", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "step": { "alias": "step"; "required": false; }; "executionPhase": { "alias": "executionPhase"; "required": true; }; "policy": { "alias": "policy"; "required": false; }; }, { "stepChange": "stepChange"; "isValid": "isValid"; }, never, never, true, never>;
30
30
  }
@@ -1,5 +1,5 @@
1
1
  import { EventEmitter, OnChanges, OnDestroy, SimpleChanges } from '@angular/core';
2
- import { ApiType, ConnectorInfo, Flow, FlowExecution, Plan, Policy, PolicyDocumentationFetcher, PolicySchemaFetcher, SaveOutput } from './models';
2
+ import { ApiType, ConnectorInfo, Flow, FlowExecution, Plan, Policy, PolicyDocumentationFetcher, PolicySchemaFetcher, SaveOutput } from '../models';
3
3
  import { FlowGroupVM, FlowVM } from './gio-policy-studio.model';
4
4
  import { GioPolicyStudioService } from './gio-policy-studio.service';
5
5
  import * as i0 from "@angular/core";
@@ -78,5 +78,5 @@ export declare class GioPolicyStudioComponent implements OnChanges, OnDestroy {
78
78
  onDeleteSelectedFlow(flow: FlowVM): void;
79
79
  onSave(): void;
80
80
  static ɵfac: i0.ɵɵFactoryDeclaration<GioPolicyStudioComponent, never>;
81
- static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioComponent, "gio-policy-studio", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "apiType": { "alias": "apiType"; "required": false; }; "flowExecution": { "alias": "flowExecution"; "required": false; }; "entrypointsInfo": { "alias": "entrypointsInfo"; "required": false; }; "endpointsInfo": { "alias": "endpointsInfo"; "required": false; }; "commonFlows": { "alias": "commonFlows"; "required": false; }; "plans": { "alias": "plans"; "required": false; }; "policies": { "alias": "policies"; "required": false; }; "trialUrl": { "alias": "trialUrl"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "policySchemaFetcher": { "alias": "policySchemaFetcher"; "required": false; }; "policyDocumentationFetcher": { "alias": "policyDocumentationFetcher"; "required": false; }; }, { "save": "save"; }, never, never, false, never>;
81
+ static ɵcmp: i0.ɵɵComponentDeclaration<GioPolicyStudioComponent, "gio-policy-studio", never, { "readOnly": { "alias": "readOnly"; "required": false; }; "apiType": { "alias": "apiType"; "required": false; }; "flowExecution": { "alias": "flowExecution"; "required": false; }; "entrypointsInfo": { "alias": "entrypointsInfo"; "required": false; }; "endpointsInfo": { "alias": "endpointsInfo"; "required": false; }; "commonFlows": { "alias": "commonFlows"; "required": false; }; "plans": { "alias": "plans"; "required": false; }; "policies": { "alias": "policies"; "required": false; }; "trialUrl": { "alias": "trialUrl"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "policySchemaFetcher": { "alias": "policySchemaFetcher"; "required": false; }; "policyDocumentationFetcher": { "alias": "policyDocumentationFetcher"; "required": false; }; }, { "save": "save"; }, never, never, true, never>;
82
82
  }
@@ -1,4 +1,4 @@
1
- import { Flow } from './models';
1
+ import { Flow } from '../models';
2
2
  export interface FlowVM extends Flow {
3
3
  _id: string;
4
4
  _hasChanged: boolean;
@@ -1,5 +1,5 @@
1
1
  import { Observable } from 'rxjs';
2
- import { Policy, PolicyDocumentationFetcher, PolicySchemaFetcher } from './models';
2
+ import { Policy, PolicyDocumentationFetcher, PolicySchemaFetcher } from '../models';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class GioPolicyStudioService {
5
5
  private schemasCache;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gravitee/ui-policy-studio-angular",
3
- "version": "12.14.0",
3
+ "version": "12.15.0",
4
4
  "description": "Gravitee.io - UI Policy Studio Angular",
5
5
  "repository": {
6
6
  "type": "git",
package/public-api.d.ts CHANGED
@@ -1,3 +1,2 @@
1
1
  export * from './lib/models';
2
- export { GioPolicyStudioModule } from './lib/gio-policy-studio.module';
3
- export { GioPolicyStudioComponent } from './lib/gio-policy-studio.component';
2
+ export { GioPolicyStudioComponent } from './lib/policy-studio/gio-policy-studio.component';
@@ -1,6 +1,6 @@
1
1
  import { ComponentHarness } from '@angular/cdk/testing';
2
- import { Flow, FlowExecution } from './models';
3
- import { GioPolicyStudioDetailsPhaseHarness, PhaseType } from './components/flow-details-phase/gio-ps-flow-details-phase.harness';
2
+ import { Flow, FlowExecution } from '../models';
3
+ import { GioPolicyStudioDetailsPhaseHarness, PhaseType } from '../components/flow-details-phase/gio-ps-flow-details-phase.harness';
4
4
  export declare class GioPolicyStudioHarness extends ComponentHarness {
5
5
  static hostSelector: string;
6
6
  private menuHarness;
@@ -1,2 +1,2 @@
1
1
  export * from './lib/models/index-testing';
2
- export * from './lib/gio-policy-studio.harness';
2
+ export * from './lib/policy-studio/gio-policy-studio.harness';
@@ -1,240 +0,0 @@
1
- /*
2
- * Copyright (C) 2022 The Gravitee team (http://gravitee.io)
3
- *
4
- * Licensed under the Apache License, Version 2.0 (the "License");
5
- * you may not use this file except in compliance with the License.
6
- * You may obtain a copy of the License at
7
- *
8
- * http://www.apache.org/licenses/LICENSE-2.0
9
- *
10
- * Unless required by applicable law or agreed to in writing, software
11
- * distributed under the License is distributed on an "AS IS" BASIS,
12
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- * See the License for the specific language governing permissions and
14
- * limitations under the License.
15
- */
16
- import { Component, EventEmitter, Input, Output } from '@angular/core';
17
- import { cloneDeep, differenceBy, flatten, isEqual, omit, unionBy, uniqueId } from 'lodash';
18
- import { EMPTY, timer } from 'rxjs';
19
- import * as i0 from "@angular/core";
20
- import * as i1 from "./gio-policy-studio.service";
21
- import * as i2 from "@angular/common";
22
- import * as i3 from "@angular/material/button";
23
- import * as i4 from "@angular/material/tooltip";
24
- import * as i5 from "@angular/material/icon";
25
- import * as i6 from "./components/flows-menu/gio-ps-flows-menu.component";
26
- import * as i7 from "./components/flow-details/gio-ps-flow-details.component";
27
- export class GioPolicyStudioComponent {
28
- constructor(policyStudioService) {
29
- this.policyStudioService = policyStudioService;
30
- /**
31
- * May be set to `true` if the API is not manageable from the UI (e.g. kubernetes operator APIs)
32
- */
33
- this.readOnly = false;
34
- /**
35
- * List of entrypoints to display
36
- */
37
- this.entrypointsInfo = [];
38
- /**
39
- * List of endpoints to display
40
- */
41
- this.endpointsInfo = [];
42
- /**
43
- * List of common flows to add to common flows group
44
- */
45
- this.commonFlows = [];
46
- /**
47
- * List of plans with their flows
48
- */
49
- this.plans = [];
50
- /**
51
- * List of policies usable in the policy studio
52
- */
53
- this.policies = [];
54
- /**
55
- * Loading state
56
- */
57
- this.loading = false;
58
- /**
59
- * Called when Policy Studio needs to fetch the policy schema
60
- * @returns Observable of the policy schema
61
- */
62
- this.policySchemaFetcher = () => EMPTY;
63
- /**
64
- * Called when Policy Studio needs to fetch the policy documentation
65
- * @returns Observable of the policy documentation
66
- */
67
- this.policyDocumentationFetcher = () => EMPTY;
68
- /**
69
- * Return what is needed to save.
70
- **/
71
- this.save = new EventEmitter();
72
- this.connectorsTooltip = '';
73
- this.selectedFlow = undefined;
74
- this.flowsGroups = [];
75
- this.disableSaveButton = true;
76
- this.saving = false;
77
- // Used to keep track of initial flows groups to know if there are deleted flows
78
- this.initialFlowsGroups = [];
79
- this.hasFlowExecutionChanged = false;
80
- this.enableSavingTimer = true;
81
- }
82
- ngOnChanges(changes) {
83
- if (changes.entrypointsInfo || changes.endpointsInfo) {
84
- this.connectorsTooltip = `Entrypoints: ${(this.entrypointsInfo ?? []).map(e => e.name).join(', ')}\nEndpoints: ${(this.endpointsInfo ?? [])
85
- .map(e => e.name)
86
- .join(', ')}`;
87
- }
88
- if (changes.commonFlows || changes.plans) {
89
- this.disableSaveButton = true;
90
- this.flowsGroups = getFlowsGroups(this.commonFlows, this.plans);
91
- this.initialFlowsGroups = cloneDeep(this.flowsGroups);
92
- // Select first flow by default on first load
93
- this.selectedFlow = flatten(this.flowsGroups.map(flowGroup => flowGroup.flows))[0];
94
- // Reset saving state when flowsGroups are updated
95
- this.saving = false;
96
- this.unSavingButtonSubscription?.unsubscribe();
97
- }
98
- if (changes.policySchemaFetcher) {
99
- this.policyStudioService.setPolicySchemaFetcher(this.policySchemaFetcher);
100
- }
101
- if (changes.policyDocumentationFetcher) {
102
- this.policyStudioService.setPolicyDocumentationFetcher(this.policyDocumentationFetcher);
103
- }
104
- }
105
- ngOnDestroy() {
106
- this.unSavingButtonSubscription?.unsubscribe();
107
- }
108
- onFlowExecutionChange(flowExecution) {
109
- this.hasFlowExecutionChanged = !isEqual(this.flowExecution, flowExecution);
110
- if (this.hasFlowExecutionChanged) {
111
- this.disableSaveButton = false;
112
- this.flowExecution = flowExecution;
113
- }
114
- }
115
- onFlowsGroupsChange(flowsGroups) {
116
- this.flowsGroups = flowsGroups;
117
- this.disableSaveButton = false;
118
- }
119
- onSelectedFlowChange(flow) {
120
- this.flowsGroups = this.flowsGroups.map(flowGroup => ({
121
- ...flowGroup,
122
- flows: flowGroup.flows.map(f => (f._id === flow._id ? flow : f)),
123
- }));
124
- this.selectedFlow = flow;
125
- this.disableSaveButton = false;
126
- }
127
- onDeleteSelectedFlow(flow) {
128
- // Define next selected flow and remove flow from flowsGroups
129
- const allFlowsId = flatten(this.flowsGroups.map(flowGroup => flowGroup.flows)).map(f => f._id);
130
- const flowToDeleteIndex = allFlowsId.indexOf(flow._id);
131
- const nextSelectedFlow = allFlowsId[flowToDeleteIndex + 1] ?? allFlowsId[flowToDeleteIndex - 1];
132
- this.flowsGroups = this.flowsGroups.map(flowGroup => ({
133
- ...flowGroup,
134
- flows: flowGroup.flows.filter(f => f._id !== flow._id),
135
- }));
136
- this.selectedFlow = flatten(this.flowsGroups.map(flowGroup => flowGroup.flows)).find(f => f._id === nextSelectedFlow);
137
- this.disableSaveButton = false;
138
- }
139
- onSave() {
140
- // Emit common flows only if they have been updated
141
- const commonFlows = getCommonFlowsOutput(this.flowsGroups, this.initialFlowsGroups);
142
- // Emit plans only if they have been updated
143
- const plansToUpdate = getPlansChangeOutput(this.flowsGroups, this.initialFlowsGroups);
144
- this.save.emit({
145
- ...(commonFlows ? { commonFlows } : {}),
146
- ...(plansToUpdate ? { plansToUpdate } : {}),
147
- ...(this.hasFlowExecutionChanged ? { flowExecution: this.flowExecution } : {}),
148
- });
149
- this.saving = true;
150
- this.unSavingButtonSubscription?.unsubscribe();
151
- if (this.enableSavingTimer) {
152
- this.unSavingButtonSubscription = timer(5000).subscribe(() => {
153
- this.saving = false;
154
- });
155
- }
156
- }
157
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: GioPolicyStudioComponent, deps: [{ token: i1.GioPolicyStudioService }], target: i0.ɵɵFactoryTarget.Component }); }
158
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: GioPolicyStudioComponent, selector: "gio-policy-studio", inputs: { readOnly: "readOnly", apiType: "apiType", flowExecution: "flowExecution", entrypointsInfo: "entrypointsInfo", endpointsInfo: "endpointsInfo", commonFlows: "commonFlows", plans: "plans", policies: "policies", trialUrl: "trialUrl", loading: "loading", policySchemaFetcher: "policySchemaFetcher", policyDocumentationFetcher: "policyDocumentationFetcher" }, outputs: { save: "save" }, usesOnChanges: true, ngImport: i0, template: "<!--\n\n Copyright (C) 2015 The Gravitee team (http://gravitee.io)\n\n Licensed under the Apache License, Version 2.0 (the \"License\");\n you may not use this file except in compliance with the License.\n You may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\n Unless required by applicable law or agreed to in writing, software\n distributed under the License is distributed on an \"AS IS\" BASIS,\n WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n See the License for the specific language governing permissions and\n limitations under the License.\n\n-->\n\n<div class=\"header\">\n <div class=\"header__apiInfo\" *ngIf=\"!loading; else loadingApiInfo\">\n <span class=\"gio-badge-primary\">\n {{ apiType | titlecase }}\n </span>\n <span\n class=\"gio-badge-neutral\"\n [matTooltip]=\"connectorsTooltip\"\n matTooltipPosition=\"right\"\n matTooltipClass=\"gio-policy-studio__tooltip-line-break\"\n >\n <mat-icon *ngFor=\"let entrypoint of entrypointsInfo\" class=\"gio-left\" [svgIcon]=\"entrypoint.icon\"></mat-icon>\n <mat-icon *ngFor=\"let endpoint of endpointsInfo\" class=\"gio-left\" [svgIcon]=\"endpoint.icon\"></mat-icon>\n </span>\n </div>\n <ng-template #loadingApiInfo>\n <div class=\"header__apiInfo\">\n <span class=\"gio-badge-primary\">&nbsp;</span>\n <span class=\"gio-badge-neutral\">&nbsp;</span>\n </div>\n </ng-template>\n\n <div class=\"header__btn\">\n <button *ngIf=\"!saving\" mat-flat-button color=\"primary\" [disabled]=\"loading || disableSaveButton\" (click)=\"onSave()\">Save</button>\n <button *ngIf=\"saving\" mat-flat-button color=\"primary\" disabled>Saving...</button>\n </div>\n</div>\n\n<div class=\"wrapper\">\n <div class=\"wrapper__flowsMenu\">\n <gio-ps-flows-menu\n [readOnly]=\"readOnly\"\n [loading]=\"loading\"\n [apiType]=\"apiType\"\n [flowExecution]=\"flowExecution\"\n [flowsGroups]=\"flowsGroups\"\n [entrypoints]=\"entrypointsInfo\"\n (flowsGroupsChange)=\"onFlowsGroupsChange($event)\"\n (flowExecutionChange)=\"onFlowExecutionChange($event)\"\n [(selectedFlow)]=\"selectedFlow\"\n ></gio-ps-flows-menu>\n </div>\n\n <div class=\"wrapper__flowDetails\">\n <gio-ps-flow-details\n [readOnly]=\"readOnly\"\n [loading]=\"loading\"\n [apiType]=\"apiType\"\n [flow]=\"selectedFlow\"\n [entrypointsInfo]=\"entrypointsInfo\"\n [endpointsInfo]=\"endpointsInfo\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n (flowChange)=\"onSelectedFlowChange($event)\"\n (deleteFlow)=\"onDeleteSelectedFlow($event)\"\n ></gio-ps-flow-details>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.gio-top-bar-menu .gio-badge-accent{background-color:var(--gio-oem-palette--active, #e7e2fb);color:var(--gio-oem-palette--active-contrast, #100c27)}:host{display:flex;height:100%;flex-direction:column;padding:16px;background-color:#fff}::ng-deep .gio-policy-studio__tooltip-line-break{white-space:pre-line}.header{display:flex;align-items:center;padding-bottom:16px}.header__apiInfo{flex:1 1 auto}.wrapper{display:flex;min-height:0;flex:1 1 auto;flex-direction:row;gap:16px}.wrapper__flowsMenu{overflow:hidden;min-width:230px;max-width:400px;flex:1 1 33%;border:1px solid #d3d5dc;border-radius:8px}.wrapper__flowDetails{overflow:hidden;flex:1 1 66%;border:1px solid #d3d5dc;border-radius:8px}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.GioPolicyStudioFlowsMenuComponent, selector: "gio-ps-flows-menu", inputs: ["readOnly", "loading", "apiType", "flowExecution", "flowsGroups", "selectedFlow", "entrypoints"], outputs: ["selectedFlowChange", "flowsGroupsChange", "flowExecutionChange"] }, { kind: "component", type: i7.GioPolicyStudioDetailsComponent, selector: "gio-ps-flow-details", inputs: ["readOnly", "loading", "apiType", "flow", "entrypointsInfo", "endpointsInfo", "policies", "trialUrl"], outputs: ["flowChange", "deleteFlow"] }, { kind: "pipe", type: i2.TitleCasePipe, name: "titlecase" }] }); }
159
- }
160
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: GioPolicyStudioComponent, decorators: [{
161
- type: Component,
162
- args: [{ selector: 'gio-policy-studio', template: "<!--\n\n Copyright (C) 2015 The Gravitee team (http://gravitee.io)\n\n Licensed under the Apache License, Version 2.0 (the \"License\");\n you may not use this file except in compliance with the License.\n You may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\n Unless required by applicable law or agreed to in writing, software\n distributed under the License is distributed on an \"AS IS\" BASIS,\n WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n See the License for the specific language governing permissions and\n limitations under the License.\n\n-->\n\n<div class=\"header\">\n <div class=\"header__apiInfo\" *ngIf=\"!loading; else loadingApiInfo\">\n <span class=\"gio-badge-primary\">\n {{ apiType | titlecase }}\n </span>\n <span\n class=\"gio-badge-neutral\"\n [matTooltip]=\"connectorsTooltip\"\n matTooltipPosition=\"right\"\n matTooltipClass=\"gio-policy-studio__tooltip-line-break\"\n >\n <mat-icon *ngFor=\"let entrypoint of entrypointsInfo\" class=\"gio-left\" [svgIcon]=\"entrypoint.icon\"></mat-icon>\n <mat-icon *ngFor=\"let endpoint of endpointsInfo\" class=\"gio-left\" [svgIcon]=\"endpoint.icon\"></mat-icon>\n </span>\n </div>\n <ng-template #loadingApiInfo>\n <div class=\"header__apiInfo\">\n <span class=\"gio-badge-primary\">&nbsp;</span>\n <span class=\"gio-badge-neutral\">&nbsp;</span>\n </div>\n </ng-template>\n\n <div class=\"header__btn\">\n <button *ngIf=\"!saving\" mat-flat-button color=\"primary\" [disabled]=\"loading || disableSaveButton\" (click)=\"onSave()\">Save</button>\n <button *ngIf=\"saving\" mat-flat-button color=\"primary\" disabled>Saving...</button>\n </div>\n</div>\n\n<div class=\"wrapper\">\n <div class=\"wrapper__flowsMenu\">\n <gio-ps-flows-menu\n [readOnly]=\"readOnly\"\n [loading]=\"loading\"\n [apiType]=\"apiType\"\n [flowExecution]=\"flowExecution\"\n [flowsGroups]=\"flowsGroups\"\n [entrypoints]=\"entrypointsInfo\"\n (flowsGroupsChange)=\"onFlowsGroupsChange($event)\"\n (flowExecutionChange)=\"onFlowExecutionChange($event)\"\n [(selectedFlow)]=\"selectedFlow\"\n ></gio-ps-flows-menu>\n </div>\n\n <div class=\"wrapper__flowDetails\">\n <gio-ps-flow-details\n [readOnly]=\"readOnly\"\n [loading]=\"loading\"\n [apiType]=\"apiType\"\n [flow]=\"selectedFlow\"\n [entrypointsInfo]=\"entrypointsInfo\"\n [endpointsInfo]=\"endpointsInfo\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n (flowChange)=\"onSelectedFlowChange($event)\"\n (deleteFlow)=\"onDeleteSelectedFlow($event)\"\n ></gio-ps-flow-details>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.gio-top-bar-menu .gio-badge-accent{background-color:var(--gio-oem-palette--active, #e7e2fb);color:var(--gio-oem-palette--active-contrast, #100c27)}:host{display:flex;height:100%;flex-direction:column;padding:16px;background-color:#fff}::ng-deep .gio-policy-studio__tooltip-line-break{white-space:pre-line}.header{display:flex;align-items:center;padding-bottom:16px}.header__apiInfo{flex:1 1 auto}.wrapper{display:flex;min-height:0;flex:1 1 auto;flex-direction:row;gap:16px}.wrapper__flowsMenu{overflow:hidden;min-width:230px;max-width:400px;flex:1 1 33%;border:1px solid #d3d5dc;border-radius:8px}.wrapper__flowDetails{overflow:hidden;flex:1 1 66%;border:1px solid #d3d5dc;border-radius:8px}\n"] }]
163
- }], ctorParameters: () => [{ type: i1.GioPolicyStudioService }], propDecorators: { readOnly: [{
164
- type: Input
165
- }], apiType: [{
166
- type: Input
167
- }], flowExecution: [{
168
- type: Input
169
- }], entrypointsInfo: [{
170
- type: Input
171
- }], endpointsInfo: [{
172
- type: Input
173
- }], commonFlows: [{
174
- type: Input
175
- }], plans: [{
176
- type: Input
177
- }], policies: [{
178
- type: Input
179
- }], trialUrl: [{
180
- type: Input
181
- }], loading: [{
182
- type: Input
183
- }], policySchemaFetcher: [{
184
- type: Input
185
- }], policyDocumentationFetcher: [{
186
- type: Input
187
- }], save: [{
188
- type: Output
189
- }] } });
190
- const getFlowsGroups = (commonFlows = [], plans = []) => {
191
- const commFlowsGroup = {
192
- _id: 'flowsGroup_commonFlow',
193
- name: 'Common flows',
194
- flows: commonFlows.map(flow => ({ ...flow, _id: uniqueId('flow_'), _hasChanged: false })),
195
- };
196
- return [
197
- ...plans.map(plan => ({
198
- _id: uniqueId('flowsGroup_'),
199
- _icon: 'gio:shield',
200
- _planId: plan.id,
201
- name: plan.name,
202
- flows: plan.flows.map(flow => ({ ...flow, _id: uniqueId('flow_'), _hasChanged: false })),
203
- })),
204
- commFlowsGroup,
205
- ];
206
- };
207
- const getCommonFlowsOutput = (flowsGroups, initialFlowsGroups) => {
208
- const commonFlowsGroup = flowsGroups.find(flowGroup => flowGroup._id === 'flowsGroup_commonFlow');
209
- const initialCommonFlowsGroup = initialFlowsGroups.find(flowGroup => flowGroup._id === 'flowsGroup_commonFlow');
210
- // Check if common flows have been updated
211
- const hasChanged = commonFlowsGroup?.flows.some(flow => flow._hasChanged);
212
- // Check if common flows have been deleted
213
- const hasDeletedFlow = differenceBy(initialCommonFlowsGroup?.flows ?? [], commonFlowsGroup?.flows ?? [], '_id').length > 0;
214
- return hasChanged || hasDeletedFlow ? (commonFlowsGroup?.flows ?? []).map(flow => omit(flow, '_id', '_hasChanged')) : null;
215
- };
216
- const getPlansChangeOutput = (flowsGroups, initialFlowsGroups) => {
217
- const plansGroups = flowsGroups.filter(flowGroup => flowGroup._id !== 'flowsGroup_commonFlow');
218
- const initialPlansGroups = initialFlowsGroups.filter(flowGroup => flowGroup._id !== 'flowsGroup_commonFlow');
219
- // Get plans with changed flows
220
- const plansGroupsWithChangedFlows = plansGroups.filter(plan => plan.flows.some(flow => flow._hasChanged));
221
- // Get plans with deleted flows
222
- const plansGroupsWithDeletedFlows = [];
223
- // Check if there are deleted flows in initial initialPlansGroups
224
- initialPlansGroups.forEach(plan => {
225
- const planGroupToCompare = plansGroups.find(p => p._planId === plan._planId);
226
- if (planGroupToCompare && differenceBy(plan.flows, planGroupToCompare?.flows ?? [], '_id').length > 0) {
227
- // If there are deleted flows, we need to return the complete plan with the new flows
228
- plansGroupsWithDeletedFlows.push(planGroupToCompare);
229
- }
230
- });
231
- // Merge plans with changed flows and plans with deleted flows
232
- const plansWithChangedFlowsOutput = unionBy([...plansGroupsWithChangedFlows, ...plansGroupsWithDeletedFlows], '_planId').map(plan => ({
233
- ...omit(plan, '_id', '_icon', '_planId'),
234
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- planId is always defined
235
- id: plan._planId,
236
- flows: plan.flows.map(flow => omit(flow, '_id', '_hasChanged')),
237
- }));
238
- return plansWithChangedFlowsOutput.length > 0 ? plansWithChangedFlowsOutput : null;
239
- };
240
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gio-policy-studio.component.js","sourceRoot":"","sources":["../../../../projects/ui-policy-studio-angular/src/lib/gio-policy-studio.component.ts","../../../../projects/ui-policy-studio-angular/src/lib/gio-policy-studio.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (C) 2022 The Gravitee team (http://gravitee.io)\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *         http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { Component, EventEmitter, Input, OnChanges, OnDestroy, Output, SimpleChanges } from '@angular/core';\nimport { cloneDeep, differenceBy, flatten, isEqual, omit, unionBy, uniqueId } from 'lodash';\nimport { EMPTY, Subscription, timer } from 'rxjs';\n\nimport {\n  ApiType,\n  ConnectorInfo,\n  Flow,\n  FlowExecution,\n  Plan,\n  Policy,\n  PolicyDocumentationFetcher,\n  PolicySchemaFetcher,\n  SaveOutput,\n} from './models';\nimport { FlowGroupVM, FlowVM } from './gio-policy-studio.model';\nimport { GioPolicyStudioService } from './gio-policy-studio.service';\n\n@Component({\n  selector: 'gio-policy-studio',\n  templateUrl: './gio-policy-studio.component.html',\n  styleUrls: ['./gio-policy-studio.component.scss'],\n})\nexport class GioPolicyStudioComponent implements OnChanges, OnDestroy {\n  /**\n   * May be set to `true` if the API is not manageable from the UI (e.g. kubernetes operator APIs)\n   */\n  @Input()\n  public readOnly = false;\n\n  /**\n   * API type (required)\n   */\n  @Input()\n  public apiType!: ApiType;\n\n  /**\n   * Flow execution config (required)\n   */\n  @Input()\n  public flowExecution!: FlowExecution;\n\n  /**\n   * List of entrypoints to display\n   */\n  @Input()\n  public entrypointsInfo: ConnectorInfo[] = [];\n\n  /**\n   * List of endpoints to display\n   */\n  @Input()\n  public endpointsInfo: ConnectorInfo[] = [];\n\n  /**\n   * List of common flows to add to common flows group\n   */\n  @Input()\n  public commonFlows: Flow[] = [];\n\n  /**\n   * List of plans with their flows\n   */\n  @Input()\n  public plans: Plan[] = [];\n\n  /**\n   * List of policies usable in the policy studio\n   */\n  @Input()\n  public policies: Policy[] = [];\n\n  /**\n   * When a policy is not available with the current license,\n   * this URL is used to redirect the user to the trial page.\n   */\n  @Input()\n  public trialUrl?: string;\n\n  /**\n   * Loading state\n   */\n  @Input()\n  public loading = false;\n\n  /**\n   * Called when Policy Studio needs to fetch the policy schema\n   * @returns Observable of the policy schema\n   */\n  @Input()\n  public policySchemaFetcher: PolicySchemaFetcher = () => EMPTY;\n\n  /**\n   * Called when Policy Studio needs to fetch the policy documentation\n   * @returns Observable of the policy documentation\n   */\n  @Input()\n  public policyDocumentationFetcher: PolicyDocumentationFetcher = () => EMPTY;\n\n  /**\n   * Return what is needed to save.\n   **/\n  @Output()\n  public save = new EventEmitter<SaveOutput>();\n\n  public connectorsTooltip = '';\n\n  public selectedFlow?: FlowVM = undefined;\n\n  public flowsGroups: FlowGroupVM[] = [];\n\n  public disableSaveButton = true;\n\n  public saving = false;\n\n  // Used to keep track of initial flows groups to know if there are deleted flows\n  private initialFlowsGroups: FlowGroupVM[] = [];\n\n  private hasFlowExecutionChanged = false;\n\n  private unSavingButtonSubscription?: Subscription;\n  public enableSavingTimer = true;\n\n  constructor(private readonly policyStudioService: GioPolicyStudioService) {}\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.entrypointsInfo || changes.endpointsInfo) {\n      this.connectorsTooltip = `Entrypoints: ${(this.entrypointsInfo ?? []).map(e => e.name).join(', ')}\\nEndpoints: ${(\n        this.endpointsInfo ?? []\n      )\n        .map(e => e.name)\n        .join(', ')}`;\n    }\n\n    if (changes.commonFlows || changes.plans) {\n      this.disableSaveButton = true;\n      this.flowsGroups = getFlowsGroups(this.commonFlows, this.plans);\n      this.initialFlowsGroups = cloneDeep(this.flowsGroups);\n\n      // Select first flow by default on first load\n      this.selectedFlow = flatten(this.flowsGroups.map(flowGroup => flowGroup.flows))[0];\n\n      // Reset saving state when flowsGroups are updated\n      this.saving = false;\n      this.unSavingButtonSubscription?.unsubscribe();\n    }\n\n    if (changes.policySchemaFetcher) {\n      this.policyStudioService.setPolicySchemaFetcher(this.policySchemaFetcher);\n    }\n\n    if (changes.policyDocumentationFetcher) {\n      this.policyStudioService.setPolicyDocumentationFetcher(this.policyDocumentationFetcher);\n    }\n  }\n\n  public ngOnDestroy() {\n    this.unSavingButtonSubscription?.unsubscribe();\n  }\n\n  public onFlowExecutionChange(flowExecution: FlowExecution): void {\n    this.hasFlowExecutionChanged = !isEqual(this.flowExecution, flowExecution);\n    if (this.hasFlowExecutionChanged) {\n      this.disableSaveButton = false;\n      this.flowExecution = flowExecution;\n    }\n  }\n\n  public onFlowsGroupsChange(flowsGroups: FlowGroupVM[]): void {\n    this.flowsGroups = flowsGroups;\n    this.disableSaveButton = false;\n  }\n\n  public onSelectedFlowChange(flow: FlowVM): void {\n    this.flowsGroups = this.flowsGroups.map(flowGroup => ({\n      ...flowGroup,\n      flows: flowGroup.flows.map(f => (f._id === flow._id ? flow : f)),\n    }));\n    this.selectedFlow = flow;\n    this.disableSaveButton = false;\n  }\n\n  public onDeleteSelectedFlow(flow: FlowVM): void {\n    // Define next selected flow and remove flow from flowsGroups\n    const allFlowsId = flatten(this.flowsGroups.map(flowGroup => flowGroup.flows)).map(f => f._id);\n    const flowToDeleteIndex = allFlowsId.indexOf(flow._id);\n    const nextSelectedFlow = allFlowsId[flowToDeleteIndex + 1] ?? allFlowsId[flowToDeleteIndex - 1];\n    this.flowsGroups = this.flowsGroups.map(flowGroup => ({\n      ...flowGroup,\n      flows: flowGroup.flows.filter(f => f._id !== flow._id),\n    }));\n\n    this.selectedFlow = flatten(this.flowsGroups.map(flowGroup => flowGroup.flows)).find(f => f._id === nextSelectedFlow);\n\n    this.disableSaveButton = false;\n  }\n\n  public onSave(): void {\n    // Emit common flows only if they have been updated\n    const commonFlows = getCommonFlowsOutput(this.flowsGroups, this.initialFlowsGroups);\n\n    // Emit plans only if they have been updated\n    const plansToUpdate = getPlansChangeOutput(this.flowsGroups, this.initialFlowsGroups);\n\n    this.save.emit({\n      ...(commonFlows ? { commonFlows } : {}),\n      ...(plansToUpdate ? { plansToUpdate } : {}),\n      ...(this.hasFlowExecutionChanged ? { flowExecution: this.flowExecution } : {}),\n    });\n    this.saving = true;\n\n    this.unSavingButtonSubscription?.unsubscribe();\n    if (this.enableSavingTimer) {\n      this.unSavingButtonSubscription = timer(5000).subscribe(() => {\n        this.saving = false;\n      });\n    }\n  }\n}\n\nconst getFlowsGroups = (commonFlows: Flow[] = [], plans: Plan[] = []): FlowGroupVM[] => {\n  const commFlowsGroup: FlowGroupVM = {\n    _id: 'flowsGroup_commonFlow',\n    name: 'Common flows',\n    flows: commonFlows.map(flow => ({ ...flow, _id: uniqueId('flow_'), _hasChanged: false })),\n  };\n\n  return [\n    ...plans.map(plan => ({\n      _id: uniqueId('flowsGroup_'),\n      _icon: 'gio:shield',\n      _planId: plan.id,\n      name: plan.name,\n      flows: plan.flows.map(flow => ({ ...flow, _id: uniqueId('flow_'), _hasChanged: false })),\n    })),\n    commFlowsGroup,\n  ];\n};\n\nconst getCommonFlowsOutput = (flowsGroups: FlowGroupVM[], initialFlowsGroups: FlowGroupVM[]): Flow[] | null => {\n  const commonFlowsGroup = flowsGroups.find(flowGroup => flowGroup._id === 'flowsGroup_commonFlow');\n  const initialCommonFlowsGroup = initialFlowsGroups.find(flowGroup => flowGroup._id === 'flowsGroup_commonFlow');\n  // Check if common flows have been updated\n  const hasChanged = commonFlowsGroup?.flows.some(flow => flow._hasChanged);\n\n  // Check if common flows have been deleted\n  const hasDeletedFlow = differenceBy(initialCommonFlowsGroup?.flows ?? [], commonFlowsGroup?.flows ?? [], '_id').length > 0;\n\n  return hasChanged || hasDeletedFlow ? (commonFlowsGroup?.flows ?? []).map(flow => omit(flow, '_id', '_hasChanged')) : null;\n};\n\nconst getPlansChangeOutput = (flowsGroups: FlowGroupVM[], initialFlowsGroups: FlowGroupVM[]): Plan[] | null => {\n  const plansGroups = flowsGroups.filter(flowGroup => flowGroup._id !== 'flowsGroup_commonFlow');\n  const initialPlansGroups = initialFlowsGroups.filter(flowGroup => flowGroup._id !== 'flowsGroup_commonFlow');\n\n  // Get plans with changed flows\n  const plansGroupsWithChangedFlows = plansGroups.filter(plan => plan.flows.some(flow => flow._hasChanged));\n\n  // Get plans with deleted flows\n  const plansGroupsWithDeletedFlows: FlowGroupVM[] = [];\n\n  // Check if there are deleted flows in initial initialPlansGroups\n  initialPlansGroups.forEach(plan => {\n    const planGroupToCompare = plansGroups.find(p => p._planId === plan._planId);\n    if (planGroupToCompare && differenceBy(plan.flows, planGroupToCompare?.flows ?? [], '_id').length > 0) {\n      // If there are deleted flows, we need to return the complete plan with the new flows\n      plansGroupsWithDeletedFlows.push(planGroupToCompare);\n    }\n  });\n\n  // Merge plans with changed flows and plans with deleted flows\n  const plansWithChangedFlowsOutput = unionBy([...plansGroupsWithChangedFlows, ...plansGroupsWithDeletedFlows], '_planId').map(plan => ({\n    ...omit(plan, '_id', '_icon', '_planId'),\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- planId is always defined\n    id: plan._planId!,\n    flows: plan.flows.map(flow => omit(flow, '_id', '_hasChanged')),\n  }));\n\n  return plansWithChangedFlowsOutput.length > 0 ? plansWithChangedFlowsOutput : null;\n};\n","<!--\n\n    Copyright (C) 2015 The Gravitee team (http://gravitee.io)\n\n    Licensed under the Apache License, Version 2.0 (the \"License\");\n    you may not use this file except in compliance with the License.\n    You may obtain a copy of the License at\n\n            http://www.apache.org/licenses/LICENSE-2.0\n\n    Unless required by applicable law or agreed to in writing, software\n    distributed under the License is distributed on an \"AS IS\" BASIS,\n    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n    See the License for the specific language governing permissions and\n    limitations under the License.\n\n-->\n\n<div class=\"header\">\n  <div class=\"header__apiInfo\" *ngIf=\"!loading; else loadingApiInfo\">\n    <span class=\"gio-badge-primary\">\n      {{ apiType | titlecase }}\n    </span>\n    <span\n      class=\"gio-badge-neutral\"\n      [matTooltip]=\"connectorsTooltip\"\n      matTooltipPosition=\"right\"\n      matTooltipClass=\"gio-policy-studio__tooltip-line-break\"\n    >\n      <mat-icon *ngFor=\"let entrypoint of entrypointsInfo\" class=\"gio-left\" [svgIcon]=\"entrypoint.icon\"></mat-icon>\n      <mat-icon *ngFor=\"let endpoint of endpointsInfo\" class=\"gio-left\" [svgIcon]=\"endpoint.icon\"></mat-icon>\n    </span>\n  </div>\n  <ng-template #loadingApiInfo>\n    <div class=\"header__apiInfo\">\n      <span class=\"gio-badge-primary\">&nbsp;</span>\n      <span class=\"gio-badge-neutral\">&nbsp;</span>\n    </div>\n  </ng-template>\n\n  <div class=\"header__btn\">\n    <button *ngIf=\"!saving\" mat-flat-button color=\"primary\" [disabled]=\"loading || disableSaveButton\" (click)=\"onSave()\">Save</button>\n    <button *ngIf=\"saving\" mat-flat-button color=\"primary\" disabled>Saving...</button>\n  </div>\n</div>\n\n<div class=\"wrapper\">\n  <div class=\"wrapper__flowsMenu\">\n    <gio-ps-flows-menu\n      [readOnly]=\"readOnly\"\n      [loading]=\"loading\"\n      [apiType]=\"apiType\"\n      [flowExecution]=\"flowExecution\"\n      [flowsGroups]=\"flowsGroups\"\n      [entrypoints]=\"entrypointsInfo\"\n      (flowsGroupsChange)=\"onFlowsGroupsChange($event)\"\n      (flowExecutionChange)=\"onFlowExecutionChange($event)\"\n      [(selectedFlow)]=\"selectedFlow\"\n    ></gio-ps-flows-menu>\n  </div>\n\n  <div class=\"wrapper__flowDetails\">\n    <gio-ps-flow-details\n      [readOnly]=\"readOnly\"\n      [loading]=\"loading\"\n      [apiType]=\"apiType\"\n      [flow]=\"selectedFlow\"\n      [entrypointsInfo]=\"entrypointsInfo\"\n      [endpointsInfo]=\"endpointsInfo\"\n      [policies]=\"policies\"\n      [trialUrl]=\"trialUrl\"\n      (flowChange)=\"onSelectedFlowChange($event)\"\n      (deleteFlow)=\"onDeleteSelectedFlow($event)\"\n    ></gio-ps-flow-details>\n  </div>\n</div>\n"]}
@@ -1,17 +0,0 @@
1
- /*
2
- * Copyright (C) 2022 The Gravitee team (http://gravitee.io)
3
- *
4
- * Licensed under the Apache License, Version 2.0 (the "License");
5
- * you may not use this file except in compliance with the License.
6
- * You may obtain a copy of the License at
7
- *
8
- * http://www.apache.org/licenses/LICENSE-2.0
9
- *
10
- * Unless required by applicable law or agreed to in writing, software
11
- * distributed under the License is distributed on an "AS IS" BASIS,
12
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- * See the License for the specific language governing permissions and
14
- * limitations under the License.
15
- */
16
- export {};
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2lvLXBvbGljeS1zdHVkaW8ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1wb2xpY3ktc3R1ZGlvLWFuZ3VsYXIvc3JjL2xpYi9naW8tcG9saWN5LXN0dWRpby5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7R0FjRyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKEMpIDIwMjIgVGhlIEdyYXZpdGVlIHRlYW0gKGh0dHA6Ly9ncmF2aXRlZS5pbylcbiAqXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogICAgICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbmltcG9ydCB7IEZsb3cgfSBmcm9tICcuL21vZGVscyc7XG5cbi8vIE1vZGVsIHVzZWQgaW50ZXJuYWxseSBieSB0aGUgY29tcG9uZW50IGFuZCBpdCdzIGNoaWxkcmVuXG5leHBvcnQgaW50ZXJmYWNlIEZsb3dWTSBleHRlbmRzIEZsb3cge1xuICBfaWQ6IHN0cmluZztcbiAgX2hhc0NoYW5nZWQ6IGJvb2xlYW47XG59XG5leHBvcnQgaW50ZXJmYWNlIEZsb3dHcm91cFZNIHtcbiAgX2lkOiBzdHJpbmc7XG4gIF9pY29uPzogc3RyaW5nO1xuICBfcGxhbklkPzogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGZsb3dzOiBGbG93Vk1bXTtcbn1cbiJdfQ==