2024-05-29 12:52:21 +02:00
|
|
|
import { PenpotFile } from '@ui/lib/types/penpotFile';
|
2024-06-03 17:29:33 +02:00
|
|
|
import { TextContent, TextShape } from '@ui/lib/types/shapes/textShape';
|
2024-05-30 17:54:37 +02:00
|
|
|
import { parseFigmaId } from '@ui/parser';
|
2024-06-05 12:36:49 +02:00
|
|
|
import { symbolBlendMode, symbolFills, symbolStrokes } from '@ui/parser/creators/symbols';
|
2024-05-29 12:52:21 +02:00
|
|
|
|
2024-05-30 17:54:37 +02:00
|
|
|
export const createText = (
|
|
|
|
file: PenpotFile,
|
2024-06-05 12:36:49 +02:00
|
|
|
{ type, blendMode, strokes, figmaId, content, figmaRelatedId, ...rest }: TextShape
|
2024-05-30 17:54:37 +02:00
|
|
|
) => {
|
2024-05-29 12:52:21 +02:00
|
|
|
file.createText({
|
2024-05-30 17:54:37 +02:00
|
|
|
id: parseFigmaId(file, figmaId),
|
|
|
|
shapeRef: parseFigmaId(file, figmaRelatedId, true),
|
2024-06-03 17:29:33 +02:00
|
|
|
content: parseContent(content),
|
2024-05-29 12:52:21 +02:00
|
|
|
blendMode: symbolBlendMode(blendMode),
|
2024-06-05 12:36:49 +02:00
|
|
|
strokes: symbolStrokes(strokes),
|
2024-05-29 12:52:21 +02:00
|
|
|
...rest
|
|
|
|
});
|
|
|
|
};
|
2024-06-03 17:29:33 +02:00
|
|
|
|
|
|
|
const parseContent = (content: TextContent | undefined): TextContent | undefined => {
|
|
|
|
if (!content) return;
|
|
|
|
|
|
|
|
content.children?.forEach(paragraphSet => {
|
|
|
|
paragraphSet.children.forEach(paragraph => {
|
|
|
|
paragraph.children.forEach(textNode => {
|
|
|
|
textNode.fills = symbolFills(textNode.fills);
|
|
|
|
});
|
|
|
|
|
|
|
|
paragraph.fills = symbolFills(paragraph.fills);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
return content;
|
|
|
|
};
|