mirror of
https://github.com/excalidraw/excalidraw.git
synced 2025-10-24 08:24:32 +02:00
86 lines
2.3 KiB
TypeScript
86 lines
2.3 KiB
TypeScript
import React from "react";
|
|
import { expect } from "vitest";
|
|
|
|
import { reseed } from "@excalidraw/common";
|
|
|
|
import { Excalidraw } from "../index";
|
|
|
|
import { UI } from "./helpers/ui";
|
|
import { render, unmountComponent } from "./test-utils";
|
|
|
|
unmountComponent();
|
|
|
|
beforeEach(() => {
|
|
localStorage.clear();
|
|
reseed(7);
|
|
});
|
|
|
|
test("unselected bound arrow updates when rotating its target element", async () => {
|
|
await render(<Excalidraw />);
|
|
const rectangle = UI.createElement("rectangle", {
|
|
width: 200,
|
|
height: 100,
|
|
});
|
|
const arrow = UI.createElement("arrow", {
|
|
x: -80,
|
|
y: 50,
|
|
width: 85,
|
|
height: 0,
|
|
});
|
|
|
|
expect(arrow.endBinding?.elementId).toEqual(rectangle.id);
|
|
|
|
UI.rotate(rectangle, [60, 36], { shift: true });
|
|
|
|
expect(arrow.endBinding?.elementId).toEqual(rectangle.id);
|
|
expect(arrow.x).toBeCloseTo(-80);
|
|
expect(arrow.y).toBeCloseTo(50);
|
|
expect(arrow.width).toBeCloseTo(84.9, 1);
|
|
expect(arrow.height).toBeCloseTo(52.717, 1);
|
|
});
|
|
|
|
test("unselected bound arrows update when rotating their target elements", async () => {
|
|
await render(<Excalidraw />);
|
|
const ellipse = UI.createElement("ellipse", {
|
|
x: 0,
|
|
y: 80,
|
|
width: 300,
|
|
height: 120,
|
|
});
|
|
const ellipseArrow = UI.createElement("arrow", {
|
|
x: -10,
|
|
y: 80,
|
|
width: 50,
|
|
height: 60,
|
|
});
|
|
const text = UI.createElement("text", {
|
|
position: 220,
|
|
});
|
|
await UI.editText(text, "test");
|
|
const textArrow = UI.createElement("arrow", {
|
|
x: 360,
|
|
y: 300,
|
|
width: -140,
|
|
height: -60,
|
|
});
|
|
|
|
expect(ellipseArrow.endBinding?.elementId).toEqual(ellipse.id);
|
|
expect(textArrow.endBinding?.elementId).toEqual(text.id);
|
|
|
|
UI.rotate([ellipse, text], [-82, 23], { shift: true });
|
|
|
|
expect(ellipseArrow.endBinding?.elementId).toEqual(ellipse.id);
|
|
expect(ellipseArrow.x).toEqual(-10);
|
|
expect(ellipseArrow.y).toEqual(80);
|
|
expect(ellipseArrow.points[0]).toEqual([0, 0]);
|
|
expect(ellipseArrow.points[1][0]).toBeCloseTo(42.318, 1);
|
|
expect(ellipseArrow.points[1][1]).toBeCloseTo(92.133, 1);
|
|
|
|
expect(textArrow.endBinding?.elementId).toEqual(text.id);
|
|
expect(textArrow.x).toEqual(360);
|
|
expect(textArrow.y).toEqual(300);
|
|
expect(textArrow.points[0]).toEqual([0, 0]);
|
|
expect(textArrow.points[1][0]).toBeCloseTo(-98.86, 0);
|
|
expect(textArrow.points[1][1]).toBeCloseTo(-123.65, 0);
|
|
});
|