mirror of
https://github.com/penpot/penpot-exporter-figma-plugin.git
synced 2025-01-06 23:00:55 -05:00
303cc833a0
* wip * wip * wip * wip * wip * fixes * fixes * fixes * fixes * fixes * fixes * fixes * fixes * fixes
33 lines
946 B
TypeScript
33 lines
946 B
TypeScript
import { PenpotFile } from '@ui/lib/types/penpotFile';
|
|
import { FrameShape } from '@ui/lib/types/shapes/frameShape';
|
|
import { Uuid } from '@ui/lib/types/utils/uuid';
|
|
import { parseFigmaId } from '@ui/parser';
|
|
import { symbolFills, symbolStrokes, symbolTouched } from '@ui/parser/creators/symbols';
|
|
|
|
import { createItems } from '.';
|
|
|
|
export const createArtboard = (
|
|
file: PenpotFile,
|
|
{ type, children = [], figmaId, figmaRelatedId, ...shape }: FrameShape
|
|
): Uuid | undefined => {
|
|
const id = parseFigmaId(file, figmaId);
|
|
|
|
shape.id = id;
|
|
shape.shapeRef ??= parseFigmaId(file, figmaRelatedId, true);
|
|
shape.fills = symbolFills(shape.fillStyleId, shape.fills);
|
|
shape.strokes = symbolStrokes(shape.strokes);
|
|
shape.touched = symbolTouched(
|
|
!shape.hidden,
|
|
undefined,
|
|
shape.touched,
|
|
shape.componentPropertyReferences
|
|
);
|
|
|
|
file.addArtboard(shape);
|
|
|
|
createItems(file, children);
|
|
|
|
file.closeArtboard();
|
|
|
|
return id;
|
|
};
|