2024-06-28 11:40:33 +02:00
|
|
|
import { overrides } from '@plugin/libraries';
|
2024-05-30 17:54:37 +02:00
|
|
|
import {
|
2024-06-14 10:18:34 +02:00
|
|
|
transformAutoLayout,
|
2024-05-30 17:54:37 +02:00
|
|
|
transformBlend,
|
|
|
|
transformChildren,
|
2024-06-06 12:17:17 +02:00
|
|
|
transformConstraints,
|
2024-05-30 17:54:37 +02:00
|
|
|
transformCornerRadius,
|
2024-06-14 16:28:01 +02:00
|
|
|
transformDimension,
|
2024-05-30 17:54:37 +02:00
|
|
|
transformEffects,
|
|
|
|
transformFigmaIds,
|
|
|
|
transformFills,
|
2024-06-14 10:18:34 +02:00
|
|
|
transformLayoutAttributes,
|
2024-06-17 09:58:23 +02:00
|
|
|
transformOverrides,
|
2024-05-30 17:54:37 +02:00
|
|
|
transformProportion,
|
2024-06-14 16:28:01 +02:00
|
|
|
transformRotationAndPosition,
|
2024-05-30 17:54:37 +02:00
|
|
|
transformSceneNode,
|
|
|
|
transformStrokes
|
|
|
|
} from '@plugin/transformers/partials';
|
|
|
|
|
2024-06-28 12:17:56 +02:00
|
|
|
import { ComponentInstance } from '@ui/types';
|
2024-05-30 17:54:37 +02:00
|
|
|
|
|
|
|
export const transformInstanceNode = async (
|
2024-06-19 08:10:20 +02:00
|
|
|
node: InstanceNode
|
2024-05-30 17:54:37 +02:00
|
|
|
): Promise<ComponentInstance | undefined> => {
|
|
|
|
const mainComponent = await node.getMainComponentAsync();
|
2024-06-17 12:19:53 +02:00
|
|
|
if (mainComponent === null) {
|
|
|
|
return;
|
|
|
|
}
|
2024-05-30 17:54:37 +02:00
|
|
|
|
2024-06-17 12:19:53 +02:00
|
|
|
const primaryComponent = getPrimaryComponent(mainComponent);
|
2024-06-28 11:40:33 +02:00
|
|
|
const isOrphan = isOrphanInstance(primaryComponent);
|
|
|
|
let nodeOverrides = {};
|
2024-06-28 12:17:56 +02:00
|
|
|
if (!isOrphan && node.overrides.length > 0) {
|
|
|
|
node.overrides.forEach(override => overrides.set(override.id, override.overriddenFields));
|
2024-06-28 11:40:33 +02:00
|
|
|
nodeOverrides = transformOverrides(node);
|
2024-06-17 09:58:23 +02:00
|
|
|
}
|
|
|
|
|
2024-06-28 12:38:25 +02:00
|
|
|
const fetchedOverrides = [...(overrides.get(node.id) ?? [])];
|
2024-06-28 12:17:56 +02:00
|
|
|
if (node.visible !== mainComponent.visible) {
|
|
|
|
fetchedOverrides.push('visible');
|
|
|
|
}
|
|
|
|
if (node.locked !== mainComponent.locked) {
|
|
|
|
fetchedOverrides.push('locked');
|
|
|
|
}
|
|
|
|
overrides.set(node.id, fetchedOverrides);
|
|
|
|
|
2024-05-30 17:54:37 +02:00
|
|
|
return {
|
|
|
|
type: 'instance',
|
2024-05-31 13:32:59 +02:00
|
|
|
name: node.name,
|
2024-06-03 13:52:50 +02:00
|
|
|
mainComponentFigmaId: mainComponent.id,
|
2024-05-30 17:54:37 +02:00
|
|
|
isComponentRoot: isComponentRoot(node),
|
2024-06-06 09:37:35 +02:00
|
|
|
showContent: !node.clipsContent,
|
2024-06-28 11:40:33 +02:00
|
|
|
isOrphan,
|
2024-05-30 17:54:37 +02:00
|
|
|
...transformFigmaIds(node),
|
2024-06-05 12:36:49 +02:00
|
|
|
...transformFills(node),
|
2024-05-30 17:54:37 +02:00
|
|
|
...transformEffects(node),
|
2024-06-05 12:36:49 +02:00
|
|
|
...transformStrokes(node),
|
2024-05-30 17:54:37 +02:00
|
|
|
...transformSceneNode(node),
|
|
|
|
...transformBlend(node),
|
|
|
|
...transformProportion(node),
|
2024-06-18 13:10:30 +02:00
|
|
|
...transformLayoutAttributes(node, true),
|
2024-05-30 17:54:37 +02:00
|
|
|
...transformCornerRadius(node),
|
2024-06-14 16:28:01 +02:00
|
|
|
...transformDimension(node),
|
2024-06-19 08:10:20 +02:00
|
|
|
...transformRotationAndPosition(node),
|
2024-06-06 12:17:17 +02:00
|
|
|
...transformConstraints(node),
|
2024-06-14 10:18:34 +02:00
|
|
|
...transformAutoLayout(node),
|
2024-06-19 08:10:20 +02:00
|
|
|
...(await transformChildren(node)),
|
2024-06-28 11:40:33 +02:00
|
|
|
...nodeOverrides
|
2024-05-30 17:54:37 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-06-17 12:19:53 +02:00
|
|
|
const getPrimaryComponent = (mainComponent: ComponentNode): ComponentNode | ComponentSetNode => {
|
|
|
|
if (mainComponent.parent?.type === 'COMPONENT_SET') {
|
|
|
|
return mainComponent.parent;
|
2024-06-06 09:37:35 +02:00
|
|
|
}
|
|
|
|
|
2024-06-17 12:19:53 +02:00
|
|
|
return mainComponent;
|
|
|
|
};
|
|
|
|
|
2024-06-28 11:40:33 +02:00
|
|
|
const isOrphanInstance = (primaryComponent: ComponentNode | ComponentSetNode): boolean => {
|
|
|
|
return primaryComponent.parent === null || primaryComponent.remote;
|
2024-06-03 13:27:30 +02:00
|
|
|
};
|
|
|
|
|
2024-05-30 17:54:37 +02:00
|
|
|
const isComponentRoot = (node: InstanceNode): boolean => {
|
|
|
|
let parent = node.parent;
|
2024-06-05 12:36:49 +02:00
|
|
|
|
2024-05-30 17:54:37 +02:00
|
|
|
while (parent !== null) {
|
|
|
|
if (parent.type === 'COMPONENT' || parent.type === 'INSTANCE') {
|
|
|
|
return false;
|
|
|
|
}
|
2024-06-05 12:36:49 +02:00
|
|
|
|
2024-05-30 17:54:37 +02:00
|
|
|
parent = parent.parent;
|
|
|
|
}
|
2024-06-05 12:36:49 +02:00
|
|
|
|
2024-05-30 17:54:37 +02:00
|
|
|
return true;
|
|
|
|
};
|