@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,29 +1,29 @@
|
|
|
1
|
-
import { AppState } from "../types";
|
|
2
|
-
import { MarkNonNullable } from "../utility-types";
|
|
3
|
-
import { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawEmbeddableElement, ExcalidrawLinearElement, ExcalidrawBindableElement, ExcalidrawGenericElement, ExcalidrawFreeDrawElement, InitializedExcalidrawImageElement, ExcalidrawImageElement, ExcalidrawTextElementWithContainer, ExcalidrawTextContainer, ExcalidrawFrameElement, RoundnessType } from "./types";
|
|
4
|
-
export declare const isGenericElement: (element: ExcalidrawElement | null) => element is ExcalidrawGenericElement;
|
|
5
|
-
export declare const isInitializedImageElement: (element: ExcalidrawElement | null) => element is InitializedExcalidrawImageElement;
|
|
6
|
-
export declare const isImageElement: (element: ExcalidrawElement | null) => element is ExcalidrawImageElement;
|
|
7
|
-
export declare const isEmbeddableElement: (element: ExcalidrawElement | null | undefined) => element is ExcalidrawEmbeddableElement;
|
|
8
|
-
export declare const isTextElement: (element: ExcalidrawElement | null) => element is ExcalidrawTextElement;
|
|
9
|
-
export declare const isFrameElement: (element: ExcalidrawElement | null) => element is ExcalidrawFrameElement;
|
|
10
|
-
export declare const isFreeDrawElement: (element?: ExcalidrawElement | null) => element is ExcalidrawFreeDrawElement;
|
|
11
|
-
export declare const isFreeDrawElementType: (elementType: ExcalidrawElement["type"]) => boolean;
|
|
12
|
-
export declare const isLinearElement: (element?: ExcalidrawElement | null) => element is ExcalidrawLinearElement;
|
|
13
|
-
export declare const isArrowElement: (element?: ExcalidrawElement | null) => element is ExcalidrawLinearElement;
|
|
14
|
-
export declare const isLinearElementType: (elementType: AppState["activeTool"]["type"]) => boolean;
|
|
15
|
-
export declare const isBindingElement: (element?: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawLinearElement;
|
|
16
|
-
export declare const isBindingElementType: (elementType: AppState["activeTool"]["type"]) => boolean;
|
|
17
|
-
export declare const isBindableElement: (element: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawBindableElement;
|
|
18
|
-
export declare const isTextBindableContainer: (element: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawTextContainer;
|
|
19
|
-
export declare const isExcalidrawElement: (element: any) => boolean;
|
|
20
|
-
export declare const hasBoundTextElement: (element: ExcalidrawElement | null) => element is MarkNonNullable<ExcalidrawBindableElement, "boundElements">;
|
|
21
|
-
export declare const isBoundToContainer: (element: ExcalidrawElement | null) => element is ExcalidrawTextElementWithContainer;
|
|
22
|
-
export declare const isUsingAdaptiveRadius: (type: string) => boolean;
|
|
23
|
-
export declare const isUsingProportionalRadius: (type: string) => boolean;
|
|
24
|
-
export declare const canApplyRoundnessTypeToElement: (roundnessType: RoundnessType, element: ExcalidrawElement) => boolean;
|
|
25
|
-
export declare const getDefaultRoundnessTypeForElement: (element: ExcalidrawElement) => {
|
|
26
|
-
type: 2;
|
|
27
|
-
} | {
|
|
28
|
-
type: 3;
|
|
29
|
-
} | null;
|
|
1
|
+
import { AppState } from "../types";
|
|
2
|
+
import { MarkNonNullable } from "../utility-types";
|
|
3
|
+
import { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawEmbeddableElement, ExcalidrawLinearElement, ExcalidrawBindableElement, ExcalidrawGenericElement, ExcalidrawFreeDrawElement, InitializedExcalidrawImageElement, ExcalidrawImageElement, ExcalidrawTextElementWithContainer, ExcalidrawTextContainer, ExcalidrawFrameElement, RoundnessType } from "./types";
|
|
4
|
+
export declare const isGenericElement: (element: ExcalidrawElement | null) => element is ExcalidrawGenericElement;
|
|
5
|
+
export declare const isInitializedImageElement: (element: ExcalidrawElement | null) => element is InitializedExcalidrawImageElement;
|
|
6
|
+
export declare const isImageElement: (element: ExcalidrawElement | null) => element is ExcalidrawImageElement;
|
|
7
|
+
export declare const isEmbeddableElement: (element: ExcalidrawElement | null | undefined) => element is ExcalidrawEmbeddableElement;
|
|
8
|
+
export declare const isTextElement: (element: ExcalidrawElement | null) => element is ExcalidrawTextElement;
|
|
9
|
+
export declare const isFrameElement: (element: ExcalidrawElement | null) => element is ExcalidrawFrameElement;
|
|
10
|
+
export declare const isFreeDrawElement: (element?: ExcalidrawElement | null) => element is ExcalidrawFreeDrawElement;
|
|
11
|
+
export declare const isFreeDrawElementType: (elementType: ExcalidrawElement["type"]) => boolean;
|
|
12
|
+
export declare const isLinearElement: (element?: ExcalidrawElement | null) => element is ExcalidrawLinearElement;
|
|
13
|
+
export declare const isArrowElement: (element?: ExcalidrawElement | null) => element is ExcalidrawLinearElement;
|
|
14
|
+
export declare const isLinearElementType: (elementType: AppState["activeTool"]["type"]) => boolean;
|
|
15
|
+
export declare const isBindingElement: (element?: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawLinearElement;
|
|
16
|
+
export declare const isBindingElementType: (elementType: AppState["activeTool"]["type"]) => boolean;
|
|
17
|
+
export declare const isBindableElement: (element: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawBindableElement;
|
|
18
|
+
export declare const isTextBindableContainer: (element: ExcalidrawElement | null, includeLocked?: boolean) => element is ExcalidrawTextContainer;
|
|
19
|
+
export declare const isExcalidrawElement: (element: any) => boolean;
|
|
20
|
+
export declare const hasBoundTextElement: (element: ExcalidrawElement | null) => element is MarkNonNullable<ExcalidrawBindableElement, "boundElements">;
|
|
21
|
+
export declare const isBoundToContainer: (element: ExcalidrawElement | null) => element is ExcalidrawTextElementWithContainer;
|
|
22
|
+
export declare const isUsingAdaptiveRadius: (type: string) => boolean;
|
|
23
|
+
export declare const isUsingProportionalRadius: (type: string) => boolean;
|
|
24
|
+
export declare const canApplyRoundnessTypeToElement: (roundnessType: RoundnessType, element: ExcalidrawElement) => boolean;
|
|
25
|
+
export declare const getDefaultRoundnessTypeForElement: (element: ExcalidrawElement) => {
|
|
26
|
+
type: 2;
|
|
27
|
+
} | {
|
|
28
|
+
type: 3;
|
|
29
|
+
} | null;
|
package/types/element/types.d.ts
CHANGED
|
@@ -1,166 +1,166 @@
|
|
|
1
|
-
import { Point } from "../types";
|
|
2
|
-
import { FONT_FAMILY, ROUNDNESS, TEXT_ALIGN, THEME, VERTICAL_ALIGN } from "../constants";
|
|
3
|
-
import { MarkNonNullable, ValueOf } from "../utility-types";
|
|
4
|
-
export type ChartType = "bar" | "line";
|
|
5
|
-
export type FillStyle = "hachure" | "cross-hatch" | "solid" | "zigzag";
|
|
6
|
-
export type FontFamilyKeys = keyof typeof FONT_FAMILY;
|
|
7
|
-
export type FontFamilyValues = typeof FONT_FAMILY[FontFamilyKeys];
|
|
8
|
-
export type Theme = typeof THEME[keyof typeof THEME];
|
|
9
|
-
export type FontString = string & {
|
|
10
|
-
_brand: "fontString";
|
|
11
|
-
};
|
|
12
|
-
export type GroupId = string;
|
|
13
|
-
export type PointerType = "mouse" | "pen" | "touch";
|
|
14
|
-
export type StrokeRoundness = "round" | "sharp";
|
|
15
|
-
export type RoundnessType = ValueOf<typeof ROUNDNESS>;
|
|
16
|
-
export type StrokeStyle = "solid" | "dashed" | "dotted";
|
|
17
|
-
export type TextAlign = typeof TEXT_ALIGN[keyof typeof TEXT_ALIGN];
|
|
18
|
-
type VerticalAlignKeys = keyof typeof VERTICAL_ALIGN;
|
|
19
|
-
export type VerticalAlign = typeof VERTICAL_ALIGN[VerticalAlignKeys];
|
|
20
|
-
type _ExcalidrawElementBase = Readonly<{
|
|
21
|
-
id: string;
|
|
22
|
-
x: number;
|
|
23
|
-
y: number;
|
|
24
|
-
strokeColor: string;
|
|
25
|
-
backgroundColor: string;
|
|
26
|
-
fillStyle: FillStyle;
|
|
27
|
-
strokeWidth: number;
|
|
28
|
-
strokeStyle: StrokeStyle;
|
|
29
|
-
roundness: null | {
|
|
30
|
-
type: RoundnessType;
|
|
31
|
-
value?: number;
|
|
32
|
-
};
|
|
33
|
-
roughness: number;
|
|
34
|
-
opacity: number;
|
|
35
|
-
width: number;
|
|
36
|
-
height: number;
|
|
37
|
-
angle: number;
|
|
38
|
-
/** Random integer used to seed shape generation so that the roughjs shape
|
|
39
|
-
doesn't differ across renders. */
|
|
40
|
-
seed: number;
|
|
41
|
-
/** Integer that is sequentially incremented on each change. Used to reconcile
|
|
42
|
-
elements during collaboration or when saving to server. */
|
|
43
|
-
version: number;
|
|
44
|
-
/** Random integer that is regenerated on each change.
|
|
45
|
-
Used for deterministic reconciliation of updates during collaboration,
|
|
46
|
-
in case the versions (see above) are identical. */
|
|
47
|
-
versionNonce: number;
|
|
48
|
-
isDeleted: boolean;
|
|
49
|
-
/** List of groups the element belongs to.
|
|
50
|
-
Ordered from deepest to shallowest. */
|
|
51
|
-
groupIds: readonly GroupId[];
|
|
52
|
-
frameId: string | null;
|
|
53
|
-
/** other elements that are bound to this element */
|
|
54
|
-
boundElements: readonly Readonly<{
|
|
55
|
-
id: ExcalidrawLinearElement["id"];
|
|
56
|
-
type: "arrow" | "text";
|
|
57
|
-
}>[] | null;
|
|
58
|
-
/** epoch (ms) timestamp of last element update */
|
|
59
|
-
updated: number;
|
|
60
|
-
link: string | null;
|
|
61
|
-
locked: boolean;
|
|
62
|
-
customData?: Record<string, any>;
|
|
63
|
-
}>;
|
|
64
|
-
export type ExcalidrawSelectionElement = _ExcalidrawElementBase & {
|
|
65
|
-
type: "selection";
|
|
66
|
-
};
|
|
67
|
-
export type ExcalidrawRectangleElement = _ExcalidrawElementBase & {
|
|
68
|
-
type: "rectangle";
|
|
69
|
-
};
|
|
70
|
-
export type ExcalidrawDiamondElement = _ExcalidrawElementBase & {
|
|
71
|
-
type: "diamond";
|
|
72
|
-
};
|
|
73
|
-
export type ExcalidrawEllipseElement = _ExcalidrawElementBase & {
|
|
74
|
-
type: "ellipse";
|
|
75
|
-
};
|
|
76
|
-
export type ExcalidrawEmbeddableElement = _ExcalidrawElementBase & Readonly<{
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
*
|
|
80
|
-
* value
|
|
81
|
-
*
|
|
82
|
-
*
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
}>;
|
|
87
|
-
export type ExcalidrawImageElement = _ExcalidrawElementBase & Readonly<{
|
|
88
|
-
type: "image";
|
|
89
|
-
fileId: FileId | null;
|
|
90
|
-
/** whether respective file is persisted */
|
|
91
|
-
status: "pending" | "saved" | "error";
|
|
92
|
-
/** X and Y scale factors <-1, 1>, used for image axis flipping */
|
|
93
|
-
scale: [number, number];
|
|
94
|
-
}>;
|
|
95
|
-
export type InitializedExcalidrawImageElement = MarkNonNullable<ExcalidrawImageElement, "fileId">;
|
|
96
|
-
export type ExcalidrawFrameElement = _ExcalidrawElementBase & {
|
|
97
|
-
type: "frame";
|
|
98
|
-
name: string | null;
|
|
99
|
-
};
|
|
100
|
-
/**
|
|
101
|
-
* These are elements that don't have any additional properties.
|
|
102
|
-
*/
|
|
103
|
-
export type ExcalidrawGenericElement = ExcalidrawSelectionElement | ExcalidrawRectangleElement |
|
|
104
|
-
/**
|
|
105
|
-
* ExcalidrawElement should be JSON serializable and (eventually) contain
|
|
106
|
-
* no computed data. The list of all ExcalidrawElements should be shareable
|
|
107
|
-
* between peers and contain no state local to the peer.
|
|
108
|
-
*/
|
|
109
|
-
export type ExcalidrawElement = ExcalidrawGenericElement | ExcalidrawTextElement | ExcalidrawLinearElement | ExcalidrawFreeDrawElement | ExcalidrawImageElement | ExcalidrawFrameElement;
|
|
110
|
-
export type NonDeleted<TElement extends ExcalidrawElement> = TElement & {
|
|
111
|
-
isDeleted: boolean;
|
|
112
|
-
};
|
|
113
|
-
export type NonDeletedExcalidrawElement = NonDeleted<ExcalidrawElement>;
|
|
114
|
-
export type ExcalidrawTextElement = _ExcalidrawElementBase & Readonly<{
|
|
115
|
-
type: "text";
|
|
116
|
-
fontSize: number;
|
|
117
|
-
fontFamily: FontFamilyValues;
|
|
118
|
-
text: string;
|
|
119
|
-
rawText: string;
|
|
120
|
-
baseline: number;
|
|
121
|
-
textAlign: TextAlign;
|
|
122
|
-
verticalAlign: VerticalAlign;
|
|
123
|
-
containerId: ExcalidrawGenericElement["id"] | null;
|
|
124
|
-
originalText: string;
|
|
125
|
-
/**
|
|
126
|
-
* Unitless line height (aligned to W3C). To get line height in px, multiply
|
|
127
|
-
* with font size (using `getLineHeightInPx` helper).
|
|
128
|
-
*/
|
|
129
|
-
lineHeight: number & {
|
|
130
|
-
_brand: "unitlessLineHeight";
|
|
131
|
-
};
|
|
132
|
-
}>;
|
|
133
|
-
export type ExcalidrawBindableElement = ExcalidrawRectangleElement | ExcalidrawDiamondElement | ExcalidrawEllipseElement | ExcalidrawTextElement | ExcalidrawImageElement | ExcalidrawEmbeddableElement | ExcalidrawFrameElement;
|
|
134
|
-
export type ExcalidrawTextContainer = ExcalidrawRectangleElement | ExcalidrawDiamondElement | ExcalidrawEllipseElement | ExcalidrawArrowElement;
|
|
135
|
-
export type ExcalidrawTextElementWithContainer = {
|
|
136
|
-
containerId: ExcalidrawTextContainer["id"];
|
|
137
|
-
} & ExcalidrawTextElement;
|
|
138
|
-
export type PointBinding = {
|
|
139
|
-
elementId: ExcalidrawBindableElement["id"];
|
|
140
|
-
focus: number;
|
|
141
|
-
gap: number;
|
|
142
|
-
};
|
|
143
|
-
export type Arrowhead = "arrow" | "bar" | "dot" | "triangle";
|
|
144
|
-
export type ExcalidrawLinearElement = _ExcalidrawElementBase & Readonly<{
|
|
145
|
-
type: "line" | "arrow";
|
|
146
|
-
points: readonly Point[];
|
|
147
|
-
lastCommittedPoint: Point | null;
|
|
148
|
-
startBinding: PointBinding | null;
|
|
149
|
-
endBinding: PointBinding | null;
|
|
150
|
-
startArrowhead: Arrowhead | null;
|
|
151
|
-
endArrowhead: Arrowhead | null;
|
|
152
|
-
}>;
|
|
153
|
-
export type ExcalidrawArrowElement = ExcalidrawLinearElement & Readonly<{
|
|
154
|
-
type: "arrow";
|
|
155
|
-
}>;
|
|
156
|
-
export type ExcalidrawFreeDrawElement = _ExcalidrawElementBase & Readonly<{
|
|
157
|
-
type: "freedraw";
|
|
158
|
-
points: readonly Point[];
|
|
159
|
-
pressures: readonly number[];
|
|
160
|
-
simulatePressure: boolean;
|
|
161
|
-
lastCommittedPoint: Point | null;
|
|
162
|
-
}>;
|
|
163
|
-
export type FileId = string & {
|
|
164
|
-
_brand: "FileId";
|
|
165
|
-
};
|
|
166
|
-
export {};
|
|
1
|
+
import { Point } from "../types";
|
|
2
|
+
import { FONT_FAMILY, ROUNDNESS, TEXT_ALIGN, THEME, VERTICAL_ALIGN } from "../constants";
|
|
3
|
+
import { MarkNonNullable, ValueOf } from "../utility-types";
|
|
4
|
+
export type ChartType = "bar" | "line";
|
|
5
|
+
export type FillStyle = "hachure" | "cross-hatch" | "solid" | "zigzag";
|
|
6
|
+
export type FontFamilyKeys = keyof typeof FONT_FAMILY;
|
|
7
|
+
export type FontFamilyValues = typeof FONT_FAMILY[FontFamilyKeys];
|
|
8
|
+
export type Theme = typeof THEME[keyof typeof THEME];
|
|
9
|
+
export type FontString = string & {
|
|
10
|
+
_brand: "fontString";
|
|
11
|
+
};
|
|
12
|
+
export type GroupId = string;
|
|
13
|
+
export type PointerType = "mouse" | "pen" | "touch";
|
|
14
|
+
export type StrokeRoundness = "round" | "sharp";
|
|
15
|
+
export type RoundnessType = ValueOf<typeof ROUNDNESS>;
|
|
16
|
+
export type StrokeStyle = "solid" | "dashed" | "dotted";
|
|
17
|
+
export type TextAlign = typeof TEXT_ALIGN[keyof typeof TEXT_ALIGN];
|
|
18
|
+
type VerticalAlignKeys = keyof typeof VERTICAL_ALIGN;
|
|
19
|
+
export type VerticalAlign = typeof VERTICAL_ALIGN[VerticalAlignKeys];
|
|
20
|
+
type _ExcalidrawElementBase = Readonly<{
|
|
21
|
+
id: string;
|
|
22
|
+
x: number;
|
|
23
|
+
y: number;
|
|
24
|
+
strokeColor: string;
|
|
25
|
+
backgroundColor: string;
|
|
26
|
+
fillStyle: FillStyle;
|
|
27
|
+
strokeWidth: number;
|
|
28
|
+
strokeStyle: StrokeStyle;
|
|
29
|
+
roundness: null | {
|
|
30
|
+
type: RoundnessType;
|
|
31
|
+
value?: number;
|
|
32
|
+
};
|
|
33
|
+
roughness: number;
|
|
34
|
+
opacity: number;
|
|
35
|
+
width: number;
|
|
36
|
+
height: number;
|
|
37
|
+
angle: number;
|
|
38
|
+
/** Random integer used to seed shape generation so that the roughjs shape
|
|
39
|
+
doesn't differ across renders. */
|
|
40
|
+
seed: number;
|
|
41
|
+
/** Integer that is sequentially incremented on each change. Used to reconcile
|
|
42
|
+
elements during collaboration or when saving to server. */
|
|
43
|
+
version: number;
|
|
44
|
+
/** Random integer that is regenerated on each change.
|
|
45
|
+
Used for deterministic reconciliation of updates during collaboration,
|
|
46
|
+
in case the versions (see above) are identical. */
|
|
47
|
+
versionNonce: number;
|
|
48
|
+
isDeleted: boolean;
|
|
49
|
+
/** List of groups the element belongs to.
|
|
50
|
+
Ordered from deepest to shallowest. */
|
|
51
|
+
groupIds: readonly GroupId[];
|
|
52
|
+
frameId: string | null;
|
|
53
|
+
/** other elements that are bound to this element */
|
|
54
|
+
boundElements: readonly Readonly<{
|
|
55
|
+
id: ExcalidrawLinearElement["id"];
|
|
56
|
+
type: "arrow" | "text";
|
|
57
|
+
}>[] | null;
|
|
58
|
+
/** epoch (ms) timestamp of last element update */
|
|
59
|
+
updated: number;
|
|
60
|
+
link: string | null;
|
|
61
|
+
locked: boolean;
|
|
62
|
+
customData?: Record<string, any>;
|
|
63
|
+
}>;
|
|
64
|
+
export type ExcalidrawSelectionElement = _ExcalidrawElementBase & {
|
|
65
|
+
type: "selection";
|
|
66
|
+
};
|
|
67
|
+
export type ExcalidrawRectangleElement = _ExcalidrawElementBase & {
|
|
68
|
+
type: "rectangle";
|
|
69
|
+
};
|
|
70
|
+
export type ExcalidrawDiamondElement = _ExcalidrawElementBase & {
|
|
71
|
+
type: "diamond";
|
|
72
|
+
};
|
|
73
|
+
export type ExcalidrawEllipseElement = _ExcalidrawElementBase & {
|
|
74
|
+
type: "ellipse";
|
|
75
|
+
};
|
|
76
|
+
export type ExcalidrawEmbeddableElement = _ExcalidrawElementBase & Readonly<{
|
|
77
|
+
type: "embeddable";
|
|
78
|
+
/**
|
|
79
|
+
* indicates whether the embeddable src (url) has been validated for rendering.
|
|
80
|
+
* null value indicates that the validation is pending. We reset the
|
|
81
|
+
* value on each restore (or url change) so that we can guarantee
|
|
82
|
+
* the validation came from a trusted source (the editor). Also because we
|
|
83
|
+
* may not have access to host-app supplied url validator during restore.
|
|
84
|
+
*/
|
|
85
|
+
validated: boolean | null;
|
|
86
|
+
}>;
|
|
87
|
+
export type ExcalidrawImageElement = _ExcalidrawElementBase & Readonly<{
|
|
88
|
+
type: "image";
|
|
89
|
+
fileId: FileId | null;
|
|
90
|
+
/** whether respective file is persisted */
|
|
91
|
+
status: "pending" | "saved" | "error";
|
|
92
|
+
/** X and Y scale factors <-1, 1>, used for image axis flipping */
|
|
93
|
+
scale: [number, number];
|
|
94
|
+
}>;
|
|
95
|
+
export type InitializedExcalidrawImageElement = MarkNonNullable<ExcalidrawImageElement, "fileId">;
|
|
96
|
+
export type ExcalidrawFrameElement = _ExcalidrawElementBase & {
|
|
97
|
+
type: "frame";
|
|
98
|
+
name: string | null;
|
|
99
|
+
};
|
|
100
|
+
/**
|
|
101
|
+
* These are elements that don't have any additional properties.
|
|
102
|
+
*/
|
|
103
|
+
export type ExcalidrawGenericElement = ExcalidrawSelectionElement | ExcalidrawRectangleElement | ExcalidrawDiamondElement | ExcalidrawEllipseElement;
|
|
104
|
+
/**
|
|
105
|
+
* ExcalidrawElement should be JSON serializable and (eventually) contain
|
|
106
|
+
* no computed data. The list of all ExcalidrawElements should be shareable
|
|
107
|
+
* between peers and contain no state local to the peer.
|
|
108
|
+
*/
|
|
109
|
+
export type ExcalidrawElement = ExcalidrawGenericElement | ExcalidrawTextElement | ExcalidrawLinearElement | ExcalidrawFreeDrawElement | ExcalidrawImageElement | ExcalidrawFrameElement | ExcalidrawEmbeddableElement;
|
|
110
|
+
export type NonDeleted<TElement extends ExcalidrawElement> = TElement & {
|
|
111
|
+
isDeleted: boolean;
|
|
112
|
+
};
|
|
113
|
+
export type NonDeletedExcalidrawElement = NonDeleted<ExcalidrawElement>;
|
|
114
|
+
export type ExcalidrawTextElement = _ExcalidrawElementBase & Readonly<{
|
|
115
|
+
type: "text";
|
|
116
|
+
fontSize: number;
|
|
117
|
+
fontFamily: FontFamilyValues;
|
|
118
|
+
text: string;
|
|
119
|
+
rawText: string;
|
|
120
|
+
baseline: number;
|
|
121
|
+
textAlign: TextAlign;
|
|
122
|
+
verticalAlign: VerticalAlign;
|
|
123
|
+
containerId: ExcalidrawGenericElement["id"] | null;
|
|
124
|
+
originalText: string;
|
|
125
|
+
/**
|
|
126
|
+
* Unitless line height (aligned to W3C). To get line height in px, multiply
|
|
127
|
+
* with font size (using `getLineHeightInPx` helper).
|
|
128
|
+
*/
|
|
129
|
+
lineHeight: number & {
|
|
130
|
+
_brand: "unitlessLineHeight";
|
|
131
|
+
};
|
|
132
|
+
}>;
|
|
133
|
+
export type ExcalidrawBindableElement = ExcalidrawRectangleElement | ExcalidrawDiamondElement | ExcalidrawEllipseElement | ExcalidrawTextElement | ExcalidrawImageElement | ExcalidrawEmbeddableElement | ExcalidrawFrameElement;
|
|
134
|
+
export type ExcalidrawTextContainer = ExcalidrawRectangleElement | ExcalidrawDiamondElement | ExcalidrawEllipseElement | ExcalidrawArrowElement;
|
|
135
|
+
export type ExcalidrawTextElementWithContainer = {
|
|
136
|
+
containerId: ExcalidrawTextContainer["id"];
|
|
137
|
+
} & ExcalidrawTextElement;
|
|
138
|
+
export type PointBinding = {
|
|
139
|
+
elementId: ExcalidrawBindableElement["id"];
|
|
140
|
+
focus: number;
|
|
141
|
+
gap: number;
|
|
142
|
+
};
|
|
143
|
+
export type Arrowhead = "arrow" | "bar" | "dot" | "triangle";
|
|
144
|
+
export type ExcalidrawLinearElement = _ExcalidrawElementBase & Readonly<{
|
|
145
|
+
type: "line" | "arrow";
|
|
146
|
+
points: readonly Point[];
|
|
147
|
+
lastCommittedPoint: Point | null;
|
|
148
|
+
startBinding: PointBinding | null;
|
|
149
|
+
endBinding: PointBinding | null;
|
|
150
|
+
startArrowhead: Arrowhead | null;
|
|
151
|
+
endArrowhead: Arrowhead | null;
|
|
152
|
+
}>;
|
|
153
|
+
export type ExcalidrawArrowElement = ExcalidrawLinearElement & Readonly<{
|
|
154
|
+
type: "arrow";
|
|
155
|
+
}>;
|
|
156
|
+
export type ExcalidrawFreeDrawElement = _ExcalidrawElementBase & Readonly<{
|
|
157
|
+
type: "freedraw";
|
|
158
|
+
points: readonly Point[];
|
|
159
|
+
pressures: readonly number[];
|
|
160
|
+
simulatePressure: boolean;
|
|
161
|
+
lastCommittedPoint: Point | null;
|
|
162
|
+
}>;
|
|
163
|
+
export type FileId = string & {
|
|
164
|
+
_brand: "FileId";
|
|
165
|
+
};
|
|
166
|
+
export {};
|
package/types/errors.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
type CANVAS_ERROR_NAMES = "CANVAS_ERROR" | "CANVAS_POSSIBLY_TOO_BIG";
|
|
2
|
-
export declare class CanvasError extends Error {
|
|
3
|
-
constructor(message?: string, name?: CANVAS_ERROR_NAMES);
|
|
4
|
-
}
|
|
5
|
-
export declare class AbortError extends DOMException {
|
|
6
|
-
constructor(message?: string);
|
|
7
|
-
}
|
|
8
|
-
export {};
|
|
1
|
+
type CANVAS_ERROR_NAMES = "CANVAS_ERROR" | "CANVAS_POSSIBLY_TOO_BIG";
|
|
2
|
+
export declare class CanvasError extends Error {
|
|
3
|
+
constructor(message?: string, name?: CANVAS_ERROR_NAMES);
|
|
4
|
+
}
|
|
5
|
+
export declare class AbortError extends DOMException {
|
|
6
|
+
constructor(message?: string);
|
|
7
|
+
}
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { AppState } from "../types";
|
|
2
|
+
import { NonDeletedExcalidrawElement } from "../element/types";
|
|
3
|
+
declare type Props = {
|
|
4
|
+
setToast: (message: string) => void;
|
|
5
|
+
elements: readonly NonDeletedExcalidrawElement[];
|
|
6
|
+
appState: AppState;
|
|
7
|
+
};
|
|
8
|
+
declare const CustomStats: (props: Props) => JSX.Element;
|
|
9
|
+
export default CustomStats;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export declare const SAVE_TO_LOCAL_STORAGE_TIMEOUT = 300;
|
|
2
|
+
export declare const INITIAL_SCENE_UPDATE_TIMEOUT = 5000;
|
|
3
|
+
export declare const FILE_UPLOAD_TIMEOUT = 300;
|
|
4
|
+
export declare const LOAD_IMAGES_TIMEOUT = 500;
|
|
5
|
+
export declare const SYNC_FULL_SCENE_INTERVAL_MS = 20000;
|
|
6
|
+
export declare const SYNC_BROWSER_TABS_TIMEOUT = 50;
|
|
7
|
+
export declare const CURSOR_SYNC_TIMEOUT = 33;
|
|
8
|
+
export declare const DELETED_ELEMENT_TIMEOUT: number;
|
|
9
|
+
export declare const FILE_UPLOAD_MAX_BYTES: number;
|
|
10
|
+
export declare const FILE_CACHE_MAX_AGE_SEC = 31536000;
|
|
11
|
+
export declare const WS_EVENTS: {
|
|
12
|
+
SERVER_VOLATILE: string;
|
|
13
|
+
SERVER: string;
|
|
14
|
+
};
|
|
15
|
+
export declare enum WS_SCENE_EVENT_TYPES {
|
|
16
|
+
INIT = "SCENE_INIT",
|
|
17
|
+
UPDATE = "SCENE_UPDATE"
|
|
18
|
+
}
|
|
19
|
+
export declare const FIREBASE_STORAGE_PREFIXES: {
|
|
20
|
+
shareLinkFiles: string;
|
|
21
|
+
collabFiles: string;
|
|
22
|
+
};
|
|
23
|
+
export declare const ROOM_ID_BYTES = 10;
|
|
24
|
+
export declare const STORAGE_KEYS: {
|
|
25
|
+
readonly LOCAL_STORAGE_ELEMENTS: "excalidraw";
|
|
26
|
+
readonly LOCAL_STORAGE_APP_STATE: "excalidraw-state";
|
|
27
|
+
readonly LOCAL_STORAGE_COLLAB: "excalidraw-collab";
|
|
28
|
+
readonly LOCAL_STORAGE_LIBRARY: "excalidraw-library";
|
|
29
|
+
readonly LOCAL_STORAGE_THEME: "excalidraw-theme";
|
|
30
|
+
readonly VERSION_DATA_STATE: "version-dataState";
|
|
31
|
+
readonly VERSION_FILES: "version-files";
|
|
32
|
+
};
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
/// <reference types="lodash" />
|
|
2
|
+
import { PureComponent } from "react";
|
|
3
|
+
import { ExcalidrawImperativeAPI } from "../../types";
|
|
4
|
+
import { ImportedDataState } from "../../data/types";
|
|
5
|
+
import { ExcalidrawElement } from "../../element/types";
|
|
6
|
+
import { Gesture } from "../../types";
|
|
7
|
+
import { SocketUpdateDataSource, SyncableExcalidrawElement } from "../data";
|
|
8
|
+
import Portal from "./Portal";
|
|
9
|
+
import { UserIdleState } from "../../types";
|
|
10
|
+
import { FileManager } from "../data/FileManager";
|
|
11
|
+
export declare const collabAPIAtom: import("jotai").Atom<CollabAPI | null> & {
|
|
12
|
+
write: (get: {
|
|
13
|
+
<Value>(atom: import("jotai").Atom<Value | Promise<Value>>): Value;
|
|
14
|
+
<Value_1>(atom: import("jotai").Atom<Promise<Value_1>>): Value_1;
|
|
15
|
+
<Value_2>(atom: import("jotai").Atom<Value_2>): Value_2 extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? any : V : V : V : V : V : V : V : V : V : V : Value_2;
|
|
16
|
+
} & {
|
|
17
|
+
<Value_3>(atom: import("jotai").Atom<Value_3 | Promise<Value_3>>, options: {
|
|
18
|
+
unstable_promise: true;
|
|
19
|
+
}): Value_3 | Promise<Value_3>;
|
|
20
|
+
<Value_4>(atom: import("jotai").Atom<Promise<Value_4>>, options: {
|
|
21
|
+
unstable_promise: true;
|
|
22
|
+
}): Value_4 | Promise<Value_4>;
|
|
23
|
+
<Value_5>(atom: import("jotai").Atom<Value_5>, options: {
|
|
24
|
+
unstable_promise: true;
|
|
25
|
+
}): (Value_5 extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? any : V : V : V : V : V : V : V : V : V : V : Value_5) | Promise<Value_5 extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? any : V : V : V : V : V : V : V : V : V : V : Value_5>;
|
|
26
|
+
}, set: {
|
|
27
|
+
<Value_6, Result extends void | Promise<void>>(atom: import("jotai").WritableAtom<Value_6, undefined, Result>): Result;
|
|
28
|
+
<Value_7, Update, Result_1 extends void | Promise<void>>(atom: import("jotai").WritableAtom<Value_7, Update, Result_1>, update: Update): Result_1;
|
|
29
|
+
}, update: CollabAPI | ((prev: CollabAPI | null) => CollabAPI | null) | null) => void;
|
|
30
|
+
onMount?: (<S extends (update: CollabAPI | ((prev: CollabAPI | null) => CollabAPI | null) | null) => void>(setAtom: S) => void | (() => void)) | undefined;
|
|
31
|
+
} & {
|
|
32
|
+
init: CollabAPI | null;
|
|
33
|
+
};
|
|
34
|
+
export declare const collabDialogShownAtom: import("jotai").Atom<boolean> & {
|
|
35
|
+
write: (get: {
|
|
36
|
+
<Value>(atom: import("jotai").Atom<Value | Promise<Value>>): Value;
|
|
37
|
+
<Value_1>(atom: import("jotai").Atom<Promise<Value_1>>): Value_1;
|
|
38
|
+
<Value_2>(atom: import("jotai").Atom<Value_2>): Value_2 extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? any : V : V : V : V : V : V : V : V : V : V : Value_2;
|
|
39
|
+
} & {
|
|
40
|
+
<Value_3>(atom: import("jotai").Atom<Value_3 | Promise<Value_3>>, options: {
|
|
41
|
+
unstable_promise: true;
|
|
42
|
+
}): Value_3 | Promise<Value_3>;
|
|
43
|
+
<Value_4>(atom: import("jotai").Atom<Promise<Value_4>>, options: {
|
|
44
|
+
unstable_promise: true;
|
|
45
|
+
}): Value_4 | Promise<Value_4>;
|
|
46
|
+
<Value_5>(atom: import("jotai").Atom<Value_5>, options: {
|
|
47
|
+
unstable_promise: true;
|
|
48
|
+
}): (Value_5 extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? any : V : V : V : V : V : V : V : V : V : V : Value_5) | Promise<Value_5 extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? any : V : V : V : V : V : V : V : V : V : V : Value_5>;
|
|
49
|
+
}, set: {
|
|
50
|
+
<Value_6, Result extends void | Promise<void>>(atom: import("jotai").WritableAtom<Value_6, undefined, Result>): Result;
|
|
51
|
+
<Value_7, Update, Result_1 extends void | Promise<void>>(atom: import("jotai").WritableAtom<Value_7, Update, Result_1>, update: Update): Result_1;
|
|
52
|
+
}, update: boolean | ((prev: boolean) => boolean)) => void;
|
|
53
|
+
onMount?: (<S extends (update: boolean | ((prev: boolean) => boolean)) => void>(setAtom: S) => void | (() => void)) | undefined;
|
|
54
|
+
} & {
|
|
55
|
+
init: boolean;
|
|
56
|
+
};
|
|
57
|
+
export declare const isCollaboratingAtom: import("jotai").Atom<boolean> & {
|
|
58
|
+
write: (get: {
|
|
59
|
+
<Value>(atom: import("jotai").Atom<Value | Promise<Value>>): Value;
|
|
60
|
+
<Value_1>(atom: import("jotai").Atom<Promise<Value_1>>): Value_1;
|
|
61
|
+
<Value_2>(atom: import("jotai").Atom<Value_2>): Value_2 extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? any : V : V : V : V : V : V : V : V : V : V : Value_2;
|
|
62
|
+
} & {
|
|
63
|
+
<Value_3>(atom: import("jotai").Atom<Value_3 | Promise<Value_3>>, options: {
|
|
64
|
+
unstable_promise: true;
|
|
65
|
+
}): Value_3 | Promise<Value_3>;
|
|
66
|
+
<Value_4>(atom: import("jotai").Atom<Promise<Value_4>>, options: {
|
|
67
|
+
unstable_promise: true;
|
|
68
|
+
}): Value_4 | Promise<Value_4>;
|
|
69
|
+
<Value_5>(atom: import("jotai").Atom<Value_5>, options: {
|
|
70
|
+
unstable_promise: true;
|
|
71
|
+
}): (Value_5 extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? any : V : V : V : V : V : V : V : V : V : V : Value_5) | Promise<Value_5 extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? V extends Promise<infer V> ? any : V : V : V : V : V : V : V : V : V : V : Value_5>;
|
|
72
|
+
}, set: {
|
|
73
|
+
<Value_6, Result extends void | Promise<void>>(atom: import("jotai").WritableAtom<Value_6, undefined, Result>): Result;
|
|
74
|
+
<Value_7, Update, Result_1 extends void | Promise<void>>(atom: import("jotai").WritableAtom<Value_7, Update, Result_1>, update: Update): Result_1;
|
|
75
|
+
}, update: boolean | ((prev: boolean) => boolean)) => void;
|
|
76
|
+
onMount?: (<S extends (update: boolean | ((prev: boolean) => boolean)) => void>(setAtom: S) => void | (() => void)) | undefined;
|
|
77
|
+
} & {
|
|
78
|
+
init: boolean;
|
|
79
|
+
};
|
|
80
|
+
interface CollabState {
|
|
81
|
+
errorMessage: string;
|
|
82
|
+
username: string;
|
|
83
|
+
activeRoomLink: string;
|
|
84
|
+
}
|
|
85
|
+
declare type CollabInstance = InstanceType<typeof Collab>;
|
|
86
|
+
export interface CollabAPI {
|
|
87
|
+
/** function so that we can access the latest value from stale callbacks */
|
|
88
|
+
isCollaborating: () => boolean;
|
|
89
|
+
onPointerUpdate: CollabInstance["onPointerUpdate"];
|
|
90
|
+
startCollaboration: CollabInstance["startCollaboration"];
|
|
91
|
+
stopCollaboration: CollabInstance["stopCollaboration"];
|
|
92
|
+
syncElements: CollabInstance["syncElements"];
|
|
93
|
+
fetchImageFilesFromFirebase: CollabInstance["fetchImageFilesFromFirebase"];
|
|
94
|
+
setUsername: (username: string) => void;
|
|
95
|
+
}
|
|
96
|
+
interface PublicProps {
|
|
97
|
+
excalidrawAPI: ExcalidrawImperativeAPI;
|
|
98
|
+
}
|
|
99
|
+
declare type Props = PublicProps & {
|
|
100
|
+
modalIsShown: boolean;
|
|
101
|
+
};
|
|
102
|
+
declare class Collab extends PureComponent<Props, CollabState> {
|
|
103
|
+
portal: Portal;
|
|
104
|
+
fileManager: FileManager;
|
|
105
|
+
excalidrawAPI: Props["excalidrawAPI"];
|
|
106
|
+
activeIntervalId: number | null;
|
|
107
|
+
idleTimeoutId: number | null;
|
|
108
|
+
private socketInitializationTimer?;
|
|
109
|
+
private lastBroadcastedOrReceivedSceneVersion;
|
|
110
|
+
private collaborators;
|
|
111
|
+
constructor(props: Props);
|
|
112
|
+
componentDidMount(): void;
|
|
113
|
+
componentWillUnmount(): void;
|
|
114
|
+
isCollaborating: () => boolean;
|
|
115
|
+
private setIsCollaborating;
|
|
116
|
+
private onUnload;
|
|
117
|
+
private beforeUnload;
|
|
118
|
+
saveCollabRoomToFirebase: (syncableElements: readonly SyncableExcalidrawElement[]) => Promise<void>;
|
|
119
|
+
stopCollaboration: (keepRemoteState?: boolean) => void;
|
|
120
|
+
private destroySocketClient;
|
|
121
|
+
private fetchImageFilesFromFirebase;
|
|
122
|
+
private decryptPayload;
|
|
123
|
+
private fallbackInitializationHandler;
|
|
124
|
+
startCollaboration: (existingRoomLinkData: null | {
|
|
125
|
+
roomId: string;
|
|
126
|
+
roomKey: string;
|
|
127
|
+
}) => Promise<ImportedDataState | null>;
|
|
128
|
+
private initializeRoom;
|
|
129
|
+
private reconcileElements;
|
|
130
|
+
private loadImageFiles;
|
|
131
|
+
private handleRemoteSceneUpdate;
|
|
132
|
+
private onPointerMove;
|
|
133
|
+
private onVisibilityChange;
|
|
134
|
+
private reportIdle;
|
|
135
|
+
private reportActive;
|
|
136
|
+
private initializeIdleDetector;
|
|
137
|
+
setCollaborators(sockets: string[]): void;
|
|
138
|
+
setLastBroadcastedOrReceivedSceneVersion: (version: number) => void;
|
|
139
|
+
getLastBroadcastedOrReceivedSceneVersion: () => number;
|
|
140
|
+
getSceneElementsIncludingDeleted: () => readonly ExcalidrawElement[];
|
|
141
|
+
onPointerUpdate: import("lodash").DebouncedFunc<(payload: {
|
|
142
|
+
pointer: SocketUpdateDataSource["MOUSE_LOCATION"]["payload"]["pointer"];
|
|
143
|
+
button: SocketUpdateDataSource["MOUSE_LOCATION"]["payload"]["button"];
|
|
144
|
+
pointersMap: Gesture["pointers"];
|
|
145
|
+
}) => void>;
|
|
146
|
+
onIdleStateChange: (userState: UserIdleState) => void;
|
|
147
|
+
broadcastElements: (elements: readonly ExcalidrawElement[]) => void;
|
|
148
|
+
syncElements: (elements: readonly ExcalidrawElement[]) => void;
|
|
149
|
+
queueBroadcastAllElements: import("lodash").DebouncedFunc<() => void>;
|
|
150
|
+
queueSaveToFirebase: import("lodash").DebouncedFunc<() => void>;
|
|
151
|
+
handleClose: () => void;
|
|
152
|
+
setUsername: (username: string) => void;
|
|
153
|
+
onUsernameChange: (username: string) => void;
|
|
154
|
+
render(): JSX.Element;
|
|
155
|
+
}
|
|
156
|
+
declare global {
|
|
157
|
+
interface Window {
|
|
158
|
+
collab: InstanceType<typeof Collab>;
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
declare const _Collab: React.FC<PublicProps>;
|
|
162
|
+
export default _Collab;
|
|
163
|
+
export declare type TCollabClass = Collab;
|