2024-05-29 05:52:21 -05:00
|
|
|
import { PenpotFile } from '@ui/lib/types/penpotFile';
|
|
|
|
import { FrameShape } from '@ui/lib/types/shapes/frameShape';
|
2024-05-30 10:54:37 -05:00
|
|
|
import { Uuid } from '@ui/lib/types/utils/uuid';
|
|
|
|
import { parseFigmaId } from '@ui/parser';
|
2024-06-05 05:36:49 -05:00
|
|
|
import { symbolBlendMode, symbolFills, symbolStrokes } from '@ui/parser/creators/symbols';
|
2024-05-29 05:52:21 -05:00
|
|
|
|
|
|
|
import { createItems } from '.';
|
|
|
|
|
|
|
|
export const createArtboard = (
|
|
|
|
file: PenpotFile,
|
2024-06-05 05:36:49 -05:00
|
|
|
{
|
|
|
|
type,
|
|
|
|
fills,
|
|
|
|
strokes,
|
|
|
|
blendMode,
|
|
|
|
children = [],
|
|
|
|
figmaId,
|
|
|
|
figmaRelatedId,
|
|
|
|
shapeRef,
|
|
|
|
...rest
|
|
|
|
}: FrameShape
|
2024-05-30 10:54:37 -05:00
|
|
|
): Uuid | undefined => {
|
|
|
|
const id = parseFigmaId(file, figmaId);
|
|
|
|
|
2024-05-29 05:52:21 -05:00
|
|
|
file.addArtboard({
|
2024-05-30 10:54:37 -05:00
|
|
|
id,
|
|
|
|
shapeRef: shapeRef ?? parseFigmaId(file, figmaRelatedId, true),
|
2024-06-03 10:29:33 -05:00
|
|
|
fills: symbolFills(fills),
|
2024-06-05 05:36:49 -05:00
|
|
|
strokes: symbolStrokes(strokes),
|
2024-05-29 05:52:21 -05:00
|
|
|
blendMode: symbolBlendMode(blendMode),
|
|
|
|
...rest
|
|
|
|
});
|
|
|
|
|
|
|
|
createItems(file, children);
|
|
|
|
|
|
|
|
file.closeArtboard();
|
2024-05-30 10:54:37 -05:00
|
|
|
|
|
|
|
return id;
|
2024-05-29 05:52:21 -05:00
|
|
|
};
|