0
Fork 0
mirror of https://github.com/penpot/penpot-exporter-figma-plugin.git synced 2025-01-22 23:38:42 -05:00
penpot-exporter-figma-plugin/plugin-src/transformers/partials/transformLayout.ts

37 lines
1.3 KiB
TypeScript
Raw Normal View History

2024-06-10 16:20:04 +02:00
import {
2024-06-11 09:26:38 +02:00
translateLayoutAlignContent,
translateLayoutAlignItems,
2024-06-10 16:20:04 +02:00
translateLayoutFlexDir,
translateLayoutGap,
translateLayoutJustifyContent,
translateLayoutJustifyItems,
translateLayoutPadding,
2024-06-11 09:26:38 +02:00
translateLayoutSizing,
2024-06-10 16:20:04 +02:00
translateLayoutWrapType
} from '@plugin/translators';
2024-06-11 09:26:38 +02:00
import { LayoutAttributes, LayoutChildAttributes } from '@ui/lib/types/shapes/layout';
2024-06-10 16:20:04 +02:00
export const transformAutoLayout = (node: BaseFrameMixin): LayoutAttributes => {
return {
layout: node.layoutMode !== 'NONE' ? 'flex' : undefined,
layoutFlexDir: translateLayoutFlexDir(node.layoutMode),
layoutGap: translateLayoutGap(node.layoutMode, node.itemSpacing),
layoutWrapType: translateLayoutWrapType(node.layoutWrap),
layoutPadding: translateLayoutPadding(node),
layoutJustifyContent: translateLayoutJustifyContent(node),
layoutJustifyItems: translateLayoutJustifyItems(node),
2024-06-11 09:26:38 +02:00
layoutAlignContent: translateLayoutAlignContent(node),
layoutAlignItems: translateLayoutAlignItems(node)
};
};
export const transformLayoutSizing = (
node: LayoutMixin
): Pick<LayoutChildAttributes, 'layoutItemHSizing' | 'layoutItemVSizing'> => {
return {
layoutItemHSizing: translateLayoutSizing(node.layoutSizingHorizontal),
layoutItemVSizing: translateLayoutSizing(node.layoutSizingVertical)
2024-06-10 16:20:04 +02:00
};
};