2024-06-14 03:33:23 -05:00
|
|
|
import { Command } from 'svg-path-parser';
|
|
|
|
|
|
|
|
import { applyInverseRotation, applyRotation, hasRotation } from '@plugin/utils';
|
|
|
|
|
|
|
|
import { Segment } from '@ui/lib/types/shapes/pathShape';
|
|
|
|
|
|
|
|
import { translateCommandsToSegments } from '.';
|
|
|
|
|
|
|
|
export const translateLineNode = (node: LineNode, baseX: number, baseY: number): Segment[] => {
|
|
|
|
if (!hasRotation(node.rotation) || !node.absoluteBoundingBox) {
|
|
|
|
return translateCommandsToSegments(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
x: 0,
|
|
|
|
y: 0,
|
|
|
|
command: 'moveto',
|
|
|
|
code: 'M'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
x: node.width,
|
|
|
|
y: 0,
|
|
|
|
command: 'lineto',
|
|
|
|
code: 'L'
|
|
|
|
}
|
|
|
|
],
|
|
|
|
baseX + node.x,
|
|
|
|
baseY + node.y
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
const startPoint = applyRotation(
|
|
|
|
{ x: 0, y: 0 },
|
|
|
|
node.absoluteTransform,
|
|
|
|
node.absoluteBoundingBox
|
|
|
|
);
|
|
|
|
|
|
|
|
const endPoint = applyRotation(
|
|
|
|
{ x: node.width, y: 0 },
|
|
|
|
node.absoluteTransform,
|
|
|
|
node.absoluteBoundingBox
|
|
|
|
);
|
|
|
|
|
|
|
|
const commands: Command[] = [
|
2024-05-21 07:36:30 -05:00
|
|
|
{
|
2024-06-14 03:33:23 -05:00
|
|
|
x: startPoint.x,
|
|
|
|
y: startPoint.y,
|
2024-05-21 07:36:30 -05:00
|
|
|
command: 'moveto',
|
2024-06-14 03:33:23 -05:00
|
|
|
code: 'M'
|
2024-05-21 07:36:30 -05:00
|
|
|
},
|
|
|
|
{
|
2024-06-14 03:33:23 -05:00
|
|
|
x: endPoint.x,
|
|
|
|
y: endPoint.y,
|
2024-05-21 07:36:30 -05:00
|
|
|
command: 'lineto',
|
2024-06-14 03:33:23 -05:00
|
|
|
code: 'L'
|
2024-05-21 07:36:30 -05:00
|
|
|
}
|
|
|
|
];
|
|
|
|
|
2024-06-14 03:33:23 -05:00
|
|
|
const referencePoint = applyInverseRotation(
|
|
|
|
{ x: node.x, y: node.y },
|
|
|
|
node.absoluteTransform,
|
|
|
|
node.absoluteBoundingBox
|
|
|
|
);
|
|
|
|
|
|
|
|
return translateCommandsToSegments(commands, baseX + referencePoint.x, baseY + referencePoint.y);
|
2024-05-21 07:36:30 -05:00
|
|
|
};
|