@excalidraw/common 0.18.0-d1f3982 → 0.18.0-d9e8a33
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 +1483 -216
- 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 +20 -12
- package/dist/types/common/src/editorInterface.d.ts +1 -1
- package/dist/types/common/src/font-metadata.d.ts +1 -3
- package/dist/types/common/src/index.d.ts +4 -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 +52 -41
- 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 +1 -1
- 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 +3 -23
- 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 +152 -201
- package/dist/types/excalidraw/actions/actionAlign.d.ts +6 -7
- package/dist/types/excalidraw/actions/actionBoundText.d.ts +82 -115
- package/dist/types/excalidraw/actions/actionCanvas.d.ts +518 -903
- package/dist/types/excalidraw/actions/actionClipboard.d.ts +113 -903
- package/dist/types/excalidraw/actions/actionCropEditor.d.ts +39 -56
- package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +132 -185
- 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 +2 -3
- package/dist/types/excalidraw/actions/actionElementLink.d.ts +48 -71
- package/dist/types/excalidraw/actions/actionElementLock.d.ts +80 -113
- package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +54 -71
- package/dist/types/excalidraw/actions/actionExport.d.ts +162 -1428
- package/dist/types/excalidraw/actions/actionFinalize.d.ts +10 -402
- package/dist/types/excalidraw/actions/actionFlip.d.ts +2 -3
- package/dist/types/excalidraw/actions/actionFrame.d.ts +280 -383
- package/dist/types/excalidraw/actions/actionGroup.d.ts +85 -126
- package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +173 -228
- package/dist/types/excalidraw/actions/actionLink.d.ts +56 -73
- package/dist/types/excalidraw/actions/actionMenu.d.ts +42 -65
- package/dist/types/excalidraw/actions/actionNavigate.d.ts +18 -367
- package/dist/types/excalidraw/actions/actionProperties.d.ts +142 -2566
- package/dist/types/excalidraw/actions/actionSelectAll.d.ts +42 -63
- package/dist/types/excalidraw/actions/actionStyles.d.ts +39 -55
- 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 +54 -71
- package/dist/types/excalidraw/actions/actionToggleMidpointSnapping.d.ts +173 -0
- package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +54 -71
- package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +42 -65
- package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +1 -1
- package/dist/types/excalidraw/actions/actionToggleStats.d.ts +53 -70
- package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +54 -71
- package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +54 -71
- package/dist/types/excalidraw/actions/actionZindex.d.ts +8 -9
- package/dist/types/excalidraw/actions/index.d.ts +3 -0
- 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 +38 -34
- 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 -40
- package/dist/types/excalidraw/components/Actions.d.ts +5 -2
- package/dist/types/excalidraw/components/App.d.ts +92 -55
- 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 +0 -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/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/keyboardNavHandlers.d.ts +0 -1
- package/dist/types/excalidraw/components/HelpDialog.d.ts +1 -1
- package/dist/types/excalidraw/components/IconPicker.d.ts +14 -9
- package/dist/types/excalidraw/components/InlineIcon.d.ts +2 -2
- 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/LibraryUnit.d.ts +2 -3
- package/dist/types/excalidraw/components/LoadingMessage.d.ts +0 -1
- package/dist/types/excalidraw/components/MobileMenu.d.ts +1 -1
- package/dist/types/excalidraw/components/MobileToolBar.d.ts +0 -1
- 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/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/Toast.d.ts +11 -7
- package/dist/types/excalidraw/components/Trans.d.ts +2 -2
- package/dist/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +5 -2
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +48 -38
- package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +7 -6
- 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 -21
- package/dist/types/excalidraw/components/main-menu/DefaultItems.d.ts +20 -2
- package/dist/types/excalidraw/components/main-menu/MainMenu.d.ts +39 -32
- package/dist/types/excalidraw/components/shapes.d.ts +74 -1
- package/dist/types/excalidraw/data/blob.d.ts +328 -7
- 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/editor-jotai.d.ts +11 -11
- package/dist/types/excalidraw/errors.d.ts +14 -0
- 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 +19 -2
- 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 +109 -21
- 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 -8
- package/dist/types/excalidraw/components/footer/FooterCenter.d.ts +0 -8
- package/dist/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +0 -22
- 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 -46
- package/dist/types/excalidraw/polyfill.d.ts +0 -2
package/dist/dev/index.js
CHANGED
|
@@ -363,173 +363,1058 @@ var BinaryHeap = class {
|
|
|
363
363
|
}
|
|
364
364
|
};
|
|
365
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
|
+
|
|
366
370
|
// src/colors.ts
|
|
367
371
|
init_define_import_meta_env();
|
|
368
372
|
|
|
369
|
-
// ../../node_modules/
|
|
370
|
-
|
|
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
|
-
|
|
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);
|
|
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();
|
|
529
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
|
+
}
|
|
530
1354
|
|
|
531
1355
|
// src/colors.ts
|
|
532
|
-
|
|
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
|
+
};
|
|
533
1418
|
var pick = (source, keys) => {
|
|
534
1419
|
return keys.reduce((acc, key) => {
|
|
535
1420
|
if (key in source) {
|
|
@@ -543,28 +1428,24 @@ var COLORS_PER_ROW = 5;
|
|
|
543
1428
|
var DEFAULT_CHART_COLOR_INDEX = 4;
|
|
544
1429
|
var DEFAULT_ELEMENT_STROKE_COLOR_INDEX = 4;
|
|
545
1430
|
var DEFAULT_ELEMENT_BACKGROUND_COLOR_INDEX = 1;
|
|
546
|
-
var ELEMENTS_PALETTE_SHADE_INDEXES = [0, 2, 4, 6, 8];
|
|
547
|
-
var CANVAS_PALETTE_SHADE_INDEXES = [0, 1, 2, 3, 4];
|
|
548
|
-
var getSpecificColorShades = (color, indexArr) => {
|
|
549
|
-
return indexArr.map((index) => open_color_default[color][index]);
|
|
550
|
-
};
|
|
551
1431
|
var COLOR_PALETTE = {
|
|
552
1432
|
transparent: "transparent",
|
|
553
1433
|
black: "#1e1e1e",
|
|
554
1434
|
white: "#ffffff",
|
|
555
|
-
// open-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
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]
|
|
568
1449
|
bronze: ["#f8f1ee", "#eaddd7", "#d2bab0", "#a18072", "#846358"]
|
|
569
1450
|
};
|
|
570
1451
|
var COMMON_ELEMENT_SHADES = pick(COLOR_PALETTE, [
|
|
@@ -636,7 +1517,58 @@ var getAllColorsSpecificShade = (index) => [
|
|
|
636
1517
|
COLOR_PALETTE.orange[index],
|
|
637
1518
|
COLOR_PALETTE.red[index]
|
|
638
1519
|
];
|
|
639
|
-
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
|
+
};
|
|
640
1572
|
|
|
641
1573
|
// src/constants.ts
|
|
642
1574
|
init_define_import_meta_env();
|
|
@@ -726,7 +1658,15 @@ var CLASSES = {
|
|
|
726
1658
|
ZOOM_ACTIONS: "zoom-actions",
|
|
727
1659
|
SEARCH_MENU_INPUT_WRAPPER: "layer-ui__search-inputWrapper",
|
|
728
1660
|
CONVERT_ELEMENT_TYPE_POPUP: "ConvertElementTypePopup",
|
|
729
|
-
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
|
|
730
1670
|
};
|
|
731
1671
|
var CJK_HAND_DRAWN_FALLBACK_FONT = "Xiaolai";
|
|
732
1672
|
var WINDOWS_EMOJI_FALLBACK_FONT = "Segoe UI Emoji";
|
|
@@ -779,6 +1719,7 @@ var THEME = {
|
|
|
779
1719
|
LIGHT: "light",
|
|
780
1720
|
DARK: "dark"
|
|
781
1721
|
};
|
|
1722
|
+
var DARK_THEME_FILTER = "invert(93%) hue-rotate(180deg)";
|
|
782
1723
|
var FRAME_STYLE = {
|
|
783
1724
|
strokeColor: "#bbb",
|
|
784
1725
|
strokeWidth: 2,
|
|
@@ -827,6 +1768,7 @@ var STRING_MIME_TYPES = {
|
|
|
827
1768
|
json: "application/json",
|
|
828
1769
|
// excalidraw data
|
|
829
1770
|
excalidraw: "application/vnd.excalidraw+json",
|
|
1771
|
+
excalidrawClipboard: "application/vnd.excalidraw.clipboard+json",
|
|
830
1772
|
// LEGACY: fully-qualified library JSON data
|
|
831
1773
|
excalidrawlib: "application/vnd.excalidrawlib+json",
|
|
832
1774
|
// list of excalidraw library item ids
|
|
@@ -871,7 +1813,6 @@ var MAX_ZOOM = 30;
|
|
|
871
1813
|
var HYPERLINK_TOOLTIP_DELAY = 300;
|
|
872
1814
|
var IDLE_THRESHOLD = 6e4;
|
|
873
1815
|
var ACTIVE_THRESHOLD = 3e3;
|
|
874
|
-
var THEME_FILTER = "invert(93%) hue-rotate(180deg)";
|
|
875
1816
|
var URL_QUERY_KEYS = {
|
|
876
1817
|
addLibrary: "addLibrary"
|
|
877
1818
|
};
|
|
@@ -1012,6 +1953,7 @@ var UserIdleState = /* @__PURE__ */ ((UserIdleState2) => {
|
|
|
1012
1953
|
})(UserIdleState || {});
|
|
1013
1954
|
var LINE_POLYGON_POINT_MERGE_DISTANCE = 20;
|
|
1014
1955
|
var DOUBLE_TAP_POSITION_THRESHOLD = 35;
|
|
1956
|
+
var BIND_MODE_TIMEOUT = 700;
|
|
1015
1957
|
var MOBILE_ACTION_BUTTON_BG = {
|
|
1016
1958
|
background: "var(--mobile-action-button-bg)"
|
|
1017
1959
|
};
|
|
@@ -1178,7 +2120,7 @@ var MQ_MAX_MOBILE = 599;
|
|
|
1178
2120
|
var MQ_MAX_WIDTH_LANDSCAPE = 1e3;
|
|
1179
2121
|
var MQ_MAX_HEIGHT_LANDSCAPE = 500;
|
|
1180
2122
|
var MQ_MIN_TABLET = MQ_MAX_MOBILE + 1;
|
|
1181
|
-
var MQ_MAX_TABLET =
|
|
2123
|
+
var MQ_MAX_TABLET = 1180;
|
|
1182
2124
|
var MQ_MIN_WIDTH_DESKTOP = 1440;
|
|
1183
2125
|
var MQ_RIGHT_SIDEBAR_MIN_WIDTH = 1229;
|
|
1184
2126
|
var isDarwin = /Mac|iPod|iPhone|iPad/.test(navigator.platform);
|
|
@@ -1542,7 +2484,7 @@ var isInteractive = (target) => {
|
|
|
1542
2484
|
return isInputLike(target) || target instanceof Element && !!target.closest("label, button");
|
|
1543
2485
|
};
|
|
1544
2486
|
var isWritableElement = (target) => target instanceof HTMLElement && target.dataset.type === "wysiwyg" || target instanceof HTMLBRElement || // newline in wysiwyg
|
|
1545
|
-
target instanceof HTMLTextAreaElement || target instanceof HTMLInputElement && (target.type === "text" || target.type === "number" || target.type === "password" || target.type === "search");
|
|
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;
|
|
1546
2488
|
var getFontFamilyString = ({
|
|
1547
2489
|
fontFamily
|
|
1548
2490
|
}) => {
|
|
@@ -1587,32 +2529,23 @@ var debounce = (fn, timeout) => {
|
|
|
1587
2529
|
};
|
|
1588
2530
|
return ret;
|
|
1589
2531
|
};
|
|
1590
|
-
var throttleRAF = (fn
|
|
2532
|
+
var throttleRAF = (fn) => {
|
|
1591
2533
|
let timerId = null;
|
|
1592
2534
|
let lastArgs = null;
|
|
1593
|
-
|
|
1594
|
-
const scheduleFunc = (args) => {
|
|
2535
|
+
const scheduleFunc = () => {
|
|
1595
2536
|
timerId = window.requestAnimationFrame(() => {
|
|
1596
2537
|
timerId = null;
|
|
1597
|
-
|
|
2538
|
+
const args = lastArgs;
|
|
1598
2539
|
lastArgs = null;
|
|
1599
|
-
if (
|
|
1600
|
-
|
|
1601
|
-
lastArgsTrailing = null;
|
|
1602
|
-
scheduleFunc(lastArgs);
|
|
2540
|
+
if (args) {
|
|
2541
|
+
fn(...args);
|
|
1603
2542
|
}
|
|
1604
2543
|
});
|
|
1605
2544
|
};
|
|
1606
2545
|
const ret = (...args) => {
|
|
1607
|
-
if (isTestEnv()) {
|
|
1608
|
-
fn(...args);
|
|
1609
|
-
return;
|
|
1610
|
-
}
|
|
1611
2546
|
lastArgs = args;
|
|
1612
2547
|
if (timerId === null) {
|
|
1613
|
-
scheduleFunc(
|
|
1614
|
-
} else if (opts?.trailing) {
|
|
1615
|
-
lastArgsTrailing = args;
|
|
2548
|
+
scheduleFunc();
|
|
1616
2549
|
}
|
|
1617
2550
|
};
|
|
1618
2551
|
ret.flush = () => {
|
|
@@ -1621,12 +2554,12 @@ var throttleRAF = (fn, opts) => {
|
|
|
1621
2554
|
timerId = null;
|
|
1622
2555
|
}
|
|
1623
2556
|
if (lastArgs) {
|
|
1624
|
-
fn(...
|
|
1625
|
-
lastArgs =
|
|
2557
|
+
fn(...lastArgs);
|
|
2558
|
+
lastArgs = null;
|
|
1626
2559
|
}
|
|
1627
2560
|
};
|
|
1628
2561
|
ret.cancel = () => {
|
|
1629
|
-
lastArgs =
|
|
2562
|
+
lastArgs = null;
|
|
1630
2563
|
if (timerId !== null) {
|
|
1631
2564
|
cancelAnimationFrame(timerId);
|
|
1632
2565
|
timerId = null;
|
|
@@ -1726,6 +2659,9 @@ var removeSelection = () => {
|
|
|
1726
2659
|
}
|
|
1727
2660
|
};
|
|
1728
2661
|
var distance = (x, y) => Math.abs(x - y);
|
|
2662
|
+
var isSelectionLikeTool = (type) => {
|
|
2663
|
+
return type === "selection" || type === "lasso";
|
|
2664
|
+
};
|
|
1729
2665
|
var updateActiveTool = (appState, data) => {
|
|
1730
2666
|
if (data.type === "custom") {
|
|
1731
2667
|
return {
|
|
@@ -1820,12 +2756,6 @@ var mapFind = (collection, iteratee) => {
|
|
|
1820
2756
|
}
|
|
1821
2757
|
return void 0;
|
|
1822
2758
|
};
|
|
1823
|
-
var isTransparent = (color) => {
|
|
1824
|
-
const isRGBTransparent = color.length === 5 && color.substr(4, 1) === "0";
|
|
1825
|
-
const isRRGGBBTransparent = color.length === 9 && color.substr(7, 2) === "00";
|
|
1826
|
-
return isRGBTransparent || isRRGGBBTransparent || color === COLOR_PALETTE.transparent;
|
|
1827
|
-
};
|
|
1828
|
-
var isBindingFallthroughEnabled = (el) => el.fillStyle !== "solid" || isTransparent(el.backgroundColor);
|
|
1829
2759
|
var resolvablePromise = () => {
|
|
1830
2760
|
let resolve;
|
|
1831
2761
|
let reject;
|
|
@@ -2146,9 +3076,9 @@ function getSvgPathFromStroke(points, closed = true) {
|
|
|
2146
3076
|
var normalizeEOL = (str) => {
|
|
2147
3077
|
return str.replace(/\r?\n|\r/g, "\n");
|
|
2148
3078
|
};
|
|
2149
|
-
|
|
3079
|
+
function toBrandedType(value) {
|
|
2150
3080
|
return value;
|
|
2151
|
-
}
|
|
3081
|
+
}
|
|
2152
3082
|
var promiseTry = async (fn, ...args) => {
|
|
2153
3083
|
return new Promise((resolve) => {
|
|
2154
3084
|
resolve(fn(...args));
|
|
@@ -2188,6 +3118,41 @@ var reduceToCommonValue = (collection, getValue) => {
|
|
|
2188
3118
|
}
|
|
2189
3119
|
return commonValue;
|
|
2190
3120
|
};
|
|
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 {
|
|
3135
|
+
}
|
|
3136
|
+
}
|
|
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);
|
|
3151
|
+
}
|
|
3152
|
+
};
|
|
3153
|
+
var oneOf = (needle, haystack) => {
|
|
3154
|
+
return haystack.includes(needle);
|
|
3155
|
+
};
|
|
2191
3156
|
|
|
2192
3157
|
// src/random.ts
|
|
2193
3158
|
var random = new Random(Date.now());
|
|
@@ -2261,6 +3226,298 @@ var Emitter = class {
|
|
|
2261
3226
|
this.subscribers = [];
|
|
2262
3227
|
}
|
|
2263
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
|
+
}
|
|
2264
3521
|
export {
|
|
2265
3522
|
ACTIVE_THRESHOLD,
|
|
2266
3523
|
ALLOWED_PASTE_MIME_TYPES,
|
|
@@ -2268,10 +3525,11 @@ export {
|
|
|
2268
3525
|
ARROW_LABEL_FONT_SIZE_TO_MIN_WIDTH_RATIO,
|
|
2269
3526
|
ARROW_LABEL_WIDTH_FRACTION,
|
|
2270
3527
|
ARROW_TYPE,
|
|
3528
|
+
AppEventBus,
|
|
3529
|
+
BIND_MODE_TIMEOUT,
|
|
2271
3530
|
BOUND_TEXT_PADDING,
|
|
2272
3531
|
BinaryHeap,
|
|
2273
3532
|
CANVAS_ONLY_ACTIONS,
|
|
2274
|
-
CANVAS_PALETTE_SHADE_INDEXES,
|
|
2275
3533
|
CANVAS_SEARCH_TAB,
|
|
2276
3534
|
CJK_HAND_DRAWN_FALLBACK_FONT,
|
|
2277
3535
|
CLASSES,
|
|
@@ -2283,6 +3541,7 @@ export {
|
|
|
2283
3541
|
COLOR_VOICE_CALL,
|
|
2284
3542
|
COLOR_WHITE,
|
|
2285
3543
|
CURSOR_TYPE,
|
|
3544
|
+
DARK_THEME_FILTER,
|
|
2286
3545
|
DEFAULT_ADAPTIVE_RADIUS,
|
|
2287
3546
|
DEFAULT_CANVAS_BACKGROUND_PICKS,
|
|
2288
3547
|
DEFAULT_CHART_COLOR_INDEX,
|
|
@@ -2312,8 +3571,8 @@ export {
|
|
|
2312
3571
|
DEFAULT_VERTICAL_ALIGN,
|
|
2313
3572
|
DOUBLE_TAP_POSITION_THRESHOLD,
|
|
2314
3573
|
DRAGGING_THRESHOLD,
|
|
3574
|
+
Debug,
|
|
2315
3575
|
EDITOR_LS_KEYS,
|
|
2316
|
-
ELEMENTS_PALETTE_SHADE_INDEXES,
|
|
2317
3576
|
ELEMENT_LINK_KEY,
|
|
2318
3577
|
ELEMENT_READY_TO_ERASE_OPACITY,
|
|
2319
3578
|
ELEMENT_SHIFT_TRANSLATE_AMOUNT,
|
|
@@ -2330,6 +3589,7 @@ export {
|
|
|
2330
3589
|
FONT_FAMILY_FALLBACKS,
|
|
2331
3590
|
FONT_FAMILY_GENERIC_FALLBACKS,
|
|
2332
3591
|
FONT_METADATA,
|
|
3592
|
+
FONT_SIZES,
|
|
2333
3593
|
FRAME_STYLE,
|
|
2334
3594
|
GOOGLE_FONTS_RANGES,
|
|
2335
3595
|
HYPERLINK_TOOLTIP_DELAY,
|
|
@@ -2382,7 +3642,6 @@ export {
|
|
|
2382
3642
|
TEXT_AUTOWRAP_THRESHOLD,
|
|
2383
3643
|
TEXT_TO_CENTER_SNAP_THRESHOLD,
|
|
2384
3644
|
THEME,
|
|
2385
|
-
THEME_FILTER,
|
|
2386
3645
|
TITLE_TIMEOUT,
|
|
2387
3646
|
TOOL_TYPE,
|
|
2388
3647
|
TOUCH_CTX_MENU_TIMEOUT,
|
|
@@ -2392,11 +3651,13 @@ export {
|
|
|
2392
3651
|
VERSIONS,
|
|
2393
3652
|
VERSION_TIMEOUT,
|
|
2394
3653
|
VERTICAL_ALIGN,
|
|
3654
|
+
VersionedSnapshotStore,
|
|
2395
3655
|
WINDOWS_EMOJI_FALLBACK_FONT,
|
|
2396
3656
|
YOUTUBE_STATES,
|
|
2397
3657
|
ZOOM_STEP,
|
|
2398
3658
|
addEventListener,
|
|
2399
3659
|
allowFullScreen,
|
|
3660
|
+
applyDarkModeFilter,
|
|
2400
3661
|
arrayToList,
|
|
2401
3662
|
arrayToMap,
|
|
2402
3663
|
arrayToMapWithIndex,
|
|
@@ -2407,6 +3668,7 @@ export {
|
|
|
2407
3668
|
castArray,
|
|
2408
3669
|
chunk,
|
|
2409
3670
|
cloneJSON,
|
|
3671
|
+
colorToHex,
|
|
2410
3672
|
composeEventHandlers,
|
|
2411
3673
|
createUserAgentDescriptor,
|
|
2412
3674
|
debounce,
|
|
@@ -2422,6 +3684,7 @@ export {
|
|
|
2422
3684
|
getAllColorsSpecificShade,
|
|
2423
3685
|
getDateTime,
|
|
2424
3686
|
getExportSource,
|
|
3687
|
+
getFeatureFlag,
|
|
2425
3688
|
getFontFamilyFallbacks,
|
|
2426
3689
|
getFontFamilyString,
|
|
2427
3690
|
getFontString,
|
|
@@ -2433,7 +3696,6 @@ export {
|
|
|
2433
3696
|
getLineHeight,
|
|
2434
3697
|
getNearestScrollableContainer,
|
|
2435
3698
|
getSizeFromPoints,
|
|
2436
|
-
getSpecificColorShades,
|
|
2437
3699
|
getSvgPathFromStroke,
|
|
2438
3700
|
getUpdatedTimestamp,
|
|
2439
3701
|
getVersion,
|
|
@@ -2442,9 +3704,10 @@ export {
|
|
|
2442
3704
|
isAndroid,
|
|
2443
3705
|
isAnyTrue,
|
|
2444
3706
|
isArrowKey,
|
|
2445
|
-
|
|
3707
|
+
isBounds,
|
|
2446
3708
|
isBrave,
|
|
2447
3709
|
isChrome,
|
|
3710
|
+
isColorDark,
|
|
2448
3711
|
isDarwin,
|
|
2449
3712
|
isDevEnv,
|
|
2450
3713
|
isFirefox,
|
|
@@ -2463,6 +3726,7 @@ export {
|
|
|
2463
3726
|
isReadonlyArray,
|
|
2464
3727
|
isRunningInIframe,
|
|
2465
3728
|
isSafari,
|
|
3729
|
+
isSelectionLikeTool,
|
|
2466
3730
|
isServerEnv,
|
|
2467
3731
|
isShallowEqual,
|
|
2468
3732
|
isTabletBreakpoint,
|
|
@@ -2479,7 +3743,9 @@ export {
|
|
|
2479
3743
|
nFormatter,
|
|
2480
3744
|
nextAnimationFrame,
|
|
2481
3745
|
normalizeEOL,
|
|
3746
|
+
normalizeInputColor,
|
|
2482
3747
|
normalizeLink,
|
|
3748
|
+
oneOf,
|
|
2483
3749
|
preventUnload,
|
|
2484
3750
|
promiseTry,
|
|
2485
3751
|
queryFocusableElements,
|
|
@@ -2490,12 +3756,13 @@ export {
|
|
|
2490
3756
|
rescalePoints,
|
|
2491
3757
|
reseed,
|
|
2492
3758
|
resolvablePromise,
|
|
2493
|
-
rgbToHex,
|
|
3759
|
+
rgbToHex2 as rgbToHex,
|
|
2494
3760
|
safelyParseJSON,
|
|
2495
3761
|
sceneCoordsToViewportCoords,
|
|
2496
3762
|
selectNode,
|
|
2497
3763
|
setDateTimeForTests,
|
|
2498
3764
|
setDesktopUIMode,
|
|
3765
|
+
setFeatureFlag,
|
|
2499
3766
|
shouldMaintainAspectRatio,
|
|
2500
3767
|
shouldResizeFromCenter,
|
|
2501
3768
|
shouldRotateWithDiscreteAngle,
|