2024-05-29 10:33:29 -05:00
|
|
|
import { componentsLibrary } from '@plugin/ComponentLibrary';
|
|
|
|
|
2024-05-29 05:52:21 -05:00
|
|
|
import { PenpotFile } from '@ui/lib/types/penpotFile';
|
2024-06-05 05:36:49 -05:00
|
|
|
import { symbolBlendMode, symbolFills, symbolStrokes } from '@ui/parser/creators/symbols';
|
2024-05-29 10:33:29 -05:00
|
|
|
import { uiComponents } from '@ui/parser/libraries';
|
2024-05-29 05:52:21 -05:00
|
|
|
|
|
|
|
import { createItems } from '.';
|
|
|
|
|
|
|
|
export const createComponentLibrary = (file: PenpotFile) => {
|
2024-05-29 10:33:29 -05:00
|
|
|
uiComponents.all().forEach(uiComponent => {
|
|
|
|
const component = componentsLibrary.get(uiComponent.componentFigmaId);
|
|
|
|
if (!component) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-06-05 05:36:49 -05:00
|
|
|
const { children = [], fills, strokes, blendMode, ...rest } = component;
|
2024-05-29 10:33:29 -05:00
|
|
|
|
|
|
|
file.startComponent({
|
|
|
|
...rest,
|
2024-06-03 10:29:33 -05:00
|
|
|
fills: symbolFills(fills),
|
2024-06-05 05:36:49 -05:00
|
|
|
strokes: symbolStrokes(strokes),
|
2024-06-03 10:29:33 -05:00
|
|
|
blendMode: symbolBlendMode(blendMode),
|
2024-05-29 10:33:29 -05:00
|
|
|
id: uiComponent.componentId,
|
|
|
|
componentId: uiComponent.componentId,
|
|
|
|
mainInstancePage: uiComponent.mainInstancePage,
|
|
|
|
mainInstanceId: uiComponent.mainInstanceId,
|
|
|
|
componentRoot: true,
|
|
|
|
mainInstance: true,
|
|
|
|
componentFile: file.getId()
|
|
|
|
});
|
2024-05-29 05:52:21 -05:00
|
|
|
|
|
|
|
createItems(file, children);
|
|
|
|
|
|
|
|
file.finishComponent();
|
|
|
|
});
|
|
|
|
};
|