2024-05-29 17:33:29 +02:00
|
|
|
import { componentsLibrary } from '@plugin/ComponentLibrary';
|
|
|
|
|
2024-05-29 12:52:21 +02:00
|
|
|
import { createFile } from '@ui/lib/penpot';
|
|
|
|
import { createComponentLibrary, createPage } from '@ui/parser/creators';
|
2024-06-05 12:36:49 +02:00
|
|
|
import { uiComponents, uiImages } from '@ui/parser/libraries';
|
2024-05-29 17:33:29 +02:00
|
|
|
import { PenpotDocument } from '@ui/types';
|
2024-05-29 12:52:21 +02:00
|
|
|
|
2024-06-05 12:36:49 +02:00
|
|
|
import { idLibrary, parseImage } from '.';
|
2024-05-30 17:54:37 +02:00
|
|
|
|
2024-06-05 12:36:49 +02:00
|
|
|
export const parse = async ({ name, children = [], components, images }: PenpotDocument) => {
|
2024-05-29 17:33:29 +02:00
|
|
|
componentsLibrary.init(components);
|
2024-06-05 12:36:49 +02:00
|
|
|
|
|
|
|
for (const [key, bytes] of Object.entries(images)) {
|
|
|
|
if (!bytes) continue;
|
|
|
|
|
|
|
|
uiImages.register(key, await parseImage(bytes));
|
|
|
|
}
|
2024-06-03 17:29:33 +02:00
|
|
|
|
2024-05-29 17:33:29 +02:00
|
|
|
uiComponents.init();
|
2024-05-30 17:54:37 +02:00
|
|
|
idLibrary.init();
|
2024-05-29 12:52:21 +02:00
|
|
|
|
|
|
|
const file = createFile(name);
|
|
|
|
|
|
|
|
for (const page of children) {
|
|
|
|
createPage(file, page);
|
|
|
|
}
|
|
|
|
|
|
|
|
createComponentLibrary(file);
|
|
|
|
|
|
|
|
return file;
|
|
|
|
};
|