@myoc/excalidraw 0.18.16 → 0.18.18

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.
Files changed (179) hide show
  1. package/dist/dev/{chunk-3HLOFB5F.js → chunk-MAGRVBVM.js} +13453 -10629
  2. package/dist/dev/chunk-MAGRVBVM.js.map +7 -0
  3. package/dist/dev/{chunk-PEI7EPYO.js → chunk-QO4EFL6B.js} +15 -5
  4. package/dist/dev/chunk-QO4EFL6B.js.map +7 -0
  5. package/dist/dev/chunk-WUH7JFG4.js +7 -0
  6. package/dist/dev/chunk-WUH7JFG4.js.map +7 -0
  7. package/dist/dev/data/{image-XPEIZ6XQ.js → image-BBHDGXQ3.js} +3 -3
  8. package/dist/dev/index.css +101 -24
  9. package/dist/dev/index.css.map +3 -3
  10. package/dist/dev/index.js +6587 -7610
  11. package/dist/dev/index.js.map +4 -4
  12. package/dist/dev/locales/{en-R455UJTM.js → en-2WXBKZE2.js} +2 -2
  13. package/dist/dev/subset-shared.chunk.js +1 -1
  14. package/dist/dev/subset-worker.chunk.js +1 -1
  15. package/dist/prod/chunk-4Z2WWUCC.js +7 -0
  16. package/dist/prod/chunk-KZXLT4YB.js +12 -0
  17. package/dist/prod/chunk-YBT3HBS6.js +33 -0
  18. package/dist/prod/data/image-JFILZTP3.js +1 -0
  19. package/dist/prod/index.css +1 -1
  20. package/dist/prod/index.js +18 -17
  21. package/dist/prod/locales/{en-YWERZJD6.js → en-XFR6MADM.js} +1 -1
  22. package/dist/prod/subset-shared.chunk.js +1 -1
  23. package/dist/prod/subset-worker.chunk.js +1 -1
  24. package/dist/types/common/src/constants.d.ts +19 -2
  25. package/dist/types/{excalidraw → common/src}/emitter.d.ts +1 -1
  26. package/dist/types/common/src/font-metadata.d.ts +4 -2
  27. package/dist/types/common/src/index.d.ts +1 -0
  28. package/dist/types/common/src/points.d.ts +1 -1
  29. package/dist/types/common/src/utility-types.d.ts +5 -0
  30. package/dist/types/common/src/utils.d.ts +17 -7
  31. package/dist/types/{excalidraw/scene → element/src}/Scene.d.ts +11 -14
  32. package/dist/types/element/src/align.d.ts +3 -3
  33. package/dist/types/element/src/arrange.d.ts +2 -1
  34. package/dist/types/element/src/binding.d.ts +21 -14
  35. package/dist/types/element/src/bounds.d.ts +11 -5
  36. package/dist/types/element/src/collision.d.ts +18 -12
  37. package/dist/types/element/src/cropElement.d.ts +1 -1
  38. package/dist/types/{excalidraw/change.d.ts → element/src/delta.d.ts} +63 -38
  39. package/dist/types/element/src/distance.d.ts +2 -2
  40. package/dist/types/element/src/dragElements.d.ts +3 -2
  41. package/dist/types/element/src/elbowArrow.d.ts +2 -2
  42. package/dist/types/element/src/flowchart.d.ts +3 -2
  43. package/dist/types/element/src/fractionalIndex.d.ts +9 -3
  44. package/dist/types/element/src/frame.d.ts +4 -3
  45. package/dist/types/element/src/heading.d.ts +2 -2
  46. package/dist/types/element/src/index.d.ts +43 -2
  47. package/dist/types/element/src/linearElementEditor.d.ts +21 -32
  48. package/dist/types/element/src/mutateElement.d.ts +11 -3
  49. package/dist/types/element/src/newElement.d.ts +4 -3
  50. package/dist/types/element/src/resizeElements.d.ts +5 -4
  51. package/dist/types/element/src/resizeTest.d.ts +2 -2
  52. package/dist/types/element/src/selection.d.ts +1 -6
  53. package/dist/types/element/src/shape.d.ts +42 -0
  54. package/dist/types/element/src/shapes.d.ts +10 -10
  55. package/dist/types/element/src/sizeHelpers.d.ts +2 -2
  56. package/dist/types/element/src/store.d.ts +231 -0
  57. package/dist/types/element/src/textElement.d.ts +4 -3
  58. package/dist/types/element/src/typeChecks.d.ts +19 -1
  59. package/dist/types/element/src/types.d.ts +15 -2
  60. package/dist/types/element/src/utils.d.ts +5 -1
  61. package/dist/types/element/src/zindex.d.ts +1 -1
  62. package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +42 -51
  63. package/dist/types/excalidraw/actions/actionAlign.d.ts +8 -8
  64. package/dist/types/excalidraw/actions/actionArrange.d.ts +2 -2
  65. package/dist/types/excalidraw/actions/actionBoundText.d.ts +28 -34
  66. package/dist/types/excalidraw/actions/actionCanvas.d.ts +187 -223
  67. package/dist/types/excalidraw/actions/actionClipboard.d.ts +87 -104
  68. package/dist/types/excalidraw/actions/actionCropEditor.d.ts +14 -17
  69. package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +41 -49
  70. package/dist/types/excalidraw/actions/actionDistribute.d.ts +4 -4
  71. package/dist/types/excalidraw/actions/actionDuplicateSelection.d.ts +2 -2
  72. package/dist/types/excalidraw/actions/actionElementLink.d.ts +14 -17
  73. package/dist/types/excalidraw/actions/actionElementLock.d.ts +43 -50
  74. package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +14 -17
  75. package/dist/types/excalidraw/actions/actionExport.d.ts +219 -246
  76. package/dist/types/excalidraw/actions/actionFinalize.d.ts +74 -40
  77. package/dist/types/excalidraw/actions/actionFlip.d.ts +4 -4
  78. package/dist/types/excalidraw/actions/actionFrame.d.ts +100 -112
  79. package/dist/types/excalidraw/actions/actionGroup.d.ts +34 -40
  80. package/dist/types/excalidraw/actions/actionHistory.d.ts +1 -2
  81. package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +506 -16
  82. package/dist/types/excalidraw/actions/actionLink.d.ts +14 -17
  83. package/dist/types/excalidraw/actions/actionMenu.d.ts +42 -51
  84. package/dist/types/excalidraw/actions/actionNavigate.d.ts +27 -33
  85. package/dist/types/excalidraw/actions/actionProperties.d.ts +206 -243
  86. package/dist/types/excalidraw/actions/actionSelectAll.d.ts +16 -19
  87. package/dist/types/excalidraw/actions/actionSmartZoom.d.ts +2 -2
  88. package/dist/types/excalidraw/actions/actionStyles.d.ts +18 -21
  89. package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +16 -19
  90. package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +16 -19
  91. package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +16 -200
  92. package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +19 -0
  93. package/dist/types/excalidraw/actions/actionToggleStats.d.ts +16 -19
  94. package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +16 -19
  95. package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +16 -19
  96. package/dist/types/excalidraw/actions/actionZindex.d.ts +8 -8
  97. package/dist/types/excalidraw/actions/types.d.ts +4 -3
  98. package/dist/types/excalidraw/appState.d.ts +40 -31
  99. package/dist/types/excalidraw/components/App.d.ts +15 -17
  100. package/dist/types/excalidraw/components/ButtonIcon.d.ts +1 -0
  101. package/dist/types/excalidraw/components/ColorPicker/ColorInput.d.ts +2 -1
  102. package/dist/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +5 -1
  103. package/dist/types/excalidraw/components/ColorPicker/CustomColorList.d.ts +1 -1
  104. package/dist/types/excalidraw/components/ColorPicker/Picker.d.ts +2 -3
  105. package/dist/types/excalidraw/components/ColorPicker/PickerColorList.d.ts +2 -3
  106. package/dist/types/excalidraw/components/ColorPicker/ShadeList.d.ts +2 -2
  107. package/dist/types/excalidraw/components/ColorPicker/TopPicks.d.ts +1 -1
  108. package/dist/types/excalidraw/components/ColorPicker/colorPickerUtils.d.ts +1 -1
  109. package/dist/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +1 -1
  110. package/dist/types/excalidraw/components/ConvertElementTypePopup.d.ts +23 -0
  111. package/dist/types/excalidraw/components/ElementLinkDialog.d.ts +4 -3
  112. package/dist/types/excalidraw/components/{ButtonIconSelect.d.ts → RadioSelection.d.ts} +1 -1
  113. package/dist/types/excalidraw/components/Range.d.ts +3 -3
  114. package/dist/types/excalidraw/components/Stats/Angle.d.ts +1 -1
  115. package/dist/types/excalidraw/components/Stats/CanvasGrid.d.ts +1 -1
  116. package/dist/types/excalidraw/components/Stats/Collapsible.d.ts +2 -1
  117. package/dist/types/excalidraw/components/Stats/Dimension.d.ts +1 -1
  118. package/dist/types/excalidraw/components/Stats/DragInput.d.ts +1 -1
  119. package/dist/types/excalidraw/components/Stats/FontSize.d.ts +1 -1
  120. package/dist/types/excalidraw/components/Stats/MultiAngle.d.ts +1 -1
  121. package/dist/types/excalidraw/components/Stats/MultiDimension.d.ts +1 -1
  122. package/dist/types/excalidraw/components/Stats/MultiFontSize.d.ts +1 -1
  123. package/dist/types/excalidraw/components/Stats/MultiPosition.d.ts +1 -1
  124. package/dist/types/excalidraw/components/Stats/Position.d.ts +1 -1
  125. package/dist/types/excalidraw/components/Stats/utils.d.ts +4 -11
  126. package/dist/types/excalidraw/components/UnlockPopup.d.ts +8 -0
  127. package/dist/types/excalidraw/components/dropdownMenu/common.d.ts +1 -1
  128. package/dist/types/excalidraw/components/hyperlink/Hyperlink.d.ts +3 -2
  129. package/dist/types/excalidraw/components/hyperlink/helpers.d.ts +2 -1
  130. package/dist/types/excalidraw/components/icons.d.ts +3 -0
  131. package/dist/types/excalidraw/components/shapes.d.ts +1 -1
  132. package/dist/types/excalidraw/data/blob.d.ts +1 -1
  133. package/dist/types/excalidraw/data/transform.d.ts +1 -1
  134. package/dist/types/excalidraw/editor-jotai.d.ts +6 -6
  135. package/dist/types/excalidraw/eraser/index.d.ts +0 -2
  136. package/dist/types/excalidraw/fonts/Fonts.d.ts +1 -1
  137. package/dist/types/excalidraw/history.d.ts +30 -22
  138. package/dist/types/excalidraw/hooks/useEmitter.d.ts +1 -1
  139. package/dist/types/excalidraw/index.d.ts +9 -9
  140. package/dist/types/excalidraw/lasso/index.d.ts +1 -0
  141. package/dist/types/excalidraw/lasso/utils.d.ts +2 -1
  142. package/dist/types/excalidraw/renderer/helpers.d.ts +7 -2
  143. package/dist/types/excalidraw/scene/Renderer.d.ts +1 -2
  144. package/dist/types/excalidraw/scene/index.d.ts +2 -2
  145. package/dist/types/excalidraw/snapping.d.ts +2 -2
  146. package/dist/types/excalidraw/types.d.ts +25 -10
  147. package/dist/types/excalidraw/visualdebug.d.ts +1 -1
  148. package/dist/types/excalidraw/wysiwyg/textWysiwyg.d.ts +3 -1
  149. package/dist/types/math/src/angle.d.ts +3 -1
  150. package/dist/types/math/src/constants.d.ts +3 -0
  151. package/dist/types/math/src/curve.d.ts +34 -0
  152. package/dist/types/math/src/ellipse.d.ts +3 -3
  153. package/dist/types/math/src/index.d.ts +1 -0
  154. package/dist/types/math/src/point.d.ts +3 -3
  155. package/dist/types/math/src/polygon.d.ts +2 -2
  156. package/dist/types/math/src/segment.d.ts +5 -5
  157. package/dist/types/math/src/utils.d.ts +2 -0
  158. package/dist/types/math/src/vector.d.ts +8 -2
  159. package/dist/types/utils/src/bbox.d.ts +1 -1
  160. package/dist/types/utils/src/index.d.ts +1 -1
  161. package/dist/types/utils/src/shape.d.ts +12 -12
  162. package/dist/types/utils/src/withinBounds.d.ts +1 -1
  163. package/history.ts +147 -110
  164. package/package.json +4 -4
  165. package/dist/dev/chunk-3HLOFB5F.js.map +0 -7
  166. package/dist/dev/chunk-PEI7EPYO.js.map +0 -7
  167. package/dist/dev/chunk-QQGTICP4.js +0 -7
  168. package/dist/dev/chunk-QQGTICP4.js.map +0 -7
  169. package/dist/prod/chunk-7HNFGNL7.js +0 -7
  170. package/dist/prod/chunk-KKQVTSHB.js +0 -33
  171. package/dist/prod/chunk-KZWZ7WHC.js +0 -12
  172. package/dist/prod/data/image-QD7FUQED.js +0 -1
  173. package/dist/types/element/src/Shape.d.ts +0 -17
  174. package/dist/types/element/src/ShapeCache.d.ts +0 -25
  175. package/dist/types/excalidraw/components/ButtonSelect.d.ts +0 -9
  176. package/dist/types/excalidraw/store.d.ts +0 -129
  177. package/dist/types/utils/src/collision.d.ts +0 -8
  178. /package/dist/dev/data/{image-XPEIZ6XQ.js.map → image-BBHDGXQ3.js.map} +0 -0
  179. /package/dist/dev/locales/{en-R455UJTM.js.map → en-2WXBKZE2.js.map} +0 -0
