From 5c62b67ea72d1f303bcb4b3d270cf9ba5e505b8b Mon Sep 17 00:00:00 2001 From: Matt Gilman Date: Thu, 6 Jun 2024 11:19:58 -0400 Subject: [PATCH] NIFI-13368: (#8931) - Allowing tooltip mouse listeners to be destroyed when necessary. - Ensuring connection source/destination run status and validation errors are updated when deleted. This closes #8931 --- .../service/canvas-utils.service.ts | 16 +++++++++++++++- .../service/manager/port-manager.service.ts | 4 ++++ .../manager/process-group-manager.service.ts | 4 ++++ .../service/manager/processor-manager.service.ts | 4 ++++ .../remote-process-group-manager.service.ts | 4 ++++ .../flow-designer/state/flow/flow.effects.ts | 4 +++- 6 files changed, 34 insertions(+), 2 deletions(-) diff --git a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/canvas-utils.service.ts b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/canvas-utils.service.ts index 93956c5894..96e35c5441 100644 --- a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/canvas-utils.service.ts +++ b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/canvas-utils.service.ts @@ -767,7 +767,7 @@ export class CanvasUtils { /** * Determines the connectable type for the specified source. * - * @argument {type} ComponentType The component type + * @param type The type of component */ getConnectableTypeForSource(type: ComponentType): string { switch (type) { @@ -1221,6 +1221,17 @@ export class CanvasUtils { }); } + /** + * Reset the tooltip for the specified selection. + * + * @param selection + */ + public resetCanvasTooltip(selection: any): void { + // while tooltips are created dynamically, we need to provide the ability to remove the mouse + // listener to prevent new tooltips from being created on subsequent mouse enter/leave + selection.on('mouseenter', null).on('mouseleave', null); + } + /** * Sets the bulletin visibility and applies a tooltip if necessary. * @@ -1232,6 +1243,9 @@ export class CanvasUtils { // reset the bulletin icon/background selection.select('text.bulletin-icon').style('visibility', 'hidden'); selection.select('rect.bulletin-background').style('visibility', 'hidden'); + + // reset the canvas tooltip + this.resetCanvasTooltip(selection); } else { // show the bulletin icon/background const bulletinIcon: any = selection.select('text.bulletin-icon').style('visibility', 'visible'); diff --git a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/port-manager.service.ts b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/port-manager.service.ts index 87a8890f8b..72e5e79c1f 100644 --- a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/port-manager.service.ts +++ b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/port-manager.service.ts @@ -323,6 +323,8 @@ export class PortManager { .each(function (this: any) { if (!self.nifiCommon.isBlank(portData.component.comments)) { self.canvasUtils.canvasTooltip(TextTip, d3.select(this), portData.component.comments); + } else { + self.canvasUtils.resetCanvasTooltip(d3.select(this)); } }); } else { @@ -414,6 +416,8 @@ export class PortManager { isValidating: false, validationErrors: d.component.validationErrors }); + } else { + self.canvasUtils.resetCanvasTooltip(d3.select(this)); } }); diff --git a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/process-group-manager.service.ts b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/process-group-manager.service.ts index bd48801e1b..43c20044bf 100644 --- a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/process-group-manager.service.ts +++ b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/process-group-manager.service.ts @@ -1127,6 +1127,8 @@ export class ProcessGroupManager { self.canvasUtils.canvasTooltip(VersionControlTip, d3.select(this), { versionControlInformation: processGroupData.component.versionControlInformation }); + } else { + self.canvasUtils.resetCanvasTooltip(d3.select(this)); } }); @@ -1144,6 +1146,8 @@ export class ProcessGroupManager { d3.select(this), processGroupData.component.comments ); + } else { + self.canvasUtils.resetCanvasTooltip(d3.select(this)); } }); diff --git a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/processor-manager.service.ts b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/processor-manager.service.ts index 0655dc0d07..bdad164279 100644 --- a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/processor-manager.service.ts +++ b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/processor-manager.service.ts @@ -550,6 +550,8 @@ export class ProcessorManager { d3.select(nodes[i]), processorData.component.config.comments ); + } else { + this.canvasUtils.resetCanvasTooltip(d3.select(nodes[i])); } }); } else { @@ -730,6 +732,8 @@ export class ProcessorManager { isValidating: d.status.aggregateSnapshot.runStatus === 'Validating', validationErrors: d.component.validationErrors }); + } else { + this.canvasUtils.resetCanvasTooltip(d3.select(nodes[i])); } }); diff --git a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/remote-process-group-manager.service.ts b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/remote-process-group-manager.service.ts index 2b50a735b4..9f750bb821 100644 --- a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/remote-process-group-manager.service.ts +++ b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/service/manager/remote-process-group-manager.service.ts @@ -465,6 +465,8 @@ export class RemoteProcessGroupManager { d3.select(this), remoteProcessGroupData.component.comments ); + } else { + self.canvasUtils.resetCanvasTooltip(d3.select(this)); } }); @@ -622,6 +624,8 @@ export class RemoteProcessGroupManager { isValidating: false, validationErrors: self.getIssues(d) }); + } else { + self.canvasUtils.resetCanvasTooltip(d3.select(this)); } }); diff --git a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/state/flow/flow.effects.ts b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/state/flow/flow.effects.ts index e14bbe7a6b..0db398c082 100644 --- a/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/state/flow/flow.effects.ts +++ b/nifi-framework-bundle/nifi-framework/nifi-web/nifi-web-frontend/src/main/nifi/apps/nifi/src/app/pages/flow-designer/state/flow/flow.effects.ts @@ -2287,7 +2287,7 @@ export class FlowEffects { mergeMap(([requests, processGroupId]) => { if (requests.length === 1) { return from(this.flowService.deleteComponent(requests[0])).pipe( - map(() => { + map((response) => { const deleteResponses: DeleteComponentResponse[] = [ { id: requests[0].id, @@ -2305,6 +2305,8 @@ export class FlowEffects { type: ComponentType.Connection }) ); + } else { + this.store.dispatch(FlowActions.loadComponentsForConnection({ connection: response })); } return FlowActions.deleteComponentsSuccess({