2024-04-17 03:53:38 -05:00
|
|
|
import { translateVectorPaths } from '@plugin/translators';
|
|
|
|
|
2024-05-06 01:06:14 -05:00
|
|
|
import { PathAttributes } from '@ui/lib/types/shapes/pathShape';
|
2024-04-17 03:53:38 -05:00
|
|
|
|
|
|
|
const getVectorPaths = (node: VectorNode | StarNode | LineNode | PolygonNode): VectorPaths => {
|
|
|
|
switch (node.type) {
|
|
|
|
case 'STAR':
|
|
|
|
case 'POLYGON':
|
|
|
|
return node.fillGeometry;
|
|
|
|
case 'VECTOR':
|
2024-04-26 10:09:57 -05:00
|
|
|
return node.vectorPaths;
|
2024-04-17 03:53:38 -05:00
|
|
|
case 'LINE':
|
|
|
|
return node.strokeGeometry;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export const transformVectorPaths = (
|
|
|
|
node: VectorNode | StarNode | LineNode | PolygonNode,
|
|
|
|
baseX: number,
|
|
|
|
baseY: number
|
|
|
|
): PathAttributes => {
|
|
|
|
const vectorPaths = getVectorPaths(node);
|
|
|
|
|
|
|
|
return {
|
|
|
|
type: 'path',
|
|
|
|
content: translateVectorPaths(vectorPaths, baseX + node.x, baseY + node.y)
|
|
|
|
};
|
|
|
|
};
|