@@ -0,0 +1,231 @@
1
+ import { Emitter } from "@excalidraw/common";
2
+ import type App from "@excalidraw/excalidraw/components/App";
3
+ import type { DTO, ValueOf } from "@excalidraw/common/utility-types";
4
+ import type { AppState, ObservedAppState } from "@excalidraw/excalidraw/types";
5
+ import { ElementsDelta, AppStateDelta } from "./delta";
6
+ import type { ExcalidrawElement, OrderedExcalidrawElement, SceneElementsMap } from "./types";
7
+ export declare const CaptureUpdateAction: {
8
+ /**
9
+ * Immediately undoable.
10
+ *
11
+ * Use for updates which should be captured.
12
+ * Should be used for most of the local updates, except ephemerals such as dragging or resizing.
13
+ *
14
+ * These updates will _immediately_ make it to the local undo / redo stacks.
15
+ */
16
+ readonly IMMEDIATELY: "IMMEDIATELY";
17
+ /**
18
+ * Never undoable.
19
+ *
20
+ * Use for updates which should never be recorded, such as remote updates
21
+ * or scene initialization.
22
+ *
23
+ * These updates will _never_ make it to the local undo / redo stacks.
24
+ */
25
+ readonly NEVER: "NEVER";
26
+ /**
27
+ * Eventually undoable.
28
+ *
29
+ * Use for updates which should not be captured immediately - likely
30
+ * exceptions which are part of some async multi-step process. Otherwise, all
31
+ * such updates would end up being captured with the next
32
+ * `CaptureUpdateAction.IMMEDIATELY` - triggered either by the next `updateScene`
33
+ * or internally by the editor.
34
+ *
35
+ * These updates will _eventually_ make it to the local undo / redo stacks.
36
+ */
37
+ readonly EVENTUALLY: "EVENTUALLY";
38
+ };
39
+ export type CaptureUpdateActionType = ValueOf<typeof CaptureUpdateAction>;
40
+ /**
41
+ * Store which captures the observed changes and emits them as `StoreIncrement` events.
42
+ */
43
+ export declare class Store {
44
+ private readonly app;
45
+ readonly onDurableIncrementEmitter: Emitter<[DurableIncrement]>;
46
+ readonly onStoreIncrementEmitter: Emitter<[DurableIncrement | EphemeralIncrement]>;
47
+ private scheduledMacroActions;
48
+ private scheduledMicroActions;
49
+ private _snapshot;
50
+ get snapshot(): StoreSnapshot;
51
+ set snapshot(snapshot: StoreSnapshot);
52
+ constructor(app: App);
53
+ scheduleAction(action: CaptureUpdateActionType): void;
54
+ /**
55
+ * Use to schedule a delta calculation, which will consquentially be emitted as `DurableStoreIncrement` and pushed in the undo stack.
56
+ */
57
+ scheduleCapture(): void;
58
+ /**
59
+ * Schedule special "micro" actions, to-be executed before the next commit, before it executes a scheduled "macro" action.
60
+ */
61
+ scheduleMicroAction(params: {
62
+ action: CaptureUpdateActionType;
63
+ elements: readonly ExcalidrawElement[] | undefined;
64
+ appState: AppState | ObservedAppState | undefined;
65
+ } | {
66
+ action: typeof CaptureUpdateAction.IMMEDIATELY;
67
+ change: StoreChange;
68
+ delta: StoreDelta;
69
+ } | {
70
+ action: typeof CaptureUpdateAction.NEVER | typeof CaptureUpdateAction.EVENTUALLY;
71
+ change: StoreChange;
72
+ }): void;
73
+ /**
74
+ * Performs the incoming `CaptureUpdateAction` and emits the corresponding `StoreIncrement`.
75
+ * Emits `DurableStoreIncrement` when action is "capture", emits `EphemeralStoreIncrement` otherwise.
76
+ *
77
+ * @emits StoreIncrement
78
+ */
79
+ commit(elements: SceneElementsMap | undefined, appState: AppState | ObservedAppState | undefined): void;
80
+ /**
81
+ * Clears the store instance.
82
+ */
83
+ clear(): void;
84
+ /**
85
+ * Performs delta & change calculation and emits a durable increment.
86
+ *
87
+ * @emits StoreIncrement.
88
+ */
89
+ private emitDurableIncrement;
90
+ /**
91
+ * Performs change calculation and emits an ephemeral increment.
92
+ *
93
+ * @emits EphemeralStoreIncrement
94
+ */
95
+ private emitEphemeralIncrement;
96
+ private applyChangeToSnapshot;
97
+ /**
98
+ * Clones the snapshot if there are changes detected.
99
+ */
100
+ private maybeCloneSnapshot;
101
+ private flushMicroActions;
102
+ private processAction;
103
+ /**
104
+ * Returns the scheduled macro action.
105
+ */
106
+ private getScheduledMacroAction;
107
+ /**
108
+ * Ensures that the scheduled actions invariant is satisfied.
109
+ */
110
+ private satisfiesScheduledActionsInvariant;
111
+ }
112
+ /**
113
+ * Repsents a change to the store containing changed elements and appState.
114
+ */
115
+ export declare class StoreChange {
116
+ readonly elements: Record<string, OrderedExcalidrawElement>;
117
+ readonly appState: Partial<ObservedAppState>;
118
+ private constructor();
119
+ static create(prevSnapshot: StoreSnapshot, nextSnapshot: StoreSnapshot): StoreChange;
120
+ }
121
+ /**
122
+ * Encpasulates any change to the store (durable or ephemeral).
123
+ */
124
+ export declare abstract class StoreIncrement {
125
+ readonly type: "durable" | "ephemeral";
126
+ readonly change: StoreChange;
127
+ protected constructor(type: "durable" | "ephemeral", change: StoreChange);
128
+ static isDurable(increment: StoreIncrement): increment is DurableIncrement;
129
+ static isEphemeral(increment: StoreIncrement): increment is EphemeralIncrement;
130
+ }
131
+ /**
132
+ * Represents a durable change to the store.
133
+ */
134
+ export declare class DurableIncrement extends StoreIncrement {
135
+ readonly change: StoreChange;
136
+ readonly delta: StoreDelta;
137
+ constructor(change: StoreChange, delta: StoreDelta);
138
+ }
139
+ /**
140
+ * Represents an ephemeral change to the store.
141
+ */
142
+ export declare class EphemeralIncrement extends StoreIncrement {
143
+ readonly change: StoreChange;
144
+ constructor(change: StoreChange);
145
+ }
146
+ /**
147
+ * Represents a captured delta by the Store.
148
+ */
149
+ export declare class StoreDelta {
150
+ readonly id: string;
151
+ readonly elements: ElementsDelta;
152
+ readonly appState: AppStateDelta;
153
+ protected constructor(id: string, elements: ElementsDelta, appState: AppStateDelta);
154
+ /**
155
+ * Create a new instance of `StoreDelta`.
156
+ */
157
+ static create(elements: ElementsDelta, appState: AppStateDelta, opts?: {
158
+ id: string;
159
+ }): StoreDelta;
160
+ /**
161
+ * Calculate the delta between the previous and next snapshot.
162
+ */
163
+ static calculate(prevSnapshot: StoreSnapshot, nextSnapshot: StoreSnapshot): StoreDelta;
164
+ /**
165
+ * Restore a store delta instance from a DTO.
166
+ */
167
+ static restore(storeDeltaDTO: DTO<StoreDelta>): StoreDelta;
168
+ /**
169
+ * Parse and load the delta from the remote payload.
170
+ */
171
+ static load({ id, elements: { added, removed, updated }, }: DTO<StoreDelta>): StoreDelta;
172
+ /**
173
+ * Inverse store delta, creates new instance of `StoreDelta`.
174
+ */
175
+ static inverse(delta: StoreDelta): StoreDelta;
176
+ /**
177
+ * Apply the delta to the passed elements and appState, does not modify the snapshot.
178
+ */
179
+ static applyTo(delta: StoreDelta, elements: SceneElementsMap, appState: AppState): [SceneElementsMap, AppState, boolean];
180
+ /**
181
+ * Apply latest (remote) changes to the delta, creates new instance of `StoreDelta`.
182
+ */
183
+ static applyLatestChanges(delta: StoreDelta, prevElements: SceneElementsMap, nextElements: SceneElementsMap, modifierOptions?: "deleted" | "inserted"): StoreDelta;
184
+ isEmpty(): boolean;
185
+ }
186
+ /**
187
+ * Represents a snapshot of the captured or updated changes in the store,
188
+ * used for producing deltas and emitting `DurableStoreIncrement`s.
189
+ */
190
+ export declare class StoreSnapshot {
191
+ readonly elements: SceneElementsMap;
192
+ readonly appState: ObservedAppState;
193
+ readonly metadata: {
194
+ didElementsChange: boolean;
195
+ didAppStateChange: boolean;
196
+ isEmpty?: boolean;
197
+ };
198
+ private _lastChangedElementsHash;
199
+ private _lastChangedAppStateHash;
200
+ private constructor();
201
+ static create(elements: SceneElementsMap, appState: AppState | ObservedAppState, metadata?: {
202
+ didElementsChange: boolean;
203
+ didAppStateChange: boolean;
204
+ }): StoreSnapshot;
205
+ static empty(): StoreSnapshot;
206
+ getChangedElements(prevSnapshot: StoreSnapshot): Record<string, OrderedExcalidrawElement>;
207
+ getChangedAppState(prevSnapshot: StoreSnapshot): Partial<ObservedAppState>;
208
+ isEmpty(): boolean | undefined;
209
+ /**
210
+ * Apply the change and return a new snapshot instance.
211
+ */
212
+ applyChange(change: StoreChange): StoreSnapshot;
213
+ /**
214
+ * Efficiently clone the existing snapshot, only if we detected changes.
215
+ *
216
+ * @returns same instance if there are no changes detected, new instance otherwise.
217
+ */
218
+ maybeClone(action: CaptureUpdateActionType, elements: SceneElementsMap | undefined, appState: AppState | ObservedAppState | undefined): StoreSnapshot;
219
+ private maybeCreateAppStateSnapshot;
220
+ private maybeCreateElementsSnapshot;
221
+ private detectChangedAppState;
222
+ /**
223
+ * Detect if there any changed elements.
224
+ */
225
+ private detectChangedElements;
226
+ /**
227
+ * Perform structural clone, deep cloning only elements that changed.
228
+ */
229
+ private createElementsSnapshot;
230
+ }
231
+ export declare const getObservedAppState: (appState: AppState | ObservedAppState) => ObservedAppState;
@@ -1,10 +1,11 @@
1
1
  import type { AppState } from "@excalidraw/excalidraw/types";
