Skip to content

Commit

Permalink
fix(core): use mobx reaction to track the value of stepDrag.model(#1370)
Browse files Browse the repository at this point in the history
  • Loading branch information
wbccb authored and wumail committed Oct 23, 2023
1 parent 1cb45dd commit a1e3bc3
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 8 deletions.
4 changes: 3 additions & 1 deletion packages/core/src/util/mobx.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { action, observable, computed, toJS, isObservable, configure } from 'mobx';
import { action, observable, computed, toJS, isObservable, configure, reaction, IReactionDisposer } from 'mobx';

configure({ isolateGlobalState: true });

Expand All @@ -9,4 +9,6 @@ export {
isObservable,
toJS,
configure,
reaction,
IReactionDisposer,
};
24 changes: 17 additions & 7 deletions packages/core/src/view/node/BaseNode.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import { cancelRaf, createRaf } from '../../util/raf';
import { EventArgs } from '../../type';
import RotateControlPoint from '../Rotate';
import { TranslateMatrix, RotateMatrix } from '../../util';
import { reaction, IReactionDisposer } from '../../util/mobx';

type IProps = {
model: BaseNodeModel;
Expand All @@ -36,6 +37,7 @@ export default abstract class BaseNode extends Component<IProps, IState> {
contextMenuTime: number;
startTime: number;
clickTimer: number;
modelDisposer: IReactionDisposer;
constructor(props) {
super();
const {
Expand All @@ -52,6 +54,21 @@ export default abstract class BaseNode extends Component<IProps, IState> {
eventCenter,
model,
});
// https://github.com/didi/LogicFlow/issues/1370
// 当使用撤销功能:LogicFlow.undo()时,会重新初始化所有model数据,即LogicFlow.undo()时会新构建一个model对象
// 但是this.stepDrag并不会重新创建
// 导致this.stepDrag持有的model并没有重新赋值,因为之前的做法是构造函数中传入一个model对象
// 使用mobx的reaction监听能力,如果this.props.model发生变化,则进行this.stepDrag.setModel()操作
this.modelDisposer = reaction(() => this.props, (newProps) => {
if (newProps && newProps.model) {
this.stepDrag.setModel(newProps.model);
}
});
}
componentWillUnmount() {
if (this.modelDisposer) {
this.modelDisposer();
}
}
abstract getShape();
getAnchorShape(anchorData): h.JSX.Element {
Expand Down Expand Up @@ -324,13 +341,6 @@ export default abstract class BaseNode extends Component<IProps, IState> {
this.startTime = new Date().getTime();
const { editConfigModel } = graphModel;
if (editConfigModel.adjustNodePosition && model.draggable) {
// https://github.com/didi/LogicFlow/issues/1370
// 当使用撤销功能:LogicFlow.undo()时,会重新初始化所有model数据,即LogicFlow.undo()时会新构建一个model对象
// 但是this.stepDrag并不会重新创建
// 导致this.stepDrag持有的model并没有重新赋值,因为之前的做法是构造函数中传入一个model对象
// 在StepDrag.ts中只有handleMouseDown、handleMouseMove、handleMouseUp使用到this.model
// 因此在handleMouseDown()进行setModel重新将this.props.model的值设置进去,刷新this.model.getData()
this.stepDrag && this.stepDrag.setModel(model);
this.stepDrag && this.stepDrag.handleMouseDown(ev);
}
};
Expand Down

0 comments on commit a1e3bc3

Please sign in to comment.