import { componentProperties } from '@plugin/libraries'; import { transformAutoLayout, transformBlend, transformChildren, transformConstraints, transformCornerRadius, transformDimension, transformEffects, transformFigmaIds, transformFills, transformLayoutAttributes, transformOverrides, transformProportion, transformRotationAndPosition, transformSceneNode, transformStrokes } from '@plugin/transformers/partials'; import { FrameShape } from '@ui/lib/types/shapes/frameShape'; import { Point } from '@ui/lib/types/utils/point'; const isSectionNode = (node: FrameNode | SectionNode | ComponentSetNode): node is SectionNode => { return node.type === 'SECTION'; }; const isComponentSetNode = ( node: FrameNode | SectionNode | ComponentSetNode ): node is ComponentSetNode => { return node.type === 'COMPONENT_SET'; }; export const transformFrameNode = async ( node: FrameNode | SectionNode | ComponentSetNode ): Promise => { let frameSpecificAttributes: Partial = {}; let referencePoint: Point = { x: node.absoluteTransform[0][2], y: node.absoluteTransform[1][2] }; if (isComponentSetNode(node)) { try { Object.entries(node.componentPropertyDefinitions).forEach(([key, value]) => { if (value.type === 'TEXT' || value.type === 'BOOLEAN') { componentProperties.set(key, value); } }); } catch (error) { console.error('Error registering component properties', error); } } if (!isSectionNode(node)) { const { x, y, ...transformAndRotation } = transformRotationAndPosition(node); referencePoint = { x, y }; // Figma API does not expose strokes, blend modes, corner radius, or constraint proportions for sections, // they plan to add it in the future. Refactor this when available. frameSpecificAttributes = { // @see: https://forum.figma.com/t/why-are-strokes-not-available-on-section-nodes/41658 ...transformStrokes(node), // @see: https://forum.figma.com/t/add-a-blendmode-property-for-sectionnode/58560 ...transformBlend(node), ...transformProportion(node), ...transformLayoutAttributes(node, true), ...transformCornerRadius(node), ...transformEffects(node), ...transformConstraints(node), ...transformAutoLayout(node), ...transformAndRotation }; } return { type: 'frame', name: node.name, showContent: isSectionNode(node) ? true : !node.clipsContent, ...transformFigmaIds(node), ...transformFills(node), ...referencePoint, ...frameSpecificAttributes, ...transformDimension(node), ...(await transformChildren(node)), ...transformSceneNode(node), ...transformOverrides(node) }; };