2024-04-15 11:58:51 +00:00
|
|
|
import { transformDimensionAndPosition } from '@plugin/transformers/partials';
|
2024-04-12 16:52:36 +02:00
|
|
|
import { detectMimeType } from '@plugin/utils';
|
|
|
|
|
|
|
|
import { ImageShape } from '@ui/lib/types/image/imageShape';
|
2024-04-12 13:55:42 +02:00
|
|
|
|
|
|
|
export const transformImageNode = async (
|
|
|
|
node: SceneNode,
|
|
|
|
baseX: number,
|
|
|
|
baseY: number
|
|
|
|
): Promise<ImageShape> => {
|
|
|
|
let dataUri = '';
|
|
|
|
if ('exportAsync' in node) {
|
|
|
|
const value = await node.exportAsync({ format: 'PNG' });
|
|
|
|
const b64 = figma.base64Encode(value);
|
|
|
|
dataUri = 'data:' + detectMimeType(b64) + ';base64,' + b64;
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
type: 'image',
|
|
|
|
name: node.name,
|
|
|
|
metadata: {
|
|
|
|
width: node.width,
|
|
|
|
height: node.height
|
|
|
|
},
|
2024-04-15 11:58:51 +00:00
|
|
|
dataUri: dataUri,
|
|
|
|
...transformDimensionAndPosition(node, baseX, baseY)
|
2024-04-12 13:55:42 +02:00
|
|
|
};
|
|
|
|
};
|