@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
@@ -31,12 +31,13 @@ export class GioFilterConnectorsByModePipe {
31
31
  return [];
32
32
  }
33
33
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: GioFilterConnectorsByModePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
34
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.3", ngImport: i0, type: GioFilterConnectorsByModePipe, name: "gioFilterConnectorsByMode" }); }
34
+ static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.3", ngImport: i0, type: GioFilterConnectorsByModePipe, isStandalone: true, name: "gioFilterConnectorsByMode" }); }
35
35
  }
36
36
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: GioFilterConnectorsByModePipe, decorators: [{
37
37
  type: Pipe,
38
38
  args: [{
39
+ standalone: true,
39
40
  name: 'gioFilterConnectorsByMode',
40
41
  }]
41
42
  }] });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2lvLWZsdGVyLWNvbm5lY3RvcnMtYnktbW9kZS5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktcG9saWN5LXN0dWRpby1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9maWx0ZXItcGlwZS9naW8tZmx0ZXItY29ubmVjdG9ycy1ieS1tb2RlLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0dBY0c7QUFDSCxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxNQUFNLFFBQVEsQ0FBQzs7QUFPekMsTUFBTSxPQUFPLDZCQUE2QjtJQUNqQyxTQUFTLENBQUMsS0FBc0IsRUFBRSxJQUFtQixFQUFFLGNBQStCLEVBQUU7UUFDN0YsSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUNWLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztnQkFDVixPQUFPLEtBQUssQ0FBQztZQUNmLENBQUM7WUFFRCxJQUFJLE9BQU8sQ0FBQyxXQUFXLENBQUMsSUFBSSxXQUFXLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7Z0JBQ3ZELE9BQU8sTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLElBQW1CLEVBQUUsRUFBRTtvQkFDM0MsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDNUMsQ0FBQyxDQUFDLENBQUM7WUFDTCxDQUFDO1FBQ0gsQ0FBQztRQUNELE9BQU8sRUFBRSxDQUFDO0lBQ1osQ0FBQzs4R0FkVSw2QkFBNkI7NEdBQTdCLDZCQUE2Qjs7MkZBQTdCLDZCQUE2QjtrQkFIekMsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsMkJBQTJCO2lCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKEMpIDIwMjMgVGhlIEdyYXZpdGVlIHRlYW0gKGh0dHA6Ly9ncmF2aXRlZS5pbylcbiAqXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogICAgICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5pbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBmaWx0ZXIsIGlzRW1wdHkgfSBmcm9tICdsb2Rhc2gnO1xuXG5pbXBvcnQgeyBDb25uZWN0b3JJbmZvLCBDb25uZWN0b3JNb2RlIH0gZnJvbSAnLi4vLi4vbW9kZWxzJztcblxuQFBpcGUoe1xuICBuYW1lOiAnZ2lvRmlsdGVyQ29ubmVjdG9yc0J5TW9kZScsXG59KVxuZXhwb3J0IGNsYXNzIEdpb0ZpbHRlckNvbm5lY3RvcnNCeU1vZGVQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHB1YmxpYyB0cmFuc2Zvcm0oaXRlbXM6IENvbm5lY3RvckluZm9bXSwgbW9kZTogQ29ubmVjdG9yTW9kZSwgYWN0aXZlTW9kZXM6IENvbm5lY3Rvck1vZGVbXSA9IFtdKTogQ29ubmVjdG9ySW5mb1tdIHtcbiAgICBpZiAoaXRlbXMpIHtcbiAgICAgIGlmICghbW9kZSkge1xuICAgICAgICByZXR1cm4gaXRlbXM7XG4gICAgICB9XG5cbiAgICAgIGlmIChpc0VtcHR5KGFjdGl2ZU1vZGVzKSB8fCBhY3RpdmVNb2Rlcy5pbmNsdWRlcyhtb2RlKSkge1xuICAgICAgICByZXR1cm4gZmlsdGVyKGl0ZW1zLCAoaXRlbTogQ29ubmVjdG9ySW5mbykgPT4ge1xuICAgICAgICAgIHJldHVybiBpdGVtLnN1cHBvcnRlZE1vZGVzLmluY2x1ZGVzKG1vZGUpO1xuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIFtdO1xuICB9XG59XG4iXX0=
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2lvLWZsdGVyLWNvbm5lY3RvcnMtYnktbW9kZS5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktcG9saWN5LXN0dWRpby1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9maWx0ZXItcGlwZS9naW8tZmx0ZXItY29ubmVjdG9ycy1ieS1tb2RlLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0dBY0c7QUFDSCxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxNQUFNLFFBQVEsQ0FBQzs7QUFRekMsTUFBTSxPQUFPLDZCQUE2QjtJQUNqQyxTQUFTLENBQUMsS0FBc0IsRUFBRSxJQUFtQixFQUFFLGNBQStCLEVBQUU7UUFDN0YsSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUNWLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztnQkFDVixPQUFPLEtBQUssQ0FBQztZQUNmLENBQUM7WUFFRCxJQUFJLE9BQU8sQ0FBQyxXQUFXLENBQUMsSUFBSSxXQUFXLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7Z0JBQ3ZELE9BQU8sTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLElBQW1CLEVBQUUsRUFBRTtvQkFDM0MsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDNUMsQ0FBQyxDQUFDLENBQUM7WUFDTCxDQUFDO1FBQ0gsQ0FBQztRQUNELE9BQU8sRUFBRSxDQUFDO0lBQ1osQ0FBQzs4R0FkVSw2QkFBNkI7NEdBQTdCLDZCQUE2Qjs7MkZBQTdCLDZCQUE2QjtrQkFKekMsSUFBSTttQkFBQztvQkFDSixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFLDJCQUEyQjtpQkFDbEMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChDKSAyMDIzIFRoZSBHcmF2aXRlZSB0ZWFtIChodHRwOi8vZ3Jhdml0ZWUuaW8pXG4gKlxuICogTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZVwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqICAgICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxuICogV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gKiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZmlsdGVyLCBpc0VtcHR5IH0gZnJvbSAnbG9kYXNoJztcblxuaW1wb3J0IHsgQ29ubmVjdG9ySW5mbywgQ29ubmVjdG9yTW9kZSB9IGZyb20gJy4uLy4uL21vZGVscyc7XG5cbkBQaXBlKHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgbmFtZTogJ2dpb0ZpbHRlckNvbm5lY3RvcnNCeU1vZGUnLFxufSlcbmV4cG9ydCBjbGFzcyBHaW9GaWx0ZXJDb25uZWN0b3JzQnlNb2RlUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICBwdWJsaWMgdHJhbnNmb3JtKGl0ZW1zOiBDb25uZWN0b3JJbmZvW10sIG1vZGU6IENvbm5lY3Rvck1vZGUsIGFjdGl2ZU1vZGVzOiBDb25uZWN0b3JNb2RlW10gPSBbXSk6IENvbm5lY3RvckluZm9bXSB7XG4gICAgaWYgKGl0ZW1zKSB7XG4gICAgICBpZiAoIW1vZGUpIHtcbiAgICAgICAgcmV0dXJuIGl0ZW1zO1xuICAgICAgfVxuXG4gICAgICBpZiAoaXNFbXB0eShhY3RpdmVNb2RlcykgfHwgYWN0aXZlTW9kZXMuaW5jbHVkZXMobW9kZSkpIHtcbiAgICAgICAgcmV0dXJuIGZpbHRlcihpdGVtcywgKGl0ZW06IENvbm5lY3RvckluZm8pID0+IHtcbiAgICAgICAgICByZXR1cm4gaXRlbS5zdXBwb3J0ZWRNb2Rlcy5pbmNsdWRlcyhtb2RlKTtcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBbXTtcbiAgfVxufVxuIl19
@@ -16,19 +16,22 @@
16
16
  import { Component, EventEmitter, Input, Output } from '@angular/core';
17
17
  import { tap } from 'rxjs/operators';
18
18
  import { isEmpty } from 'lodash';
19
- import { GIO_DIALOG_WIDTH } from '@gravitee/ui-particles-angular';
19
+ import { GIO_DIALOG_WIDTH, GioIconsModule, GioLoaderModule } from '@gravitee/ui-particles-angular';
20
+ import { MatTabsModule } from '@angular/material/tabs';
21
+ import { MatButtonModule } from '@angular/material/button';
22
+ import { CommonModule } from '@angular/common';
20
23
  import { GioPolicyStudioFlowMessageFormDialogComponent, } from '../flow-form-dialog/flow-message-form-dialog/gio-ps-flow-message-form-dialog.component';
21
24
  import { GioPolicyStudioFlowProxyFormDialogComponent, } from '../flow-form-dialog/flow-proxy-form-dialog/gio-ps-flow-proxy-form-dialog.component';
25
+ import { GioPolicyStudioDetailsPhaseComponent } from '../flow-details-phase/gio-ps-flow-details-phase.component';
26
+ import { GioFilterConnectorsByModePipe } from '../filter-pipe/gio-flter-connectors-by-mode.pipe';
27
+ import { GioPolicyStudioDetailsInfoBarComponent } from '../flow-details-info-bar/gio-ps-flow-details-info-bar.component';
22
28
  import * as i0 from "@angular/core";
23
29
  import * as i1 from "@angular/material/dialog";
24
30
  import * as i2 from "@angular/common";
25
- import * as i3 from "@angular/material/button";
26
- import * as i4 from "@angular/material/tabs";
31
+ import * as i3 from "@angular/material/tabs";
32
+ import * as i4 from "@angular/material/button";
27
33
  import * as i5 from "@angular/material/icon";
28
34
  import * as i6 from "@gravitee/ui-particles-angular";
29
- import * as i7 from "../flow-details-info-bar/gio-ps-flow-details-info-bar.component";
30
- import * as i8 from "../flow-details-phase/gio-ps-flow-details-phase.component";
31
- import * as i9 from "../filter-pipe/gio-flter-connectors-by-mode.pipe";
32
35
  export class GioPolicyStudioDetailsComponent {
33
36
  constructor(matDialog) {
34
37
  this.matDialog = matDialog;
@@ -104,11 +107,20 @@ export class GioPolicyStudioDetailsComponent {
104
107
  });
105
108
  }
