mirror of
https://github.com/penpot/penpot-exporter-figma-plugin.git
synced 2025-01-23 07:48:41 -05:00
d3c144e5e9
* color library * fixes * wip * wip * wip * wip * working * improvements * changeset * changeset * changeset & cleaning * changeset & cleaning * improvements * fixes * rebase
68 lines
1.5 KiB
TypeScript
68 lines
1.5 KiB
TypeScript
import { TextNode as PenpotTextNode } from '@ui/lib/types/shapes/textShape';
|
|
|
|
import { Paragraph } from './Paragraph';
|
|
|
|
export type TextSegment = Pick<
|
|
StyledTextSegment,
|
|
| 'characters'
|
|
| 'start'
|
|
| 'end'
|
|
| 'fontName'
|
|
| 'fontSize'
|
|
| 'fontWeight'
|
|
| 'lineHeight'
|
|
| 'letterSpacing'
|
|
| 'textCase'
|
|
| 'textDecoration'
|
|
| 'indentation'
|
|
| 'listOptions'
|
|
| 'fills'
|
|
| 'fillStyleId'
|
|
| 'textStyleId'
|
|
>;
|
|
|
|
type PartialTranslation = {
|
|
textNodes: PenpotTextNode[];
|
|
segment: TextSegment;
|
|
};
|
|
|
|
export const translateParagraphProperties = (
|
|
node: TextNode,
|
|
partials: { textNode: PenpotTextNode; segment: TextSegment }[]
|
|
): PenpotTextNode[] => {
|
|
const splitSegments: PartialTranslation[] = [];
|
|
|
|
partials.forEach(({ textNode, segment }) => {
|
|
splitSegments.push({
|
|
textNodes: splitTextNodeByEOL(textNode),
|
|
segment
|
|
});
|
|
});
|
|
|
|
return addParagraphProperties(node, splitSegments);
|
|
};
|
|
|
|
const splitTextNodeByEOL = (node: PenpotTextNode): PenpotTextNode[] => {
|
|
const split = node.text.split(/(\n)/).filter(text => text !== '');
|
|
|
|
return split.map(text => ({
|
|
...node,
|
|
text: text.replace(/\u2028/g, '\n')
|
|
}));
|
|
};
|
|
|
|
const addParagraphProperties = (
|
|
node: TextNode,
|
|
partials: PartialTranslation[]
|
|
): PenpotTextNode[] => {
|
|
const formattedParagraphs: PenpotTextNode[] = [];
|
|
const paragraph = new Paragraph();
|
|
|
|
partials.forEach(({ textNodes, segment }) =>
|
|
textNodes.forEach(textNode => {
|
|
formattedParagraphs.push(...paragraph.format(node, textNode, segment));
|
|
})
|
|
);
|
|
|
|
return formattedParagraphs;
|
|
};
|