@zsviczian/excalidraw 0.15.2-obsidian-10 → 0.15.2-obsidian-12
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 +1710 -1849
- package/dist/excalidraw.production.min.js +1 -1
- package/package.json +2 -1
- package/types/actions/actionAddToLibrary.d.ts +440 -441
- package/types/actions/actionAlign.d.ts +96 -97
- package/types/actions/actionBoundText.d.ts +330 -331
- package/types/actions/actionCanvas.d.ts +1844 -1845
- package/types/actions/actionClipboard.d.ts +828 -829
- package/types/actions/actionDeleteSelected.d.ts +474 -475
- package/types/actions/actionDistribute.d.ts +32 -33
- package/types/actions/actionDuplicateSelection.d.ts +21 -22
- package/types/actions/actionElementLock.d.ts +315 -316
- package/types/actions/actionExport.d.ts +1388 -1389
- package/types/actions/actionFinalize.d.ts +298 -299
- package/types/actions/actionFlip.d.ts +32 -33
- package/types/actions/actionFrame.d.ts +489 -490
- package/types/actions/actionGroup.d.ts +44 -45
- package/types/actions/actionHistory.d.ts +6 -6
- package/types/actions/actionLinearEditor.d.ts +157 -158
- package/types/actions/actionMenu.d.ts +478 -479
- package/types/actions/actionNavigate.d.ts +14 -14
- package/types/actions/actionProperties.d.ts +2012 -2013
- package/types/actions/actionSelectAll.d.ts +15 -16
- package/types/actions/actionStyles.d.ts +171 -172
- package/types/actions/actionToggleGridMode.d.ts +160 -161
- package/types/actions/actionToggleLock.d.ts +139 -135
- package/types/actions/actionToggleStats.d.ts +157 -158
- package/types/actions/actionToggleViewMode.d.ts +159 -160
- package/types/actions/actionToggleZenMode.d.ts +159 -160
- package/types/actions/actionZindex.d.ts +67 -67
- package/types/actions/index.d.ts +24 -24
- package/types/actions/manager.d.ts +21 -21
- package/types/actions/register.d.ts +5 -5
- package/types/actions/shortcuts.d.ts +4 -4
- package/types/actions/types.d.ts +45 -45
- package/types/align.d.ts +6 -6
- package/types/analytics.d.ts +1 -1
- package/types/appState.d.ts +81 -81
- package/types/bug-issue-template.d.ts +2 -0
- package/types/charts.d.ts +27 -27
- package/types/clients.d.ts +5 -5
- package/types/clipboard.d.ts +25 -25
- package/types/colors.d.ts +61 -61
- package/types/components/Actions.d.ts +36 -36
- package/types/components/ActiveConfirmDialog.d.ts +4 -4
- package/types/components/ActiveFile.d.ts +7 -0
- package/types/components/App.d.ts +288 -288
- package/types/components/Avatar.d.ts +10 -10
- package/types/components/BackgroundPickerAndDarkModeToggle.d.ts +4 -0
- package/types/components/BraveMeasureTextError.d.ts +2 -2
- package/types/components/Button.d.ts +16 -17
- package/types/components/ButtonIconSelect.d.ts +19 -19
- package/types/components/Card.d.ts +6 -7
- package/types/components/CheckboxItem.d.ts +8 -8
- package/types/components/ClearCanvas.d.ts +4 -0
- package/types/components/CollabButton.d.ts +7 -0
- package/types/components/ColorPicker/ColorInput.d.ts +7 -7
- package/types/components/ColorPicker/ColorPicker.d.ts +19 -19
- package/types/components/ColorPicker/CustomColorList.d.ts +8 -8
- package/types/components/ColorPicker/HotkeyLabel.d.ts +8 -8
- package/types/components/ColorPicker/Picker.d.ts +18 -18
- package/types/components/ColorPicker/PickerColorList.d.ts +10 -10
- package/types/components/ColorPicker/PickerHeading.d.ts +5 -5
- package/types/components/ColorPicker/ShadeList.d.ts +8 -8
- package/types/components/ColorPicker/TopPicks.d.ts +9 -9
- package/types/components/ColorPicker/colorPickerUtils.d.ts +21 -21
- package/types/components/ColorPicker/keyboardNavHandlers.d.ts +20 -21
- package/types/components/ColorPicker.d.ts +19 -19
- package/types/components/ConfirmDialog.d.ts +10 -10
- package/types/components/ContextMenu.d.ts +15 -15
- package/types/components/DarkModeToggle.d.ts +7 -7
- package/types/components/DefaultSidebar.d.ts +29 -30
- package/types/components/Dialog.d.ts +13 -13
- package/types/components/DialogActionButton.d.ts +10 -10
- package/types/components/EncryptedIcon.d.ts +2 -0
- package/types/components/ErrorDialog.d.ts +5 -5
- package/types/components/EyeDropper.d.ts +17 -18
- package/types/components/FilledButton.d.ts +17 -17
- package/types/components/FixedSideContainer.d.ts +9 -9
- package/types/components/Footer.d.ts +10 -0
- package/types/components/HandButton.d.ts +10 -10
- package/types/components/HelpButton.d.ts +7 -7
- package/types/components/HelpDialog.d.ts +4 -4
- package/types/components/HelpIcon.d.ts +8 -0
- package/types/components/HintViewer.d.ts +10 -10
- package/types/components/IconPicker.d.ts +13 -13
- package/types/components/ImageExportDialog.d.ts +13 -13
- package/types/components/InitializeApp.d.ts +10 -10
- package/types/components/Island.d.ts +10 -10
- package/types/components/JSONExportDialog.d.ts +15 -15
- package/types/components/LayerUI.d.ts +32 -32
- package/types/components/LibraryButton.d.ts +8 -8
- package/types/components/LibraryMenu.d.ts +24 -24
- package/types/components/LibraryMenuBrowseButton.d.ts +7 -7
- package/types/components/LibraryMenuControlButtons.d.ts +9 -9
- package/types/components/LibraryMenuHeaderContent.d.ts +17 -18
- package/types/components/LibraryMenuItems.d.ts +14 -14
- package/types/components/LibraryMenuSection.d.ts +22 -22
- package/types/components/LibraryUnit.d.ts +14 -15
- package/types/components/LoadingMessage.d.ts +5 -6
- package/types/components/LockButton.d.ts +10 -10
- package/types/components/MenuItem.d.ts +11 -0
- package/types/components/MenuUtils.d.ts +2 -0
- package/types/components/MobileMenu.d.ts +27 -27
- package/types/components/Modal.d.ts +13 -13
- package/types/components/OverwriteConfirm/OverwriteConfirm.d.ts +17 -17
- package/types/components/OverwriteConfirm/OverwriteConfirmActions.d.ts +17 -17
- package/types/components/OverwriteConfirm/OverwriteConfirmState.d.ts +22 -22
- package/types/components/PasteChartDialog.d.ts +8 -8
- package/types/components/PenModeButton.d.ts +12 -12
- package/types/components/Popover.d.ts +15 -15
- package/types/components/ProjectName.d.ts +11 -11
- package/types/components/PublishLibrary.d.ts +16 -16
- package/types/components/RadioGroup.d.ts +12 -12
- package/types/components/Section.d.ts +6 -6
- package/types/components/Sidebar/Sidebar.d.ts +76 -76
- package/types/components/Sidebar/SidebarHeader.d.ts +7 -7
- package/types/components/Sidebar/SidebarTab.d.ts +8 -9
- package/types/components/Sidebar/SidebarTabTrigger.d.ts +9 -10
- package/types/components/Sidebar/SidebarTabTriggers.d.ts +6 -7
- package/types/components/Sidebar/SidebarTabs.d.ts +6 -7
- package/types/components/Sidebar/SidebarTrigger.d.ts +6 -6
- package/types/components/Sidebar/common.d.ts +33 -33
- package/types/components/SidebarLockButton.d.ts +8 -0
- package/types/components/SingleLibraryItem.d.ts +10 -10
- package/types/components/Spinner.d.ts +7 -7
- package/types/components/Stack.d.ts +16 -16
- package/types/components/Stats.d.ts +11 -11
- package/types/components/Switch.d.ts +9 -9
- package/types/components/Toast.d.ts +7 -7
- package/types/components/ToolButton.d.ts +47 -47
- package/types/components/Tooltip.d.ts +17 -17
- package/types/components/TopErrorBoundary.d.ts +15 -0
- package/types/components/Trans.d.ts +9 -9
- package/types/components/UserList.d.ts +8 -8
- package/types/components/WelcomeScreen.d.ts +8 -0
- package/types/components/WelcomeScreenDecor.d.ts +6 -0
- package/types/components/context/tunnels.d.ts +16 -16
- package/types/components/dropdownMenu/DropdownMenu.d.ts +67 -67
- package/types/components/dropdownMenu/DropdownMenuContent.d.ts +15 -15
- package/types/components/dropdownMenu/DropdownMenuGroup.d.ts +11 -11
- package/types/components/dropdownMenu/DropdownMenuItem.d.ts +12 -12
- package/types/components/dropdownMenu/DropdownMenuItemContent.d.ts +6 -6
- package/types/components/dropdownMenu/DropdownMenuItemCustom.d.ts +6 -6
- package/types/components/dropdownMenu/DropdownMenuItemLink.d.ts +13 -13
- package/types/components/dropdownMenu/DropdownMenuSeparator.d.ts +5 -5
- package/types/components/dropdownMenu/DropdownMenuTrigger.d.ts +10 -11
- package/types/components/dropdownMenu/common.d.ts +6 -6
- package/types/components/dropdownMenu/dropdownMenuUtils.d.ts +3 -3
- package/types/components/footer/Footer.d.ts +12 -12
- package/types/components/footer/FooterCenter.d.ts +8 -8
- package/types/components/hoc/withInternalFallback.d.ts +4 -4
- package/types/components/hoc/withUpstreamOverride.d.ts +10 -10
- package/types/components/icons.d.ts +154 -154
- package/types/components/live-collaboration/LiveCollaborationTrigger.d.ts +9 -10
- package/types/components/main-menu/DefaultItems.d.ts +44 -44
- package/types/components/main-menu/MainMenu.d.ts +61 -61
- package/types/components/mainMenu/DefaultItems.d.ts +44 -0
- package/types/components/mainMenu/MainMenu.d.ts +63 -0
- package/types/components/welcome-screen/WelcomeScreen.Center.d.ts +57 -58
- package/types/components/welcome-screen/WelcomeScreen.Hints.d.ts +19 -19
- package/types/components/welcome-screen/WelcomeScreen.d.ts +84 -85
- package/types/constants.d.ts +229 -226
- package/types/context/tunnels.d.ts +19 -19
- package/types/context/ui-appState.d.ts +4 -4
- package/types/data/blob.d.ts +48 -48
- package/types/data/encode.d.ts +53 -53
- package/types/data/encryption.d.ts +9 -9
- package/types/data/filesystem.d.ts +19 -19
- package/types/data/image.d.ts +15 -15
- package/types/data/index.d.ts +13 -13
- package/types/data/json.d.ts +16 -16
- package/types/data/library.d.ts +54 -54
- package/types/data/resave.d.ts +5 -5
- package/types/data/restore.d.ts +21 -21
- package/types/data/types.d.ts +45 -45
- package/types/data/url.d.ts +7 -7
- package/types/distribute.d.ts +6 -6
- package/types/element/Hyperlink.d.ts +181 -182
- package/types/element/binding.d.ts +33 -33
- package/types/element/bounds.d.ts +53 -53
- package/types/element/collision.d.ts +21 -21
- package/types/element/dragElements.d.ts +6 -6
- package/types/element/embeddable.d.ts +175 -176
- package/types/element/iframe.d.ts +167 -0
- package/types/element/image.d.ts +32 -32
- package/types/element/index.d.ts +21 -21
- package/types/element/linearElementEditor.d.ts +292 -293
- package/types/element/mutateElement.d.ts +12 -12
- package/types/element/newElement.d.ts +95 -95
- package/types/element/resizeElements.d.ts +9 -9
- package/types/element/resizeTest.d.ts +13 -13
- package/types/element/showSelectedShapeActions.d.ts +3 -3
- package/types/element/sizeHelpers.d.ts +21 -21
- package/types/element/sortElements.d.ts +2 -2
- package/types/element/textElement.d.ts +76 -80
- package/types/element/textWysiwyg.d.ts +21 -21
- package/types/element/transformHandles.d.ts +35 -35
- package/types/element/typeChecks.d.ts +29 -29
- package/types/element/types.d.ts +166 -166
- package/types/errors.d.ts +8 -8
- package/types/excalidraw-app/CustomStats.d.ts +9 -0
- package/types/excalidraw-app/app_constants.d.ts +32 -0
- package/types/excalidraw-app/collab/Collab.d.ts +163 -0
- package/types/excalidraw-app/collab/Portal.d.ts +28 -0
- package/types/excalidraw-app/collab/RoomDialog.d.ts +13 -0
- package/types/excalidraw-app/collab/reconciliation.d.ts +10 -0
- package/types/excalidraw-app/components/ExportToExcalidrawPlus.d.ts +9 -0
- package/types/excalidraw-app/components/LanguageList.d.ts +4 -0
- package/types/excalidraw-app/components/icons.d.ts +1 -0
- package/types/excalidraw-app/data/FileManager.d.ts +66 -0
- package/types/excalidraw-app/data/LocalData.d.ts +32 -0
- package/types/excalidraw-app/data/Locker.d.ts +8 -0
- package/types/excalidraw-app/data/firebase.d.ts +25 -0
- package/types/excalidraw-app/data/index.d.ts +190 -0
- package/types/excalidraw-app/data/localStorage.d.ts +116 -0
- package/types/excalidraw-app/data/tabSync.d.ts +9 -0
- package/types/excalidraw-app/index.d.ts +26 -0
- package/types/frame.d.ts +40 -40
- package/types/ga.d.ts +63 -63
- package/types/gadirections.d.ts +8 -8
- package/types/galines.d.ts +22 -22
- package/types/gapoints.d.ts +7 -7
- package/types/gatransforms.d.ts +10 -10
- package/types/gesture.d.ts +6 -6
- package/types/groups.d.ts +31 -31
- package/types/history.d.ts +52 -52
- package/types/hooks/useCallbackRefState.d.ts +1 -1
- package/types/hooks/useCreatePortalContainer.d.ts +5 -5
- package/types/hooks/useLibraryItemSvg.d.ts +11 -11
- package/types/hooks/useOutsideClick.d.ts +19 -20
- package/types/hooks/useScrollPosition.d.ts +1 -2
- package/types/hooks/useTransition.d.ts +2 -2
- package/types/i18n.d.ts +24 -24
- package/types/jotai.d.ts +34 -34
- package/types/keys.d.ts +80 -80
- package/types/math.d.ts +30 -30
- package/types/packages/common.webpack.dev.config.d.ts +72 -72
- package/types/packages/common.webpack.prod.config.d.ts +84 -84
- package/types/packages/excalidraw/dist/excalidraw.development.d.ts +2 -4
- package/types/packages/excalidraw/dist/excalidraw.production.min.d.ts +1 -1
- package/types/packages/excalidraw/entry.d.ts +1 -1
- package/types/packages/excalidraw/env.d.ts +1 -1
- package/types/packages/excalidraw/example/App.d.ts +14 -14
- package/types/packages/excalidraw/example/CustomFooter.d.ts +5 -5
- package/types/packages/excalidraw/example/MobileFooter.d.ts +5 -5
- package/types/packages/excalidraw/example/index.d.ts +1 -1
- package/types/packages/excalidraw/example/initialData.d.ts +178 -178
- package/types/packages/excalidraw/example/sidebar/ExampleSidebar.d.ts +5 -5
- package/types/packages/excalidraw/example/sidebar/Sidebar.d.ts +5 -0
- package/types/packages/excalidraw/index.d.ts +38 -37
- package/types/packages/excalidraw/main.d.ts +2 -2
- package/types/packages/excalidraw/publicPath.d.ts +1 -1
- package/types/packages/excalidraw/webpack.dev-server.config.d.ts +19 -19
- package/types/packages/excalidraw/webpack.dev.config.d.ts +80 -69
- package/types/packages/excalidraw/webpack.prod.config.d.ts +95 -78
- package/types/packages/utils.d.ts +43 -43
- package/types/points.d.ts +7 -7
- package/types/polyfill.d.ts +2 -2
- package/types/random.d.ts +4 -4
- package/types/renderer/easingFunctions.d.ts +6 -6
- package/types/renderer/renderElement.d.ts +37 -37
- package/types/renderer/renderScene.d.ts +51 -51
- package/types/renderer/roundRect.d.ts +11 -11
- package/types/scene/Fonts.d.ts +21 -21
- package/types/scene/Scene.d.ts +60 -60
- package/types/scene/comparisons.d.ts +10 -10
- package/types/scene/export.d.ts +25 -25
- package/types/scene/index.d.ts +5 -5
- package/types/scene/scroll.d.ts +17 -17
- package/types/scene/scrollbars.d.ts +16 -16
- package/types/scene/selection.d.ts +31 -31
- package/types/scene/types.d.ts +59 -59
- package/types/scene/zoom.d.ts +13 -13
- package/types/shapes.d.ts +62 -62
- package/types/types.d.ts +501 -501
- package/types/utility-types.d.ts +24 -25
- package/types/utils.d.ts +192 -192
- package/types/zindex.d.ts +6 -6
- package/types/.DS_Store +0 -0
|
@@ -1,95 +1,95 @@
|
|
|
1
|
-
import { ExcalidrawElement, ExcalidrawImageElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawGenericElement, NonDeleted, TextAlign, GroupId, VerticalAlign, Arrowhead, ExcalidrawFreeDrawElement, FontFamilyValues, ExcalidrawTextContainer, ExcalidrawFrameElement, ExcalidrawEmbeddableElement } from "../element/types";
|
|
2
|
-
import { AppState } from "../types";
|
|
3
|
-
import { MarkOptional, Mutable } from "../utility-types";
|
|
4
|
-
type ElementConstructorOpts = MarkOptional<Omit<ExcalidrawGenericElement, "id" | "type" | "isDeleted" | "updated">, "width" | "height" | "angle" | "groupIds" | "frameId" | "boundElements" | "seed" | "version" | "versionNonce" | "link" | "strokeStyle" | "fillStyle" | "strokeColor" | "backgroundColor" | "roughness" | "strokeWidth" | "roundness" | "locked" | "opacity">;
|
|
5
|
-
export declare const newElement: (opts: {
|
|
6
|
-
type: ExcalidrawGenericElement["type"];
|
|
7
|
-
} & ElementConstructorOpts) => NonDeleted<ExcalidrawGenericElement>;
|
|
8
|
-
export declare const newEmbeddableElement: (opts: {
|
|
9
|
-
type: "embeddable";
|
|
10
|
-
validated:
|
|
11
|
-
} & ElementConstructorOpts) => NonDeleted<ExcalidrawEmbeddableElement>;
|
|
12
|
-
export declare const newFrameElement: (opts: ElementConstructorOpts) => NonDeleted<ExcalidrawFrameElement>;
|
|
13
|
-
export declare const newTextElement: (opts: {
|
|
14
|
-
text: string;
|
|
15
|
-
rawText: string;
|
|
16
|
-
fontSize?: number;
|
|
17
|
-
fontFamily?: FontFamilyValues;
|
|
18
|
-
textAlign?: TextAlign;
|
|
19
|
-
verticalAlign?: VerticalAlign;
|
|
20
|
-
containerId?: ExcalidrawTextContainer["id"];
|
|
21
|
-
lineHeight?: ExcalidrawTextElement["lineHeight"];
|
|
22
|
-
strokeWidth?: ExcalidrawTextElement["strokeWidth"];
|
|
23
|
-
} & ElementConstructorOpts) => NonDeleted<ExcalidrawTextElement>;
|
|
24
|
-
export declare const refreshTextDimensions: (textElement: ExcalidrawTextElement, text?: string) => {
|
|
25
|
-
x: number;
|
|
26
|
-
y: number;
|
|
27
|
-
width: number;
|
|
28
|
-
height: number;
|
|
29
|
-
baseline: number;
|
|
30
|
-
text: string;
|
|
31
|
-
} | undefined;
|
|
32
|
-
export declare const updateTextElement: (textElement: ExcalidrawTextElement, { text, isDeleted, originalText, rawText, link, }: {
|
|
33
|
-
text: string;
|
|
34
|
-
isDeleted?: boolean | undefined;
|
|
35
|
-
originalText: string;
|
|
36
|
-
rawText?: string | undefined;
|
|
37
|
-
link?: string | undefined;
|
|
38
|
-
}) => ExcalidrawTextElement;
|
|
39
|
-
export declare const newFreeDrawElement: (opts: {
|
|
40
|
-
type: "freedraw";
|
|
41
|
-
points?: ExcalidrawFreeDrawElement["points"];
|
|
42
|
-
simulatePressure: boolean;
|
|
43
|
-
} & ElementConstructorOpts) => NonDeleted<ExcalidrawFreeDrawElement>;
|
|
44
|
-
export declare const newLinearElement: (opts: {
|
|
45
|
-
type: ExcalidrawLinearElement["type"];
|
|
46
|
-
startArrowhead: Arrowhead | null;
|
|
47
|
-
endArrowhead: Arrowhead | null;
|
|
48
|
-
points?: ExcalidrawLinearElement["points"];
|
|
49
|
-
} & ElementConstructorOpts) => NonDeleted<ExcalidrawLinearElement>;
|
|
50
|
-
export declare const newImageElement: (opts: {
|
|
51
|
-
type: ExcalidrawImageElement["type"];
|
|
52
|
-
status?: ExcalidrawImageElement["status"];
|
|
53
|
-
fileId?: ExcalidrawImageElement["fileId"];
|
|
54
|
-
scale?: ExcalidrawImageElement["scale"];
|
|
55
|
-
} & ElementConstructorOpts) => NonDeleted<ExcalidrawImageElement>;
|
|
56
|
-
/**
|
|
57
|
-
* Clones ExcalidrawElement data structure. Does not regenerate id, nonce, or
|
|
58
|
-
* any value. The purpose is to to break object references for immutability
|
|
59
|
-
* reasons, whenever we want to keep the original element, but ensure it's not
|
|
60
|
-
* mutated.
|
|
61
|
-
*
|
|
62
|
-
* Only clones plain objects and arrays. Doesn't clone Date, RegExp, Map, Set,
|
|
63
|
-
* Typed arrays and other non-null objects.
|
|
64
|
-
*/
|
|
65
|
-
export declare const deepCopyElement: <T extends ExcalidrawElement>(val: T) => Mutable<T>;
|
|
66
|
-
/**
|
|
67
|
-
* Duplicate an element, often used in the alt-drag operation.
|
|
68
|
-
* Note that this method has gotten a bit complicated since the
|
|
69
|
-
* introduction of gruoping/ungrouping elements.
|
|
70
|
-
* @param editingGroupId The current group being edited. The new
|
|
71
|
-
* element will inherit this group and its
|
|
72
|
-
* parents.
|
|
73
|
-
* @param groupIdMapForOperation A Map that maps old group IDs to
|
|
74
|
-
* duplicated ones. If you are duplicating
|
|
75
|
-
* multiple elements at once, share this map
|
|
76
|
-
* amongst all of them
|
|
77
|
-
* @param element Element to duplicate
|
|
78
|
-
* @param overrides Any element properties to override
|
|
79
|
-
*/
|
|
80
|
-
export declare const duplicateElement: <TElement extends ExcalidrawElement>(editingGroupId: AppState["editingGroupId"], groupIdMapForOperation: Map<GroupId, GroupId>, element: TElement, overrides?: Partial<TElement> | undefined) => Readonly<TElement>;
|
|
81
|
-
/**
|
|
82
|
-
* Clones elements, regenerating their ids (including bindings) and group ids.
|
|
83
|
-
*
|
|
84
|
-
* If bindings don't exist in the elements array, they are removed. Therefore,
|
|
85
|
-
* it's advised to supply the whole elements array, or sets of elements that
|
|
86
|
-
* are encapsulated (such as library items), if the purpose is to retain
|
|
87
|
-
* bindings to the cloned elements intact.
|
|
88
|
-
*
|
|
89
|
-
* NOTE by default does not randomize or regenerate anything except the id.
|
|
90
|
-
*/
|
|
91
|
-
export declare const duplicateElements: (elements: readonly ExcalidrawElement[], opts?: {
|
|
92
|
-
/** NOTE also updates version flags and `updated` */
|
|
93
|
-
randomizeSeed: boolean;
|
|
94
|
-
}) => ExcalidrawElement[];
|
|
95
|
-
export {};
|
|
1
|
+
import { ExcalidrawElement, ExcalidrawImageElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawGenericElement, NonDeleted, TextAlign, GroupId, VerticalAlign, Arrowhead, ExcalidrawFreeDrawElement, FontFamilyValues, ExcalidrawTextContainer, ExcalidrawFrameElement, ExcalidrawEmbeddableElement } from "../element/types";
|
|
2
|
+
import { AppState } from "../types";
|
|
3
|
+
import { MarkOptional, Mutable } from "../utility-types";
|
|
4
|
+
type ElementConstructorOpts = MarkOptional<Omit<ExcalidrawGenericElement, "id" | "type" | "isDeleted" | "updated">, "width" | "height" | "angle" | "groupIds" | "frameId" | "boundElements" | "seed" | "version" | "versionNonce" | "link" | "strokeStyle" | "fillStyle" | "strokeColor" | "backgroundColor" | "roughness" | "strokeWidth" | "roundness" | "locked" | "opacity">;
|
|
5
|
+
export declare const newElement: (opts: {
|
|
6
|
+
type: ExcalidrawGenericElement["type"];
|
|
7
|
+
} & ElementConstructorOpts) => NonDeleted<ExcalidrawGenericElement>;
|
|
8
|
+
export declare const newEmbeddableElement: (opts: {
|
|
9
|
+
type: "embeddable";
|
|
10
|
+
validated: ExcalidrawEmbeddableElement["validated"];
|
|
11
|
+
} & ElementConstructorOpts) => NonDeleted<ExcalidrawEmbeddableElement>;
|
|
12
|
+
export declare const newFrameElement: (opts: ElementConstructorOpts) => NonDeleted<ExcalidrawFrameElement>;
|
|
13
|
+
export declare const newTextElement: (opts: {
|
|
14
|
+
text: string;
|
|
15
|
+
rawText: string;
|
|
16
|
+
fontSize?: number;
|
|
17
|
+
fontFamily?: FontFamilyValues;
|
|
18
|
+
textAlign?: TextAlign;
|
|
19
|
+
verticalAlign?: VerticalAlign;
|
|
20
|
+
containerId?: ExcalidrawTextContainer["id"];
|
|
21
|
+
lineHeight?: ExcalidrawTextElement["lineHeight"];
|
|
22
|
+
strokeWidth?: ExcalidrawTextElement["strokeWidth"];
|
|
23
|
+
} & ElementConstructorOpts) => NonDeleted<ExcalidrawTextElement>;
|
|
24
|
+
export declare const refreshTextDimensions: (textElement: ExcalidrawTextElement, text?: string) => {
|
|
25
|
+
x: number;
|
|
26
|
+
y: number;
|
|
27
|
+
width: number;
|
|
28
|
+
height: number;
|
|
29
|
+
baseline: number;
|
|
30
|
+
text: string;
|
|
31
|
+
} | undefined;
|
|
32
|
+
export declare const updateTextElement: (textElement: ExcalidrawTextElement, { text, isDeleted, originalText, rawText, link, }: {
|
|
33
|
+
text: string;
|
|
34
|
+
isDeleted?: boolean | undefined;
|
|
35
|
+
originalText: string;
|
|
36
|
+
rawText?: string | undefined;
|
|
37
|
+
link?: string | undefined;
|
|
38
|
+
}) => ExcalidrawTextElement;
|
|
39
|
+
export declare const newFreeDrawElement: (opts: {
|
|
40
|
+
type: "freedraw";
|
|
41
|
+
points?: ExcalidrawFreeDrawElement["points"];
|
|
42
|
+
simulatePressure: boolean;
|
|
43
|
+
} & ElementConstructorOpts) => NonDeleted<ExcalidrawFreeDrawElement>;
|
|
44
|
+
export declare const newLinearElement: (opts: {
|
|
45
|
+
type: ExcalidrawLinearElement["type"];
|
|
46
|
+
startArrowhead: Arrowhead | null;
|
|
47
|
+
endArrowhead: Arrowhead | null;
|
|
48
|
+
points?: ExcalidrawLinearElement["points"];
|
|
49
|
+
} & ElementConstructorOpts) => NonDeleted<ExcalidrawLinearElement>;
|
|
50
|
+
export declare const newImageElement: (opts: {
|
|
51
|
+
type: ExcalidrawImageElement["type"];
|
|
52
|
+
status?: ExcalidrawImageElement["status"];
|
|
53
|
+
fileId?: ExcalidrawImageElement["fileId"];
|
|
54
|
+
scale?: ExcalidrawImageElement["scale"];
|
|
55
|
+
} & ElementConstructorOpts) => NonDeleted<ExcalidrawImageElement>;
|
|
56
|
+
/**
|
|
57
|
+
* Clones ExcalidrawElement data structure. Does not regenerate id, nonce, or
|
|
58
|
+
* any value. The purpose is to to break object references for immutability
|
|
59
|
+
* reasons, whenever we want to keep the original element, but ensure it's not
|
|
60
|
+
* mutated.
|
|
61
|
+
*
|
|
62
|
+
* Only clones plain objects and arrays. Doesn't clone Date, RegExp, Map, Set,
|
|
63
|
+
* Typed arrays and other non-null objects.
|
|
64
|
+
*/
|
|
65
|
+
export declare const deepCopyElement: <T extends ExcalidrawElement>(val: T) => Mutable<T>;
|
|
66
|
+
/**
|
|
67
|
+
* Duplicate an element, often used in the alt-drag operation.
|
|
68
|
+
* Note that this method has gotten a bit complicated since the
|
|
69
|
+
* introduction of gruoping/ungrouping elements.
|
|
70
|
+
* @param editingGroupId The current group being edited. The new
|
|
71
|
+
* element will inherit this group and its
|
|
72
|
+
* parents.
|
|
73
|
+
* @param groupIdMapForOperation A Map that maps old group IDs to
|
|
74
|
+
* duplicated ones. If you are duplicating
|
|
75
|
+
* multiple elements at once, share this map
|
|
76
|
+
* amongst all of them
|
|
77
|
+
* @param element Element to duplicate
|
|
78
|
+
* @param overrides Any element properties to override
|
|
79
|
+
*/
|
|
80
|
+
export declare const duplicateElement: <TElement extends ExcalidrawElement>(editingGroupId: AppState["editingGroupId"], groupIdMapForOperation: Map<GroupId, GroupId>, element: TElement, overrides?: Partial<TElement> | undefined) => Readonly<TElement>;
|
|
81
|
+
/**
|
|
82
|
+
* Clones elements, regenerating their ids (including bindings) and group ids.
|
|
83
|
+
*
|
|
84
|
+
* If bindings don't exist in the elements array, they are removed. Therefore,
|
|
85
|
+
* it's advised to supply the whole elements array, or sets of elements that
|
|
86
|
+
* are encapsulated (such as library items), if the purpose is to retain
|
|
87
|
+
* bindings to the cloned elements intact.
|
|
88
|
+
*
|
|
89
|
+
* NOTE by default does not randomize or regenerate anything except the id.
|
|
90
|
+
*/
|
|
91
|
+
export declare const duplicateElements: (elements: readonly ExcalidrawElement[], opts?: {
|
|
92
|
+
/** NOTE also updates version flags and `updated` */
|
|
93
|
+
randomizeSeed: boolean;
|
|
94
|
+
}) => ExcalidrawElement[];
|
|
95
|
+
export {};
|
|
@@ -1,9 +1,9 @@
|
|
|
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 resizeMultipleElements: (pointerDownState: PointerDownState, selectedElements: readonly NonDeletedExcalidrawElement[], transformHandleType: "nw" | "ne" | "sw" | "se", shouldResizeFromCenter: boolean, pointerX: number, pointerY: number) => void;
|
|
8
|
-
export declare const getResizeOffsetXY: (transformHandleType: MaybeTransformHandleType, selectedElements: NonDeletedExcalidrawElement[], x: number, y: number) => [number, number];
|
|
9
|
-
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 resizeMultipleElements: (pointerDownState: PointerDownState, selectedElements: readonly NonDeletedExcalidrawElement[], transformHandleType: "nw" | "ne" | "sw" | "se", shouldResizeFromCenter: boolean, pointerX: number, pointerY: number) => void;
|
|
8
|
+
export declare const getResizeOffsetXY: (transformHandleType: MaybeTransformHandleType, selectedElements: NonDeletedExcalidrawElement[], x: number, y: number) => [number, number];
|
|
9
|
+
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 { NonDeletedExcalidrawElement } from "./types";
|
|
2
|
-
import { UIAppState } from "../types";
|
|
3
|
-
export declare const showSelectedShapeActions: (appState: UIAppState, elements: readonly NonDeletedExcalidrawElement[]) => boolean;
|
|
1
|
+
import { NonDeletedExcalidrawElement } from "./types";
|
|
2
|
+
import { UIAppState } from "../types";
|
|
3
|
+
export declare const showSelectedShapeActions: (appState: UIAppState, 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,80 +1,76 @@
|
|
|
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 computeBoundTextPosition: (container: ExcalidrawElement, boundTextElement: ExcalidrawTextElementWithContainer) => {
|
|
11
|
-
x: number;
|
|
12
|
-
y: number;
|
|
13
|
-
};
|
|
14
|
-
export declare const measureText: (text: string, font: FontString, lineHeight: ExcalidrawTextElement["lineHeight"]) => {
|
|
15
|
-
width: number;
|
|
16
|
-
height: number;
|
|
17
|
-
baseline: number;
|
|
18
|
-
};
|
|
19
|
-
export declare const measureBaseline: (text: string, font: FontString, lineHeight: ExcalidrawTextElement["lineHeight"], wrapInContainer?: boolean) => number;
|
|
20
|
-
/**
|
|
21
|
-
* To get unitless line-height (if unknown) we can calculate it by dividing
|
|
22
|
-
* height-per-line by fontSize.
|
|
23
|
-
*/
|
|
24
|
-
export declare const detectLineHeight: (textElement: ExcalidrawTextElement) => number & {
|
|
25
|
-
_brand: "unitlessLineHeight";
|
|
26
|
-
};
|
|
27
|
-
/**
|
|
28
|
-
* We calculate the line height from the font size and the unitless line height,
|
|
29
|
-
* aligning with the W3C spec.
|
|
30
|
-
*/
|
|
31
|
-
export declare const getLineHeightInPx: (fontSize: ExcalidrawTextElement["fontSize"], lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
|
|
32
|
-
export declare const getApproxMinLineHeight: (fontSize: ExcalidrawTextElement["fontSize"], lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
|
|
33
|
-
export declare const getTextWidth: (text: string, font: FontString) => number;
|
|
34
|
-
export declare const getTextHeight: (text: string, fontSize: number, lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
|
|
35
|
-
export declare const parseTokens: (text: string) => string[];
|
|
36
|
-
export declare const wrapText: (text: string, font: FontString, maxWidth: number) => string;
|
|
37
|
-
export declare const charWidth: {
|
|
38
|
-
calculate: (char: string, font: FontString) => number;
|
|
39
|
-
getCache: (font: FontString) => number[];
|
|
40
|
-
};
|
|
41
|
-
export declare const getApproxMinLineWidth: (font: FontString, lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
|
|
42
|
-
export declare const getMinCharWidth: (font: FontString) => number;
|
|
43
|
-
export declare const getMaxCharWidth: (font: FontString) => number;
|
|
44
|
-
export declare const getApproxCharsToFitInWidth: (font: FontString, width: number) => number;
|
|
45
|
-
export declare const getBoundTextElementId: (container: ExcalidrawElement | null) => string | null;
|
|
46
|
-
export declare const getBoundTextElement: (element: ExcalidrawElement | null) => ExcalidrawTextElementWithContainer | null;
|
|
47
|
-
export declare const getContainerElement: (element: (ExcalidrawElement & {
|
|
48
|
-
containerId: ExcalidrawElement["id"] | null;
|
|
49
|
-
}) | null) => ExcalidrawElement | null;
|
|
50
|
-
export declare const
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
};
|
|
54
|
-
export declare const
|
|
55
|
-
x: number;
|
|
56
|
-
y: number;
|
|
57
|
-
};
|
|
58
|
-
export declare const
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
export declare const
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
export declare const
|
|
69
|
-
export declare const
|
|
70
|
-
export declare const
|
|
71
|
-
declare const
|
|
72
|
-
export declare const
|
|
73
|
-
export declare const
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
export
|
|
77
|
-
export declare const getDefaultLineHeight: (fontFamily: FontFamilyValues) => number & {
|
|
78
|
-
_brand: "unitlessLineHeight";
|
|
79
|
-
};
|
|
80
|
-
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, shouldMaintainAspectRatio?: boolean) => void;
|
|
10
|
+
export declare const computeBoundTextPosition: (container: ExcalidrawElement, boundTextElement: ExcalidrawTextElementWithContainer) => {
|
|
11
|
+
x: number;
|
|
12
|
+
y: number;
|
|
13
|
+
};
|
|
14
|
+
export declare const measureText: (text: string, font: FontString, lineHeight: ExcalidrawTextElement["lineHeight"]) => {
|
|
15
|
+
width: number;
|
|
16
|
+
height: number;
|
|
17
|
+
baseline: number;
|
|
18
|
+
};
|
|
19
|
+
export declare const measureBaseline: (text: string, font: FontString, lineHeight: ExcalidrawTextElement["lineHeight"], wrapInContainer?: boolean) => number;
|
|
20
|
+
/**
|
|
21
|
+
* To get unitless line-height (if unknown) we can calculate it by dividing
|
|
22
|
+
* height-per-line by fontSize.
|
|
23
|
+
*/
|
|
24
|
+
export declare const detectLineHeight: (textElement: ExcalidrawTextElement) => number & {
|
|
25
|
+
_brand: "unitlessLineHeight";
|
|
26
|
+
};
|
|
27
|
+
/**
|
|
28
|
+
* We calculate the line height from the font size and the unitless line height,
|
|
29
|
+
* aligning with the W3C spec.
|
|
30
|
+
*/
|
|
31
|
+
export declare const getLineHeightInPx: (fontSize: ExcalidrawTextElement["fontSize"], lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
|
|
32
|
+
export declare const getApproxMinLineHeight: (fontSize: ExcalidrawTextElement["fontSize"], lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
|
|
33
|
+
export declare const getTextWidth: (text: string, font: FontString) => number;
|
|
34
|
+
export declare const getTextHeight: (text: string, fontSize: number, lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
|
|
35
|
+
export declare const parseTokens: (text: string) => string[];
|
|
36
|
+
export declare const wrapText: (text: string, font: FontString, maxWidth: number) => string;
|
|
37
|
+
export declare const charWidth: {
|
|
38
|
+
calculate: (char: string, font: FontString) => number;
|
|
39
|
+
getCache: (font: FontString) => number[];
|
|
40
|
+
};
|
|
41
|
+
export declare const getApproxMinLineWidth: (font: FontString, lineHeight: ExcalidrawTextElement["lineHeight"]) => number;
|
|
42
|
+
export declare const getMinCharWidth: (font: FontString) => number;
|
|
43
|
+
export declare const getMaxCharWidth: (font: FontString) => number;
|
|
44
|
+
export declare const getApproxCharsToFitInWidth: (font: FontString, width: number) => number;
|
|
45
|
+
export declare const getBoundTextElementId: (container: ExcalidrawElement | null) => string | null;
|
|
46
|
+
export declare const getBoundTextElement: (element: ExcalidrawElement | null) => ExcalidrawTextElementWithContainer | null;
|
|
47
|
+
export declare const getContainerElement: (element: (ExcalidrawElement & {
|
|
48
|
+
containerId: ExcalidrawElement["id"] | null;
|
|
49
|
+
}) | null) => ExcalidrawElement | null;
|
|
50
|
+
export declare const getContainerCenter: (container: ExcalidrawElement, appState: AppState) => {
|
|
51
|
+
x: number;
|
|
52
|
+
y: number;
|
|
53
|
+
};
|
|
54
|
+
export declare const getContainerCoords: (container: NonDeletedExcalidrawElement) => {
|
|
55
|
+
x: number;
|
|
56
|
+
y: number;
|
|
57
|
+
};
|
|
58
|
+
export declare const getTextElementAngle: (textElement: ExcalidrawTextElement) => number;
|
|
59
|
+
export declare const getBoundTextElementOffset: (boundTextElement: ExcalidrawTextElement | null) => number;
|
|
60
|
+
export declare const getBoundTextElementPosition: (container: ExcalidrawElement, boundTextElement: ExcalidrawTextElementWithContainer) => {
|
|
61
|
+
x: number;
|
|
62
|
+
y: number;
|
|
63
|
+
} | undefined;
|
|
64
|
+
export declare const shouldAllowVerticalAlign: (selectedElements: NonDeletedExcalidrawElement[]) => boolean;
|
|
65
|
+
export declare const suppportsHorizontalAlign: (selectedElements: NonDeletedExcalidrawElement[]) => boolean;
|
|
66
|
+
export declare const getTextBindableContainerAtPosition: (elements: readonly ExcalidrawElement[], appState: AppState, x: number, y: number) => ExcalidrawTextContainer | null;
|
|
67
|
+
declare const VALID_CONTAINER_TYPES: Set<string>;
|
|
68
|
+
export declare const isValidTextContainer: (element: ExcalidrawElement) => boolean;
|
|
69
|
+
export declare const computeContainerDimensionForBoundText: (dimension: number, containerType: ExtractSetType<typeof VALID_CONTAINER_TYPES>, legacy?: boolean) => number;
|
|
70
|
+
export declare const getBoundTextMaxWidth: (container: ExcalidrawElement, boundTextElement?: ExcalidrawTextElement | null) => number;
|
|
71
|
+
export declare const getBoundTextMaxHeight: (container: ExcalidrawElement, boundTextElement: ExcalidrawTextElementWithContainer) => number;
|
|
72
|
+
export declare const isMeasureTextSupported: () => boolean;
|
|
73
|
+
export declare const getDefaultLineHeight: (fontFamily: FontFamilyValues) => number & {
|
|
74
|
+
_brand: "unitlessLineHeight";
|
|
75
|
+
};
|
|
76
|
+
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,35 +1,35 @@
|
|
|
1
|
-
import { ExcalidrawElement, NonDeletedExcalidrawElement, PointerType } from "./types";
|
|
2
|
-
import { AppState, Zoom } from "../types";
|
|
3
|
-
export type TransformHandleDirection = "n" | "s" | "w" | "e" | "nw" | "ne" | "sw" | "se";
|
|
4
|
-
export type TransformHandleType = TransformHandleDirection | "rotation";
|
|
5
|
-
export type TransformHandle = [number, number, number, number];
|
|
6
|
-
export type TransformHandles = Partial<{
|
|
7
|
-
[T in TransformHandleType]: TransformHandle;
|
|
8
|
-
}>;
|
|
9
|
-
export 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 OMIT_SIDES_FOR_FRAME: {
|
|
17
|
-
e: boolean;
|
|
18
|
-
s: boolean;
|
|
19
|
-
n: boolean;
|
|
20
|
-
w: boolean;
|
|
21
|
-
rotation: boolean;
|
|
22
|
-
};
|
|
23
|
-
export declare const getTransformHandlesFromCoords: ([x1, y1, x2, y2, cx, cy]: [number, number, number, number, number, number], angle: number, zoom: Zoom, pointerType: PointerType, omitSides?: {
|
|
24
|
-
s?: boolean | undefined;
|
|
25
|
-
e?: boolean | undefined;
|
|
26
|
-
w?: boolean | undefined;
|
|
27
|
-
n?: boolean | undefined;
|
|
28
|
-
nw?: boolean | undefined;
|
|
29
|
-
ne?: boolean | undefined;
|
|
30
|
-
sw?: boolean | undefined;
|
|
31
|
-
se?: boolean | undefined;
|
|
32
|
-
rotation?: boolean | undefined;
|
|
33
|
-
}, margin?: number) => TransformHandles;
|
|
34
|
-
export declare const getTransformHandles: (element: ExcalidrawElement, zoom: Zoom, pointerType?: PointerType) => TransformHandles;
|
|
35
|
-
export declare const shouldShowBoundingBox: (elements: NonDeletedExcalidrawElement[], appState: AppState) => boolean;
|
|
1
|
+
import { ExcalidrawElement, NonDeletedExcalidrawElement, PointerType } from "./types";
|
|
2
|
+
import { AppState, Zoom } from "../types";
|
|
3
|
+
export type TransformHandleDirection = "n" | "s" | "w" | "e" | "nw" | "ne" | "sw" | "se";
|
|
4
|
+
export type TransformHandleType = TransformHandleDirection | "rotation";
|
|
5
|
+
export type TransformHandle = [number, number, number, number];
|
|
6
|
+
export type TransformHandles = Partial<{
|
|
7
|
+
[T in TransformHandleType]: TransformHandle;
|
|
8
|
+
}>;
|
|
9
|
+
export 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 OMIT_SIDES_FOR_FRAME: {
|
|
17
|
+
e: boolean;
|
|
18
|
+
s: boolean;
|
|
19
|
+
n: boolean;
|
|
20
|
+
w: boolean;
|
|
21
|
+
rotation: boolean;
|
|
22
|
+
};
|
|
23
|
+
export declare const getTransformHandlesFromCoords: ([x1, y1, x2, y2, cx, cy]: [number, number, number, number, number, number], angle: number, zoom: Zoom, pointerType: PointerType, omitSides?: {
|
|
24
|
+
s?: boolean | undefined;
|
|
25
|
+
e?: boolean | undefined;
|
|
26
|
+
w?: boolean | undefined;
|
|
27
|
+
n?: boolean | undefined;
|
|
28
|
+
nw?: boolean | undefined;
|
|
29
|
+
ne?: boolean | undefined;
|
|
30
|
+
sw?: boolean | undefined;
|
|
31
|
+
se?: boolean | undefined;
|
|
32
|
+
rotation?: boolean | undefined;
|
|
33
|
+
}, margin?: number) => TransformHandles;
|
|
34
|
+
export declare const getTransformHandles: (element: ExcalidrawElement, zoom: Zoom, pointerType?: PointerType) => TransformHandles;
|
|
35
|
+
export declare const shouldShowBoundingBox: (elements: NonDeletedExcalidrawElement[], appState: AppState) => boolean;
|