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
|
|
|
};
|
|
|
|
};
|