@excalidraw/common 0.18.0-1b287a8ba → 0.18.0-2874f9e
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 +1524 -239
- 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/bounds.d.ts +10 -0
- package/dist/types/common/src/colors.d.ts +59 -39
- package/dist/types/common/src/constants.d.ts +39 -27
- 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 +3 -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 +53 -39
- package/dist/types/element/src/Scene.d.ts +10 -6
- 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 +66 -46
- package/dist/types/element/src/bounds.d.ts +3 -11
- 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/delta.d.ts +16 -4
- 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/fractionalIndex.d.ts +2 -2
- package/dist/types/element/src/frame.d.ts +7 -3
- 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 +20 -21
- package/dist/types/element/src/mutateElement.d.ts +3 -1
- package/dist/types/element/src/newElement.d.ts +6 -6
- package/dist/types/element/src/positionElementsOnGrid.d.ts +2 -0
- package/dist/types/element/src/renderElement.d.ts +4 -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 +3 -7
- package/dist/types/element/src/shape.d.ts +8 -7
- package/dist/types/element/src/store.d.ts +6 -1
- package/dist/types/element/src/textElement.d.ts +1 -1
- package/dist/types/element/src/textMeasurements.d.ts +1 -3
- 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 +7 -11
- package/dist/types/element/src/utils.d.ts +8 -3
- package/dist/types/element/src/zindex.d.ts +7 -1
- package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +147 -184
- package/dist/types/excalidraw/actions/actionAlign.d.ts +6 -7
- package/dist/types/excalidraw/actions/actionBoundText.d.ts +73 -98
- package/dist/types/excalidraw/actions/actionCanvas.d.ts +438 -771
- package/dist/types/excalidraw/actions/actionClipboard.d.ts +109 -878
- package/dist/types/excalidraw/actions/actionCropEditor.d.ts +35 -48
- package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +124 -165
- 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 +50 -65
- package/dist/types/excalidraw/actions/actionElementLock.d.ts +72 -97
- package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +52 -65
- package/dist/types/excalidraw/actions/actionExport.d.ts +161 -1118
- package/dist/types/excalidraw/actions/actionFinalize.d.ts +10 -395
- package/dist/types/excalidraw/actions/actionFlip.d.ts +2 -3
- package/dist/types/excalidraw/actions/actionFrame.d.ts +264 -351
- package/dist/types/excalidraw/actions/actionGroup.d.ts +76 -109
- package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +191 -211
- package/dist/types/excalidraw/actions/actionLink.d.ts +52 -65
- package/dist/types/excalidraw/actions/actionMenu.d.ts +45 -428
- package/dist/types/excalidraw/actions/actionNavigate.d.ts +18 -361
- package/dist/types/excalidraw/actions/actionProperties.d.ts +135 -2503
- package/dist/types/excalidraw/actions/actionSelectAll.d.ts +38 -55
- package/dist/types/excalidraw/actions/actionStyles.d.ts +35 -48
- package/dist/types/excalidraw/actions/actionTextAutoResize.d.ts +3 -3
- package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +52 -65
- package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +52 -65
- package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +44 -59
- package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +1 -1
- package/dist/types/excalidraw/actions/actionToggleStats.d.ts +51 -64
- package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +52 -65
- package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +52 -65
- package/dist/types/excalidraw/actions/actionZindex.d.ts +8 -9
- package/dist/types/excalidraw/actions/index.d.ts +2 -2
- 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 +26 -21
- package/dist/types/excalidraw/clipboard.d.ts +58 -17
- package/dist/types/excalidraw/components/Actions.d.ts +21 -8
- package/dist/types/excalidraw/components/App.d.ts +77 -67
- 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/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/ExcalidrawLogo.d.ts +1 -2
- 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/FontPicker.d.ts +2 -1
- package/dist/types/excalidraw/components/FontPicker/FontPickerTrigger.d.ts +3 -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/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/Popover.d.ts +2 -1
- package/dist/types/excalidraw/components/PropertiesPopover.d.ts +2 -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/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/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/TTDDialogOutput.d.ts +2 -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/TTDDialogTrigger.d.ts +2 -3
- 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/types.d.ts +95 -0
- package/dist/types/excalidraw/components/TTDDialog/useTTDChatStorage.d.ts +22 -0
- package/dist/types/excalidraw/components/TTDDialog/utils/TTDStreamFetch.d.ts +24 -0
- package/dist/types/excalidraw/components/TTDDialog/utils/chat.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 +3 -3
- 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 +6 -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 +0 -1
- 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 +32 -13
- package/dist/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +4 -3
- package/dist/types/excalidraw/components/main-menu/DefaultItems.d.ts +17 -2
- package/dist/types/excalidraw/components/main-menu/MainMenu.d.ts +39 -35
- package/dist/types/excalidraw/components/shapes.d.ts +202 -1
- package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.Center.d.ts +6 -6
- package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.d.ts +15 -16
- package/dist/types/excalidraw/data/blob.d.ts +330 -10
- 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 +2 -2
- package/dist/types/excalidraw/data/index.d.ts +3 -3
- package/dist/types/excalidraw/data/json.d.ts +162 -2
- package/dist/types/excalidraw/data/library.d.ts +24 -9
- package/dist/types/excalidraw/data/reconcile.d.ts +1 -0
- package/dist/types/excalidraw/data/restore.d.ts +27 -7
- 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/hooks/useTextEditorFocus.d.ts +14 -0
- package/dist/types/excalidraw/i18n.d.ts +2 -2
- package/dist/types/excalidraw/index.d.ts +7 -7
- 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/renderer/staticScene.d.ts +4 -1
- 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/types.d.ts +44 -25
- package/dist/types/excalidraw/wysiwyg/textWysiwyg.d.ts +2 -2
- package/dist/types/math/src/point.d.ts +6 -1
- 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 +4 -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/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,23 +1517,66 @@ 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/.test(navigator.platform) || // iPadOS 13+
|
|
651
|
-
navigator.userAgent.includes("Mac") && "ontouchend" in document;
|
|
652
|
-
var isBrave = () => navigator.brave?.isBrave?.name === "isBrave";
|
|
653
1575
|
var supportsResizeObserver = typeof window !== "undefined" && "ResizeObserver" in window;
|
|
654
1576
|
var APP_NAME = "Excalidraw";
|
|
655
1577
|
var TEXT_AUTOWRAP_THRESHOLD = 36;
|
|
656
1578
|
var DRAGGING_THRESHOLD = 10;
|
|
1579
|
+
var MINIMUM_ARROW_SIZE = 20;
|
|
657
1580
|
var LINE_CONFIRM_THRESHOLD = 8;
|
|
658
1581
|
var ELEMENT_SHIFT_TRANSLATE_AMOUNT = 5;
|
|
659
1582
|
var ELEMENT_TRANSLATE_AMOUNT = 1;
|
|
@@ -730,10 +1653,20 @@ var ENV = {
|
|
|
730
1653
|
PRODUCTION: "production"
|
|
731
1654
|
};
|
|
732
1655
|
var CLASSES = {
|
|
1656
|
+
SIDEBAR: "sidebar",
|
|
733
1657
|
SHAPE_ACTIONS_MENU: "App-menu__left",
|
|
734
1658
|
ZOOM_ACTIONS: "zoom-actions",
|
|
735
1659
|
SEARCH_MENU_INPUT_WRAPPER: "layer-ui__search-inputWrapper",
|
|
736
|
-
CONVERT_ELEMENT_TYPE_POPUP: "ConvertElementTypePopup"
|
|
1660
|
+
CONVERT_ELEMENT_TYPE_POPUP: "ConvertElementTypePopup",
|
|
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
|
|
737
1670
|
};
|
|
738
1671
|
var CJK_HAND_DRAWN_FALLBACK_FONT = "Xiaolai";
|
|
739
1672
|
var WINDOWS_EMOJI_FALLBACK_FONT = "Segoe UI Emoji";
|
|
@@ -786,6 +1719,7 @@ var THEME = {
|
|
|
786
1719
|
LIGHT: "light",
|
|
787
1720
|
DARK: "dark"
|
|
788
1721
|
};
|
|
1722
|
+
var DARK_THEME_FILTER = "invert(93%) hue-rotate(180deg)";
|
|
789
1723
|
var FRAME_STYLE = {
|
|
790
1724
|
strokeColor: "#bbb",
|
|
791
1725
|
strokeWidth: 2,
|
|
@@ -828,13 +1762,20 @@ var IMAGE_MIME_TYPES = {
|
|
|
828
1762
|
avif: "image/avif",
|
|
829
1763
|
jfif: "image/jfif"
|
|
830
1764
|
};
|
|
831
|
-
var
|
|
1765
|
+
var STRING_MIME_TYPES = {
|
|
832
1766
|
text: "text/plain",
|
|
833
1767
|
html: "text/html",
|
|
834
1768
|
json: "application/json",
|
|
835
1769
|
// excalidraw data
|
|
836
1770
|
excalidraw: "application/vnd.excalidraw+json",
|
|
1771
|
+
excalidrawClipboard: "application/vnd.excalidraw.clipboard+json",
|
|
1772
|
+
// LEGACY: fully-qualified library JSON data
|
|
837
1773
|
excalidrawlib: "application/vnd.excalidrawlib+json",
|
|
1774
|
+
// list of excalidraw library item ids
|
|
1775
|
+
excalidrawlibIds: "application/vnd.excalidrawlib.ids+json"
|
|
1776
|
+
};
|
|
1777
|
+
var MIME_TYPES = {
|
|
1778
|
+
...STRING_MIME_TYPES,
|
|
838
1779
|
// image-encoded excalidraw data
|
|
839
1780
|
"excalidraw.svg": "image/svg+xml",
|
|
840
1781
|
"excalidraw.png": "image/png",
|
|
@@ -872,7 +1813,6 @@ var MAX_ZOOM = 30;
|
|
|
872
1813
|
var HYPERLINK_TOOLTIP_DELAY = 300;
|
|
873
1814
|
var IDLE_THRESHOLD = 6e4;
|
|
874
1815
|
var ACTIVE_THRESHOLD = 3e3;
|
|
875
|
-
var THEME_FILTER = "invert(93%) hue-rotate(180deg)";
|
|
876
1816
|
var URL_QUERY_KEYS = {
|
|
877
1817
|
addLibrary: "addLibrary"
|
|
878
1818
|
};
|
|
@@ -893,10 +1833,6 @@ var DEFAULT_UI_OPTIONS = {
|
|
|
893
1833
|
image: true
|
|
894
1834
|
}
|
|
895
1835
|
};
|
|
896
|
-
var MQ_MAX_WIDTH_PORTRAIT = 730;
|
|
897
|
-
var MQ_MAX_WIDTH_LANDSCAPE = 1e3;
|
|
898
|
-
var MQ_MAX_HEIGHT_LANDSCAPE = 500;
|
|
899
|
-
var MQ_RIGHT_SIDEBAR_MIN_WIDTH = 1229;
|
|
900
1836
|
var MAX_DECIMALS_FOR_SVG_EXPORT = 2;
|
|
901
1837
|
var EXPORT_SCALES = [1, 2, 3];
|
|
902
1838
|
var DEFAULT_EXPORT_PADDING = 10;
|
|
@@ -1016,6 +1952,11 @@ var UserIdleState = /* @__PURE__ */ ((UserIdleState2) => {
|
|
|
1016
1952
|
return UserIdleState2;
|
|
1017
1953
|
})(UserIdleState || {});
|
|
1018
1954
|
var LINE_POLYGON_POINT_MERGE_DISTANCE = 20;
|
|
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
|
+
};
|
|
1019
1960
|
|
|
1020
1961
|
// src/font-metadata.ts
|
|
1021
1962
|
init_define_import_meta_env();
|
|
@@ -1171,6 +2112,133 @@ var Queue = class {
|
|
|
1171
2112
|
|
|
1172
2113
|
// src/keys.ts
|
|
1173
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
|
|
1174
2242
|
var CODES = {
|
|
1175
2243
|
EQUAL: "Equal",
|
|
1176
2244
|
MINUS: "Minus",
|
|
@@ -1416,7 +2484,7 @@ var isInteractive = (target) => {
|
|
|
1416
2484
|
return isInputLike(target) || target instanceof Element && !!target.closest("label, button");
|
|
1417
2485
|
};
|
|
1418
2486
|
var isWritableElement = (target) => target instanceof HTMLElement && target.dataset.type === "wysiwyg" || target instanceof HTMLBRElement || // newline in wysiwyg
|
|
1419
|
-
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");
|
|
1420
2488
|
var getFontFamilyString = ({
|
|
1421
2489
|
fontFamily
|
|
1422
2490
|
}) => {
|
|
@@ -1433,6 +2501,9 @@ var getFontString = ({
|
|
|
1433
2501
|
}) => {
|
|
1434
2502
|
return `${fontSize}px ${getFontFamilyString({ fontFamily })}`;
|
|
1435
2503
|
};
|
|
2504
|
+
var nextAnimationFrame = async (cb) => {
|
|
2505
|
+
requestAnimationFrame(() => requestAnimationFrame(cb));
|
|
2506
|
+
};
|
|
1436
2507
|
var debounce = (fn, timeout) => {
|
|
1437
2508
|
let handle = 0;
|
|
1438
2509
|
let lastArgs = null;
|
|
@@ -1597,6 +2668,9 @@ var removeSelection = () => {
|
|
|
1597
2668
|
}
|
|
1598
2669
|
};
|
|
1599
2670
|
var distance = (x, y) => Math.abs(x - y);
|
|
2671
|
+
var isSelectionLikeTool = (type) => {
|
|
2672
|
+
return type === "selection" || type === "lasso";
|
|
2673
|
+
};
|
|
1600
2674
|
var updateActiveTool = (appState, data) => {
|
|
1601
2675
|
if (data.type === "custom") {
|
|
1602
2676
|
return {
|
|
@@ -1618,13 +2692,6 @@ var updateActiveTool = (appState, data) => {
|
|
|
1618
2692
|
var isFullScreen = () => document.fullscreenElement?.nodeName === "HTML";
|
|
1619
2693
|
var allowFullScreen = () => document.documentElement.requestFullscreen();
|
|
1620
2694
|
var exitFullScreen = () => document.exitFullscreen();
|
|
1621
|
-
var getShortcutKey = (shortcut) => {
|
|
1622
|
-
shortcut = shortcut.replace(/\bAlt\b/i, "Alt").replace(/\bShift\b/i, "Shift").replace(/\b(Enter|Return)\b/i, "Enter");
|
|
1623
|
-
if (isDarwin) {
|
|
1624
|
-
return shortcut.replace(/\bCtrlOrCmd\b/gi, "Cmd").replace(/\bAlt\b/i, "Option");
|
|
1625
|
-
}
|
|
1626
|
-
return shortcut.replace(/\bCtrlOrCmd\b/gi, "Ctrl");
|
|
1627
|
-
};
|
|
1628
2695
|
var viewportCoordsToSceneCoords = ({ clientX, clientY }, {
|
|
1629
2696
|
zoom,
|
|
1630
2697
|
offsetLeft,
|
|
@@ -1698,12 +2765,6 @@ var mapFind = (collection, iteratee) => {
|
|
|
1698
2765
|
}
|
|
1699
2766
|
return void 0;
|
|
1700
2767
|
};
|
|
1701
|
-
var isTransparent = (color) => {
|
|
1702
|
-
const isRGBTransparent = color.length === 5 && color.substr(4, 1) === "0";
|
|
1703
|
-
const isRRGGBBTransparent = color.length === 9 && color.substr(7, 2) === "00";
|
|
1704
|
-
return isRGBTransparent || isRRGGBBTransparent || color === COLOR_PALETTE.transparent;
|
|
1705
|
-
};
|
|
1706
|
-
var isBindingFallthroughEnabled = (el) => el.fillStyle !== "solid" || isTransparent(el.backgroundColor);
|
|
1707
2768
|
var resolvablePromise = () => {
|
|
1708
2769
|
let resolve;
|
|
1709
2770
|
let reject;
|
|
@@ -2024,9 +3085,9 @@ function getSvgPathFromStroke(points, closed = true) {
|
|
|
2024
3085
|
var normalizeEOL = (str) => {
|
|
2025
3086
|
return str.replace(/\r?\n|\r/g, "\n");
|
|
2026
3087
|
};
|
|
2027
|
-
|
|
3088
|
+
function toBrandedType(value) {
|
|
2028
3089
|
return value;
|
|
2029
|
-
}
|
|
3090
|
+
}
|
|
2030
3091
|
var promiseTry = async (fn, ...args) => {
|
|
2031
3092
|
return new Promise((resolve) => {
|
|
2032
3093
|
resolve(fn(...args));
|
|
@@ -2066,6 +3127,41 @@ var reduceToCommonValue = (collection, getValue) => {
|
|
|
2066
3127
|
}
|
|
2067
3128
|
return commonValue;
|
|
2068
3129
|
};
|
|
3130
|
+
var FEATURE_FLAGS_STORAGE_KEY = "excalidraw-feature-flags";
|
|
3131
|
+
var DEFAULT_FEATURE_FLAGS = {
|
|
3132
|
+
COMPLEX_BINDINGS: false
|
|
3133
|
+
};
|
|
3134
|
+
var featureFlags = null;
|
|
3135
|
+
var getFeatureFlag = (flag) => {
|
|
3136
|
+
if (!featureFlags) {
|
|
3137
|
+
try {
|
|
3138
|
+
const serializedFlags = localStorage.getItem(FEATURE_FLAGS_STORAGE_KEY);
|
|
3139
|
+
if (serializedFlags) {
|
|
3140
|
+
const flags = JSON.parse(serializedFlags);
|
|
3141
|
+
featureFlags = flags ?? DEFAULT_FEATURE_FLAGS;
|
|
3142
|
+
}
|
|
3143
|
+
} catch {
|
|
3144
|
+
}
|
|
3145
|
+
}
|
|
3146
|
+
return (featureFlags || DEFAULT_FEATURE_FLAGS)[flag];
|
|
3147
|
+
};
|
|
3148
|
+
var setFeatureFlag = (flag, value) => {
|
|
3149
|
+
try {
|
|
3150
|
+
featureFlags = {
|
|
3151
|
+
...featureFlags || DEFAULT_FEATURE_FLAGS,
|
|
3152
|
+
[flag]: value
|
|
3153
|
+
};
|
|
3154
|
+
localStorage.setItem(
|
|
3155
|
+
FEATURE_FLAGS_STORAGE_KEY,
|
|
3156
|
+
JSON.stringify(featureFlags)
|
|
3157
|
+
);
|
|
3158
|
+
} catch (e) {
|
|
3159
|
+
console.error("unable to set feature flag", e);
|
|
3160
|
+
}
|
|
3161
|
+
};
|
|
3162
|
+
var oneOf = (needle, haystack) => {
|
|
3163
|
+
return haystack.includes(needle);
|
|
3164
|
+
};
|
|
2069
3165
|
|
|
2070
3166
|
// src/random.ts
|
|
2071
3167
|
var random = new Random(Date.now());
|
|
@@ -2139,6 +3235,173 @@ var Emitter = class {
|
|
|
2139
3235
|
this.subscribers = [];
|
|
2140
3236
|
}
|
|
2141
3237
|
};
|
|
3238
|
+
|
|
3239
|
+
// debug.ts
|
|
3240
|
+
init_define_import_meta_env();
|
|
3241
|
+
var lessPrecise = (num, precision = 5) => parseFloat(num.toPrecision(precision));
|
|
3242
|
+
var getAvgFrameTime = (times) => lessPrecise(times.reduce((a, b) => a + b) / times.length);
|
|
3243
|
+
var Debug = class _Debug {
|
|
3244
|
+
static DEBUG_LOG_TIMES = true;
|
|
3245
|
+
static TIMES_AGGR = {};
|
|
3246
|
+
static TIMES_AVG = {};
|
|
3247
|
+
static LAST_DEBUG_LOG_CALL = 0;
|
|
3248
|
+
static DEBUG_LOG_INTERVAL_ID = null;
|
|
3249
|
+
static LAST_FRAME_TIMESTAMP = 0;
|
|
3250
|
+
static FRAME_COUNT = 0;
|
|
3251
|
+
static ANIMATION_FRAME_ID = null;
|
|
3252
|
+
static scheduleAnimationFrame = () => {
|
|
3253
|
+
if (_Debug.DEBUG_LOG_INTERVAL_ID !== null) {
|
|
3254
|
+
_Debug.ANIMATION_FRAME_ID = requestAnimationFrame((timestamp) => {
|
|
3255
|
+
if (_Debug.LAST_FRAME_TIMESTAMP !== timestamp) {
|
|
3256
|
+
_Debug.LAST_FRAME_TIMESTAMP = timestamp;
|
|
3257
|
+
_Debug.FRAME_COUNT++;
|
|
3258
|
+
}
|
|
3259
|
+
if (_Debug.DEBUG_LOG_INTERVAL_ID !== null) {
|
|
3260
|
+
_Debug.scheduleAnimationFrame();
|
|
3261
|
+
}
|
|
3262
|
+
});
|
|
3263
|
+
}
|
|
3264
|
+
};
|
|
3265
|
+
static setupInterval = () => {
|
|
3266
|
+
if (_Debug.DEBUG_LOG_INTERVAL_ID === null) {
|
|
3267
|
+
console.info("%c(starting perf recording)", "color: lime");
|
|
3268
|
+
_Debug.DEBUG_LOG_INTERVAL_ID = window.setInterval(_Debug.debugLogger, 1e3);
|
|
3269
|
+
_Debug.scheduleAnimationFrame();
|
|
3270
|
+
}
|
|
3271
|
+
_Debug.LAST_DEBUG_LOG_CALL = Date.now();
|
|
3272
|
+
};
|
|
3273
|
+
static debugLogger = () => {
|
|
3274
|
+
if (_Debug.DEBUG_LOG_TIMES) {
|
|
3275
|
+
for (const [name, { t, times }] of Object.entries(_Debug.TIMES_AGGR)) {
|
|
3276
|
+
if (times.length) {
|
|
3277
|
+
console.info(
|
|
3278
|
+
name,
|
|
3279
|
+
lessPrecise(times.reduce((a, b) => a + b)),
|
|
3280
|
+
times.sort((a, b) => a - b).map((x) => lessPrecise(x))
|
|
3281
|
+
);
|
|
3282
|
+
_Debug.TIMES_AGGR[name] = { t, times: [] };
|
|
3283
|
+
}
|
|
3284
|
+
}
|
|
3285
|
+
for (const [name, { t, times, avg }] of Object.entries(_Debug.TIMES_AVG)) {
|
|
3286
|
+
if (times.length) {
|
|
3287
|
+
const totalTime = times.reduce((a, b) => a + b);
|
|
3288
|
+
const avgFrameTime = lessPrecise(totalTime / _Debug.FRAME_COUNT);
|
|
3289
|
+
console.info(
|
|
3290
|
+
name,
|
|
3291
|
+
`- ${times.length} calls - ${avgFrameTime}ms/frame across ${_Debug.FRAME_COUNT} frames (${lessPrecise(
|
|
3292
|
+
avgFrameTime / 16.67 * 100,
|
|
3293
|
+
1
|
|
3294
|
+
)}% of frame budget)`
|
|
3295
|
+
);
|
|
3296
|
+
_Debug.TIMES_AVG[name] = {
|
|
3297
|
+
t,
|
|
3298
|
+
times: [],
|
|
3299
|
+
avg: avg != null ? getAvgFrameTime([avg, avgFrameTime]) : avgFrameTime
|
|
3300
|
+
};
|
|
3301
|
+
}
|
|
3302
|
+
}
|
|
3303
|
+
}
|
|
3304
|
+
_Debug.FRAME_COUNT = 0;
|
|
3305
|
+
if (Date.now() - _Debug.LAST_DEBUG_LOG_CALL > 600 && _Debug.DEBUG_LOG_INTERVAL_ID !== null) {
|
|
3306
|
+
console.info("%c(stopping perf recording)", "color: red");
|
|
3307
|
+
window.clearInterval(_Debug.DEBUG_LOG_INTERVAL_ID);
|
|
3308
|
+
window.cancelAnimationFrame(_Debug.ANIMATION_FRAME_ID);
|
|
3309
|
+
_Debug.ANIMATION_FRAME_ID = null;
|
|
3310
|
+
_Debug.FRAME_COUNT = 0;
|
|
3311
|
+
_Debug.LAST_FRAME_TIMESTAMP = 0;
|
|
3312
|
+
_Debug.DEBUG_LOG_INTERVAL_ID = null;
|
|
3313
|
+
_Debug.TIMES_AGGR = {};
|
|
3314
|
+
_Debug.TIMES_AVG = {};
|
|
3315
|
+
}
|
|
3316
|
+
};
|
|
3317
|
+
static logTime = (time, name = "default") => {
|
|
3318
|
+
_Debug.setupInterval();
|
|
3319
|
+
const now = performance.now();
|
|
3320
|
+
const { t, times } = _Debug.TIMES_AGGR[name] = _Debug.TIMES_AGGR[name] || {
|
|
3321
|
+
t: 0,
|
|
3322
|
+
times: []
|
|
3323
|
+
};
|
|
3324
|
+
if (t) {
|
|
3325
|
+
times.push(time != null ? time : now - t);
|
|
3326
|
+
}
|
|
3327
|
+
_Debug.TIMES_AGGR[name].t = now;
|
|
3328
|
+
};
|
|
3329
|
+
static logTimeAverage = (time, name = "default") => {
|
|
3330
|
+
_Debug.setupInterval();
|
|
3331
|
+
const now = performance.now();
|
|
3332
|
+
const { t, times } = _Debug.TIMES_AVG[name] = _Debug.TIMES_AVG[name] || {
|
|
3333
|
+
t: 0,
|
|
3334
|
+
times: []
|
|
3335
|
+
};
|
|
3336
|
+
if (t) {
|
|
3337
|
+
times.push(time != null ? time : now - t);
|
|
3338
|
+
}
|
|
3339
|
+
_Debug.TIMES_AVG[name].t = now;
|
|
3340
|
+
};
|
|
3341
|
+
static logWrapper = (type) => (fn, name = "default") => {
|
|
3342
|
+
return (...args) => {
|
|
3343
|
+
const t0 = performance.now();
|
|
3344
|
+
const ret = fn(...args);
|
|
3345
|
+
_Debug[type](performance.now() - t0, name);
|
|
3346
|
+
return ret;
|
|
3347
|
+
};
|
|
3348
|
+
};
|
|
3349
|
+
static logTimeWrap = _Debug.logWrapper("logTime");
|
|
3350
|
+
static logTimeAverageWrap = _Debug.logWrapper("logTimeAverage");
|
|
3351
|
+
static perfWrap = (fn, name = "default") => {
|
|
3352
|
+
return (...args) => {
|
|
3353
|
+
console.time(name);
|
|
3354
|
+
const ret = fn(...args);
|
|
3355
|
+
console.timeEnd(name);
|
|
3356
|
+
return ret;
|
|
3357
|
+
};
|
|
3358
|
+
};
|
|
3359
|
+
static CHANGED_CACHE = {};
|
|
3360
|
+
static logChanged(name, obj) {
|
|
3361
|
+
const prev = _Debug.CHANGED_CACHE[name];
|
|
3362
|
+
_Debug.CHANGED_CACHE[name] = obj;
|
|
3363
|
+
if (!prev) {
|
|
3364
|
+
return;
|
|
3365
|
+
}
|
|
3366
|
+
const allKeys = /* @__PURE__ */ new Set([...Object.keys(prev), ...Object.keys(obj)]);
|
|
3367
|
+
const changed = {};
|
|
3368
|
+
for (const key of allKeys) {
|
|
3369
|
+
const prevVal = prev[key];
|
|
3370
|
+
const nextVal = obj[key];
|
|
3371
|
+
if (!deepEqual(prevVal, nextVal)) {
|
|
3372
|
+
changed[key] = { prev: prevVal, next: nextVal };
|
|
3373
|
+
}
|
|
3374
|
+
}
|
|
3375
|
+
if (Object.keys(changed).length > 0) {
|
|
3376
|
+
console.info(`[${name}] changed:`, changed);
|
|
3377
|
+
}
|
|
3378
|
+
}
|
|
3379
|
+
};
|
|
3380
|
+
function deepEqual(a, b) {
|
|
3381
|
+
if (Object.is(a, b)) {
|
|
3382
|
+
return true;
|
|
3383
|
+
}
|
|
3384
|
+
if (a === null || b === null || typeof a !== "object" || typeof b !== "object") {
|
|
3385
|
+
return false;
|
|
3386
|
+
}
|
|
3387
|
+
if (Array.isArray(a) !== Array.isArray(b)) {
|
|
3388
|
+
return false;
|
|
3389
|
+
}
|
|
3390
|
+
const keysA = Object.keys(a);
|
|
3391
|
+
const keysB = Object.keys(b);
|
|
3392
|
+
if (keysA.length !== keysB.length) {
|
|
3393
|
+
return false;
|
|
3394
|
+
}
|
|
3395
|
+
for (const key of keysA) {
|
|
3396
|
+
if (!deepEqual(
|
|
3397
|
+
a[key],
|
|
3398
|
+
b[key]
|
|
3399
|
+
)) {
|
|
3400
|
+
return false;
|
|
3401
|
+
}
|
|
3402
|
+
}
|
|
3403
|
+
return true;
|
|
3404
|
+
}
|
|
2142
3405
|
export {
|
|
2143
3406
|
ACTIVE_THRESHOLD,
|
|
2144
3407
|
ALLOWED_PASTE_MIME_TYPES,
|
|
@@ -2146,10 +3409,10 @@ export {
|
|
|
2146
3409
|
ARROW_LABEL_FONT_SIZE_TO_MIN_WIDTH_RATIO,
|
|
2147
3410
|
ARROW_LABEL_WIDTH_FRACTION,
|
|
2148
3411
|
ARROW_TYPE,
|
|
3412
|
+
BIND_MODE_TIMEOUT,
|
|
2149
3413
|
BOUND_TEXT_PADDING,
|
|
2150
3414
|
BinaryHeap,
|
|
2151
3415
|
CANVAS_ONLY_ACTIONS,
|
|
2152
|
-
CANVAS_PALETTE_SHADE_INDEXES,
|
|
2153
3416
|
CANVAS_SEARCH_TAB,
|
|
2154
3417
|
CJK_HAND_DRAWN_FALLBACK_FONT,
|
|
2155
3418
|
CLASSES,
|
|
@@ -2161,6 +3424,7 @@ export {
|
|
|
2161
3424
|
COLOR_VOICE_CALL,
|
|
2162
3425
|
COLOR_WHITE,
|
|
2163
3426
|
CURSOR_TYPE,
|
|
3427
|
+
DARK_THEME_FILTER,
|
|
2164
3428
|
DEFAULT_ADAPTIVE_RADIUS,
|
|
2165
3429
|
DEFAULT_CANVAS_BACKGROUND_PICKS,
|
|
2166
3430
|
DEFAULT_CHART_COLOR_INDEX,
|
|
@@ -2188,9 +3452,10 @@ export {
|
|
|
2188
3452
|
DEFAULT_UI_OPTIONS,
|
|
2189
3453
|
DEFAULT_VERSION,
|
|
2190
3454
|
DEFAULT_VERTICAL_ALIGN,
|
|
3455
|
+
DOUBLE_TAP_POSITION_THRESHOLD,
|
|
2191
3456
|
DRAGGING_THRESHOLD,
|
|
3457
|
+
Debug,
|
|
2192
3458
|
EDITOR_LS_KEYS,
|
|
2193
|
-
ELEMENTS_PALETTE_SHADE_INDEXES,
|
|
2194
3459
|
ELEMENT_LINK_KEY,
|
|
2195
3460
|
ELEMENT_READY_TO_ERASE_OPACITY,
|
|
2196
3461
|
ELEMENT_SHIFT_TRANSLATE_AMOUNT,
|
|
@@ -2207,6 +3472,7 @@ export {
|
|
|
2207
3472
|
FONT_FAMILY_FALLBACKS,
|
|
2208
3473
|
FONT_FAMILY_GENERIC_FALLBACKS,
|
|
2209
3474
|
FONT_METADATA,
|
|
3475
|
+
FONT_SIZES,
|
|
2210
3476
|
FRAME_STYLE,
|
|
2211
3477
|
GOOGLE_FONTS_RANGES,
|
|
2212
3478
|
HYPERLINK_TOOLTIP_DELAY,
|
|
@@ -2225,13 +3491,18 @@ export {
|
|
|
2225
3491
|
MAX_DECIMALS_FOR_SVG_EXPORT,
|
|
2226
3492
|
MAX_ZOOM,
|
|
2227
3493
|
MIME_TYPES,
|
|
3494
|
+
MINIMUM_ARROW_SIZE,
|
|
2228
3495
|
MIN_FONT_SIZE,
|
|
2229
3496
|
MIN_WIDTH_OR_HEIGHT,
|
|
2230
3497
|
MIN_ZOOM,
|
|
3498
|
+
MOBILE_ACTION_BUTTON_BG,
|
|
2231
3499
|
MONOSPACE_GENERIC_FONT,
|
|
2232
3500
|
MQ_MAX_HEIGHT_LANDSCAPE,
|
|
3501
|
+
MQ_MAX_MOBILE,
|
|
3502
|
+
MQ_MAX_TABLET,
|
|
2233
3503
|
MQ_MAX_WIDTH_LANDSCAPE,
|
|
2234
|
-
|
|
3504
|
+
MQ_MIN_TABLET,
|
|
3505
|
+
MQ_MIN_WIDTH_DESKTOP,
|
|
2235
3506
|
MQ_RIGHT_SIDEBAR_MIN_WIDTH,
|
|
2236
3507
|
ORIG_ID,
|
|
2237
3508
|
POINTER_BUTTON,
|
|
@@ -2245,6 +3516,7 @@ export {
|
|
|
2245
3516
|
SHIFT_LOCKING_ANGLE,
|
|
2246
3517
|
SIDE_RESIZING_THRESHOLD,
|
|
2247
3518
|
STATS_PANELS,
|
|
3519
|
+
STRING_MIME_TYPES,
|
|
2248
3520
|
STROKE_WIDTH,
|
|
2249
3521
|
SVG_DOCUMENT_PREAMBLE,
|
|
2250
3522
|
SVG_NS,
|
|
@@ -2253,7 +3525,6 @@ export {
|
|
|
2253
3525
|
TEXT_AUTOWRAP_THRESHOLD,
|
|
2254
3526
|
TEXT_TO_CENTER_SNAP_THRESHOLD,
|
|
2255
3527
|
THEME,
|
|
2256
|
-
THEME_FILTER,
|
|
2257
3528
|
TITLE_TIMEOUT,
|
|
2258
3529
|
TOOL_TYPE,
|
|
2259
3530
|
TOUCH_CTX_MENU_TIMEOUT,
|
|
@@ -2268,6 +3539,7 @@ export {
|
|
|
2268
3539
|
ZOOM_STEP,
|
|
2269
3540
|
addEventListener,
|
|
2270
3541
|
allowFullScreen,
|
|
3542
|
+
applyDarkModeFilter,
|
|
2271
3543
|
arrayToList,
|
|
2272
3544
|
arrayToMap,
|
|
2273
3545
|
arrayToMapWithIndex,
|
|
@@ -2278,8 +3550,11 @@ export {
|
|
|
2278
3550
|
castArray,
|
|
2279
3551
|
chunk,
|
|
2280
3552
|
cloneJSON,
|
|
3553
|
+
colorToHex,
|
|
2281
3554
|
composeEventHandlers,
|
|
3555
|
+
createUserAgentDescriptor,
|
|
2282
3556
|
debounce,
|
|
3557
|
+
deriveStylesPanelMode,
|
|
2283
3558
|
distance,
|
|
2284
3559
|
easeOut,
|
|
2285
3560
|
easeToValuesRAF,
|
|
@@ -2291,18 +3566,18 @@ export {
|
|
|
2291
3566
|
getAllColorsSpecificShade,
|
|
2292
3567
|
getDateTime,
|
|
2293
3568
|
getExportSource,
|
|
3569
|
+
getFeatureFlag,
|
|
2294
3570
|
getFontFamilyFallbacks,
|
|
2295
3571
|
getFontFamilyString,
|
|
2296
3572
|
getFontString,
|
|
3573
|
+
getFormFactor,
|
|
2297
3574
|
getFrame,
|
|
2298
3575
|
getGenericFontFamilyFallback,
|
|
2299
3576
|
getGlobalCSSVariable,
|
|
2300
3577
|
getGridPoint,
|
|
2301
3578
|
getLineHeight,
|
|
2302
3579
|
getNearestScrollableContainer,
|
|
2303
|
-
getShortcutKey,
|
|
2304
3580
|
getSizeFromPoints,
|
|
2305
|
-
getSpecificColorShades,
|
|
2306
3581
|
getSvgPathFromStroke,
|
|
2307
3582
|
getUpdatedTimestamp,
|
|
2308
3583
|
getVersion,
|
|
@@ -2311,9 +3586,10 @@ export {
|
|
|
2311
3586
|
isAndroid,
|
|
2312
3587
|
isAnyTrue,
|
|
2313
3588
|
isArrowKey,
|
|
2314
|
-
|
|
3589
|
+
isBounds,
|
|
2315
3590
|
isBrave,
|
|
2316
3591
|
isChrome,
|
|
3592
|
+
isColorDark,
|
|
2317
3593
|
isDarwin,
|
|
2318
3594
|
isDevEnv,
|
|
2319
3595
|
isFirefox,
|
|
@@ -2324,6 +3600,7 @@ export {
|
|
|
2324
3600
|
isLatinChar,
|
|
2325
3601
|
isLocalLink,
|
|
2326
3602
|
isMemberOf,
|
|
3603
|
+
isMobileBreakpoint,
|
|
2327
3604
|
isPrimitive,
|
|
2328
3605
|
isProdEnv,
|
|
2329
3606
|
isPromiseLike,
|
|
@@ -2331,20 +3608,26 @@ export {
|
|
|
2331
3608
|
isReadonlyArray,
|
|
2332
3609
|
isRunningInIframe,
|
|
2333
3610
|
isSafari,
|
|
3611
|
+
isSelectionLikeTool,
|
|
2334
3612
|
isServerEnv,
|
|
2335
3613
|
isShallowEqual,
|
|
3614
|
+
isTabletBreakpoint,
|
|
2336
3615
|
isTestEnv,
|
|
2337
3616
|
isToolIcon,
|
|
2338
3617
|
isTransparent,
|
|
2339
3618
|
isWindows,
|
|
2340
3619
|
isWritableElement,
|
|
3620
|
+
loadDesktopUIModePreference,
|
|
2341
3621
|
mapFind,
|
|
2342
3622
|
matchKey,
|
|
2343
3623
|
memoize,
|
|
2344
3624
|
muteFSAbortError,
|
|
2345
3625
|
nFormatter,
|
|
3626
|
+
nextAnimationFrame,
|
|
2346
3627
|
normalizeEOL,
|
|
3628
|
+
normalizeInputColor,
|
|
2347
3629
|
normalizeLink,
|
|
3630
|
+
oneOf,
|
|
2348
3631
|
preventUnload,
|
|
2349
3632
|
promiseTry,
|
|
2350
3633
|
queryFocusableElements,
|
|
@@ -2355,11 +3638,13 @@ export {
|
|
|
2355
3638
|
rescalePoints,
|
|
2356
3639
|
reseed,
|
|
2357
3640
|
resolvablePromise,
|
|
2358
|
-
rgbToHex,
|
|
3641
|
+
rgbToHex2 as rgbToHex,
|
|
2359
3642
|
safelyParseJSON,
|
|
2360
3643
|
sceneCoordsToViewportCoords,
|
|
2361
3644
|
selectNode,
|
|
2362
3645
|
setDateTimeForTests,
|
|
3646
|
+
setDesktopUIMode,
|
|
3647
|
+
setFeatureFlag,
|
|
2363
3648
|
shouldMaintainAspectRatio,
|
|
2364
3649
|
shouldResizeFromCenter,
|
|
2365
3650
|
shouldRotateWithDiscreteAngle,
|