2024-06-26 01:11:57 -05:00
|
|
|
import { toArray } from '@common/map';
|
|
|
|
import { sleep } from '@common/sleep';
|
2024-06-18 02:50:38 -05:00
|
|
|
|
|
|
|
import { sendMessage } from '@ui/context';
|
|
|
|
import { PenpotFile } from '@ui/lib/types/penpotFile';
|
2024-06-26 04:38:42 -05:00
|
|
|
import { componentShapes, components as uiComponents } from '@ui/parser';
|
2024-06-18 04:20:51 -05:00
|
|
|
import { symbolFills, symbolStrokes } from '@ui/parser/creators/symbols';
|
2024-06-26 04:38:42 -05:00
|
|
|
import { UiComponent } from '@ui/types';
|
2024-06-18 02:50:38 -05:00
|
|
|
|
|
|
|
import { createItems } from '.';
|
|
|
|
|
|
|
|
export const createComponentsLibrary = async (file: PenpotFile) => {
|
|
|
|
let componentsBuilt = 1;
|
2024-06-26 01:11:57 -05:00
|
|
|
const components = toArray(uiComponents);
|
2024-06-18 02:50:38 -05:00
|
|
|
|
|
|
|
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) {
|
2024-06-18 02:50:38 -05:00
|
|
|
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-18 02:50:38 -05:00
|
|
|
|
2024-06-26 01:11:57 -05:00
|
|
|
if (!componentShape) {
|
2024-06-18 02:50:38 -05:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-06-26 01:11:57 -05:00
|
|
|
const { children = [], ...shape } = componentShape;
|
2024-06-18 04:20:51 -05:00
|
|
|
|
2024-06-19 08:58:13 -05:00
|
|
|
shape.fills = symbolFills(shape.fillStyleId, shape.fills);
|
2024-06-18 04:20:51 -05:00
|
|
|
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);
|
2024-06-18 02:50:38 -05:00
|
|
|
|
|
|
|
createItems(file, children);
|
|
|
|
|
|
|
|
file.finishComponent();
|
|
|
|
};
|