0
Fork 0
mirror of https://github.com/penpot/penpot-exporter-figma-plugin.git synced 2025-01-06 23:00:55 -05:00
penpot-exporter-figma-plugin/ui-src/parser/creators/createComponentInstance.ts
Alex Sánchez 303cc833a0
Fix component overrides (#200)
* wip

* wip

* wip

* wip

* wip

* fixes

* fixes

* fixes

* fixes

* fixes

* fixes

* fixes

* fixes

* fixes
2024-06-28 12:17:56 +02:00

54 lines
1.4 KiB
TypeScript

import { PenpotFile } from '@ui/lib/types/penpotFile';
import { Uuid } from '@ui/lib/types/utils/uuid';
import { components, parseFigmaId } from '@ui/parser';
import { ComponentInstance } from '@ui/types';
import { createArtboard } from '.';
let remoteFileId: Uuid | undefined = undefined;
export const createComponentInstance = (
file: PenpotFile,
{ type, mainComponentFigmaId, isComponentRoot, ...shape }: ComponentInstance
) => {
const uiComponent =
components.get(mainComponentFigmaId) ?? createUiComponent(file, mainComponentFigmaId);
if (!uiComponent) {
return;
}
if (!shape.figmaRelatedId) {
shape.shapeRef = uiComponent.mainInstanceId;
}
shape.componentFile = shape.isOrphan ? getRemoteFileId(file) : file.getId();
shape.componentRoot = isComponentRoot;
shape.componentId = uiComponent.componentId;
createArtboard(file, shape);
};
const createUiComponent = (file: PenpotFile, mainComponentFigmaId: string) => {
const mainInstanceId = parseFigmaId(file, mainComponentFigmaId);
if (!mainInstanceId) {
return;
}
const uiComponent = {
componentId: file.newId(),
componentFigmaId: mainComponentFigmaId,
mainInstanceId
};
components.set(mainComponentFigmaId, uiComponent);
return uiComponent;
};
const getRemoteFileId = (file: PenpotFile): Uuid => {
if (!remoteFileId) {
remoteFileId = file.newId();
}
return remoteFileId;
};