2024-05-29 12:52:21 +02:00
|
|
|
import { PenpotFile } from '@ui/lib/types/penpotFile';
|
2024-06-25 16:08:59 +02:00
|
|
|
import { Paragraph, TextContent, TextNode, TextShape } from '@ui/lib/types/shapes/textShape';
|
2024-06-26 08:11:57 +02:00
|
|
|
import { parseFigmaId, typographies } from '@ui/parser';
|
2024-06-28 12:17:56 +02:00
|
|
|
import { symbolFills, symbolStrokes, symbolTouched } 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-28 12:17:56 +02:00
|
|
|
{ type, figmaId, figmaRelatedId, characters, ...shape }: TextShape
|
2024-05-30 17:54:37 +02:00
|
|
|
) => {
|
2024-06-18 11:20:51 +02:00
|
|
|
shape.id = parseFigmaId(file, figmaId);
|
|
|
|
shape.shapeRef = parseFigmaId(file, figmaRelatedId, true);
|
|
|
|
shape.content = parseContent(shape.content);
|
|
|
|
shape.strokes = symbolStrokes(shape.strokes);
|
2024-06-28 12:17:56 +02:00
|
|
|
shape.touched = symbolTouched(
|
|
|
|
!shape.hidden,
|
|
|
|
characters,
|
|
|
|
shape.touched,
|
|
|
|
shape.componentPropertyReferences
|
|
|
|
);
|
2024-06-18 11:20:51 +02:00
|
|
|
|
|
|
|
file.createText(shape);
|
2024-05-29 12:52:21 +02:00
|
|
|
};
|
2024-06-03 17:29:33 +02:00
|
|
|
|
|
|
|
const parseContent = (content: TextContent | undefined): TextContent | undefined => {
|
|
|
|
if (!content) return;
|
|
|
|
|
2024-06-25 16:08:59 +02:00
|
|
|
content.children = content.children?.map(paragraphSet => {
|
|
|
|
paragraphSet.children = paragraphSet.children.map(paragraph => {
|
|
|
|
paragraph.children = paragraph.children.map(textNode => {
|
|
|
|
return parseTextStyle(textNode, textNode.textStyleId) as TextNode;
|
2024-06-03 17:29:33 +02:00
|
|
|
});
|
2024-06-25 16:08:59 +02:00
|
|
|
return parseTextStyle(paragraph, paragraph.textStyleId) as Paragraph;
|
2024-06-03 17:29:33 +02:00
|
|
|
});
|
2024-06-25 16:08:59 +02:00
|
|
|
return paragraphSet;
|
2024-06-03 17:29:33 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
return content;
|
|
|
|
};
|
2024-06-25 16:08:59 +02:00
|
|
|
|
|
|
|
const parseTextStyle = (text: Paragraph | TextNode, textStyleId?: string): Paragraph | TextNode => {
|
|
|
|
let textStyle = text;
|
|
|
|
textStyle.fills = symbolFills(text.fillStyleId, text.fills);
|
|
|
|
|
2024-06-25 17:12:20 +02:00
|
|
|
const libraryStyle = textStyleId ? typographies.get(textStyleId) : undefined;
|
2024-06-25 16:08:59 +02:00
|
|
|
|
|
|
|
if (libraryStyle) {
|
|
|
|
textStyle = {
|
|
|
|
...libraryStyle.textStyle,
|
|
|
|
...textStyle
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
return textStyle;
|
|
|
|
};
|