mirror of
https://github.com/penpot/penpot-exporter-figma-plugin.git
synced 2025-01-08 16:10:07 -05:00
7b3192936e
* wip * wip * wipo * more structure * wip * id library wip * wip * main instance working * improvements * fix node order * refactor * remove not used method * refactor * fix component set translation * refactor * add changelog * penpot lib update --------- Co-authored-by: Jordi Sala Morales <jordism91@gmail.com>
44 lines
1 KiB
TypeScript
44 lines
1 KiB
TypeScript
import { PenpotFile } from '@ui/lib/types/penpotFile';
|
|
import { parseFigmaId } from '@ui/parser';
|
|
import { uiComponents } from '@ui/parser/libraries';
|
|
import { ComponentInstance } from '@ui/types';
|
|
|
|
import { createArtboard } from '.';
|
|
|
|
export const createComponentInstance = (
|
|
file: PenpotFile,
|
|
{
|
|
type,
|
|
mainComponentFigmaId,
|
|
figmaId,
|
|
figmaRelatedId,
|
|
isComponentRoot,
|
|
...rest
|
|
}: ComponentInstance
|
|
) => {
|
|
let uiComponent = uiComponents.get(mainComponentFigmaId);
|
|
|
|
if (!uiComponent) {
|
|
const mainInstanceId = parseFigmaId(file, mainComponentFigmaId);
|
|
if (!mainInstanceId) {
|
|
return;
|
|
}
|
|
|
|
uiComponent = {
|
|
componentId: file.newId(),
|
|
componentFigmaId: mainComponentFigmaId,
|
|
mainInstanceId
|
|
};
|
|
uiComponents.register(mainComponentFigmaId, uiComponent);
|
|
}
|
|
|
|
createArtboard(file, {
|
|
...rest,
|
|
showContent: true,
|
|
shapeRef: uiComponent.mainInstanceId,
|
|
componentFile: file.getId(),
|
|
componentRoot: isComponentRoot,
|
|
componentId: uiComponent.componentId,
|
|
type: 'frame'
|
|
});
|
|
};
|