mirror of
https://github.com/penpot/penpot-exporter-figma-plugin.git
synced 2025-01-10 00:50:16 -05:00
3118d36f0a
* refactor * changeset * fixes
79 lines
2.1 KiB
TypeScript
79 lines
2.1 KiB
TypeScript
import {
|
|
transformBlend,
|
|
transformDimensionAndPositionFromVectorPath,
|
|
transformEffects,
|
|
transformProportion,
|
|
transformSceneNode,
|
|
transformStrokes
|
|
} from '@plugin/transformers/partials';
|
|
import { createLineGeometry, translateVectorPath, translateVectorPaths } from '@plugin/translators';
|
|
import { translateFills } from '@plugin/translators/fills';
|
|
|
|
import { PathAttributes } from '@ui/lib/types/shapes/pathShape';
|
|
import { PathShape } from '@ui/lib/types/shapes/pathShape';
|
|
import { Children } from '@ui/lib/types/utils/children';
|
|
|
|
const getVectorPaths = (node: VectorNode | StarNode | LineNode | PolygonNode): VectorPaths => {
|
|
switch (node.type) {
|
|
case 'STAR':
|
|
case 'POLYGON':
|
|
return node.fillGeometry;
|
|
case 'VECTOR':
|
|
return node.vectorPaths;
|
|
case 'LINE':
|
|
return createLineGeometry(node);
|
|
}
|
|
};
|
|
|
|
export const transformVectorPathsAsContent = (
|
|
node: VectorNode | StarNode | LineNode | PolygonNode,
|
|
baseX: number,
|
|
baseY: number
|
|
): PathAttributes => {
|
|
const vectorPaths = getVectorPaths(node);
|
|
|
|
return {
|
|
content: translateVectorPaths(vectorPaths, baseX + node.x, baseY + node.y)
|
|
};
|
|
};
|
|
|
|
export const transformVectorPathsAsChildren = async (
|
|
node: VectorNode,
|
|
baseX: number,
|
|
baseY: number
|
|
): Promise<Children> => {
|
|
return {
|
|
children: await Promise.all(
|
|
node.vectorPaths.map((vectorPath, index) =>
|
|
transformVectorPath(
|
|
node,
|
|
vectorPath,
|
|
(node.vectorNetwork.regions ?? [])[index],
|
|
baseX,
|
|
baseY
|
|
)
|
|
)
|
|
)
|
|
};
|
|
};
|
|
|
|
const transformVectorPath = async (
|
|
node: VectorNode,
|
|
vectorPath: VectorPath,
|
|
vectorRegion: VectorRegion | undefined,
|
|
baseX: number,
|
|
baseY: number
|
|
): Promise<PathShape> => {
|
|
return {
|
|
type: 'path',
|
|
name: 'svg-path',
|
|
content: translateVectorPath(vectorPath, baseX + node.x, baseY + node.y),
|
|
fills: await translateFills(vectorRegion?.fills ?? node.fills),
|
|
...(await transformStrokes(node)),
|
|
...transformEffects(node),
|
|
...transformDimensionAndPositionFromVectorPath(vectorPath, baseX, baseY),
|
|
...transformSceneNode(node),
|
|
...transformBlend(node),
|
|
...transformProportion(node)
|
|
};
|
|
};
|