Skip to content

Commit

Permalink
fix(stage): 设置margin后拖动位置出现漂移
Browse files Browse the repository at this point in the history
fix #549
  • Loading branch information
roymondchen committed Nov 13, 2023
1 parent 3b789f4 commit 7f6ba9d
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 11 deletions.
31 changes: 20 additions & 11 deletions packages/stage/src/DragResizeHelper.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ import MoveableHelper from 'moveable-helper';
import { DRAG_EL_ID_PREFIX, GHOST_EL_ID_PREFIX, Mode, ZIndex } from './const';
import TargetShadow from './TargetShadow';
import { DragResizeHelperConfig, Rect, TargetElement } from './types';
import { calcValueByFontsize, getAbsolutePosition, getOffset } from './util';
import { calcValueByFontsize, getAbsolutePosition, getMarginValue, getOffset } from './util';

/**
* 拖拽/改变大小等操作发生时,moveable会抛出各种状态事件,DragResizeHelper负责响应这些事件,对目标节点target和拖拽节点targetShadow进行修改;
Expand Down Expand Up @@ -126,8 +126,9 @@ export default class DragResizeHelper {
}
} else {
this.moveableHelper.onResize(e);
this.target.style.left = `${this.frameSnapShot.left + beforeTranslate[0]}px`;
this.target.style.top = `${this.frameSnapShot.top + beforeTranslate[1]}px`;
const { marginLeft, marginTop } = getMarginValue(this.target);
this.target.style.left = `${this.frameSnapShot.left + beforeTranslate[0] - marginLeft}px`;
this.target.style.top = `${this.frameSnapShot.top + beforeTranslate[1] - marginTop} - marginToppx`;
}

this.target.style.width = `${width}px`;
Expand All @@ -154,8 +155,10 @@ export default class DragResizeHelper {

this.moveableHelper.onDrag(e);

this.target.style.left = `${this.frameSnapShot.left + e.beforeTranslate[0]}px`;
this.target.style.top = `${this.frameSnapShot.top + e.beforeTranslate[1]}px`;
const { marginLeft, marginTop } = getMarginValue(this.target);

this.target.style.left = `${this.frameSnapShot.left + e.beforeTranslate[0] - marginLeft}px`;
this.target.style.top = `${this.frameSnapShot.top + e.beforeTranslate[1] - marginTop}px`;
}

public onRotateStart(e: OnRotateStart): void {
Expand Down Expand Up @@ -241,8 +244,9 @@ export default class DragResizeHelper {

if (!isParentIncluded) {
// 更新页面元素位置
targeEl.style.left = `${frameSnapShot.left + beforeTranslate[0]}px`;
targeEl.style.top = `${frameSnapShot.top + beforeTranslate[1]}px`;
const { marginLeft, marginTop } = getMarginValue(targeEl);
targeEl.style.left = `${frameSnapShot.left + beforeTranslate[0] - marginLeft}px`;
targeEl.style.top = `${frameSnapShot.top + beforeTranslate[1] - marginTop}px`;
}

// 更新页面元素大小
Expand Down Expand Up @@ -275,8 +279,9 @@ export default class DragResizeHelper {
const isParentIncluded = this.targetList.find((targetItem) => targetItem.id === targeEl.parentElement?.id);
if (!isParentIncluded) {
// 更新页面元素位置
targeEl.style.left = `${frameSnapShot.left + ev.beforeTranslate[0]}px`;
targeEl.style.top = `${frameSnapShot.top + ev.beforeTranslate[1]}px`;
const { marginLeft, marginTop } = getMarginValue(targeEl);
targeEl.style.left = `${frameSnapShot.left + ev.beforeTranslate[0] - marginLeft}px`;
targeEl.style.top = `${frameSnapShot.top + ev.beforeTranslate[1] - marginTop}px`;
}
});
this.moveableHelper.onDragGroup(e);
Expand All @@ -285,8 +290,10 @@ export default class DragResizeHelper {
public getUpdatedElRect(el: HTMLElement, parentEl: HTMLElement | null, doc: Document): Rect {
const offset = this.mode === Mode.SORTABLE ? { left: 0, top: 0 } : { left: el.offsetLeft, top: el.offsetTop };

let left = calcValueByFontsize(doc, offset.left);
let top = calcValueByFontsize(doc, offset.top);
const { marginLeft, marginTop } = getMarginValue(el);

let left = calcValueByFontsize(doc, offset.left) - marginLeft;
let top = calcValueByFontsize(doc, offset.top) - marginTop;
const width = calcValueByFontsize(doc, el.clientWidth);
const height = calcValueByFontsize(doc, el.clientHeight);

Expand Down Expand Up @@ -358,6 +365,8 @@ export default class DragResizeHelper {
ghostEl.style.position = 'absolute';
ghostEl.style.left = `${left}px`;
ghostEl.style.top = `${top}px`;
ghostEl.style.marginLeft = '0';
ghostEl.style.marginTop = '0';
el.after(ghostEl);
return ghostEl;
}
Expand Down
18 changes: 18 additions & 0 deletions packages/stage/src/util.ts
Original file line number Diff line number Diff line change
Expand Up @@ -242,3 +242,21 @@ export const up = (deltaTop: number, target: TargetElement): SortEventData | voi

export const isMoveableButton = (target: Element) =>
target.classList.contains('moveable-button') || target.parentElement?.classList.contains('moveable-button');

export const getMarginValue = (el: Element) => {
if (!el)
return {
marginLeft: 0,
marginTop: 0,
};

const { marginLeft, marginTop } = getComputedStyle(el);

const marginLeftValue = parseFloat(marginLeft) || 0;
const marginTopValue = parseFloat(marginTop) || 0;

return {
marginLeft: marginLeftValue,
marginTop: marginTopValue,
};
};

0 comments on commit 7f6ba9d

Please sign in to comment.