2024-04-12 16:52:36 +02:00
|
|
|
import { PenpotFile } from '@ui/lib/penpot';
|
2024-05-09 16:59:27 +02:00
|
|
|
import {
|
|
|
|
Paragraph,
|
|
|
|
ParagraphSet,
|
|
|
|
TextContent,
|
|
|
|
TextNode,
|
|
|
|
TextShape
|
|
|
|
} from '@ui/lib/types/shapes/textShape';
|
2024-04-16 09:24:53 +00:00
|
|
|
import { translateUiBlendMode } from '@ui/translators';
|
2024-04-08 17:50:01 +02:00
|
|
|
|
2024-05-09 16:59:27 +02:00
|
|
|
export const createPenpotText = (
|
|
|
|
file: PenpotFile,
|
|
|
|
{ type, blendMode, content, ...rest }: TextShape
|
|
|
|
) => {
|
2024-04-12 13:55:42 +02:00
|
|
|
file.createText({
|
2024-04-16 09:24:53 +00:00
|
|
|
blendMode: translateUiBlendMode(blendMode),
|
2024-05-09 16:59:27 +02:00
|
|
|
content: fixContentFills(content), //@TODO: fix text image fills
|
2024-04-12 13:55:42 +02:00
|
|
|
...rest
|
2024-04-08 17:50:01 +02:00
|
|
|
});
|
|
|
|
};
|
2024-05-09 16:59:27 +02:00
|
|
|
|
|
|
|
const fixContentFills = (content?: TextContent): TextContent | undefined => {
|
|
|
|
if (!content) return;
|
|
|
|
|
|
|
|
return {
|
|
|
|
...content,
|
|
|
|
children: content.children?.map(children => fixParagraphSetFills(children))
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const fixParagraphSetFills = (paragraphSet: ParagraphSet): ParagraphSet => {
|
|
|
|
return {
|
|
|
|
...paragraphSet,
|
|
|
|
children: paragraphSet.children.map(paragraph => fixParagraphFills(paragraph))
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const fixParagraphFills = (paragraph: Paragraph): Paragraph => {
|
|
|
|
return {
|
|
|
|
...paragraph,
|
|
|
|
fills: paragraph.fills?.filter(fill => fill.fillImage === undefined),
|
|
|
|
children: paragraph.children.map(child => fixTextNodeFills(child))
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const fixTextNodeFills = (textNode: TextNode): TextNode => {
|
|
|
|
return {
|
|
|
|
...textNode,
|
|
|
|
fills: textNode.fills?.filter(fill => fill.fillImage === undefined)
|
|
|
|
};
|
|
|
|
};
|