106
109
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: GioPolicyStudioDetailsComponent, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component }); }
107
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: GioPolicyStudioDetailsComponent, selector: "gio-ps-flow-details", inputs: { readOnly: "readOnly", loading: "loading", apiType: "apiType", flow: "flow", entrypointsInfo: "entrypointsInfo", endpointsInfo: "endpointsInfo", policies: "policies", trialUrl: "trialUrl" }, outputs: { flowChange: "flowChange", deleteFlow: "deleteFlow" }, usesOnChanges: true, ngImport: i0, template: "<!--\n\n Copyright (C) 2023 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<ng-container *ngIf=\"!loading; then flowDetailsTpl; else loadingTpl\"></ng-container>\n\n<ng-template #flowDetailsTpl>\n <ng-container *ngIf=\"flow; else emptyFlows\">\n <div class=\"header\">\n <div class=\"header__label\">Flow details</div>\n <div class=\"header__configBtn\">\n <button [disabled]=\"readOnly\" class=\"header__configBtn__edit\" mat-stroked-button (click)=\"onEditFlow()\">\n <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n </button>\n <button [disabled]=\"readOnly\" class=\"header__configBtn__delete\" mat-stroked-button (click)=\"onDeleteFlow()\">\n <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n </button>\n </div>\n </div>\n <gio-ps-flow-details-info-bar class=\"infoBar\" [flow]=\"flow\" [entrypointsInfo]=\"entrypointsInfo\"></gio-ps-flow-details-info-bar>\n\n <div class=\"content\">\n <mat-tab-group *ngIf=\"apiType === 'MESSAGE'\" class=\"content__tabs\" dynamicHeight>\n <mat-tab label=\"Initial connection\" bodyClass=\"content__tabs__body\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Request phase\"\n description=\"Policies will be applied during the connection establishment\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"messageFlowEntrypointsInfo\"\n [endConnector]=\"endpointsInfo\"\n [steps]=\"flow.request ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"REQUEST\"\n (stepsChange)=\"onStepsChange('request', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Response phase\"\n description=\"Policies will be applied to the response from the initial connection\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo\"\n [endConnector]=\"messageFlowEntrypointsInfo\"\n [steps]=\"flow.response ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"RESPONSE\"\n (stepsChange)=\"onStepsChange('response', $event)\"\n ></gio-ps-flow-details-phase>\n </mat-tab>\n <mat-tab label=\"Event messages\" bodyClass=\"content__tabs__body\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Publish phase\"\n description=\"Policies will be applied on messages sent to the endpoint\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n [steps]=\"flow.publish ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"MESSAGE_REQUEST\"\n (stepsChange)=\"onStepsChange('publish', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Subscribe phase\"\n description=\"Policies will be applied on messages received by the entrypoint\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n [endConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n [steps]=\"flow.subscribe ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"MESSAGE_RESPONSE\"\n (stepsChange)=\"onStepsChange('subscribe', $event)\"\n ></gio-ps-flow-details-phase>\n </mat-tab>\n </mat-tab-group>\n\n <ng-container *ngIf=\"apiType === 'PROXY'\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Request phase\"\n description=\"Policies will be applied during the connection establishment\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [steps]=\"flow.request ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"REQUEST\"\n (stepsChange)=\"onStepsChange('request', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Response phase\"\n description=\"Policies will be applied during the connection termination\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [endConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [steps]=\"flow.response ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"RESPONSE\"\n (stepsChange)=\"onStepsChange('response', $event)\"\n ></gio-ps-flow-details-phase>\n </ng-container>\n </div>\n </ng-container>\n\n <ng-template #emptyFlows>\n <div class=\"emptyFlows\">\n <h2>No flows yet</h2>\n <p class=\"mat-body-1\">Flows allow you to customize the behavior of your API event phases through configurable policies</p>\n </div>\n </ng-template>\n</ng-template>\n\n<ng-template #loadingTpl>\n <div class=\"header loading\">\n <div class=\"header__label\">Flow details</div>\n <div class=\"header__configBtn\">\n <button class=\"header__configBtn__edit\" mat-stroked-button disabled>\n <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n </button>\n <button class=\"header__configBtn__delete\" mat-stroked-button disabled>\n <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n </button>\n </div>\n </div>\n <gio-ps-flow-details-info-bar class=\"infoBar loading\"></gio-ps-flow-details-info-bar>\n <div class=\"content loading\">\n <gio-loader></gio-loader>\n </div>\n</ng-template>\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}.emptyFlows{display:flex;max-width:500px;height:100%;flex-direction:column;justify-content:center;margin:auto;text-align:center}.header{display:flex;align-items:center;padding:16px;border-bottom:1px solid #d3d5dc}.header__label{font-size:16px;font-weight:500;letter-spacing:.4px;line-height:24px;display:flex;flex:1 1 auto;align-items:center;margin-bottom:0;gap:8px}.header__configBtn{display:flex;align-items:center;margin-left:8px;gap:8px}.infoBar{border-bottom:1px solid #d3d5dc}.infoBar.loading{min-height:52px}.content{overflow:auto;flex:1 1 auto;background-color:#f7f8fd}.content__tabs{min-height:100%;min-height:calc(100% - 64px)}.content__phase{margin:16px 16px 0}.content.loading{display:flex}\n"], dependencies: [{ 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: "component", type: i4.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "component", type: i4.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "fitInkBarToContent", "mat-stretch-tabs", "dynamicHeight", "selectedIndex", "headerPosition", "animationDuration", "contentTabIndex", "disablePagination", "disableRipple", "preserveContent", "backgroundColor"], outputs: ["selectedIndexChange", "focusChange", "animationDone", "selectedTabChange"], exportAs: ["matTabGroup"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.GioLoaderComponent, selector: "gio-loader" }, { kind: "component", type: i7.GioPolicyStudioDetailsInfoBarComponent, selector: "gio-ps-flow-details-info-bar", inputs: ["flow", "entrypointsInfo"] }, { kind: "component", type: i8.GioPolicyStudioDetailsPhaseComponent, selector: "gio-ps-flow-details-phase", inputs: ["readOnly", "steps", "name", "description", "startConnector", "endConnector", "apiType", "policies", "policyExecutionPhase", "trialUrl"], outputs: ["stepsChange"] }, { kind: "pipe", type: i9.GioFilterConnectorsByModePipe, name: "gioFilterConnectorsByMode" }] }); }
110
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: GioPolicyStudioDetailsComponent, isStandalone: true, selector: "gio-ps-flow-details", inputs: { readOnly: "readOnly", loading: "loading", apiType: "apiType", flow: "flow", entrypointsInfo: "entrypointsInfo", endpointsInfo: "endpointsInfo", policies: "policies", trialUrl: "trialUrl" }, outputs: { flowChange: "flowChange", deleteFlow: "deleteFlow" }, usesOnChanges: true, ngImport: i0, template: "<!--\n\n Copyright (C) 2023 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<ng-container *ngIf=\"!loading; then flowDetailsTpl; else loadingTpl\"></ng-container>\n\n<ng-template #flowDetailsTpl>\n <ng-container *ngIf=\"flow; else emptyFlows\">\n <div class=\"header\">\n <div class=\"header__label\">Flow details</div>\n <div class=\"header__configBtn\">\n <button [disabled]=\"readOnly\" class=\"header__configBtn__edit\" mat-stroked-button (click)=\"onEditFlow()\">\n <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n </button>\n <button [disabled]=\"readOnly\" class=\"header__configBtn__delete\" mat-stroked-button (click)=\"onDeleteFlow()\">\n <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n </button>\n </div>\n </div>\n <gio-ps-flow-details-info-bar class=\"infoBar\" [flow]=\"flow\" [entrypointsInfo]=\"entrypointsInfo\"></gio-ps-flow-details-info-bar>\n\n <div class=\"content\">\n <mat-tab-group *ngIf=\"apiType === 'MESSAGE'\" class=\"content__tabs\" dynamicHeight>\n <mat-tab label=\"Initial connection\" bodyClass=\"content__tabs__body\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Request phase\"\n description=\"Policies will be applied during the connection establishment\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"messageFlowEntrypointsInfo\"\n [endConnector]=\"endpointsInfo\"\n [steps]=\"flow.request ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"REQUEST\"\n (stepsChange)=\"onStepsChange('request', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Response phase\"\n description=\"Policies will be applied to the response from the initial connection\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo\"\n [endConnector]=\"messageFlowEntrypointsInfo\"\n [steps]=\"flow.response ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"RESPONSE\"\n (stepsChange)=\"onStepsChange('response', $event)\"\n ></gio-ps-flow-details-phase>\n </mat-tab>\n <mat-tab label=\"Event messages\" bodyClass=\"content__tabs__body\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Publish phase\"\n description=\"Policies will be applied on messages sent to the endpoint\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n [steps]=\"flow.publish ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"MESSAGE_REQUEST\"\n (stepsChange)=\"onStepsChange('publish', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Subscribe phase\"\n description=\"Policies will be applied on messages received by the entrypoint\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n [endConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n [steps]=\"flow.subscribe ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"MESSAGE_RESPONSE\"\n (stepsChange)=\"onStepsChange('subscribe', $event)\"\n ></gio-ps-flow-details-phase>\n </mat-tab>\n </mat-tab-group>\n\n <ng-container *ngIf=\"apiType === 'PROXY'\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Request phase\"\n description=\"Policies will be applied during the connection establishment\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [steps]=\"flow.request ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"REQUEST\"\n (stepsChange)=\"onStepsChange('request', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Response phase\"\n description=\"Policies will be applied during the connection termination\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [endConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [steps]=\"flow.response ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"RESPONSE\"\n (stepsChange)=\"onStepsChange('response', $event)\"\n ></gio-ps-flow-details-phase>\n </ng-container>\n </div>\n </ng-container>\n\n <ng-template #emptyFlows>\n <div class=\"emptyFlows\">\n <h2>No flows yet</h2>\n <p class=\"mat-body-1\">Flows allow you to customize the behavior of your API event phases through configurable policies</p>\n </div>\n </ng-template>\n</ng-template>\n\n<ng-template #loadingTpl>\n <div class=\"header loading\">\n <div class=\"header__label\">Flow details</div>\n <div class=\"header__configBtn\">\n <button class=\"header__configBtn__edit\" mat-stroked-button disabled>\n <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n </button>\n <button class=\"header__configBtn__delete\" mat-stroked-button disabled>\n <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n </button>\n </div>\n </div>\n <gio-ps-flow-details-info-bar class=\"infoBar loading\"></gio-ps-flow-details-info-bar>\n <div class=\"content loading\">\n <gio-loader></gio-loader>\n </div>\n</ng-template>\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}.emptyFlows{display:flex;max-width:500px;height:100%;flex-direction:column;justify-content:center;margin:auto;text-align:center}.header{display:flex;align-items:center;padding:16px;border-bottom:1px solid #d3d5dc}.header__label{font-size:16px;font-weight:500;letter-spacing:.4px;line-height:24px;display:flex;flex:1 1 auto;align-items:center;margin-bottom:0;gap:8px}.header__configBtn{display:flex;align-items:center;margin-left:8px;gap:8px}.infoBar{border-bottom:1px solid #d3d5dc}.infoBar.loading{min-height:52px}.content{overflow:auto;flex:1 1 auto;background-color:#f7f8fd}.content__tabs{min-height:100%;min-height:calc(100% - 64px)}.content__phase{margin:16px 16px 0}.content.loading{display:flex}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatTabsModule }, { kind: "component", type: i3.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "component", type: i3.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "fitInkBarToContent", "mat-stretch-tabs", "dynamicHeight", "selectedIndex", "headerPosition", "animationDuration", "contentTabIndex", "disablePagination", "disableRipple", "preserveContent", "backgroundColor"], outputs: ["selectedIndexChange", "focusChange", "animationDone", "selectedTabChange"], exportAs: ["matTabGroup"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "ngmodule", type: GioIconsModule }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: GioPolicyStudioDetailsPhaseComponent, selector: "gio-ps-flow-details-phase", inputs: ["readOnly", "steps", "name", "description", "startConnector", "endConnector", "apiType", "policies", "policyExecutionPhase", "trialUrl"], outputs: ["stepsChange"] }, { kind: "pipe", type: GioFilterConnectorsByModePipe, name: "gioFilterConnectorsByMode" }, { kind: "ngmodule", type: GioLoaderModule }, { kind: "component", type: i6.GioLoaderComponent, selector: "gio-loader" }, { kind: "component", type: GioPolicyStudioDetailsInfoBarComponent, selector: "gio-ps-flow-details-info-bar", inputs: ["flow", "entrypointsInfo"] }] }); }
108
111
  }
