2024-06-25 07:12:37 -05:00
|
|
|
import { translateFillStyleId, translateFills } from '@plugin/translators/fills';
|
2024-06-19 08:58:13 -05:00
|
|
|
import { StyleTextSegment } from '@plugin/translators/text/paragraph';
|
2024-04-17 08:27:53 -05:00
|
|
|
|
2024-05-06 01:06:14 -05:00
|
|
|
import { ShapeAttributes } from '@ui/lib/types/shapes/shape';
|
2024-06-19 08:58:13 -05:00
|
|
|
import { TextStyle } from '@ui/lib/types/shapes/textShape';
|
2024-04-17 08:27:53 -05:00
|
|
|
|
2024-06-05 05:36:49 -05:00
|
|
|
export const transformFills = (
|
2024-06-19 08:58:13 -05:00
|
|
|
node:
|
|
|
|
| (MinimalFillsMixin & DimensionAndPositionMixin)
|
|
|
|
| VectorRegion
|
|
|
|
| VectorNode
|
|
|
|
| StyleTextSegment
|
|
|
|
): Pick<ShapeAttributes, 'fills' | 'fillStyleId'> | Pick<TextStyle, 'fills' | 'fillStyleId'> => {
|
|
|
|
if (hasFillStyle(node)) {
|
|
|
|
return {
|
|
|
|
fills: [],
|
2024-06-25 07:12:37 -05:00
|
|
|
fillStyleId: translateFillStyleId(node.fillStyleId)
|
2024-06-19 08:58:13 -05:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2024-04-17 08:27:53 -05:00
|
|
|
return {
|
2024-06-05 05:36:49 -05:00
|
|
|
fills: translateFills(node.fills)
|
2024-04-17 08:27:53 -05:00
|
|
|
};
|
|
|
|
};
|
2024-06-19 08:58:13 -05:00
|
|
|
|
|
|
|
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
|
|
|
|
| StyleTextSegment
|
|
|
|
): boolean => {
|
|
|
|
return (
|
|
|
|
node.fillStyleId !== figma.mixed &&
|
|
|
|
node.fillStyleId !== undefined &&
|
|
|
|
node.fillStyleId.length > 0
|
|
|
|
);
|
|
|
|
};
|