@zsviczian/excalidraw 0.14.2-obsidian-2 → 0.14.2-obsidian-4

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 (241) hide show
  1. package/dist/.DS_Store +0 -0
  2. package/dist/excalidraw.development.js +196 -185
  3. package/dist/excalidraw.production.min.js +1 -1
  4. package/package.json +2 -2
  5. package/types/actions/actionAddToLibrary.d.ts +372 -365
  6. package/types/actions/actionAlign.d.ts +91 -91
  7. package/types/actions/actionBoundText.d.ts +284 -162
  8. package/types/actions/actionCanvas.d.ts +1315 -1295
  9. package/types/actions/actionClipboard.d.ts +717 -707
  10. package/types/actions/actionDeleteSelected.d.ts +409 -403
  11. package/types/actions/actionDistribute.d.ts +33 -33
  12. package/types/actions/actionDuplicateSelection.d.ts +22 -22
  13. package/types/actions/actionExport.d.ts +1181 -1163
  14. package/types/actions/actionFinalize.d.ts +256 -252
  15. package/types/actions/actionFlip.d.ts +35 -35
  16. package/types/actions/actionGroup.d.ts +45 -45
  17. package/types/actions/actionHistory.d.ts +6 -6
  18. package/types/actions/actionLinearEditor.d.ts +135 -132
  19. package/types/actions/actionMenu.d.ts +410 -404
  20. package/types/actions/actionNavigate.d.ts +14 -14
  21. package/types/actions/actionProperties.d.ts +1714 -1688
  22. package/types/actions/actionSelectAll.d.ts +16 -16
  23. package/types/actions/actionStyles.d.ts +149 -147
  24. package/types/actions/actionToggleGridMode.d.ts +138 -136
  25. package/types/actions/actionToggleLock.d.ts +135 -133
  26. package/types/actions/actionToggleStats.d.ts +135 -133
  27. package/types/actions/actionToggleViewMode.d.ts +137 -135
  28. package/types/actions/actionToggleZenMode.d.ts +137 -135
  29. package/types/actions/actionZindex.d.ts +67 -67
  30. package/types/actions/index.d.ts +24 -24
  31. package/types/actions/manager.d.ts +21 -21
  32. package/types/actions/register.d.ts +5 -5
  33. package/types/actions/shortcuts.d.ts +4 -3
  34. package/types/actions/types.d.ts +44 -43
  35. package/types/align.d.ts +6 -6
  36. package/types/analytics.d.ts +1 -1
  37. package/types/appState.d.ts +78 -78
  38. package/types/charts.d.ts +27 -27
  39. package/types/clients.d.ts +6 -6
  40. package/types/clipboard.d.ts +25 -25
  41. package/types/colors.d.ts +6 -6
  42. package/types/components/Actions.d.ts +36 -36
  43. package/types/components/ActiveConfirmDialog.d.ts +24 -24
  44. package/types/components/App.d.ts +248 -237
  45. package/types/components/Avatar.d.ts +11 -11
  46. package/types/components/BraveMeasureTextError.d.ts +2 -0
  47. package/types/components/Button.d.ts +15 -15
  48. package/types/components/ButtonIconSelect.d.ts +11 -11
  49. package/types/components/Card.d.ts +7 -7
  50. package/types/components/CheckboxItem.d.ts +8 -8
  51. package/types/components/ColorPicker.d.ts +19 -19
  52. package/types/components/ConfirmDialog.d.ts +10 -10
  53. package/types/components/ContextMenu.d.ts +15 -15
  54. package/types/components/DarkModeToggle.d.ts +7 -7
  55. package/types/components/Dialog.d.ts +14 -14
  56. package/types/components/DialogActionButton.d.ts +10 -10
  57. package/types/components/ErrorDialog.d.ts +5 -4
  58. package/types/components/FixedSideContainer.d.ts +9 -9
  59. package/types/components/HandButton.d.ts +10 -10
  60. package/types/components/HelpButton.d.ts +7 -7
  61. package/types/components/HelpDialog.d.ts +4 -4
  62. package/types/components/HintViewer.d.ts +11 -11
  63. package/types/components/IconPicker.d.ts +13 -13
  64. package/types/components/ImageExportDialog.d.ts +18 -18
  65. package/types/components/InitializeApp.d.ts +10 -10
  66. package/types/components/Island.d.ts +10 -10
  67. package/types/components/JSONExportDialog.d.ts +15 -15
  68. package/types/components/LayerUI.d.ts +37 -37
  69. package/types/components/LibraryButton.d.ts +8 -8
  70. package/types/components/LibraryMenu.d.ts +25 -25
  71. package/types/components/LibraryMenuBrowseButton.d.ts +7 -7
  72. package/types/components/LibraryMenuHeaderContent.d.ts +35 -35
  73. package/types/components/LibraryMenuItems.d.ts +15 -15
  74. package/types/components/LibraryUnit.d.ts +11 -11
  75. package/types/components/LoadingMessage.d.ts +6 -6
  76. package/types/components/LockButton.d.ts +10 -10
  77. package/types/components/MobileMenu.d.ts +26 -26
  78. package/types/components/Modal.d.ts +13 -12
  79. package/types/components/PasteChartDialog.d.ts +9 -9
  80. package/types/components/PenModeButton.d.ts +12 -12
  81. package/types/components/Popover.d.ts +15 -15
  82. package/types/components/ProjectName.d.ts +10 -10
  83. package/types/components/PublishLibrary.d.ts +16 -16
  84. package/types/components/Section.d.ts +6 -6
  85. package/types/components/Sidebar/Sidebar.d.ts +73 -73
  86. package/types/components/Sidebar/SidebarHeader.d.ts +20 -20
  87. package/types/components/Sidebar/common.d.ts +16 -16
  88. package/types/components/SingleLibraryItem.d.ts +10 -10
  89. package/types/components/Spinner.d.ts +6 -6
  90. package/types/components/Stack.d.ts +15 -15
  91. package/types/components/Stats.d.ts +11 -11
  92. package/types/components/Toast.d.ts +7 -7
  93. package/types/components/ToolButton.d.ts +46 -46
  94. package/types/components/Tooltip.d.ts +17 -17
  95. package/types/components/UserList.d.ts +8 -8
  96. package/types/components/context/tunnels.d.ts +16 -16
  97. package/types/components/dropdownMenu/DropdownMenu.d.ts +66 -66
  98. package/types/components/dropdownMenu/DropdownMenuContent.d.ts +15 -15
  99. package/types/components/dropdownMenu/DropdownMenuGroup.d.ts +11 -11
  100. package/types/components/dropdownMenu/DropdownMenuItem.d.ts +12 -12
  101. package/types/components/dropdownMenu/DropdownMenuItemContent.d.ts +6 -6
  102. package/types/components/dropdownMenu/DropdownMenuItemCustom.d.ts +6 -6
  103. package/types/components/dropdownMenu/DropdownMenuItemLink.d.ts +13 -13
  104. package/types/components/dropdownMenu/DropdownMenuSeparator.d.ts +5 -5
  105. package/types/components/dropdownMenu/DropdownMenuTrigger.d.ts +9 -9
  106. package/types/components/dropdownMenu/common.d.ts +6 -6
  107. package/types/components/dropdownMenu/dropdownMenuUtils.d.ts +3 -3
  108. package/types/components/footer/Footer.d.ts +12 -12
  109. package/types/components/footer/FooterCenter.d.ts +8 -8
  110. package/types/components/hoc/withInternalFallback.d.ts +4 -4
  111. package/types/components/hoc/withUpstreamOverride.d.ts +10 -10
  112. package/types/components/icons.d.ts +142 -142
  113. package/types/components/live-collaboration/LiveCollaborationTrigger.d.ts +10 -10
  114. package/types/components/main-menu/DefaultItems.d.ts +44 -44
  115. package/types/components/main-menu/MainMenu.d.ts +60 -60
  116. package/types/components/welcome-screen/WelcomeScreen.Center.d.ts +58 -58
  117. package/types/components/welcome-screen/WelcomeScreen.Hints.d.ts +19 -19
  118. package/types/components/welcome-screen/WelcomeScreen.d.ts +85 -85
  119. package/types/constants.d.ts +170 -169
  120. package/types/data/blob.d.ts +48 -47
  121. package/types/data/encode.d.ts +53 -53
  122. package/types/data/encryption.d.ts +9 -9
  123. package/types/data/filesystem.d.ts +18 -18
  124. package/types/data/image.d.ts +15 -15
  125. package/types/data/index.d.ts +13 -13
  126. package/types/data/json.d.ts +16 -16
  127. package/types/data/library.d.ts +96 -96
  128. package/types/data/resave.d.ts +5 -5
  129. package/types/data/restore.d.ts +21 -21
  130. package/types/data/types.d.ts +47 -47
  131. package/types/distribute.d.ts +6 -6
  132. package/types/element/Hyperlink.d.ts +155 -153
  133. package/types/element/binding.d.ts +33 -33
  134. package/types/element/bounds.d.ts +28 -28
  135. package/types/element/collision.d.ts +21 -21
  136. package/types/element/dragElements.d.ts +5 -5
  137. package/types/element/image.d.ts +22 -22
  138. package/types/element/index.d.ts +20 -20
  139. package/types/element/linearElementEditor.d.ts +273 -269
  140. package/types/element/mutateElement.d.ts +12 -11
  141. package/types/element/newElement.d.ts +65 -63
  142. package/types/element/resizeElements.d.ts +8 -8
  143. package/types/element/resizeTest.d.ts +13 -13
  144. package/types/element/showSelectedShapeActions.d.ts +3 -3
  145. package/types/element/sizeHelpers.d.ts +21 -21
  146. package/types/element/sortElements.d.ts +2 -2
  147. package/types/element/textElement.d.ts +73 -55
  148. package/types/element/textWysiwyg.d.ts +21 -21
  149. package/types/element/transformHandles.d.ts +28 -28
  150. package/types/element/typeChecks.d.ts +27 -26
  151. package/types/element/types.d.ts +149 -141
  152. package/types/errors.d.ts +8 -8
  153. package/types/ga.d.ts +63 -63
  154. package/types/gadirections.d.ts +8 -8
  155. package/types/galines.d.ts +22 -22
  156. package/types/gapoints.d.ts +7 -7
  157. package/types/gatransforms.d.ts +10 -10
  158. package/types/gesture.d.ts +6 -6
  159. package/types/groups.d.ts +27 -27
  160. package/types/history.d.ts +52 -52
  161. package/types/hooks/useCallbackRefState.d.ts +1 -1
  162. package/types/hooks/useOutsideClick.d.ts +2 -2
  163. package/types/i18n.d.ts +21 -21
  164. package/types/jotai.d.ts +122 -122
  165. package/types/keys.d.ts +77 -77
  166. package/types/math.d.ts +29 -29
  167. package/types/packages/common.webpack.dev.config.d.ts +72 -71
  168. package/types/packages/common.webpack.prod.config.d.ts +84 -83
  169. package/types/packages/excalidraw/dist/excalidraw.development.d.ts +4 -4
  170. package/types/packages/excalidraw/dist/excalidraw.production.min.d.ts +1 -1
  171. package/types/packages/excalidraw/entry.d.ts +1 -1
  172. package/types/packages/excalidraw/env.d.ts +1 -1
  173. package/types/packages/excalidraw/example/App.d.ts +14 -14
  174. package/types/packages/excalidraw/example/CustomFooter.d.ts +5 -5
  175. package/types/packages/excalidraw/example/MobileFooter.d.ts +5 -5
  176. package/types/packages/excalidraw/example/index.d.ts +1 -1
  177. package/types/packages/excalidraw/example/initialData.d.ts +172 -172
  178. package/types/packages/excalidraw/example/sidebar/ExampleSidebar.d.ts +5 -5
  179. package/types/packages/excalidraw/index.d.ts +35 -34
  180. package/types/packages/excalidraw/main.d.ts +2 -2
  181. package/types/packages/excalidraw/publicPath.d.ts +1 -1
  182. package/types/packages/excalidraw/webpack.dev-server.config.d.ts +19 -19
  183. package/types/packages/excalidraw/webpack.dev.config.d.ts +69 -68
  184. package/types/packages/excalidraw/webpack.prod.config.d.ts +78 -77
  185. package/types/packages/utils.d.ts +42 -42
  186. package/types/points.d.ts +7 -7
  187. package/types/polyfill.d.ts +2 -2
  188. package/types/random.d.ts +4 -4
  189. package/types/renderer/easingFunctions.d.ts +6 -6
  190. package/types/renderer/renderElement.d.ts +35 -35
  191. package/types/renderer/renderScene.d.ts +41 -41
  192. package/types/renderer/roundRect.d.ts +11 -11
  193. package/types/scene/Fonts.d.ts +21 -21
  194. package/types/scene/Scene.d.ts +40 -40
  195. package/types/scene/comparisons.d.ts +10 -10
  196. package/types/scene/export.d.ts +20 -20
  197. package/types/scene/index.d.ts +5 -5
  198. package/types/scene/scroll.d.ts +17 -17
  199. package/types/scene/scrollbars.d.ts +16 -16
  200. package/types/scene/selection.d.ts +11 -11
  201. package/types/scene/types.d.ts +59 -59
  202. package/types/scene/zoom.d.ts +13 -13
  203. package/types/shapes.d.ts +62 -62
  204. package/types/types.d.ts +442 -439
  205. package/types/utility-types.d.ts +22 -0
  206. package/types/utils.d.ts +162 -143
  207. package/types/zindex.d.ts +6 -6
  208. package/types/bug-issue-template.d.ts +0 -2
  209. package/types/components/ActiveFile.d.ts +0 -7
  210. package/types/components/BackgroundPickerAndDarkModeToggle.d.ts +0 -4
  211. package/types/components/ClearCanvas.d.ts +0 -4
  212. package/types/components/CollabButton.d.ts +0 -7
  213. package/types/components/EncryptedIcon.d.ts +0 -2
  214. package/types/components/Footer.d.ts +0 -10
  215. package/types/components/HelpIcon.d.ts +0 -8
  216. package/types/components/MenuItem.d.ts +0 -11
  217. package/types/components/MenuUtils.d.ts +0 -2
  218. package/types/components/SidebarLockButton.d.ts +0 -8
  219. package/types/components/TopErrorBoundary.d.ts +0 -15
  220. package/types/components/WelcomeScreen.d.ts +0 -8
  221. package/types/components/WelcomeScreenDecor.d.ts +0 -6
  222. package/types/components/mainMenu/DefaultItems.d.ts +0 -44
  223. package/types/components/mainMenu/MainMenu.d.ts +0 -63
  224. package/types/excalidraw-app/CustomStats.d.ts +0 -9
  225. package/types/excalidraw-app/app_constants.d.ts +0 -32
  226. package/types/excalidraw-app/collab/Collab.d.ts +0 -163
  227. package/types/excalidraw-app/collab/Portal.d.ts +0 -28
  228. package/types/excalidraw-app/collab/RoomDialog.d.ts +0 -13
  229. package/types/excalidraw-app/collab/reconciliation.d.ts +0 -10
  230. package/types/excalidraw-app/components/ExportToExcalidrawPlus.d.ts +0 -9
  231. package/types/excalidraw-app/components/LanguageList.d.ts +0 -4
  232. package/types/excalidraw-app/components/icons.d.ts +0 -1
  233. package/types/excalidraw-app/data/FileManager.d.ts +0 -66
  234. package/types/excalidraw-app/data/LocalData.d.ts +0 -32
  235. package/types/excalidraw-app/data/Locker.d.ts +0 -8
  236. package/types/excalidraw-app/data/firebase.d.ts +0 -25
  237. package/types/excalidraw-app/data/index.d.ts +0 -190
  238. package/types/excalidraw-app/data/localStorage.d.ts +0 -116
  239. package/types/excalidraw-app/data/tabSync.d.ts +0 -9
  240. package/types/excalidraw-app/index.d.ts +0 -26
  241. package/types/packages/excalidraw/example/sidebar/Sidebar.d.ts +0 -5
