Skip to content

Commit

Permalink
[FIX] figure: crash on deleting dragged figure
Browse files Browse the repository at this point in the history
There was a traceback if a figure was deleted while being dragged.

closes #5334

Task: 4329240
X-original-commit: fbae6df
Signed-off-by: Lucas Lefèvre (lul) <[email protected]>
Signed-off-by: Adrien Minne (adrm) <[email protected]>
  • Loading branch information
hokolomopo committed Dec 10, 2024
1 parent 3fdd729 commit af6ae5f
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 8 deletions.
32 changes: 24 additions & 8 deletions src/components/figures/figure_container/figure_container.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Component, onMounted, useState } from "@odoo/owl";
import { Component, onMounted, onWillUpdateProps, useState } from "@odoo/owl";
import { ComponentsImportance, MIN_FIG_SIZE } from "../../../constants";
import { isDefined } from "../../../helpers";
import { rectIntersection, rectUnion } from "../../../helpers/rectangle";
Expand Down Expand Up @@ -43,6 +43,7 @@ interface DndState {
draggedFigure?: Figure;
horizontalSnap?: Snap<HFigureAxisType>;
verticalSnap?: Snap<VFigureAxisType>;
cancelDnd: (() => void) | undefined;
}

css/*SCSS*/ `
Expand Down Expand Up @@ -135,6 +136,7 @@ export class FiguresContainer extends Component<Props, SpreadsheetChildEnv> {
draggedFigure: undefined,
horizontalSnap: undefined,
verticalSnap: undefined,
cancelDnd: undefined,
});

setup() {
Expand All @@ -148,6 +150,19 @@ export class FiguresContainer extends Component<Props, SpreadsheetChildEnv> {
// new rendering
this.render();
});
onWillUpdateProps(() => {
const sheetId = this.env.model.getters.getActiveSheetId();
const draggedFigureId = this.dnd.draggedFigure?.id;
if (draggedFigureId && !this.env.model.getters.getFigure(sheetId, draggedFigureId)) {
if (this.dnd.cancelDnd) {
this.dnd.cancelDnd();
}
this.dnd.draggedFigure = undefined;
this.dnd.horizontalSnap = undefined;
this.dnd.verticalSnap = undefined;
this.dnd.cancelDnd = undefined;
}
});
}

private getVisibleFigures(): Figure[] {
Expand All @@ -156,12 +171,13 @@ export class FiguresContainer extends Component<Props, SpreadsheetChildEnv> {
this.dnd.draggedFigure &&
!visibleFigures.some((figure) => figure.id === this.dnd.draggedFigure?.id)
) {
visibleFigures.push(
this.env.model.getters.getFigure(
this.env.model.getters.getActiveSheetId(),
this.dnd.draggedFigure?.id
)!
const draggedFigure = this.env.model.getters.getFigure(
this.env.model.getters.getActiveSheetId(),
this.dnd.draggedFigure?.id
);
if (draggedFigure) {
visibleFigures.push(draggedFigure);
}
}
return visibleFigures;
}
Expand Down Expand Up @@ -314,7 +330,7 @@ export class FiguresContainer extends Component<Props, SpreadsheetChildEnv> {
this.dnd.verticalSnap = undefined;
this.env.model.dispatch("UPDATE_FIGURE", { sheetId, id: figure.id, x, y });
};
startDnd(onMouseMove, onMouseUp);
this.dnd.cancelDnd = startDnd(onMouseMove, onMouseUp);
}

/**
Expand Down Expand Up @@ -382,7 +398,7 @@ export class FiguresContainer extends Component<Props, SpreadsheetChildEnv> {
this.dnd.horizontalSnap = undefined;
this.dnd.verticalSnap = undefined;
};
startDnd(onMouseMove, onMouseUp);
this.dnd.cancelDnd = startDnd(onMouseMove, onMouseUp);
}

private getOtherFigures(figId: UID): Figure[] {
Expand Down
9 changes: 9 additions & 0 deletions tests/figures/figure_component.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -416,6 +416,15 @@ describe("figures", () => {
);
}
);

test("Deleting a figure during drag and drop does not crash", async () => {
createFigure(model, { id: "someuuid", x: 200, y: 100 });
await nextTick();
await dragElement(".o-figure", { x: 150, y: 100 }, undefined, false);
model.dispatch("DELETE_FIGURE", { id: "someuuid", sheetId });
await nextTick();
expect(model.getters.getFigure(sheetId, "someuuid")).toEqual(undefined);
});
});

test("Cannot select/move figure in readonly mode", async () => {
Expand Down

0 comments on commit af6ae5f

Please sign in to comment.