mirror of
https://github.com/excalidraw/excalidraw.git
synced 2025-05-03 10:00:07 -04:00
fix: update coords when text unbinded from its container (#6445)
* fix: update coords when text unbinded from its container * Add specs
This commit is contained in:
parent
372743f59f
commit
13b27afe0f
4 changed files with 109 additions and 3 deletions
|
@ -23,7 +23,7 @@ import {
|
|||
getMaxContainerWidth,
|
||||
} from "../element/textElement";
|
||||
import * as textElementUtils from "../element/textElement";
|
||||
import { ROUNDNESS } from "../constants";
|
||||
import { ROUNDNESS, VERTICAL_ALIGN } from "../constants";
|
||||
|
||||
const renderScene = jest.spyOn(Renderer, "renderScene");
|
||||
|
||||
|
@ -1191,5 +1191,62 @@ describe("Test Linear Elements", () => {
|
|||
expect(queryByTestId(container, "align-horizontal-center")).toBeNull();
|
||||
expect(queryByTestId(container, "align-right")).toBeNull();
|
||||
});
|
||||
|
||||
it("should update label coords when a label binded via context menu is unbinded", async () => {
|
||||
createTwoPointerLinearElement("arrow");
|
||||
const text = API.createElement({
|
||||
type: "text",
|
||||
text: "Hello Excalidraw",
|
||||
});
|
||||
expect(text.x).toBe(0);
|
||||
expect(text.y).toBe(0);
|
||||
|
||||
h.elements = [h.elements[0], text];
|
||||
|
||||
const container = h.elements[0];
|
||||
API.setSelectedElements([container, text]);
|
||||
fireEvent.contextMenu(GlobalTestState.canvas, {
|
||||
button: 2,
|
||||
clientX: 20,
|
||||
clientY: 30,
|
||||
});
|
||||
let contextMenu = document.querySelector(".context-menu");
|
||||
|
||||
fireEvent.click(
|
||||
queryByText(contextMenu as HTMLElement, "Bind text to the container")!,
|
||||
);
|
||||
expect(container.boundElements).toStrictEqual([
|
||||
{ id: h.elements[1].id, type: "text" },
|
||||
]);
|
||||
expect(text.containerId).toBe(container.id);
|
||||
expect(text.verticalAlign).toBe(VERTICAL_ALIGN.MIDDLE);
|
||||
|
||||
mouse.reset();
|
||||
mouse.clickAt(
|
||||
container.x + container.width / 2,
|
||||
container.y + container.height / 2,
|
||||
);
|
||||
mouse.down();
|
||||
mouse.up();
|
||||
API.setSelectedElements([h.elements[0], h.elements[1]]);
|
||||
|
||||
fireEvent.contextMenu(GlobalTestState.canvas, {
|
||||
button: 2,
|
||||
clientX: 20,
|
||||
clientY: 30,
|
||||
});
|
||||
contextMenu = document.querySelector(".context-menu");
|
||||
fireEvent.click(queryByText(contextMenu as HTMLElement, "Unbind text")!);
|
||||
expect(container.boundElements).toEqual([]);
|
||||
expect(text).toEqual(
|
||||
expect.objectContaining({
|
||||
containerId: null,
|
||||
width: 160,
|
||||
height: 25,
|
||||
x: -40,
|
||||
y: 7.5,
|
||||
}),
|
||||
);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue