mirror of
https://github.com/penpot/penpot-exporter-figma-plugin.git
synced 2024-12-22 21:53:27 -05:00
af81fc7e92
* Implement rotation for vector lines * wip * Improve rotations for lines * add changelog * add layout attributes to line
51 lines
1.1 KiB
TypeScript
51 lines
1.1 KiB
TypeScript
import { getBoundingBox } from '@plugin/utils';
|
|
|
|
import { ShapeGeomAttributes } from '@ui/lib/types/shapes/shape';
|
|
|
|
export const transformDimension = (
|
|
node: DimensionAndPositionMixin
|
|
): Pick<ShapeGeomAttributes, 'width' | 'height'> => {
|
|
return {
|
|
width: node.width,
|
|
height: node.height
|
|
};
|
|
};
|
|
|
|
export const transformPosition = (
|
|
node: DimensionAndPositionMixin,
|
|
baseX: number,
|
|
baseY: number
|
|
): Pick<ShapeGeomAttributes, 'x' | 'y'> => {
|
|
return {
|
|
x: node.x + baseX,
|
|
y: node.y + baseY
|
|
};
|
|
};
|
|
|
|
export const transformDimensionAndPosition = (
|
|
node: DimensionAndPositionMixin,
|
|
baseX: number,
|
|
baseY: number
|
|
): ShapeGeomAttributes => {
|
|
return {
|
|
x: node.x + baseX,
|
|
y: node.y + baseY,
|
|
width: node.width,
|
|
height: node.height
|
|
};
|
|
};
|
|
|
|
export const transformDimensionAndPositionFromVectorPath = (
|
|
vectorPath: VectorPath,
|
|
baseX: number,
|
|
baseY: number
|
|
): ShapeGeomAttributes => {
|
|
const boundingBox = getBoundingBox(vectorPath);
|
|
|
|
return {
|
|
x: boundingBox.x1 + baseX,
|
|
y: boundingBox.y1 + baseY,
|
|
width: boundingBox.x2 - boundingBox.x1,
|
|
height: boundingBox.y2 - boundingBox.y1
|
|
};
|
|
};
|