0
Fork 0
mirror of https://github.com/penpot/penpot-exporter-figma-plugin.git synced 2025-01-07 23:50:05 -05:00
penpot-exporter-figma-plugin/ui-src/parser/creators/createText.ts

55 lines
1.7 KiB
TypeScript
Raw Normal View History

import { PenpotFile } from '@ui/lib/types/penpotFile';
import { Paragraph, TextContent, TextNode, TextShape } from '@ui/lib/types/shapes/textShape';
2024-06-26 01:11:57 -05:00
import { parseFigmaId, typographies } from '@ui/parser';
import { symbolFills, symbolStrokes, symbolTouched } from '@ui/parser/creators/symbols';
export const createText = (
file: PenpotFile,
{ type, figmaId, figmaRelatedId, characters, ...shape }: TextShape
) => {
shape.id = parseFigmaId(file, figmaId);
shape.shapeRef = parseFigmaId(file, figmaRelatedId, true);
shape.content = parseContent(shape.content);
shape.strokes = symbolStrokes(shape.strokes);
shape.touched = symbolTouched(
!shape.hidden,
characters,
shape.touched,
shape.componentPropertyReferences
);
file.createText(shape);
};
const parseContent = (content: TextContent | undefined): TextContent | undefined => {
if (!content) return;
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;
});
return parseTextStyle(paragraph, paragraph.textStyleId) as Paragraph;
});
return paragraphSet;
});
return content;
};
const parseTextStyle = (text: Paragraph | TextNode, textStyleId?: string): Paragraph | TextNode => {
let textStyle = text;
textStyle.fills = symbolFills(text.fillStyleId, text.fills);
const libraryStyle = textStyleId ? typographies.get(textStyleId) : undefined;
if (libraryStyle) {
textStyle = {
...libraryStyle.textStyle,
...textStyle
};
}
return textStyle;
};