@excalidraw/common 0.18.0-ac0d305 → 0.18.0-b1c6bfc
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/dev/index.js +1644 -296
- package/dist/dev/index.js.map +4 -4
- package/dist/prod/index.js +3 -3
- package/dist/types/common/debug.d.ts +21 -0
- package/dist/types/common/src/appEventBus.d.ts +27 -0
- package/dist/types/common/src/bounds.d.ts +10 -0
- package/dist/types/common/src/colors.d.ts +59 -39
- package/dist/types/common/src/constants.d.ts +26 -28
- package/dist/types/common/src/editorInterface.d.ts +34 -0
- package/dist/types/common/src/font-metadata.d.ts +1 -3
- package/dist/types/common/src/index.d.ts +5 -0
- package/dist/types/common/src/keys.d.ts +1 -1
- package/dist/types/common/src/utility-types.d.ts +0 -1
- package/dist/types/common/src/utils.d.ts +54 -43
- package/dist/types/common/src/versionedSnapshotStore.d.ts +17 -0
- package/dist/types/element/src/Scene.d.ts +6 -4
- package/dist/types/element/src/arrowheads.d.ts +3 -0
- package/dist/types/element/src/arrows/focus.d.ts +27 -0
- package/dist/types/element/src/arrows/helpers.d.ts +5 -0
- package/dist/types/element/src/binding.d.ts +67 -48
- package/dist/types/element/src/bounds.d.ts +7 -13
- package/dist/types/element/src/collision.d.ts +7 -2
- package/dist/types/element/src/comparisons.d.ts +7 -7
- package/dist/types/element/src/distribute.d.ts +2 -1
- package/dist/types/element/src/dragElements.d.ts +3 -3
- package/dist/types/element/src/duplicate.d.ts +3 -3
- package/dist/types/element/src/elbowArrow.d.ts +2 -0
- package/dist/types/element/src/fractionalIndex.d.ts +2 -2
- package/dist/types/element/src/frame.d.ts +8 -4
- package/dist/types/element/src/heading.d.ts +2 -1
- package/dist/types/element/src/image.d.ts +1 -11
- package/dist/types/element/src/index.d.ts +4 -3
- package/dist/types/element/src/linearElementEditor.d.ts +23 -22
- package/dist/types/element/src/mutateElement.d.ts +5 -1
- package/dist/types/element/src/newElement.d.ts +6 -6
- package/dist/types/element/src/renderElement.d.ts +1 -7
- package/dist/types/element/src/resizeElements.d.ts +10 -10
- package/dist/types/element/src/resizeTest.d.ts +6 -5
- package/dist/types/element/src/selection.d.ts +10 -10
- package/dist/types/element/src/shape.d.ts +9 -8
- package/dist/types/element/src/textElement.d.ts +1 -1
- package/dist/types/element/src/textMeasurements.d.ts +1 -3
- package/dist/types/element/src/textWrapping.d.ts +26 -0
- package/dist/types/{excalidraw/data → element/src}/transform.d.ts +3 -3
- package/dist/types/element/src/transformHandles.d.ts +8 -27
- package/dist/types/element/src/typeChecks.d.ts +4 -7
- package/dist/types/element/src/types.d.ts +12 -13
- package/dist/types/element/src/utils.d.ts +9 -4
- package/dist/types/element/src/zindex.d.ts +7 -1
- package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +170 -210
- package/dist/types/excalidraw/actions/actionAlign.d.ts +6 -7
- package/dist/types/excalidraw/actions/actionBoundText.d.ts +94 -121
- package/dist/types/excalidraw/actions/actionCanvas.d.ts +590 -936
- package/dist/types/excalidraw/actions/actionClipboard.d.ts +125 -897
- package/dist/types/excalidraw/actions/actionCropEditor.d.ts +45 -59
- package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +151 -195
- package/dist/types/excalidraw/actions/actionDeselect.d.ts +160 -0
- package/dist/types/excalidraw/actions/actionDistribute.d.ts +2 -3
- package/dist/types/excalidraw/actions/actionDuplicateSelection.d.ts +3 -4
- package/dist/types/excalidraw/actions/actionElementLink.d.ts +54 -74
- package/dist/types/excalidraw/actions/actionElementLock.d.ts +92 -119
- package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +60 -74
- package/dist/types/excalidraw/actions/actionExport.d.ts +174 -1413
- package/dist/types/excalidraw/actions/actionFinalize.d.ts +10 -396
- package/dist/types/excalidraw/actions/actionFlip.d.ts +2 -3
- package/dist/types/excalidraw/actions/actionFrame.d.ts +304 -395
- package/dist/types/excalidraw/actions/actionGroup.d.ts +97 -132
- package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +179 -231
- package/dist/types/excalidraw/actions/actionLink.d.ts +60 -74
- package/dist/types/excalidraw/actions/actionMenu.d.ts +49 -437
- package/dist/types/excalidraw/actions/actionNavigate.d.ts +18 -361
- package/dist/types/excalidraw/actions/actionProperties.d.ts +154 -2533
- package/dist/types/excalidraw/actions/actionSelectAll.d.ts +48 -66
- package/dist/types/excalidraw/actions/actionStyles.d.ts +45 -58
- package/dist/types/excalidraw/actions/actionTextAutoResize.d.ts +4 -4
- package/dist/types/excalidraw/actions/actionToggleArrowBinding.d.ts +173 -0
- package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +60 -74
- package/dist/types/excalidraw/actions/actionToggleMidpointSnapping.d.ts +173 -0
- package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +60 -74
- package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +48 -68
- package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +1 -1
- package/dist/types/excalidraw/actions/actionToggleStats.d.ts +59 -73
- package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +60 -74
- package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +60 -74
- package/dist/types/excalidraw/actions/actionZindex.d.ts +8 -9
- package/dist/types/excalidraw/actions/index.d.ts +4 -1
- package/dist/types/excalidraw/actions/register.d.ts +2 -2
- package/dist/types/excalidraw/actions/shortcuts.d.ts +1 -1
- package/dist/types/excalidraw/actions/types.d.ts +4 -4
- package/dist/types/excalidraw/appState.d.ts +43 -36
- package/dist/types/excalidraw/charts/charts.bar.d.ts +2 -0
- package/dist/types/excalidraw/charts/charts.constants.d.ts +48 -0
- package/dist/types/excalidraw/charts/charts.helpers.d.ts +32 -0
- package/dist/types/excalidraw/charts/charts.line.d.ts +2 -0
- package/dist/types/excalidraw/charts/charts.parse.d.ts +10 -0
- package/dist/types/excalidraw/charts/charts.radar.d.ts +2 -0
- package/dist/types/excalidraw/charts/charts.types.d.ts +18 -0
- package/dist/types/excalidraw/charts/index.d.ts +7 -0
- package/dist/types/excalidraw/clipboard.d.ts +15 -38
- package/dist/types/excalidraw/components/Actions.d.ts +14 -4
- package/dist/types/excalidraw/components/App.d.ts +109 -70
- package/dist/types/excalidraw/components/AppStateObserver.d.ts +37 -0
- package/dist/types/excalidraw/components/Card.d.ts +1 -3
- package/dist/types/excalidraw/components/ColorPicker/ColorInput.d.ts +2 -4
- package/dist/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +1 -3
- package/dist/types/excalidraw/components/ColorPicker/Picker.d.ts +2 -0
- package/dist/types/excalidraw/components/ColorPicker/PickerColorList.d.ts +2 -1
- package/dist/types/excalidraw/components/ColorPicker/ShadeList.d.ts +2 -1
- package/dist/types/excalidraw/components/ColorPicker/colorPickerUtils.d.ts +0 -1
- package/dist/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +0 -1
- package/dist/types/excalidraw/components/CommandPalette/CommandPalette.d.ts +1 -0
- package/dist/types/excalidraw/components/CommandPalette/types.d.ts +2 -4
- package/dist/types/excalidraw/components/ConvertElementTypePopup.d.ts +2 -2
- package/dist/types/excalidraw/components/DarkModeToggle.d.ts +1 -1
- package/dist/types/excalidraw/components/DefaultSidebar.d.ts +9 -13
- package/dist/types/excalidraw/components/ElementLinkDialog.d.ts +1 -1
- package/dist/types/excalidraw/components/Ellipsify.d.ts +1 -2
- package/dist/types/excalidraw/components/ErrorDialog.d.ts +1 -1
- package/dist/types/excalidraw/components/EyeDropper.d.ts +0 -1
- package/dist/types/excalidraw/components/FilledButton.d.ts +2 -1
- package/dist/types/excalidraw/components/FontPicker/FontPickerTrigger.d.ts +2 -1
- package/dist/types/excalidraw/components/FontPicker/keyboardNavHandlers.d.ts +0 -1
- package/dist/types/excalidraw/components/HelpDialog.d.ts +1 -1
- package/dist/types/excalidraw/components/HintViewer.d.ts +4 -3
- package/dist/types/excalidraw/components/IconPicker.d.ts +14 -9
- package/dist/types/excalidraw/components/InlineIcon.d.ts +3 -1
- package/dist/types/excalidraw/components/LayerUI.d.ts +2 -1
- package/dist/types/excalidraw/components/LibraryMenuControlButtons.d.ts +1 -1
- package/dist/types/excalidraw/components/LibraryMenuHeaderContent.d.ts +1 -2
- package/dist/types/excalidraw/components/LibraryMenuSection.d.ts +1 -1
- package/dist/types/excalidraw/components/LibraryUnit.d.ts +2 -3
- package/dist/types/excalidraw/components/LoadingMessage.d.ts +0 -1
- package/dist/types/excalidraw/components/MobileMenu.d.ts +3 -5
- package/dist/types/excalidraw/components/MobileToolBar.d.ts +10 -0
- package/dist/types/excalidraw/components/Modal.d.ts +0 -1
- package/dist/types/excalidraw/components/OverwriteConfirm/OverwriteConfirm.d.ts +1 -1
- package/dist/types/excalidraw/components/PasteChartDialog.d.ts +4 -5
- package/dist/types/excalidraw/components/Popover.d.ts +2 -1
- package/dist/types/excalidraw/components/PropertiesPopover.d.ts +1 -1
- package/dist/types/excalidraw/components/RadioGroup.d.ts +0 -1
- package/dist/types/excalidraw/components/RadioSelection.d.ts +4 -4
- package/dist/types/excalidraw/components/Range.d.ts +10 -4
- package/dist/types/excalidraw/components/ScrollableList.d.ts +0 -1
- package/dist/types/excalidraw/components/Sidebar/Sidebar.d.ts +15 -21
- package/dist/types/excalidraw/components/Sidebar/SidebarHeader.d.ts +1 -1
- package/dist/types/excalidraw/components/Sidebar/SidebarTab.d.ts +1 -2
- package/dist/types/excalidraw/components/Sidebar/SidebarTabTrigger.d.ts +1 -2
- package/dist/types/excalidraw/components/Sidebar/SidebarTabTriggers.d.ts +1 -2
- package/dist/types/excalidraw/components/Sidebar/SidebarTabs.d.ts +1 -2
- package/dist/types/excalidraw/components/Spinner.d.ts +4 -4
- package/dist/types/excalidraw/components/Stats/CanvasGrid.d.ts +0 -1
- package/dist/types/excalidraw/components/Stats/Collapsible.d.ts +0 -1
- package/dist/types/excalidraw/components/Stats/DragInput.d.ts +0 -1
- package/dist/types/excalidraw/components/Stats/index.d.ts +7 -8
- package/dist/types/excalidraw/components/Stats/utils.d.ts +1 -1
- package/dist/types/excalidraw/components/TTDDialog/Chat/ChatHistoryMenu.d.ts +15 -0
- package/dist/types/excalidraw/components/TTDDialog/Chat/ChatInterface.d.ts +23 -0
- package/dist/types/excalidraw/components/TTDDialog/Chat/ChatMessage.d.ts +14 -0
- package/dist/types/excalidraw/components/TTDDialog/Chat/TTDChatPanel.d.ts +27 -0
- package/dist/types/excalidraw/components/TTDDialog/Chat/index.d.ts +3 -0
- package/dist/types/excalidraw/components/TTDDialog/Chat/useChatAgent.d.ts +8 -0
- package/dist/types/excalidraw/components/TTDDialog/CodeMirrorEditor.d.ts +11 -0
- package/dist/types/excalidraw/components/TTDDialog/MermaidToExcalidraw.d.ts +3 -2
- package/dist/types/excalidraw/components/TTDDialog/TTDContext.d.ts +13 -0
- package/dist/types/excalidraw/components/TTDDialog/TTDDialog.d.ts +12 -29
- package/dist/types/excalidraw/components/TTDDialog/TTDDialogInput.d.ts +3 -3
- package/dist/types/excalidraw/components/TTDDialog/TTDDialogOutput.d.ts +5 -2
- package/dist/types/excalidraw/components/TTDDialog/TTDDialogPanel.d.ts +13 -9
- package/dist/types/excalidraw/components/TTDDialog/TTDDialogTab.d.ts +1 -2
- package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTrigger.d.ts +1 -2
- package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTriggers.d.ts +1 -2
- package/dist/types/excalidraw/components/TTDDialog/TTDPreviewPanel.d.ts +9 -0
- package/dist/types/excalidraw/components/TTDDialog/TTDWelcomeMessage.d.ts +1 -0
- package/dist/types/excalidraw/components/TTDDialog/TextToDiagram.d.ts +9 -0
- package/dist/types/excalidraw/components/TTDDialog/common.d.ts +16 -16
- package/dist/types/excalidraw/components/TTDDialog/hooks/useChatManagement.d.ts +13 -0
- package/dist/types/excalidraw/components/TTDDialog/hooks/useMermaidRenderer.d.ts +14 -0
- package/dist/types/excalidraw/components/TTDDialog/hooks/useTextGeneration.d.ts +7 -0
- package/dist/types/excalidraw/components/TTDDialog/mermaid-lang-lite.d.ts +2 -0
- package/dist/types/excalidraw/components/TTDDialog/types.d.ts +95 -0
- package/dist/types/excalidraw/components/TTDDialog/useTTDChatStorage.d.ts +22 -0
- package/dist/types/excalidraw/components/TTDDialog/utils/chat.d.ts +10 -0
- package/dist/types/excalidraw/components/TTDDialog/utils/mermaidAutoFix.d.ts +1 -0
- package/dist/types/excalidraw/components/TTDDialog/utils/mermaidError.d.ts +10 -0
- package/dist/types/excalidraw/components/TTDDialog/utils/mermaidValidation.d.ts +1 -0
- package/dist/types/excalidraw/components/TextField.d.ts +1 -0
- package/dist/types/excalidraw/components/Toast.d.ts +11 -7
- package/dist/types/excalidraw/components/ToolPopover.d.ts +25 -0
- package/dist/types/excalidraw/components/Trans.d.ts +2 -2
- package/dist/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +7 -3
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +47 -35
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +7 -5
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuGroup.d.ts +3 -3
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItem.d.ts +13 -22
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCheckbox.d.ts +5 -0
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContent.d.ts +5 -4
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContentRadio.d.ts +2 -2
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCustom.d.ts +2 -2
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemLink.d.ts +6 -6
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSub.d.ts +23 -0
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSubContent.d.ts +8 -0
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSubTrigger.d.ts +12 -0
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuTrigger.d.ts +3 -4
- package/dist/types/excalidraw/components/dropdownMenu/common.d.ts +2 -2
- package/dist/types/excalidraw/components/dropdownMenu/dropdownMenuUtils.d.ts +2 -0
- package/dist/types/excalidraw/components/hoc/withInternalFallback.d.ts +1 -1
- package/dist/types/excalidraw/components/hyperlink/helpers.d.ts +1 -1
- package/dist/types/excalidraw/components/icons.d.ts +44 -22
- package/dist/types/excalidraw/components/main-menu/DefaultItems.d.ts +20 -2
- package/dist/types/excalidraw/components/main-menu/MainMenu.d.ts +39 -35
- package/dist/types/excalidraw/components/shapes.d.ts +74 -1
- package/dist/types/excalidraw/data/blob.d.ts +329 -8
- package/dist/types/excalidraw/data/encode.d.ts +4 -4
- package/dist/types/excalidraw/data/encryption.d.ts +5 -5
- package/dist/types/excalidraw/data/filesystem.d.ts +5 -7
- package/dist/types/excalidraw/data/index.d.ts +4 -5
- package/dist/types/excalidraw/data/json.d.ts +171 -4
- package/dist/types/excalidraw/data/library.d.ts +24 -9
- package/dist/types/excalidraw/data/resave.d.ts +7 -2
- package/dist/types/excalidraw/data/restore.d.ts +25 -10
- package/dist/types/excalidraw/data/types.d.ts +4 -1
- package/dist/types/excalidraw/editor-jotai.d.ts +11 -11
- package/dist/types/excalidraw/errors.d.ts +14 -0
- package/dist/types/excalidraw/hooks/useLibraryItemSvg.d.ts +1 -1
- package/dist/types/excalidraw/hooks/useOutsideClick.d.ts +4 -3
- package/dist/types/excalidraw/hooks/useScrollPosition.d.ts +1 -2
- package/dist/types/excalidraw/i18n.d.ts +2 -2
- package/dist/types/excalidraw/renderer/animation.d.ts +12 -0
- package/dist/types/excalidraw/renderer/helpers.d.ts +6 -8
- package/dist/types/excalidraw/renderer/interactiveScene.d.ts +8 -14
- package/dist/types/excalidraw/scene/Renderer.d.ts +5 -2
- package/dist/types/excalidraw/scene/export.d.ts +2 -2
- package/dist/types/excalidraw/scene/scroll.d.ts +1 -6
- package/dist/types/excalidraw/scene/types.d.ts +22 -5
- package/dist/types/excalidraw/shortcut.d.ts +1 -0
- package/dist/types/excalidraw/snapping.d.ts +5 -5
- package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-bindings.d.ts +1 -1
- package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-loader.d.ts +1 -1
- package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-wasm.d.ts +1 -1
- package/dist/types/excalidraw/subset/woff2/woff2-loader.d.ts +2 -2
- package/dist/types/excalidraw/subset/woff2/woff2-wasm.d.ts +1 -1
- package/dist/types/excalidraw/textAutoResizeHandle.d.ts +15 -0
- package/dist/types/excalidraw/types.d.ts +123 -36
- package/dist/types/excalidraw/wysiwyg/textWysiwyg.d.ts +7 -3
- package/dist/types/math/src/curve.d.ts +4 -1
- package/dist/types/math/src/point.d.ts +7 -2
- package/dist/types/math/src/polygon.d.ts +2 -2
- package/dist/types/math/src/range.d.ts +1 -3
- package/dist/types/math/src/segment.d.ts +3 -3
- package/dist/types/math/src/types.d.ts +25 -1
- package/dist/types/utils/src/bbox.d.ts +1 -1
- package/dist/types/utils/src/export.d.ts +5 -5
- package/dist/types/utils/src/shape.d.ts +6 -6
- package/dist/types/utils/src/withinBounds.d.ts +2 -2
- package/package.json +7 -1
- package/dist/types/excalidraw/charts.d.ts +0 -27
- package/dist/types/excalidraw/components/DiagramToCodePlugin/DiagramToCodePlugin.d.ts +0 -4
- package/dist/types/excalidraw/components/ExcalidrawLogo.d.ts +0 -16
- package/dist/types/excalidraw/components/InitializeApp.d.ts +0 -10
- package/dist/types/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +0 -9
- package/dist/types/excalidraw/components/footer/FooterCenter.d.ts +0 -8
- package/dist/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +0 -10
- package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.Center.d.ts +0 -58
- package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.Hints.d.ts +0 -19
- package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.d.ts +0 -85
- package/dist/types/excalidraw/data/reconcile.d.ts +0 -7
- package/dist/types/excalidraw/index.d.ts +0 -47
- package/dist/types/excalidraw/polyfill.d.ts +0 -2
package/dist/dev/index.js
CHANGED
|
@@ -281,49 +281,48 @@ var BinaryHeap = class {
|
|
|
281
281
|
content = [];
|
|
282
282
|
sinkDown(idx) {
|
|
283
283
|
const node = this.content[idx];
|
|
284
|
+
const nodeScore = this.scoreFunction(node);
|
|
284
285
|
while (idx > 0) {
|
|
285
286
|
const parentN = (idx + 1 >> 1) - 1;
|
|
286
287
|
const parent = this.content[parentN];
|
|
287
|
-
if (
|
|
288
|
-
this.content[parentN] = node;
|
|
288
|
+
if (nodeScore < this.scoreFunction(parent)) {
|
|
289
289
|
this.content[idx] = parent;
|
|
290
290
|
idx = parentN;
|
|
291
291
|
} else {
|
|
292
292
|
break;
|
|
293
293
|
}
|
|
294
294
|
}
|
|
295
|
+
this.content[idx] = node;
|
|
295
296
|
}
|
|
296
297
|
bubbleUp(idx) {
|
|
297
298
|
const length = this.content.length;
|
|
298
299
|
const node = this.content[idx];
|
|
299
300
|
const score = this.scoreFunction(node);
|
|
300
301
|
while (true) {
|
|
301
|
-
const
|
|
302
|
-
const
|
|
303
|
-
let
|
|
304
|
-
let
|
|
302
|
+
const child1N = (idx + 1 << 1) - 1;
|
|
303
|
+
const child2N = child1N + 1;
|
|
304
|
+
let smallestIdx = idx;
|
|
305
|
+
let smallestScore = score;
|
|
305
306
|
if (child1N < length) {
|
|
306
|
-
const
|
|
307
|
-
child1Score
|
|
308
|
-
|
|
309
|
-
|
|
307
|
+
const child1Score = this.scoreFunction(this.content[child1N]);
|
|
308
|
+
if (child1Score < smallestScore) {
|
|
309
|
+
smallestIdx = child1N;
|
|
310
|
+
smallestScore = child1Score;
|
|
310
311
|
}
|
|
311
312
|
}
|
|
312
313
|
if (child2N < length) {
|
|
313
|
-
const
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
swap = child2N;
|
|
314
|
+
const child2Score = this.scoreFunction(this.content[child2N]);
|
|
315
|
+
if (child2Score < smallestScore) {
|
|
316
|
+
smallestIdx = child2N;
|
|
317
317
|
}
|
|
318
318
|
}
|
|
319
|
-
if (
|
|
320
|
-
this.content[idx] = this.content[swap];
|
|
321
|
-
this.content[swap] = node;
|
|
322
|
-
idx = swap;
|
|
323
|
-
} else {
|
|
319
|
+
if (smallestIdx === idx) {
|
|
324
320
|
break;
|
|
325
321
|
}
|
|
322
|
+
this.content[idx] = this.content[smallestIdx];
|
|
323
|
+
idx = smallestIdx;
|
|
326
324
|
}
|
|
325
|
+
this.content[idx] = node;
|
|
327
326
|
}
|
|
328
327
|
push(node) {
|
|
329
328
|
this.content.push(node);
|
|
@@ -364,173 +363,1058 @@ var BinaryHeap = class {
|
|
|
364
363
|
}
|
|
365
364
|
};
|
|
366
365
|
|
|
366
|
+
// src/bounds.ts
|
|
367
|
+
init_define_import_meta_env();
|
|
368
|
+
var isBounds = (box) => Array.isArray(box) && box.length === 4 && typeof box[0] === "number" && typeof box[1] === "number" && typeof box[2] === "number" && typeof box[3] === "number";
|
|
369
|
+
|
|
367
370
|
// src/colors.ts
|
|
368
371
|
init_define_import_meta_env();
|
|
369
372
|
|
|
370
|
-
// ../../node_modules/
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
"
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
"
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
"
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
"#
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
"
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
"
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
"#
|
|
523
|
-
|
|
524
|
-
"
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
373
|
+
// ../../node_modules/tinycolor2/esm/tinycolor.js
|
|
374
|
+
init_define_import_meta_env();
|
|
375
|
+
function _typeof(obj) {
|
|
376
|
+
"@babel/helpers - typeof";
|
|
377
|
+
return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(obj2) {
|
|
378
|
+
return typeof obj2;
|
|
379
|
+
} : function(obj2) {
|
|
380
|
+
return obj2 && "function" == typeof Symbol && obj2.constructor === Symbol && obj2 !== Symbol.prototype ? "symbol" : typeof obj2;
|
|
381
|
+
}, _typeof(obj);
|
|
382
|
+
}
|
|
383
|
+
var trimLeft = /^\s+/;
|
|
384
|
+
var trimRight = /\s+$/;
|
|
385
|
+
function tinycolor(color, opts) {
|
|
386
|
+
color = color ? color : "";
|
|
387
|
+
opts = opts || {};
|
|
388
|
+
if (color instanceof tinycolor) {
|
|
389
|
+
return color;
|
|
390
|
+
}
|
|
391
|
+
if (!(this instanceof tinycolor)) {
|
|
392
|
+
return new tinycolor(color, opts);
|
|
393
|
+
}
|
|
394
|
+
var rgb = inputToRGB(color);
|
|
395
|
+
this._originalInput = color, this._r = rgb.r, this._g = rgb.g, this._b = rgb.b, this._a = rgb.a, this._roundA = Math.round(100 * this._a) / 100, this._format = opts.format || rgb.format;
|
|
396
|
+
this._gradientType = opts.gradientType;
|
|
397
|
+
if (this._r < 1)
|
|
398
|
+
this._r = Math.round(this._r);
|
|
399
|
+
if (this._g < 1)
|
|
400
|
+
this._g = Math.round(this._g);
|
|
401
|
+
if (this._b < 1)
|
|
402
|
+
this._b = Math.round(this._b);
|
|
403
|
+
this._ok = rgb.ok;
|
|
404
|
+
}
|
|
405
|
+
tinycolor.prototype = {
|
|
406
|
+
isDark: function isDark() {
|
|
407
|
+
return this.getBrightness() < 128;
|
|
408
|
+
},
|
|
409
|
+
isLight: function isLight() {
|
|
410
|
+
return !this.isDark();
|
|
411
|
+
},
|
|
412
|
+
isValid: function isValid() {
|
|
413
|
+
return this._ok;
|
|
414
|
+
},
|
|
415
|
+
getOriginalInput: function getOriginalInput() {
|
|
416
|
+
return this._originalInput;
|
|
417
|
+
},
|
|
418
|
+
getFormat: function getFormat() {
|
|
419
|
+
return this._format;
|
|
420
|
+
},
|
|
421
|
+
getAlpha: function getAlpha() {
|
|
422
|
+
return this._a;
|
|
423
|
+
},
|
|
424
|
+
getBrightness: function getBrightness() {
|
|
425
|
+
var rgb = this.toRgb();
|
|
426
|
+
return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1e3;
|
|
427
|
+
},
|
|
428
|
+
getLuminance: function getLuminance() {
|
|
429
|
+
var rgb = this.toRgb();
|
|
430
|
+
var RsRGB, GsRGB, BsRGB, R, G, B;
|
|
431
|
+
RsRGB = rgb.r / 255;
|
|
432
|
+
GsRGB = rgb.g / 255;
|
|
433
|
+
BsRGB = rgb.b / 255;
|
|
434
|
+
if (RsRGB <= 0.03928)
|
|
435
|
+
R = RsRGB / 12.92;
|
|
436
|
+
else
|
|
437
|
+
R = Math.pow((RsRGB + 0.055) / 1.055, 2.4);
|
|
438
|
+
if (GsRGB <= 0.03928)
|
|
439
|
+
G = GsRGB / 12.92;
|
|
440
|
+
else
|
|
441
|
+
G = Math.pow((GsRGB + 0.055) / 1.055, 2.4);
|
|
442
|
+
if (BsRGB <= 0.03928)
|
|
443
|
+
B = BsRGB / 12.92;
|
|
444
|
+
else
|
|
445
|
+
B = Math.pow((BsRGB + 0.055) / 1.055, 2.4);
|
|
446
|
+
return 0.2126 * R + 0.7152 * G + 0.0722 * B;
|
|
447
|
+
},
|
|
448
|
+
setAlpha: function setAlpha(value) {
|
|
449
|
+
this._a = boundAlpha(value);
|
|
450
|
+
this._roundA = Math.round(100 * this._a) / 100;
|
|
451
|
+
return this;
|
|
452
|
+
},
|
|
453
|
+
toHsv: function toHsv() {
|
|
454
|
+
var hsv = rgbToHsv(this._r, this._g, this._b);
|
|
455
|
+
return {
|
|
456
|
+
h: hsv.h * 360,
|
|
457
|
+
s: hsv.s,
|
|
458
|
+
v: hsv.v,
|
|
459
|
+
a: this._a
|
|
460
|
+
};
|
|
461
|
+
},
|
|
462
|
+
toHsvString: function toHsvString() {
|
|
463
|
+
var hsv = rgbToHsv(this._r, this._g, this._b);
|
|
464
|
+
var h = Math.round(hsv.h * 360), s = Math.round(hsv.s * 100), v = Math.round(hsv.v * 100);
|
|
465
|
+
return this._a == 1 ? "hsv(" + h + ", " + s + "%, " + v + "%)" : "hsva(" + h + ", " + s + "%, " + v + "%, " + this._roundA + ")";
|
|
466
|
+
},
|
|
467
|
+
toHsl: function toHsl() {
|
|
468
|
+
var hsl = rgbToHsl(this._r, this._g, this._b);
|
|
469
|
+
return {
|
|
470
|
+
h: hsl.h * 360,
|
|
471
|
+
s: hsl.s,
|
|
472
|
+
l: hsl.l,
|
|
473
|
+
a: this._a
|
|
474
|
+
};
|
|
475
|
+
},
|
|
476
|
+
toHslString: function toHslString() {
|
|
477
|
+
var hsl = rgbToHsl(this._r, this._g, this._b);
|
|
478
|
+
var h = Math.round(hsl.h * 360), s = Math.round(hsl.s * 100), l = Math.round(hsl.l * 100);
|
|
479
|
+
return this._a == 1 ? "hsl(" + h + ", " + s + "%, " + l + "%)" : "hsla(" + h + ", " + s + "%, " + l + "%, " + this._roundA + ")";
|
|
480
|
+
},
|
|
481
|
+
toHex: function toHex(allow3Char) {
|
|
482
|
+
return rgbToHex(this._r, this._g, this._b, allow3Char);
|
|
483
|
+
},
|
|
484
|
+
toHexString: function toHexString(allow3Char) {
|
|
485
|
+
return "#" + this.toHex(allow3Char);
|
|
486
|
+
},
|
|
487
|
+
toHex8: function toHex8(allow4Char) {
|
|
488
|
+
return rgbaToHex(this._r, this._g, this._b, this._a, allow4Char);
|
|
489
|
+
},
|
|
490
|
+
toHex8String: function toHex8String(allow4Char) {
|
|
491
|
+
return "#" + this.toHex8(allow4Char);
|
|
492
|
+
},
|
|
493
|
+
toRgb: function toRgb() {
|
|
494
|
+
return {
|
|
495
|
+
r: Math.round(this._r),
|
|
496
|
+
g: Math.round(this._g),
|
|
497
|
+
b: Math.round(this._b),
|
|
498
|
+
a: this._a
|
|
499
|
+
};
|
|
500
|
+
},
|
|
501
|
+
toRgbString: function toRgbString() {
|
|
502
|
+
return this._a == 1 ? "rgb(" + Math.round(this._r) + ", " + Math.round(this._g) + ", " + Math.round(this._b) + ")" : "rgba(" + Math.round(this._r) + ", " + Math.round(this._g) + ", " + Math.round(this._b) + ", " + this._roundA + ")";
|
|
503
|
+
},
|
|
504
|
+
toPercentageRgb: function toPercentageRgb() {
|
|
505
|
+
return {
|
|
506
|
+
r: Math.round(bound01(this._r, 255) * 100) + "%",
|
|
507
|
+
g: Math.round(bound01(this._g, 255) * 100) + "%",
|
|
508
|
+
b: Math.round(bound01(this._b, 255) * 100) + "%",
|
|
509
|
+
a: this._a
|
|
510
|
+
};
|
|
511
|
+
},
|
|
512
|
+
toPercentageRgbString: function toPercentageRgbString() {
|
|
513
|
+
return this._a == 1 ? "rgb(" + Math.round(bound01(this._r, 255) * 100) + "%, " + Math.round(bound01(this._g, 255) * 100) + "%, " + Math.round(bound01(this._b, 255) * 100) + "%)" : "rgba(" + Math.round(bound01(this._r, 255) * 100) + "%, " + Math.round(bound01(this._g, 255) * 100) + "%, " + Math.round(bound01(this._b, 255) * 100) + "%, " + this._roundA + ")";
|
|
514
|
+
},
|
|
515
|
+
toName: function toName() {
|
|
516
|
+
if (this._a === 0) {
|
|
517
|
+
return "transparent";
|
|
518
|
+
}
|
|
519
|
+
if (this._a < 1) {
|
|
520
|
+
return false;
|
|
521
|
+
}
|
|
522
|
+
return hexNames[rgbToHex(this._r, this._g, this._b, true)] || false;
|
|
523
|
+
},
|
|
524
|
+
toFilter: function toFilter(secondColor) {
|
|
525
|
+
var hex8String = "#" + rgbaToArgbHex(this._r, this._g, this._b, this._a);
|
|
526
|
+
var secondHex8String = hex8String;
|
|
527
|
+
var gradientType = this._gradientType ? "GradientType = 1, " : "";
|
|
528
|
+
if (secondColor) {
|
|
529
|
+
var s = tinycolor(secondColor);
|
|
530
|
+
secondHex8String = "#" + rgbaToArgbHex(s._r, s._g, s._b, s._a);
|
|
531
|
+
}
|
|
532
|
+
return "progid:DXImageTransform.Microsoft.gradient(" + gradientType + "startColorstr=" + hex8String + ",endColorstr=" + secondHex8String + ")";
|
|
533
|
+
},
|
|
534
|
+
toString: function toString(format) {
|
|
535
|
+
var formatSet = !!format;
|
|
536
|
+
format = format || this._format;
|
|
537
|
+
var formattedString = false;
|
|
538
|
+
var hasAlpha = this._a < 1 && this._a >= 0;
|
|
539
|
+
var needsAlphaFormat = !formatSet && hasAlpha && (format === "hex" || format === "hex6" || format === "hex3" || format === "hex4" || format === "hex8" || format === "name");
|
|
540
|
+
if (needsAlphaFormat) {
|
|
541
|
+
if (format === "name" && this._a === 0) {
|
|
542
|
+
return this.toName();
|
|
543
|
+
}
|
|
544
|
+
return this.toRgbString();
|
|
545
|
+
}
|
|
546
|
+
if (format === "rgb") {
|
|
547
|
+
formattedString = this.toRgbString();
|
|
548
|
+
}
|
|
549
|
+
if (format === "prgb") {
|
|
550
|
+
formattedString = this.toPercentageRgbString();
|
|
551
|
+
}
|
|
552
|
+
if (format === "hex" || format === "hex6") {
|
|
553
|
+
formattedString = this.toHexString();
|
|
554
|
+
}
|
|
555
|
+
if (format === "hex3") {
|
|
556
|
+
formattedString = this.toHexString(true);
|
|
557
|
+
}
|
|
558
|
+
if (format === "hex4") {
|
|
559
|
+
formattedString = this.toHex8String(true);
|
|
560
|
+
}
|
|
561
|
+
if (format === "hex8") {
|
|
562
|
+
formattedString = this.toHex8String();
|
|
563
|
+
}
|
|
564
|
+
if (format === "name") {
|
|
565
|
+
formattedString = this.toName();
|
|
566
|
+
}
|
|
567
|
+
if (format === "hsl") {
|
|
568
|
+
formattedString = this.toHslString();
|
|
569
|
+
}
|
|
570
|
+
if (format === "hsv") {
|
|
571
|
+
formattedString = this.toHsvString();
|
|
572
|
+
}
|
|
573
|
+
return formattedString || this.toHexString();
|
|
574
|
+
},
|
|
575
|
+
clone: function clone() {
|
|
576
|
+
return tinycolor(this.toString());
|
|
577
|
+
},
|
|
578
|
+
_applyModification: function _applyModification(fn, args) {
|
|
579
|
+
var color = fn.apply(null, [this].concat([].slice.call(args)));
|
|
580
|
+
this._r = color._r;
|
|
581
|
+
this._g = color._g;
|
|
582
|
+
this._b = color._b;
|
|
583
|
+
this.setAlpha(color._a);
|
|
584
|
+
return this;
|
|
585
|
+
},
|
|
586
|
+
lighten: function lighten() {
|
|
587
|
+
return this._applyModification(_lighten, arguments);
|
|
588
|
+
},
|
|
589
|
+
brighten: function brighten() {
|
|
590
|
+
return this._applyModification(_brighten, arguments);
|
|
591
|
+
},
|
|
592
|
+
darken: function darken() {
|
|
593
|
+
return this._applyModification(_darken, arguments);
|
|
594
|
+
},
|
|
595
|
+
desaturate: function desaturate() {
|
|
596
|
+
return this._applyModification(_desaturate, arguments);
|
|
597
|
+
},
|
|
598
|
+
saturate: function saturate() {
|
|
599
|
+
return this._applyModification(_saturate, arguments);
|
|
600
|
+
},
|
|
601
|
+
greyscale: function greyscale() {
|
|
602
|
+
return this._applyModification(_greyscale, arguments);
|
|
603
|
+
},
|
|
604
|
+
spin: function spin() {
|
|
605
|
+
return this._applyModification(_spin, arguments);
|
|
606
|
+
},
|
|
607
|
+
_applyCombination: function _applyCombination(fn, args) {
|
|
608
|
+
return fn.apply(null, [this].concat([].slice.call(args)));
|
|
609
|
+
},
|
|
610
|
+
analogous: function analogous() {
|
|
611
|
+
return this._applyCombination(_analogous, arguments);
|
|
612
|
+
},
|
|
613
|
+
complement: function complement() {
|
|
614
|
+
return this._applyCombination(_complement, arguments);
|
|
615
|
+
},
|
|
616
|
+
monochromatic: function monochromatic() {
|
|
617
|
+
return this._applyCombination(_monochromatic, arguments);
|
|
618
|
+
},
|
|
619
|
+
splitcomplement: function splitcomplement() {
|
|
620
|
+
return this._applyCombination(_splitcomplement, arguments);
|
|
621
|
+
},
|
|
622
|
+
// Disabled until https://github.com/bgrins/TinyColor/issues/254
|
|
623
|
+
// polyad: function (number) {
|
|
624
|
+
// return this._applyCombination(polyad, [number]);
|
|
625
|
+
// },
|
|
626
|
+
triad: function triad() {
|
|
627
|
+
return this._applyCombination(polyad, [3]);
|
|
628
|
+
},
|
|
629
|
+
tetrad: function tetrad() {
|
|
630
|
+
return this._applyCombination(polyad, [4]);
|
|
631
|
+
}
|
|
632
|
+
};
|
|
633
|
+
tinycolor.fromRatio = function(color, opts) {
|
|
634
|
+
if (_typeof(color) == "object") {
|
|
635
|
+
var newColor = {};
|
|
636
|
+
for (var i in color) {
|
|
637
|
+
if (color.hasOwnProperty(i)) {
|
|
638
|
+
if (i === "a") {
|
|
639
|
+
newColor[i] = color[i];
|
|
640
|
+
} else {
|
|
641
|
+
newColor[i] = convertToPercentage(color[i]);
|
|
642
|
+
}
|
|
643
|
+
}
|
|
644
|
+
}
|
|
645
|
+
color = newColor;
|
|
646
|
+
}
|
|
647
|
+
return tinycolor(color, opts);
|
|
530
648
|
};
|
|
649
|
+
function inputToRGB(color) {
|
|
650
|
+
var rgb = {
|
|
651
|
+
r: 0,
|
|
652
|
+
g: 0,
|
|
653
|
+
b: 0
|
|
654
|
+
};
|
|
655
|
+
var a = 1;
|
|
656
|
+
var s = null;
|
|
657
|
+
var v = null;
|
|
658
|
+
var l = null;
|
|
659
|
+
var ok = false;
|
|
660
|
+
var format = false;
|
|
661
|
+
if (typeof color == "string") {
|
|
662
|
+
color = stringInputToObject(color);
|
|
663
|
+
}
|
|
664
|
+
if (_typeof(color) == "object") {
|
|
665
|
+
if (isValidCSSUnit(color.r) && isValidCSSUnit(color.g) && isValidCSSUnit(color.b)) {
|
|
666
|
+
rgb = rgbToRgb(color.r, color.g, color.b);
|
|
667
|
+
ok = true;
|
|
668
|
+
format = String(color.r).substr(-1) === "%" ? "prgb" : "rgb";
|
|
669
|
+
} else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.v)) {
|
|
670
|
+
s = convertToPercentage(color.s);
|
|
671
|
+
v = convertToPercentage(color.v);
|
|
672
|
+
rgb = hsvToRgb(color.h, s, v);
|
|
673
|
+
ok = true;
|
|
674
|
+
format = "hsv";
|
|
675
|
+
} else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.l)) {
|
|
676
|
+
s = convertToPercentage(color.s);
|
|
677
|
+
l = convertToPercentage(color.l);
|
|
678
|
+
rgb = hslToRgb(color.h, s, l);
|
|
679
|
+
ok = true;
|
|
680
|
+
format = "hsl";
|
|
681
|
+
}
|
|
682
|
+
if (color.hasOwnProperty("a")) {
|
|
683
|
+
a = color.a;
|
|
684
|
+
}
|
|
685
|
+
}
|
|
686
|
+
a = boundAlpha(a);
|
|
687
|
+
return {
|
|
688
|
+
ok,
|
|
689
|
+
format: color.format || format,
|
|
690
|
+
r: Math.min(255, Math.max(rgb.r, 0)),
|
|
691
|
+
g: Math.min(255, Math.max(rgb.g, 0)),
|
|
692
|
+
b: Math.min(255, Math.max(rgb.b, 0)),
|
|
693
|
+
a
|
|
694
|
+
};
|
|
695
|
+
}
|
|
696
|
+
function rgbToRgb(r, g, b) {
|
|
697
|
+
return {
|
|
698
|
+
r: bound01(r, 255) * 255,
|
|
699
|
+
g: bound01(g, 255) * 255,
|
|
700
|
+
b: bound01(b, 255) * 255
|
|
701
|
+
};
|
|
702
|
+
}
|
|
703
|
+
function rgbToHsl(r, g, b) {
|
|
704
|
+
r = bound01(r, 255);
|
|
705
|
+
g = bound01(g, 255);
|
|
706
|
+
b = bound01(b, 255);
|
|
707
|
+
var max = Math.max(r, g, b), min = Math.min(r, g, b);
|
|
708
|
+
var h, s, l = (max + min) / 2;
|
|
709
|
+
if (max == min) {
|
|
710
|
+
h = s = 0;
|
|
711
|
+
} else {
|
|
712
|
+
var d = max - min;
|
|
713
|
+
s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
|
|
714
|
+
switch (max) {
|
|
715
|
+
case r:
|
|
716
|
+
h = (g - b) / d + (g < b ? 6 : 0);
|
|
717
|
+
break;
|
|
718
|
+
case g:
|
|
719
|
+
h = (b - r) / d + 2;
|
|
720
|
+
break;
|
|
721
|
+
case b:
|
|
722
|
+
h = (r - g) / d + 4;
|
|
723
|
+
break;
|
|
724
|
+
}
|
|
725
|
+
h /= 6;
|
|
726
|
+
}
|
|
727
|
+
return {
|
|
728
|
+
h,
|
|
729
|
+
s,
|
|
730
|
+
l
|
|
731
|
+
};
|
|
732
|
+
}
|
|
733
|
+
function hslToRgb(h, s, l) {
|
|
734
|
+
var r, g, b;
|
|
735
|
+
h = bound01(h, 360);
|
|
736
|
+
s = bound01(s, 100);
|
|
737
|
+
l = bound01(l, 100);
|
|
738
|
+
function hue2rgb(p2, q2, t) {
|
|
739
|
+
if (t < 0)
|
|
740
|
+
t += 1;
|
|
741
|
+
if (t > 1)
|
|
742
|
+
t -= 1;
|
|
743
|
+
if (t < 1 / 6)
|
|
744
|
+
return p2 + (q2 - p2) * 6 * t;
|
|
745
|
+
if (t < 1 / 2)
|
|
746
|
+
return q2;
|
|
747
|
+
if (t < 2 / 3)
|
|
748
|
+
return p2 + (q2 - p2) * (2 / 3 - t) * 6;
|
|
749
|
+
return p2;
|
|
750
|
+
}
|
|
751
|
+
if (s === 0) {
|
|
752
|
+
r = g = b = l;
|
|
753
|
+
} else {
|
|
754
|
+
var q = l < 0.5 ? l * (1 + s) : l + s - l * s;
|
|
755
|
+
var p = 2 * l - q;
|
|
756
|
+
r = hue2rgb(p, q, h + 1 / 3);
|
|
757
|
+
g = hue2rgb(p, q, h);
|
|
758
|
+
b = hue2rgb(p, q, h - 1 / 3);
|
|
759
|
+
}
|
|
760
|
+
return {
|
|
761
|
+
r: r * 255,
|
|
762
|
+
g: g * 255,
|
|
763
|
+
b: b * 255
|
|
764
|
+
};
|
|
765
|
+
}
|
|
766
|
+
function rgbToHsv(r, g, b) {
|
|
767
|
+
r = bound01(r, 255);
|
|
768
|
+
g = bound01(g, 255);
|
|
769
|
+
b = bound01(b, 255);
|
|
770
|
+
var max = Math.max(r, g, b), min = Math.min(r, g, b);
|
|
771
|
+
var h, s, v = max;
|
|
772
|
+
var d = max - min;
|
|
773
|
+
s = max === 0 ? 0 : d / max;
|
|
774
|
+
if (max == min) {
|
|
775
|
+
h = 0;
|
|
776
|
+
} else {
|
|
777
|
+
switch (max) {
|
|
778
|
+
case r:
|
|
779
|
+
h = (g - b) / d + (g < b ? 6 : 0);
|
|
780
|
+
break;
|
|
781
|
+
case g:
|
|
782
|
+
h = (b - r) / d + 2;
|
|
783
|
+
break;
|
|
784
|
+
case b:
|
|
785
|
+
h = (r - g) / d + 4;
|
|
786
|
+
break;
|
|
787
|
+
}
|
|
788
|
+
h /= 6;
|
|
789
|
+
}
|
|
790
|
+
return {
|
|
791
|
+
h,
|
|
792
|
+
s,
|
|
793
|
+
v
|
|
794
|
+
};
|
|
795
|
+
}
|
|
796
|
+
function hsvToRgb(h, s, v) {
|
|
797
|
+
h = bound01(h, 360) * 6;
|
|
798
|
+
s = bound01(s, 100);
|
|
799
|
+
v = bound01(v, 100);
|
|
800
|
+
var i = Math.floor(h), f = h - i, p = v * (1 - s), q = v * (1 - f * s), t = v * (1 - (1 - f) * s), mod = i % 6, r = [v, q, p, p, t, v][mod], g = [t, v, v, q, p, p][mod], b = [p, p, t, v, v, q][mod];
|
|
801
|
+
return {
|
|
802
|
+
r: r * 255,
|
|
803
|
+
g: g * 255,
|
|
804
|
+
b: b * 255
|
|
805
|
+
};
|
|
806
|
+
}
|
|
807
|
+
function rgbToHex(r, g, b, allow3Char) {
|
|
808
|
+
var hex = [pad2(Math.round(r).toString(16)), pad2(Math.round(g).toString(16)), pad2(Math.round(b).toString(16))];
|
|
809
|
+
if (allow3Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1)) {
|
|
810
|
+
return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0);
|
|
811
|
+
}
|
|
812
|
+
return hex.join("");
|
|
813
|
+
}
|
|
814
|
+
function rgbaToHex(r, g, b, a, allow4Char) {
|
|
815
|
+
var hex = [pad2(Math.round(r).toString(16)), pad2(Math.round(g).toString(16)), pad2(Math.round(b).toString(16)), pad2(convertDecimalToHex(a))];
|
|
816
|
+
if (allow4Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1) && hex[3].charAt(0) == hex[3].charAt(1)) {
|
|
817
|
+
return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0) + hex[3].charAt(0);
|
|
818
|
+
}
|
|
819
|
+
return hex.join("");
|
|
820
|
+
}
|
|
821
|
+
function rgbaToArgbHex(r, g, b, a) {
|
|
822
|
+
var hex = [pad2(convertDecimalToHex(a)), pad2(Math.round(r).toString(16)), pad2(Math.round(g).toString(16)), pad2(Math.round(b).toString(16))];
|
|
823
|
+
return hex.join("");
|
|
824
|
+
}
|
|
825
|
+
tinycolor.equals = function(color1, color2) {
|
|
826
|
+
if (!color1 || !color2)
|
|
827
|
+
return false;
|
|
828
|
+
return tinycolor(color1).toRgbString() == tinycolor(color2).toRgbString();
|
|
829
|
+
};
|
|
830
|
+
tinycolor.random = function() {
|
|
831
|
+
return tinycolor.fromRatio({
|
|
832
|
+
r: Math.random(),
|
|
833
|
+
g: Math.random(),
|
|
834
|
+
b: Math.random()
|
|
835
|
+
});
|
|
836
|
+
};
|
|
837
|
+
function _desaturate(color, amount) {
|
|
838
|
+
amount = amount === 0 ? 0 : amount || 10;
|
|
839
|
+
var hsl = tinycolor(color).toHsl();
|
|
840
|
+
hsl.s -= amount / 100;
|
|
841
|
+
hsl.s = clamp01(hsl.s);
|
|
842
|
+
return tinycolor(hsl);
|
|
843
|
+
}
|
|
844
|
+
function _saturate(color, amount) {
|
|
845
|
+
amount = amount === 0 ? 0 : amount || 10;
|
|
846
|
+
var hsl = tinycolor(color).toHsl();
|
|
847
|
+
hsl.s += amount / 100;
|
|
848
|
+
hsl.s = clamp01(hsl.s);
|
|
849
|
+
return tinycolor(hsl);
|
|
850
|
+
}
|
|
851
|
+
function _greyscale(color) {
|
|
852
|
+
return tinycolor(color).desaturate(100);
|
|
853
|
+
}
|
|
854
|
+
function _lighten(color, amount) {
|
|
855
|
+
amount = amount === 0 ? 0 : amount || 10;
|
|
856
|
+
var hsl = tinycolor(color).toHsl();
|
|
857
|
+
hsl.l += amount / 100;
|
|
858
|
+
hsl.l = clamp01(hsl.l);
|
|
859
|
+
return tinycolor(hsl);
|
|
860
|
+
}
|
|
861
|
+
function _brighten(color, amount) {
|
|
862
|
+
amount = amount === 0 ? 0 : amount || 10;
|
|
863
|
+
var rgb = tinycolor(color).toRgb();
|
|
864
|
+
rgb.r = Math.max(0, Math.min(255, rgb.r - Math.round(255 * -(amount / 100))));
|
|
865
|
+
rgb.g = Math.max(0, Math.min(255, rgb.g - Math.round(255 * -(amount / 100))));
|
|
866
|
+
rgb.b = Math.max(0, Math.min(255, rgb.b - Math.round(255 * -(amount / 100))));
|
|
867
|
+
return tinycolor(rgb);
|
|
868
|
+
}
|
|
869
|
+
function _darken(color, amount) {
|
|
870
|
+
amount = amount === 0 ? 0 : amount || 10;
|
|
871
|
+
var hsl = tinycolor(color).toHsl();
|
|
872
|
+
hsl.l -= amount / 100;
|
|
873
|
+
hsl.l = clamp01(hsl.l);
|
|
874
|
+
return tinycolor(hsl);
|
|
875
|
+
}
|
|
876
|
+
function _spin(color, amount) {
|
|
877
|
+
var hsl = tinycolor(color).toHsl();
|
|
878
|
+
var hue = (hsl.h + amount) % 360;
|
|
879
|
+
hsl.h = hue < 0 ? 360 + hue : hue;
|
|
880
|
+
return tinycolor(hsl);
|
|
881
|
+
}
|
|
882
|
+
function _complement(color) {
|
|
883
|
+
var hsl = tinycolor(color).toHsl();
|
|
884
|
+
hsl.h = (hsl.h + 180) % 360;
|
|
885
|
+
return tinycolor(hsl);
|
|
886
|
+
}
|
|
887
|
+
function polyad(color, number) {
|
|
888
|
+
if (isNaN(number) || number <= 0) {
|
|
889
|
+
throw new Error("Argument to polyad must be a positive number");
|
|
890
|
+
}
|
|
891
|
+
var hsl = tinycolor(color).toHsl();
|
|
892
|
+
var result = [tinycolor(color)];
|
|
893
|
+
var step = 360 / number;
|
|
894
|
+
for (var i = 1; i < number; i++) {
|
|
895
|
+
result.push(tinycolor({
|
|
896
|
+
h: (hsl.h + i * step) % 360,
|
|
897
|
+
s: hsl.s,
|
|
898
|
+
l: hsl.l
|
|
899
|
+
}));
|
|
900
|
+
}
|
|
901
|
+
return result;
|
|
902
|
+
}
|
|
903
|
+
function _splitcomplement(color) {
|
|
904
|
+
var hsl = tinycolor(color).toHsl();
|
|
905
|
+
var h = hsl.h;
|
|
906
|
+
return [tinycolor(color), tinycolor({
|
|
907
|
+
h: (h + 72) % 360,
|
|
908
|
+
s: hsl.s,
|
|
909
|
+
l: hsl.l
|
|
910
|
+
}), tinycolor({
|
|
911
|
+
h: (h + 216) % 360,
|
|
912
|
+
s: hsl.s,
|
|
913
|
+
l: hsl.l
|
|
914
|
+
})];
|
|
915
|
+
}
|
|
916
|
+
function _analogous(color, results, slices) {
|
|
917
|
+
results = results || 6;
|
|
918
|
+
slices = slices || 30;
|
|
919
|
+
var hsl = tinycolor(color).toHsl();
|
|
920
|
+
var part = 360 / slices;
|
|
921
|
+
var ret = [tinycolor(color)];
|
|
922
|
+
for (hsl.h = (hsl.h - (part * results >> 1) + 720) % 360; --results; ) {
|
|
923
|
+
hsl.h = (hsl.h + part) % 360;
|
|
924
|
+
ret.push(tinycolor(hsl));
|
|
925
|
+
}
|
|
926
|
+
return ret;
|
|
927
|
+
}
|
|
928
|
+
function _monochromatic(color, results) {
|
|
929
|
+
results = results || 6;
|
|
930
|
+
var hsv = tinycolor(color).toHsv();
|
|
931
|
+
var h = hsv.h, s = hsv.s, v = hsv.v;
|
|
932
|
+
var ret = [];
|
|
933
|
+
var modification = 1 / results;
|
|
934
|
+
while (results--) {
|
|
935
|
+
ret.push(tinycolor({
|
|
936
|
+
h,
|
|
937
|
+
s,
|
|
938
|
+
v
|
|
939
|
+
}));
|
|
940
|
+
v = (v + modification) % 1;
|
|
941
|
+
}
|
|
942
|
+
return ret;
|
|
943
|
+
}
|
|
944
|
+
tinycolor.mix = function(color1, color2, amount) {
|
|
945
|
+
amount = amount === 0 ? 0 : amount || 50;
|
|
946
|
+
var rgb1 = tinycolor(color1).toRgb();
|
|
947
|
+
var rgb2 = tinycolor(color2).toRgb();
|
|
948
|
+
var p = amount / 100;
|
|
949
|
+
var rgba = {
|
|
950
|
+
r: (rgb2.r - rgb1.r) * p + rgb1.r,
|
|
951
|
+
g: (rgb2.g - rgb1.g) * p + rgb1.g,
|
|
952
|
+
b: (rgb2.b - rgb1.b) * p + rgb1.b,
|
|
953
|
+
a: (rgb2.a - rgb1.a) * p + rgb1.a
|
|
954
|
+
};
|
|
955
|
+
return tinycolor(rgba);
|
|
956
|
+
};
|
|
957
|
+
tinycolor.readability = function(color1, color2) {
|
|
958
|
+
var c1 = tinycolor(color1);
|
|
959
|
+
var c2 = tinycolor(color2);
|
|
960
|
+
return (Math.max(c1.getLuminance(), c2.getLuminance()) + 0.05) / (Math.min(c1.getLuminance(), c2.getLuminance()) + 0.05);
|
|
961
|
+
};
|
|
962
|
+
tinycolor.isReadable = function(color1, color2, wcag2) {
|
|
963
|
+
var readability = tinycolor.readability(color1, color2);
|
|
964
|
+
var wcag2Parms, out;
|
|
965
|
+
out = false;
|
|
966
|
+
wcag2Parms = validateWCAG2Parms(wcag2);
|
|
967
|
+
switch (wcag2Parms.level + wcag2Parms.size) {
|
|
968
|
+
case "AAsmall":
|
|
969
|
+
case "AAAlarge":
|
|
970
|
+
out = readability >= 4.5;
|
|
971
|
+
break;
|
|
972
|
+
case "AAlarge":
|
|
973
|
+
out = readability >= 3;
|
|
974
|
+
break;
|
|
975
|
+
case "AAAsmall":
|
|
976
|
+
out = readability >= 7;
|
|
977
|
+
break;
|
|
978
|
+
}
|
|
979
|
+
return out;
|
|
980
|
+
};
|
|
981
|
+
tinycolor.mostReadable = function(baseColor, colorList, args) {
|
|
982
|
+
var bestColor = null;
|
|
983
|
+
var bestScore = 0;
|
|
984
|
+
var readability;
|
|
985
|
+
var includeFallbackColors, level, size;
|
|
986
|
+
args = args || {};
|
|
987
|
+
includeFallbackColors = args.includeFallbackColors;
|
|
988
|
+
level = args.level;
|
|
989
|
+
size = args.size;
|
|
990
|
+
for (var i = 0; i < colorList.length; i++) {
|
|
991
|
+
readability = tinycolor.readability(baseColor, colorList[i]);
|
|
992
|
+
if (readability > bestScore) {
|
|
993
|
+
bestScore = readability;
|
|
994
|
+
bestColor = tinycolor(colorList[i]);
|
|
995
|
+
}
|
|
996
|
+
}
|
|
997
|
+
if (tinycolor.isReadable(baseColor, bestColor, {
|
|
998
|
+
level,
|
|
999
|
+
size
|
|
1000
|
+
}) || !includeFallbackColors) {
|
|
1001
|
+
return bestColor;
|
|
1002
|
+
} else {
|
|
1003
|
+
args.includeFallbackColors = false;
|
|
1004
|
+
return tinycolor.mostReadable(baseColor, ["#fff", "#000"], args);
|
|
1005
|
+
}
|
|
1006
|
+
};
|
|
1007
|
+
var names = tinycolor.names = {
|
|
1008
|
+
aliceblue: "f0f8ff",
|
|
1009
|
+
antiquewhite: "faebd7",
|
|
1010
|
+
aqua: "0ff",
|
|
1011
|
+
aquamarine: "7fffd4",
|
|
1012
|
+
azure: "f0ffff",
|
|
1013
|
+
beige: "f5f5dc",
|
|
1014
|
+
bisque: "ffe4c4",
|
|
1015
|
+
black: "000",
|
|
1016
|
+
blanchedalmond: "ffebcd",
|
|
1017
|
+
blue: "00f",
|
|
1018
|
+
blueviolet: "8a2be2",
|
|
1019
|
+
brown: "a52a2a",
|
|
1020
|
+
burlywood: "deb887",
|
|
1021
|
+
burntsienna: "ea7e5d",
|
|
1022
|
+
cadetblue: "5f9ea0",
|
|
1023
|
+
chartreuse: "7fff00",
|
|
1024
|
+
chocolate: "d2691e",
|
|
1025
|
+
coral: "ff7f50",
|
|
1026
|
+
cornflowerblue: "6495ed",
|
|
1027
|
+
cornsilk: "fff8dc",
|
|
1028
|
+
crimson: "dc143c",
|
|
1029
|
+
cyan: "0ff",
|
|
1030
|
+
darkblue: "00008b",
|
|
1031
|
+
darkcyan: "008b8b",
|
|
1032
|
+
darkgoldenrod: "b8860b",
|
|
1033
|
+
darkgray: "a9a9a9",
|
|
1034
|
+
darkgreen: "006400",
|
|
1035
|
+
darkgrey: "a9a9a9",
|
|
1036
|
+
darkkhaki: "bdb76b",
|
|
1037
|
+
darkmagenta: "8b008b",
|
|
1038
|
+
darkolivegreen: "556b2f",
|
|
1039
|
+
darkorange: "ff8c00",
|
|
1040
|
+
darkorchid: "9932cc",
|
|
1041
|
+
darkred: "8b0000",
|
|
1042
|
+
darksalmon: "e9967a",
|
|
1043
|
+
darkseagreen: "8fbc8f",
|
|
1044
|
+
darkslateblue: "483d8b",
|
|
1045
|
+
darkslategray: "2f4f4f",
|
|
1046
|
+
darkslategrey: "2f4f4f",
|
|
1047
|
+
darkturquoise: "00ced1",
|
|
1048
|
+
darkviolet: "9400d3",
|
|
1049
|
+
deeppink: "ff1493",
|
|
1050
|
+
deepskyblue: "00bfff",
|
|
1051
|
+
dimgray: "696969",
|
|
1052
|
+
dimgrey: "696969",
|
|
1053
|
+
dodgerblue: "1e90ff",
|
|
1054
|
+
firebrick: "b22222",
|
|
1055
|
+
floralwhite: "fffaf0",
|
|
1056
|
+
forestgreen: "228b22",
|
|
1057
|
+
fuchsia: "f0f",
|
|
1058
|
+
gainsboro: "dcdcdc",
|
|
1059
|
+
ghostwhite: "f8f8ff",
|
|
1060
|
+
gold: "ffd700",
|
|
1061
|
+
goldenrod: "daa520",
|
|
1062
|
+
gray: "808080",
|
|
1063
|
+
green: "008000",
|
|
1064
|
+
greenyellow: "adff2f",
|
|
1065
|
+
grey: "808080",
|
|
1066
|
+
honeydew: "f0fff0",
|
|
1067
|
+
hotpink: "ff69b4",
|
|
1068
|
+
indianred: "cd5c5c",
|
|
1069
|
+
indigo: "4b0082",
|
|
1070
|
+
ivory: "fffff0",
|
|
1071
|
+
khaki: "f0e68c",
|
|
1072
|
+
lavender: "e6e6fa",
|
|
1073
|
+
lavenderblush: "fff0f5",
|
|
1074
|
+
lawngreen: "7cfc00",
|
|
1075
|
+
lemonchiffon: "fffacd",
|
|
1076
|
+
lightblue: "add8e6",
|
|
1077
|
+
lightcoral: "f08080",
|
|
1078
|
+
lightcyan: "e0ffff",
|
|
1079
|
+
lightgoldenrodyellow: "fafad2",
|
|
1080
|
+
lightgray: "d3d3d3",
|
|
1081
|
+
lightgreen: "90ee90",
|
|
1082
|
+
lightgrey: "d3d3d3",
|
|
1083
|
+
lightpink: "ffb6c1",
|
|
1084
|
+
lightsalmon: "ffa07a",
|
|
1085
|
+
lightseagreen: "20b2aa",
|
|
1086
|
+
lightskyblue: "87cefa",
|
|
1087
|
+
lightslategray: "789",
|
|
1088
|
+
lightslategrey: "789",
|
|
1089
|
+
lightsteelblue: "b0c4de",
|
|
1090
|
+
lightyellow: "ffffe0",
|
|
1091
|
+
lime: "0f0",
|
|
1092
|
+
limegreen: "32cd32",
|
|
1093
|
+
linen: "faf0e6",
|
|
1094
|
+
magenta: "f0f",
|
|
1095
|
+
maroon: "800000",
|
|
1096
|
+
mediumaquamarine: "66cdaa",
|
|
1097
|
+
mediumblue: "0000cd",
|
|
1098
|
+
mediumorchid: "ba55d3",
|
|
1099
|
+
mediumpurple: "9370db",
|
|
1100
|
+
mediumseagreen: "3cb371",
|
|
1101
|
+
mediumslateblue: "7b68ee",
|
|
1102
|
+
mediumspringgreen: "00fa9a",
|
|
1103
|
+
mediumturquoise: "48d1cc",
|
|
1104
|
+
mediumvioletred: "c71585",
|
|
1105
|
+
midnightblue: "191970",
|
|
1106
|
+
mintcream: "f5fffa",
|
|
1107
|
+
mistyrose: "ffe4e1",
|
|
1108
|
+
moccasin: "ffe4b5",
|
|
1109
|
+
navajowhite: "ffdead",
|
|
1110
|
+
navy: "000080",
|
|
1111
|
+
oldlace: "fdf5e6",
|
|
1112
|
+
olive: "808000",
|
|
1113
|
+
olivedrab: "6b8e23",
|
|
1114
|
+
orange: "ffa500",
|
|
1115
|
+
orangered: "ff4500",
|
|
1116
|
+
orchid: "da70d6",
|
|
1117
|
+
palegoldenrod: "eee8aa",
|
|
1118
|
+
palegreen: "98fb98",
|
|
1119
|
+
paleturquoise: "afeeee",
|
|
1120
|
+
palevioletred: "db7093",
|
|
1121
|
+
papayawhip: "ffefd5",
|
|
1122
|
+
peachpuff: "ffdab9",
|
|
1123
|
+
peru: "cd853f",
|
|
1124
|
+
pink: "ffc0cb",
|
|
1125
|
+
plum: "dda0dd",
|
|
1126
|
+
powderblue: "b0e0e6",
|
|
1127
|
+
purple: "800080",
|
|
1128
|
+
rebeccapurple: "663399",
|
|
1129
|
+
red: "f00",
|
|
1130
|
+
rosybrown: "bc8f8f",
|
|
1131
|
+
royalblue: "4169e1",
|
|
1132
|
+
saddlebrown: "8b4513",
|
|
1133
|
+
salmon: "fa8072",
|
|
1134
|
+
sandybrown: "f4a460",
|
|
1135
|
+
seagreen: "2e8b57",
|
|
1136
|
+
seashell: "fff5ee",
|
|
1137
|
+
sienna: "a0522d",
|
|
1138
|
+
silver: "c0c0c0",
|
|
1139
|
+
skyblue: "87ceeb",
|
|
1140
|
+
slateblue: "6a5acd",
|
|
1141
|
+
slategray: "708090",
|
|
1142
|
+
slategrey: "708090",
|
|
1143
|
+
snow: "fffafa",
|
|
1144
|
+
springgreen: "00ff7f",
|
|
1145
|
+
steelblue: "4682b4",
|
|
1146
|
+
tan: "d2b48c",
|
|
1147
|
+
teal: "008080",
|
|
1148
|
+
thistle: "d8bfd8",
|
|
1149
|
+
tomato: "ff6347",
|
|
1150
|
+
turquoise: "40e0d0",
|
|
1151
|
+
violet: "ee82ee",
|
|
1152
|
+
wheat: "f5deb3",
|
|
1153
|
+
white: "fff",
|
|
1154
|
+
whitesmoke: "f5f5f5",
|
|
1155
|
+
yellow: "ff0",
|
|
1156
|
+
yellowgreen: "9acd32"
|
|
1157
|
+
};
|
|
1158
|
+
var hexNames = tinycolor.hexNames = flip(names);
|
|
1159
|
+
function flip(o) {
|
|
1160
|
+
var flipped = {};
|
|
1161
|
+
for (var i in o) {
|
|
1162
|
+
if (o.hasOwnProperty(i)) {
|
|
1163
|
+
flipped[o[i]] = i;
|
|
1164
|
+
}
|
|
1165
|
+
}
|
|
1166
|
+
return flipped;
|
|
1167
|
+
}
|
|
1168
|
+
function boundAlpha(a) {
|
|
1169
|
+
a = parseFloat(a);
|
|
1170
|
+
if (isNaN(a) || a < 0 || a > 1) {
|
|
1171
|
+
a = 1;
|
|
1172
|
+
}
|
|
1173
|
+
return a;
|
|
1174
|
+
}
|
|
1175
|
+
function bound01(n, max) {
|
|
1176
|
+
if (isOnePointZero(n))
|
|
1177
|
+
n = "100%";
|
|
1178
|
+
var processPercent = isPercentage(n);
|
|
1179
|
+
n = Math.min(max, Math.max(0, parseFloat(n)));
|
|
1180
|
+
if (processPercent) {
|
|
1181
|
+
n = parseInt(n * max, 10) / 100;
|
|
1182
|
+
}
|
|
1183
|
+
if (Math.abs(n - max) < 1e-6) {
|
|
1184
|
+
return 1;
|
|
1185
|
+
}
|
|
1186
|
+
return n % max / parseFloat(max);
|
|
1187
|
+
}
|
|
1188
|
+
function clamp01(val) {
|
|
1189
|
+
return Math.min(1, Math.max(0, val));
|
|
1190
|
+
}
|
|
1191
|
+
function parseIntFromHex(val) {
|
|
1192
|
+
return parseInt(val, 16);
|
|
1193
|
+
}
|
|
1194
|
+
function isOnePointZero(n) {
|
|
1195
|
+
return typeof n == "string" && n.indexOf(".") != -1 && parseFloat(n) === 1;
|
|
1196
|
+
}
|
|
1197
|
+
function isPercentage(n) {
|
|
1198
|
+
return typeof n === "string" && n.indexOf("%") != -1;
|
|
1199
|
+
}
|
|
1200
|
+
function pad2(c) {
|
|
1201
|
+
return c.length == 1 ? "0" + c : "" + c;
|
|
1202
|
+
}
|
|
1203
|
+
function convertToPercentage(n) {
|
|
1204
|
+
if (n <= 1) {
|
|
1205
|
+
n = n * 100 + "%";
|
|
1206
|
+
}
|
|
1207
|
+
return n;
|
|
1208
|
+
}
|
|
1209
|
+
function convertDecimalToHex(d) {
|
|
1210
|
+
return Math.round(parseFloat(d) * 255).toString(16);
|
|
1211
|
+
}
|
|
1212
|
+
function convertHexToDecimal(h) {
|
|
1213
|
+
return parseIntFromHex(h) / 255;
|
|
1214
|
+
}
|
|
1215
|
+
var matchers = function() {
|
|
1216
|
+
var CSS_INTEGER = "[-\\+]?\\d+%?";
|
|
1217
|
+
var CSS_NUMBER = "[-\\+]?\\d*\\.\\d+%?";
|
|
1218
|
+
var CSS_UNIT = "(?:" + CSS_NUMBER + ")|(?:" + CSS_INTEGER + ")";
|
|
1219
|
+
var PERMISSIVE_MATCH3 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?";
|
|
1220
|
+
var PERMISSIVE_MATCH4 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?";
|
|
1221
|
+
return {
|
|
1222
|
+
CSS_UNIT: new RegExp(CSS_UNIT),
|
|
1223
|
+
rgb: new RegExp("rgb" + PERMISSIVE_MATCH3),
|
|
1224
|
+
rgba: new RegExp("rgba" + PERMISSIVE_MATCH4),
|
|
1225
|
+
hsl: new RegExp("hsl" + PERMISSIVE_MATCH3),
|
|
1226
|
+
hsla: new RegExp("hsla" + PERMISSIVE_MATCH4),
|
|
1227
|
+
hsv: new RegExp("hsv" + PERMISSIVE_MATCH3),
|
|
1228
|
+
hsva: new RegExp("hsva" + PERMISSIVE_MATCH4),
|
|
1229
|
+
hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,
|
|
1230
|
+
hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,
|
|
1231
|
+
hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,
|
|
1232
|
+
hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/
|
|
1233
|
+
};
|
|
1234
|
+
}();
|
|
1235
|
+
function isValidCSSUnit(color) {
|
|
1236
|
+
return !!matchers.CSS_UNIT.exec(color);
|
|
1237
|
+
}
|
|
1238
|
+
function stringInputToObject(color) {
|
|
1239
|
+
color = color.replace(trimLeft, "").replace(trimRight, "").toLowerCase();
|
|
1240
|
+
var named = false;
|
|
1241
|
+
if (names[color]) {
|
|
1242
|
+
color = names[color];
|
|
1243
|
+
named = true;
|
|
1244
|
+
} else if (color == "transparent") {
|
|
1245
|
+
return {
|
|
1246
|
+
r: 0,
|
|
1247
|
+
g: 0,
|
|
1248
|
+
b: 0,
|
|
1249
|
+
a: 0,
|
|
1250
|
+
format: "name"
|
|
1251
|
+
};
|
|
1252
|
+
}
|
|
1253
|
+
var match;
|
|
1254
|
+
if (match = matchers.rgb.exec(color)) {
|
|
1255
|
+
return {
|
|
1256
|
+
r: match[1],
|
|
1257
|
+
g: match[2],
|
|
1258
|
+
b: match[3]
|
|
1259
|
+
};
|
|
1260
|
+
}
|
|
1261
|
+
if (match = matchers.rgba.exec(color)) {
|
|
1262
|
+
return {
|
|
1263
|
+
r: match[1],
|
|
1264
|
+
g: match[2],
|
|
1265
|
+
b: match[3],
|
|
1266
|
+
a: match[4]
|
|
1267
|
+
};
|
|
1268
|
+
}
|
|
1269
|
+
if (match = matchers.hsl.exec(color)) {
|
|
1270
|
+
return {
|
|
1271
|
+
h: match[1],
|
|
1272
|
+
s: match[2],
|
|
1273
|
+
l: match[3]
|
|
1274
|
+
};
|
|
1275
|
+
}
|
|
1276
|
+
if (match = matchers.hsla.exec(color)) {
|
|
1277
|
+
return {
|
|
1278
|
+
h: match[1],
|
|
1279
|
+
s: match[2],
|
|
1280
|
+
l: match[3],
|
|
1281
|
+
a: match[4]
|
|
1282
|
+
};
|
|
1283
|
+
}
|
|
1284
|
+
if (match = matchers.hsv.exec(color)) {
|
|
1285
|
+
return {
|
|
1286
|
+
h: match[1],
|
|
1287
|
+
s: match[2],
|
|
1288
|
+
v: match[3]
|
|
1289
|
+
};
|
|
1290
|
+
}
|
|
1291
|
+
if (match = matchers.hsva.exec(color)) {
|
|
1292
|
+
return {
|
|
1293
|
+
h: match[1],
|
|
1294
|
+
s: match[2],
|
|
1295
|
+
v: match[3],
|
|
1296
|
+
a: match[4]
|
|
1297
|
+
};
|
|
1298
|
+
}
|
|
1299
|
+
if (match = matchers.hex8.exec(color)) {
|
|
1300
|
+
return {
|
|
1301
|
+
r: parseIntFromHex(match[1]),
|
|
1302
|
+
g: parseIntFromHex(match[2]),
|
|
1303
|
+
b: parseIntFromHex(match[3]),
|
|
1304
|
+
a: convertHexToDecimal(match[4]),
|
|
1305
|
+
format: named ? "name" : "hex8"
|
|
1306
|
+
};
|
|
1307
|
+
}
|
|
1308
|
+
if (match = matchers.hex6.exec(color)) {
|
|
1309
|
+
return {
|
|
1310
|
+
r: parseIntFromHex(match[1]),
|
|
1311
|
+
g: parseIntFromHex(match[2]),
|
|
1312
|
+
b: parseIntFromHex(match[3]),
|
|
1313
|
+
format: named ? "name" : "hex"
|
|
1314
|
+
};
|
|
1315
|
+
}
|
|
1316
|
+
if (match = matchers.hex4.exec(color)) {
|
|
1317
|
+
return {
|
|
1318
|
+
r: parseIntFromHex(match[1] + "" + match[1]),
|
|
1319
|
+
g: parseIntFromHex(match[2] + "" + match[2]),
|
|
1320
|
+
b: parseIntFromHex(match[3] + "" + match[3]),
|
|
1321
|
+
a: convertHexToDecimal(match[4] + "" + match[4]),
|
|
1322
|
+
format: named ? "name" : "hex8"
|
|
1323
|
+
};
|
|
1324
|
+
}
|
|
1325
|
+
if (match = matchers.hex3.exec(color)) {
|
|
1326
|
+
return {
|
|
1327
|
+
r: parseIntFromHex(match[1] + "" + match[1]),
|
|
1328
|
+
g: parseIntFromHex(match[2] + "" + match[2]),
|
|
1329
|
+
b: parseIntFromHex(match[3] + "" + match[3]),
|
|
1330
|
+
format: named ? "name" : "hex"
|
|
1331
|
+
};
|
|
1332
|
+
}
|
|
1333
|
+
return false;
|
|
1334
|
+
}
|
|
1335
|
+
function validateWCAG2Parms(parms) {
|
|
1336
|
+
var level, size;
|
|
1337
|
+
parms = parms || {
|
|
1338
|
+
level: "AA",
|
|
1339
|
+
size: "small"
|
|
1340
|
+
};
|
|
1341
|
+
level = (parms.level || "AA").toUpperCase();
|
|
1342
|
+
size = (parms.size || "small").toLowerCase();
|
|
1343
|
+
if (level !== "AA" && level !== "AAA") {
|
|
1344
|
+
level = "AA";
|
|
1345
|
+
}
|
|
1346
|
+
if (size !== "small" && size !== "large") {
|
|
1347
|
+
size = "small";
|
|
1348
|
+
}
|
|
1349
|
+
return {
|
|
1350
|
+
level,
|
|
1351
|
+
size
|
|
1352
|
+
};
|
|
1353
|
+
}
|
|
531
1354
|
|
|
532
1355
|
// src/colors.ts
|
|
533
|
-
|
|
1356
|
+
import { clamp } from "@excalidraw/math";
|
|
1357
|
+
import { degreesToRadians } from "@excalidraw/math";
|
|
1358
|
+
var DARK_MODE_COLORS_CACHE = typeof window !== "undefined" ? /* @__PURE__ */ new Map() : null;
|
|
1359
|
+
function cssHueRotate(red, green, blue, degrees) {
|
|
1360
|
+
const r = red / 255;
|
|
1361
|
+
const g = green / 255;
|
|
1362
|
+
const b = blue / 255;
|
|
1363
|
+
const a = degreesToRadians(degrees);
|
|
1364
|
+
const c = Math.cos(a);
|
|
1365
|
+
const s = Math.sin(a);
|
|
1366
|
+
const matrix = [
|
|
1367
|
+
0.213 + c * 0.787 - s * 0.213,
|
|
1368
|
+
0.715 - c * 0.715 - s * 0.715,
|
|
1369
|
+
0.072 - c * 0.072 + s * 0.928,
|
|
1370
|
+
0.213 - c * 0.213 + s * 0.143,
|
|
1371
|
+
0.715 + c * 0.285 + s * 0.14,
|
|
1372
|
+
0.072 - c * 0.072 - s * 0.283,
|
|
1373
|
+
0.213 - c * 0.213 - s * 0.787,
|
|
1374
|
+
0.715 - c * 0.715 + s * 0.715,
|
|
1375
|
+
0.072 + c * 0.928 + s * 0.072
|
|
1376
|
+
];
|
|
1377
|
+
const newR = r * matrix[0] + g * matrix[1] + b * matrix[2];
|
|
1378
|
+
const newG = r * matrix[3] + g * matrix[4] + b * matrix[5];
|
|
1379
|
+
const newB = r * matrix[6] + g * matrix[7] + b * matrix[8];
|
|
1380
|
+
return {
|
|
1381
|
+
r: Math.round(Math.max(0, Math.min(1, newR)) * 255),
|
|
1382
|
+
g: Math.round(Math.max(0, Math.min(1, newG)) * 255),
|
|
1383
|
+
b: Math.round(Math.max(0, Math.min(1, newB)) * 255)
|
|
1384
|
+
};
|
|
1385
|
+
}
|
|
1386
|
+
var cssInvert = (r, g, b, percent) => {
|
|
1387
|
+
const p = clamp(percent, 0, 100) / 100;
|
|
1388
|
+
const invertComponent = (color) => {
|
|
1389
|
+
const inverted = color * (1 - p) + (255 - color) * p;
|
|
1390
|
+
return Math.round(clamp(inverted, 0, 255));
|
|
1391
|
+
};
|
|
1392
|
+
const invertedR = invertComponent(r);
|
|
1393
|
+
const invertedG = invertComponent(g);
|
|
1394
|
+
const invertedB = invertComponent(b);
|
|
1395
|
+
return { r: invertedR, g: invertedG, b: invertedB };
|
|
1396
|
+
};
|
|
1397
|
+
var applyDarkModeFilter = (color) => {
|
|
1398
|
+
const cached = DARK_MODE_COLORS_CACHE?.get(color);
|
|
1399
|
+
if (cached) {
|
|
1400
|
+
return cached;
|
|
1401
|
+
}
|
|
1402
|
+
const tc = tinycolor(color);
|
|
1403
|
+
const alpha = tc.getAlpha();
|
|
1404
|
+
const rgb = tc.toRgb();
|
|
1405
|
+
const inverted = cssInvert(rgb.r, rgb.g, rgb.b, 93);
|
|
1406
|
+
const rotated = cssHueRotate(
|
|
1407
|
+
inverted.r,
|
|
1408
|
+
inverted.g,
|
|
1409
|
+
inverted.b,
|
|
1410
|
+
180
|
|
1411
|
+
);
|
|
1412
|
+
const result = rgbToHex2(rotated.r, rotated.g, rotated.b, alpha);
|
|
1413
|
+
if (DARK_MODE_COLORS_CACHE) {
|
|
1414
|
+
DARK_MODE_COLORS_CACHE.set(color, result);
|
|
1415
|
+
}
|
|
1416
|
+
return result;
|
|
1417
|
+
};
|
|
534
1418
|
var pick = (source, keys) => {
|
|
535
1419
|
return keys.reduce((acc, key) => {
|
|
536
1420
|
if (key in source) {
|
|
@@ -544,28 +1428,24 @@ var COLORS_PER_ROW = 5;
|
|
|
544
1428
|
var DEFAULT_CHART_COLOR_INDEX = 4;
|
|
545
1429
|
var DEFAULT_ELEMENT_STROKE_COLOR_INDEX = 4;
|
|
546
1430
|
var DEFAULT_ELEMENT_BACKGROUND_COLOR_INDEX = 1;
|
|
547
|
-
var ELEMENTS_PALETTE_SHADE_INDEXES = [0, 2, 4, 6, 8];
|
|
548
|
-
var CANVAS_PALETTE_SHADE_INDEXES = [0, 1, 2, 3, 4];
|
|
549
|
-
var getSpecificColorShades = (color, indexArr) => {
|
|
550
|
-
return indexArr.map((index) => open_color_default[color][index]);
|
|
551
|
-
};
|
|
552
1431
|
var COLOR_PALETTE = {
|
|
553
1432
|
transparent: "transparent",
|
|
554
1433
|
black: "#1e1e1e",
|
|
555
1434
|
white: "#ffffff",
|
|
556
|
-
// open-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
1435
|
+
// open-color from https://github.com/yeun/open-color/blob/master/open-color.js
|
|
1436
|
+
// corresponds to indexes [0,2,4,6,8] (weights: 50, 200, 400, 600, 800)
|
|
1437
|
+
gray: ["#f8f9fa", "#e9ecef", "#ced4da", "#868e96", "#343a40"],
|
|
1438
|
+
red: ["#fff5f5", "#ffc9c9", "#ff8787", "#fa5252", "#e03131"],
|
|
1439
|
+
pink: ["#fff0f6", "#fcc2d7", "#f783ac", "#e64980", "#c2255c"],
|
|
1440
|
+
grape: ["#f8f0fc", "#eebefa", "#da77f2", "#be4bdb", "#9c36b5"],
|
|
1441
|
+
violet: ["#f3f0ff", "#d0bfff", "#9775fa", "#7950f2", "#6741d9"],
|
|
1442
|
+
blue: ["#e7f5ff", "#a5d8ff", "#4dabf7", "#228be6", "#1971c2"],
|
|
1443
|
+
cyan: ["#e3fafc", "#99e9f2", "#3bc9db", "#15aabf", "#0c8599"],
|
|
1444
|
+
teal: ["#e6fcf5", "#96f2d7", "#38d9a9", "#12b886", "#099268"],
|
|
1445
|
+
green: ["#ebfbee", "#b2f2bb", "#69db7c", "#40c057", "#2f9e44"],
|
|
1446
|
+
yellow: ["#fff9db", "#ffec99", "#ffd43b", "#fab005", "#f08c00"],
|
|
1447
|
+
orange: ["#fff4e6", "#ffd8a8", "#ffa94d", "#fd7e14", "#e8590c"],
|
|
1448
|
+
// radix bronze shades [3,5,7,9,11]
|
|
569
1449
|
bronze: ["#f8f1ee", "#eaddd7", "#d2bab0", "#a18072", "#846358"]
|
|
570
1450
|
};
|
|
571
1451
|
var COMMON_ELEMENT_SHADES = pick(COLOR_PALETTE, [
|
|
@@ -637,22 +1517,61 @@ var getAllColorsSpecificShade = (index) => [
|
|
|
637
1517
|
COLOR_PALETTE.orange[index],
|
|
638
1518
|
COLOR_PALETTE.red[index]
|
|
639
1519
|
];
|
|
640
|
-
var
|
|
1520
|
+
var rgbToHex2 = (r, g, b, a) => {
|
|
1521
|
+
const hex6 = `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1)}`;
|
|
1522
|
+
if (a !== void 0 && a < 1) {
|
|
1523
|
+
const alphaHex = Math.round(a * 255).toString(16).padStart(2, "0");
|
|
1524
|
+
return `${hex6}${alphaHex}`;
|
|
1525
|
+
}
|
|
1526
|
+
return hex6;
|
|
1527
|
+
};
|
|
1528
|
+
var colorToHex = (color) => {
|
|
1529
|
+
const tc = tinycolor(color);
|
|
1530
|
+
if (!tc.isValid()) {
|
|
1531
|
+
return null;
|
|
1532
|
+
}
|
|
1533
|
+
const { r, g, b, a } = tc.toRgb();
|
|
1534
|
+
return rgbToHex2(r, g, b, a);
|
|
1535
|
+
};
|
|
1536
|
+
var isTransparent = (color) => {
|
|
1537
|
+
return tinycolor(color).getAlpha() === 0;
|
|
1538
|
+
};
|
|
1539
|
+
var COLOR_OUTLINE_CONTRAST_THRESHOLD = 240;
|
|
1540
|
+
var calculateContrast = (r, g, b) => {
|
|
1541
|
+
const yiq = (r * 299 + g * 587 + b * 114) / 1e3;
|
|
1542
|
+
return yiq;
|
|
1543
|
+
};
|
|
1544
|
+
var isColorDark = (color, threshold = 160) => {
|
|
1545
|
+
if (!color) {
|
|
1546
|
+
return true;
|
|
1547
|
+
}
|
|
1548
|
+
if (isTransparent(color)) {
|
|
1549
|
+
return false;
|
|
1550
|
+
}
|
|
1551
|
+
const tc = tinycolor(color);
|
|
1552
|
+
if (!tc.isValid()) {
|
|
1553
|
+
return true;
|
|
1554
|
+
}
|
|
1555
|
+
const { r, g, b } = tc.toRgb();
|
|
1556
|
+
return calculateContrast(r, g, b) < threshold;
|
|
1557
|
+
};
|
|
1558
|
+
var normalizeInputColor = (color) => {
|
|
1559
|
+
color = color.trim();
|
|
1560
|
+
if (isTransparent(color)) {
|
|
1561
|
+
return color;
|
|
1562
|
+
}
|
|
1563
|
+
const tc = tinycolor(color);
|
|
1564
|
+
if (tc.isValid()) {
|
|
1565
|
+
if (["hex", "hex8"].includes(tc.getFormat()) && !color.startsWith("#")) {
|
|
1566
|
+
return `#${color}`;
|
|
1567
|
+
}
|
|
1568
|
+
return color;
|
|
1569
|
+
}
|
|
1570
|
+
return null;
|
|
1571
|
+
};
|
|
641
1572
|
|
|
642
1573
|
// src/constants.ts
|
|
643
1574
|
init_define_import_meta_env();
|
|
644
|
-
var isDarwin = /Mac|iPod|iPhone|iPad/.test(navigator.platform);
|
|
645
|
-
var isWindows = /^Win/.test(navigator.platform);
|
|
646
|
-
var isAndroid = /\b(android)\b/i.test(navigator.userAgent);
|
|
647
|
-
var isFirefox = typeof window !== "undefined" && "netscape" in window && navigator.userAgent.indexOf("rv:") > 1 && navigator.userAgent.indexOf("Gecko") > 1;
|
|
648
|
-
var isChrome = navigator.userAgent.indexOf("Chrome") !== -1;
|
|
649
|
-
var isSafari = !isChrome && navigator.userAgent.indexOf("Safari") !== -1;
|
|
650
|
-
var isIOS = /iPad|iPhone/i.test(navigator.platform) || // iPadOS 13+
|
|
651
|
-
navigator.userAgent.includes("Mac") && "ontouchend" in document;
|
|
652
|
-
var isBrave = () => navigator.brave?.isBrave?.name === "isBrave";
|
|
653
|
-
var isMobile = isIOS || /android|webos|ipod|blackberry|iemobile|opera mini/i.test(
|
|
654
|
-
navigator.userAgent
|
|
655
|
-
) || /android|ios|ipod|blackberry|windows phone/i.test(navigator.platform);
|
|
656
1575
|
var supportsResizeObserver = typeof window !== "undefined" && "ResizeObserver" in window;
|
|
657
1576
|
var APP_NAME = "Excalidraw";
|
|
658
1577
|
var TEXT_AUTOWRAP_THRESHOLD = 36;
|
|
@@ -734,11 +1653,20 @@ var ENV = {
|
|
|
734
1653
|
PRODUCTION: "production"
|
|
735
1654
|
};
|
|
736
1655
|
var CLASSES = {
|
|
1656
|
+
SIDEBAR: "sidebar",
|
|
737
1657
|
SHAPE_ACTIONS_MENU: "App-menu__left",
|
|
738
1658
|
ZOOM_ACTIONS: "zoom-actions",
|
|
739
1659
|
SEARCH_MENU_INPUT_WRAPPER: "layer-ui__search-inputWrapper",
|
|
740
1660
|
CONVERT_ELEMENT_TYPE_POPUP: "ConvertElementTypePopup",
|
|
741
|
-
SHAPE_ACTIONS_THEME_SCOPE: "shape-actions-theme-scope"
|
|
1661
|
+
SHAPE_ACTIONS_THEME_SCOPE: "shape-actions-theme-scope",
|
|
1662
|
+
FRAME_NAME: "frame-name",
|
|
1663
|
+
DROPDOWN_MENU_EVENT_WRAPPER: "dropdown-menu-event-wrapper"
|
|
1664
|
+
};
|
|
1665
|
+
var FONT_SIZES = {
|
|
1666
|
+
sm: 16,
|
|
1667
|
+
md: 20,
|
|
1668
|
+
lg: 28,
|
|
1669
|
+
xl: 36
|
|
742
1670
|
};
|
|
743
1671
|
var CJK_HAND_DRAWN_FALLBACK_FONT = "Xiaolai";
|
|
744
1672
|
var WINDOWS_EMOJI_FALLBACK_FONT = "Segoe UI Emoji";
|
|
@@ -791,6 +1719,7 @@ var THEME = {
|
|
|
791
1719
|
LIGHT: "light",
|
|
792
1720
|
DARK: "dark"
|
|
793
1721
|
};
|
|
1722
|
+
var DARK_THEME_FILTER = "invert(93%) hue-rotate(180deg)";
|
|
794
1723
|
var FRAME_STYLE = {
|
|
795
1724
|
strokeColor: "#bbb",
|
|
796
1725
|
strokeWidth: 2,
|
|
@@ -839,7 +1768,11 @@ var STRING_MIME_TYPES = {
|
|
|
839
1768
|
json: "application/json",
|
|
840
1769
|
// excalidraw data
|
|
841
1770
|
excalidraw: "application/vnd.excalidraw+json",
|
|
842
|
-
|
|
1771
|
+
excalidrawClipboard: "application/vnd.excalidraw.clipboard+json",
|
|
1772
|
+
// LEGACY: fully-qualified library JSON data
|
|
1773
|
+
excalidrawlib: "application/vnd.excalidrawlib+json",
|
|
1774
|
+
// list of excalidraw library item ids
|
|
1775
|
+
excalidrawlibIds: "application/vnd.excalidrawlib.ids+json"
|
|
843
1776
|
};
|
|
844
1777
|
var MIME_TYPES = {
|
|
845
1778
|
...STRING_MIME_TYPES,
|
|
@@ -880,7 +1813,6 @@ var MAX_ZOOM = 30;
|
|
|
880
1813
|
var HYPERLINK_TOOLTIP_DELAY = 300;
|
|
881
1814
|
var IDLE_THRESHOLD = 6e4;
|
|
882
1815
|
var ACTIVE_THRESHOLD = 3e3;
|
|
883
|
-
var THEME_FILTER = "invert(93%) hue-rotate(180deg)";
|
|
884
1816
|
var URL_QUERY_KEYS = {
|
|
885
1817
|
addLibrary: "addLibrary"
|
|
886
1818
|
};
|
|
@@ -901,13 +1833,6 @@ var DEFAULT_UI_OPTIONS = {
|
|
|
901
1833
|
image: true
|
|
902
1834
|
}
|
|
903
1835
|
};
|
|
904
|
-
var MQ_MAX_WIDTH_LANDSCAPE = 1e3;
|
|
905
|
-
var MQ_MAX_HEIGHT_LANDSCAPE = 500;
|
|
906
|
-
var MQ_MAX_WIDTH_MOBILE = 699;
|
|
907
|
-
var MQ_MIN_TABLET = 600;
|
|
908
|
-
var MQ_MAX_TABLET = 1400;
|
|
909
|
-
var MQ_MIN_WIDTH_DESKTOP = 1440;
|
|
910
|
-
var MQ_RIGHT_SIDEBAR_MIN_WIDTH = 1229;
|
|
911
1836
|
var MAX_DECIMALS_FOR_SVG_EXPORT = 2;
|
|
912
1837
|
var EXPORT_SCALES = [1, 2, 3];
|
|
913
1838
|
var DEFAULT_EXPORT_PADDING = 10;
|
|
@@ -1028,6 +1953,10 @@ var UserIdleState = /* @__PURE__ */ ((UserIdleState2) => {
|
|
|
1028
1953
|
})(UserIdleState || {});
|
|
1029
1954
|
var LINE_POLYGON_POINT_MERGE_DISTANCE = 20;
|
|
1030
1955
|
var DOUBLE_TAP_POSITION_THRESHOLD = 35;
|
|
1956
|
+
var BIND_MODE_TIMEOUT = 700;
|
|
1957
|
+
var MOBILE_ACTION_BUTTON_BG = {
|
|
1958
|
+
background: "var(--mobile-action-button-bg)"
|
|
1959
|
+
};
|
|
1031
1960
|
|
|
1032
1961
|
// src/font-metadata.ts
|
|
1033
1962
|
init_define_import_meta_env();
|
|
@@ -1183,6 +2112,133 @@ var Queue = class {
|
|
|
1183
2112
|
|
|
1184
2113
|
// src/keys.ts
|
|
1185
2114
|
init_define_import_meta_env();
|
|
2115
|
+
|
|
2116
|
+
// src/editorInterface.ts
|
|
2117
|
+
init_define_import_meta_env();
|
|
2118
|
+
var DESKTOP_UI_MODE_STORAGE_KEY = "excalidraw.desktopUIMode";
|
|
2119
|
+
var MQ_MAX_MOBILE = 599;
|
|
2120
|
+
var MQ_MAX_WIDTH_LANDSCAPE = 1e3;
|
|
2121
|
+
var MQ_MAX_HEIGHT_LANDSCAPE = 500;
|
|
2122
|
+
var MQ_MIN_TABLET = MQ_MAX_MOBILE + 1;
|
|
2123
|
+
var MQ_MAX_TABLET = 1180;
|
|
2124
|
+
var MQ_MIN_WIDTH_DESKTOP = 1440;
|
|
2125
|
+
var MQ_RIGHT_SIDEBAR_MIN_WIDTH = 1229;
|
|
2126
|
+
var isDarwin = /Mac|iPod|iPhone|iPad/.test(navigator.platform);
|
|
2127
|
+
var isWindows = /^Win/.test(navigator.platform);
|
|
2128
|
+
var isAndroid = /\b(android)\b/i.test(navigator.userAgent);
|
|
2129
|
+
var isFirefox = typeof window !== "undefined" && "netscape" in window && navigator.userAgent.indexOf("rv:") > 1 && navigator.userAgent.indexOf("Gecko") > 1;
|
|
2130
|
+
var isChrome = navigator.userAgent.indexOf("Chrome") !== -1;
|
|
2131
|
+
var isSafari = !isChrome && navigator.userAgent.indexOf("Safari") !== -1;
|
|
2132
|
+
var isIOS = /iPad|iPhone/i.test(navigator.platform) || // iPadOS 13+
|
|
2133
|
+
navigator.userAgent.includes("Mac") && "ontouchend" in document;
|
|
2134
|
+
var isBrave = () => navigator.brave?.isBrave?.name === "isBrave";
|
|
2135
|
+
var isMobileBreakpoint = (width, height) => {
|
|
2136
|
+
return width <= MQ_MAX_MOBILE || height < MQ_MAX_HEIGHT_LANDSCAPE && width < MQ_MAX_WIDTH_LANDSCAPE;
|
|
2137
|
+
};
|
|
2138
|
+
var isTabletBreakpoint = (editorWidth, editorHeight) => {
|
|
2139
|
+
const minSide = Math.min(editorWidth, editorHeight);
|
|
2140
|
+
const maxSide = Math.max(editorWidth, editorHeight);
|
|
2141
|
+
return minSide >= MQ_MIN_TABLET && maxSide <= MQ_MAX_TABLET;
|
|
2142
|
+
};
|
|
2143
|
+
var isMobileOrTablet = () => {
|
|
2144
|
+
const ua = navigator.userAgent || "";
|
|
2145
|
+
const platform = navigator.platform || "";
|
|
2146
|
+
const uaData = navigator.userAgentData;
|
|
2147
|
+
if (uaData) {
|
|
2148
|
+
const plat = (uaData.platform || "").toLowerCase();
|
|
2149
|
+
const isDesktopOS = plat === "windows" || plat === "macos" || plat === "linux" || plat === "chrome os";
|
|
2150
|
+
if (uaData.mobile === true) {
|
|
2151
|
+
return true;
|
|
2152
|
+
}
|
|
2153
|
+
if (uaData.mobile === false && plat === "android") {
|
|
2154
|
+
const looksTouchTablet = matchMedia?.("(hover: none)").matches && matchMedia?.("(pointer: coarse)").matches;
|
|
2155
|
+
return looksTouchTablet;
|
|
2156
|
+
}
|
|
2157
|
+
if (isDesktopOS) {
|
|
2158
|
+
return false;
|
|
2159
|
+
}
|
|
2160
|
+
}
|
|
2161
|
+
if (isIOS) {
|
|
2162
|
+
return true;
|
|
2163
|
+
}
|
|
2164
|
+
if (isAndroid) {
|
|
2165
|
+
const isAndroidPhone = /Mobile/i.test(ua);
|
|
2166
|
+
const isAndroidTablet = !isAndroidPhone;
|
|
2167
|
+
if (isAndroidPhone || isAndroidTablet) {
|
|
2168
|
+
const looksTouchTablet = matchMedia?.("(hover: none)").matches && matchMedia?.("(pointer: coarse)").matches;
|
|
2169
|
+
return looksTouchTablet;
|
|
2170
|
+
}
|
|
2171
|
+
}
|
|
2172
|
+
const looksDesktopPlatform = /Win|Linux|CrOS|Mac/.test(platform) || /Windows NT|X11|CrOS|Macintosh/.test(ua);
|
|
2173
|
+
if (looksDesktopPlatform) {
|
|
2174
|
+
return false;
|
|
2175
|
+
}
|
|
2176
|
+
return false;
|
|
2177
|
+
};
|
|
2178
|
+
var getFormFactor = (editorWidth, editorHeight) => {
|
|
2179
|
+
if (isMobileBreakpoint(editorWidth, editorHeight)) {
|
|
2180
|
+
return "phone";
|
|
2181
|
+
}
|
|
2182
|
+
if (isTabletBreakpoint(editorWidth, editorHeight)) {
|
|
2183
|
+
return "tablet";
|
|
2184
|
+
}
|
|
2185
|
+
return "desktop";
|
|
2186
|
+
};
|
|
2187
|
+
var deriveStylesPanelMode = (editorInterface) => {
|
|
2188
|
+
if (editorInterface.formFactor === "phone") {
|
|
2189
|
+
return "mobile";
|
|
2190
|
+
}
|
|
2191
|
+
if (editorInterface.formFactor === "tablet") {
|
|
2192
|
+
return "compact";
|
|
2193
|
+
}
|
|
2194
|
+
return editorInterface.desktopUIMode;
|
|
2195
|
+
};
|
|
2196
|
+
var createUserAgentDescriptor = (userAgentString) => {
|
|
2197
|
+
const normalizedUA = userAgentString ?? "";
|
|
2198
|
+
let platform = "unknown";
|
|
2199
|
+
if (isIOS) {
|
|
2200
|
+
platform = "ios";
|
|
2201
|
+
} else if (isAndroid) {
|
|
2202
|
+
platform = "android";
|
|
2203
|
+
} else if (normalizedUA) {
|
|
2204
|
+
platform = "other";
|
|
2205
|
+
}
|
|
2206
|
+
return {
|
|
2207
|
+
isMobileDevice: isMobileOrTablet(),
|
|
2208
|
+
platform
|
|
2209
|
+
};
|
|
2210
|
+
};
|
|
2211
|
+
var loadDesktopUIModePreference = () => {
|
|
2212
|
+
if (typeof window === "undefined") {
|
|
2213
|
+
return null;
|
|
2214
|
+
}
|
|
2215
|
+
try {
|
|
2216
|
+
const stored = window.localStorage.getItem(DESKTOP_UI_MODE_STORAGE_KEY);
|
|
2217
|
+
if (stored === "compact" || stored === "full") {
|
|
2218
|
+
return stored;
|
|
2219
|
+
}
|
|
2220
|
+
} catch (error) {
|
|
2221
|
+
}
|
|
2222
|
+
return null;
|
|
2223
|
+
};
|
|
2224
|
+
var persistDesktopUIMode = (mode) => {
|
|
2225
|
+
if (typeof window === "undefined") {
|
|
2226
|
+
return;
|
|
2227
|
+
}
|
|
2228
|
+
try {
|
|
2229
|
+
window.localStorage.setItem(DESKTOP_UI_MODE_STORAGE_KEY, mode);
|
|
2230
|
+
} catch (error) {
|
|
2231
|
+
}
|
|
2232
|
+
};
|
|
2233
|
+
var setDesktopUIMode = (mode) => {
|
|
2234
|
+
if (mode !== "compact" && mode !== "full") {
|
|
2235
|
+
return;
|
|
2236
|
+
}
|
|
2237
|
+
persistDesktopUIMode(mode);
|
|
2238
|
+
return mode;
|
|
2239
|
+
};
|
|
2240
|
+
|
|
2241
|
+
// src/keys.ts
|
|
1186
2242
|
var CODES = {
|
|
1187
2243
|
EQUAL: "Equal",
|
|
1188
2244
|
MINUS: "Minus",
|
|
@@ -1428,7 +2484,7 @@ var isInteractive = (target) => {
|
|
|
1428
2484
|
return isInputLike(target) || target instanceof Element && !!target.closest("label, button");
|
|
1429
2485
|
};
|
|
1430
2486
|
var isWritableElement = (target) => target instanceof HTMLElement && target.dataset.type === "wysiwyg" || target instanceof HTMLBRElement || // newline in wysiwyg
|
|
1431
|
-
target instanceof HTMLTextAreaElement || target instanceof HTMLInputElement && (target.type === "text" || target.type === "number" || target.type === "password");
|
|
2487
|
+
target instanceof HTMLTextAreaElement || target instanceof HTMLInputElement && (target.type === "text" || target.type === "number" || target.type === "password" || target.type === "search") || target instanceof HTMLElement && target.closest(".cm-editor") !== null;
|
|
1432
2488
|
var getFontFamilyString = ({
|
|
1433
2489
|
fontFamily
|
|
1434
2490
|
}) => {
|
|
@@ -1445,6 +2501,9 @@ var getFontString = ({
|
|
|
1445
2501
|
}) => {
|
|
1446
2502
|
return `${fontSize}px ${getFontFamilyString({ fontFamily })}`;
|
|
1447
2503
|
};
|
|
2504
|
+
var nextAnimationFrame = async (cb) => {
|
|
2505
|
+
requestAnimationFrame(() => requestAnimationFrame(cb));
|
|
2506
|
+
};
|
|
1448
2507
|
var debounce = (fn, timeout) => {
|
|
1449
2508
|
let handle = 0;
|
|
1450
2509
|
let lastArgs = null;
|
|
@@ -1470,32 +2529,23 @@ var debounce = (fn, timeout) => {
|
|
|
1470
2529
|
};
|
|
1471
2530
|
return ret;
|
|
1472
2531
|
};
|
|
1473
|
-
var throttleRAF = (fn
|
|
2532
|
+
var throttleRAF = (fn) => {
|
|
1474
2533
|
let timerId = null;
|
|
1475
2534
|
let lastArgs = null;
|
|
1476
|
-
|
|
1477
|
-
const scheduleFunc = (args) => {
|
|
2535
|
+
const scheduleFunc = () => {
|
|
1478
2536
|
timerId = window.requestAnimationFrame(() => {
|
|
1479
2537
|
timerId = null;
|
|
1480
|
-
|
|
2538
|
+
const args = lastArgs;
|
|
1481
2539
|
lastArgs = null;
|
|
1482
|
-
if (
|
|
1483
|
-
|
|
1484
|
-
lastArgsTrailing = null;
|
|
1485
|
-
scheduleFunc(lastArgs);
|
|
2540
|
+
if (args) {
|
|
2541
|
+
fn(...args);
|
|
1486
2542
|
}
|
|
1487
2543
|
});
|
|
1488
2544
|
};
|
|
1489
2545
|
const ret = (...args) => {
|
|
1490
|
-
if (isTestEnv()) {
|
|
1491
|
-
fn(...args);
|
|
1492
|
-
return;
|
|
1493
|
-
}
|
|
1494
2546
|
lastArgs = args;
|
|
1495
2547
|
if (timerId === null) {
|
|
1496
|
-
scheduleFunc(
|
|
1497
|
-
} else if (opts?.trailing) {
|
|
1498
|
-
lastArgsTrailing = args;
|
|
2548
|
+
scheduleFunc();
|
|
1499
2549
|
}
|
|
1500
2550
|
};
|
|
1501
2551
|
ret.flush = () => {
|
|
@@ -1504,12 +2554,12 @@ var throttleRAF = (fn, opts) => {
|
|
|
1504
2554
|
timerId = null;
|
|
1505
2555
|
}
|
|
1506
2556
|
if (lastArgs) {
|
|
1507
|
-
fn(...
|
|
1508
|
-
lastArgs =
|
|
2557
|
+
fn(...lastArgs);
|
|
2558
|
+
lastArgs = null;
|
|
1509
2559
|
}
|
|
1510
2560
|
};
|
|
1511
2561
|
ret.cancel = () => {
|
|
1512
|
-
lastArgs =
|
|
2562
|
+
lastArgs = null;
|
|
1513
2563
|
if (timerId !== null) {
|
|
1514
2564
|
cancelAnimationFrame(timerId);
|
|
1515
2565
|
timerId = null;
|
|
@@ -1609,6 +2659,9 @@ var removeSelection = () => {
|
|
|
1609
2659
|
}
|
|
1610
2660
|
};
|
|
1611
2661
|
var distance = (x, y) => Math.abs(x - y);
|
|
2662
|
+
var isSelectionLikeTool = (type) => {
|
|
2663
|
+
return type === "selection" || type === "lasso";
|
|
2664
|
+
};
|
|
1612
2665
|
var updateActiveTool = (appState, data) => {
|
|
1613
2666
|
if (data.type === "custom") {
|
|
1614
2667
|
return {
|
|
@@ -1630,13 +2683,6 @@ var updateActiveTool = (appState, data) => {
|
|
|
1630
2683
|
var isFullScreen = () => document.fullscreenElement?.nodeName === "HTML";
|
|
1631
2684
|
var allowFullScreen = () => document.documentElement.requestFullscreen();
|
|
1632
2685
|
var exitFullScreen = () => document.exitFullscreen();
|
|
1633
|
-
var getShortcutKey = (shortcut) => {
|
|
1634
|
-
shortcut = shortcut.replace(/\bAlt\b/i, "Alt").replace(/\bShift\b/i, "Shift").replace(/\b(Enter|Return)\b/i, "Enter");
|
|
1635
|
-
if (isDarwin) {
|
|
1636
|
-
return shortcut.replace(/\bCtrlOrCmd\b/gi, "Cmd").replace(/\bAlt\b/i, "Option");
|
|
1637
|
-
}
|
|
1638
|
-
return shortcut.replace(/\bCtrlOrCmd\b/gi, "Ctrl");
|
|
1639
|
-
};
|
|
1640
2686
|
var viewportCoordsToSceneCoords = ({ clientX, clientY }, {
|
|
1641
2687
|
zoom,
|
|
1642
2688
|
offsetLeft,
|
|
@@ -1710,12 +2756,6 @@ var mapFind = (collection, iteratee) => {
|
|
|
1710
2756
|
}
|
|
1711
2757
|
return void 0;
|
|
1712
2758
|
};
|
|
1713
|
-
var isTransparent = (color) => {
|
|
1714
|
-
const isRGBTransparent = color.length === 5 && color.substr(4, 1) === "0";
|
|
1715
|
-
const isRRGGBBTransparent = color.length === 9 && color.substr(7, 2) === "00";
|
|
1716
|
-
return isRGBTransparent || isRRGGBBTransparent || color === COLOR_PALETTE.transparent;
|
|
1717
|
-
};
|
|
1718
|
-
var isBindingFallthroughEnabled = (el) => el.fillStyle !== "solid" || isTransparent(el.backgroundColor);
|
|
1719
2759
|
var resolvablePromise = () => {
|
|
1720
2760
|
let resolve;
|
|
1721
2761
|
let reject;
|
|
@@ -2036,9 +3076,9 @@ function getSvgPathFromStroke(points, closed = true) {
|
|
|
2036
3076
|
var normalizeEOL = (str) => {
|
|
2037
3077
|
return str.replace(/\r?\n|\r/g, "\n");
|
|
2038
3078
|
};
|
|
2039
|
-
|
|
3079
|
+
function toBrandedType(value) {
|
|
2040
3080
|
return value;
|
|
2041
|
-
}
|
|
3081
|
+
}
|
|
2042
3082
|
var promiseTry = async (fn, ...args) => {
|
|
2043
3083
|
return new Promise((resolve) => {
|
|
2044
3084
|
resolve(fn(...args));
|
|
@@ -2078,40 +3118,40 @@ var reduceToCommonValue = (collection, getValue) => {
|
|
|
2078
3118
|
}
|
|
2079
3119
|
return commonValue;
|
|
2080
3120
|
};
|
|
2081
|
-
var
|
|
2082
|
-
|
|
2083
|
-
|
|
2084
|
-
|
|
2085
|
-
|
|
2086
|
-
|
|
2087
|
-
|
|
2088
|
-
|
|
2089
|
-
|
|
2090
|
-
|
|
2091
|
-
|
|
2092
|
-
|
|
2093
|
-
|
|
2094
|
-
}
|
|
2095
|
-
if (isDesktopOS) {
|
|
2096
|
-
return false;
|
|
2097
|
-
}
|
|
2098
|
-
}
|
|
2099
|
-
if (isIOS) {
|
|
2100
|
-
return true;
|
|
2101
|
-
}
|
|
2102
|
-
if (isAndroid) {
|
|
2103
|
-
const isAndroidPhone = /Mobile/i.test(ua);
|
|
2104
|
-
const isAndroidTablet = !isAndroidPhone;
|
|
2105
|
-
if (isAndroidPhone || isAndroidTablet) {
|
|
2106
|
-
const looksTouchTablet = matchMedia?.("(hover: none)").matches && matchMedia?.("(pointer: coarse)").matches;
|
|
2107
|
-
return looksTouchTablet;
|
|
3121
|
+
var FEATURE_FLAGS_STORAGE_KEY = "excalidraw-feature-flags";
|
|
3122
|
+
var DEFAULT_FEATURE_FLAGS = {
|
|
3123
|
+
COMPLEX_BINDINGS: false
|
|
3124
|
+
};
|
|
3125
|
+
var featureFlags = null;
|
|
3126
|
+
var getFeatureFlag = (flag) => {
|
|
3127
|
+
if (!featureFlags) {
|
|
3128
|
+
try {
|
|
3129
|
+
const serializedFlags = localStorage.getItem(FEATURE_FLAGS_STORAGE_KEY);
|
|
3130
|
+
if (serializedFlags) {
|
|
3131
|
+
const flags = JSON.parse(serializedFlags);
|
|
3132
|
+
featureFlags = flags ?? DEFAULT_FEATURE_FLAGS;
|
|
3133
|
+
}
|
|
3134
|
+
} catch {
|
|
2108
3135
|
}
|
|
2109
3136
|
}
|
|
2110
|
-
|
|
2111
|
-
|
|
2112
|
-
|
|
3137
|
+
return (featureFlags || DEFAULT_FEATURE_FLAGS)[flag];
|
|
3138
|
+
};
|
|
3139
|
+
var setFeatureFlag = (flag, value) => {
|
|
3140
|
+
try {
|
|
3141
|
+
featureFlags = {
|
|
3142
|
+
...featureFlags || DEFAULT_FEATURE_FLAGS,
|
|
3143
|
+
[flag]: value
|
|
3144
|
+
};
|
|
3145
|
+
localStorage.setItem(
|
|
3146
|
+
FEATURE_FLAGS_STORAGE_KEY,
|
|
3147
|
+
JSON.stringify(featureFlags)
|
|
3148
|
+
);
|
|
3149
|
+
} catch (e) {
|
|
3150
|
+
console.error("unable to set feature flag", e);
|
|
2113
3151
|
}
|
|
2114
|
-
|
|
3152
|
+
};
|
|
3153
|
+
var oneOf = (needle, haystack) => {
|
|
3154
|
+
return haystack.includes(needle);
|
|
2115
3155
|
};
|
|
2116
3156
|
|
|
2117
3157
|
// src/random.ts
|
|
@@ -2186,6 +3226,298 @@ var Emitter = class {
|
|
|
2186
3226
|
this.subscribers = [];
|
|
2187
3227
|
}
|
|
2188
3228
|
};
|
|
3229
|
+
|
|
3230
|
+
// src/appEventBus.ts
|
|
3231
|
+
init_define_import_meta_env();
|
|
3232
|
+
var AppEventBus = class {
|
|
3233
|
+
constructor(behavior) {
|
|
3234
|
+
this.behavior = behavior;
|
|
3235
|
+
}
|
|
3236
|
+
emitters = /* @__PURE__ */ new Map();
|
|
3237
|
+
lastPayload = /* @__PURE__ */ new Map();
|
|
3238
|
+
emittedOnce = /* @__PURE__ */ new Set();
|
|
3239
|
+
getEmitter(name) {
|
|
3240
|
+
let emitter = this.emitters.get(name);
|
|
3241
|
+
if (!emitter) {
|
|
3242
|
+
emitter = new Emitter();
|
|
3243
|
+
this.emitters.set(name, emitter);
|
|
3244
|
+
}
|
|
3245
|
+
return emitter;
|
|
3246
|
+
}
|
|
3247
|
+
toPromiseValue(args) {
|
|
3248
|
+
return args.length === 1 ? args[0] : args;
|
|
3249
|
+
}
|
|
3250
|
+
on(name, callback) {
|
|
3251
|
+
const eventBehavior = this.behavior[name];
|
|
3252
|
+
const cachedPayload = this.lastPayload.get(name);
|
|
3253
|
+
if (callback) {
|
|
3254
|
+
if (eventBehavior.replay === "last" && cachedPayload) {
|
|
3255
|
+
queueMicrotask(() => callback(...cachedPayload));
|
|
3256
|
+
if (eventBehavior.cardinality === "once") {
|
|
3257
|
+
return () => {
|
|
3258
|
+
};
|
|
3259
|
+
}
|
|
3260
|
+
}
|
|
3261
|
+
return this.getEmitter(name).on(callback);
|
|
3262
|
+
}
|
|
3263
|
+
if (eventBehavior.cardinality !== "once" || eventBehavior.replay !== "last") {
|
|
3264
|
+
throw new Error(`Event "${String(name)}" requires a callback`);
|
|
3265
|
+
}
|
|
3266
|
+
if (cachedPayload) {
|
|
3267
|
+
return Promise.resolve(this.toPromiseValue(cachedPayload));
|
|
3268
|
+
}
|
|
3269
|
+
return new Promise((resolve) => {
|
|
3270
|
+
this.getEmitter(name).once((...args) => {
|
|
3271
|
+
resolve(this.toPromiseValue(args));
|
|
3272
|
+
});
|
|
3273
|
+
});
|
|
3274
|
+
}
|
|
3275
|
+
emit(name, ...args) {
|
|
3276
|
+
const eventBehavior = this.behavior[name];
|
|
3277
|
+
if (!isProdEnv()) {
|
|
3278
|
+
if (eventBehavior.cardinality === "once") {
|
|
3279
|
+
if (this.emittedOnce.has(name)) {
|
|
3280
|
+
throw new Error(`Event "${String(name)}" can only be emitted once`);
|
|
3281
|
+
}
|
|
3282
|
+
this.emittedOnce.add(name);
|
|
3283
|
+
}
|
|
3284
|
+
}
|
|
3285
|
+
if (eventBehavior.replay === "last") {
|
|
3286
|
+
this.lastPayload.set(name, args);
|
|
3287
|
+
}
|
|
3288
|
+
try {
|
|
3289
|
+
this.getEmitter(name).trigger(...args);
|
|
3290
|
+
} finally {
|
|
3291
|
+
if (eventBehavior.cardinality === "once") {
|
|
3292
|
+
this.getEmitter(name).clear();
|
|
3293
|
+
}
|
|
3294
|
+
}
|
|
3295
|
+
}
|
|
3296
|
+
clear() {
|
|
3297
|
+
this.lastPayload.clear();
|
|
3298
|
+
this.emittedOnce.clear();
|
|
3299
|
+
for (const emitter of this.emitters.values()) {
|
|
3300
|
+
emitter.clear();
|
|
3301
|
+
}
|
|
3302
|
+
this.emitters.clear();
|
|
3303
|
+
}
|
|
3304
|
+
};
|
|
3305
|
+
|
|
3306
|
+
// src/versionedSnapshotStore.ts
|
|
3307
|
+
init_define_import_meta_env();
|
|
3308
|
+
var VersionedSnapshotStore = class {
|
|
3309
|
+
constructor(initialValue, isEqual = Object.is) {
|
|
3310
|
+
this.isEqual = isEqual;
|
|
3311
|
+
this.value = initialValue;
|
|
3312
|
+
}
|
|
3313
|
+
version = 0;
|
|
3314
|
+
value;
|
|
3315
|
+
waiters = /* @__PURE__ */ new Set();
|
|
3316
|
+
subscribers = /* @__PURE__ */ new Set();
|
|
3317
|
+
getSnapshot() {
|
|
3318
|
+
return { version: this.version, value: this.value };
|
|
3319
|
+
}
|
|
3320
|
+
set(nextValue) {
|
|
3321
|
+
if (this.isEqual(this.value, nextValue)) {
|
|
3322
|
+
return false;
|
|
3323
|
+
}
|
|
3324
|
+
this.value = nextValue;
|
|
3325
|
+
this.version += 1;
|
|
3326
|
+
const snapshot = this.getSnapshot();
|
|
3327
|
+
for (const subscriber of this.subscribers) {
|
|
3328
|
+
subscriber(snapshot);
|
|
3329
|
+
}
|
|
3330
|
+
for (const waiter of this.waiters) {
|
|
3331
|
+
waiter(snapshot);
|
|
3332
|
+
}
|
|
3333
|
+
this.waiters.clear();
|
|
3334
|
+
return true;
|
|
3335
|
+
}
|
|
3336
|
+
update(updater) {
|
|
3337
|
+
return this.set(updater(this.value));
|
|
3338
|
+
}
|
|
3339
|
+
subscribe(subscriber) {
|
|
3340
|
+
this.subscribers.add(subscriber);
|
|
3341
|
+
return () => {
|
|
3342
|
+
this.subscribers.delete(subscriber);
|
|
3343
|
+
};
|
|
3344
|
+
}
|
|
3345
|
+
pull(sinceVersion = -1) {
|
|
3346
|
+
if (this.version !== sinceVersion) {
|
|
3347
|
+
return Promise.resolve(this.getSnapshot());
|
|
3348
|
+
}
|
|
3349
|
+
return new Promise((resolve) => {
|
|
3350
|
+
this.waiters.add(resolve);
|
|
3351
|
+
});
|
|
3352
|
+
}
|
|
3353
|
+
};
|
|
3354
|
+
|
|
3355
|
+
// debug.ts
|
|
3356
|
+
init_define_import_meta_env();
|
|
3357
|
+
var lessPrecise = (num, precision = 5) => parseFloat(num.toPrecision(precision));
|
|
3358
|
+
var getAvgFrameTime = (times) => lessPrecise(times.reduce((a, b) => a + b) / times.length);
|
|
3359
|
+
var Debug = class _Debug {
|
|
3360
|
+
static DEBUG_LOG_TIMES = true;
|
|
3361
|
+
static TIMES_AGGR = {};
|
|
3362
|
+
static TIMES_AVG = {};
|
|
3363
|
+
static LAST_DEBUG_LOG_CALL = 0;
|
|
3364
|
+
static DEBUG_LOG_INTERVAL_ID = null;
|
|
3365
|
+
static LAST_FRAME_TIMESTAMP = 0;
|
|
3366
|
+
static FRAME_COUNT = 0;
|
|
3367
|
+
static ANIMATION_FRAME_ID = null;
|
|
3368
|
+
static scheduleAnimationFrame = () => {
|
|
3369
|
+
if (_Debug.DEBUG_LOG_INTERVAL_ID !== null) {
|
|
3370
|
+
_Debug.ANIMATION_FRAME_ID = requestAnimationFrame((timestamp) => {
|
|
3371
|
+
if (_Debug.LAST_FRAME_TIMESTAMP !== timestamp) {
|
|
3372
|
+
_Debug.LAST_FRAME_TIMESTAMP = timestamp;
|
|
3373
|
+
_Debug.FRAME_COUNT++;
|
|
3374
|
+
}
|
|
3375
|
+
if (_Debug.DEBUG_LOG_INTERVAL_ID !== null) {
|
|
3376
|
+
_Debug.scheduleAnimationFrame();
|
|
3377
|
+
}
|
|
3378
|
+
});
|
|
3379
|
+
}
|
|
3380
|
+
};
|
|
3381
|
+
static setupInterval = () => {
|
|
3382
|
+
if (_Debug.DEBUG_LOG_INTERVAL_ID === null) {
|
|
3383
|
+
console.info("%c(starting perf recording)", "color: lime");
|
|
3384
|
+
_Debug.DEBUG_LOG_INTERVAL_ID = window.setInterval(_Debug.debugLogger, 1e3);
|
|
3385
|
+
_Debug.scheduleAnimationFrame();
|
|
3386
|
+
}
|
|
3387
|
+
_Debug.LAST_DEBUG_LOG_CALL = Date.now();
|
|
3388
|
+
};
|
|
3389
|
+
static debugLogger = () => {
|
|
3390
|
+
if (_Debug.DEBUG_LOG_TIMES) {
|
|
3391
|
+
for (const [name, { t, times }] of Object.entries(_Debug.TIMES_AGGR)) {
|
|
3392
|
+
if (times.length) {
|
|
3393
|
+
console.info(
|
|
3394
|
+
name,
|
|
3395
|
+
lessPrecise(times.reduce((a, b) => a + b)),
|
|
3396
|
+
times.sort((a, b) => a - b).map((x) => lessPrecise(x))
|
|
3397
|
+
);
|
|
3398
|
+
_Debug.TIMES_AGGR[name] = { t, times: [] };
|
|
3399
|
+
}
|
|
3400
|
+
}
|
|
3401
|
+
for (const [name, { t, times, avg }] of Object.entries(_Debug.TIMES_AVG)) {
|
|
3402
|
+
if (times.length) {
|
|
3403
|
+
const totalTime = times.reduce((a, b) => a + b);
|
|
3404
|
+
const avgFrameTime = lessPrecise(totalTime / _Debug.FRAME_COUNT);
|
|
3405
|
+
console.info(
|
|
3406
|
+
name,
|
|
3407
|
+
`- ${times.length} calls - ${avgFrameTime}ms/frame across ${_Debug.FRAME_COUNT} frames (${lessPrecise(
|
|
3408
|
+
avgFrameTime / 16.67 * 100,
|
|
3409
|
+
1
|
|
3410
|
+
)}% of frame budget)`
|
|
3411
|
+
);
|
|
3412
|
+
_Debug.TIMES_AVG[name] = {
|
|
3413
|
+
t,
|
|
3414
|
+
times: [],
|
|
3415
|
+
avg: avg != null ? getAvgFrameTime([avg, avgFrameTime]) : avgFrameTime
|
|
3416
|
+
};
|
|
3417
|
+
}
|
|
3418
|
+
}
|
|
3419
|
+
}
|
|
3420
|
+
_Debug.FRAME_COUNT = 0;
|
|
3421
|
+
if (Date.now() - _Debug.LAST_DEBUG_LOG_CALL > 600 && _Debug.DEBUG_LOG_INTERVAL_ID !== null) {
|
|
3422
|
+
console.info("%c(stopping perf recording)", "color: red");
|
|
3423
|
+
window.clearInterval(_Debug.DEBUG_LOG_INTERVAL_ID);
|
|
3424
|
+
window.cancelAnimationFrame(_Debug.ANIMATION_FRAME_ID);
|
|
3425
|
+
_Debug.ANIMATION_FRAME_ID = null;
|
|
3426
|
+
_Debug.FRAME_COUNT = 0;
|
|
3427
|
+
_Debug.LAST_FRAME_TIMESTAMP = 0;
|
|
3428
|
+
_Debug.DEBUG_LOG_INTERVAL_ID = null;
|
|
3429
|
+
_Debug.TIMES_AGGR = {};
|
|
3430
|
+
_Debug.TIMES_AVG = {};
|
|
3431
|
+
}
|
|
3432
|
+
};
|
|
3433
|
+
static logTime = (time, name = "default") => {
|
|
3434
|
+
_Debug.setupInterval();
|
|
3435
|
+
const now = performance.now();
|
|
3436
|
+
const { t, times } = _Debug.TIMES_AGGR[name] = _Debug.TIMES_AGGR[name] || {
|
|
3437
|
+
t: 0,
|
|
3438
|
+
times: []
|
|
3439
|
+
};
|
|
3440
|
+
if (t) {
|
|
3441
|
+
times.push(time != null ? time : now - t);
|
|
3442
|
+
}
|
|
3443
|
+
_Debug.TIMES_AGGR[name].t = now;
|
|
3444
|
+
};
|
|
3445
|
+
static logTimeAverage = (time, name = "default") => {
|
|
3446
|
+
_Debug.setupInterval();
|
|
3447
|
+
const now = performance.now();
|
|
3448
|
+
const { t, times } = _Debug.TIMES_AVG[name] = _Debug.TIMES_AVG[name] || {
|
|
3449
|
+
t: 0,
|
|
3450
|
+
times: []
|
|
3451
|
+
};
|
|
3452
|
+
if (t) {
|
|
3453
|
+
times.push(time != null ? time : now - t);
|
|
3454
|
+
}
|
|
3455
|
+
_Debug.TIMES_AVG[name].t = now;
|
|
3456
|
+
};
|
|
3457
|
+
static logWrapper = (type) => (fn, name = "default") => {
|
|
3458
|
+
return (...args) => {
|
|
3459
|
+
const t0 = performance.now();
|
|
3460
|
+
const ret = fn(...args);
|
|
3461
|
+
_Debug[type](performance.now() - t0, name);
|
|
3462
|
+
return ret;
|
|
3463
|
+
};
|
|
3464
|
+
};
|
|
3465
|
+
static logTimeWrap = _Debug.logWrapper("logTime");
|
|
3466
|
+
static logTimeAverageWrap = _Debug.logWrapper("logTimeAverage");
|
|
3467
|
+
static perfWrap = (fn, name = "default") => {
|
|
3468
|
+
return (...args) => {
|
|
3469
|
+
console.time(name);
|
|
3470
|
+
const ret = fn(...args);
|
|
3471
|
+
console.timeEnd(name);
|
|
3472
|
+
return ret;
|
|
3473
|
+
};
|
|
3474
|
+
};
|
|
3475
|
+
static CHANGED_CACHE = {};
|
|
3476
|
+
static logChanged(name, obj) {
|
|
3477
|
+
const prev = _Debug.CHANGED_CACHE[name];
|
|
3478
|
+
_Debug.CHANGED_CACHE[name] = obj;
|
|
3479
|
+
if (!prev) {
|
|
3480
|
+
return;
|
|
3481
|
+
}
|
|
3482
|
+
const allKeys = /* @__PURE__ */ new Set([...Object.keys(prev), ...Object.keys(obj)]);
|
|
3483
|
+
const changed = {};
|
|
3484
|
+
for (const key of allKeys) {
|
|
3485
|
+
const prevVal = prev[key];
|
|
3486
|
+
const nextVal = obj[key];
|
|
3487
|
+
if (!deepEqual(prevVal, nextVal)) {
|
|
3488
|
+
changed[key] = { prev: prevVal, next: nextVal };
|
|
3489
|
+
}
|
|
3490
|
+
}
|
|
3491
|
+
if (Object.keys(changed).length > 0) {
|
|
3492
|
+
console.info(`[${name}] changed:`, changed);
|
|
3493
|
+
}
|
|
3494
|
+
}
|
|
3495
|
+
};
|
|
3496
|
+
function deepEqual(a, b) {
|
|
3497
|
+
if (Object.is(a, b)) {
|
|
3498
|
+
return true;
|
|
3499
|
+
}
|
|
3500
|
+
if (a === null || b === null || typeof a !== "object" || typeof b !== "object") {
|
|
3501
|
+
return false;
|
|
3502
|
+
}
|
|
3503
|
+
if (Array.isArray(a) !== Array.isArray(b)) {
|
|
3504
|
+
return false;
|
|
3505
|
+
}
|
|
3506
|
+
const keysA = Object.keys(a);
|
|
3507
|
+
const keysB = Object.keys(b);
|
|
3508
|
+
if (keysA.length !== keysB.length) {
|
|
3509
|
+
return false;
|
|
3510
|
+
}
|
|
3511
|
+
for (const key of keysA) {
|
|
3512
|
+
if (!deepEqual(
|
|
3513
|
+
a[key],
|
|
3514
|
+
b[key]
|
|
3515
|
+
)) {
|
|
3516
|
+
return false;
|
|
3517
|
+
}
|
|
3518
|
+
}
|
|
3519
|
+
return true;
|
|
3520
|
+
}
|
|
2189
3521
|
export {
|
|
2190
3522
|
ACTIVE_THRESHOLD,
|
|
2191
3523
|
ALLOWED_PASTE_MIME_TYPES,
|
|
@@ -2193,10 +3525,11 @@ export {
|
|
|
2193
3525
|
ARROW_LABEL_FONT_SIZE_TO_MIN_WIDTH_RATIO,
|
|
2194
3526
|
ARROW_LABEL_WIDTH_FRACTION,
|
|
2195
3527
|
ARROW_TYPE,
|
|
3528
|
+
AppEventBus,
|
|
3529
|
+
BIND_MODE_TIMEOUT,
|
|
2196
3530
|
BOUND_TEXT_PADDING,
|
|
2197
3531
|
BinaryHeap,
|
|
2198
3532
|
CANVAS_ONLY_ACTIONS,
|
|
2199
|
-
CANVAS_PALETTE_SHADE_INDEXES,
|
|
2200
3533
|
CANVAS_SEARCH_TAB,
|
|
2201
3534
|
CJK_HAND_DRAWN_FALLBACK_FONT,
|
|
2202
3535
|
CLASSES,
|
|
@@ -2208,6 +3541,7 @@ export {
|
|
|
2208
3541
|
COLOR_VOICE_CALL,
|
|
2209
3542
|
COLOR_WHITE,
|
|
2210
3543
|
CURSOR_TYPE,
|
|
3544
|
+
DARK_THEME_FILTER,
|
|
2211
3545
|
DEFAULT_ADAPTIVE_RADIUS,
|
|
2212
3546
|
DEFAULT_CANVAS_BACKGROUND_PICKS,
|
|
2213
3547
|
DEFAULT_CHART_COLOR_INDEX,
|
|
@@ -2237,8 +3571,8 @@ export {
|
|
|
2237
3571
|
DEFAULT_VERTICAL_ALIGN,
|
|
2238
3572
|
DOUBLE_TAP_POSITION_THRESHOLD,
|
|
2239
3573
|
DRAGGING_THRESHOLD,
|
|
3574
|
+
Debug,
|
|
2240
3575
|
EDITOR_LS_KEYS,
|
|
2241
|
-
ELEMENTS_PALETTE_SHADE_INDEXES,
|
|
2242
3576
|
ELEMENT_LINK_KEY,
|
|
2243
3577
|
ELEMENT_READY_TO_ERASE_OPACITY,
|
|
2244
3578
|
ELEMENT_SHIFT_TRANSLATE_AMOUNT,
|
|
@@ -2255,6 +3589,7 @@ export {
|
|
|
2255
3589
|
FONT_FAMILY_FALLBACKS,
|
|
2256
3590
|
FONT_FAMILY_GENERIC_FALLBACKS,
|
|
2257
3591
|
FONT_METADATA,
|
|
3592
|
+
FONT_SIZES,
|
|
2258
3593
|
FRAME_STYLE,
|
|
2259
3594
|
GOOGLE_FONTS_RANGES,
|
|
2260
3595
|
HYPERLINK_TOOLTIP_DELAY,
|
|
@@ -2277,11 +3612,12 @@ export {
|
|
|
2277
3612
|
MIN_FONT_SIZE,
|
|
2278
3613
|
MIN_WIDTH_OR_HEIGHT,
|
|
2279
3614
|
MIN_ZOOM,
|
|
3615
|
+
MOBILE_ACTION_BUTTON_BG,
|
|
2280
3616
|
MONOSPACE_GENERIC_FONT,
|
|
2281
3617
|
MQ_MAX_HEIGHT_LANDSCAPE,
|
|
3618
|
+
MQ_MAX_MOBILE,
|
|
2282
3619
|
MQ_MAX_TABLET,
|
|
2283
3620
|
MQ_MAX_WIDTH_LANDSCAPE,
|
|
2284
|
-
MQ_MAX_WIDTH_MOBILE,
|
|
2285
3621
|
MQ_MIN_TABLET,
|
|
2286
3622
|
MQ_MIN_WIDTH_DESKTOP,
|
|
2287
3623
|
MQ_RIGHT_SIDEBAR_MIN_WIDTH,
|
|
@@ -2306,7 +3642,6 @@ export {
|
|
|
2306
3642
|
TEXT_AUTOWRAP_THRESHOLD,
|
|
2307
3643
|
TEXT_TO_CENTER_SNAP_THRESHOLD,
|
|
2308
3644
|
THEME,
|
|
2309
|
-
THEME_FILTER,
|
|
2310
3645
|
TITLE_TIMEOUT,
|
|
2311
3646
|
TOOL_TYPE,
|
|
2312
3647
|
TOUCH_CTX_MENU_TIMEOUT,
|
|
@@ -2316,11 +3651,13 @@ export {
|
|
|
2316
3651
|
VERSIONS,
|
|
2317
3652
|
VERSION_TIMEOUT,
|
|
2318
3653
|
VERTICAL_ALIGN,
|
|
3654
|
+
VersionedSnapshotStore,
|
|
2319
3655
|
WINDOWS_EMOJI_FALLBACK_FONT,
|
|
2320
3656
|
YOUTUBE_STATES,
|
|
2321
3657
|
ZOOM_STEP,
|
|
2322
3658
|
addEventListener,
|
|
2323
3659
|
allowFullScreen,
|
|
3660
|
+
applyDarkModeFilter,
|
|
2324
3661
|
arrayToList,
|
|
2325
3662
|
arrayToMap,
|
|
2326
3663
|
arrayToMapWithIndex,
|
|
@@ -2331,8 +3668,11 @@ export {
|
|
|
2331
3668
|
castArray,
|
|
2332
3669
|
chunk,
|
|
2333
3670
|
cloneJSON,
|
|
3671
|
+
colorToHex,
|
|
2334
3672
|
composeEventHandlers,
|
|
3673
|
+
createUserAgentDescriptor,
|
|
2335
3674
|
debounce,
|
|
3675
|
+
deriveStylesPanelMode,
|
|
2336
3676
|
distance,
|
|
2337
3677
|
easeOut,
|
|
2338
3678
|
easeToValuesRAF,
|
|
@@ -2344,18 +3684,18 @@ export {
|
|
|
2344
3684
|
getAllColorsSpecificShade,
|
|
2345
3685
|
getDateTime,
|
|
2346
3686
|
getExportSource,
|
|
3687
|
+
getFeatureFlag,
|
|
2347
3688
|
getFontFamilyFallbacks,
|
|
2348
3689
|
getFontFamilyString,
|
|
2349
3690
|
getFontString,
|
|
3691
|
+
getFormFactor,
|
|
2350
3692
|
getFrame,
|
|
2351
3693
|
getGenericFontFamilyFallback,
|
|
2352
3694
|
getGlobalCSSVariable,
|
|
2353
3695
|
getGridPoint,
|
|
2354
3696
|
getLineHeight,
|
|
2355
3697
|
getNearestScrollableContainer,
|
|
2356
|
-
getShortcutKey,
|
|
2357
3698
|
getSizeFromPoints,
|
|
2358
|
-
getSpecificColorShades,
|
|
2359
3699
|
getSvgPathFromStroke,
|
|
2360
3700
|
getUpdatedTimestamp,
|
|
2361
3701
|
getVersion,
|
|
@@ -2364,9 +3704,10 @@ export {
|
|
|
2364
3704
|
isAndroid,
|
|
2365
3705
|
isAnyTrue,
|
|
2366
3706
|
isArrowKey,
|
|
2367
|
-
|
|
3707
|
+
isBounds,
|
|
2368
3708
|
isBrave,
|
|
2369
3709
|
isChrome,
|
|
3710
|
+
isColorDark,
|
|
2370
3711
|
isDarwin,
|
|
2371
3712
|
isDevEnv,
|
|
2372
3713
|
isFirefox,
|
|
@@ -2377,8 +3718,7 @@ export {
|
|
|
2377
3718
|
isLatinChar,
|
|
2378
3719
|
isLocalLink,
|
|
2379
3720
|
isMemberOf,
|
|
2380
|
-
|
|
2381
|
-
isMobileOrTablet,
|
|
3721
|
+
isMobileBreakpoint,
|
|
2382
3722
|
isPrimitive,
|
|
2383
3723
|
isProdEnv,
|
|
2384
3724
|
isPromiseLike,
|
|
@@ -2386,20 +3726,26 @@ export {
|
|
|
2386
3726
|
isReadonlyArray,
|
|
2387
3727
|
isRunningInIframe,
|
|
2388
3728
|
isSafari,
|
|
3729
|
+
isSelectionLikeTool,
|
|
2389
3730
|
isServerEnv,
|
|
2390
3731
|
isShallowEqual,
|
|
3732
|
+
isTabletBreakpoint,
|
|
2391
3733
|
isTestEnv,
|
|
2392
3734
|
isToolIcon,
|
|
2393
3735
|
isTransparent,
|
|
2394
3736
|
isWindows,
|
|
2395
3737
|
isWritableElement,
|
|
3738
|
+
loadDesktopUIModePreference,
|
|
2396
3739
|
mapFind,
|
|
2397
3740
|
matchKey,
|
|
2398
3741
|
memoize,
|
|
2399
3742
|
muteFSAbortError,
|
|
2400
3743
|
nFormatter,
|
|
3744
|
+
nextAnimationFrame,
|
|
2401
3745
|
normalizeEOL,
|
|
3746
|
+
normalizeInputColor,
|
|
2402
3747
|
normalizeLink,
|
|
3748
|
+
oneOf,
|
|
2403
3749
|
preventUnload,
|
|
2404
3750
|
promiseTry,
|
|
2405
3751
|
queryFocusableElements,
|
|
@@ -2410,11 +3756,13 @@ export {
|
|
|
2410
3756
|
rescalePoints,
|
|
2411
3757
|
reseed,
|
|
2412
3758
|
resolvablePromise,
|
|
2413
|
-
rgbToHex,
|
|
3759
|
+
rgbToHex2 as rgbToHex,
|
|
2414
3760
|
safelyParseJSON,
|
|
2415
3761
|
sceneCoordsToViewportCoords,
|
|
2416
3762
|
selectNode,
|
|
2417
3763
|
setDateTimeForTests,
|
|
3764
|
+
setDesktopUIMode,
|
|
3765
|
+
setFeatureFlag,
|
|
2418
3766
|
shouldMaintainAspectRatio,
|
|
2419
3767
|
shouldResizeFromCenter,
|
|
2420
3768
|
shouldRotateWithDiscreteAngle,
|