2
2
  import type { ExtractSetType } from "@excalidraw/common/utility-types";
3
- import type { Radians } from "../../math/src";
3
+ import type { Radians } from "@excalidraw/math";
4
+ import type { Scene } from "./Scene";
4
5
  import type { MaybeTransformHandleType } from "./transformHandles";
5
6
  import type { ElementsMap, ExcalidrawElement, ExcalidrawElementType, ExcalidrawTextContainer, ExcalidrawTextElement, ExcalidrawTextElementWithContainer, NonDeletedExcalidrawElement } from "./types";
6
- export declare const redrawTextBoundingBox: (textElement: ExcalidrawTextElement, container: ExcalidrawElement | null, elementsMap: ElementsMap, informMutation?: boolean) => void;
7
- export declare const handleBindTextResize: (container: NonDeletedExcalidrawElement, elementsMap: ElementsMap, transformHandleType: MaybeTransformHandleType, shouldMaintainAspectRatio?: boolean) => void;
7
+ export declare const redrawTextBoundingBox: (textElement: ExcalidrawTextElement, container: ExcalidrawElement | null, scene: Scene) => void;
8
+ export declare const handleBindTextResize: (container: NonDeletedExcalidrawElement, scene: Scene, transformHandleType: MaybeTransformHandleType, shouldMaintainAspectRatio?: boolean) => void;
8
9
  export declare const computeBoundTextPosition: (container: ExcalidrawElement, boundTextElement: ExcalidrawTextElementWithContainer, elementsMap: ElementsMap) => {
9
10
  x: number;
10
11
  y: number;
@@ -1,7 +1,7 @@
1
1
  import type { ElementOrToolType } from "@excalidraw/excalidraw/types";
2
2
  import type { MarkNonNullable } from "@excalidraw/common/utility-types";
3
3
  import type { Bounds } from "./bounds";
4
- import type { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawEmbeddableElement, ExcalidrawLinearElement, ExcalidrawBindableElement, ExcalidrawFreeDrawElement, InitializedExcalidrawImageElement, ExcalidrawImageElement, ExcalidrawTextElementWithContainer, ExcalidrawTextContainer, ExcalidrawFrameElement, RoundnessType, ExcalidrawFrameLikeElement, ExcalidrawElementType, ExcalidrawIframeElement, ExcalidrawIframeLikeElement, ExcalidrawMagicFrameElement, ExcalidrawArrowElement, ExcalidrawElbowArrowElement, PointBinding, FixedPointBinding, ExcalidrawFlowchartNodeElement } from "./types";
4
+ import type { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawEmbeddableElement, ExcalidrawLinearElement, ExcalidrawBindableElement, ExcalidrawFreeDrawElement, InitializedExcalidrawImageElement, ExcalidrawImageElement, ExcalidrawTextElementWithContainer, ExcalidrawTextContainer, ExcalidrawFrameElement, RoundnessType, ExcalidrawFrameLikeElement, ExcalidrawElementType, ExcalidrawIframeElement, ExcalidrawIframeLikeElement, ExcalidrawMagicFrameElement, ExcalidrawArrowElement, ExcalidrawElbowArrowElement, ExcalidrawLineElement, PointBinding, FixedPointBinding, ExcalidrawFlowchartNodeElement, ExcalidrawLinearElementSubType } from "./types";
5
5
  export declare const isInitializedImageElement: (element: ExcalidrawElement | null) => element is InitializedExcalidrawImageElement;
6
6
  export declare const isImageElement: (element: ExcalidrawElement | null) => element is ExcalidrawImageElement;
7
7
  export declare const isEmbeddableElement: (element: ExcalidrawElement | null | undefined) => element is ExcalidrawEmbeddableElement;
@@ -14,8 +14,15 @@ export declare const isFrameLikeElement: (element: ExcalidrawElement | null) =>
14
14
  export declare const isFreeDrawElement: (element?: ExcalidrawElement | null) => element is ExcalidrawFreeDrawElement;
15
15
  export declare const isFreeDrawElementType: (elementType: ExcalidrawElementType) => boolean;
16
16
  export declare const isLinearElement: (element?: ExcalidrawElement | null) => element is ExcalidrawLinearElement;
17
+ export declare const isLineElement: (element?: ExcalidrawElement | null) => element is ExcalidrawLineElement;
17
18
  export declare const isArrowElement: (element?: ExcalidrawElement | null) => element is ExcalidrawArrowElement;
18
19
  export declare const isElbowArrow: (element?: ExcalidrawElement) => element is ExcalidrawElbowArrowElement;
20
+ /**
21
+ * sharp or curved arrow, but not elbow
22
+ */
23
+ export declare const isSimpleArrow: (element?: ExcalidrawElement) => element is ExcalidrawArrowElement;
24
+ export declare const isSharpArrow: (element?: ExcalidrawElement) => element is ExcalidrawArrowElement;
25
+ export declare const isCurvedArrow: (element?: ExcalidrawElement) => element is ExcalidrawArrowElement;
19
26
  export declare const isLinearElementType: (elementType: ElementOrToolType) => boolean;
20
27
  export declare const isBindingElement: (element?: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawLinearElement;
21
28
  export declare const isBindingElementType: (elementType: ElementOrToolType) => boolean;
@@ -27,6 +34,7 @@ export declare const isExcalidrawElement: (element: any) => element is Excalidra
27
34
  export declare const isFlowchartNodeElement: (element: ExcalidrawElement) => element is ExcalidrawFlowchartNodeElement;
28
35
  export declare const hasBoundTextElement: (element: ExcalidrawElement | null) => element is MarkNonNullable<ExcalidrawBindableElement, "boundElements">;
29
36
  export declare const isBoundToContainer: (element: ExcalidrawElement | null) => element is ExcalidrawTextElementWithContainer;
37
+ export declare const isArrowBoundToElement: (element: ExcalidrawArrowElement) => boolean;
30
38
  export declare const isUsingAdaptiveRadius: (type: string) => boolean;
31
39
  export declare const isUsingProportionalRadius: (type: string) => boolean;
32
40
  export declare const canApplyRoundnessTypeToElement: (roundnessType: RoundnessType, element: ExcalidrawElement) => boolean;
@@ -37,3 +45,13 @@ export declare const getDefaultRoundnessTypeForElement: (element: ExcalidrawElem
37
45
  } | null;
38
46
  export declare const isFixedPointBinding: (binding: PointBinding | FixedPointBinding) => binding is FixedPointBinding;
39
47
  export declare const isBounds: (box: unknown) => box is Bounds;
48
+ export declare const getLinearElementSubType: (element: ExcalidrawLinearElement) => ExcalidrawLinearElementSubType;
49
+ /**
50
+ * Checks if current element points meet all the conditions for polygon=true
51
+ * (this isn't a element type check, for that use isLineElement).
52
+ *
53
+ * If you want to check if points *can* be turned into a polygon, use
54
+ * canBecomePolygon(points).
55
+ */
56
+ export declare const isValidPolygon: (points: ExcalidrawLineElement["points"]) => boolean;
57
+ export declare const canBecomePolygon: (points: ExcalidrawLineElement["points"]) => boolean;
@@ -151,7 +151,7 @@ export type ExcalidrawFrameLikeElement = ExcalidrawFrameElement | ExcalidrawMagi
151
151
  */
152
152
  export type ExcalidrawGenericElement = ExcalidrawSelectionElement | ExcalidrawRectangleElement | ExcalidrawDiamondElement | ExcalidrawEllipseElement;
153
153
  export type ExcalidrawFlowchartNodeElement = ExcalidrawRectangleElement | ExcalidrawDiamondElement | ExcalidrawEllipseElement;
154
- export type ExcalidrawRectanguloidElement = ExcalidrawRectangleElement | ExcalidrawImageElement | ExcalidrawTextElement | ExcalidrawFreeDrawElement | ExcalidrawIframeLikeElement | ExcalidrawFrameLikeElement | ExcalidrawEmbeddableElement;
154
+ export type ExcalidrawRectanguloidElement = ExcalidrawRectangleElement | ExcalidrawImageElement | ExcalidrawTextElement | ExcalidrawFreeDrawElement | ExcalidrawIframeLikeElement | ExcalidrawFrameLikeElement | ExcalidrawEmbeddableElement | ExcalidrawSelectionElement;
155
155
  /**
156
156
  * ExcalidrawElement should be JSON serializable and (eventually) contain
157
157
  * no computed data. The list of all ExcalidrawElements should be shareable
@@ -205,6 +205,11 @@ export type PointBinding = {
205
205
  export type FixedPointBinding = Merge<PointBinding, {
206
206
  fixedPoint: FixedPoint;
207
207
  }>;
208
+ type Index = number;
209
+ export type PointsPositionUpdates = Map<Index, {
210
+ point: LocalPoint;
211
+ isDragging?: boolean;
212
+ }>;
208
213
  export type Arrowhead = "arrow" | "bar" | "dot" | "circle" | "circle_outline" | "triangle" | "triangle_outline" | "diamond" | "diamond_outline" | "crowfoot_one" | "crowfoot_many" | "crowfoot_one_or_many";
209
214
  export type ExcalidrawLinearElement = _ExcalidrawElementBase & Readonly<{
210
215
  type: "line" | "arrow";
@@ -215,10 +220,14 @@ export type ExcalidrawLinearElement = _ExcalidrawElementBase & Readonly<{
215
220
  startArrowhead: Arrowhead | null;
216
221
  endArrowhead: Arrowhead | null;
217
222
  }>;
223
+ export type ExcalidrawLineElement = ExcalidrawLinearElement & Readonly<{
224
+ type: "line";
225
+ polygon: boolean;
226
+ }>;
218
227
  export type FixedSegment = {
219
228
  start: LocalPoint;
220
229
  end: LocalPoint;
221
- index: number;
230
+ index: Index;
222
231
  };
223
232
  export type ExcalidrawArrowElement = ExcalidrawLinearElement & Readonly<{
224
233
  type: "arrow";
@@ -280,4 +289,8 @@ export type SceneElementsMap = Map<ExcalidrawElement["id"], Ordered<ExcalidrawEl
280
289
  export type NonDeletedSceneElementsMap = Map<ExcalidrawElement["id"], Ordered<NonDeletedExcalidrawElement>> & MakeBrand<"NonDeletedSceneElementsMap">;
281
290
  export type ElementsMapOrArray = readonly ExcalidrawElement[] | Readonly<ElementsMap>;
282
291
  export type ArrangeAlgorithms = "bin-packing";
292
+ export type ExcalidrawLinearElementSubType = "line" | "sharpArrow" | "curvedArrow" | "elbowArrow";
293
+ export type ConvertibleGenericTypes = "rectangle" | "diamond" | "ellipse";
294
+ export type ConvertibleLinearTypes = ExcalidrawLinearElementSubType;
295
+ export type ConvertibleTypes = ConvertibleGenericTypes | ConvertibleLinearTypes;
283
296
  export {};
@@ -1,6 +1,8 @@
1
1
  import { type GlobalPoint } from "@excalidraw/math";
2
2
  import type { Curve, LineSegment } from "@excalidraw/math";
3
- import type { ExcalidrawDiamondElement, ExcalidrawRectanguloidElement } from "./types";
3
+ import type { Zoom } from "@excalidraw/excalidraw/types";
4
+ import type { ExcalidrawDiamondElement, ExcalidrawElement, ExcalidrawFreeDrawElement, ExcalidrawLinearElement, ExcalidrawRectanguloidElement } from "./types";
5
+ export declare function deconstructLinearOrFreeDrawElement(element: ExcalidrawLinearElement | ExcalidrawFreeDrawElement): [LineSegment<GlobalPoint>[], Curve<GlobalPoint>[]];
4
6
  /**
5
7
  * Get the building components of a rectanguloid element in the form of
6
8
  * line segments and curves.
@@ -19,3 +21,5 @@ export declare function deconstructRectanguloidElement(element: ExcalidrawRectan
19
21
  * @returns Tuple of line segments (0) and curves (1)
20
22
  */
21
23
  export declare function deconstructDiamondElement(element: ExcalidrawDiamondElement, offset?: number): [LineSegment<GlobalPoint>[], Curve<GlobalPoint>[]];
24
+ export declare const isPathALoop: (points: ExcalidrawLinearElement["points"], zoomValue?: Zoom["value"]) => boolean;
25
+ export declare const getCornerRadius: (x: number, element: ExcalidrawElement) => number;
@@ -1,5 +1,5 @@
1
1
  import type { AppState } from "@excalidraw/excalidraw/types";
2
- import type Scene from "@excalidraw/excalidraw/scene/Scene";
2
+ import type { Scene } from "./Scene";
3
3
  import type { ExcalidrawElement } from "./types";
4
4
  export declare const moveOneLeft: (allElements: readonly ExcalidrawElement[], appState: AppState, scene: Scene) => readonly ExcalidrawElement[];
5
5
  export declare const moveOneRight: (allElements: readonly ExcalidrawElement[], appState: AppState, scene: Scene) => readonly ExcalidrawElement[];
@@ -36,7 +36,7 @@ export declare const actionAddToLibrary: {
36
36
  selectionElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
37
37
  isBindingEnabled: boolean;
38
38
  startBoundElement: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawBindableElement> | null;
39
- suggestedBindings: import("@excalidraw/element/binding").SuggestedBinding[];
39
+ suggestedBindings: import("@excalidraw/element").SuggestedBinding[];
40
40
  frameToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawFrameLikeElement> | null;
41
41
  frameRendering: {
42
42
  enabled: boolean;
@@ -47,7 +47,7 @@ export declare const actionAddToLibrary: {
47
47
  editingFrame: string | null;
48
48
  elementsToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawElement>[] | null;
49
49
  editingTextElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
50
- editingLinearElement: import("@excalidraw/element/linearElementEditor").LinearElementEditor | null;
50
+ editingLinearElement: import("@excalidraw/element").LinearElementEditor | null;
51
51
  activeTool: {
52
52
  lastActiveTool: import("../types").ActiveTool | null;
53
53
  locked: boolean;
@@ -73,7 +73,7 @@ export declare const actionAddToLibrary: {
73
73
  currentItemEndArrowhead: import("@excalidraw/element/types").Arrowhead | null;
74
74
  currentHoveredFontFamily: number | null;
75
75
  currentItemRoundness: import("@excalidraw/element/types").StrokeRoundness;
76
- currentItemArrowType: "round" | "sharp" | "elbow";
76
+ currentItemArrowType: "sharp" | "round" | "elbow";
77
77
  viewBackgroundColor: string;
78
78
  scrollX: number;
79
79
  scrollY: number;
@@ -85,7 +85,7 @@ export declare const actionAddToLibrary: {
85
85
  zoom: Readonly<{
86
86
  value: import("../types").NormalizedZoomValue;
87
87
  }>;
88
- openMenu: "shape" | "canvas" | null;
88
+ openMenu: "canvas" | "shape" | null;
89
89
  openPopup: "fontFamily" | "canvasBackground" | "elementBackground" | "elementStroke" | null;
90
90
  openSidebar: {
91
91
  name: string;
@@ -162,9 +162,8 @@ export declare const actionAddToLibrary: {
162
162
  shown: true;
163
163
  data: import("../charts").Spreadsheet;
164
164
  };
165
- pendingImageElementId: string | null;
166
- showHyperlinkPopup: false | "editor" | "info";
167
- selectedLinearElement: import("@excalidraw/element/linearElementEditor").LinearElementEditor | null;
165
+ showHyperlinkPopup: false | "info" | "editor";
166
+ selectedLinearElement: import("@excalidraw/element").LinearElementEditor | null;
168
167
  snapLines: readonly import("../snapping").SnapLine[];
169
168
  originSnapOffset: {
170
169
  x: number;
@@ -175,16 +174,14 @@ export declare const actionAddToLibrary: {
175
174
  followedBy: Set<import("../types").SocketId>;
176
175
  isCropping: boolean;
177
176
  croppingElementId: string | null;
178
- searchMatches: readonly {
179
- id: string;
180
- focus: boolean;
181
- matchedLines: {
182
- offsetX: number;
183
- offsetY: number;
184
- width: number;
185
- height: number;
186
- }[];
187
- }[];
177
+ searchMatches: Readonly<{
178
+ focusedId: string | null;
179
+ matches: readonly import("../types").SearchMatch[];
180
+ }> | null;
181
+ activeLockedId: string | null;
182
+ lockedMultiSelections: {
183
+ [groupId: string]: true;
184
+ };
188
185
  };
189
186
  } | {
190
187
  captureUpdate: "EVENTUALLY";
@@ -215,7 +212,7 @@ export declare const actionAddToLibrary: {
215
212
  selectionElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
216
213
  isBindingEnabled: boolean;
217
214
  startBoundElement: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawBindableElement> | null;
218
- suggestedBindings: import("@excalidraw/element/binding").SuggestedBinding[];
215
+ suggestedBindings: import("@excalidraw/element").SuggestedBinding[];
219
216
  frameToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawFrameLikeElement> | null;
220
217
  frameRendering: {
221
218
  enabled: boolean;
@@ -226,7 +223,7 @@ export declare const actionAddToLibrary: {
226
223
  editingFrame: string | null;
227
224
  elementsToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawElement>[] | null;
228
225
  editingTextElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
229
- editingLinearElement: import("@excalidraw/element/linearElementEditor").LinearElementEditor | null;
226
+ editingLinearElement: import("@excalidraw/element").LinearElementEditor | null;
230
227
  activeTool: {
231
228
  lastActiveTool: import("../types").ActiveTool | null;
232
229
  locked: boolean;
@@ -252,7 +249,7 @@ export declare const actionAddToLibrary: {
252
249
  currentItemEndArrowhead: import("@excalidraw/element/types").Arrowhead | null;
253
250
  currentHoveredFontFamily: number | null;
254
251
  currentItemRoundness: import("@excalidraw/element/types").StrokeRoundness;
255
- currentItemArrowType: "round" | "sharp" | "elbow";
252
+ currentItemArrowType: "sharp" | "round" | "elbow";
256
253
  viewBackgroundColor: string;
257
254
  scrollX: number;
258
255
  scrollY: number;
@@ -264,7 +261,7 @@ export declare const actionAddToLibrary: {
264
261
  zoom: Readonly<{
265
262
  value: import("../types").NormalizedZoomValue;
266
263
  }>;
267
- openMenu: "shape" | "canvas" | null;
264
+ openMenu: "canvas" | "shape" | null;
268
265
  openPopup: "fontFamily" | "canvasBackground" | "elementBackground" | "elementStroke" | null;
269
266
  openSidebar: {
270
267
  name: string;
@@ -346,9 +343,8 @@ export declare const actionAddToLibrary: {
346
343
  shown: true;
347
344
  data: import("../charts").Spreadsheet;
348
345
  };
349
- pendingImageElementId: string | null;
350
- showHyperlinkPopup: false | "editor" | "info";
351
- selectedLinearElement: import("@excalidraw/element/linearElementEditor").LinearElementEditor | null;
346
+ showHyperlinkPopup: false | "info" | "editor";
347
+ selectedLinearElement: import("@excalidraw/element").LinearElementEditor | null;
352
348
  snapLines: readonly import("../snapping").SnapLine[];
353
349
  originSnapOffset: {
354
350
  x: number;
@@ -359,16 +355,14 @@ export declare const actionAddToLibrary: {
359
355
  followedBy: Set<import("../types").SocketId>;
360
356
  isCropping: boolean;
361
357
  croppingElementId: string | null;
362
- searchMatches: readonly {
363
- id: string;
364
- focus: boolean;
365
- matchedLines: {
366
- offsetX: number;
367
- offsetY: number;
368
- width: number;
369
- height: number;
370
- }[];
371
- }[];
358
+ searchMatches: Readonly<{
359
+ focusedId: string | null;
360
+ matches: readonly import("../types").SearchMatch[];
361
+ }> | null;
362
+ activeLockedId: string | null;
363
+ lockedMultiSelections: {
364
+ [groupId: string]: true;
365
+ };
372
366
  };
373
367
  }> | {
374
368
  captureUpdate: "EVENTUALLY";
@@ -399,7 +393,7 @@ export declare const actionAddToLibrary: {
399
393
  selectionElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
400
394
  isBindingEnabled: boolean;
401
395
  startBoundElement: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawBindableElement> | null;
402
- suggestedBindings: import("@excalidraw/element/binding").SuggestedBinding[];
396
+ suggestedBindings: import("@excalidraw/element").SuggestedBinding[];
403
397
  frameToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawFrameLikeElement> | null;
404
398
  frameRendering: {
405
399
  enabled: boolean;
@@ -410,7 +404,7 @@ export declare const actionAddToLibrary: {
410
404
  editingFrame: string | null;
411
405
  elementsToHighlight: import("@excalidraw/element/types").NonDeleted<import("@excalidraw/element/types").ExcalidrawElement>[] | null;
412
406
  editingTextElement: import("@excalidraw/element/types").NonDeletedExcalidrawElement | null;
413
- editingLinearElement: import("@excalidraw/element/linearElementEditor").LinearElementEditor | null;
407
+ editingLinearElement: import("@excalidraw/element").LinearElementEditor | null;
414
408
  activeTool: {
415
409
  lastActiveTool: import("../types").ActiveTool | null;
416
410
  locked: boolean;
@@ -436,7 +430,7 @@ export declare const actionAddToLibrary: {
436
430
  currentItemEndArrowhead: import("@excalidraw/element/types").Arrowhead | null;
437
431
  currentHoveredFontFamily: number | null;
438
432
  currentItemRoundness: import("@excalidraw/element/types").StrokeRoundness;
439
- currentItemArrowType: "round" | "sharp" | "elbow";
433
+ currentItemArrowType: "sharp" | "round" | "elbow";
440
434
  viewBackgroundColor: string;
441
435
  scrollX: number;
442
436
  scrollY: number;
@@ -448,7 +442,7 @@ export declare const actionAddToLibrary: {
448
442
  zoom: Readonly<{
449
443
  value: import("../types").NormalizedZoomValue;
450
444
  }>;
451
- openMenu: "shape" | "canvas" | null;
445
+ openMenu: "canvas" | "shape" | null;
452
446
  openPopup: "fontFamily" | "canvasBackground" | "elementBackground" | "elementStroke" | null;
453
447
  openSidebar: {
454
448
  name: string;
@@ -530,9 +524,8 @@ export declare const actionAddToLibrary: {
530
524
  shown: true;
531
525
  data: import("../charts").Spreadsheet;
532
526
  };
533
- pendingImageElementId: string | null;
534
- showHyperlinkPopup: false | "editor" | "info";
535
- selectedLinearElement: import("@excalidraw/element/linearElementEditor").LinearElementEditor | null;
527
+ showHyperlinkPopup: false | "info" | "editor";
528
+ selectedLinearElement: import("@excalidraw/element").LinearElementEditor | null;
536
529
  snapLines: readonly import("../snapping").SnapLine[];
537
530
  originSnapOffset: {
538
531
  x: number;
@@ -543,16 +536,14 @@ export declare const actionAddToLibrary: {
543
536
  followedBy: Set<import("../types").SocketId>;
544
537
  isCropping: boolean;
545
538
  croppingElementId: string | null;
546
- searchMatches: readonly {
547
- id: string;
548
- focus: boolean;
549
- matchedLines: {
550
- offsetX: number;
551
- offsetY: number;
552
- width: number;
553
- height: number;
554
- }[];
555
- }[];
539
+ searchMatches: Readonly<{
540
+ focusedId: string | null;
541
+ matches: readonly import("../types").SearchMatch[];
542
+ }> | null;
543
+ activeLockedId: string | null;
544
+ lockedMultiSelections: {
545
+ [groupId: string]: true;
546
+ };
556
547
  };
557
548
  };
558
549
  label: string;
@@ -15,10 +15,10 @@ export declare const actionAlignTop: {
15
15
  elements: ExcalidrawElement[];
16
16
  captureUpdate: "IMMEDIATELY";
17
17
  };
18
- keyTest: (event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean;
18
+ keyTest: (event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean;
19
19
  PanelComponent: ({ elements, appState, updateData, app }: import("./types").PanelComponentProps) => import("react/jsx-runtime").JSX.Element;
20
20
  } & {
21
- keyTest?: ((event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean) | undefined;
21
+ keyTest?: ((event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
22
22
  };
23
23
  export declare const actionAlignBottom: {
24
24
  name: "alignBottom";
@@ -33,10 +33,10 @@ export declare const actionAlignBottom: {
33
33
  elements: ExcalidrawElement[];
34
34
  captureUpdate: "IMMEDIATELY";
35
35
  };
36
- keyTest: (event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean;
36
+ keyTest: (event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean;
37
37
  PanelComponent: ({ elements, appState, updateData, app }: import("./types").PanelComponentProps) => import("react/jsx-runtime").JSX.Element;
38
38
  } & {
39
- keyTest?: ((event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean) | undefined;
39
+ keyTest?: ((event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
40
40
  };
41
41
  export declare const actionAlignLeft: {
42
42
  name: "alignLeft";
@@ -51,10 +51,10 @@ export declare const actionAlignLeft: {
51
51
  elements: ExcalidrawElement[];
52
52
  captureUpdate: "IMMEDIATELY";
53
53
  };
54
- keyTest: (event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean;
54
+ keyTest: (event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean;
55
55
  PanelComponent: ({ elements, appState, updateData, app }: import("./types").PanelComponentProps) => import("react/jsx-runtime").JSX.Element;
56
56
  } & {
57
- keyTest?: ((event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean) | undefined;
57
+ keyTest?: ((event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
58
58
  };
59
59
  export declare const actionAlignRight: {
60
60
  name: "alignRight";
@@ -69,10 +69,10 @@ export declare const actionAlignRight: {
69
69
  elements: ExcalidrawElement[];
70
70
  captureUpdate: "IMMEDIATELY";
71
71
  };
72
- keyTest: (event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean;
72
+ keyTest: (event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean;
73
73
  PanelComponent: ({ elements, appState, updateData, app }: import("./types").PanelComponentProps) => import("react/jsx-runtime").JSX.Element;
74
74
  } & {
75
- keyTest?: ((event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean) | undefined;
75
+ keyTest?: ((event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
76
76
  };
77
77
  export declare const actionAlignVerticallyCentered: {
78
78
  name: "alignVerticallyCentered";
@@ -23,8 +23,8 @@ export declare const actionArrangeElements: {
23
23
  elements: ExcalidrawElement[];
24
24
  captureUpdate: "IMMEDIATELY";
25
25
  };
26
- keyTest: (event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean;
26
+ keyTest: (event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean;
27
27
  PanelComponent: ({ updateData }: import("./types").PanelComponentProps) => import("react/jsx-runtime").JSX.Element;
28
28
  } & {
29
- keyTest?: ((event: KeyboardEvent | import("react").KeyboardEvent<Element>) => boolean) | undefined;
29
+ keyTest?: ((event: import("react").KeyboardEvent<Element> | KeyboardEvent) => boolean) | undefined;
30
30
  };