import { transformConstraints, transformFigmaIds, transformLayoutItemZIndex, transformVectorPaths } from '@plugin/transformers/partials'; import { GroupShape } from '@ui/lib/types/shapes/groupShape'; import { PathShape } from '@ui/lib/types/shapes/pathShape'; import { transformGroupNodeLike } from '.'; /* * Vector nodes can have multiple vector paths, each with its own fills. * * If there are no regions on the vector network, we treat it like a normal `PathShape`. * If there are regions, we treat the vector node as a `GroupShape` with multiple `PathShape` children. */ export const transformVectorNode = ( node: VectorNode, baseX: number, baseY: number, zIndex: number ): GroupShape | PathShape => { const children = transformVectorPaths(node, baseX, baseY, zIndex); if (children.length === 1) { return { ...children[0], name: node.name, ...transformLayoutItemZIndex(zIndex), ...transformFigmaIds(node), ...transformConstraints(node) }; } return { ...transformGroupNodeLike(node, baseX, baseY, zIndex), ...transformFigmaIds(node), ...transformConstraints(node), children }; };