@excalidraw/excalidraw 0.18.0-6fc8502 → 0.18.0-7b8a5f54c
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/dev/chunk-CP5DND7P.js +7 -0
- package/dist/dev/chunk-CP5DND7P.js.map +7 -0
- package/dist/dev/chunk-CRKRRBMD.js +5677 -0
- package/dist/dev/chunk-CRKRRBMD.js.map +7 -0
- package/dist/dev/{chunk-X3RYHLJU.js → chunk-QF5FRM6O.js} +15 -5
- package/dist/dev/chunk-QF5FRM6O.js.map +7 -0
- package/dist/dev/data/{image-NKFINVKH.js → image-IWGLHPIX.js} +3 -3
- package/dist/dev/index.css +104 -22
- package/dist/dev/index.css.map +3 -3
- package/dist/dev/index.js +15051 -15792
- package/dist/dev/index.js.map +4 -4
- package/dist/dev/locales/{en-CKWC2GMK.js → en-SMAPCEOQ.js} +2 -2
- package/dist/dev/subset-shared.chunk.js +1 -1
- package/dist/dev/subset-worker.chunk.js +1 -1
- package/dist/prod/chunk-A66AFZZU.js +7 -0
- package/dist/prod/chunk-HHV2PJKY.js +4 -0
- package/dist/prod/chunk-I4UNSFV6.js +12 -0
- package/dist/prod/data/image-4SM4COIL.js +1 -0
- package/dist/prod/index.css +1 -1
- package/dist/prod/index.js +25 -17
- package/dist/prod/locales/{en-SBO6ZHT2.js → en-TYY6KWIJ.js} +1 -1
- package/dist/prod/subset-shared.chunk.js +1 -1
- package/dist/prod/subset-worker.chunk.js +1 -1
- package/dist/types/common/src/constants.d.ts +23 -3
- package/dist/types/{excalidraw → common/src}/emitter.d.ts +1 -1
- package/dist/types/common/src/font-metadata.d.ts +4 -2
- package/dist/types/common/src/index.d.ts +1 -0
- package/dist/types/common/src/utility-types.d.ts +5 -0
- package/dist/types/common/src/utils.d.ts +17 -1
- package/dist/types/{excalidraw/scene → element/src}/Scene.d.ts +16 -15
- package/dist/types/element/src/align.d.ts +4 -3
- package/dist/types/element/src/binding.d.ts +26 -16
- package/dist/types/element/src/bounds.d.ts +13 -5
- package/dist/types/element/src/collision.d.ts +18 -12
- package/dist/types/element/src/cropElement.d.ts +1 -1
- package/dist/types/{excalidraw/change.d.ts → element/src/delta.d.ts} +77 -40
- package/dist/types/element/src/distance.d.ts +2 -2
- package/dist/types/element/src/distribute.d.ts +2 -1
- package/dist/types/element/src/dragElements.d.ts +3 -2
- package/dist/types/element/src/duplicate.d.ts +10 -13
- package/dist/types/element/src/elbowArrow.d.ts +1 -1
- package/dist/types/element/src/flowchart.d.ts +3 -2
- package/dist/types/element/src/fractionalIndex.d.ts +9 -3
- package/dist/types/element/src/frame.d.ts +5 -4
- package/dist/types/element/src/groups.d.ts +1 -0
- package/dist/types/element/src/index.d.ts +43 -2
- package/dist/types/element/src/linearElementEditor.d.ts +23 -36
- package/dist/types/element/src/mutateElement.d.ts +11 -3
- package/dist/types/element/src/newElement.d.ts +4 -3
- package/dist/types/element/src/resizeElements.d.ts +5 -4
- package/dist/types/element/src/selection.d.ts +11 -5
- package/dist/types/element/src/shape.d.ts +42 -0
- package/dist/types/element/src/sizeHelpers.d.ts +2 -2
- package/dist/types/element/src/store.d.ts +236 -0
- package/dist/types/element/src/textElement.d.ts +5 -3
- package/dist/types/element/src/typeChecks.d.ts +19 -1
- package/dist/types/element/src/types.d.ts +15 -2
- package/dist/types/element/src/utils.d.ts +16 -6
- package/dist/types/element/src/zindex.d.ts +1 -1
- package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +39 -51
- package/dist/types/excalidraw/actions/actionBoundText.d.ts +26 -34
- package/dist/types/excalidraw/actions/actionCanvas.d.ts +175 -227
- package/dist/types/excalidraw/actions/actionClipboard.d.ts +78 -100
- package/dist/types/excalidraw/actions/actionCropEditor.d.ts +13 -17
- package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +39 -50
- package/dist/types/excalidraw/actions/actionElementLink.d.ts +12 -16
- package/dist/types/excalidraw/actions/actionElementLock.d.ts +41 -50
- package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +13 -17
- package/dist/types/excalidraw/actions/actionExport.d.ts +127 -163
- package/dist/types/excalidraw/actions/actionFinalize.d.ts +73 -40
- package/dist/types/excalidraw/actions/actionFrame.d.ts +99 -115
- package/dist/types/excalidraw/actions/actionGroup.d.ts +26 -34
- package/dist/types/excalidraw/actions/actionHistory.d.ts +1 -2
- package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +538 -18
- package/dist/types/excalidraw/actions/actionLink.d.ts +12 -16
- package/dist/types/excalidraw/actions/actionMenu.d.ts +36 -48
- package/dist/types/excalidraw/actions/actionNavigate.d.ts +25 -33
- package/dist/types/excalidraw/actions/actionProperties.d.ts +203 -255
- package/dist/types/excalidraw/actions/actionSelectAll.d.ts +13 -17
- package/dist/types/excalidraw/actions/actionStyles.d.ts +13 -17
- package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +13 -17
- package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +13 -17
- package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +12 -189
- package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +19 -0
- package/dist/types/excalidraw/actions/actionToggleStats.d.ts +13 -17
- package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +13 -17
- package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +13 -17
- package/dist/types/excalidraw/actions/types.d.ts +4 -3
- package/dist/types/excalidraw/appState.d.ts +19 -10
- package/dist/types/excalidraw/components/Actions.d.ts +0 -4
- package/dist/types/excalidraw/components/App.d.ts +34 -22
- package/dist/types/excalidraw/components/ButtonIcon.d.ts +1 -0
- package/dist/types/excalidraw/components/ColorPicker/ColorInput.d.ts +2 -1
- package/dist/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +5 -1
- package/dist/types/excalidraw/components/ColorPicker/CustomColorList.d.ts +1 -1
- package/dist/types/excalidraw/components/ColorPicker/Picker.d.ts +2 -3
- package/dist/types/excalidraw/components/ColorPicker/PickerColorList.d.ts +2 -3
- package/dist/types/excalidraw/components/ColorPicker/ShadeList.d.ts +2 -2
- package/dist/types/excalidraw/components/ColorPicker/TopPicks.d.ts +1 -1
- package/dist/types/excalidraw/components/ColorPicker/colorPickerUtils.d.ts +1 -1
- package/dist/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +1 -1
- package/dist/types/excalidraw/components/ConvertElementTypePopup.d.ts +23 -0
- package/dist/types/excalidraw/components/ElementLinkDialog.d.ts +4 -3
- package/dist/types/excalidraw/components/Ellipsify.d.ts +4 -0
- package/dist/types/excalidraw/components/{ButtonIconSelect.d.ts → RadioSelection.d.ts} +1 -1
- package/dist/types/excalidraw/components/Range.d.ts +3 -3
- package/dist/types/excalidraw/components/Stats/Angle.d.ts +1 -1
- package/dist/types/excalidraw/components/Stats/CanvasGrid.d.ts +1 -1
- package/dist/types/excalidraw/components/Stats/Collapsible.d.ts +2 -1
- package/dist/types/excalidraw/components/Stats/Dimension.d.ts +1 -1
- package/dist/types/excalidraw/components/Stats/DragInput.d.ts +12 -2
- package/dist/types/excalidraw/components/Stats/FontSize.d.ts +1 -1
- package/dist/types/excalidraw/components/Stats/MultiAngle.d.ts +1 -1
- package/dist/types/excalidraw/components/Stats/MultiDimension.d.ts +1 -1
- package/dist/types/excalidraw/components/Stats/MultiFontSize.d.ts +1 -1
- package/dist/types/excalidraw/components/Stats/MultiPosition.d.ts +1 -1
- package/dist/types/excalidraw/components/Stats/Position.d.ts +1 -1
- package/dist/types/excalidraw/components/Stats/utils.d.ts +4 -11
- package/dist/types/excalidraw/components/UnlockPopup.d.ts +8 -0
- package/dist/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +1 -0
- package/dist/types/excalidraw/components/hyperlink/Hyperlink.d.ts +3 -2
- package/dist/types/excalidraw/components/hyperlink/helpers.d.ts +2 -1
- package/dist/types/excalidraw/components/icons.d.ts +3 -0
- package/dist/types/excalidraw/components/shapes.d.ts +1 -1
- package/dist/types/excalidraw/data/reconcile.d.ts +1 -0
- package/dist/types/excalidraw/data/restore.d.ts +6 -1
- package/dist/types/excalidraw/data/transform.d.ts +1 -1
- package/dist/types/excalidraw/editor-jotai.d.ts +6 -6
- package/dist/types/excalidraw/eraser/index.d.ts +12 -0
- package/dist/types/excalidraw/fonts/Fonts.d.ts +1 -1
- package/dist/types/excalidraw/history.d.ts +30 -22
- package/dist/types/excalidraw/hooks/useEmitter.d.ts +1 -1
- package/dist/types/excalidraw/index.d.ts +11 -10
- package/dist/types/excalidraw/lasso/index.d.ts +1 -0
- package/dist/types/excalidraw/lasso/utils.d.ts +3 -3
- package/dist/types/excalidraw/renderer/helpers.d.ts +7 -2
- package/dist/types/excalidraw/renderer/staticScene.d.ts +4 -1
- package/dist/types/excalidraw/scene/Renderer.d.ts +1 -2
- package/dist/types/excalidraw/scene/index.d.ts +2 -2
- package/dist/types/excalidraw/scene/scrollbars.d.ts +2 -3
- package/dist/types/excalidraw/scene/types.d.ts +2 -0
- package/dist/types/excalidraw/snapping.d.ts +2 -2
- package/dist/types/excalidraw/types.d.ts +35 -14
- package/dist/types/excalidraw/wysiwyg/textWysiwyg.d.ts +3 -1
- package/dist/types/math/src/angle.d.ts +2 -0
- package/dist/types/math/src/constants.d.ts +3 -0
- package/dist/types/math/src/curve.d.ts +34 -0
- package/dist/types/math/src/index.d.ts +1 -0
- package/dist/types/math/src/point.d.ts +1 -1
- package/dist/types/math/src/rectangle.d.ts +2 -0
- package/dist/types/math/src/types.d.ts +1 -0
- package/dist/types/math/src/vector.d.ts +8 -2
- package/dist/types/utils/src/bbox.d.ts +1 -1
- package/dist/types/utils/src/index.d.ts +1 -1
- package/dist/types/utils/src/withinBounds.d.ts +1 -1
- package/history.ts +146 -109
- package/package.json +12 -9
- package/dist/dev/chunk-H7XJ5UVD.js +0 -7
- package/dist/dev/chunk-H7XJ5UVD.js.map +0 -7
- package/dist/dev/chunk-KYBDXI6F.js +0 -18739
- package/dist/dev/chunk-KYBDXI6F.js.map +0 -7
- package/dist/dev/chunk-X3RYHLJU.js.map +0 -7
- package/dist/prod/chunk-CAN5RS4P.js +0 -31
- package/dist/prod/chunk-IUH5AXLB.js +0 -12
- package/dist/prod/chunk-KJYFYP64.js +0 -7
- package/dist/prod/data/image-5XD47O4X.js +0 -1
- package/dist/types/element/src/Shape.d.ts +0 -17
- package/dist/types/element/src/ShapeCache.d.ts +0 -25
- package/dist/types/element/src/shapes.d.ts +0 -23
- package/dist/types/excalidraw/components/ButtonSelect.d.ts +0 -9
- package/dist/types/excalidraw/store.d.ts +0 -129
- package/dist/types/excalidraw/visualdebug.d.ts +0 -41
- package/dist/types/utils/src/collision.d.ts +0 -8
- /package/dist/dev/data/{image-NKFINVKH.js.map → image-IWGLHPIX.js.map} +0 -0
- /package/dist/dev/locales/{en-CKWC2GMK.js.map → en-SMAPCEOQ.js.map} +0 -0
package/history.ts
CHANGED
|
@@ -1,12 +1,84 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { Emitter } from "@excalidraw/common";
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
CaptureUpdateAction,
|
|
5
|
+
StoreChange,
|
|
6
|
+
StoreDelta,
|
|
7
|
+
} from "@excalidraw/element";
|
|
8
|
+
|
|
9
|
+
import type { StoreSnapshot, Store } from "@excalidraw/element";
|
|
2
10
|
|
|
3
|
-
import {
|
|
11
|
+
import type { SceneElementsMap } from "@excalidraw/element/types";
|
|
4
12
|
|
|
5
|
-
import type { AppStateChange, ElementsChange } from "./change";
|
|
6
|
-
import type { Snapshot } from "./store";
|
|
7
13
|
import type { AppState } from "./types";
|
|
8
14
|
|
|
9
|
-
|
|
15
|
+
export class HistoryDelta extends StoreDelta {
|
|
16
|
+
/**
|
|
17
|
+
* Apply the delta to the passed elements and appState, does not modify the snapshot.
|
|
18
|
+
*/
|
|
19
|
+
public applyTo(
|
|
20
|
+
elements: SceneElementsMap,
|
|
21
|
+
appState: AppState,
|
|
22
|
+
snapshot: StoreSnapshot,
|
|
23
|
+
): [SceneElementsMap, AppState, boolean] {
|
|
24
|
+
const [nextElements, elementsContainVisibleChange] = this.elements.applyTo(
|
|
25
|
+
elements,
|
|
26
|
+
// used to fallback into local snapshot in case we couldn't apply the delta
|
|
27
|
+
// due to a missing (force deleted) elements in the scene
|
|
28
|
+
snapshot.elements,
|
|
29
|
+
// we don't want to apply the `version` and `versionNonce` properties for history
|
|
30
|
+
// as we always need to end up with a new version due to collaboration,
|
|
31
|
+
// approaching each undo / redo as a new user action
|
|
32
|
+
{
|
|
33
|
+
excludedProperties: new Set(["version", "versionNonce"]),
|
|
34
|
+
},
|
|
35
|
+
);
|
|
36
|
+
|
|
37
|
+
const [nextAppState, appStateContainsVisibleChange] = this.appState.applyTo(
|
|
38
|
+
appState,
|
|
39
|
+
nextElements,
|
|
40
|
+
);
|
|
41
|
+
|
|
42
|
+
const appliedVisibleChanges =
|
|
43
|
+
elementsContainVisibleChange || appStateContainsVisibleChange;
|
|
44
|
+
|
|
45
|
+
return [nextElements, nextAppState, appliedVisibleChanges];
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* Overriding once to avoid type casting everywhere.
|
|
50
|
+
*/
|
|
51
|
+
public static override calculate(
|
|
52
|
+
prevSnapshot: StoreSnapshot,
|
|
53
|
+
nextSnapshot: StoreSnapshot,
|
|
54
|
+
) {
|
|
55
|
+
return super.calculate(prevSnapshot, nextSnapshot) as HistoryDelta;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Overriding once to avoid type casting everywhere.
|
|
60
|
+
*/
|
|
61
|
+
public static override inverse(delta: StoreDelta): HistoryDelta {
|
|
62
|
+
return super.inverse(delta) as HistoryDelta;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* Overriding once to avoid type casting everywhere.
|
|
67
|
+
*/
|
|
68
|
+
public static override applyLatestChanges(
|
|
69
|
+
delta: StoreDelta,
|
|
70
|
+
prevElements: SceneElementsMap,
|
|
71
|
+
nextElements: SceneElementsMap,
|
|
72
|
+
modifierOptions?: "deleted" | "inserted",
|
|
73
|
+
) {
|
|
74
|
+
return super.applyLatestChanges(
|
|
75
|
+
delta,
|
|
76
|
+
prevElements,
|
|
77
|
+
nextElements,
|
|
78
|
+
modifierOptions,
|
|
79
|
+
) as HistoryDelta;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
10
82
|
|
|
11
83
|
export class HistoryChangedEvent {
|
|
12
84
|
constructor(
|
|
@@ -20,8 +92,8 @@ export class History {
|
|
|
20
92
|
[HistoryChangedEvent]
|
|
21
93
|
>();
|
|
22
94
|
|
|
23
|
-
|
|
24
|
-
|
|
95
|
+
public readonly undoStack: HistoryDelta[] = [];
|
|
96
|
+
public readonly redoStack: HistoryDelta[] = [];
|
|
25
97
|
|
|
26
98
|
public get isUndoStackEmpty() {
|
|
27
99
|
return this.undoStack.length === 0;
|
|
@@ -31,98 +103,119 @@ export class History {
|
|
|
31
103
|
return this.redoStack.length === 0;
|
|
32
104
|
}
|
|
33
105
|
|
|
106
|
+
constructor(private readonly store: Store) {}
|
|
107
|
+
|
|
34
108
|
public clear() {
|
|
35
109
|
this.undoStack.length = 0;
|
|
36
110
|
this.redoStack.length = 0;
|
|
37
111
|
}
|
|
38
112
|
|
|
39
113
|
/**
|
|
40
|
-
* Record a local
|
|
114
|
+
* Record a non-empty local durable increment, which will go into the undo stack..
|
|
115
|
+
* Do not re-record history entries, which were already pushed to undo / redo stack, as part of history action.
|
|
41
116
|
*/
|
|
42
|
-
public record(
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
const entry = HistoryEntry.create(appStateChange, elementsChange);
|
|
117
|
+
public record(delta: StoreDelta) {
|
|
118
|
+
if (delta.isEmpty() || delta instanceof HistoryDelta) {
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
47
121
|
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
this.undoStack.push(entry.inverse());
|
|
122
|
+
// construct history entry, so once it's emitted, it's not recorded again
|
|
123
|
+
const historyDelta = HistoryDelta.inverse(delta);
|
|
51
124
|
|
|
52
|
-
|
|
53
|
-
// don't reset redo stack on local appState changes,
|
|
54
|
-
// as a simple click (unselect) could lead to losing all the redo entries
|
|
55
|
-
// only reset on non empty elements changes!
|
|
56
|
-
this.redoStack.length = 0;
|
|
57
|
-
}
|
|
125
|
+
this.undoStack.push(historyDelta);
|
|
58
126
|
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
)
|
|
127
|
+
if (!historyDelta.elements.isEmpty()) {
|
|
128
|
+
// don't reset redo stack on local appState changes,
|
|
129
|
+
// as a simple click (unselect) could lead to losing all the redo entries
|
|
130
|
+
// only reset on non empty elements changes!
|
|
131
|
+
this.redoStack.length = 0;
|
|
62
132
|
}
|
|
133
|
+
|
|
134
|
+
this.onHistoryChangedEmitter.trigger(
|
|
135
|
+
new HistoryChangedEvent(this.isUndoStackEmpty, this.isRedoStackEmpty),
|
|
136
|
+
);
|
|
63
137
|
}
|
|
64
138
|
|
|
65
|
-
public undo(
|
|
66
|
-
elements: SceneElementsMap,
|
|
67
|
-
appState: AppState,
|
|
68
|
-
snapshot: Readonly<Snapshot>,
|
|
69
|
-
) {
|
|
139
|
+
public undo(elements: SceneElementsMap, appState: AppState) {
|
|
70
140
|
return this.perform(
|
|
71
141
|
elements,
|
|
72
142
|
appState,
|
|
73
|
-
snapshot,
|
|
74
143
|
() => History.pop(this.undoStack),
|
|
75
|
-
(entry:
|
|
144
|
+
(entry: HistoryDelta) => History.push(this.redoStack, entry),
|
|
76
145
|
);
|
|
77
146
|
}
|
|
78
147
|
|
|
79
|
-
public redo(
|
|
80
|
-
elements: SceneElementsMap,
|
|
81
|
-
appState: AppState,
|
|
82
|
-
snapshot: Readonly<Snapshot>,
|
|
83
|
-
) {
|
|
148
|
+
public redo(elements: SceneElementsMap, appState: AppState) {
|
|
84
149
|
return this.perform(
|
|
85
150
|
elements,
|
|
86
151
|
appState,
|
|
87
|
-
snapshot,
|
|
88
152
|
() => History.pop(this.redoStack),
|
|
89
|
-
(entry:
|
|
153
|
+
(entry: HistoryDelta) => History.push(this.undoStack, entry),
|
|
90
154
|
);
|
|
91
155
|
}
|
|
92
156
|
|
|
93
157
|
private perform(
|
|
94
158
|
elements: SceneElementsMap,
|
|
95
159
|
appState: AppState,
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
push: (entry: HistoryEntry) => void,
|
|
160
|
+
pop: () => HistoryDelta | null,
|
|
161
|
+
push: (entry: HistoryDelta) => void,
|
|
99
162
|
): [SceneElementsMap, AppState] | void {
|
|
100
163
|
try {
|
|
101
|
-
let
|
|
164
|
+
let historyDelta = pop();
|
|
102
165
|
|
|
103
|
-
if (
|
|
166
|
+
if (historyDelta === null) {
|
|
104
167
|
return;
|
|
105
168
|
}
|
|
106
169
|
|
|
170
|
+
const action = CaptureUpdateAction.IMMEDIATELY;
|
|
171
|
+
|
|
172
|
+
let prevSnapshot = this.store.snapshot;
|
|
173
|
+
|
|
107
174
|
let nextElements = elements;
|
|
108
175
|
let nextAppState = appState;
|
|
109
176
|
let containsVisibleChange = false;
|
|
110
177
|
|
|
111
178
|
// iterate through the history entries in case they result in no visible changes
|
|
112
|
-
while (
|
|
179
|
+
while (historyDelta) {
|
|
113
180
|
try {
|
|
114
181
|
[nextElements, nextAppState, containsVisibleChange] =
|
|
115
|
-
|
|
182
|
+
historyDelta.applyTo(nextElements, nextAppState, prevSnapshot);
|
|
183
|
+
|
|
184
|
+
const prevElements = prevSnapshot.elements;
|
|
185
|
+
const nextSnapshot = prevSnapshot.maybeClone(
|
|
186
|
+
action,
|
|
187
|
+
nextElements,
|
|
188
|
+
nextAppState,
|
|
189
|
+
);
|
|
190
|
+
|
|
191
|
+
const change = StoreChange.create(prevSnapshot, nextSnapshot);
|
|
192
|
+
const delta = HistoryDelta.applyLatestChanges(
|
|
193
|
+
historyDelta,
|
|
194
|
+
prevElements,
|
|
195
|
+
nextElements,
|
|
196
|
+
);
|
|
197
|
+
|
|
198
|
+
if (!delta.isEmpty()) {
|
|
199
|
+
// schedule immediate capture, so that it's emitted for the sync purposes
|
|
200
|
+
this.store.scheduleMicroAction({
|
|
201
|
+
action,
|
|
202
|
+
change,
|
|
203
|
+
delta,
|
|
204
|
+
});
|
|
205
|
+
|
|
206
|
+
historyDelta = delta;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
prevSnapshot = nextSnapshot;
|
|
116
210
|
} finally {
|
|
117
|
-
|
|
118
|
-
push(historyEntry);
|
|
211
|
+
push(historyDelta);
|
|
119
212
|
}
|
|
120
213
|
|
|
121
214
|
if (containsVisibleChange) {
|
|
122
215
|
break;
|
|
123
216
|
}
|
|
124
217
|
|
|
125
|
-
|
|
218
|
+
historyDelta = pop();
|
|
126
219
|
}
|
|
127
220
|
|
|
128
221
|
return [nextElements, nextAppState];
|
|
@@ -135,7 +228,7 @@ export class History {
|
|
|
135
228
|
}
|
|
136
229
|
}
|
|
137
230
|
|
|
138
|
-
private static pop(stack:
|
|
231
|
+
private static pop(stack: HistoryDelta[]): HistoryDelta | null {
|
|
139
232
|
if (!stack.length) {
|
|
140
233
|
return null;
|
|
141
234
|
}
|
|
@@ -149,64 +242,8 @@ export class History {
|
|
|
149
242
|
return null;
|
|
150
243
|
}
|
|
151
244
|
|
|
152
|
-
private static push(
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
prevElements: SceneElementsMap,
|
|
156
|
-
) {
|
|
157
|
-
const updatedEntry = entry.inverse().applyLatestChanges(prevElements);
|
|
158
|
-
return stack.push(updatedEntry);
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
export class HistoryEntry {
|
|
163
|
-
private constructor(
|
|
164
|
-
public readonly appStateChange: AppStateChange,
|
|
165
|
-
public readonly elementsChange: ElementsChange,
|
|
166
|
-
) {}
|
|
167
|
-
|
|
168
|
-
public static create(
|
|
169
|
-
appStateChange: AppStateChange,
|
|
170
|
-
elementsChange: ElementsChange,
|
|
171
|
-
) {
|
|
172
|
-
return new HistoryEntry(appStateChange, elementsChange);
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
public inverse(): HistoryEntry {
|
|
176
|
-
return new HistoryEntry(
|
|
177
|
-
this.appStateChange.inverse(),
|
|
178
|
-
this.elementsChange.inverse(),
|
|
179
|
-
);
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
public applyTo(
|
|
183
|
-
elements: SceneElementsMap,
|
|
184
|
-
appState: AppState,
|
|
185
|
-
snapshot: Readonly<Snapshot>,
|
|
186
|
-
): [SceneElementsMap, AppState, boolean] {
|
|
187
|
-
const [nextElements, elementsContainVisibleChange] =
|
|
188
|
-
this.elementsChange.applyTo(elements, snapshot.elements);
|
|
189
|
-
|
|
190
|
-
const [nextAppState, appStateContainsVisibleChange] =
|
|
191
|
-
this.appStateChange.applyTo(appState, nextElements);
|
|
192
|
-
|
|
193
|
-
const appliedVisibleChanges =
|
|
194
|
-
elementsContainVisibleChange || appStateContainsVisibleChange;
|
|
195
|
-
|
|
196
|
-
return [nextElements, nextAppState, appliedVisibleChanges];
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
/**
|
|
200
|
-
* Apply latest (remote) changes to the history entry, creates new instance of `HistoryEntry`.
|
|
201
|
-
*/
|
|
202
|
-
public applyLatestChanges(elements: SceneElementsMap): HistoryEntry {
|
|
203
|
-
const updatedElementsChange =
|
|
204
|
-
this.elementsChange.applyLatestChanges(elements);
|
|
205
|
-
|
|
206
|
-
return HistoryEntry.create(this.appStateChange, updatedElementsChange);
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
public isEmpty(): boolean {
|
|
210
|
-
return this.appStateChange.isEmpty() && this.elementsChange.isEmpty();
|
|
245
|
+
private static push(stack: HistoryDelta[], entry: HistoryDelta) {
|
|
246
|
+
const inversedEntry = HistoryDelta.inverse(entry);
|
|
247
|
+
return stack.push(inversedEntry);
|
|
211
248
|
}
|
|
212
249
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@excalidraw/excalidraw",
|
|
3
|
-
"version": "0.18.0-
|
|
3
|
+
"version": "0.18.0-7b8a5f54c",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"types": "./dist/types/excalidraw/index.d.ts",
|
|
6
6
|
"main": "./dist/prod/index.js",
|
|
@@ -66,12 +66,22 @@
|
|
|
66
66
|
"last 1 safari version"
|
|
67
67
|
]
|
|
68
68
|
},
|
|
69
|
+
"repository": "https://github.com/excalidraw/excalidraw",
|
|
70
|
+
"bugs": "https://github.com/excalidraw/excalidraw/issues",
|
|
71
|
+
"homepage": "https://github.com/excalidraw/excalidraw/tree/master/packages/excalidraw",
|
|
72
|
+
"scripts": {
|
|
73
|
+
"gen:types": "rimraf types && tsc",
|
|
74
|
+
"build:esm": "rimraf dist && node ../../scripts/buildPackage.js && yarn gen:types"
|
|
75
|
+
},
|
|
69
76
|
"peerDependencies": {
|
|
70
77
|
"react": "^17.0.2 || ^18.2.0 || ^19.0.0",
|
|
71
78
|
"react-dom": "^17.0.2 || ^18.2.0 || ^19.0.0"
|
|
72
79
|
},
|
|
73
80
|
"dependencies": {
|
|
74
81
|
"@braintree/sanitize-url": "6.0.2",
|
|
82
|
+
"@excalidraw/common": "0.18.0-7b8a5f54c",
|
|
83
|
+
"@excalidraw/element": "0.18.0-7b8a5f54c",
|
|
84
|
+
"@excalidraw/math": "0.18.0-7b8a5f54c",
|
|
75
85
|
"@excalidraw/laser-pointer": "1.3.1",
|
|
76
86
|
"@excalidraw/mermaid-to-excalidraw": "1.1.2",
|
|
77
87
|
"@excalidraw/random-username": "1.1.0",
|
|
@@ -124,12 +134,5 @@
|
|
|
124
134
|
"harfbuzzjs": "0.3.6",
|
|
125
135
|
"jest-diff": "29.7.0",
|
|
126
136
|
"typescript": "4.9.4"
|
|
127
|
-
},
|
|
128
|
-
"repository": "https://github.com/excalidraw/excalidraw",
|
|
129
|
-
"bugs": "https://github.com/excalidraw/excalidraw/issues",
|
|
130
|
-
"homepage": "https://github.com/excalidraw/excalidraw/tree/master/packages/excalidraw",
|
|
131
|
-
"scripts": {
|
|
132
|
-
"gen:types": "rm -rf types && tsc",
|
|
133
|
-
"build:esm": "rm -rf dist && node ../../scripts/buildPackage.js && yarn gen:types"
|
|
134
137
|
}
|
|
135
|
-
}
|
|
138
|
+
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
// <define:import.meta.env>
|
|
2
|
-
var define_import_meta_env_default = { VITE_APP_BACKEND_V2_GET_URL: "https://json-dev.excalidraw.com/api/v2/", VITE_APP_BACKEND_V2_POST_URL: "https://json-dev.excalidraw.com/api/v2/post/", VITE_APP_LIBRARY_URL: "https://libraries.excalidraw.com", VITE_APP_LIBRARY_BACKEND: "https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries", VITE_APP_WS_SERVER_URL: "http://localhost:3002", VITE_APP_PLUS_LP: "https://plus.excalidraw.com", VITE_APP_PLUS_APP: "http://localhost:3000", VITE_APP_AI_BACKEND: "http://localhost:3015", VITE_APP_FIREBASE_CONFIG: '{"apiKey":"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8","authDomain":"excalidraw-oss-dev.firebaseapp.com","projectId":"excalidraw-oss-dev","storageBucket":"excalidraw-oss-dev.appspot.com","messagingSenderId":"664559512677","appId":"1:664559512677:web:a385181f2928d328a7aa8c"}', VITE_APP_DEV_DISABLE_LIVE_RELOAD: "", VITE_APP_ENABLE_TRACKING: "true", FAST_REFRESH: "false", VITE_APP_PORT: "3000", VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX: "", VITE_APP_COLLAPSE_OVERLAY: "true", VITE_APP_ENABLE_ESLINT: "true", VITE_APP_ENABLE_PWA: "false", VITE_APP_PLUS_EXPORT_PUBLIC_KEY: "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\nHQIDAQAB", VITE_APP_DISABLE_PREVENT_UNLOAD: "", PKG_NAME: "@excalidraw/excalidraw", PKG_VERSION: "0.18.0-6fc8502", DEV: true };
|
|
3
|
-
|
|
4
|
-
export {
|
|
5
|
-
define_import_meta_env_default
|
|
6
|
-
};
|
|
7
|
-
//# sourceMappingURL=chunk-H7XJ5UVD.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["<define:import.meta.env>"],
|
|
4
|
-
"sourcesContent": [""],
|
|
5
|
-
"mappings": ";AAAA,uCAAC,6BAA8B,2CAA0C,8BAA+B,gDAA+C,sBAAuB,oCAAmC,0BAA2B,gFAA+E,wBAAyB,yBAAwB,kBAAmB,+BAA8B,mBAAoB,yBAAwB,qBAAsB,yBAAwB,0BAA2B,mRAA0S,kCAAmC,IAAG,0BAA2B,QAAO,cAAe,SAAQ,eAAgB,QAAO,mDAAoD,IAAG,2BAA4B,QAAO,wBAAyB,QAAO,qBAAsB,SAAQ,iCAAkC,wZAAuZ,iCAAkC,IAAG,UAAW,0BAAyB,aAAc,kBAAiB,KAAM,KAAI;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|