109
112
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: GioPolicyStudioDetailsComponent, decorators: [{
110
113
  type: Component,
111
- args: [{ selector: 'gio-ps-flow-details', template: "<!--\n\n Copyright (C) 2023 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<ng-container *ngIf=\"!loading; then flowDetailsTpl; else loadingTpl\"></ng-container>\n\n<ng-template #flowDetailsTpl>\n <ng-container *ngIf=\"flow; else emptyFlows\">\n <div class=\"header\">\n <div class=\"header__label\">Flow details</div>\n <div class=\"header__configBtn\">\n <button [disabled]=\"readOnly\" class=\"header__configBtn__edit\" mat-stroked-button (click)=\"onEditFlow()\">\n <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n </button>\n <button [disabled]=\"readOnly\" class=\"header__configBtn__delete\" mat-stroked-button (click)=\"onDeleteFlow()\">\n <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n </button>\n </div>\n </div>\n <gio-ps-flow-details-info-bar class=\"infoBar\" [flow]=\"flow\" [entrypointsInfo]=\"entrypointsInfo\"></gio-ps-flow-details-info-bar>\n\n <div class=\"content\">\n <mat-tab-group *ngIf=\"apiType === 'MESSAGE'\" class=\"content__tabs\" dynamicHeight>\n <mat-tab label=\"Initial connection\" bodyClass=\"content__tabs__body\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Request phase\"\n description=\"Policies will be applied during the connection establishment\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"messageFlowEntrypointsInfo\"\n [endConnector]=\"endpointsInfo\"\n [steps]=\"flow.request ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"REQUEST\"\n (stepsChange)=\"onStepsChange('request', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Response phase\"\n description=\"Policies will be applied to the response from the initial connection\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo\"\n [endConnector]=\"messageFlowEntrypointsInfo\"\n [steps]=\"flow.response ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"RESPONSE\"\n (stepsChange)=\"onStepsChange('response', $event)\"\n ></gio-ps-flow-details-phase>\n </mat-tab>\n <mat-tab label=\"Event messages\" bodyClass=\"content__tabs__body\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Publish phase\"\n description=\"Policies will be applied on messages sent to the endpoint\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n [steps]=\"flow.publish ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"MESSAGE_REQUEST\"\n (stepsChange)=\"onStepsChange('publish', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Subscribe phase\"\n description=\"Policies will be applied on messages received by the entrypoint\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n [endConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n [steps]=\"flow.subscribe ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"MESSAGE_RESPONSE\"\n (stepsChange)=\"onStepsChange('subscribe', $event)\"\n ></gio-ps-flow-details-phase>\n </mat-tab>\n </mat-tab-group>\n\n <ng-container *ngIf=\"apiType === 'PROXY'\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Request phase\"\n description=\"Policies will be applied during the connection establishment\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [steps]=\"flow.request ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"REQUEST\"\n (stepsChange)=\"onStepsChange('request', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Response phase\"\n description=\"Policies will be applied during the connection termination\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [endConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [steps]=\"flow.response ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"RESPONSE\"\n (stepsChange)=\"onStepsChange('response', $event)\"\n ></gio-ps-flow-details-phase>\n </ng-container>\n </div>\n </ng-container>\n\n <ng-template #emptyFlows>\n <div class=\"emptyFlows\">\n <h2>No flows yet</h2>\n <p class=\"mat-body-1\">Flows allow you to customize the behavior of your API event phases through configurable policies</p>\n </div>\n </ng-template>\n</ng-template>\n\n<ng-template #loadingTpl>\n <div class=\"header loading\">\n <div class=\"header__label\">Flow details</div>\n <div class=\"header__configBtn\">\n <button class=\"header__configBtn__edit\" mat-stroked-button disabled>\n <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n </button>\n <button class=\"header__configBtn__delete\" mat-stroked-button disabled>\n <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n </button>\n </div>\n </div>\n <gio-ps-flow-details-info-bar class=\"infoBar loading\"></gio-ps-flow-details-info-bar>\n <div class=\"content loading\">\n <gio-loader></gio-loader>\n </div>\n</ng-template>\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}.emptyFlows{display:flex;max-width:500px;height:100%;flex-direction:column;justify-content:center;margin:auto;text-align:center}.header{display:flex;align-items:center;padding:16px;border-bottom:1px solid #d3d5dc}.header__label{font-size:16px;font-weight:500;letter-spacing:.4px;line-height:24px;display:flex;flex:1 1 auto;align-items:center;margin-bottom:0;gap:8px}.header__configBtn{display:flex;align-items:center;margin-left:8px;gap:8px}.infoBar{border-bottom:1px solid #d3d5dc}.infoBar.loading{min-height:52px}.content{overflow:auto;flex:1 1 auto;background-color:#f7f8fd}.content__tabs{min-height:100%;min-height:calc(100% - 64px)}.content__phase{margin:16px 16px 0}.content.loading{display:flex}\n"] }]
114
+ args: [{ standalone: true, imports: [
115
+ CommonModule,
116
+ MatTabsModule,
117
+ MatButtonModule,
118
+ GioIconsModule,
119
+ GioPolicyStudioDetailsPhaseComponent,
120
+ GioFilterConnectorsByModePipe,
121
+ GioLoaderModule,
122
+ GioPolicyStudioDetailsInfoBarComponent,
123
+ ], selector: 'gio-ps-flow-details', template: "<!--\n\n Copyright (C) 2023 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<ng-container *ngIf=\"!loading; then flowDetailsTpl; else loadingTpl\"></ng-container>\n\n<ng-template #flowDetailsTpl>\n <ng-container *ngIf=\"flow; else emptyFlows\">\n <div class=\"header\">\n <div class=\"header__label\">Flow details</div>\n <div class=\"header__configBtn\">\n <button [disabled]=\"readOnly\" class=\"header__configBtn__edit\" mat-stroked-button (click)=\"onEditFlow()\">\n <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n </button>\n <button [disabled]=\"readOnly\" class=\"header__configBtn__delete\" mat-stroked-button (click)=\"onDeleteFlow()\">\n <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n </button>\n </div>\n </div>\n <gio-ps-flow-details-info-bar class=\"infoBar\" [flow]=\"flow\" [entrypointsInfo]=\"entrypointsInfo\"></gio-ps-flow-details-info-bar>\n\n <div class=\"content\">\n <mat-tab-group *ngIf=\"apiType === 'MESSAGE'\" class=\"content__tabs\" dynamicHeight>\n <mat-tab label=\"Initial connection\" bodyClass=\"content__tabs__body\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Request phase\"\n description=\"Policies will be applied during the connection establishment\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"messageFlowEntrypointsInfo\"\n [endConnector]=\"endpointsInfo\"\n [steps]=\"flow.request ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"REQUEST\"\n (stepsChange)=\"onStepsChange('request', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Response phase\"\n description=\"Policies will be applied to the response from the initial connection\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo\"\n [endConnector]=\"messageFlowEntrypointsInfo\"\n [steps]=\"flow.response ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"RESPONSE\"\n (stepsChange)=\"onStepsChange('response', $event)\"\n ></gio-ps-flow-details-phase>\n </mat-tab>\n <mat-tab label=\"Event messages\" bodyClass=\"content__tabs__body\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Publish phase\"\n description=\"Policies will be applied on messages sent to the endpoint\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n [steps]=\"flow.publish ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"MESSAGE_REQUEST\"\n (stepsChange)=\"onStepsChange('publish', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Subscribe phase\"\n description=\"Policies will be applied on messages received by the entrypoint\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n [endConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n [steps]=\"flow.subscribe ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"MESSAGE_RESPONSE\"\n (stepsChange)=\"onStepsChange('subscribe', $event)\"\n ></gio-ps-flow-details-phase>\n </mat-tab>\n </mat-tab-group>\n\n <ng-container *ngIf=\"apiType === 'PROXY'\">\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Request phase\"\n description=\"Policies will be applied during the connection establishment\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [steps]=\"flow.request ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"REQUEST\"\n (stepsChange)=\"onStepsChange('request', $event)\"\n ></gio-ps-flow-details-phase>\n <gio-ps-flow-details-phase\n class=\"content__phase\"\n name=\"Response phase\"\n description=\"Policies will be applied during the connection termination\"\n [readOnly]=\"readOnly\"\n [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [endConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n [steps]=\"flow.response ?? []\"\n [apiType]=\"apiType\"\n [policies]=\"policies\"\n [trialUrl]=\"trialUrl\"\n policyExecutionPhase=\"RESPONSE\"\n (stepsChange)=\"onStepsChange('response', $event)\"\n ></gio-ps-flow-details-phase>\n </ng-container>\n </div>\n </ng-container>\n\n <ng-template #emptyFlows>\n <div class=\"emptyFlows\">\n <h2>No flows yet</h2>\n <p class=\"mat-body-1\">Flows allow you to customize the behavior of your API event phases through configurable policies</p>\n </div>\n </ng-template>\n</ng-template>\n\n<ng-template #loadingTpl>\n <div class=\"header loading\">\n <div class=\"header__label\">Flow details</div>\n <div class=\"header__configBtn\">\n <button class=\"header__configBtn__edit\" mat-stroked-button disabled>\n <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n </button>\n <button class=\"header__configBtn__delete\" mat-stroked-button disabled>\n <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n </button>\n </div>\n </div>\n <gio-ps-flow-details-info-bar class=\"infoBar loading\"></gio-ps-flow-details-info-bar>\n <div class=\"content loading\">\n <gio-loader></gio-loader>\n </div>\n</ng-template>\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}.emptyFlows{display:flex;max-width:500px;height:100%;flex-direction:column;justify-content:center;margin:auto;text-align:center}.header{display:flex;align-items:center;padding:16px;border-bottom:1px solid #d3d5dc}.header__label{font-size:16px;font-weight:500;letter-spacing:.4px;line-height:24px;display:flex;flex:1 1 auto;align-items:center;margin-bottom:0;gap:8px}.header__configBtn{display:flex;align-items:center;margin-left:8px;gap:8px}.infoBar{border-bottom:1px solid #d3d5dc}.infoBar.loading{min-height:52px}.content{overflow:auto;flex:1 1 auto;background-color:#f7f8fd}.content__tabs{min-height:100%;min-height:calc(100% - 64px)}.content__phase{margin:16px 16px 0}.content.loading{display:flex}\n"] }]
112
124
  }], ctorParameters: () => [{ type: i1.MatDialog }], propDecorators: { readOnly: [{
113
125
  type: Input
114
126
  }], loading: [{
@@ -130,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
130
142
  }], deleteFlow: [{
131
143
  type: Output
132
144
  }] } });
