diff --git a/packages/editor-ui/src/__tests__/data/canvas.ts b/packages/editor-ui/src/__tests__/data/canvas.ts index e5ccb071a5..b7ac64fedc 100644 --- a/packages/editor-ui/src/__tests__/data/canvas.ts +++ b/packages/editor-ui/src/__tests__/data/canvas.ts @@ -1,6 +1,7 @@ import { CanvasNodeKey } from '@/constants'; import { ref } from 'vue'; -import type { CanvasElement, CanvasElementData } from '@/types'; +import type { CanvasNode, CanvasNodeData } from '@/types'; +import { CanvasNodeRenderType } from '@/types'; export function createCanvasNodeData({ id = 'node', @@ -15,10 +16,10 @@ export function createCanvasNodeData({ pinnedData = { count: 0, visible: false }, runData = { count: 0, visible: false }, render = { - type: 'default', + type: CanvasNodeRenderType.Default, options: { configurable: false, configuration: false, trigger: false }, }, -}: Partial = {}): CanvasElementData { +}: Partial = {}): CanvasNodeData { return { execution, issues, @@ -41,9 +42,7 @@ export function createCanvasNodeElement({ label = 'Node', position = { x: 100, y: 100 }, data, -}: Partial< - Omit & { data: Partial } -> = {}): CanvasElement { +}: Partial & { data: Partial }> = {}): CanvasNode { return { id, type, @@ -58,7 +57,7 @@ export function createCanvasNodeProps({ label = 'Test Node', selected = false, data = {}, -}: { id?: string; label?: string; selected?: boolean; data?: Partial } = {}) { +}: { id?: string; label?: string; selected?: boolean; data?: Partial } = {}) { return { id, label, @@ -72,7 +71,7 @@ export function createCanvasNodeProvide({ label = 'Test Node', selected = false, data = {}, -}: { id?: string; label?: string; selected?: boolean; data?: Partial } = {}) { +}: { id?: string; label?: string; selected?: boolean; data?: Partial } = {}) { const props = createCanvasNodeProps({ id, label, selected, data }); return { [`${CanvasNodeKey}`]: { @@ -85,8 +84,8 @@ export function createCanvasNodeProvide({ } export function createCanvasConnection( - nodeA: CanvasElement, - nodeB: CanvasElement, + nodeA: CanvasNode, + nodeB: CanvasNode, { sourceIndex = 0, targetIndex = 0 } = {}, ) { const nodeAOutput = nodeA.data?.outputs[sourceIndex]; diff --git a/packages/editor-ui/src/components/canvas/Canvas.spec.ts b/packages/editor-ui/src/components/canvas/Canvas.spec.ts index 5b99630fdf..d23e46cbfe 100644 --- a/packages/editor-ui/src/components/canvas/Canvas.spec.ts +++ b/packages/editor-ui/src/components/canvas/Canvas.spec.ts @@ -4,7 +4,7 @@ import { fireEvent, waitFor } from '@testing-library/vue'; import { createComponentRenderer } from '@/__tests__/render'; import Canvas from '@/components/canvas/Canvas.vue'; import { createPinia, setActivePinia } from 'pinia'; -import type { CanvasConnection, CanvasElement } from '@/types'; +import type { CanvasConnection, CanvasNode } from '@/types'; import { createCanvasConnection, createCanvasNodeElement } from '@/__tests__/data'; import { NodeConnectionType } from 'n8n-workflow'; @@ -44,7 +44,7 @@ describe('Canvas', () => { }); it('should render nodes and edges', async () => { - const elements: CanvasElement[] = [ + const nodes: CanvasNode[] = [ createCanvasNodeElement({ id: '1', label: 'Node 1', @@ -72,33 +72,33 @@ describe('Canvas', () => { }), ]; - const connections: CanvasConnection[] = [createCanvasConnection(elements[0], elements[1])]; + const connections: CanvasConnection[] = [createCanvasConnection(nodes[0], nodes[1])]; const { container } = renderComponent({ props: { - elements, + nodes, connections, }, }); await waitFor(() => expect(container.querySelectorAll('.vue-flow__node')).toHaveLength(2)); - expect(container.querySelector(`[data-id="${elements[0].id}"]`)).toBeInTheDocument(); - expect(container.querySelector(`[data-id="${elements[1].id}"]`)).toBeInTheDocument(); + expect(container.querySelector(`[data-id="${nodes[0].id}"]`)).toBeInTheDocument(); + expect(container.querySelector(`[data-id="${nodes[1].id}"]`)).toBeInTheDocument(); expect(container.querySelector(`[data-id="${connections[0].id}"]`)).toBeInTheDocument(); }); it('should handle node drag stop event', async () => { - const elements = [createCanvasNodeElement()]; + const nodes = [createCanvasNodeElement()]; const { container, emitted } = renderComponent({ props: { - elements, + nodes, }, }); await waitFor(() => expect(container.querySelectorAll('.vue-flow__node')).toHaveLength(1)); - const node = container.querySelector(`[data-id="${elements[0].id}"]`) as Element; + const node = container.querySelector(`[data-id="${nodes[0].id}"]`) as Element; await fireEvent.mouseDown(node, { view: window }); await fireEvent.mouseMove(node, { view: window, diff --git a/packages/editor-ui/src/components/canvas/Canvas.vue b/packages/editor-ui/src/components/canvas/Canvas.vue index c6ba71ad17..3fa90ea296 100644 --- a/packages/editor-ui/src/components/canvas/Canvas.vue +++ b/packages/editor-ui/src/components/canvas/Canvas.vue @@ -1,18 +1,18 @@