@gravitee/ui-policy-studio-angular 13.1.2 → 13.1.3

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.
@@ -76,7 +76,7 @@ export class GioPolicyStudioFlowsMenuComponent {
76
76
  if (httpSelector) {
77
77
  // Keep only 2 first http methods and add +X badge if there are more
78
78
  const httpMethodsToKeep = httpSelector.methods?.slice(0, 2);
79
- const httpMethodsLength = httpSelector.methods?.length;
79
+ const httpMethodsLength = httpSelector.methods?.length ?? 0;
80
80
  httpMethodsToKeep &&
81
81
  badges.push(...httpMethodsToKeep.map(method => ({ label: method, class: `gio-method-badge-${method.toLowerCase()}` })));
82
82
  if (httpMethodsLength && httpMethodsLength > 2) {
@@ -203,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
203
203
  }], flowExecutionChange: [{
204
204
  type: Output
205
205
  }] } });
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gio-ps-flows-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-policy-studio-angular/src/lib/components/flows-menu/gio-ps-flows-menu.component.ts","../../../../../../projects/ui-policy-studio-angular/src/lib/components/flows-menu/gio-ps-flows-menu.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 { cloneDeep, isEmpty } from 'lodash';\nimport { GIO_DIALOG_WIDTH, GioIconsModule, GioLoaderModule } from '@gravitee/ui-particles-angular';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatButtonModule } from '@angular/material/button';\nimport { CommonModule } from '@angular/common';\n\nimport {\n  GioPolicyStudioFlowMessageFormDialogComponent,\n  GioPolicyStudioFlowMessageFormDialogData,\n} from '../flow-form-dialog/flow-message-form-dialog/gio-ps-flow-message-form-dialog.component';\nimport { FlowGroupVM, FlowVM } from '../../policy-studio/gio-policy-studio.model';\nimport { ApiType, ChannelSelector, ConditionSelector, ConnectorInfo, FlowExecution, HttpSelector, Operation } 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 {\n  GioPolicyStudioFlowExecutionFormDialogComponent,\n  GioPolicyStudioFlowExecutionFormDialogData,\n} from '../flow-execution-form-dialog/gio-ps-flow-execution-form-dialog.component';\n\ninterface FlowGroupMenuVM extends FlowGroupVM {\n  flows: FlowMenuVM[];\n}\n\ninterface FlowMenuVM extends FlowVM {\n  selected: boolean;\n  mouseOver: boolean;\n  badges: {\n    label: string;\n    class: string;\n  }[];\n  pathOrChannelLabel: string;\n  hasCondition: boolean;\n}\n\n@Component({\n  standalone: true,\n  imports: [GioIconsModule, MatTooltipModule, MatButtonModule, CommonModule, GioLoaderModule],\n  selector: 'gio-ps-flows-menu',\n  templateUrl: './gio-ps-flows-menu.component.html',\n  styleUrls: ['./gio-ps-flows-menu.component.scss'],\n})\nexport class GioPolicyStudioFlowsMenuComponent 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 flowExecution!: FlowExecution;\n\n  @Input()\n  public flowsGroups: FlowGroupVM[] = [];\n\n  @Input()\n  public selectedFlow?: FlowVM = undefined;\n\n  @Input()\n  public entrypoints: ConnectorInfo[] = [];\n\n  @Output()\n  public selectedFlowChange = new EventEmitter<FlowVM>();\n\n  @Output()\n  public flowsGroupsChange = new EventEmitter<FlowGroupVM[]>();\n\n  @Output()\n  public flowExecutionChange = new EventEmitter<FlowExecution>();\n\n  public flowGroupMenuItems: FlowGroupMenuVM[] = [];\n\n  constructor(private readonly matDialog: MatDialog) {}\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.flowsGroups || changes.selectedFlow) {\n      this.flowGroupMenuItems = cloneDeep(this.flowsGroups).map(flowGroup => {\n        return {\n          ...flowGroup,\n          flows: flowGroup.flows.map(flow => {\n            const badges: FlowMenuVM['badges'] = [];\n            let pathOrChannelLabel = '';\n            let hasCondition = false;\n\n            // MESSAGE API - CHANNEL\n            const channelSelector = flow.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n            if (channelSelector) {\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 operationBadges = (\n                !channelSelector.operations || isEmpty(channelSelector.operations)\n                  ? (['PUBLISH', 'SUBSCRIBE'] as const)\n                  : channelSelector.operations\n              )\n                .map(operation => ({\n                  label: operationToBadge[operation],\n                  class: 'gio-badge-neutral',\n                }))\n                .sort((a, b) => a.label.localeCompare(b.label));\n              operationBadges && badges.push(...operationBadges);\n              pathOrChannelLabel = `${channelSelector.channel}${channelSelector.channelOperator === 'STARTS_WITH' ? '**' : ''}`;\n            }\n\n            // HTTP API - HTTP\n            const httpSelector = flow.selectors?.find(s => s.type === 'HTTP') as HttpSelector;\n            if (httpSelector) {\n              // Keep only 2 first http methods and add +X badge if there are more\n              const httpMethodsToKeep = httpSelector.methods?.slice(0, 2);\n              const httpMethodsLength = httpSelector.methods?.length;\n              httpMethodsToKeep &&\n                badges.push(...httpMethodsToKeep.map(method => ({ label: method, class: `gio-method-badge-${method.toLowerCase()}` })));\n              if (httpMethodsLength && httpMethodsLength > 2) {\n                badges?.push({\n                  label: `+${httpMethodsLength - 2}`,\n                  class: 'gio-badge-neutral',\n                });\n              }\n              if (httpMethodsLength === 0) {\n                badges?.push({\n                  label: 'ALL',\n                  class: 'gio-badge-neutral',\n                });\n              }\n\n              pathOrChannelLabel = `${httpSelector.path}${httpSelector.pathOperator === 'STARTS_WITH' ? '/**' : ''}`;\n            }\n\n            const conditionSelector = flow.selectors?.find(s => s.type === 'CONDITION') as ConditionSelector;\n            if (conditionSelector && conditionSelector.condition) {\n              hasCondition = true;\n            }\n\n            return {\n              ...flow,\n              selected: this.selectedFlow?._id === flow._id,\n              mouseOver: false,\n              badges,\n              pathOrChannelLabel,\n              hasCondition,\n            };\n          }),\n        };\n      });\n    }\n  }\n\n  public selectFlow(groupId: string, flowId: string): void {\n    const flow = this.flowsGroups.find(fg => fg._id === groupId)?.flows.find(f => f._id === flowId);\n    if (flow) {\n      this.selectedFlowChange.emit(flow);\n    }\n  }\n\n  public onAddFlow(flowGroup: FlowGroupVM): 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: undefined,\n                entrypoints: this.entrypoints,\n              },\n              role: 'alertdialog',\n              id: 'gioPsFlowFormDialog',\n              width: GIO_DIALOG_WIDTH.MEDIUM,\n            })\n            .afterClosed()\n        : this.matDialog\n            .open<GioPolicyStudioFlowProxyFormDialogComponent, GioPolicyStudioFlowProxyFormDialogData, GioPolicyStudioFlowFormDialogResult>(\n              GioPolicyStudioFlowProxyFormDialogComponent,\n              {\n                data: {\n                  flow: undefined,\n                },\n                role: 'alertdialog',\n                id: 'gioPsFlowFormDialog',\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          const editedFlowsGroups = cloneDeep(this.flowsGroups);\n\n          const flowsGroupToEdit = editedFlowsGroups.find(fg => fg._id === flowGroup._id);\n          if (!flowsGroupToEdit) {\n            throw new Error(`Flow group ${flowGroup._id} not found`);\n          }\n          flowsGroupToEdit.flows.push(createdOrEdited);\n\n          this.flowsGroupsChange.emit(editedFlowsGroups);\n          this.selectedFlowChange.emit(createdOrEdited);\n        }),\n      )\n      .subscribe();\n  }\n\n  public onConfigureExecution(flowExecution: FlowExecution): void {\n    const dialogResult = this.matDialog\n      .open<GioPolicyStudioFlowExecutionFormDialogComponent, GioPolicyStudioFlowExecutionFormDialogData, FlowExecution | undefined>(\n        GioPolicyStudioFlowExecutionFormDialogComponent,\n        {\n          data: {\n            flowExecution,\n            readOnly: this.readOnly,\n          },\n          role: 'alertdialog',\n          id: 'gioPsFlowExecutionFormDialog',\n          width: GIO_DIALOG_WIDTH.MEDIUM,\n        },\n      )\n      .afterClosed();\n\n    dialogResult\n      .pipe(\n        tap(edited => {\n          if (!edited) {\n            return;\n          }\n          this.flowExecutionChange.emit(edited);\n        }),\n      )\n      .subscribe();\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<div class=\"header\">\n  <div class=\"header__label\">\n    Flows <mat-icon svgIcon=\"gio:info\" matTooltip=\"Flows allow you to apply different policies on your API event phases\"></mat-icon>\n  </div>\n  <div class=\"header__configBtn\">\n    <button class=\"header__configBtn_edit\" mat-stroked-button [disabled]=\"loading\" (click)=\"onConfigureExecution(flowExecution)\">\n      <mat-icon [svgIcon]=\"readOnly ? 'gio:eye-empty' : 'gio:settings'\"></mat-icon>\n    </button>\n  </div>\n</div>\n\n<div class=\"list\" *ngIf=\"!loading; else loadingList\">\n  <div *ngFor=\"let flowsGroup of flowGroupMenuItems\" class=\"list__flowsGroup\">\n    <div class=\"list__flowsGroup__header\">\n      <div class=\"list__flowsGroup__header__label\">\n        <mat-icon *ngIf=\"flowsGroup._icon\" [svgIcon]=\"flowsGroup._icon\"></mat-icon>\n        <span>{{ flowsGroup.name }}</span>\n      </div>\n      <div class=\"list__flowsGroup__header__addBtn\">\n        <button mat-button [disabled]=\"readOnly\" (click)=\"onAddFlow(flowsGroup)\">\n          <mat-icon svgIcon=\"gio:plus\" matTooltip=\"New flow\"></mat-icon>\n        </button>\n      </div>\n    </div>\n\n    <div\n      *ngFor=\"let flow of flowsGroup.flows\"\n      class=\"list__flowsGroup__flow\"\n      [class.selected]=\"flow.selected\"\n      (click)=\"selectFlow(flowsGroup._id, flow._id)\"\n      (mouseout)=\"flow.mouseOver = false\"\n      (mouseover)=\"flow.mouseOver = true\"\n    >\n      <div *ngIf=\"flow.name\" class=\"list__flowsGroup__flow__name\" [attr.title]=\"flow.name\">\n        {{ flow.name }}\n      </div>\n      <div class=\"list__flowsGroup__flow__infos\">\n        <div class=\"list__flowsGroup__flow__infos__badges\">\n          <span *ngFor=\"let badge of flow.badges\" class=\"list__flowsGroup__flow__infos__badges__badge\" [ngClass]=\"badge.class\">{{\n            badge.label\n          }}</span>\n        </div>\n        <div class=\"list__flowsGroup__flow__infos__pathOrChannelLabel\">\n          <span *ngIf=\"flow.pathOrChannelLabel; else emptyPathOrChannelLabel\" [attr.title]=\"flow.pathOrChannelLabel\">{{\n            flow.pathOrChannelLabel\n          }}</span>\n          <ng-template #emptyPathOrChannelLabel>\n            <em>Empty</em>\n          </ng-template>\n        </div>\n\n        <span *ngIf=\"flow.hasCondition\" class=\"list__flowsGroup__flow__infos__conditionBadge gio-badge-neutral\" matTooltip=\"Conditioned\"\n          ><mat-icon svgIcon=\"gio:if\"></mat-icon\n        ></span>\n      </div>\n    </div>\n  </div>\n</div>\n\n<ng-template #loadingList>\n  <div class=\"loadingList\">\n    <gio-loader></gio-loader>\n  </div>\n</ng-template>\n"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gio-ps-flows-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-policy-studio-angular/src/lib/components/flows-menu/gio-ps-flows-menu.component.ts","../../../../../../projects/ui-policy-studio-angular/src/lib/components/flows-menu/gio-ps-flows-menu.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 { cloneDeep, isEmpty } from 'lodash';\nimport { GIO_DIALOG_WIDTH, GioIconsModule, GioLoaderModule } from '@gravitee/ui-particles-angular';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatButtonModule } from '@angular/material/button';\nimport { CommonModule } from '@angular/common';\n\nimport {\n  GioPolicyStudioFlowMessageFormDialogComponent,\n  GioPolicyStudioFlowMessageFormDialogData,\n} from '../flow-form-dialog/flow-message-form-dialog/gio-ps-flow-message-form-dialog.component';\nimport { FlowGroupVM, FlowVM } from '../../policy-studio/gio-policy-studio.model';\nimport { ApiType, ChannelSelector, ConditionSelector, ConnectorInfo, FlowExecution, HttpSelector, Operation } 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 {\n  GioPolicyStudioFlowExecutionFormDialogComponent,\n  GioPolicyStudioFlowExecutionFormDialogData,\n} from '../flow-execution-form-dialog/gio-ps-flow-execution-form-dialog.component';\n\ninterface FlowGroupMenuVM extends FlowGroupVM {\n  flows: FlowMenuVM[];\n}\n\ninterface FlowMenuVM extends FlowVM {\n  selected: boolean;\n  mouseOver: boolean;\n  badges: {\n    label: string;\n    class: string;\n  }[];\n  pathOrChannelLabel: string;\n  hasCondition: boolean;\n}\n\n@Component({\n  standalone: true,\n  imports: [GioIconsModule, MatTooltipModule, MatButtonModule, CommonModule, GioLoaderModule],\n  selector: 'gio-ps-flows-menu',\n  templateUrl: './gio-ps-flows-menu.component.html',\n  styleUrls: ['./gio-ps-flows-menu.component.scss'],\n})\nexport class GioPolicyStudioFlowsMenuComponent 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 flowExecution!: FlowExecution;\n\n  @Input()\n  public flowsGroups: FlowGroupVM[] = [];\n\n  @Input()\n  public selectedFlow?: FlowVM = undefined;\n\n  @Input()\n  public entrypoints: ConnectorInfo[] = [];\n\n  @Output()\n  public selectedFlowChange = new EventEmitter<FlowVM>();\n\n  @Output()\n  public flowsGroupsChange = new EventEmitter<FlowGroupVM[]>();\n\n  @Output()\n  public flowExecutionChange = new EventEmitter<FlowExecution>();\n\n  public flowGroupMenuItems: FlowGroupMenuVM[] = [];\n\n  constructor(private readonly matDialog: MatDialog) {}\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.flowsGroups || changes.selectedFlow) {\n      this.flowGroupMenuItems = cloneDeep(this.flowsGroups).map(flowGroup => {\n        return {\n          ...flowGroup,\n          flows: flowGroup.flows.map(flow => {\n            const badges: FlowMenuVM['badges'] = [];\n            let pathOrChannelLabel = '';\n            let hasCondition = false;\n\n            // MESSAGE API - CHANNEL\n            const channelSelector = flow.selectors?.find(s => s.type === 'CHANNEL') as ChannelSelector;\n            if (channelSelector) {\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 operationBadges = (\n                !channelSelector.operations || isEmpty(channelSelector.operations)\n                  ? (['PUBLISH', 'SUBSCRIBE'] as const)\n                  : channelSelector.operations\n              )\n                .map(operation => ({\n                  label: operationToBadge[operation],\n                  class: 'gio-badge-neutral',\n                }))\n                .sort((a, b) => a.label.localeCompare(b.label));\n              operationBadges && badges.push(...operationBadges);\n              pathOrChannelLabel = `${channelSelector.channel}${channelSelector.channelOperator === 'STARTS_WITH' ? '**' : ''}`;\n            }\n\n            // HTTP API - HTTP\n            const httpSelector = flow.selectors?.find(s => s.type === 'HTTP') as HttpSelector;\n            if (httpSelector) {\n              // Keep only 2 first http methods and add +X badge if there are more\n              const httpMethodsToKeep = httpSelector.methods?.slice(0, 2);\n              const httpMethodsLength = httpSelector.methods?.length ?? 0;\n              httpMethodsToKeep &&\n                badges.push(...httpMethodsToKeep.map(method => ({ label: method, class: `gio-method-badge-${method.toLowerCase()}` })));\n              if (httpMethodsLength && httpMethodsLength > 2) {\n                badges?.push({\n                  label: `+${httpMethodsLength - 2}`,\n                  class: 'gio-badge-neutral',\n                });\n              }\n              if (httpMethodsLength === 0) {\n                badges?.push({\n                  label: 'ALL',\n                  class: 'gio-badge-neutral',\n                });\n              }\n\n              pathOrChannelLabel = `${httpSelector.path}${httpSelector.pathOperator === 'STARTS_WITH' ? '/**' : ''}`;\n            }\n\n            const conditionSelector = flow.selectors?.find(s => s.type === 'CONDITION') as ConditionSelector;\n            if (conditionSelector && conditionSelector.condition) {\n              hasCondition = true;\n            }\n\n            return {\n              ...flow,\n              selected: this.selectedFlow?._id === flow._id,\n              mouseOver: false,\n              badges,\n              pathOrChannelLabel,\n              hasCondition,\n            };\n          }),\n        };\n      });\n    }\n  }\n\n  public selectFlow(groupId: string, flowId: string): void {\n    const flow = this.flowsGroups.find(fg => fg._id === groupId)?.flows.find(f => f._id === flowId);\n    if (flow) {\n      this.selectedFlowChange.emit(flow);\n    }\n  }\n\n  public onAddFlow(flowGroup: FlowGroupVM): 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: undefined,\n                entrypoints: this.entrypoints,\n              },\n              role: 'alertdialog',\n              id: 'gioPsFlowFormDialog',\n              width: GIO_DIALOG_WIDTH.MEDIUM,\n            })\n            .afterClosed()\n        : this.matDialog\n            .open<GioPolicyStudioFlowProxyFormDialogComponent, GioPolicyStudioFlowProxyFormDialogData, GioPolicyStudioFlowFormDialogResult>(\n              GioPolicyStudioFlowProxyFormDialogComponent,\n              {\n                data: {\n                  flow: undefined,\n                },\n                role: 'alertdialog',\n                id: 'gioPsFlowFormDialog',\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          const editedFlowsGroups = cloneDeep(this.flowsGroups);\n\n          const flowsGroupToEdit = editedFlowsGroups.find(fg => fg._id === flowGroup._id);\n          if (!flowsGroupToEdit) {\n            throw new Error(`Flow group ${flowGroup._id} not found`);\n          }\n          flowsGroupToEdit.flows.push(createdOrEdited);\n\n          this.flowsGroupsChange.emit(editedFlowsGroups);\n          this.selectedFlowChange.emit(createdOrEdited);\n        }),\n      )\n      .subscribe();\n  }\n\n  public onConfigureExecution(flowExecution: FlowExecution): void {\n    const dialogResult = this.matDialog\n      .open<GioPolicyStudioFlowExecutionFormDialogComponent, GioPolicyStudioFlowExecutionFormDialogData, FlowExecution | undefined>(\n        GioPolicyStudioFlowExecutionFormDialogComponent,\n        {\n          data: {\n            flowExecution,\n            readOnly: this.readOnly,\n          },\n          role: 'alertdialog',\n          id: 'gioPsFlowExecutionFormDialog',\n          width: GIO_DIALOG_WIDTH.MEDIUM,\n        },\n      )\n      .afterClosed();\n\n    dialogResult\n      .pipe(\n        tap(edited => {\n          if (!edited) {\n            return;\n          }\n          this.flowExecutionChange.emit(edited);\n        }),\n      )\n      .subscribe();\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<div class=\"header\">\n  <div class=\"header__label\">\n    Flows <mat-icon svgIcon=\"gio:info\" matTooltip=\"Flows allow you to apply different policies on your API event phases\"></mat-icon>\n  </div>\n  <div class=\"header__configBtn\">\n    <button class=\"header__configBtn_edit\" mat-stroked-button [disabled]=\"loading\" (click)=\"onConfigureExecution(flowExecution)\">\n      <mat-icon [svgIcon]=\"readOnly ? 'gio:eye-empty' : 'gio:settings'\"></mat-icon>\n    </button>\n  </div>\n</div>\n\n<div class=\"list\" *ngIf=\"!loading; else loadingList\">\n  <div *ngFor=\"let flowsGroup of flowGroupMenuItems\" class=\"list__flowsGroup\">\n    <div class=\"list__flowsGroup__header\">\n      <div class=\"list__flowsGroup__header__label\">\n        <mat-icon *ngIf=\"flowsGroup._icon\" [svgIcon]=\"flowsGroup._icon\"></mat-icon>\n        <span>{{ flowsGroup.name }}</span>\n      </div>\n      <div class=\"list__flowsGroup__header__addBtn\">\n        <button mat-button [disabled]=\"readOnly\" (click)=\"onAddFlow(flowsGroup)\">\n          <mat-icon svgIcon=\"gio:plus\" matTooltip=\"New flow\"></mat-icon>\n        </button>\n      </div>\n    </div>\n\n    <div\n      *ngFor=\"let flow of flowsGroup.flows\"\n      class=\"list__flowsGroup__flow\"\n      [class.selected]=\"flow.selected\"\n      (click)=\"selectFlow(flowsGroup._id, flow._id)\"\n      (mouseout)=\"flow.mouseOver = false\"\n      (mouseover)=\"flow.mouseOver = true\"\n    >\n      <div *ngIf=\"flow.name\" class=\"list__flowsGroup__flow__name\" [attr.title]=\"flow.name\">\n        {{ flow.name }}\n      </div>\n      <div class=\"list__flowsGroup__flow__infos\">\n        <div class=\"list__flowsGroup__flow__infos__badges\">\n          <span *ngFor=\"let badge of flow.badges\" class=\"list__flowsGroup__flow__infos__badges__badge\" [ngClass]=\"badge.class\">{{\n            badge.label\n          }}</span>\n        </div>\n        <div class=\"list__flowsGroup__flow__infos__pathOrChannelLabel\">\n          <span *ngIf=\"flow.pathOrChannelLabel; else emptyPathOrChannelLabel\" [attr.title]=\"flow.pathOrChannelLabel\">{{\n            flow.pathOrChannelLabel\n          }}</span>\n          <ng-template #emptyPathOrChannelLabel>\n            <em>Empty</em>\n          </ng-template>\n        </div>\n\n        <span *ngIf=\"flow.hasCondition\" class=\"list__flowsGroup__flow__infos__conditionBadge gio-badge-neutral\" matTooltip=\"Conditioned\"\n          ><mat-icon svgIcon=\"gio:if\"></mat-icon\n        ></span>\n      </div>\n    </div>\n  </div>\n</div>\n\n<ng-template #loadingList>\n  <div class=\"loadingList\">\n    <gio-loader></gio-loader>\n  </div>\n</ng-template>\n"]}
@@ -536,7 +536,7 @@ class GioPolicyStudioFlowsMenuComponent {
536
536
  if (httpSelector) {
537
537
  // Keep only 2 first http methods and add +X badge if there are more
538
538
  const httpMethodsToKeep = httpSelector.methods?.slice(0, 2);
539
- const httpMethodsLength = httpSelector.methods?.length;
539
+ const httpMethodsLength = httpSelector.methods?.length ?? 0;
540
540
  httpMethodsToKeep &&
541
541
  badges.push(...httpMethodsToKeep.map(method => ({ label: method, class: `gio-method-badge-${method.toLowerCase()}` })));
542
542
  if (httpMethodsLength && httpMethodsLength > 2) {