2024-05-29 17:33:29 +02:00
|
|
|
import { componentsLibrary } from '@plugin/ComponentLibrary';
|
2024-06-06 17:24:59 +02:00
|
|
|
// @TODO: Direct import on purpose, to avoid problems with the tsc linting
|
|
|
|
import { sleep } from '@plugin/utils/sleep';
|
2024-05-29 17:33:29 +02:00
|
|
|
|
2024-06-06 17:24:59 +02:00
|
|
|
import { sendMessage } from '@ui/context';
|
2024-06-18 09:50:38 +02:00
|
|
|
import { createFile } from '@ui/parser/creators';
|
|
|
|
import { 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-18 09:50:38 +02:00
|
|
|
import { parseImage } from '.';
|
2024-05-30 17:54:37 +02:00
|
|
|
|
2024-06-06 17:24:59 +02:00
|
|
|
const optimizeImages = async (images: Record<string, Uint8Array>) => {
|
|
|
|
const imagesToOptimize = Object.entries(images);
|
2024-06-18 09:50:38 +02:00
|
|
|
|
|
|
|
if (imagesToOptimize.length === 0) return;
|
|
|
|
|
2024-06-06 17:24:59 +02:00
|
|
|
let imagesOptimized = 1;
|
|
|
|
|
|
|
|
sendMessage({
|
2024-06-18 09:50:38 +02:00
|
|
|
type: 'PROGRESS_TOTAL_ITEMS',
|
|
|
|
data: imagesToOptimize.length
|
2024-06-06 17:24:59 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
sendMessage({
|
2024-06-18 09:50:38 +02:00
|
|
|
type: 'PROGRESS_STEP',
|
|
|
|
data: 'optimization'
|
2024-06-06 17:24:59 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
for (const [key, bytes] of imagesToOptimize) {
|
|
|
|
if (bytes) {
|
|
|
|
uiImages.register(key, await parseImage(bytes));
|
|
|
|
}
|
|
|
|
|
|
|
|
sendMessage({
|
|
|
|
type: 'PROGRESS_PROCESSED_ITEMS',
|
|
|
|
data: imagesOptimized++
|
|
|
|
});
|
|
|
|
|
|
|
|
await sleep(0);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
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
|
|
|
|
2024-06-06 17:24:59 +02:00
|
|
|
await optimizeImages(images);
|
2024-06-05 12:36:49 +02:00
|
|
|
|
2024-06-18 09:50:38 +02:00
|
|
|
return createFile(name, children);
|
2024-05-29 12:52:21 +02:00
|
|
|
};
|