133
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gio-ps-flow-details.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-policy-studio-angular/src/lib/components/flow-details/gio-ps-flow-details.component.ts","../../../../../../projects/ui-policy-studio-angular/src/lib/components/flow-details/gio-ps-flow-details.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, Output, SimpleChanges } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { tap } from 'rxjs/operators';\nimport { isEmpty } from 'lodash';\nimport { GIO_DIALOG_WIDTH } from '@gravitee/ui-particles-angular';\n\nimport { FlowVM } from '../../gio-policy-studio.model';\nimport {\n  GioPolicyStudioFlowMessageFormDialogComponent,\n  GioPolicyStudioFlowMessageFormDialogData,\n} from '../flow-form-dialog/flow-message-form-dialog/gio-ps-flow-message-form-dialog.component';\nimport { ApiType, ChannelSelector, ConnectorInfo, Operation, Policy, Step } from '../../models';\nimport {\n  GioPolicyStudioFlowProxyFormDialogComponent,\n  GioPolicyStudioFlowProxyFormDialogData,\n} from '../flow-form-dialog/flow-proxy-form-dialog/gio-ps-flow-proxy-form-dialog.component';\nimport { GioPolicyStudioFlowFormDialogResult } from '../flow-form-dialog/gio-ps-flow-form-dialog-result.model';\n\n@Component({\n  selector: 'gio-ps-flow-details',\n  templateUrl: './gio-ps-flow-details.component.html',\n  styleUrls: ['./gio-ps-flow-details.component.scss'],\n})\nexport class GioPolicyStudioDetailsComponent implements OnChanges {\n  @Input()\n  public readOnly = false;\n\n  @Input()\n  public loading = false;\n\n  @Input()\n  public apiType!: ApiType;\n\n  @Input()\n  public flow?: FlowVM = undefined;\n\n  @Input()\n  public entrypointsInfo: ConnectorInfo[] = [];\n\n  @Input()\n  public endpointsInfo: ConnectorInfo[] = [];\n\n  @Input()\n  public policies: Policy[] = [];\n\n  @Input()\n  public trialUrl?: string;\n\n  @Output()\n  public flowChange = new EventEmitter<FlowVM>();\n\n  @Output()\n  public deleteFlow = new EventEmitter<FlowVM>();\n\n  public messageFlowEntrypointsInfo: ConnectorInfo[] = [];\n\n  public operations: Operation[] = [];\n\n  constructor(private readonly matDialog: MatDialog) {}\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.entrypointsInfo || changes.flow) {\n      const channelSelector = this.flow?.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n\n      this.operations = channelSelector?.operations ?? [];\n\n      if (!channelSelector) {\n        // If no channel selector found. Keep default value\n        this.messageFlowEntrypointsInfo = [];\n        return;\n      }\n\n      this.messageFlowEntrypointsInfo =\n        this.entrypointsInfo?.filter(\n          e =>\n            // If not entrypoints are defined, all entrypoints are valid\n            !channelSelector.entrypoints || isEmpty(channelSelector.entrypoints) || channelSelector.entrypoints?.includes(e.type),\n        ) ?? [];\n    }\n  }\n\n  public onEditFlow(): void {\n    const dialogResult =\n      this.apiType === 'MESSAGE'\n        ? this.matDialog\n            .open<\n              GioPolicyStudioFlowMessageFormDialogComponent,\n              GioPolicyStudioFlowMessageFormDialogData,\n              GioPolicyStudioFlowFormDialogResult\n            >(GioPolicyStudioFlowMessageFormDialogComponent, {\n              data: {\n                flow: this.flow,\n                entrypoints: this.entrypointsInfo ?? [],\n              },\n              role: 'alertdialog',\n              id: 'gioPsFlowMessageFormDialog',\n              width: GIO_DIALOG_WIDTH.MEDIUM,\n            })\n            .afterClosed()\n        : this.matDialog\n            .open<GioPolicyStudioFlowProxyFormDialogComponent, GioPolicyStudioFlowProxyFormDialogData, GioPolicyStudioFlowFormDialogResult>(\n              GioPolicyStudioFlowProxyFormDialogComponent,\n              {\n                data: {\n                  flow: this.flow,\n                },\n                role: 'alertdialog',\n                id: 'gioPsFlowProxyFormDialog',\n                width: GIO_DIALOG_WIDTH.MEDIUM,\n              },\n            )\n            .afterClosed();\n\n    dialogResult\n      .pipe(\n        tap(createdOrEdited => {\n          if (!createdOrEdited) {\n            return;\n          }\n\n          this.flowChange.emit(createdOrEdited);\n        }),\n      )\n      .subscribe();\n  }\n\n  public onDeleteFlow(): void {\n    this.deleteFlow.emit(this.flow);\n  }\n\n  public onStepsChange(flowPhase: 'request' | 'response' | 'publish' | 'subscribe', steps: Step[]): void {\n    if (!this.flow) {\n      return;\n    }\n\n    this.flowChange.emit({\n      ...this.flow,\n      [flowPhase]: steps,\n      _hasChanged: true,\n    });\n  }\n}\n","<!--\n\n    Copyright (C) 2023 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<ng-container *ngIf=\"!loading; then flowDetailsTpl; else loadingTpl\"></ng-container>\n\n<ng-template #flowDetailsTpl>\n  <ng-container *ngIf=\"flow; else emptyFlows\">\n    <div class=\"header\">\n      <div class=\"header__label\">Flow details</div>\n      <div class=\"header__configBtn\">\n        <button [disabled]=\"readOnly\" class=\"header__configBtn__edit\" mat-stroked-button (click)=\"onEditFlow()\">\n          <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n        </button>\n        <button [disabled]=\"readOnly\" class=\"header__configBtn__delete\" mat-stroked-button (click)=\"onDeleteFlow()\">\n          <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n        </button>\n      </div>\n    </div>\n    <gio-ps-flow-details-info-bar class=\"infoBar\" [flow]=\"flow\" [entrypointsInfo]=\"entrypointsInfo\"></gio-ps-flow-details-info-bar>\n\n    <div class=\"content\">\n      <mat-tab-group *ngIf=\"apiType === 'MESSAGE'\" class=\"content__tabs\" dynamicHeight>\n        <mat-tab label=\"Initial connection\" bodyClass=\"content__tabs__body\">\n          <gio-ps-flow-details-phase\n            class=\"content__phase\"\n            name=\"Request phase\"\n            description=\"Policies will be applied during the connection establishment\"\n            [readOnly]=\"readOnly\"\n            [startConnector]=\"messageFlowEntrypointsInfo\"\n            [endConnector]=\"endpointsInfo\"\n            [steps]=\"flow.request ?? []\"\n            [apiType]=\"apiType\"\n            [policies]=\"policies\"\n            [trialUrl]=\"trialUrl\"\n            policyExecutionPhase=\"REQUEST\"\n            (stepsChange)=\"onStepsChange('request', $event)\"\n          ></gio-ps-flow-details-phase>\n          <gio-ps-flow-details-phase\n            class=\"content__phase\"\n            name=\"Response phase\"\n            description=\"Policies will be applied to the response from the initial connection\"\n            [readOnly]=\"readOnly\"\n            [startConnector]=\"endpointsInfo\"\n            [endConnector]=\"messageFlowEntrypointsInfo\"\n            [steps]=\"flow.response ?? []\"\n            [apiType]=\"apiType\"\n            [policies]=\"policies\"\n            [trialUrl]=\"trialUrl\"\n            policyExecutionPhase=\"RESPONSE\"\n            (stepsChange)=\"onStepsChange('response', $event)\"\n          ></gio-ps-flow-details-phase>\n        </mat-tab>\n        <mat-tab label=\"Event messages\" bodyClass=\"content__tabs__body\">\n          <gio-ps-flow-details-phase\n            class=\"content__phase\"\n            name=\"Publish phase\"\n            description=\"Policies will be applied on messages sent to the endpoint\"\n            [readOnly]=\"readOnly\"\n            [startConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n            [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n            [steps]=\"flow.publish ?? []\"\n            [apiType]=\"apiType\"\n            [policies]=\"policies\"\n            [trialUrl]=\"trialUrl\"\n            policyExecutionPhase=\"MESSAGE_REQUEST\"\n            (stepsChange)=\"onStepsChange('publish', $event)\"\n          ></gio-ps-flow-details-phase>\n          <gio-ps-flow-details-phase\n            class=\"content__phase\"\n            name=\"Subscribe phase\"\n            description=\"Policies will be applied on messages received by the entrypoint\"\n            [readOnly]=\"readOnly\"\n            [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n            [endConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n            [steps]=\"flow.subscribe ?? []\"\n            [apiType]=\"apiType\"\n            [policies]=\"policies\"\n            [trialUrl]=\"trialUrl\"\n            policyExecutionPhase=\"MESSAGE_RESPONSE\"\n            (stepsChange)=\"onStepsChange('subscribe', $event)\"\n          ></gio-ps-flow-details-phase>\n        </mat-tab>\n      </mat-tab-group>\n\n      <ng-container *ngIf=\"apiType === 'PROXY'\">\n        <gio-ps-flow-details-phase\n          class=\"content__phase\"\n          name=\"Request phase\"\n          description=\"Policies will be applied during the connection establishment\"\n          [readOnly]=\"readOnly\"\n          [startConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n          [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n          [steps]=\"flow.request ?? []\"\n          [apiType]=\"apiType\"\n          [policies]=\"policies\"\n          [trialUrl]=\"trialUrl\"\n          policyExecutionPhase=\"REQUEST\"\n          (stepsChange)=\"onStepsChange('request', $event)\"\n        ></gio-ps-flow-details-phase>\n        <gio-ps-flow-details-phase\n          class=\"content__phase\"\n          name=\"Response phase\"\n          description=\"Policies will be applied during the connection termination\"\n          [readOnly]=\"readOnly\"\n          [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n          [endConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n          [steps]=\"flow.response ?? []\"\n          [apiType]=\"apiType\"\n          [policies]=\"policies\"\n          [trialUrl]=\"trialUrl\"\n          policyExecutionPhase=\"RESPONSE\"\n          (stepsChange)=\"onStepsChange('response', $event)\"\n        ></gio-ps-flow-details-phase>\n      </ng-container>\n    </div>\n  </ng-container>\n\n  <ng-template #emptyFlows>\n    <div class=\"emptyFlows\">\n      <h2>No flows yet</h2>\n      <p class=\"mat-body-1\">Flows allow you to customize the behavior of your API event phases through configurable policies</p>\n    </div>\n  </ng-template>\n</ng-template>\n\n<ng-template #loadingTpl>\n  <div class=\"header loading\">\n    <div class=\"header__label\">Flow details</div>\n    <div class=\"header__configBtn\">\n      <button class=\"header__configBtn__edit\" mat-stroked-button disabled>\n        <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n      </button>\n      <button class=\"header__configBtn__delete\" mat-stroked-button disabled>\n        <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n      </button>\n    </div>\n  </div>\n  <gio-ps-flow-details-info-bar class=\"infoBar loading\"></gio-ps-flow-details-info-bar>\n  <div class=\"content loading\">\n    <gio-loader></gio-loader>\n  </div>\n</ng-template>\n"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gio-ps-flow-details.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-policy-studio-angular/src/lib/components/flow-details/gio-ps-flow-details.component.ts","../../../../../../projects/ui-policy-studio-angular/src/lib/components/flow-details/gio-ps-flow-details.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, Output, SimpleChanges } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { tap } from 'rxjs/operators';\nimport { isEmpty } from 'lodash';\nimport { GIO_DIALOG_WIDTH, GioIconsModule, GioLoaderModule } from '@gravitee/ui-particles-angular';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { MatButtonModule } from '@angular/material/button';\nimport { CommonModule } from '@angular/common';\n\nimport { FlowVM } from '../../policy-studio/gio-policy-studio.model';\nimport {\n  GioPolicyStudioFlowMessageFormDialogComponent,\n  GioPolicyStudioFlowMessageFormDialogData,\n} from '../flow-form-dialog/flow-message-form-dialog/gio-ps-flow-message-form-dialog.component';\nimport { ApiType, ChannelSelector, ConnectorInfo, Operation, Policy, Step } from '../../models';\nimport {\n  GioPolicyStudioFlowProxyFormDialogComponent,\n  GioPolicyStudioFlowProxyFormDialogData,\n} from '../flow-form-dialog/flow-proxy-form-dialog/gio-ps-flow-proxy-form-dialog.component';\nimport { GioPolicyStudioFlowFormDialogResult } from '../flow-form-dialog/gio-ps-flow-form-dialog-result.model';\nimport { GioPolicyStudioDetailsPhaseComponent } from '../flow-details-phase/gio-ps-flow-details-phase.component';\nimport { GioFilterConnectorsByModePipe } from '../filter-pipe/gio-flter-connectors-by-mode.pipe';\nimport { GioPolicyStudioDetailsInfoBarComponent } from '../flow-details-info-bar/gio-ps-flow-details-info-bar.component';\n\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatTabsModule,\n    MatButtonModule,\n    GioIconsModule,\n    GioPolicyStudioDetailsPhaseComponent,\n    GioFilterConnectorsByModePipe,\n    GioLoaderModule,\n    GioPolicyStudioDetailsInfoBarComponent,\n  ],\n  selector: 'gio-ps-flow-details',\n  templateUrl: './gio-ps-flow-details.component.html',\n  styleUrls: ['./gio-ps-flow-details.component.scss'],\n})\nexport class GioPolicyStudioDetailsComponent implements OnChanges {\n  @Input()\n  public readOnly = false;\n\n  @Input()\n  public loading = false;\n\n  @Input()\n  public apiType!: ApiType;\n\n  @Input()\n  public flow?: FlowVM = undefined;\n\n  @Input()\n  public entrypointsInfo: ConnectorInfo[] = [];\n\n  @Input()\n  public endpointsInfo: ConnectorInfo[] = [];\n\n  @Input()\n  public policies: Policy[] = [];\n\n  @Input()\n  public trialUrl?: string;\n\n  @Output()\n  public flowChange = new EventEmitter<FlowVM>();\n\n  @Output()\n  public deleteFlow = new EventEmitter<FlowVM>();\n\n  public messageFlowEntrypointsInfo: ConnectorInfo[] = [];\n\n  public operations: Operation[] = [];\n\n  constructor(private readonly matDialog: MatDialog) {}\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.entrypointsInfo || changes.flow) {\n      const channelSelector = this.flow?.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n\n      this.operations = channelSelector?.operations ?? [];\n\n      if (!channelSelector) {\n        // If no channel selector found. Keep default value\n        this.messageFlowEntrypointsInfo = [];\n        return;\n      }\n\n      this.messageFlowEntrypointsInfo =\n        this.entrypointsInfo?.filter(\n          e =>\n            // If not entrypoints are defined, all entrypoints are valid\n            !channelSelector.entrypoints || isEmpty(channelSelector.entrypoints) || channelSelector.entrypoints?.includes(e.type),\n        ) ?? [];\n    }\n  }\n\n  public onEditFlow(): void {\n    const dialogResult =\n      this.apiType === 'MESSAGE'\n        ? this.matDialog\n            .open<\n              GioPolicyStudioFlowMessageFormDialogComponent,\n              GioPolicyStudioFlowMessageFormDialogData,\n              GioPolicyStudioFlowFormDialogResult\n            >(GioPolicyStudioFlowMessageFormDialogComponent, {\n              data: {\n                flow: this.flow,\n                entrypoints: this.entrypointsInfo ?? [],\n              },\n              role: 'alertdialog',\n              id: 'gioPsFlowMessageFormDialog',\n              width: GIO_DIALOG_WIDTH.MEDIUM,\n            })\n            .afterClosed()\n        : this.matDialog\n            .open<GioPolicyStudioFlowProxyFormDialogComponent, GioPolicyStudioFlowProxyFormDialogData, GioPolicyStudioFlowFormDialogResult>(\n              GioPolicyStudioFlowProxyFormDialogComponent,\n              {\n                data: {\n                  flow: this.flow,\n                },\n                role: 'alertdialog',\n                id: 'gioPsFlowProxyFormDialog',\n                width: GIO_DIALOG_WIDTH.MEDIUM,\n              },\n            )\n            .afterClosed();\n\n    dialogResult\n      .pipe(\n        tap(createdOrEdited => {\n          if (!createdOrEdited) {\n            return;\n          }\n\n          this.flowChange.emit(createdOrEdited);\n        }),\n      )\n      .subscribe();\n  }\n\n  public onDeleteFlow(): void {\n    this.deleteFlow.emit(this.flow);\n  }\n\n  public onStepsChange(flowPhase: 'request' | 'response' | 'publish' | 'subscribe', steps: Step[]): void {\n    if (!this.flow) {\n      return;\n    }\n\n    this.flowChange.emit({\n      ...this.flow,\n      [flowPhase]: steps,\n      _hasChanged: true,\n    });\n  }\n}\n","<!--\n\n    Copyright (C) 2023 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<ng-container *ngIf=\"!loading; then flowDetailsTpl; else loadingTpl\"></ng-container>\n\n<ng-template #flowDetailsTpl>\n  <ng-container *ngIf=\"flow; else emptyFlows\">\n    <div class=\"header\">\n      <div class=\"header__label\">Flow details</div>\n      <div class=\"header__configBtn\">\n        <button [disabled]=\"readOnly\" class=\"header__configBtn__edit\" mat-stroked-button (click)=\"onEditFlow()\">\n          <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n        </button>\n        <button [disabled]=\"readOnly\" class=\"header__configBtn__delete\" mat-stroked-button (click)=\"onDeleteFlow()\">\n          <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n        </button>\n      </div>\n    </div>\n    <gio-ps-flow-details-info-bar class=\"infoBar\" [flow]=\"flow\" [entrypointsInfo]=\"entrypointsInfo\"></gio-ps-flow-details-info-bar>\n\n    <div class=\"content\">\n      <mat-tab-group *ngIf=\"apiType === 'MESSAGE'\" class=\"content__tabs\" dynamicHeight>\n        <mat-tab label=\"Initial connection\" bodyClass=\"content__tabs__body\">\n          <gio-ps-flow-details-phase\n            class=\"content__phase\"\n            name=\"Request phase\"\n            description=\"Policies will be applied during the connection establishment\"\n            [readOnly]=\"readOnly\"\n            [startConnector]=\"messageFlowEntrypointsInfo\"\n            [endConnector]=\"endpointsInfo\"\n            [steps]=\"flow.request ?? []\"\n            [apiType]=\"apiType\"\n            [policies]=\"policies\"\n            [trialUrl]=\"trialUrl\"\n            policyExecutionPhase=\"REQUEST\"\n            (stepsChange)=\"onStepsChange('request', $event)\"\n          ></gio-ps-flow-details-phase>\n          <gio-ps-flow-details-phase\n            class=\"content__phase\"\n            name=\"Response phase\"\n            description=\"Policies will be applied to the response from the initial connection\"\n            [readOnly]=\"readOnly\"\n            [startConnector]=\"endpointsInfo\"\n            [endConnector]=\"messageFlowEntrypointsInfo\"\n            [steps]=\"flow.response ?? []\"\n            [apiType]=\"apiType\"\n            [policies]=\"policies\"\n            [trialUrl]=\"trialUrl\"\n            policyExecutionPhase=\"RESPONSE\"\n            (stepsChange)=\"onStepsChange('response', $event)\"\n          ></gio-ps-flow-details-phase>\n        </mat-tab>\n        <mat-tab label=\"Event messages\" bodyClass=\"content__tabs__body\">\n          <gio-ps-flow-details-phase\n            class=\"content__phase\"\n            name=\"Publish phase\"\n            description=\"Policies will be applied on messages sent to the endpoint\"\n            [readOnly]=\"readOnly\"\n            [startConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n            [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'PUBLISH' : operations\"\n            [steps]=\"flow.publish ?? []\"\n            [apiType]=\"apiType\"\n            [policies]=\"policies\"\n            [trialUrl]=\"trialUrl\"\n            policyExecutionPhase=\"MESSAGE_REQUEST\"\n            (stepsChange)=\"onStepsChange('publish', $event)\"\n          ></gio-ps-flow-details-phase>\n          <gio-ps-flow-details-phase\n            class=\"content__phase\"\n            name=\"Subscribe phase\"\n            description=\"Policies will be applied on messages received by the entrypoint\"\n            [readOnly]=\"readOnly\"\n            [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n            [endConnector]=\"messageFlowEntrypointsInfo | gioFilterConnectorsByMode: 'SUBSCRIBE' : operations\"\n            [steps]=\"flow.subscribe ?? []\"\n            [apiType]=\"apiType\"\n            [policies]=\"policies\"\n            [trialUrl]=\"trialUrl\"\n            policyExecutionPhase=\"MESSAGE_RESPONSE\"\n            (stepsChange)=\"onStepsChange('subscribe', $event)\"\n          ></gio-ps-flow-details-phase>\n        </mat-tab>\n      </mat-tab-group>\n\n      <ng-container *ngIf=\"apiType === 'PROXY'\">\n        <gio-ps-flow-details-phase\n          class=\"content__phase\"\n          name=\"Request phase\"\n          description=\"Policies will be applied during the connection establishment\"\n          [readOnly]=\"readOnly\"\n          [startConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n          [endConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n          [steps]=\"flow.request ?? []\"\n          [apiType]=\"apiType\"\n          [policies]=\"policies\"\n          [trialUrl]=\"trialUrl\"\n          policyExecutionPhase=\"REQUEST\"\n          (stepsChange)=\"onStepsChange('request', $event)\"\n        ></gio-ps-flow-details-phase>\n        <gio-ps-flow-details-phase\n          class=\"content__phase\"\n          name=\"Response phase\"\n          description=\"Policies will be applied during the connection termination\"\n          [readOnly]=\"readOnly\"\n          [startConnector]=\"endpointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n          [endConnector]=\"entrypointsInfo | gioFilterConnectorsByMode: 'REQUEST_RESPONSE'\"\n          [steps]=\"flow.response ?? []\"\n          [apiType]=\"apiType\"\n          [policies]=\"policies\"\n          [trialUrl]=\"trialUrl\"\n          policyExecutionPhase=\"RESPONSE\"\n          (stepsChange)=\"onStepsChange('response', $event)\"\n        ></gio-ps-flow-details-phase>\n      </ng-container>\n    </div>\n  </ng-container>\n\n  <ng-template #emptyFlows>\n    <div class=\"emptyFlows\">\n      <h2>No flows yet</h2>\n      <p class=\"mat-body-1\">Flows allow you to customize the behavior of your API event phases through configurable policies</p>\n    </div>\n  </ng-template>\n</ng-template>\n\n<ng-template #loadingTpl>\n  <div class=\"header loading\">\n    <div class=\"header__label\">Flow details</div>\n    <div class=\"header__configBtn\">\n      <button class=\"header__configBtn__edit\" mat-stroked-button disabled>\n        <mat-icon svgIcon=\"gio:edit-pencil\"></mat-icon>\n      </button>\n      <button class=\"header__configBtn__delete\" mat-stroked-button disabled>\n        <mat-icon svgIcon=\"gio:trash\"></mat-icon>\n      </button>\n    </div>\n  </div>\n  <gio-ps-flow-details-info-bar class=\"infoBar loading\"></gio-ps-flow-details-info-bar>\n  <div class=\"content loading\">\n    <gio-loader></gio-loader>\n  </div>\n</ng-template>\n"]}
@@ -15,6 +15,9 @@
15
15
  */
16
16
  import { Component, Input } from '@angular/core';
17
17
  import { isEmpty } from 'lodash';
18
+ import { GioIconsModule } from '@gravitee/ui-particles-angular';
19
+ import { MatCommonModule } from '@angular/material/core';
20
+ import { CommonModule } from '@angular/common';
18
21
  import * as i0 from "@angular/core";
19
22
  import * as i1 from "@angular/common";
20
23
  import * as i2 from "@angular/material/icon";
@@ -99,14 +102,14 @@ export class GioPolicyStudioDetailsInfoBarComponent {
99
102
  ];
100
103
  }
101
104
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: GioPolicyStudioDetailsInfoBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
102
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: GioPolicyStudioDetailsInfoBarComponent, selector: "gio-ps-flow-details-info-bar", inputs: { flow: "flow", entrypointsInfo: "entrypointsInfo" }, ngImport: i0, template: "<!--\n\n Copyright (C) 2023 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<div *ngIf=\"flow?.name\" class=\"info\">\n <span class=\"info__label\">Name</span>\n <span class=\"info__value strong\">{{ flow?.name }}</span>\n</div>\n\n<div *ngIf=\"entrypoints\" class=\"info\">\n <span class=\"info__label\">Entrypoints</span>\n <span *ngFor=\"let entrypoint of entrypoints\" class=\"info__value gio-badge gio-badge-neutral\">\n <mat-icon [svgIcon]=\"entrypoint.icon\"></mat-icon>\n {{ entrypoint.name }}</span\n >\n</div>\n\n<!-- MESSAGE API type -->\n\n<div *ngIf=\"operations\" class=\"info\">\n <span class=\"info__label\">Operations</span>\n <span *ngFor=\"let operation of operations\" class=\"info__value gio-badge-neutral\"> {{ operation }}</span>\n</div>\n\n<div *ngIf=\"channel\" class=\"info\">\n <span class=\"info__label\">Channel</span>\n <span class=\"info__value strong\">{{ channel }}</span>\n</div>\n\n<div *ngIf=\"channelOperator\" class=\"info\">\n <span class=\"info__label\">Channel Operator</span>\n <span class=\"info__value gio-badge-neutral\">{{ channelOperator }}</span>\n</div>\n\n<!-- PROXY API type -->\n\n<div *ngIf=\"path\" class=\"info\">\n <span class=\"info__label\">Path</span>\n <span class=\"info__value strong\">{{ path }}</span>\n</div>\n\n<div *ngIf=\"pathOperator\" class=\"info\">\n <span class=\"info__label\">Path Operator</span>\n <span class=\"info__value gio-badge-neutral\">{{ pathOperator }}</span>\n</div>\n\n<div *ngIf=\"methods\" class=\"info\">\n <span class=\"info__label\">HTTP methods</span>\n <span *ngFor=\"let method of methods\" class=\"info__value method\" [ngClass]=\"method.class\"> {{ method.name }}</span>\n</div>\n\n<!-- Condition -->\n\n<div *ngIf=\"condition\" class=\"info\">\n <span class=\"info__label\">Condition</span>\n <span class=\"info__value gio-badge-neutral condition\">{{ condition }}</span>\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;flex-flow:row wrap;padding:16px;gap:12px}.info__label{font-size:14px;font-weight:400;line-height:22px;font-family:Golos UI,Roboto,Helvetica Neue,sans-serif;letter-spacing:.4px;color:#606274}.info__value.strong{padding-left:8px;font-size:14px;font-weight:500;line-height:20px;font-family:Golos UI,Roboto,Helvetica Neue,sans-serif;letter-spacing:.4px}.info__value.method{width:auto}.info__value.gio-badge mat-icon{margin-right:4px}.info__value.condition{text-transform:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] }); }
105
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: GioPolicyStudioDetailsInfoBarComponent, isStandalone: true, selector: "gio-ps-flow-details-info-bar", inputs: { flow: "flow", entrypointsInfo: "entrypointsInfo" }, ngImport: i0, template: "<!--\n\n Copyright (C) 2023 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<div *ngIf=\"flow?.name\" class=\"info\">\n <span class=\"info__label\">Name</span>\n <span class=\"info__value strong\">{{ flow?.name }}</span>\n</div>\n\n<div *ngIf=\"entrypoints\" class=\"info\">\n <span class=\"info__label\">Entrypoints</span>\n <span *ngFor=\"let entrypoint of entrypoints\" class=\"info__value gio-badge gio-badge-neutral\">\n <mat-icon [svgIcon]=\"entrypoint.icon\"></mat-icon>\n {{ entrypoint.name }}</span\n >\n</div>\n\n<!-- MESSAGE API type -->\n\n<div *ngIf=\"operations\" class=\"info\">\n <span class=\"info__label\">Operations</span>\n <span *ngFor=\"let operation of operations\" class=\"info__value gio-badge-neutral\"> {{ operation }}</span>\n</div>\n\n<div *ngIf=\"channel\" class=\"info\">\n <span class=\"info__label\">Channel</span>\n <span class=\"info__value strong\">{{ channel }}</span>\n</div>\n\n<div *ngIf=\"channelOperator\" class=\"info\">\n <span class=\"info__label\">Channel Operator</span>\n <span class=\"info__value gio-badge-neutral\">{{ channelOperator }}</span>\n</div>\n\n<!-- PROXY API type -->\n\n<div *ngIf=\"path\" class=\"info\">\n <span class=\"info__label\">Path</span>\n <span class=\"info__value strong\">{{ path }}</span>\n</div>\n\n<div *ngIf=\"pathOperator\" class=\"info\">\n <span class=\"info__label\">Path Operator</span>\n <span class=\"info__value gio-badge-neutral\">{{ pathOperator }}</span>\n</div>\n\n<div *ngIf=\"methods\" class=\"info\">\n <span class=\"info__label\">HTTP methods</span>\n <span *ngFor=\"let method of methods\" class=\"info__value method\" [ngClass]=\"method.class\"> {{ method.name }}</span>\n</div>\n\n<!-- Condition -->\n\n<div *ngIf=\"condition\" class=\"info\">\n <span class=\"info__label\">Condition</span>\n <span class=\"info__value gio-badge-neutral condition\">{{ condition }}</span>\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;flex-flow:row wrap;padding:16px;gap:12px}.info__label{font-size:14px;font-weight:400;line-height:22px;font-family:Golos UI,Roboto,Helvetica Neue,sans-serif;letter-spacing:.4px;color:#606274}.info__value.strong{padding-left:8px;font-size:14px;font-weight:500;line-height:20px;font-family:Golos UI,Roboto,Helvetica Neue,sans-serif;letter-spacing:.4px}.info__value.method{width:auto}.info__value.gio-badge mat-icon{margin-right:4px}.info__value.condition{text-transform:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: GioIconsModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatCommonModule }] }); }
103
106
  }
