mirror of
https://github.com/penpot/penpot-exporter-figma-plugin.git
synced 2025-01-03 13:20:37 -05:00
d3c144e5e9
* color library * fixes * wip * wip * wip * wip * working * improvements * changeset * changeset * changeset & cleaning * changeset & cleaning * improvements * fixes * rebase
45 lines
1.3 KiB
TypeScript
45 lines
1.3 KiB
TypeScript
import { translateFillStyleId, translateFills } from '@plugin/translators/fills';
|
|
import { TextSegment } from '@plugin/translators/text/paragraph';
|
|
|
|
import { ShapeAttributes } from '@ui/lib/types/shapes/shape';
|
|
import { TextStyle } from '@ui/lib/types/shapes/textShape';
|
|
|
|
export const transformFills = (
|
|
node: (MinimalFillsMixin & DimensionAndPositionMixin) | VectorRegion | VectorNode | TextSegment
|
|
): Pick<ShapeAttributes, 'fills' | 'fillStyleId'> | Pick<TextStyle, 'fills' | 'fillStyleId'> => {
|
|
if (hasFillStyle(node)) {
|
|
return {
|
|
fills: [],
|
|
fillStyleId: translateFillStyleId(node.fillStyleId)
|
|
};
|
|
}
|
|
|
|
return {
|
|
fills: translateFills(node.fills)
|
|
};
|
|
};
|
|
|
|
export const transformVectorFills = (
|
|
node: VectorNode,
|
|
vectorPath: VectorPath,
|
|
vectorRegion: VectorRegion | undefined
|
|
): Pick<ShapeAttributes, 'fills' | 'fillStyleId'> => {
|
|
if (vectorPath.windingRule === 'NONE') {
|
|
return {
|
|
fills: []
|
|
};
|
|
}
|
|
|
|
const fillsNode = vectorRegion?.fills ? vectorRegion : node;
|
|
return transformFills(fillsNode);
|
|
};
|
|
|
|
const hasFillStyle = (
|
|
node: (MinimalFillsMixin & DimensionAndPositionMixin) | VectorRegion | VectorNode | TextSegment
|
|
): boolean => {
|
|
return (
|
|
node.fillStyleId !== figma.mixed &&
|
|
node.fillStyleId !== undefined &&
|
|
node.fillStyleId.length > 0
|
|
);
|
|
};
|