2024-05-29 17:33:29 +02:00
|
|
|
import { PenpotNode } from '@ui/types';
|
2024-04-12 16:52:36 +02:00
|
|
|
|
2024-04-12 13:55:42 +02:00
|
|
|
import {
|
2024-05-27 10:05:23 +02:00
|
|
|
transformBooleanNode,
|
2024-05-29 12:52:21 +02:00
|
|
|
transformComponentNode,
|
2024-04-12 13:55:42 +02:00
|
|
|
transformEllipseNode,
|
|
|
|
transformFrameNode,
|
|
|
|
transformGroupNode,
|
2024-05-30 17:54:37 +02:00
|
|
|
transformInstanceNode,
|
2024-06-14 10:33:23 +02:00
|
|
|
transformLineNode,
|
2024-04-17 10:53:38 +02:00
|
|
|
transformPathNode,
|
2024-04-12 13:55:42 +02:00
|
|
|
transformRectangleNode,
|
2024-05-13 13:21:46 +02:00
|
|
|
transformTextNode,
|
|
|
|
transformVectorNode
|
2024-04-12 13:55:42 +02:00
|
|
|
} from '.';
|
|
|
|
|
|
|
|
export const transformSceneNode = async (
|
|
|
|
node: SceneNode,
|
2024-06-14 16:28:01 +02:00
|
|
|
baseRotation: number = 0
|
2024-04-19 09:48:19 +02:00
|
|
|
): Promise<PenpotNode | undefined> => {
|
2024-05-31 11:25:32 +02:00
|
|
|
let penpotNode: PenpotNode | undefined;
|
|
|
|
|
|
|
|
figma.ui.postMessage({
|
2024-06-06 17:24:59 +02:00
|
|
|
type: 'PROGRESS_CURRENT_ITEM',
|
2024-05-31 11:25:32 +02:00
|
|
|
data: node.name
|
|
|
|
});
|
|
|
|
|
2024-04-12 13:55:42 +02:00
|
|
|
switch (node.type) {
|
|
|
|
case 'RECTANGLE':
|
2024-06-14 16:28:01 +02:00
|
|
|
penpotNode = transformRectangleNode(node, baseRotation);
|
2024-05-31 11:25:32 +02:00
|
|
|
break;
|
2024-04-12 13:55:42 +02:00
|
|
|
case 'ELLIPSE':
|
2024-06-14 16:28:01 +02:00
|
|
|
penpotNode = transformEllipseNode(node, baseRotation);
|
2024-05-31 11:25:32 +02:00
|
|
|
break;
|
2024-04-17 11:38:13 +02:00
|
|
|
case 'SECTION':
|
2024-04-12 13:55:42 +02:00
|
|
|
case 'FRAME':
|
2024-05-31 13:32:59 +02:00
|
|
|
case 'COMPONENT_SET':
|
2024-06-14 16:28:01 +02:00
|
|
|
penpotNode = await transformFrameNode(node, baseRotation);
|
2024-05-31 11:25:32 +02:00
|
|
|
break;
|
2024-04-12 13:55:42 +02:00
|
|
|
case 'GROUP':
|
2024-06-14 16:28:01 +02:00
|
|
|
penpotNode = await transformGroupNode(node, baseRotation);
|
2024-05-31 11:25:32 +02:00
|
|
|
break;
|
2024-04-12 13:55:42 +02:00
|
|
|
case 'TEXT':
|
2024-06-14 16:28:01 +02:00
|
|
|
penpotNode = transformTextNode(node, baseRotation);
|
2024-05-31 11:25:32 +02:00
|
|
|
break;
|
2024-05-13 13:21:46 +02:00
|
|
|
case 'VECTOR':
|
2024-06-14 16:28:01 +02:00
|
|
|
penpotNode = transformVectorNode(node, baseRotation);
|
2024-05-31 11:25:32 +02:00
|
|
|
break;
|
2024-06-14 10:33:23 +02:00
|
|
|
case 'LINE':
|
2024-06-14 16:28:01 +02:00
|
|
|
penpotNode = transformLineNode(node, baseRotation);
|
2024-06-14 10:33:23 +02:00
|
|
|
break;
|
2024-04-16 16:08:39 +02:00
|
|
|
case 'STAR':
|
|
|
|
case 'POLYGON':
|
2024-06-14 16:28:01 +02:00
|
|
|
penpotNode = transformPathNode(node, baseRotation);
|
2024-05-31 11:25:32 +02:00
|
|
|
break;
|
2024-05-27 10:05:23 +02:00
|
|
|
case 'BOOLEAN_OPERATION':
|
2024-06-14 16:28:01 +02:00
|
|
|
penpotNode = await transformBooleanNode(node, baseRotation);
|
2024-05-31 11:25:32 +02:00
|
|
|
break;
|
2024-05-29 12:52:21 +02:00
|
|
|
case 'COMPONENT':
|
2024-06-14 16:28:01 +02:00
|
|
|
penpotNode = await transformComponentNode(node, baseRotation);
|
2024-05-31 11:25:32 +02:00
|
|
|
break;
|
2024-05-30 17:54:37 +02:00
|
|
|
case 'INSTANCE':
|
2024-06-14 16:28:01 +02:00
|
|
|
penpotNode = await transformInstanceNode(node, baseRotation);
|
2024-05-31 11:25:32 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (penpotNode === undefined) {
|
|
|
|
console.error(`Unsupported node type: ${node.type}`);
|
2024-04-12 13:55:42 +02:00
|
|
|
}
|
|
|
|
|
2024-05-31 11:25:32 +02:00
|
|
|
return penpotNode;
|
2024-04-12 13:55:42 +02:00
|
|
|
};
|