mirror of
https://github.com/penpot/penpot-exporter-figma-plugin.git
synced 2025-01-03 05:10:13 -05:00
303cc833a0
* wip * wip * wip * wip * wip * fixes * fixes * fixes * fixes * fixes * fixes * fixes * fixes * fixes
145 lines
3.3 KiB
TypeScript
145 lines
3.3 KiB
TypeScript
import { init } from '@common/map';
|
|
import { sleep } from '@common/sleep';
|
|
|
|
import { sendMessage } from '@ui/context';
|
|
import { createFile } from '@ui/lib/penpot';
|
|
import { PenpotFile } from '@ui/lib/types/penpotFile';
|
|
import { TypographyStyle } from '@ui/lib/types/shapes/textShape';
|
|
import { FillStyle } from '@ui/lib/types/utils/fill';
|
|
import {
|
|
colors,
|
|
componentShapes,
|
|
images,
|
|
typographies,
|
|
componentProperties as uiComponentProperties
|
|
} from '@ui/parser';
|
|
import { buildFile } from '@ui/parser/creators';
|
|
import { PenpotDocument } from '@ui/types';
|
|
|
|
import { parseImage } from '.';
|
|
|
|
const optimizeImages = async (binaryImages: Record<string, Uint8Array>) => {
|
|
const imagesToOptimize = Object.entries(binaryImages);
|
|
|
|
if (imagesToOptimize.length === 0) return;
|
|
|
|
let imagesOptimized = 1;
|
|
|
|
sendMessage({
|
|
type: 'PROGRESS_TOTAL_ITEMS',
|
|
data: imagesToOptimize.length
|
|
});
|
|
|
|
sendMessage({
|
|
type: 'PROGRESS_STEP',
|
|
data: 'optimization'
|
|
});
|
|
|
|
for (const [key, bytes] of imagesToOptimize) {
|
|
if (bytes) {
|
|
images.set(key, await parseImage(bytes));
|
|
}
|
|
|
|
sendMessage({
|
|
type: 'PROGRESS_PROCESSED_ITEMS',
|
|
data: imagesOptimized++
|
|
});
|
|
|
|
await sleep(0);
|
|
}
|
|
};
|
|
|
|
const prepareTypographyLibraries = async (
|
|
file: PenpotFile,
|
|
styles: Record<string, TypographyStyle>
|
|
) => {
|
|
const stylesToRegister = Object.entries(styles);
|
|
|
|
if (stylesToRegister.length === 0) return;
|
|
|
|
let stylesRegistered = 1;
|
|
|
|
sendMessage({
|
|
type: 'PROGRESS_TOTAL_ITEMS',
|
|
data: stylesToRegister.length
|
|
});
|
|
|
|
sendMessage({
|
|
type: 'PROGRESS_STEP',
|
|
data: 'typoFormat'
|
|
});
|
|
|
|
for (const [key, style] of stylesToRegister) {
|
|
const typographyId = file.newId();
|
|
style.textStyle.typographyRefId = typographyId;
|
|
style.textStyle.typographyRefFile = file.getId();
|
|
style.typography.id = typographyId;
|
|
|
|
typographies.set(key, style);
|
|
|
|
sendMessage({
|
|
type: 'PROGRESS_PROCESSED_ITEMS',
|
|
data: stylesRegistered++
|
|
});
|
|
|
|
await sleep(0);
|
|
}
|
|
};
|
|
|
|
const prepareColorLibraries = async (file: PenpotFile, styles: Record<string, FillStyle>) => {
|
|
const stylesToRegister = Object.entries(styles);
|
|
|
|
if (stylesToRegister.length === 0) return;
|
|
|
|
let stylesRegistered = 1;
|
|
|
|
sendMessage({
|
|
type: 'PROGRESS_TOTAL_ITEMS',
|
|
data: stylesToRegister.length
|
|
});
|
|
|
|
sendMessage({
|
|
type: 'PROGRESS_STEP',
|
|
data: 'format'
|
|
});
|
|
|
|
for (const [key, fillStyle] of stylesToRegister) {
|
|
for (let index = 0; index < fillStyle.fills.length; index++) {
|
|
const colorId = file.newId();
|
|
fillStyle.fills[index].fillColorRefId = colorId;
|
|
fillStyle.fills[index].fillColorRefFile = file.getId();
|
|
fillStyle.colors[index].id = colorId;
|
|
fillStyle.colors[index].refFile = file.getId();
|
|
}
|
|
|
|
colors.set(key, fillStyle);
|
|
|
|
sendMessage({
|
|
type: 'PROGRESS_PROCESSED_ITEMS',
|
|
data: stylesRegistered++
|
|
});
|
|
|
|
await sleep(0);
|
|
}
|
|
};
|
|
|
|
export const parse = async ({
|
|
name,
|
|
children = [],
|
|
components,
|
|
images,
|
|
paintStyles,
|
|
textStyles,
|
|
componentProperties
|
|
}: PenpotDocument) => {
|
|
init(componentShapes, components);
|
|
init(uiComponentProperties, componentProperties);
|
|
|
|
const file = createFile(name);
|
|
|
|
await optimizeImages(images);
|
|
await prepareColorLibraries(file, paintStyles);
|
|
await prepareTypographyLibraries(file, textStyles);
|
|
|
|
return buildFile(file, children);
|
|
};
|