import { componentsLibrary } from '@plugin/ComponentLibrary'; import { transformAutoLayout, transformBlend, transformChildren, transformConstraints, transformCornerRadius, transformDimensionAndPosition, transformEffects, transformFigmaIds, transformFills, transformLayoutAttributes, transformProportion, transformSceneNode, transformStrokes } from '@plugin/transformers/partials'; import { ComponentRoot } from '@ui/types'; export const transformComponentNode = async ( node: ComponentNode, baseX: number, baseY: number ): Promise => { componentsLibrary.register(node.id, { type: 'component', name: node.name, path: node.parent?.type === 'COMPONENT_SET' ? node.parent.name : '', showContent: !node.clipsContent, ...transformFigmaIds(node), ...transformFills(node), ...transformEffects(node), ...transformStrokes(node), ...transformSceneNode(node), ...transformBlend(node), ...transformProportion(node), ...transformLayoutAttributes(node), ...transformCornerRadius(node), ...(await transformChildren(node, baseX + node.x, baseY + node.y)), ...transformDimensionAndPosition(node, baseX, baseY), ...transformConstraints(node), ...transformAutoLayout(node) }); return { figmaId: node.id, type: 'component' }; };