aboutsummaryrefslogtreecommitdiff
path: root/src/client/util/UndoManager.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/client/util/UndoManager.ts')
-rw-r--r--src/client/util/UndoManager.ts57
1 files changed, 35 insertions, 22 deletions
diff --git a/src/client/util/UndoManager.ts b/src/client/util/UndoManager.ts
index 34910bac3..8e9e11a11 100644
--- a/src/client/util/UndoManager.ts
+++ b/src/client/util/UndoManager.ts
@@ -1,36 +1,49 @@
import { observable, action } from "mobx";
import { Opt } from "../../fields/Field";
-export function undoBatch(target: any, key: string | symbol, descriptor?: TypedPropertyDescriptor<any>): any {
- let fn: (...args: any[]) => any;
- let patchedFn: Opt<(...args: any[]) => any>;
-
- if (descriptor) {
- fn = descriptor.value;
- }
-
- return {
+function propertyDecorator(target: any, key: string | symbol) {
+ Object.defineProperty(target, key, {
configurable: true,
enumerable: false,
- get() {
- if (!patchedFn) {
- patchedFn = (...args: any[]) => {
+ get: function () {
+ return 5;
+ },
+ set: function (value: any) {
+ Object.defineProperty(this, key, {
+ enumerable: false,
+ writable: true,
+ configurable: true,
+ value: function (...args: any[]) {
try {
- UndoManager.StartBatch()
- return fn.call(this, ...args)
+ UndoManager.StartBatch();
+ return value.apply(this, args);
} finally {
- UndoManager.EndBatch()
+ UndoManager.EndBatch();
}
- };
- }
- return patchedFn;
- },
- set(newFn: any) {
- patchedFn = undefined;
- fn = newFn;
+ }
+ })
+ }
+ })
+}
+export function undoBatch(target: any, key: string | symbol, descriptor: TypedPropertyDescriptor<any>): any {
+ if (!descriptor) {
+ propertyDecorator(target, key);
+ return;
+ }
+ const oldFunction = descriptor.value;
+
+ descriptor.value = function (...args: any[]) {
+ try {
+ UndoManager.StartBatch()
+ return oldFunction.apply(this, args)
+ } finally {
+ UndoManager.EndBatch()
}
}
+
+ return descriptor;
}
+
export namespace UndoManager {
export interface UndoEvent {
undo: () => void;