0
Fork 0
mirror of https://github.com/penpot/penpot-exporter-figma-plugin.git synced 2025-01-05 06:10:52 -05:00
penpot-exporter-figma-plugin/ui-src/parser/creators/createComponentsLibrary.ts

63 lines
1.6 KiB
TypeScript
Raw Normal View History

2024-06-26 01:11:57 -05:00
import { toArray } from '@common/map';
import { sleep } from '@common/sleep';
import { sendMessage } from '@ui/context';
import { PenpotFile } from '@ui/lib/types/penpotFile';
import { componentShapes, components as uiComponents } from '@ui/parser';
import { symbolFills, symbolStrokes } from '@ui/parser/creators/symbols';
import { UiComponent } from '@ui/types';
import { createItems } from '.';
export const createComponentsLibrary = async (file: PenpotFile) => {
let componentsBuilt = 1;
2024-06-26 01:11:57 -05:00
const components = toArray(uiComponents);
sendMessage({
type: 'PROGRESS_TOTAL_ITEMS',
data: components.length
});
sendMessage({
type: 'PROGRESS_STEP',
data: 'components'
});
2024-06-26 01:11:57 -05:00
for (const [_, uiComponent] of components) {
createComponentLibrary(file, uiComponent);
sendMessage({
type: 'PROGRESS_PROCESSED_ITEMS',
data: componentsBuilt++
});
await sleep(0);
}
};
2024-06-26 01:11:57 -05:00
const createComponentLibrary = (file: PenpotFile, uiComponent: UiComponent) => {
const componentShape = componentShapes.get(uiComponent.componentFigmaId);
2024-06-26 01:11:57 -05:00
if (!componentShape) {
return;
}
2024-06-26 01:11:57 -05:00
const { children = [], ...shape } = componentShape;
shape.fills = symbolFills(shape.fillStyleId, shape.fills);
shape.strokes = symbolStrokes(shape.strokes);
shape.id = uiComponent.componentId;
shape.componentId = uiComponent.componentId;
shape.mainInstancePage = uiComponent.mainInstancePage;
shape.mainInstanceId = uiComponent.mainInstanceId;
shape.componentRoot = true;
shape.mainInstance = true;
shape.componentFile = file.getId();
file.startComponent(shape);
createItems(file, children);
file.finishComponent();
};