diff --git a/packages/editor-ui/src/components/NodeCreator/NodeCreator.vue b/packages/editor-ui/src/components/NodeCreator/NodeCreator.vue index b269b367e4..f15adc8cf7 100644 --- a/packages/editor-ui/src/components/NodeCreator/NodeCreator.vue +++ b/packages/editor-ui/src/components/NodeCreator/NodeCreator.vue @@ -41,14 +41,9 @@ export default Vue.extend({ props: [ 'active', ], - data() { - return { - allLatestNodeTypes: [] as INodeTypeDescription[], - }; - }, computed: { ...mapGetters('users', ['personalizedNodeTypes']), - nodeTypes(): INodeTypeDescription[] { + allLatestNodeTypes(): INodeTypeDescription[] { return this.$store.getters['nodeTypes/allLatestNodeTypes']; }, visibleNodeTypes(): INodeTypeDescription[] { @@ -107,13 +102,6 @@ export default Vue.extend({ } }, }, - watch: { - nodeTypes(newList) { - if (newList.length !== this.allLatestNodeTypes.length) { - this.allLatestNodeTypes = newList; - } - }, - }, }); diff --git a/packages/editor-ui/src/components/SettingsSidebar.vue b/packages/editor-ui/src/components/SettingsSidebar.vue index ac14f52c04..9ade642415 100644 --- a/packages/editor-ui/src/components/SettingsSidebar.vue +++ b/packages/editor-ui/src/components/SettingsSidebar.vue @@ -56,11 +56,13 @@ import mixins from 'vue-typed-mixins'; import { mapGetters } from 'vuex'; import { ABOUT_MODAL_KEY, VERSIONS_MODAL_KEY, VIEWS } from '@/constants'; import { userHelpers } from './mixins/userHelpers'; +import { pushConnection } from "@/components/mixins/pushConnection"; import { IFakeDoor } from '@/Interface'; import GiftNotificationIcon from './GiftNotificationIcon.vue'; export default mixins( userHelpers, + pushConnection, ).extend({ name: 'SettingsSidebar', components: { @@ -95,6 +97,9 @@ export default mixins( this.$store.dispatch('ui/openModal', VERSIONS_MODAL_KEY); }, }, + mounted() { + this.pushConnect(); + }, }); diff --git a/packages/editor-ui/src/components/mixins/pushConnection.ts b/packages/editor-ui/src/components/mixins/pushConnection.ts index 41a08a2bc5..4030bac463 100644 --- a/packages/editor-ui/src/components/mixins/pushConnection.ts +++ b/packages/editor-ui/src/components/mixins/pushConnection.ts @@ -362,6 +362,7 @@ export const pushConnection = mixins( this.processWaitingPushMessages(); } else if (receivedData.type === 'reloadNodeType') { + this.$store.dispatch('nodeTypes/getNodeTypes'); this.$store.dispatch('nodeTypes/getFullNodesProperties', [receivedData.data]); } else if (receivedData.type === 'removeNodeType') { const pushData = receivedData.data; diff --git a/packages/editor-ui/src/modules/nodeTypes.ts b/packages/editor-ui/src/modules/nodeTypes.ts index 2df865d977..1f0a35f3ee 100644 --- a/packages/editor-ui/src/modules/nodeTypes.ts +++ b/packages/editor-ui/src/modules/nodeTypes.ts @@ -57,7 +57,7 @@ const module: Module = { }, }, mutations: { - setNodeTypes(state, newNodeTypes: INodeTypeDescription[]) { + setNodeTypes(state, newNodeTypes: INodeTypeDescription[] = []) { const nodeTypes = newNodeTypes.reduce>>((acc, newNodeType) => { const newNodeVersions = getNodeVersions(newNodeType); diff --git a/packages/editor-ui/src/views/CredentialsView.vue b/packages/editor-ui/src/views/CredentialsView.vue index f0e1fb4aae..00de72a231 100644 --- a/packages/editor-ui/src/views/CredentialsView.vue +++ b/packages/editor-ui/src/views/CredentialsView.vue @@ -393,11 +393,16 @@ export default mixins( }); }, async initialize() { - await Promise.all([ + const loadPromises = [ this.$store.dispatch('credentials/fetchAllCredentials'), this.$store.dispatch('credentials/fetchCredentialTypes'), - this.$store.dispatch('nodeTypes/getNodeTypes'), - ]); + ]; + + if (this.$store.getters['nodeTypes/allNodeTypes'].length === 0) { + loadPromises.push(this.$store.dispatch('nodeTypes/getNodeTypes')); + } + + await Promise.all(loadPromises); this.loading = false; this.$nextTick(this.focusSearchInput); diff --git a/packages/editor-ui/src/views/NodeView.vue b/packages/editor-ui/src/views/NodeView.vue index a34d3671d1..0c0f6663d3 100644 --- a/packages/editor-ui/src/views/NodeView.vue +++ b/packages/editor-ui/src/views/NodeView.vue @@ -3044,9 +3044,12 @@ export default mixins( this.loadActiveWorkflows(), this.loadCredentials(), this.loadCredentialTypes(), - this.loadNodeTypes(), ]; + if (this.$store.getters['nodeTypes/allNodeTypes'].length === 0) { + loadPromises.push(this.loadNodeTypes()); + } + try { await Promise.all(loadPromises); } catch (error) {