@zsviczian/excalidraw 0.17.1-obsidian-43 → 0.17.1-obsidian-44
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/excalidraw.development.js +87 -76
- package/dist/excalidraw.production.min.js +1 -1
- package/dist/excalidraw.production.min.js.LICENSE.txt +2 -0
- package/dist/styles.development.css +72 -9
- package/dist/styles.production.css +4 -4
- package/package.json +1 -1
- package/types/excalidraw/actions/actionAddToLibrary.d.ts +575 -575
- package/types/excalidraw/actions/actionAlign.d.ts +108 -108
- package/types/excalidraw/actions/actionBoundText.d.ts +420 -420
- package/types/excalidraw/actions/actionCanvas.d.ts +2802 -2802
- package/types/excalidraw/actions/actionClipboard.d.ts +1436 -1436
- package/types/excalidraw/actions/actionDeleteSelected.d.ts +609 -609
- package/types/excalidraw/actions/actionDistribute.d.ts +34 -34
- package/types/excalidraw/actions/actionDuplicateSelection.d.ts +21 -21
- package/types/excalidraw/actions/actionElementLock.d.ts +408 -408
- package/types/excalidraw/actions/actionExport.d.ts +1794 -1794
- package/types/excalidraw/actions/actionFinalize.d.ts +389 -389
- package/types/excalidraw/actions/actionFlip.d.ts +34 -34
- package/types/excalidraw/actions/actionFrame.d.ts +815 -815
- package/types/excalidraw/actions/actionGroup.d.ts +418 -418
- package/types/excalidraw/actions/actionHistory.d.ts +7 -7
- package/types/excalidraw/actions/actionLinearEditor.d.ts +205 -205
- package/types/excalidraw/actions/actionLink.d.ts +205 -205
- package/types/excalidraw/actions/actionMenu.d.ts +598 -598
- package/types/excalidraw/actions/actionNavigate.d.ts +394 -394
- package/types/excalidraw/actions/actionProperties.d.ts +3006 -3006
- package/types/excalidraw/actions/actionSelectAll.d.ts +204 -204
- package/types/excalidraw/actions/actionStyles.d.ts +218 -218
- package/types/excalidraw/actions/actionTextAutoResize.d.ts +17 -17
- package/types/excalidraw/actions/actionToggleGridMode.d.ts +207 -207
- package/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +205 -205
- package/types/excalidraw/actions/actionToggleStats.d.ts +205 -205
- package/types/excalidraw/actions/actionToggleViewMode.d.ts +206 -206
- package/types/excalidraw/actions/actionToggleZenMode.d.ts +206 -206
- package/types/excalidraw/actions/actionZindex.d.ts +74 -74
- package/types/excalidraw/actions/index.d.ts +25 -25
- package/types/excalidraw/actions/manager.d.ts +21 -21
- package/types/excalidraw/actions/register.d.ts +5 -5
- package/types/excalidraw/actions/shortcuts.d.ts +4 -4
- package/types/excalidraw/actions/types.d.ts +47 -47
- package/types/excalidraw/align.d.ts +6 -6
- package/types/excalidraw/analytics.d.ts +1 -1
- package/types/excalidraw/animated-trail.d.ts +33 -33
- package/types/excalidraw/animation-frame-handler.d.ts +16 -16
- package/types/excalidraw/appState.d.ts +89 -89
- package/types/excalidraw/binaryheap.d.ts +12 -12
- package/types/excalidraw/change.d.ts +191 -191
- package/types/excalidraw/charts.d.ts +27 -27
- package/types/excalidraw/clients.d.ts +14 -14
- package/types/excalidraw/clipboard.d.ts +44 -44
- package/types/excalidraw/colors.d.ts +61 -61
- package/types/excalidraw/components/Actions.d.ts +34 -34
- package/types/excalidraw/components/ActiveConfirmDialog.d.ts +4 -4
- package/types/excalidraw/components/App.d.ts +527 -527
- package/types/excalidraw/components/Avatar.d.ts +11 -11
- package/types/excalidraw/components/BraveMeasureTextError.d.ts +2 -2
- package/types/excalidraw/components/Button.d.ts +17 -17
- package/types/excalidraw/components/ButtonIcon.d.ts +14 -14
- package/types/excalidraw/components/ButtonIconCycle.d.ts +10 -10
- package/types/excalidraw/components/ButtonIconSelect.d.ts +19 -19
- package/types/excalidraw/components/ButtonSelect.d.ts +9 -9
- package/types/excalidraw/components/ButtonSeparator.d.ts +1 -1
- package/types/excalidraw/components/Card.d.ts +6 -6
- package/types/excalidraw/components/CheckboxItem.d.ts +8 -8
- package/types/excalidraw/components/ColorPicker/ColorInput.d.ts +9 -9
- package/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +19 -19
- package/types/excalidraw/components/ColorPicker/CustomColorList.d.ts +8 -8
- package/types/excalidraw/components/ColorPicker/HotkeyLabel.d.ts +8 -8
- package/types/excalidraw/components/ColorPicker/Picker.d.ts +18 -18
- package/types/excalidraw/components/ColorPicker/PickerColorList.d.ts +10 -10
- package/types/excalidraw/components/ColorPicker/PickerHeading.d.ts +5 -5
- package/types/excalidraw/components/ColorPicker/ShadeList.d.ts +8 -8
- package/types/excalidraw/components/ColorPicker/TopPicks.d.ts +9 -9
- package/types/excalidraw/components/ColorPicker/colorPickerUtils.d.ts +21 -21
- package/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +20 -20
- package/types/excalidraw/components/CommandPalette/CommandPalette.d.ts +18 -18
- package/types/excalidraw/components/CommandPalette/defaultCommandPaletteItems.d.ts +2 -2
- package/types/excalidraw/components/CommandPalette/types.d.ts +25 -25
- package/types/excalidraw/components/ConfirmDialog.d.ts +10 -10
- package/types/excalidraw/components/ContextMenu.d.ts +16 -16
- package/types/excalidraw/components/DarkModeToggle.d.ts +7 -7
- package/types/excalidraw/components/DefaultSidebar.d.ts +29 -29
- package/types/excalidraw/components/DiagramToCodePlugin/DiagramToCodePlugin.d.ts +4 -4
- package/types/excalidraw/components/Dialog.d.ts +13 -13
- package/types/excalidraw/components/DialogActionButton.d.ts +10 -10
- package/types/excalidraw/components/ErrorDialog.d.ts +5 -5
- package/types/excalidraw/components/ExcalidrawLogo.d.ts +15 -15
- package/types/excalidraw/components/EyeDropper.d.ts +27 -27
- package/types/excalidraw/components/FilledButton.d.ts +18 -17
- package/types/excalidraw/components/FixedSideContainer.d.ts +9 -9
- package/types/excalidraw/components/FollowMode/FollowMode.d.ts +10 -10
- package/types/excalidraw/components/FontPicker/FontPicker.d.ts +21 -21
- package/types/excalidraw/components/FontPicker/FontPickerList.d.ts +25 -25
- package/types/excalidraw/components/FontPicker/FontPickerTrigger.d.ts +6 -6
- package/types/excalidraw/components/FontPicker/keyboardNavHandlers.d.ts +13 -13
- package/types/excalidraw/components/HandButton.d.ts +10 -10
- package/types/excalidraw/components/HelpButton.d.ts +7 -7
- package/types/excalidraw/components/HelpDialog.d.ts +4 -4
- package/types/excalidraw/components/HintViewer.d.ts +10 -10
- package/types/excalidraw/components/IconPicker.d.ts +14 -14
- package/types/excalidraw/components/ImageExportDialog.d.ts +14 -14
- package/types/excalidraw/components/InitializeApp.d.ts +10 -10
- package/types/excalidraw/components/InlineIcon.d.ts +3 -3
- package/types/excalidraw/components/Island.d.ts +10 -10
- package/types/excalidraw/components/JSONExportDialog.d.ts +15 -15
- package/types/excalidraw/components/LaserPointerButton.d.ts +10 -10
- package/types/excalidraw/components/LayerUI.d.ts +30 -30
- package/types/excalidraw/components/LibraryMenu.d.ts +24 -24
- package/types/excalidraw/components/LibraryMenuBrowseButton.d.ts +7 -7
- package/types/excalidraw/components/LibraryMenuControlButtons.d.ts +9 -9
- package/types/excalidraw/components/LibraryMenuHeaderContent.d.ts +17 -17
- package/types/excalidraw/components/LibraryMenuItems.d.ts +14 -14
- package/types/excalidraw/components/LibraryMenuSection.d.ts +23 -23
- package/types/excalidraw/components/LibraryUnit.d.ts +14 -14
- package/types/excalidraw/components/LoadingMessage.d.ts +5 -5
- package/types/excalidraw/components/LockButton.d.ts +10 -10
- package/types/excalidraw/components/MagicButton.d.ts +9 -9
- package/types/excalidraw/components/MagicSettings.d.ts +8 -0
- package/types/excalidraw/components/MobileMenu.d.ts +24 -24
- package/types/excalidraw/components/Modal.d.ts +14 -14
- package/types/excalidraw/components/OverwriteConfirm/OverwriteConfirm.d.ts +17 -17
- package/types/excalidraw/components/OverwriteConfirm/OverwriteConfirmActions.d.ts +17 -17
- package/types/excalidraw/components/OverwriteConfirm/OverwriteConfirmState.d.ts +22 -22
- package/types/excalidraw/components/Paragraph.d.ts +4 -4
- package/types/excalidraw/components/PasteChartDialog.d.ts +8 -8
- package/types/excalidraw/components/PenModeButton.d.ts +12 -12
- package/types/excalidraw/components/Popover.d.ts +15 -15
- package/types/excalidraw/components/ProjectName.d.ts +10 -10
- package/types/excalidraw/components/PropertiesPopover.d.ts +15 -15
- package/types/excalidraw/components/PublishLibrary.d.ts +16 -16
- package/types/excalidraw/components/QuickSearch.d.ts +9 -9
- package/types/excalidraw/components/RadioGroup.d.ts +13 -13
- package/types/excalidraw/components/SVGLayer.d.ts +7 -7
- package/types/excalidraw/components/ScrollableList.d.ts +8 -8
- package/types/excalidraw/components/Section.d.ts +6 -6
- package/types/excalidraw/components/ShareableLinkDialog.d.ts +7 -7
- package/types/excalidraw/components/Sidebar/Sidebar.d.ts +76 -76
- package/types/excalidraw/components/Sidebar/SidebarHeader.d.ts +7 -7
- package/types/excalidraw/components/Sidebar/SidebarTab.d.ts +8 -8
- package/types/excalidraw/components/Sidebar/SidebarTabTrigger.d.ts +9 -9
- package/types/excalidraw/components/Sidebar/SidebarTabTriggers.d.ts +6 -6
- package/types/excalidraw/components/Sidebar/SidebarTabs.d.ts +6 -6
- package/types/excalidraw/components/Sidebar/SidebarTrigger.d.ts +6 -6
- package/types/excalidraw/components/Sidebar/common.d.ts +33 -33
- package/types/excalidraw/components/Spinner.d.ts +8 -7
- package/types/excalidraw/components/Stack.d.ts +16 -16
- package/types/excalidraw/components/Stats/Angle.d.ts +11 -11
- package/types/excalidraw/components/Stats/CanvasGrid.d.ts +10 -10
- package/types/excalidraw/components/Stats/CanvasGridSize.d.ts +10 -10
- package/types/excalidraw/components/Stats/Collapsible.d.ts +8 -8
- package/types/excalidraw/components/Stats/Dimension.d.ts +11 -11
- package/types/excalidraw/components/Stats/DragInput.d.ts +34 -34
- package/types/excalidraw/components/Stats/FontSize.d.ts +11 -11
- package/types/excalidraw/components/Stats/MultiAngle.d.ts +11 -11
- package/types/excalidraw/components/Stats/MultiDimension.d.ts +14 -14
- package/types/excalidraw/components/Stats/MultiFontSize.d.ts +12 -12
- package/types/excalidraw/components/Stats/MultiPosition.d.ts +14 -14
- package/types/excalidraw/components/Stats/Position.d.ts +12 -12
- package/types/excalidraw/components/Stats/index.d.ts +35 -35
- package/types/excalidraw/components/Stats/utils.d.ts +26 -26
- package/types/excalidraw/components/Stats.d.ts +11 -0
- package/types/excalidraw/components/Switch.d.ts +9 -9
- package/types/excalidraw/components/TTDDialog/MermaidToExcalidraw.d.ts +14 -14
- package/types/excalidraw/components/TTDDialog/TTDDialog.d.ts +29 -29
- package/types/excalidraw/components/TTDDialog/TTDDialogInput.d.ts +9 -9
- package/types/excalidraw/components/TTDDialog/TTDDialogOutput.d.ts +7 -7
- package/types/excalidraw/components/TTDDialog/TTDDialogPanel.d.ts +17 -17
- package/types/excalidraw/components/TTDDialog/TTDDialogPanels.d.ts +4 -4
- package/types/excalidraw/components/TTDDialog/TTDDialogSubmitShortcut.d.ts +1 -1
- package/types/excalidraw/components/TTDDialog/TTDDialogTab.d.ts +7 -7
- package/types/excalidraw/components/TTDDialog/TTDDialogTabTrigger.d.ts +8 -8
- package/types/excalidraw/components/TTDDialog/TTDDialogTabTriggers.d.ts +6 -6
- package/types/excalidraw/components/TTDDialog/TTDDialogTabs.d.ts +11 -11
- package/types/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +8 -8
- package/types/excalidraw/components/TTDDialog/common.d.ts +32 -32
- package/types/excalidraw/components/TextField.d.ts +19 -19
- package/types/excalidraw/components/Toast.d.ts +9 -9
- package/types/excalidraw/components/ToolButton.d.ts +49 -49
- package/types/excalidraw/components/Tooltip.d.ts +18 -18
- package/types/excalidraw/components/Trans.d.ts +9 -9
- package/types/excalidraw/components/UserList.d.ts +18 -18
- package/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +29 -29
- package/types/excalidraw/components/canvases/NewElementCanvas.d.ts +14 -14
- package/types/excalidraw/components/canvases/StaticCanvas.d.ts +19 -19
- package/types/excalidraw/components/canvases/index.d.ts +3 -3
- package/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +86 -86
- package/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +15 -15
- package/types/excalidraw/components/dropdownMenu/DropdownMenuGroup.d.ts +11 -11
- package/types/excalidraw/components/dropdownMenu/DropdownMenuItem.d.ts +45 -45
- package/types/excalidraw/components/dropdownMenu/DropdownMenuItemContent.d.ts +7 -7
- package/types/excalidraw/components/dropdownMenu/DropdownMenuItemContentRadio.d.ts +17 -17
- package/types/excalidraw/components/dropdownMenu/DropdownMenuItemCustom.d.ts +7 -7
- package/types/excalidraw/components/dropdownMenu/DropdownMenuItemLink.d.ts +15 -15
- package/types/excalidraw/components/dropdownMenu/DropdownMenuSeparator.d.ts +5 -5
- package/types/excalidraw/components/dropdownMenu/DropdownMenuTrigger.d.ts +10 -10
- package/types/excalidraw/components/dropdownMenu/common.d.ts +6 -6
- package/types/excalidraw/components/dropdownMenu/dropdownMenuUtils.d.ts +3 -3
- package/types/excalidraw/components/footer/Footer.d.ts +12 -12
- package/types/excalidraw/components/footer/FooterCenter.d.ts +8 -8
- package/types/excalidraw/components/hoc/withInternalFallback.d.ts +4 -4
- package/types/excalidraw/components/hyperlink/Hyperlink.d.ts +18 -18
- package/types/excalidraw/components/hyperlink/helpers.d.ts +7 -7
- package/types/excalidraw/components/icons.d.ts +211 -211
- package/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +9 -9
- package/types/excalidraw/components/main-menu/DefaultItems.d.ts +58 -58
- package/types/excalidraw/components/main-menu/MainMenu.d.ts +80 -80
- package/types/excalidraw/components/welcome-screen/WelcomeScreen.Center.d.ts +59 -59
- package/types/excalidraw/components/welcome-screen/WelcomeScreen.Hints.d.ts +19 -19
- package/types/excalidraw/components/welcome-screen/WelcomeScreen.d.ts +86 -86
- package/types/excalidraw/constants.d.ts +314 -313
- package/types/excalidraw/context/tunnels.d.ts +20 -20
- package/types/excalidraw/context/ui-appState.d.ts +4 -4
- package/types/excalidraw/cursor.d.ts +6 -6
- package/types/excalidraw/data/EditorLocalStorage.d.ts +8 -8
- package/types/excalidraw/data/ai/types.d.ts +242 -242
- package/types/excalidraw/data/blob.d.ts +49 -49
- package/types/excalidraw/data/encode.d.ts +53 -53
- package/types/excalidraw/data/encryption.d.ts +9 -9
- package/types/excalidraw/data/filesystem.d.ts +20 -20
- package/types/excalidraw/data/image.d.ts +15 -15
- package/types/excalidraw/data/index.d.ts +22 -22
- package/types/excalidraw/data/json.d.ts +16 -16
- package/types/excalidraw/data/library.d.ts +106 -106
- package/types/excalidraw/data/magic.d.ts +23 -0
- package/types/excalidraw/data/reconcile.d.ts +6 -6
- package/types/excalidraw/data/resave.d.ts +5 -5
- package/types/excalidraw/data/restore.d.ts +21 -21
- package/types/excalidraw/data/transform.d.ts +81 -81
- package/types/excalidraw/data/types.d.ts +45 -45
- package/types/excalidraw/data/url.d.ts +8 -8
- package/types/excalidraw/deburr.d.ts +1 -1
- package/types/excalidraw/dist/excalidraw.development.d.ts +2 -2
- package/types/excalidraw/dist/excalidraw.production.min.d.ts +1 -1
- package/types/excalidraw/distribute.d.ts +6 -6
- package/types/excalidraw/element/ElementCanvasButtons.d.ts +7 -7
- package/types/excalidraw/element/binding.d.ts +97 -97
- package/types/excalidraw/element/bounds.d.ts +74 -74
- package/types/excalidraw/element/collision.d.ts +16 -16
- package/types/excalidraw/element/containerCache.d.ts +11 -11
- package/types/excalidraw/element/dragElements.d.ts +32 -32
- package/types/excalidraw/element/embeddable.d.ts +211 -211
- package/types/excalidraw/element/flowchart.d.ts +25 -25
- package/types/excalidraw/element/heading.d.ts +11 -11
- package/types/excalidraw/element/image.d.ts +32 -32
- package/types/excalidraw/element/index.d.ts +26 -26
- package/types/excalidraw/element/linearElementEditor.d.ts +344 -344
- package/types/excalidraw/element/mutateElement.d.ts +11 -11
- package/types/excalidraw/element/newElement.d.ts +106 -106
- package/types/excalidraw/element/resizeElements.d.ts +17 -17
- package/types/excalidraw/element/resizeTest.d.ts +14 -14
- package/types/excalidraw/element/routing.d.ts +10 -10
- package/types/excalidraw/element/showSelectedShapeActions.d.ts +3 -3
- package/types/excalidraw/element/sizeHelpers.d.ts +40 -40
- package/types/excalidraw/element/sortElements.d.ts +2 -2
- package/types/excalidraw/element/textElement.d.ts +70 -70
- package/types/excalidraw/element/textWysiwyg.d.ts +22 -22
- package/types/excalidraw/element/transformHandles.d.ts +54 -54
- package/types/excalidraw/element/typeChecks.d.ts +42 -37
- package/types/excalidraw/element/types.d.ts +253 -253
- package/types/excalidraw/emitter.d.ts +16 -16
- package/types/excalidraw/entry.d.ts +1 -1
- package/types/excalidraw/env.d.cts +1 -1
- package/types/excalidraw/env.d.ts +1 -1
- package/types/excalidraw/errors.d.ts +16 -16
- package/types/excalidraw/fonts/ExcalidrawFont.d.ts +21 -21
- package/types/excalidraw/fonts/index.d.ts +83 -83
- package/types/excalidraw/fonts/metadata.d.ts +35 -35
- package/types/excalidraw/fractionalIndex.d.ts +48 -48
- package/types/excalidraw/frame.d.ts +63 -63
- package/types/excalidraw/ga.d.ts +63 -63
- package/types/excalidraw/gadirections.d.ts +8 -8
- package/types/excalidraw/galines.d.ts +22 -22
- package/types/excalidraw/gapoints.d.ts +7 -7
- package/types/excalidraw/gatransforms.d.ts +10 -10
- package/types/excalidraw/gesture.d.ts +6 -6
- package/types/excalidraw/groups.d.ts +33 -33
- package/types/excalidraw/history.d.ts +40 -40
- package/types/excalidraw/hooks/useCallbackRefState.d.ts +1 -1
- package/types/excalidraw/hooks/useCopiedIndicator.d.ts +5 -0
- package/types/excalidraw/hooks/useCreatePortalContainer.d.ts +7 -7
- package/types/excalidraw/hooks/useEmitter.d.ts +2 -2
- package/types/excalidraw/hooks/useLibraryItemSvg.d.ts +11 -11
- package/types/excalidraw/hooks/useOutsideClick.d.ts +19 -19
- package/types/excalidraw/hooks/useScrollPosition.d.ts +1 -1
- package/types/excalidraw/hooks/useStable.d.ts +1 -1
- package/types/excalidraw/hooks/useStableCallback.d.ts +4 -4
- package/types/excalidraw/hooks/useTransition.d.ts +2 -2
- package/types/excalidraw/i18n.d.ts +24 -24
- package/types/excalidraw/index-node.d.ts +1 -1
- package/types/excalidraw/index.d.ts +61 -61
- package/types/excalidraw/jotai.d.ts +34 -34
- package/types/excalidraw/keys.d.ts +82 -82
- package/types/excalidraw/laser-trails.d.ts +20 -20
- package/types/excalidraw/main.d.ts +2 -2
- package/types/excalidraw/math.d.ts +79 -79
- package/types/excalidraw/mermaid.d.ts +2 -2
- package/types/excalidraw/obsidianUtils.d.ts +17 -17
- package/types/excalidraw/points.d.ts +7 -7
- package/types/excalidraw/polyfill.d.ts +2 -2
- package/types/excalidraw/publicPath.d.ts +1 -1
- package/types/excalidraw/queue.d.ts +9 -9
- package/types/excalidraw/random.d.ts +4 -4
- package/types/excalidraw/reactUtils.d.ts +14 -14
- package/types/excalidraw/renderer/easingFunctions.d.ts +6 -6
- package/types/excalidraw/renderer/helpers.d.ts +13 -13
- package/types/excalidraw/renderer/interactiveScene.d.ts +20 -20
- package/types/excalidraw/renderer/renderElement.d.ts +27 -27
- package/types/excalidraw/renderer/renderNewElementScene.d.ts +7 -7
- package/types/excalidraw/renderer/renderSnaps.d.ts +2 -2
- package/types/excalidraw/renderer/roundRect.d.ts +11 -11
- package/types/excalidraw/renderer/staticScene.d.ts +11 -11
- package/types/excalidraw/renderer/staticSvgScene.d.ts +5 -5
- package/types/excalidraw/scene/Fonts.d.ts +19 -0
- package/types/excalidraw/scene/Renderer.d.ts +28 -28
- package/types/excalidraw/scene/Scene.d.ts +78 -78
- package/types/excalidraw/scene/Shape.d.ts +17 -17
- package/types/excalidraw/scene/ShapeCache.d.ts +25 -25
- package/types/excalidraw/scene/comparisons.d.ts +11 -11
- package/types/excalidraw/scene/export.d.ts +29 -29
- package/types/excalidraw/scene/index.d.ts +4 -4
- package/types/excalidraw/scene/normalize.d.ts +4 -4
- package/types/excalidraw/scene/scroll.d.ts +17 -17
- package/types/excalidraw/scene/scrollbars.d.ts +12 -12
- package/types/excalidraw/scene/selection.d.ts +32 -32
- package/types/excalidraw/scene/types.d.ts +112 -112
- package/types/excalidraw/scene/zoom.d.ts +12 -12
- package/types/excalidraw/shapes.d.ts +70 -70
- package/types/excalidraw/snapping.d.ts +109 -109
- package/types/excalidraw/store.d.ts +129 -129
- package/types/excalidraw/types.d.ts +700 -700
- package/types/excalidraw/utility-types.d.ts +31 -31
- package/types/excalidraw/utils.d.ts +243 -243
- package/types/excalidraw/visualdebug.d.ts +34 -0
- package/types/excalidraw/webpack.dev.config.d.ts +81 -81
- package/types/excalidraw/webpack.prod.config.d.ts +97 -97
- package/types/excalidraw/zindex.d.ts +6 -6
- package/types/utils/bbox.d.ts +11 -11
- package/types/utils/collision.d.ts +4 -4
- package/types/utils/export.d.ts +44 -44
- package/types/utils/geometry/geometry.d.ts +89 -89
- package/types/utils/geometry/shape.d.ts +56 -56
- package/types/utils/index.d.ts +4 -4
- package/types/utils/withinBounds.d.ts +19 -19
|
@@ -1,83 +1,83 @@
|
|
|
1
|
-
import type Scene from "../scene/Scene";
|
|
2
|
-
import type { ValueOf } from "../utility-types";
|
|
3
|
-
import type { ExcalidrawElement, ExcalidrawTextElement, FontFamilyValues } from "../element/types";
|
|
4
|
-
import { FONT_FAMILY } from "../constants";
|
|
5
|
-
import { type FontMetadata } from "./metadata";
|
|
6
|
-
import { type Font } from "./ExcalidrawFont";
|
|
7
|
-
export declare class Fonts {
|
|
8
|
-
static readonly loadedFontsCache: Set<string>;
|
|
9
|
-
private static _registered;
|
|
10
|
-
private static _initialized;
|
|
11
|
-
static get registered(): Map<number, {
|
|
12
|
-
metadata: FontMetadata;
|
|
13
|
-
fonts: Font[];
|
|
14
|
-
}>;
|
|
15
|
-
get registered(): Map<number, {
|
|
16
|
-
metadata: FontMetadata;
|
|
17
|
-
fonts: Font[];
|
|
18
|
-
}>;
|
|
19
|
-
private readonly scene;
|
|
20
|
-
constructor({ scene }: {
|
|
21
|
-
scene: Scene;
|
|
22
|
-
});
|
|
23
|
-
/**
|
|
24
|
-
* if we load a (new) font, it's likely that text elements using it have
|
|
25
|
-
* already been rendered using a fallback font. Thus, we want invalidate
|
|
26
|
-
* their shapes and rerender. See #637.
|
|
27
|
-
*
|
|
28
|
-
* Invalidates text elements and rerenders scene, provided that at least one
|
|
29
|
-
* of the supplied fontFaces has not already been processed.
|
|
30
|
-
*/
|
|
31
|
-
onLoaded: (fontFaces: readonly FontFace[]) => false | undefined;
|
|
32
|
-
/**
|
|
33
|
-
* Load font faces for a given scene and trigger scene update.
|
|
34
|
-
*/
|
|
35
|
-
loadSceneFonts: () => Promise<FontFace[]>;
|
|
36
|
-
/**
|
|
37
|
-
* Gets all the font families for the given scene.
|
|
38
|
-
*/
|
|
39
|
-
getSceneFontFamilies: () => number[];
|
|
40
|
-
/**
|
|
41
|
-
* Load font faces for passed elements - use when the scene is unavailable (i.e. export).
|
|
42
|
-
*/
|
|
43
|
-
static loadFontsForElements: (elements: readonly ExcalidrawElement[]) => Promise<FontFace[]>;
|
|
44
|
-
private static loadFontFaces;
|
|
45
|
-
/**
|
|
46
|
-
* WARN: should be called just once on init, even across multiple instances.
|
|
47
|
-
*/
|
|
48
|
-
private static init;
|
|
49
|
-
private static getFontFamilies;
|
|
50
|
-
}
|
|
51
|
-
/**
|
|
52
|
-
* Register a new font.
|
|
53
|
-
*
|
|
54
|
-
* @param family font family
|
|
55
|
-
* @param metadata font metadata
|
|
56
|
-
* @param params array of the rest of the FontFace parameters [uri: string, descriptors: FontFaceDescriptors?] ,
|
|
57
|
-
*/
|
|
58
|
-
export declare function register(//zsviczian (changed from private to export)
|
|
59
|
-
this: Fonts | {
|
|
60
|
-
registered: Map<ValueOf<typeof FONT_FAMILY>, {
|
|
61
|
-
metadata: FontMetadata;
|
|
62
|
-
fonts: Font[];
|
|
63
|
-
}>;
|
|
64
|
-
}, family: string, metadata: FontMetadata, ...params: Array<{
|
|
65
|
-
uri: string;
|
|
66
|
-
descriptors?: FontFaceDescriptors;
|
|
67
|
-
}>): Map<number, {
|
|
68
|
-
metadata: FontMetadata;
|
|
69
|
-
fonts: Font[];
|
|
70
|
-
}> | Map<number, {
|
|
71
|
-
metadata: FontMetadata;
|
|
72
|
-
fonts: Font[];
|
|
73
|
-
}>;
|
|
74
|
-
/**
|
|
75
|
-
* Calculates vertical offset for a text with alphabetic baseline.
|
|
76
|
-
*/
|
|
77
|
-
export declare const getVerticalOffset: (fontFamily: ExcalidrawTextElement["fontFamily"], fontSize: ExcalidrawTextElement["fontSize"], lineHeightPx: number) => number;
|
|
78
|
-
/**
|
|
79
|
-
* Gets line height forr a selected family.
|
|
80
|
-
*/
|
|
81
|
-
export declare const getLineHeight: (fontFamily: FontFamilyValues) => number & {
|
|
82
|
-
_brand: "unitlessLineHeight";
|
|
83
|
-
};
|
|
1
|
+
import type Scene from "../scene/Scene";
|
|
2
|
+
import type { ValueOf } from "../utility-types";
|
|
3
|
+
import type { ExcalidrawElement, ExcalidrawTextElement, FontFamilyValues } from "../element/types";
|
|
4
|
+
import { FONT_FAMILY } from "../constants";
|
|
5
|
+
import { type FontMetadata } from "./metadata";
|
|
6
|
+
import { type Font } from "./ExcalidrawFont";
|
|
7
|
+
export declare class Fonts {
|
|
8
|
+
static readonly loadedFontsCache: Set<string>;
|
|
9
|
+
private static _registered;
|
|
10
|
+
private static _initialized;
|
|
11
|
+
static get registered(): Map<number, {
|
|
12
|
+
metadata: FontMetadata;
|
|
13
|
+
fonts: Font[];
|
|
14
|
+
}>;
|
|
15
|
+
get registered(): Map<number, {
|
|
16
|
+
metadata: FontMetadata;
|
|
17
|
+
fonts: Font[];
|
|
18
|
+
}>;
|
|
19
|
+
private readonly scene;
|
|
20
|
+
constructor({ scene }: {
|
|
21
|
+
scene: Scene;
|
|
22
|
+
});
|
|
23
|
+
/**
|
|
24
|
+
* if we load a (new) font, it's likely that text elements using it have
|
|
25
|
+
* already been rendered using a fallback font. Thus, we want invalidate
|
|
26
|
+
* their shapes and rerender. See #637.
|
|
27
|
+
*
|
|
28
|
+
* Invalidates text elements and rerenders scene, provided that at least one
|
|
29
|
+
* of the supplied fontFaces has not already been processed.
|
|
30
|
+
*/
|
|
31
|
+
onLoaded: (fontFaces: readonly FontFace[]) => false | undefined;
|
|
32
|
+
/**
|
|
33
|
+
* Load font faces for a given scene and trigger scene update.
|
|
34
|
+
*/
|
|
35
|
+
loadSceneFonts: () => Promise<FontFace[]>;
|
|
36
|
+
/**
|
|
37
|
+
* Gets all the font families for the given scene.
|
|
38
|
+
*/
|
|
39
|
+
getSceneFontFamilies: () => number[];
|
|
40
|
+
/**
|
|
41
|
+
* Load font faces for passed elements - use when the scene is unavailable (i.e. export).
|
|
42
|
+
*/
|
|
43
|
+
static loadFontsForElements: (elements: readonly ExcalidrawElement[]) => Promise<FontFace[]>;
|
|
44
|
+
private static loadFontFaces;
|
|
45
|
+
/**
|
|
46
|
+
* WARN: should be called just once on init, even across multiple instances.
|
|
47
|
+
*/
|
|
48
|
+
private static init;
|
|
49
|
+
private static getFontFamilies;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Register a new font.
|
|
53
|
+
*
|
|
54
|
+
* @param family font family
|
|
55
|
+
* @param metadata font metadata
|
|
56
|
+
* @param params array of the rest of the FontFace parameters [uri: string, descriptors: FontFaceDescriptors?] ,
|
|
57
|
+
*/
|
|
58
|
+
export declare function register(//zsviczian (changed from private to export)
|
|
59
|
+
this: Fonts | {
|
|
60
|
+
registered: Map<ValueOf<typeof FONT_FAMILY>, {
|
|
61
|
+
metadata: FontMetadata;
|
|
62
|
+
fonts: Font[];
|
|
63
|
+
}>;
|
|
64
|
+
}, family: string, metadata: FontMetadata, ...params: Array<{
|
|
65
|
+
uri: string;
|
|
66
|
+
descriptors?: FontFaceDescriptors;
|
|
67
|
+
}>): Map<number, {
|
|
68
|
+
metadata: FontMetadata;
|
|
69
|
+
fonts: Font[];
|
|
70
|
+
}> | Map<number, {
|
|
71
|
+
metadata: FontMetadata;
|
|
72
|
+
fonts: Font[];
|
|
73
|
+
}>;
|
|
74
|
+
/**
|
|
75
|
+
* Calculates vertical offset for a text with alphabetic baseline.
|
|
76
|
+
*/
|
|
77
|
+
export declare const getVerticalOffset: (fontFamily: ExcalidrawTextElement["fontFamily"], fontSize: ExcalidrawTextElement["fontSize"], lineHeightPx: number) => number;
|
|
78
|
+
/**
|
|
79
|
+
* Gets line height forr a selected family.
|
|
80
|
+
*/
|
|
81
|
+
export declare const getLineHeight: (fontFamily: FontFamilyValues) => number & {
|
|
82
|
+
_brand: "unitlessLineHeight";
|
|
83
|
+
};
|
|
@@ -1,35 +1,35 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Encapsulates font metrics with additional font metadata.
|
|
3
|
-
* */
|
|
4
|
-
export interface FontMetadata {
|
|
5
|
-
/** for head & hhea metrics read the woff2 with https://fontdrop.info/ */
|
|
6
|
-
metrics: {
|
|
7
|
-
/** head.unitsPerEm metric */
|
|
8
|
-
unitsPerEm: 1000 | 1024 | 2048;
|
|
9
|
-
/** hhea.ascender metric */
|
|
10
|
-
ascender: number;
|
|
11
|
-
/** hhea.descender metric */
|
|
12
|
-
descender: number;
|
|
13
|
-
/** harcoded unitless line-height, https://github.com/excalidraw/excalidraw/pull/6360#issuecomment-1477635971 */
|
|
14
|
-
lineHeight: number;
|
|
15
|
-
};
|
|
16
|
-
/** element to be displayed as an icon */
|
|
17
|
-
icon: JSX.Element;
|
|
18
|
-
/** flag to indicate a deprecated font */
|
|
19
|
-
deprecated?: true;
|
|
20
|
-
/** flag to indicate a server-side only font */
|
|
21
|
-
serverSide?: true;
|
|
22
|
-
/** flag to indiccate a local-only font */
|
|
23
|
-
local?: true;
|
|
24
|
-
}
|
|
25
|
-
export declare const FONT_METADATA: Record<number, FontMetadata>;
|
|
26
|
-
/** Unicode ranges */
|
|
27
|
-
export declare const RANGES: {
|
|
28
|
-
LATIN: string;
|
|
29
|
-
LATIN_EXT: string;
|
|
30
|
-
CYRILIC_EXT: string;
|
|
31
|
-
CYRILIC: string;
|
|
32
|
-
VIETNAMESE: string;
|
|
33
|
-
};
|
|
34
|
-
/** local protocol to skip the local font from registering or inlining */
|
|
35
|
-
export declare const LOCAL_FONT_PROTOCOL = "local:";
|
|
1
|
+
/**
|
|
2
|
+
* Encapsulates font metrics with additional font metadata.
|
|
3
|
+
* */
|
|
4
|
+
export interface FontMetadata {
|
|
5
|
+
/** for head & hhea metrics read the woff2 with https://fontdrop.info/ */
|
|
6
|
+
metrics: {
|
|
7
|
+
/** head.unitsPerEm metric */
|
|
8
|
+
unitsPerEm: 1000 | 1024 | 2048;
|
|
9
|
+
/** hhea.ascender metric */
|
|
10
|
+
ascender: number;
|
|
11
|
+
/** hhea.descender metric */
|
|
12
|
+
descender: number;
|
|
13
|
+
/** harcoded unitless line-height, https://github.com/excalidraw/excalidraw/pull/6360#issuecomment-1477635971 */
|
|
14
|
+
lineHeight: number;
|
|
15
|
+
};
|
|
16
|
+
/** element to be displayed as an icon */
|
|
17
|
+
icon: JSX.Element;
|
|
18
|
+
/** flag to indicate a deprecated font */
|
|
19
|
+
deprecated?: true;
|
|
20
|
+
/** flag to indicate a server-side only font */
|
|
21
|
+
serverSide?: true;
|
|
22
|
+
/** flag to indiccate a local-only font */
|
|
23
|
+
local?: true;
|
|
24
|
+
}
|
|
25
|
+
export declare const FONT_METADATA: Record<number, FontMetadata>;
|
|
26
|
+
/** Unicode ranges */
|
|
27
|
+
export declare const RANGES: {
|
|
28
|
+
LATIN: string;
|
|
29
|
+
LATIN_EXT: string;
|
|
30
|
+
CYRILIC_EXT: string;
|
|
31
|
+
CYRILIC: string;
|
|
32
|
+
VIETNAMESE: string;
|
|
33
|
+
};
|
|
34
|
+
/** local protocol to skip the local font from registering or inlining */
|
|
35
|
+
export declare const LOCAL_FONT_PROTOCOL = "local:";
|
|
@@ -1,48 +1,48 @@
|
|
|
1
|
-
import type { ExcalidrawElement, OrderedExcalidrawElement } from "./element/types";
|
|
2
|
-
/**
|
|
3
|
-
* Envisioned relation between array order and fractional indices:
|
|
4
|
-
*
|
|
5
|
-
* 1) Array (or array-like ordered data structure) should be used as a cache of elements order, hiding the internal fractional indices implementation.
|
|
6
|
-
* - it's undesirable to perform reorder for each related operation, therefore it's necessary to cache the order defined by fractional indices into an ordered data structure
|
|
7
|
-
* - it's easy enough to define the order of the elements from the outside (boundaries), without worrying about the underlying structure of fractional indices (especially for the host apps)
|
|
8
|
-
* - it's necessary to always keep the array support for backwards compatibility (restore) - old scenes, old libraries, supporting multiple excalidraw versions etc.
|
|
9
|
-
* - it's necessary to always keep the fractional indices in sync with the array order
|
|
10
|
-
* - elements with invalid indices should be detected and synced, without altering the already valid indices
|
|
11
|
-
*
|
|
12
|
-
* 2) Fractional indices should be used to reorder the elements, whenever the cached order is expected to be invalidated.
|
|
13
|
-
* - as the fractional indices are encoded as part of the elements, it opens up possibilities for incremental-like APIs
|
|
14
|
-
* - re-order based on fractional indices should be part of (multiplayer) operations such as reconciliation & undo/redo
|
|
15
|
-
* - technically all the z-index actions could perform also re-order based on fractional indices,but in current state it would not bring much benefits,
|
|
16
|
-
* as it's faster & more efficient to perform re-order based on array manipulation and later synchronisation of moved indices with the array order
|
|
17
|
-
*/
|
|
18
|
-
/**
|
|
19
|
-
* Ensure that all elements have valid fractional indices.
|
|
20
|
-
*
|
|
21
|
-
* @throws `InvalidFractionalIndexError` if invalid index is detected.
|
|
22
|
-
*/
|
|
23
|
-
export declare const validateFractionalIndices: (elements: readonly ExcalidrawElement[], { shouldThrow, includeBoundTextValidation, ignoreLogs, reconciliationContext, }: {
|
|
24
|
-
shouldThrow: boolean;
|
|
25
|
-
includeBoundTextValidation: boolean;
|
|
26
|
-
ignoreLogs?: true | undefined;
|
|
27
|
-
reconciliationContext?: {
|
|
28
|
-
localElements: ReadonlyArray<ExcalidrawElement>;
|
|
29
|
-
remoteElements: ReadonlyArray<ExcalidrawElement>;
|
|
30
|
-
} | undefined;
|
|
31
|
-
}) => void;
|
|
32
|
-
/**
|
|
33
|
-
* Order the elements based on the fractional indices.
|
|
34
|
-
* - when fractional indices are identical, break the tie based on the element id
|
|
35
|
-
* - when there is no fractional index in one of the elements, respect the order of the array
|
|
36
|
-
*/
|
|
37
|
-
export declare const orderByFractionalIndex: (elements: OrderedExcalidrawElement[]) => OrderedExcalidrawElement[];
|
|
38
|
-
/**
|
|
39
|
-
* Synchronizes invalid fractional indices of moved elements with the array order by mutating passed elements.
|
|
40
|
-
* If the synchronization fails or the result is invalid, it fallbacks to `syncInvalidIndices`.
|
|
41
|
-
*/
|
|
42
|
-
export declare const syncMovedIndices: (elements: readonly ExcalidrawElement[], movedElements: Map<string, ExcalidrawElement>) => OrderedExcalidrawElement[];
|
|
43
|
-
/**
|
|
44
|
-
* Synchronizes all invalid fractional indices with the array order by mutating passed elements.
|
|
45
|
-
*
|
|
46
|
-
* WARN: in edge cases it could modify the elements which were not moved, as it's impossible to guess the actually moved elements from the elements array itself.
|
|
47
|
-
*/
|
|
48
|
-
export declare const syncInvalidIndices: (elements: readonly ExcalidrawElement[]) => OrderedExcalidrawElement[];
|
|
1
|
+
import type { ExcalidrawElement, OrderedExcalidrawElement } from "./element/types";
|
|
2
|
+
/**
|
|
3
|
+
* Envisioned relation between array order and fractional indices:
|
|
4
|
+
*
|
|
5
|
+
* 1) Array (or array-like ordered data structure) should be used as a cache of elements order, hiding the internal fractional indices implementation.
|
|
6
|
+
* - it's undesirable to perform reorder for each related operation, therefore it's necessary to cache the order defined by fractional indices into an ordered data structure
|
|
7
|
+
* - it's easy enough to define the order of the elements from the outside (boundaries), without worrying about the underlying structure of fractional indices (especially for the host apps)
|
|
8
|
+
* - it's necessary to always keep the array support for backwards compatibility (restore) - old scenes, old libraries, supporting multiple excalidraw versions etc.
|
|
9
|
+
* - it's necessary to always keep the fractional indices in sync with the array order
|
|
10
|
+
* - elements with invalid indices should be detected and synced, without altering the already valid indices
|
|
11
|
+
*
|
|
12
|
+
* 2) Fractional indices should be used to reorder the elements, whenever the cached order is expected to be invalidated.
|
|
13
|
+
* - as the fractional indices are encoded as part of the elements, it opens up possibilities for incremental-like APIs
|
|
14
|
+
* - re-order based on fractional indices should be part of (multiplayer) operations such as reconciliation & undo/redo
|
|
15
|
+
* - technically all the z-index actions could perform also re-order based on fractional indices,but in current state it would not bring much benefits,
|
|
16
|
+
* as it's faster & more efficient to perform re-order based on array manipulation and later synchronisation of moved indices with the array order
|
|
17
|
+
*/
|
|
18
|
+
/**
|
|
19
|
+
* Ensure that all elements have valid fractional indices.
|
|
20
|
+
*
|
|
21
|
+
* @throws `InvalidFractionalIndexError` if invalid index is detected.
|
|
22
|
+
*/
|
|
23
|
+
export declare const validateFractionalIndices: (elements: readonly ExcalidrawElement[], { shouldThrow, includeBoundTextValidation, ignoreLogs, reconciliationContext, }: {
|
|
24
|
+
shouldThrow: boolean;
|
|
25
|
+
includeBoundTextValidation: boolean;
|
|
26
|
+
ignoreLogs?: true | undefined;
|
|
27
|
+
reconciliationContext?: {
|
|
28
|
+
localElements: ReadonlyArray<ExcalidrawElement>;
|
|
29
|
+
remoteElements: ReadonlyArray<ExcalidrawElement>;
|
|
30
|
+
} | undefined;
|
|
31
|
+
}) => void;
|
|
32
|
+
/**
|
|
33
|
+
* Order the elements based on the fractional indices.
|
|
34
|
+
* - when fractional indices are identical, break the tie based on the element id
|
|
35
|
+
* - when there is no fractional index in one of the elements, respect the order of the array
|
|
36
|
+
*/
|
|
37
|
+
export declare const orderByFractionalIndex: (elements: OrderedExcalidrawElement[]) => OrderedExcalidrawElement[];
|
|
38
|
+
/**
|
|
39
|
+
* Synchronizes invalid fractional indices of moved elements with the array order by mutating passed elements.
|
|
40
|
+
* If the synchronization fails or the result is invalid, it fallbacks to `syncInvalidIndices`.
|
|
41
|
+
*/
|
|
42
|
+
export declare const syncMovedIndices: (elements: readonly ExcalidrawElement[], movedElements: Map<string, ExcalidrawElement>) => OrderedExcalidrawElement[];
|
|
43
|
+
/**
|
|
44
|
+
* Synchronizes all invalid fractional indices with the array order by mutating passed elements.
|
|
45
|
+
*
|
|
46
|
+
* WARN: in edge cases it could modify the elements which were not moved, as it's impossible to guess the actually moved elements from the elements array itself.
|
|
47
|
+
*/
|
|
48
|
+
export declare const syncInvalidIndices: (elements: readonly ExcalidrawElement[]) => OrderedExcalidrawElement[];
|
|
@@ -1,63 +1,63 @@
|
|
|
1
|
-
import type { ElementsMap, ElementsMapOrArray, ExcalidrawElement, ExcalidrawFrameLikeElement, NonDeleted, NonDeletedExcalidrawElement } from "./element/types";
|
|
2
|
-
import type { AppClassProperties, AppState, StaticCanvasAppState } from "./types";
|
|
3
|
-
import type { ExcalidrawElementsIncludingDeleted } from "./scene/Scene";
|
|
4
|
-
import type { ReadonlySetLike } from "./utility-types";
|
|
5
|
-
export declare const bindElementsToFramesAfterDuplication: (nextElements: readonly ExcalidrawElement[], oldElements: readonly ExcalidrawElement[], oldIdToDuplicatedId: Map<ExcalidrawElement["id"], ExcalidrawElement["id"]>) => void;
|
|
6
|
-
export declare function isElementIntersectingFrame(element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap): boolean;
|
|
7
|
-
export declare const getElementsCompletelyInFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => ExcalidrawElement[];
|
|
8
|
-
export declare const isElementContainingFrame: (elements: readonly ExcalidrawElement[], element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
|
|
9
|
-
export declare const getElementsIntersectingFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => ExcalidrawElement[];
|
|
10
|
-
export declare const elementsAreInFrameBounds: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
|
|
11
|
-
export declare const elementOverlapsWithFrame: (element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
|
|
12
|
-
export declare const isCursorInFrame: (cursorCoords: {
|
|
13
|
-
x: number;
|
|
14
|
-
y: number;
|
|
15
|
-
}, frame: NonDeleted<ExcalidrawFrameLikeElement>, elementsMap: ElementsMap) => boolean;
|
|
16
|
-
export declare const groupsAreAtLeastIntersectingTheFrame: (elements: readonly NonDeletedExcalidrawElement[], groupIds: readonly string[], frame: ExcalidrawFrameLikeElement) => boolean;
|
|
17
|
-
export declare const groupsAreCompletelyOutOfFrame: (elements: readonly NonDeletedExcalidrawElement[], groupIds: readonly string[], frame: ExcalidrawFrameLikeElement) => boolean;
|
|
18
|
-
/**
|
|
19
|
-
* Returns a map of frameId to frame elements. Includes empty frames.
|
|
20
|
-
*/
|
|
21
|
-
export declare const groupByFrameLikes: (elements: readonly ExcalidrawElement[]) => Map<string, ExcalidrawElement[]>;
|
|
22
|
-
export declare const getFrameChildren: (allElements: ElementsMapOrArray, frameId: string) => ExcalidrawElement[];
|
|
23
|
-
export declare const getFrameLikeElements: (allElements: ExcalidrawElementsIncludingDeleted) => ExcalidrawFrameLikeElement[];
|
|
24
|
-
/**
|
|
25
|
-
* Returns ExcalidrawFrameElements and non-frame-children elements.
|
|
26
|
-
*
|
|
27
|
-
* Considers children as root elements if they point to a frame parent
|
|
28
|
-
* non-existing in the elements set.
|
|
29
|
-
*
|
|
30
|
-
* Considers non-frame bound elements (container or arrow labels) as root.
|
|
31
|
-
*/
|
|
32
|
-
export declare const getRootElements: (allElements: ExcalidrawElementsIncludingDeleted) => ExcalidrawElement[];
|
|
33
|
-
export declare const getElementsInResizingFrame: (allElements: ExcalidrawElementsIncludingDeleted, frame: ExcalidrawFrameLikeElement, appState: AppState, elementsMap: ElementsMap) => ExcalidrawElement[];
|
|
34
|
-
export declare const getElementsInNewFrame: (elements: ExcalidrawElementsIncludingDeleted, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => ExcalidrawElement[];
|
|
35
|
-
export declare const getContainingFrame: (element: ExcalidrawElement, elementsMap: ElementsMap) => ExcalidrawFrameLikeElement | null;
|
|
36
|
-
/** */
|
|
37
|
-
export declare const filterElementsEligibleAsFrameChildren: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => ExcalidrawElement[];
|
|
38
|
-
/**
|
|
39
|
-
* Retains (or repairs for target frame) the ordering invriant where children
|
|
40
|
-
* elements come right before the parent frame:
|
|
41
|
-
* [el, el, child, child, frame, el]
|
|
42
|
-
*
|
|
43
|
-
* @returns mutated allElements (same data structure)
|
|
44
|
-
*/
|
|
45
|
-
export declare const addElementsToFrame: <T extends ElementsMapOrArray>(allElements: T, elementsToAdd: NonDeletedExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => T;
|
|
46
|
-
export declare const removeElementsFromFrame: (elementsToRemove: ReadonlySetLike<NonDeletedExcalidrawElement>, elementsMap: ElementsMap) => void;
|
|
47
|
-
export declare const removeAllElementsFromFrame: <T extends ExcalidrawElement>(allElements: readonly T[], frame: ExcalidrawFrameLikeElement) => readonly T[];
|
|
48
|
-
export declare const replaceAllElementsInFrame: <T extends ExcalidrawElement>(allElements: readonly T[], nextElementsInFrame: ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, app: AppClassProperties) => T[];
|
|
49
|
-
/** does not mutate elements, but returns new ones */
|
|
50
|
-
export declare const updateFrameMembershipOfSelectedElements: <T extends ElementsMapOrArray>(allElements: T, appState: AppState, app: AppClassProperties) => T;
|
|
51
|
-
/**
|
|
52
|
-
* filters out elements that are inside groups that contain a frame element
|
|
53
|
-
* anywhere in the group tree
|
|
54
|
-
*/
|
|
55
|
-
export declare const omitGroupsContainingFrameLikes: (allElements: ElementsMapOrArray, selectedElements?: readonly ExcalidrawElement[]) => ExcalidrawElement[];
|
|
56
|
-
/**
|
|
57
|
-
* depending on the appState, return target frame, which is the frame the given element
|
|
58
|
-
* is going to be added to or remove from
|
|
59
|
-
*/
|
|
60
|
-
export declare const getTargetFrame: (element: ExcalidrawElement, elementsMap: ElementsMap, appState: StaticCanvasAppState) => import("./element/types").ExcalidrawFrameElement | import("./element/types").ExcalidrawMagicFrameElement | null;
|
|
61
|
-
export declare const isElementInFrame: (element: ExcalidrawElement, allElementsMap: ElementsMap, appState: StaticCanvasAppState) => boolean;
|
|
62
|
-
export declare const getFrameLikeTitle: (element: ExcalidrawFrameLikeElement) => string;
|
|
63
|
-
export declare const getElementsOverlappingFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => NonDeletedExcalidrawElement[];
|
|
1
|
+
import type { ElementsMap, ElementsMapOrArray, ExcalidrawElement, ExcalidrawFrameLikeElement, NonDeleted, NonDeletedExcalidrawElement } from "./element/types";
|
|
2
|
+
import type { AppClassProperties, AppState, StaticCanvasAppState } from "./types";
|
|
3
|
+
import type { ExcalidrawElementsIncludingDeleted } from "./scene/Scene";
|
|
4
|
+
import type { ReadonlySetLike } from "./utility-types";
|
|
5
|
+
export declare const bindElementsToFramesAfterDuplication: (nextElements: readonly ExcalidrawElement[], oldElements: readonly ExcalidrawElement[], oldIdToDuplicatedId: Map<ExcalidrawElement["id"], ExcalidrawElement["id"]>) => void;
|
|
6
|
+
export declare function isElementIntersectingFrame(element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap): boolean;
|
|
7
|
+
export declare const getElementsCompletelyInFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => ExcalidrawElement[];
|
|
8
|
+
export declare const isElementContainingFrame: (elements: readonly ExcalidrawElement[], element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
|
|
9
|
+
export declare const getElementsIntersectingFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => ExcalidrawElement[];
|
|
10
|
+
export declare const elementsAreInFrameBounds: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
|
|
11
|
+
export declare const elementOverlapsWithFrame: (element: ExcalidrawElement, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => boolean;
|
|
12
|
+
export declare const isCursorInFrame: (cursorCoords: {
|
|
13
|
+
x: number;
|
|
14
|
+
y: number;
|
|
15
|
+
}, frame: NonDeleted<ExcalidrawFrameLikeElement>, elementsMap: ElementsMap) => boolean;
|
|
16
|
+
export declare const groupsAreAtLeastIntersectingTheFrame: (elements: readonly NonDeletedExcalidrawElement[], groupIds: readonly string[], frame: ExcalidrawFrameLikeElement) => boolean;
|
|
17
|
+
export declare const groupsAreCompletelyOutOfFrame: (elements: readonly NonDeletedExcalidrawElement[], groupIds: readonly string[], frame: ExcalidrawFrameLikeElement) => boolean;
|
|
18
|
+
/**
|
|
19
|
+
* Returns a map of frameId to frame elements. Includes empty frames.
|
|
20
|
+
*/
|
|
21
|
+
export declare const groupByFrameLikes: (elements: readonly ExcalidrawElement[]) => Map<string, ExcalidrawElement[]>;
|
|
22
|
+
export declare const getFrameChildren: (allElements: ElementsMapOrArray, frameId: string) => ExcalidrawElement[];
|
|
23
|
+
export declare const getFrameLikeElements: (allElements: ExcalidrawElementsIncludingDeleted) => ExcalidrawFrameLikeElement[];
|
|
24
|
+
/**
|
|
25
|
+
* Returns ExcalidrawFrameElements and non-frame-children elements.
|
|
26
|
+
*
|
|
27
|
+
* Considers children as root elements if they point to a frame parent
|
|
28
|
+
* non-existing in the elements set.
|
|
29
|
+
*
|
|
30
|
+
* Considers non-frame bound elements (container or arrow labels) as root.
|
|
31
|
+
*/
|
|
32
|
+
export declare const getRootElements: (allElements: ExcalidrawElementsIncludingDeleted) => ExcalidrawElement[];
|
|
33
|
+
export declare const getElementsInResizingFrame: (allElements: ExcalidrawElementsIncludingDeleted, frame: ExcalidrawFrameLikeElement, appState: AppState, elementsMap: ElementsMap) => ExcalidrawElement[];
|
|
34
|
+
export declare const getElementsInNewFrame: (elements: ExcalidrawElementsIncludingDeleted, frame: ExcalidrawFrameLikeElement, elementsMap: ElementsMap) => ExcalidrawElement[];
|
|
35
|
+
export declare const getContainingFrame: (element: ExcalidrawElement, elementsMap: ElementsMap) => ExcalidrawFrameLikeElement | null;
|
|
36
|
+
/** */
|
|
37
|
+
export declare const filterElementsEligibleAsFrameChildren: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => ExcalidrawElement[];
|
|
38
|
+
/**
|
|
39
|
+
* Retains (or repairs for target frame) the ordering invriant where children
|
|
40
|
+
* elements come right before the parent frame:
|
|
41
|
+
* [el, el, child, child, frame, el]
|
|
42
|
+
*
|
|
43
|
+
* @returns mutated allElements (same data structure)
|
|
44
|
+
*/
|
|
45
|
+
export declare const addElementsToFrame: <T extends ElementsMapOrArray>(allElements: T, elementsToAdd: NonDeletedExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => T;
|
|
46
|
+
export declare const removeElementsFromFrame: (elementsToRemove: ReadonlySetLike<NonDeletedExcalidrawElement>, elementsMap: ElementsMap) => void;
|
|
47
|
+
export declare const removeAllElementsFromFrame: <T extends ExcalidrawElement>(allElements: readonly T[], frame: ExcalidrawFrameLikeElement) => readonly T[];
|
|
48
|
+
export declare const replaceAllElementsInFrame: <T extends ExcalidrawElement>(allElements: readonly T[], nextElementsInFrame: ExcalidrawElement[], frame: ExcalidrawFrameLikeElement, app: AppClassProperties) => T[];
|
|
49
|
+
/** does not mutate elements, but returns new ones */
|
|
50
|
+
export declare const updateFrameMembershipOfSelectedElements: <T extends ElementsMapOrArray>(allElements: T, appState: AppState, app: AppClassProperties) => T;
|
|
51
|
+
/**
|
|
52
|
+
* filters out elements that are inside groups that contain a frame element
|
|
53
|
+
* anywhere in the group tree
|
|
54
|
+
*/
|
|
55
|
+
export declare const omitGroupsContainingFrameLikes: (allElements: ElementsMapOrArray, selectedElements?: readonly ExcalidrawElement[]) => ExcalidrawElement[];
|
|
56
|
+
/**
|
|
57
|
+
* depending on the appState, return target frame, which is the frame the given element
|
|
58
|
+
* is going to be added to or remove from
|
|
59
|
+
*/
|
|
60
|
+
export declare const getTargetFrame: (element: ExcalidrawElement, elementsMap: ElementsMap, appState: StaticCanvasAppState) => import("./element/types").ExcalidrawFrameElement | import("./element/types").ExcalidrawMagicFrameElement | null;
|
|
61
|
+
export declare const isElementInFrame: (element: ExcalidrawElement, allElementsMap: ElementsMap, appState: StaticCanvasAppState) => boolean;
|
|
62
|
+
export declare const getFrameLikeTitle: (element: ExcalidrawFrameLikeElement) => string;
|
|
63
|
+
export declare const getElementsOverlappingFrame: (elements: readonly ExcalidrawElement[], frame: ExcalidrawFrameLikeElement) => NonDeletedExcalidrawElement[];
|
package/types/excalidraw/ga.d.ts
CHANGED
|
@@ -1,63 +1,63 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* This is a 2D Projective Geometric Algebra implementation.
|
|
3
|
-
*
|
|
4
|
-
* For wider context on geometric algebra visit see https://bivector.net.
|
|
5
|
-
*
|
|
6
|
-
* For this specific algebra see cheatsheet https://bivector.net/2DPGA.pdf.
|
|
7
|
-
*
|
|
8
|
-
* Converted from generator written by enki, with a ton of added on top.
|
|
9
|
-
*
|
|
10
|
-
* This library uses 8-vectors to represent points, directions and lines
|
|
11
|
-
* in 2D space.
|
|
12
|
-
*
|
|
13
|
-
* An array `[a, b, c, d, e, f, g, h]` represents a n(8)vector:
|
|
14
|
-
* a + b*e0 + c*e1 + d*e2 + e*e01 + f*e20 + g*e12 + h*e012
|
|
15
|
-
*
|
|
16
|
-
* See GAPoint, GALine, GADirection and GATransform modules for common
|
|
17
|
-
* operations.
|
|
18
|
-
*/
|
|
19
|
-
export type Point = NVector;
|
|
20
|
-
export type Direction = NVector;
|
|
21
|
-
export type Line = NVector;
|
|
22
|
-
export type Transform = NVector;
|
|
23
|
-
export declare const point: (x: number, y: number) => NVector;
|
|
24
|
-
export declare const origin: () => NVector;
|
|
25
|
-
export declare const direction: (x: number, y: number) => NVector;
|
|
26
|
-
export declare const offset: (x: number, y: number) => NVector;
|
|
27
|
-
type NVector = readonly [
|
|
28
|
-
number,
|
|
29
|
-
number,
|
|
30
|
-
number,
|
|
31
|
-
number,
|
|
32
|
-
number,
|
|
33
|
-
number,
|
|
34
|
-
number,
|
|
35
|
-
number
|
|
36
|
-
];
|
|
37
|
-
export declare const nvector: (value?: number, index?: number) => NVector;
|
|
38
|
-
export declare const toString: (nvector: NVector) => string;
|
|
39
|
-
export declare const reverse: (nvector: NVector) => NVector;
|
|
40
|
-
export declare const dual: (nvector: NVector) => NVector;
|
|
41
|
-
export declare const conjugate: (nvector: NVector) => NVector;
|
|
42
|
-
export declare const involute: (nvector: NVector) => NVector;
|
|
43
|
-
export declare const add: (a: NVector, b: NVector | number) => NVector;
|
|
44
|
-
export declare const sub: (a: NVector, b: NVector | number) => NVector;
|
|
45
|
-
export declare const mul: (a: NVector, b: NVector | number) => NVector;
|
|
46
|
-
export declare const mulScalar: (a: NVector, b: NVector) => number;
|
|
47
|
-
export declare const meet: (a: NVector, b: NVector) => NVector;
|
|
48
|
-
export declare const join: (a: NVector, b: NVector) => NVector;
|
|
49
|
-
export declare const joinScalar: (a: NVector, b: NVector) => number;
|
|
50
|
-
export declare const dot: (a: NVector, b: NVector) => NVector;
|
|
51
|
-
export declare const norm: (a: NVector) => number;
|
|
52
|
-
export declare const inorm: (a: NVector) => number;
|
|
53
|
-
export declare const normalized: (a: NVector) => NVector;
|
|
54
|
-
export declare const inormalized: (a: NVector) => NVector;
|
|
55
|
-
export declare const E0: NVector;
|
|
56
|
-
export declare const E1: NVector;
|
|
57
|
-
export declare const E2: NVector;
|
|
58
|
-
export declare const E01: NVector;
|
|
59
|
-
export declare const E20: NVector;
|
|
60
|
-
export declare const E12: NVector;
|
|
61
|
-
export declare const E012: NVector;
|
|
62
|
-
export declare const I: NVector;
|
|
63
|
-
export {};
|
|
1
|
+
/**
|
|
2
|
+
* This is a 2D Projective Geometric Algebra implementation.
|
|
3
|
+
*
|
|
4
|
+
* For wider context on geometric algebra visit see https://bivector.net.
|
|
5
|
+
*
|
|
6
|
+
* For this specific algebra see cheatsheet https://bivector.net/2DPGA.pdf.
|
|
7
|
+
*
|
|
8
|
+
* Converted from generator written by enki, with a ton of added on top.
|
|
9
|
+
*
|
|
10
|
+
* This library uses 8-vectors to represent points, directions and lines
|
|
11
|
+
* in 2D space.
|
|
12
|
+
*
|
|
13
|
+
* An array `[a, b, c, d, e, f, g, h]` represents a n(8)vector:
|
|
14
|
+
* a + b*e0 + c*e1 + d*e2 + e*e01 + f*e20 + g*e12 + h*e012
|
|
15
|
+
*
|
|
16
|
+
* See GAPoint, GALine, GADirection and GATransform modules for common
|
|
17
|
+
* operations.
|
|
18
|
+
*/
|
|
19
|
+
export type Point = NVector;
|
|
20
|
+
export type Direction = NVector;
|
|
21
|
+
export type Line = NVector;
|
|
22
|
+
export type Transform = NVector;
|
|
23
|
+
export declare const point: (x: number, y: number) => NVector;
|
|
24
|
+
export declare const origin: () => NVector;
|
|
25
|
+
export declare const direction: (x: number, y: number) => NVector;
|
|
26
|
+
export declare const offset: (x: number, y: number) => NVector;
|
|
27
|
+
type NVector = readonly [
|
|
28
|
+
number,
|
|
29
|
+
number,
|
|
30
|
+
number,
|
|
31
|
+
number,
|
|
32
|
+
number,
|
|
33
|
+
number,
|
|
34
|
+
number,
|
|
35
|
+
number
|
|
36
|
+
];
|
|
37
|
+
export declare const nvector: (value?: number, index?: number) => NVector;
|
|
38
|
+
export declare const toString: (nvector: NVector) => string;
|
|
39
|
+
export declare const reverse: (nvector: NVector) => NVector;
|
|
40
|
+
export declare const dual: (nvector: NVector) => NVector;
|
|
41
|
+
export declare const conjugate: (nvector: NVector) => NVector;
|
|
42
|
+
export declare const involute: (nvector: NVector) => NVector;
|
|
43
|
+
export declare const add: (a: NVector, b: NVector | number) => NVector;
|
|
44
|
+
export declare const sub: (a: NVector, b: NVector | number) => NVector;
|
|
45
|
+
export declare const mul: (a: NVector, b: NVector | number) => NVector;
|
|
46
|
+
export declare const mulScalar: (a: NVector, b: NVector) => number;
|
|
47
|
+
export declare const meet: (a: NVector, b: NVector) => NVector;
|
|
48
|
+
export declare const join: (a: NVector, b: NVector) => NVector;
|
|
49
|
+
export declare const joinScalar: (a: NVector, b: NVector) => number;
|
|
50
|
+
export declare const dot: (a: NVector, b: NVector) => NVector;
|
|
51
|
+
export declare const norm: (a: NVector) => number;
|
|
52
|
+
export declare const inorm: (a: NVector) => number;
|
|
53
|
+
export declare const normalized: (a: NVector) => NVector;
|
|
54
|
+
export declare const inormalized: (a: NVector) => NVector;
|
|
55
|
+
export declare const E0: NVector;
|
|
56
|
+
export declare const E1: NVector;
|
|
57
|
+
export declare const E2: NVector;
|
|
58
|
+
export declare const E01: NVector;
|
|
59
|
+
export declare const E20: NVector;
|
|
60
|
+
export declare const E12: NVector;
|
|
61
|
+
export declare const E012: NVector;
|
|
62
|
+
export declare const I: NVector;
|
|
63
|
+
export {};
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* A direction is stored as an array `[0, 0, 0, 0, y, x, 0, 0]` representing
|
|
3
|
-
* vector `(x, y)`.
|
|
4
|
-
*/
|
|
5
|
-
export declare const from: (point: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
|
|
6
|
-
export declare const fromTo: (from: readonly [number, number, number, number, number, number, number, number], to: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
|
|
7
|
-
export declare const orthogonal: (direction: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
|
|
8
|
-
export declare const orthogonalToLine: (line: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
|
|
1
|
+
/**
|
|
2
|
+
* A direction is stored as an array `[0, 0, 0, 0, y, x, 0, 0]` representing
|
|
3
|
+
* vector `(x, y)`.
|
|
4
|
+
*/
|
|
5
|
+
export declare const from: (point: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
|
|
6
|
+
export declare const fromTo: (from: readonly [number, number, number, number, number, number, number, number], to: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
|
|
7
|
+
export declare const orthogonal: (direction: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
|
|
8
|
+
export declare const orthogonalToLine: (line: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
|