Skip to content

Commit

Permalink
chore(core): cleanup
Browse files Browse the repository at this point in the history
Signed-off-by: braks <78412429+bcakmakoglu@users.noreply.github.com>
  • Loading branch information
bcakmakoglu committed Mar 22, 2023
1 parent baaabbe commit 44b37ed
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 29 deletions.
14 changes: 5 additions & 9 deletions packages/core/src/container/VueFlow/VueFlow.vue
Original file line number Diff line number Diff line change
Expand Up @@ -114,20 +114,22 @@ const modelValue = useVModel(props, 'modelValue', emit)
const modelNodes = useVModel(props, 'nodes', emit)
const modelEdges = useVModel(props, 'edges', emit)
const { vueFlowRef, id, hooks, getNodeTypes, getEdgeTypes, $reset, ...rest } = useVueFlow(props)
const { vueFlowRef, hooks, getNodeTypes, getEdgeTypes, ...rest } = useVueFlow(props)
const dispose = useWatch({ modelValue, nodes: modelNodes, edges: modelEdges }, props, {
vueFlowRef,
id,
hooks,
getNodeTypes,
getEdgeTypes,
$reset,
...rest,
})
useHooks(emit, hooks)
const el = ref<HTMLDivElement>()
provide(Slots, useSlots())
onUnmounted(() => {
dispose()
})
Expand All @@ -136,17 +138,11 @@ onMounted(() => {
vueFlowRef.value = el.value!
})
useHooks(emit, hooks)
provide(Slots, useSlots())
defineExpose<VueFlowStore>({
vueFlowRef,
id,
hooks,
getNodeTypes,
getEdgeTypes,
$reset,
...rest,
})
</script>
Expand Down
42 changes: 24 additions & 18 deletions packages/core/src/utils/graph.ts
Original file line number Diff line number Diff line change
Expand Up @@ -67,11 +67,12 @@ export const isGraphNode = <Data = ElementData>(element: MaybeElement): element

export const isRect = (obj: any): obj is Rect => !!obj.width && !!obj.height && !!obj.x && !!obj.y

export function parseNode(node: Node, defaults?: Partial<GraphNode>): GraphNode {
let defaultValues = defaults
export function parseNode(node: Node, defaults: Partial<GraphNode> = {}): GraphNode {
let initialState = defaults

if (!isGraphNode(node)) {
defaultValues = {
type: node.type ?? 'default',
initialState = {
type: node.type ?? defaults.type ?? 'default',
dimensions: markRaw({
width: 0,
height: 0,
Expand Down Expand Up @@ -99,31 +100,31 @@ export function parseNode(node: Node, defaults?: Partial<GraphNode>): GraphNode
}

return {
...defaultValues,
...initialState,
...(node as GraphNode),
id: node.id.toString(),
}
}

export function parseEdge(edge: Edge, defaults?: Partial<GraphEdge>): GraphEdge {
const events = isDef(edge.events) ? edge.events : defaults?.events && isDef(defaults?.events) ? defaults?.events : {}
const data = isDef(edge.data) ? edge.data : defaults?.data && isDef(defaults?.data) ? defaults?.data : {}
export function parseEdge(edge: Edge, defaults: Partial<GraphEdge> = {}): GraphEdge {
const events = isDef(edge.events) ? edge.events : defaults.events && isDef(defaults.events) ? defaults.events : {}
const data = isDef(edge.data) ? edge.data : defaults.data && isDef(defaults.data) ? defaults.data : {}

defaults = !isGraphEdge(edge)
? ({
...defaults,
sourceHandle: (edge.sourceHandle ? edge.sourceHandle.toString() : undefined) || defaults?.sourceHandle,
targetHandle: (edge.targetHandle ? edge.targetHandle.toString() : undefined) || defaults?.targetHandle,
type: edge.type ?? defaults?.type ?? 'default',
source: edge.source.toString() || defaults?.source,
target: edge.target.toString() || defaults?.target,
updatable: edge.updatable ?? defaults?.updatable,
selectable: edge.selectable ?? defaults?.selectable,
focusable: edge.focusable ?? defaults?.focusable,
sourceHandle: (edge.sourceHandle ? edge.sourceHandle.toString() : undefined) || defaults.sourceHandle,
targetHandle: (edge.targetHandle ? edge.targetHandle.toString() : undefined) || defaults.targetHandle,
type: edge.type ?? defaults.type ?? 'default',
source: edge.source.toString() || defaults.source,
target: edge.target.toString() || defaults.target,
updatable: edge.updatable ?? defaults.updatable,
selectable: edge.selectable ?? defaults.selectable,
focusable: edge.focusable ?? defaults.focusable,
data,
events: markRaw(events),
label: (edge.label && !isString(edge.label) ? markRaw(edge.label) : edge.label) || defaults?.label,
interactionWidth: edge.interactionWidth || defaults?.interactionWidth,
label: (edge.label && !isString(edge.label) ? markRaw(edge.label) : edge.label) || defaults.label,
interactionWidth: edge.interactionWidth || defaults.interactionWidth,
} as GraphEdge)
: defaults

Expand Down Expand Up @@ -166,6 +167,7 @@ export function addEdge(edgeParams: Edge | Connection, elements: Elements, defau
}

let edge

if (isEdge(edgeParams)) {
edge = { ...edgeParams }
} else {
Expand All @@ -174,9 +176,13 @@ export function addEdge(edgeParams: Edge | Connection, elements: Elements, defau
id: getEdgeId(edgeParams),
} as Edge
}

edge = parseEdge(edge, defaults)

if (connectionExists(edge, elements)) return elements

elements.push(edge)

return elements
}

Expand Down
4 changes: 2 additions & 2 deletions packages/core/src/utils/store.ts
Original file line number Diff line number Diff line change
Expand Up @@ -76,9 +76,9 @@ export function createGraphNodes(nodes: Node[], findNode: Actions['findNode'], c
return parsed
})

graphNodes.forEach((node) => {
const nextNodes = [...graphNodes, ...currGraphNodes]
const nextNodes = [...graphNodes, ...currGraphNodes]

graphNodes.forEach((node) => {
const parentNode = nextNodes.find((n) => n.id === node.parentNode)

if (node.parentNode && !parentNode) {
Expand Down

0 comments on commit 44b37ed

Please sign in to comment.