diff --git a/packages/editor-ui/src/views/NodeView.vue b/packages/editor-ui/src/views/NodeView.vue index 239c3246cc..1f1c591c0f 100644 --- a/packages/editor-ui/src/views/NodeView.vue +++ b/packages/editor-ui/src/views/NodeView.vue @@ -2003,10 +2003,8 @@ export default mixins( this.$store.commit('renameNodeSelectedAndExecution', { old: currentName, new: newName }); // Reset all nodes and connections to load the new ones - if (this.instance) { - // On first load it does not exist - this.instance.deleteEveryEndpoint(); - } + this.deleteEveryEndpoint(); + this.$store.commit('removeAllConnections'); this.$store.commit('removeAllNodes', {setStateDirty: true}); @@ -2020,6 +2018,16 @@ export default mixins( this.deselectAllNodes(); this.nodeSelectedByName(newName); }, + deleteEveryEndpoint () { + if (this.instance) { + const nodes = this.$store.getters.allNodes as INodeUi[]; + // @ts-ignore + nodes.forEach((node: INodeUi) => this.instance.destroyDraggable(`${NODE_NAME_PREFIX}${this.$store.getters.getNodeIndex(node.name)}`)); + + // On first load it does not exist + this.instance.deleteEveryEndpoint(); + } + }, matchCredentials(node: INodeUi) { if (!node.credentials) { return; @@ -2336,10 +2344,7 @@ export default mixins( }, resetWorkspace () { // Reset nodes - if (this.instance) { - // On first load it does not exist - this.instance.deleteEveryEndpoint(); - } + this.deleteEveryEndpoint(); if (this.executionWaitingForWebhook === true) { // Make sure that if there is a waiting test-webhook that