2024-04-29 08:44:49 -05:00
|
|
|
import { transformFills } from '@plugin/transformers/partials';
|
2024-06-25 09:08:59 -05:00
|
|
|
import { transformTextStyle, translateTextSegments } from '@plugin/translators/text';
|
2024-05-07 05:18:15 -05:00
|
|
|
import { translateGrowType, translateVerticalAlign } from '@plugin/translators/text/properties';
|
2024-04-29 08:44:49 -05:00
|
|
|
|
2024-05-29 03:30:56 -05:00
|
|
|
import { TextAttributes, TextShape } from '@ui/lib/types/shapes/textShape';
|
2024-04-29 08:44:49 -05:00
|
|
|
|
2024-06-05 05:36:49 -05:00
|
|
|
export const transformText = (node: TextNode): TextAttributes & Pick<TextShape, 'growType'> => {
|
2024-04-29 08:44:49 -05:00
|
|
|
const styledTextSegments = node.getStyledTextSegments([
|
|
|
|
'fontName',
|
|
|
|
'fontSize',
|
|
|
|
'fontWeight',
|
|
|
|
'lineHeight',
|
|
|
|
'letterSpacing',
|
|
|
|
'textCase',
|
|
|
|
'textDecoration',
|
2024-05-07 05:18:15 -05:00
|
|
|
'indentation',
|
|
|
|
'listOptions',
|
2024-06-19 08:58:13 -05:00
|
|
|
'fills',
|
2024-06-25 09:08:59 -05:00
|
|
|
'fillStyleId',
|
|
|
|
'textStyleId'
|
2024-04-29 08:44:49 -05:00
|
|
|
]);
|
|
|
|
|
|
|
|
return {
|
2024-06-28 05:17:56 -05:00
|
|
|
characters: node.characters,
|
2024-04-29 08:44:49 -05:00
|
|
|
content: {
|
|
|
|
type: 'root',
|
|
|
|
verticalAlign: translateVerticalAlign(node.textAlignVertical),
|
2024-05-27 11:13:19 -05:00
|
|
|
children: styledTextSegments.length
|
|
|
|
? [
|
2024-04-29 08:44:49 -05:00
|
|
|
{
|
2024-05-27 11:13:19 -05:00
|
|
|
type: 'paragraph-set',
|
|
|
|
children: [
|
|
|
|
{
|
|
|
|
type: 'paragraph',
|
2024-06-25 09:08:59 -05:00
|
|
|
children: translateTextSegments(node, styledTextSegments),
|
2024-05-27 11:13:19 -05:00
|
|
|
...transformTextStyle(node, styledTextSegments[0]),
|
2024-06-05 05:36:49 -05:00
|
|
|
...transformFills(node)
|
2024-05-27 11:13:19 -05:00
|
|
|
}
|
|
|
|
]
|
2024-04-29 08:44:49 -05:00
|
|
|
}
|
|
|
|
]
|
2024-05-27 11:13:19 -05:00
|
|
|
: undefined
|
2024-04-29 08:44:49 -05:00
|
|
|
},
|
|
|
|
growType: translateGrowType(node)
|
|
|
|
};
|
|
|
|
};
|