@@ -1,63 +1,65 @@
1
- import { ExcalidrawElement, ExcalidrawImageElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawGenericElement, NonDeleted, TextAlign, GroupId, VerticalAlign, Arrowhead, ExcalidrawFreeDrawElement, FontFamilyValues, ExcalidrawTextContainer } from "../element/types";
2
- import { AppState } from "../types";
3
- declare type ElementConstructorOpts = MarkOptional<Omit<ExcalidrawGenericElement, "id" | "type" | "isDeleted" | "updated">, "width" | "height" | "angle" | "groupIds" | "boundElements" | "seed" | "version" | "versionNonce" | "link">;
4
- export declare const newElement: (opts: {
5
- type: ExcalidrawGenericElement["type"];
6
- } & ElementConstructorOpts) => NonDeleted<ExcalidrawGenericElement>;
7
- export declare const newTextElement: (opts: {
8
- text: string;
9
- rawText: string;
10
- fontSize: number;
11
- fontFamily: FontFamilyValues;
12
- textAlign: TextAlign;
13
- verticalAlign: VerticalAlign;
14
- containerId?: ExcalidrawTextContainer["id"];
15
- } & ElementConstructorOpts) => NonDeleted<ExcalidrawTextElement>;
16
- export declare const refreshTextDimensions: (textElement: ExcalidrawTextElement, text?: string) => {
17
- x: number;
18
- y: number;
19
- width: number;
20
- height: number;
21
- text: string;
22
- };
23
- export declare const updateTextElement: (textElement: ExcalidrawTextElement, { text, isDeleted, originalText, rawText, link, }: {
24
- text: string;
25
- isDeleted?: boolean | undefined;
26
- originalText: string;
27
- rawText?: string | undefined;
28
- link?: string | undefined;
29
- }) => ExcalidrawTextElement;
30
- export declare const newFreeDrawElement: (opts: {
31
- type: "freedraw";
32
- points?: ExcalidrawFreeDrawElement["points"];
33
- simulatePressure: boolean;
34
- } & ElementConstructorOpts) => NonDeleted<ExcalidrawFreeDrawElement>;
35
- export declare const newLinearElement: (opts: {
36
- type: ExcalidrawLinearElement["type"];
37
- startArrowhead: Arrowhead | null;
38
- endArrowhead: Arrowhead | null;
39
- points?: ExcalidrawLinearElement["points"];
40
- } & ElementConstructorOpts) => NonDeleted<ExcalidrawLinearElement>;
41
- export declare const newImageElement: (opts: {
42
- type: ExcalidrawImageElement["type"];
43
- status?: ExcalidrawImageElement["status"];
44
- fileId?: ExcalidrawImageElement["fileId"];
45
- scale?: ExcalidrawImageElement["scale"];
46
- } & ElementConstructorOpts) => NonDeleted<ExcalidrawImageElement>;
47
- export declare const deepCopyElement: (val: any, depth?: number) => any;
48
- /**
49
- * Duplicate an element, often used in the alt-drag operation.
50
- * Note that this method has gotten a bit complicated since the
51
- * introduction of gruoping/ungrouping elements.
52
- * @param editingGroupId The current group being edited. The new
53
- * element will inherit this group and its
54
- * parents.
55
- * @param groupIdMapForOperation A Map that maps old group IDs to
56
- * duplicated ones. If you are duplicating
57
- * multiple elements at once, share this map
58
- * amongst all of them
59
- * @param element Element to duplicate
60
- * @param overrides Any element properties to override
61
- */
62
- export declare const duplicateElement: <TElement extends Mutable<ExcalidrawElement>>(editingGroupId: AppState["editingGroupId"], groupIdMapForOperation: Map<GroupId, GroupId>, element: TElement, overrides?: Partial<TElement> | undefined) => TElement;
63
- export {};
1
+ import { ExcalidrawElement, ExcalidrawImageElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawGenericElement, NonDeleted, TextAlign, GroupId, VerticalAlign, Arrowhead, ExcalidrawFreeDrawElement, FontFamilyValues, ExcalidrawTextContainer } from "../element/types";
2
+ import { AppState } from "../types";
3
+ import { MarkOptional, Mutable } from "../utility-types";
4
+ declare type ElementConstructorOpts = MarkOptional<Omit<ExcalidrawGenericElement, "id" | "type" | "isDeleted" | "updated">, "width" | "height" | "angle" | "groupIds" | "boundElements" | "seed" | "version" | "versionNonce" | "link">;
5
+ export declare const newElement: (opts: {
6
+ type: ExcalidrawGenericElement["type"];
7
+ } & ElementConstructorOpts) => NonDeleted<ExcalidrawGenericElement>;
8
+ export declare const newTextElement: (opts: {
9
+ text: string;
10
+ rawText: string;
11
+ fontSize: number;
12
+ fontFamily: FontFamilyValues;
13
+ textAlign: TextAlign;
14
+ verticalAlign: VerticalAlign;
15
+ containerId?: ExcalidrawTextContainer["id"];
16
+ lineHeight?: ExcalidrawTextElement["lineHeight"];
17
+ } & ElementConstructorOpts) => NonDeleted<ExcalidrawTextElement>;
18
+ export declare const refreshTextDimensions: (textElement: ExcalidrawTextElement, text?: string) => {
19
+ x: number;
20
+ y: number;
21
+ width: number;
22
+ height: number;
23
+ text: string;
24
+ };
25
+ export declare const updateTextElement: (textElement: ExcalidrawTextElement, { text, isDeleted, originalText, rawText, link, }: {
26
+ text: string;
27
+ isDeleted?: boolean | undefined;
28
+ originalText: string;
29
+ rawText?: string | undefined;
30
+ link?: string | undefined;
31
+ }) => ExcalidrawTextElement;
32
+ export declare const newFreeDrawElement: (opts: {
33
+ type: "freedraw";
34
+ points?: ExcalidrawFreeDrawElement["points"];
35
+ simulatePressure: boolean;
36
+ } & ElementConstructorOpts) => NonDeleted<ExcalidrawFreeDrawElement>;
37
+ export declare const newLinearElement: (opts: {
38
+ type: ExcalidrawLinearElement["type"];
39
+ startArrowhead: Arrowhead | null;
40
+ endArrowhead: Arrowhead | null;
41
+ points?: ExcalidrawLinearElement["points"];
42
+ } & ElementConstructorOpts) => NonDeleted<ExcalidrawLinearElement>;
43
+ export declare const newImageElement: (opts: {
44
+ type: ExcalidrawImageElement["type"];
45
+ status?: ExcalidrawImageElement["status"];
46
+ fileId?: ExcalidrawImageElement["fileId"];
47
+ scale?: ExcalidrawImageElement["scale"];
48
+ } & ElementConstructorOpts) => NonDeleted<ExcalidrawImageElement>;
49
+ export declare const deepCopyElement: (val: any, depth?: number) => any;
50
+ /**
51
+ * Duplicate an element, often used in the alt-drag operation.
52
+ * Note that this method has gotten a bit complicated since the
53
+ * introduction of gruoping/ungrouping elements.
54
+ * @param editingGroupId The current group being edited. The new
55
+ * element will inherit this group and its
56
+ * parents.
57
+ * @param groupIdMapForOperation A Map that maps old group IDs to
58
+ * duplicated ones. If you are duplicating
59
+ * multiple elements at once, share this map
60
+ * amongst all of them
61
+ * @param element Element to duplicate
62
+ * @param overrides Any element properties to override
63
+ */
64
+ export declare const duplicateElement: <TElement extends Mutable<ExcalidrawElement>>(editingGroupId: AppState["editingGroupId"], groupIdMapForOperation: Map<GroupId, GroupId>, element: TElement, overrides?: Partial<TElement> | undefined) => TElement;
65
+ export {};
@@ -1,8 +1,8 @@
1
- import { ExcalidrawLinearElement, NonDeletedExcalidrawElement, NonDeleted } from "./types";
2
- import { MaybeTransformHandleType, TransformHandleDirection } from "./transformHandles";
3
- import { PointerDownState } from "../types";
4
- export declare const normalizeAngle: (angle: number) => number;
5
- export declare const transformElements: (pointerDownState: PointerDownState, transformHandleType: MaybeTransformHandleType, selectedElements: readonly NonDeletedExcalidrawElement[], resizeArrowDirection: "origin" | "end", shouldRotateWithDiscreteAngle: boolean, shouldResizeFromCenter: boolean, shouldMaintainAspectRatio: boolean, pointerX: number, pointerY: number, centerX: number, centerY: number) => boolean;
6
- export declare const resizeSingleElement: (originalElements: PointerDownState["originalElements"], shouldMaintainAspectRatio: boolean, element: NonDeletedExcalidrawElement, transformHandleDirection: TransformHandleDirection, shouldResizeFromCenter: boolean, pointerX: number, pointerY: number) => void;
7
- export declare const getResizeOffsetXY: (transformHandleType: MaybeTransformHandleType, selectedElements: NonDeletedExcalidrawElement[], x: number, y: number) => [number, number];
8
- export declare const getResizeArrowDirection: (transformHandleType: MaybeTransformHandleType, element: NonDeleted<ExcalidrawLinearElement>) => "origin" | "end";
1
+ import { ExcalidrawLinearElement, NonDeletedExcalidrawElement, NonDeleted } from "./types";
2
+ import { MaybeTransformHandleType, TransformHandleDirection } from "./transformHandles";
3
+ import { PointerDownState } from "../types";
4
+ export declare const normalizeAngle: (angle: number) => number;
5
+ export declare const transformElements: (pointerDownState: PointerDownState, transformHandleType: MaybeTransformHandleType, selectedElements: readonly NonDeletedExcalidrawElement[], resizeArrowDirection: "origin" | "end", shouldRotateWithDiscreteAngle: boolean, shouldResizeFromCenter: boolean, shouldMaintainAspectRatio: boolean, pointerX: number, pointerY: number, centerX: number, centerY: number) => boolean;
6
+ export declare const resizeSingleElement: (originalElements: PointerDownState["originalElements"], shouldMaintainAspectRatio: boolean, element: NonDeletedExcalidrawElement, transformHandleDirection: TransformHandleDirection, shouldResizeFromCenter: boolean, pointerX: number, pointerY: number) => void;
7
+ export declare const getResizeOffsetXY: (transformHandleType: MaybeTransformHandleType, selectedElements: NonDeletedExcalidrawElement[], x: number, y: number) => [number, number];
8
+ export declare const getResizeArrowDirection: (transformHandleType: MaybeTransformHandleType, element: NonDeleted<ExcalidrawLinearElement>) => "origin" | "end";
@@ -1,13 +1,13 @@
1
- import { ExcalidrawElement, PointerType, NonDeletedExcalidrawElement } from "./types";
2
- import { MaybeTransformHandleType } from "./transformHandles";
3
- import { AppState, Zoom } from "../types";
4
- export declare const resizeTest: (element: NonDeletedExcalidrawElement, appState: AppState, x: number, y: number, zoom: Zoom, pointerType: PointerType) => MaybeTransformHandleType;
5
- export declare const getElementWithTransformHandleType: (elements: readonly NonDeletedExcalidrawElement[], appState: AppState, scenePointerX: number, scenePointerY: number, zoom: Zoom, pointerType: PointerType) => {
6
- element: NonDeletedExcalidrawElement;
7
- transformHandleType: MaybeTransformHandleType;
8
- } | null;
9
- export declare const getTransformHandleTypeFromCoords: ([x1, y1, x2, y2]: readonly [number, number, number, number], scenePointerX: number, scenePointerY: number, zoom: Zoom, pointerType: PointerType) => MaybeTransformHandleType;
10
- export declare const getCursorForResizingElement: (resizingElement: {
11
- element?: ExcalidrawElement;
12
- transformHandleType: MaybeTransformHandleType;
13
- }) => string;
1
+ import { ExcalidrawElement, PointerType, NonDeletedExcalidrawElement } from "./types";
2
+ import { MaybeTransformHandleType } from "./transformHandles";
3
+ import { AppState, Zoom } from "../types";
4
+ export declare const resizeTest: (element: NonDeletedExcalidrawElement, appState: AppState, x: number, y: number, zoom: Zoom, pointerType: PointerType) => MaybeTransformHandleType;
5
+ export declare const getElementWithTransformHandleType: (elements: readonly NonDeletedExcalidrawElement[], appState: AppState, scenePointerX: number, scenePointerY: number, zoom: Zoom, pointerType: PointerType) => {
6
+ element: NonDeletedExcalidrawElement;
7
+ transformHandleType: MaybeTransformHandleType;
8
+ } | null;
9
+ export declare const getTransformHandleTypeFromCoords: ([x1, y1, x2, y2]: readonly [number, number, number, number], scenePointerX: number, scenePointerY: number, zoom: Zoom, pointerType: PointerType) => MaybeTransformHandleType;
10
+ export declare const getCursorForResizingElement: (resizingElement: {
11
+ element?: ExcalidrawElement;
12
+ transformHandleType: MaybeTransformHandleType;
13
+ }) => string;
@@ -1,3 +1,3 @@
1
- import { AppState } from "../types";
2
- import { NonDeletedExcalidrawElement } from "./types";
3
- export declare const showSelectedShapeActions: (appState: AppState, elements: readonly NonDeletedExcalidrawElement[]) => boolean;
1
+ import { AppState } from "../types";
2
+ import { NonDeletedExcalidrawElement } from "./types";
3
+ export declare const showSelectedShapeActions: (appState: AppState, elements: readonly NonDeletedExcalidrawElement[]) => boolean;
@@ -1,21 +1,21 @@
1
- import { ExcalidrawElement } from "./types";
2
- import { AppState } from "../types";
3
- export declare const isInvisiblySmallElement: (element: ExcalidrawElement) => boolean;
4
- /**
5
- * Makes a perfect shape or diagonal/horizontal/vertical line
6
- */
7
- export declare const getPerfectElementSize: (elementType: AppState["activeTool"]["type"], width: number, height: number) => {
8
- width: number;
9
- height: number;
10
- };
11
- export declare const getLockedLinearCursorAlignSize: (originX: number, originY: number, x: number, y: number) => {
12
- width: number;
13
- height: number;
14
- };
15
- export declare const resizePerfectLineForNWHandler: (element: ExcalidrawElement, x: number, y: number) => void;
16
- export declare const getNormalizedDimensions: (element: Pick<ExcalidrawElement, "width" | "height" | "x" | "y">) => {
17
- width: ExcalidrawElement["width"];
18
- height: ExcalidrawElement["height"];
19
- x: ExcalidrawElement["x"];
20
- y: ExcalidrawElement["y"];
21
- };
1
+ import { ExcalidrawElement } from "./types";
2
+ import { AppState } from "../types";
3
+ export declare const isInvisiblySmallElement: (element: ExcalidrawElement) => boolean;
4
+ /**
5
+ * Makes a perfect shape or diagonal/horizontal/vertical line
6
+ */
7
+ export declare const getPerfectElementSize: (elementType: AppState["activeTool"]["type"], width: number, height: number) => {
8
+ width: number;
9
+ height: number;
10
+ };
11
+ export declare const getLockedLinearCursorAlignSize: (originX: number, originY: number, x: number, y: number) => {
12
+ width: number;
13
+ height: number;
14
+ };
15
+ export declare const resizePerfectLineForNWHandler: (element: ExcalidrawElement, x: number, y: number) => void;
16
+ export declare const getNormalizedDimensions: (element: Pick<ExcalidrawElement, "width" | "height" | "x" | "y">) => {
17
+ width: ExcalidrawElement["width"];
18
+ height: ExcalidrawElement["height"];
19
+ x: ExcalidrawElement["x"];
20
+ y: ExcalidrawElement["y"];
21
+ };
@@ -1,2 +1,2 @@
1
- import { ExcalidrawElement } from "./types";
2
- export declare const normalizeElementOrder: (elements: readonly ExcalidrawElement[]) => readonly ExcalidrawElement[];
1
+ import { ExcalidrawElement } from "./types";
2
+ export declare const normalizeElementOrder: (elements: readonly ExcalidrawElement[]) => readonly ExcalidrawElement[];
@@ -1,55 +1,73 @@
1
- import { ExcalidrawElement, ExcalidrawTextContainer, ExcalidrawTextElement, ExcalidrawTextElementWithContainer, FontString, NonDeletedExcalidrawElement } from "./types";
2
- import { MaybeTransformHandleType } from "./transformHandles";
3
- import { AppState } from "../types";
4
- export declare const normalizeText: (text: string) => string;
5
- export declare const redrawTextBoundingBox: (textElement: ExcalidrawTextElement, container: ExcalidrawElement | null) => void;
6
- export declare const bindTextToShapeAfterDuplication: (sceneElements: ExcalidrawElement[], oldElements: ExcalidrawElement[], oldIdToDuplicatedId: Map<ExcalidrawElement["id"], ExcalidrawElement["id"]>) => void;
7
- export declare const handleBindTextResize: (container: NonDeletedExcalidrawElement, transformHandleType: MaybeTransformHandleType) => void;
8
- export declare const measureText: (text: string, font: FontString) => {
9
- width: number;
10
- height: number;
11
- };
12
- export declare const getApproxLineHeight: (font: FontString) => number;
13
- export declare const getTextWidth: (text: string, font: FontString) => number;
14
- export declare const getTextHeight: (text: string, font: FontString) => number;
15
- export declare const wrapText: (text: string, font: FontString, maxWidth: number) => string;
16
- export declare const charWidth: {
17
- calculate: (char: string, font: FontString) => number;
18
- getCache: (font: FontString) => number[];
19
- };
20
- export declare const getApproxMinLineWidth: (font: FontString) => number;
21
- export declare const getApproxMinLineHeight: (font: FontString) => number;
22
- export declare const getMinCharWidth: (font: FontString) => number;
23
- export declare const getMaxCharWidth: (font: FontString) => number;
24
- export declare const getApproxCharsToFitInWidth: (font: FontString, width: number) => number;
25
- export declare const getBoundTextElementId: (container: ExcalidrawElement | null) => string | null;
26
- export declare const getBoundTextElement: (element: ExcalidrawElement | null) => ExcalidrawTextElementWithContainer | null;
27
- export declare const getContainerElement: (element: (ExcalidrawElement & {
28
- containerId: ExcalidrawElement["id"] | null;
29
- }) | null) => ExcalidrawElement | null;
30
- export declare const getContainerDims: (element: ExcalidrawElement) => {
31
- width: number;
32
- height: number;
33
- };
34
- export declare const getContainerCenter: (container: ExcalidrawElement, appState: AppState) => {
35
- x: number;
36
- y: number;
37
- };
38
- export declare const getContainerCoords: (container: NonDeletedExcalidrawElement) => {
39
- x: number;
40
- y: number;
41
- };
42
- export declare const getTextElementAngle: (textElement: ExcalidrawTextElement) => number;
43
- export declare const getBoundTextElementOffset: (boundTextElement: ExcalidrawTextElement | null) => number;
44
- export declare const getBoundTextElementPosition: (container: ExcalidrawElement, boundTextElement: ExcalidrawTextElementWithContainer) => {
45
- x: number;
46
- y: number;
47
- } | undefined;
48
- export declare const shouldAllowVerticalAlign: (selectedElements: NonDeletedExcalidrawElement[]) => boolean;
49
- export declare const getTextBindableContainerAtPosition: (elements: readonly ExcalidrawElement[], appState: AppState, x: number, y: number) => ExcalidrawTextContainer | null;
50
- declare const VALID_CONTAINER_TYPES: Set<string>;
51
- export declare const isValidTextContainer: (element: ExcalidrawElement) => boolean;
52
- export declare const computeContainerDimensionForBoundText: (dimension: number, containerType: ExtractSetType<typeof VALID_CONTAINER_TYPES>, legacy?: boolean) => number;
53
- export declare const getMaxContainerWidth: (container: ExcalidrawElement) => number;
54
- export declare const getMaxContainerHeight: (container: ExcalidrawElement) => number;
55
- export {};
1
+ import { ExcalidrawElement, ExcalidrawTextContainer, ExcalidrawTextElement, ExcalidrawTextElementWithContainer, FontFamilyValues, FontString, NonDeletedExcalidrawElement } from "./types";
2
+ import { MaybeTransformHandleType } from "./transformHandles";
3
+ import { AppState } from "../types";
4
+ import { ExtractSetType } from "../utility-types";
5
+ export declare const normalizeText: (text: string) => string;
6
+ export declare const splitIntoLines: (text: string) => string[];
7
+ export declare const redrawTextBoundingBox: (textElement: ExcalidrawTextElement, container: ExcalidrawElement | null) => void;
8
+ export declare const bindTextToShapeAfterDuplication: (sceneElements: ExcalidrawElement[], oldElements: ExcalidrawElement[], oldIdToDuplicatedId: Map<ExcalidrawElement["id"], ExcalidrawElement["id"]>) => void;
9
+ export declare const handleBindTextResize: (container: NonDeletedExcalidrawElement, transformHandleType: MaybeTransformHandleType) => void;
10
+ export declare const measureText: (text: string, font: FontString, lineHeight: ExcalidrawTextElement["lineHeight"]) => {
11
+ width: number;
12
+ height: number;
13
+ };
14
+ /**
15
+ * To get unitless line-height (if unknown) we can calculate it by dividing
16
+ * height-per-line by fontSize.
17
+ */
18
+ export declare const detectLineHeight: (textElement: ExcalidrawTextElement) => number & {
19
+ _brand: "unitlessLineHeight";
20
+ };
21
+ /**
22
+ * We calculate the line height from the font size and the unitless line height,
23
+ * aligning with the W3C spec.
24
+ */
25
+ export declare const getLineHeightInPx: (fontSize: ExcalidrawTextElement["fontSize"], lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
26
+ export declare const getApproxMinLineHeight: (fontSize: ExcalidrawTextElement["fontSize"], lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
27
+ export declare const getTextWidth: (text: string, font: FontString) => number;
28
+ export declare const getTextHeight: (text: string, fontSize: number, lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
29
+ export declare const wrapText: (text: string, font: FontString, maxWidth: number) => string;
30
+ export declare const charWidth: {
31
+ calculate: (char: string, font: FontString) => number;
32
+ getCache: (font: FontString) => number[];
33
+ };
34
+ export declare const getApproxMinLineWidth: (font: FontString, lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
35
+ export declare const getMinCharWidth: (font: FontString) => number;
36
+ export declare const getMaxCharWidth: (font: FontString) => number;
37
+ export declare const getApproxCharsToFitInWidth: (font: FontString, width: number) => number;
38
+ export declare const getBoundTextElementId: (container: ExcalidrawElement | null) => string | null;
39
+ export declare const getBoundTextElement: (element: ExcalidrawElement | null) => ExcalidrawTextElementWithContainer | null;
40
+ export declare const getContainerElement: (element: (ExcalidrawElement & {
41
+ containerId: ExcalidrawElement["id"] | null;
42
+ }) | null) => ExcalidrawElement | null;
43
+ export declare const getContainerDims: (element: ExcalidrawElement) => {
44
+ width: number;
45
+ height: number;
46
+ };
47
+ export declare const getContainerCenter: (container: ExcalidrawElement, appState: AppState) => {
48
+ x: number;
49
+ y: number;
50
+ };
51
+ export declare const getContainerCoords: (container: NonDeletedExcalidrawElement) => {
52
+ x: number;
53
+ y: number;
54
+ };
55
+ export declare const getTextElementAngle: (textElement: ExcalidrawTextElement) => number;
56
+ export declare const getBoundTextElementOffset: (boundTextElement: ExcalidrawTextElement | null) => number;
57
+ export declare const getBoundTextElementPosition: (container: ExcalidrawElement, boundTextElement: ExcalidrawTextElementWithContainer) => {
58
+ x: number;
59
+ y: number;
60
+ } | undefined;
61
+ export declare const shouldAllowVerticalAlign: (selectedElements: NonDeletedExcalidrawElement[]) => boolean;
62
+ export declare const suppportsHorizontalAlign: (selectedElements: NonDeletedExcalidrawElement[]) => boolean;
63
+ export declare const getTextBindableContainerAtPosition: (elements: readonly ExcalidrawElement[], appState: AppState, x: number, y: number) => ExcalidrawTextContainer | null;
64
+ declare const VALID_CONTAINER_TYPES: Set<string>;
65
+ export declare const isValidTextContainer: (element: ExcalidrawElement) => boolean;
66
+ export declare const computeContainerDimensionForBoundText: (dimension: number, containerType: ExtractSetType<typeof VALID_CONTAINER_TYPES>, legacy?: boolean) => number;
67
+ export declare const getMaxContainerWidth: (container: ExcalidrawElement) => number;
68
+ export declare const getMaxContainerHeight: (container: ExcalidrawElement) => number;
69
+ export declare const isMeasureTextSupported: () => boolean;
70
+ export declare const getDefaultLineHeight: (fontFamily: FontFamilyValues) => number & {
71
+ _brand: "unitlessLineHeight";
72
+ };
73
+ export {};
@@ -1,21 +1,21 @@
1
- import { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawTextContainer } from "./types";
2
- import App from "../components/App";
3
- export declare const updateOriginalContainerCache: (id: ExcalidrawTextContainer["id"], height: ExcalidrawTextContainer["height"]) => {
4
- height: ExcalidrawTextContainer["height"];
5
- };
6
- export declare const resetOriginalContainerCache: (id: ExcalidrawTextContainer["id"]) => void;
7
- export declare const getOriginalContainerHeightFromCache: (id: ExcalidrawTextContainer["id"]) => number | null;
8
- export declare const textWysiwyg: ({ id, onChange, onSubmit, getViewportCoords, element, canvas, excalidrawContainer, app, }: {
9
- id: ExcalidrawElement["id"];
10
- onChange?: ((text: string) => void) | undefined;
11
- onSubmit: (data: {
12
- text: string;
13
- viaKeyboard: boolean;
14
- originalText: string;
15
- }) => void;
16
- getViewportCoords: (x: number, y: number) => [number, number];
17
- element: ExcalidrawTextElement;
18
- canvas: HTMLCanvasElement | null;
19
- excalidrawContainer: HTMLDivElement | null;
20
- app: App;
21
- }) => void;
1
+ import { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawTextContainer } from "./types";
2
+ import App from "../components/App";
3
+ export declare const updateOriginalContainerCache: (id: ExcalidrawTextContainer["id"], height: ExcalidrawTextContainer["height"]) => {
4
+ height: ExcalidrawTextContainer["height"];
5
+ };
6
+ export declare const resetOriginalContainerCache: (id: ExcalidrawTextContainer["id"]) => void;
7
+ export declare const getOriginalContainerHeightFromCache: (id: ExcalidrawTextContainer["id"]) => number | null;
8
+ export declare const textWysiwyg: ({ id, onChange, onSubmit, getViewportCoords, element, canvas, excalidrawContainer, app, }: {
9
+ id: ExcalidrawElement["id"];
10
+ onChange?: ((text: string) => void) | undefined;
11
+ onSubmit: (data: {
12
+ text: string;
13
+ viaKeyboard: boolean;
14
+ originalText: string;
15
+ }) => void;
16
+ getViewportCoords: (x: number, y: number) => [number, number];
17
+ element: ExcalidrawTextElement;
18
+ canvas: HTMLCanvasElement | null;
19
+ excalidrawContainer: HTMLDivElement | null;
20
+ app: App;
21
+ }) => void;
@@ -1,28 +1,28 @@
1
- import { ExcalidrawElement, NonDeletedExcalidrawElement, PointerType } from "./types";
2
- import { AppState, Zoom } from "../types";
3
- export declare type TransformHandleDirection = "n" | "s" | "w" | "e" | "nw" | "ne" | "sw" | "se";
4
- export declare type TransformHandleType = TransformHandleDirection | "rotation";
5
- export declare type TransformHandle = [number, number, number, number];
6
- export declare type TransformHandles = Partial<{
7
- [T in TransformHandleType]: TransformHandle;
8
- }>;
9
- export declare type MaybeTransformHandleType = TransformHandleType | false;
10
- export declare const OMIT_SIDES_FOR_MULTIPLE_ELEMENTS: {
11
- e: boolean;
12
- s: boolean;
13
- n: boolean;
14
- w: boolean;
15
- };
16
- export declare const getTransformHandlesFromCoords: ([x1, y1, x2, y2, cx, cy]: [number, number, number, number, number, number], angle: number, zoom: Zoom, pointerType: PointerType, omitSides?: {
17
- s?: boolean | undefined;
18
- e?: boolean | undefined;
19
- n?: boolean | undefined;
20
- w?: boolean | undefined;
21
- nw?: boolean | undefined;
22
- ne?: boolean | undefined;
23
- sw?: boolean | undefined;
24
- se?: boolean | undefined;
25
- rotation?: boolean | undefined;
26
- }, margin?: number) => TransformHandles;
27
- export declare const getTransformHandles: (element: ExcalidrawElement, zoom: Zoom, pointerType?: PointerType) => TransformHandles;
28
- export declare const shouldShowBoundingBox: (elements: NonDeletedExcalidrawElement[], appState: AppState) => boolean;
1
+ import { ExcalidrawElement, NonDeletedExcalidrawElement, PointerType } from "./types";
2
+ import { AppState, Zoom } from "../types";
3
+ export declare type TransformHandleDirection = "n" | "s" | "w" | "e" | "nw" | "ne" | "sw" | "se";
4
+ export declare type TransformHandleType = TransformHandleDirection | "rotation";
5
+ export declare type TransformHandle = [number, number, number, number];
6
+ export declare type TransformHandles = Partial<{
7
+ [T in TransformHandleType]: TransformHandle;
8
+ }>;
9
+ export declare type MaybeTransformHandleType = TransformHandleType | false;
10
+ export declare const OMIT_SIDES_FOR_MULTIPLE_ELEMENTS: {
11
+ e: boolean;
12
+ s: boolean;
13
+ n: boolean;
14
+ w: boolean;
15
+ };
16
+ export declare const getTransformHandlesFromCoords: ([x1, y1, x2, y2, cx, cy]: [number, number, number, number, number, number], angle: number, zoom: Zoom, pointerType: PointerType, omitSides?: {
17
+ s?: boolean | undefined;
18
+ e?: boolean | undefined;
19
+ n?: boolean | undefined;
20
+ w?: boolean | undefined;
21
+ nw?: boolean | undefined;
22
+ ne?: boolean | undefined;
23
+ sw?: boolean | undefined;
24
+ se?: boolean | undefined;
25
+ rotation?: boolean | undefined;
26
+ }, margin?: number) => TransformHandles;
27
+ export declare const getTransformHandles: (element: ExcalidrawElement, zoom: Zoom, pointerType?: PointerType) => TransformHandles;
28
+ export declare const shouldShowBoundingBox: (elements: NonDeletedExcalidrawElement[], appState: AppState) => boolean;
@@ -1,26 +1,27 @@
1
- import { AppState } from "../types";
2
- import { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawBindableElement, ExcalidrawGenericElement, ExcalidrawFreeDrawElement, InitializedExcalidrawImageElement, ExcalidrawImageElement, ExcalidrawTextElementWithContainer, ExcalidrawTextContainer, RoundnessType } from "./types";
3
- export declare const isGenericElement: (element: ExcalidrawElement | null) => element is ExcalidrawGenericElement;
4
- export declare const isInitializedImageElement: (element: ExcalidrawElement | null) => element is InitializedExcalidrawImageElement;
5
- export declare const isImageElement: (element: ExcalidrawElement | null) => element is ExcalidrawImageElement;
6
- export declare const isTextElement: (element: ExcalidrawElement | null) => element is ExcalidrawTextElement;
7
- export declare const isFreeDrawElement: (element?: ExcalidrawElement | null) => element is ExcalidrawFreeDrawElement;
8
- export declare const isFreeDrawElementType: (elementType: ExcalidrawElement["type"]) => boolean;
9
- export declare const isLinearElement: (element?: ExcalidrawElement | null) => element is ExcalidrawLinearElement;
10
- export declare const isArrowElement: (element?: ExcalidrawElement | null) => element is ExcalidrawLinearElement;
11
- export declare const isLinearElementType: (elementType: AppState["activeTool"]["type"]) => boolean;
12
- export declare const isBindingElement: (element?: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawLinearElement;
13
- export declare const isBindingElementType: (elementType: AppState["activeTool"]["type"]) => boolean;
14
- export declare const isBindableElement: (element: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawBindableElement;
15
- export declare const isTextBindableContainer: (element: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawTextContainer;
16
- export declare const isExcalidrawElement: (element: any) => boolean;
17
- export declare const hasBoundTextElement: (element: ExcalidrawElement | null) => element is MarkNonNullable<ExcalidrawBindableElement, "boundElements">;
18
- export declare const isBoundToContainer: (element: ExcalidrawElement | null) => element is ExcalidrawTextElementWithContainer;
19
- export declare const isUsingAdaptiveRadius: (type: string) => boolean;
20
- export declare const isUsingProportionalRadius: (type: string) => boolean;
21
- export declare const canApplyRoundnessTypeToElement: (roundnessType: RoundnessType, element: ExcalidrawElement) => boolean;
22
- export declare const getDefaultRoundnessTypeForElement: (element: ExcalidrawElement) => {
23
- type: 2;
24
- } | {
25
- type: 3;
26
- } | null;
1
+ import { AppState } from "../types";
2
+ import { MarkNonNullable } from "../utility-types";
3
+ import { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawBindableElement, ExcalidrawGenericElement, ExcalidrawFreeDrawElement, InitializedExcalidrawImageElement, ExcalidrawImageElement, ExcalidrawTextElementWithContainer, ExcalidrawTextContainer, RoundnessType } from "./types";
4
+ export declare const isGenericElement: (element: ExcalidrawElement | null) => element is ExcalidrawGenericElement;
5
+ export declare const isInitializedImageElement: (element: ExcalidrawElement | null) => element is InitializedExcalidrawImageElement;
6
+ export declare const isImageElement: (element: ExcalidrawElement | null) => element is ExcalidrawImageElement;
7
+ export declare const isTextElement: (element: ExcalidrawElement | null) => element is ExcalidrawTextElement;
8
+ export declare const isFreeDrawElement: (element?: ExcalidrawElement | null) => element is ExcalidrawFreeDrawElement;
9
+ export declare const isFreeDrawElementType: (elementType: ExcalidrawElement["type"]) => boolean;
10
+ export declare const isLinearElement: (element?: ExcalidrawElement | null) => element is ExcalidrawLinearElement;
11
+ export declare const isArrowElement: (element?: ExcalidrawElement | null) => element is ExcalidrawLinearElement;
12
+ export declare const isLinearElementType: (elementType: AppState["activeTool"]["type"]) => boolean;
13
+ export declare const isBindingElement: (element?: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawLinearElement;
14
+ export declare const isBindingElementType: (elementType: AppState["activeTool"]["type"]) => boolean;
15
+ export declare const isBindableElement: (element: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawBindableElement;
16
+ export declare const isTextBindableContainer: (element: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawTextContainer;
17
+ export declare const isExcalidrawElement: (element: any) => boolean;
18
+ export declare const hasBoundTextElement: (element: ExcalidrawElement | null) => element is MarkNonNullable<ExcalidrawBindableElement, "boundElements">;
19
+ export declare const isBoundToContainer: (element: ExcalidrawElement | null) => element is ExcalidrawTextElementWithContainer;
20
+ export declare const isUsingAdaptiveRadius: (type: string) => boolean;
21
+ export declare const isUsingProportionalRadius: (type: string) => boolean;
22
+ export declare const canApplyRoundnessTypeToElement: (roundnessType: RoundnessType, element: ExcalidrawElement) => boolean;
23
+ export declare const getDefaultRoundnessTypeForElement: (element: ExcalidrawElement) => {
24
+ type: 2;
25
+ } | {
26
+ type: 3;
27
+ } | null;