2024-06-03 17:29:33 +02:00
|
|
|
import { imagesLibrary } from '@plugin/ImageLibrary';
|
|
|
|
|
2024-04-12 16:52:36 +02:00
|
|
|
import { Fill } from '@ui/lib/types/utils/fill';
|
2024-05-06 08:06:14 +02:00
|
|
|
import { Gradient, LINEAR_TYPE, RADIAL_TYPE } from '@ui/lib/types/utils/gradient';
|
2024-06-03 17:29:33 +02:00
|
|
|
import { ImageColor } from '@ui/lib/types/utils/imageColor';
|
2024-04-12 13:55:42 +02:00
|
|
|
|
2024-06-03 17:29:33 +02:00
|
|
|
export const symbolFills = (fills?: Fill[]): Fill[] | undefined => {
|
2024-05-09 16:59:27 +02:00
|
|
|
if (!fills) return;
|
2024-05-06 08:06:14 +02:00
|
|
|
|
2024-04-12 13:55:42 +02:00
|
|
|
return fills.map(fill => {
|
|
|
|
if (fill.fillColorGradient) {
|
2024-05-29 12:52:21 +02:00
|
|
|
fill.fillColorGradient = symbolFillGradient(fill.fillColorGradient);
|
2024-04-12 13:55:42 +02:00
|
|
|
}
|
|
|
|
|
2024-06-03 17:29:33 +02:00
|
|
|
if (fill.fillImage) {
|
|
|
|
fill.fillImage = symbolFillImage(fill.fillImage);
|
|
|
|
}
|
|
|
|
|
2024-04-12 13:55:42 +02:00
|
|
|
return fill;
|
|
|
|
});
|
|
|
|
};
|
2024-05-06 08:06:14 +02:00
|
|
|
|
2024-05-29 12:52:21 +02:00
|
|
|
const symbolFillGradient = ({ type, ...rest }: Gradient): Gradient | undefined => {
|
2024-05-06 08:06:14 +02:00
|
|
|
switch (type) {
|
|
|
|
case 'linear':
|
|
|
|
return {
|
|
|
|
type: LINEAR_TYPE,
|
|
|
|
...rest
|
|
|
|
};
|
|
|
|
case 'radial':
|
|
|
|
return {
|
|
|
|
type: RADIAL_TYPE,
|
|
|
|
...rest
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
console.error(`Unsupported gradient type: ${String(type)}`);
|
|
|
|
};
|
2024-06-03 17:29:33 +02:00
|
|
|
|
|
|
|
const symbolFillImage = ({ imageHash, ...rest }: ImageColor): ImageColor | undefined => {
|
|
|
|
if (!imageHash) return;
|
|
|
|
|
|
|
|
const imageColor = imagesLibrary.get(imageHash);
|
|
|
|
|
|
|
|
if (!imageColor) return;
|
|
|
|
|
|
|
|
return {
|
|
|
|
...rest,
|
|
|
|
dataUri: imageColor?.dataUri
|
|
|
|
};
|
|
|
|
};
|