104
107
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: GioPolicyStudioDetailsInfoBarComponent, decorators: [{
105
108
  type: Component,
106
- args: [{ selector: 'gio-ps-flow-details-info-bar', template: "<!--\n\n Copyright (C) 2023 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<div *ngIf=\"flow?.name\" class=\"info\">\n <span class=\"info__label\">Name</span>\n <span class=\"info__value strong\">{{ flow?.name }}</span>\n</div>\n\n<div *ngIf=\"entrypoints\" class=\"info\">\n <span class=\"info__label\">Entrypoints</span>\n <span *ngFor=\"let entrypoint of entrypoints\" class=\"info__value gio-badge gio-badge-neutral\">\n <mat-icon [svgIcon]=\"entrypoint.icon\"></mat-icon>\n {{ entrypoint.name }}</span\n >\n</div>\n\n<!-- MESSAGE API type -->\n\n<div *ngIf=\"operations\" class=\"info\">\n <span class=\"info__label\">Operations</span>\n <span *ngFor=\"let operation of operations\" class=\"info__value gio-badge-neutral\"> {{ operation }}</span>\n</div>\n\n<div *ngIf=\"channel\" class=\"info\">\n <span class=\"info__label\">Channel</span>\n <span class=\"info__value strong\">{{ channel }}</span>\n</div>\n\n<div *ngIf=\"channelOperator\" class=\"info\">\n <span class=\"info__label\">Channel Operator</span>\n <span class=\"info__value gio-badge-neutral\">{{ channelOperator }}</span>\n</div>\n\n<!-- PROXY API type -->\n\n<div *ngIf=\"path\" class=\"info\">\n <span class=\"info__label\">Path</span>\n <span class=\"info__value strong\">{{ path }}</span>\n</div>\n\n<div *ngIf=\"pathOperator\" class=\"info\">\n <span class=\"info__label\">Path Operator</span>\n <span class=\"info__value gio-badge-neutral\">{{ pathOperator }}</span>\n</div>\n\n<div *ngIf=\"methods\" class=\"info\">\n <span class=\"info__label\">HTTP methods</span>\n <span *ngFor=\"let method of methods\" class=\"info__value method\" [ngClass]=\"method.class\"> {{ method.name }}</span>\n</div>\n\n<!-- Condition -->\n\n<div *ngIf=\"condition\" class=\"info\">\n <span class=\"info__label\">Condition</span>\n <span class=\"info__value gio-badge-neutral condition\">{{ condition }}</span>\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;flex-flow:row wrap;padding:16px;gap:12px}.info__label{font-size:14px;font-weight:400;line-height:22px;font-family:Golos UI,Roboto,Helvetica Neue,sans-serif;letter-spacing:.4px;color:#606274}.info__value.strong{padding-left:8px;font-size:14px;font-weight:500;line-height:20px;font-family:Golos UI,Roboto,Helvetica Neue,sans-serif;letter-spacing:.4px}.info__value.method{width:auto}.info__value.gio-badge mat-icon{margin-right:4px}.info__value.condition{text-transform:none}\n"] }]
109
+ args: [{ standalone: true, imports: [CommonModule, GioIconsModule, MatCommonModule], selector: 'gio-ps-flow-details-info-bar', template: "<!--\n\n Copyright (C) 2023 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<div *ngIf=\"flow?.name\" class=\"info\">\n <span class=\"info__label\">Name</span>\n <span class=\"info__value strong\">{{ flow?.name }}</span>\n</div>\n\n<div *ngIf=\"entrypoints\" class=\"info\">\n <span class=\"info__label\">Entrypoints</span>\n <span *ngFor=\"let entrypoint of entrypoints\" class=\"info__value gio-badge gio-badge-neutral\">\n <mat-icon [svgIcon]=\"entrypoint.icon\"></mat-icon>\n {{ entrypoint.name }}</span\n >\n</div>\n\n<!-- MESSAGE API type -->\n\n<div *ngIf=\"operations\" class=\"info\">\n <span class=\"info__label\">Operations</span>\n <span *ngFor=\"let operation of operations\" class=\"info__value gio-badge-neutral\"> {{ operation }}</span>\n</div>\n\n<div *ngIf=\"channel\" class=\"info\">\n <span class=\"info__label\">Channel</span>\n <span class=\"info__value strong\">{{ channel }}</span>\n</div>\n\n<div *ngIf=\"channelOperator\" class=\"info\">\n <span class=\"info__label\">Channel Operator</span>\n <span class=\"info__value gio-badge-neutral\">{{ channelOperator }}</span>\n</div>\n\n<!-- PROXY API type -->\n\n<div *ngIf=\"path\" class=\"info\">\n <span class=\"info__label\">Path</span>\n <span class=\"info__value strong\">{{ path }}</span>\n</div>\n\n<div *ngIf=\"pathOperator\" class=\"info\">\n <span class=\"info__label\">Path Operator</span>\n <span class=\"info__value gio-badge-neutral\">{{ pathOperator }}</span>\n</div>\n\n<div *ngIf=\"methods\" class=\"info\">\n <span class=\"info__label\">HTTP methods</span>\n <span *ngFor=\"let method of methods\" class=\"info__value method\" [ngClass]=\"method.class\"> {{ method.name }}</span>\n</div>\n\n<!-- Condition -->\n\n<div *ngIf=\"condition\" class=\"info\">\n <span class=\"info__label\">Condition</span>\n <span class=\"info__value gio-badge-neutral condition\">{{ condition }}</span>\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;flex-flow:row wrap;padding:16px;gap:12px}.info__label{font-size:14px;font-weight:400;line-height:22px;font-family:Golos UI,Roboto,Helvetica Neue,sans-serif;letter-spacing:.4px;color:#606274}.info__value.strong{padding-left:8px;font-size:14px;font-weight:500;line-height:20px;font-family:Golos UI,Roboto,Helvetica Neue,sans-serif;letter-spacing:.4px}.info__value.method{width:auto}.info__value.gio-badge mat-icon{margin-right:4px}.info__value.condition{text-transform:none}\n"] }]
107
110
  }], propDecorators: { flow: [{
108
111
  type: Input
109
112
  }], entrypointsInfo: [{
110
113
  type: Input
111
114
  }] } });
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gio-ps-flow-details-info-bar.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-policy-studio-angular/src/lib/components/flow-details-info-bar/gio-ps-flow-details-info-bar.component.ts","../../../../../../projects/ui-policy-studio-angular/src/lib/components/flow-details-info-bar/gio-ps-flow-details-info-bar.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, Input } from '@angular/core';\nimport { isEmpty } from 'lodash';\n\nimport { FlowVM } from '../../gio-policy-studio.model';\nimport { ChannelSelector, ConditionSelector, ConnectorInfo, HttpSelector, Operation } from '../../models';\n\n@Component({\n  selector: 'gio-ps-flow-details-info-bar',\n  templateUrl: './gio-ps-flow-details-info-bar.component.html',\n  styleUrls: ['./gio-ps-flow-details-info-bar.component.scss'],\n})\nexport class GioPolicyStudioDetailsInfoBarComponent {\n  @Input()\n  public flow?: FlowVM = undefined;\n\n  @Input()\n  public entrypointsInfo?: ConnectorInfo[];\n\n  public get condition(): string | undefined {\n    const conditionSelector = this.flow?.selectors?.find(s => s.type === 'CONDITION') as ConditionSelector;\n    if (!conditionSelector) {\n      return undefined;\n    }\n    return conditionSelector?.condition;\n  }\n\n  // MESSAGE API type\n\n  public get operations(): string[] | undefined {\n    const channelSelector = this.flow?.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n    if (!channelSelector) {\n      return undefined;\n    }\n    const operationToBadge: Record<Operation, string> = {\n      PUBLISH: 'PUB',\n      SUBSCRIBE: 'SUB',\n    };\n    // If no operations are selected, all operations are valid\n    const operations =\n      !channelSelector.operations || isEmpty(channelSelector.operations) ? (['PUBLISH', 'SUBSCRIBE'] as const) : channelSelector.operations;\n\n    return operations.map(o => operationToBadge[o]).sort();\n  }\n\n  public get channel(): string | undefined {\n    const channelSelector = this.flow?.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n    if (!channelSelector) {\n      return undefined;\n    }\n    return channelSelector?.channel;\n  }\n\n  public get channelOperator(): string | undefined {\n    const channelSelector = this.flow?.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n    if (!channelSelector) {\n      return undefined;\n    }\n    return channelSelector?.channelOperator;\n  }\n\n  public get entrypoints(): ConnectorInfo[] | undefined {\n    const channelSelector = this.flow?.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n    if (!channelSelector) {\n      return undefined;\n    }\n\n    return this.entrypointsInfo?.filter(\n      e =>\n        // If no entrypoints are selected, all entrypoints are valid\n        !channelSelector.entrypoints || isEmpty(channelSelector.entrypoints) || channelSelector.entrypoints?.includes(e.type),\n    );\n  }\n\n  // PROXY API type\n\n  public get path(): string | undefined {\n    const httpSelector = this.flow?.selectors?.find(s => s.type === 'HTTP') as HttpSelector;\n    if (!httpSelector) {\n      return undefined;\n    }\n    return httpSelector?.path;\n  }\n\n  public get pathOperator(): string | undefined {\n    const httpSelector = this.flow?.selectors?.find(s => s.type === 'HTTP') as HttpSelector;\n    if (!httpSelector) {\n      return undefined;\n    }\n    return httpSelector?.pathOperator;\n  }\n\n  public get methods(): { name: string; class: string }[] | undefined {\n    const httpSelector = this.flow?.selectors?.find(s => s.type === 'HTTP') as HttpSelector;\n    if (!httpSelector) {\n      return undefined;\n    }\n    return httpSelector?.methods?.length\n      ? httpSelector?.methods.map(m => ({\n          name: m,\n          class: `gio-method-badge-${m.toLowerCase()}`,\n        }))\n      : [\n          {\n            name: 'ALL',\n            class: 'gio-badge-neutral',\n          },\n        ];\n  }\n}\n","<!--\n\n    Copyright (C) 2023 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<div *ngIf=\"flow?.name\" class=\"info\">\n  <span class=\"info__label\">Name</span>\n  <span class=\"info__value strong\">{{ flow?.name }}</span>\n</div>\n\n<div *ngIf=\"entrypoints\" class=\"info\">\n  <span class=\"info__label\">Entrypoints</span>\n  <span *ngFor=\"let entrypoint of entrypoints\" class=\"info__value gio-badge gio-badge-neutral\">\n    <mat-icon [svgIcon]=\"entrypoint.icon\"></mat-icon>\n    {{ entrypoint.name }}</span\n  >\n</div>\n\n<!-- MESSAGE API type -->\n\n<div *ngIf=\"operations\" class=\"info\">\n  <span class=\"info__label\">Operations</span>\n  <span *ngFor=\"let operation of operations\" class=\"info__value gio-badge-neutral\"> {{ operation }}</span>\n</div>\n\n<div *ngIf=\"channel\" class=\"info\">\n  <span class=\"info__label\">Channel</span>\n  <span class=\"info__value strong\">{{ channel }}</span>\n</div>\n\n<div *ngIf=\"channelOperator\" class=\"info\">\n  <span class=\"info__label\">Channel Operator</span>\n  <span class=\"info__value gio-badge-neutral\">{{ channelOperator }}</span>\n</div>\n\n<!-- PROXY API type -->\n\n<div *ngIf=\"path\" class=\"info\">\n  <span class=\"info__label\">Path</span>\n  <span class=\"info__value strong\">{{ path }}</span>\n</div>\n\n<div *ngIf=\"pathOperator\" class=\"info\">\n  <span class=\"info__label\">Path Operator</span>\n  <span class=\"info__value gio-badge-neutral\">{{ pathOperator }}</span>\n</div>\n\n<div *ngIf=\"methods\" class=\"info\">\n  <span class=\"info__label\">HTTP methods</span>\n  <span *ngFor=\"let method of methods\" class=\"info__value method\" [ngClass]=\"method.class\"> {{ method.name }}</span>\n</div>\n\n<!-- Condition -->\n\n<div *ngIf=\"condition\" class=\"info\">\n  <span class=\"info__label\">Condition</span>\n  <span class=\"info__value gio-badge-neutral condition\">{{ condition }}</span>\n</div>\n"]}
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gio-ps-flow-details-info-bar.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-policy-studio-angular/src/lib/components/flow-details-info-bar/gio-ps-flow-details-info-bar.component.ts","../../../../../../projects/ui-policy-studio-angular/src/lib/components/flow-details-info-bar/gio-ps-flow-details-info-bar.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, Input } from '@angular/core';\nimport { isEmpty } from 'lodash';\nimport { GioIconsModule } from '@gravitee/ui-particles-angular';\nimport { MatCommonModule } from '@angular/material/core';\nimport { CommonModule } from '@angular/common';\n\nimport { ChannelSelector, ConditionSelector, ConnectorInfo, HttpSelector, Operation } from '../../models';\nimport { FlowVM } from '../../policy-studio/gio-policy-studio.model';\n\n@Component({\n  standalone: true,\n  imports: [CommonModule, GioIconsModule, MatCommonModule],\n  selector: 'gio-ps-flow-details-info-bar',\n  templateUrl: './gio-ps-flow-details-info-bar.component.html',\n  styleUrls: ['./gio-ps-flow-details-info-bar.component.scss'],\n})\nexport class GioPolicyStudioDetailsInfoBarComponent {\n  @Input()\n  public flow?: FlowVM = undefined;\n\n  @Input()\n  public entrypointsInfo?: ConnectorInfo[];\n\n  public get condition(): string | undefined {\n    const conditionSelector = this.flow?.selectors?.find(s => s.type === 'CONDITION') as ConditionSelector;\n    if (!conditionSelector) {\n      return undefined;\n    }\n    return conditionSelector?.condition;\n  }\n\n  // MESSAGE API type\n\n  public get operations(): string[] | undefined {\n    const channelSelector = this.flow?.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n    if (!channelSelector) {\n      return undefined;\n    }\n    const operationToBadge: Record<Operation, string> = {\n      PUBLISH: 'PUB',\n      SUBSCRIBE: 'SUB',\n    };\n    // If no operations are selected, all operations are valid\n    const operations =\n      !channelSelector.operations || isEmpty(channelSelector.operations) ? (['PUBLISH', 'SUBSCRIBE'] as const) : channelSelector.operations;\n\n    return operations.map(o => operationToBadge[o]).sort();\n  }\n\n  public get channel(): string | undefined {\n    const channelSelector = this.flow?.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n    if (!channelSelector) {\n      return undefined;\n    }\n    return channelSelector?.channel;\n  }\n\n  public get channelOperator(): string | undefined {\n    const channelSelector = this.flow?.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n    if (!channelSelector) {\n      return undefined;\n    }\n    return channelSelector?.channelOperator;\n  }\n\n  public get entrypoints(): ConnectorInfo[] | undefined {\n    const channelSelector = this.flow?.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n    if (!channelSelector) {\n      return undefined;\n    }\n\n    return this.entrypointsInfo?.filter(\n      e =>\n        // If no entrypoints are selected, all entrypoints are valid\n        !channelSelector.entrypoints || isEmpty(channelSelector.entrypoints) || channelSelector.entrypoints?.includes(e.type),\n    );\n  }\n\n  // PROXY API type\n\n  public get path(): string | undefined {\n    const httpSelector = this.flow?.selectors?.find(s => s.type === 'HTTP') as HttpSelector;\n    if (!httpSelector) {\n      return undefined;\n    }\n    return httpSelector?.path;\n  }\n\n  public get pathOperator(): string | undefined {\n    const httpSelector = this.flow?.selectors?.find(s => s.type === 'HTTP') as HttpSelector;\n    if (!httpSelector) {\n      return undefined;\n    }\n    return httpSelector?.pathOperator;\n  }\n\n  public get methods(): { name: string; class: string }[] | undefined {\n    const httpSelector = this.flow?.selectors?.find(s => s.type === 'HTTP') as HttpSelector;\n    if (!httpSelector) {\n      return undefined;\n    }\n    return httpSelector?.methods?.length\n      ? httpSelector?.methods.map(m => ({\n          name: m,\n          class: `gio-method-badge-${m.toLowerCase()}`,\n        }))\n      : [\n          {\n            name: 'ALL',\n            class: 'gio-badge-neutral',\n          },\n        ];\n  }\n}\n","<!--\n\n    Copyright (C) 2023 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<div *ngIf=\"flow?.name\" class=\"info\">\n  <span class=\"info__label\">Name</span>\n  <span class=\"info__value strong\">{{ flow?.name }}</span>\n</div>\n\n<div *ngIf=\"entrypoints\" class=\"info\">\n  <span class=\"info__label\">Entrypoints</span>\n  <span *ngFor=\"let entrypoint of entrypoints\" class=\"info__value gio-badge gio-badge-neutral\">\n    <mat-icon [svgIcon]=\"entrypoint.icon\"></mat-icon>\n    {{ entrypoint.name }}</span\n  >\n</div>\n\n<!-- MESSAGE API type -->\n\n<div *ngIf=\"operations\" class=\"info\">\n  <span class=\"info__label\">Operations</span>\n  <span *ngFor=\"let operation of operations\" class=\"info__value gio-badge-neutral\"> {{ operation }}</span>\n</div>\n\n<div *ngIf=\"channel\" class=\"info\">\n  <span class=\"info__label\">Channel</span>\n  <span class=\"info__value strong\">{{ channel }}</span>\n</div>\n\n<div *ngIf=\"channelOperator\" class=\"info\">\n  <span class=\"info__label\">Channel Operator</span>\n  <span class=\"info__value gio-badge-neutral\">{{ channelOperator }}</span>\n</div>\n\n<!-- PROXY API type -->\n\n<div *ngIf=\"path\" class=\"info\">\n  <span class=\"info__label\">Path</span>\n  <span class=\"info__value strong\">{{ path }}</span>\n</div>\n\n<div *ngIf=\"pathOperator\" class=\"info\">\n  <span class=\"info__label\">Path Operator</span>\n  <span class=\"info__value gio-badge-neutral\">{{ pathOperator }}</span>\n</div>\n\n<div *ngIf=\"methods\" class=\"info\">\n  <span class=\"info__label\">HTTP methods</span>\n  <span *ngFor=\"let method of methods\" class=\"info__value method\" [ngClass]=\"method.class\"> {{ method.name }}</span>\n</div>\n\n<!-- Condition -->\n\n<div *ngIf=\"condition\" class=\"info\">\n  <span class=\"info__label\">Condition</span>\n  <span class=\"info__value gio-badge-neutral condition\">{{ condition }}</span>\n</div>\n"]}