@excalidraw/common 0.18.0-b9d27d3 → 0.18.0-c158187

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.
Files changed (202) hide show
  1. package/dist/dev/index.js +1390 -59
  2. package/dist/dev/index.js.map +4 -4
  3. package/dist/prod/index.js +3 -3
  4. package/dist/types/common/src/bounds.d.ts +10 -0
  5. package/dist/types/common/src/colors.d.ts +5 -2
  6. package/dist/types/common/src/constants.d.ts +23 -25
  7. package/dist/types/common/src/editorInterface.d.ts +34 -0
  8. package/dist/types/common/src/font-metadata.d.ts +1 -3
  9. package/dist/types/common/src/index.d.ts +3 -0
  10. package/dist/types/common/src/keys.d.ts +1 -1
  11. package/dist/types/common/src/utility-types.d.ts +0 -1
  12. package/dist/types/common/src/utils.d.ts +50 -34
  13. package/dist/types/common/src/visualdebug.d.ts +41 -0
  14. package/dist/types/element/src/Scene.d.ts +4 -4
  15. package/dist/types/element/src/binding.d.ts +58 -44
  16. package/dist/types/element/src/bounds.d.ts +2 -10
  17. package/dist/types/element/src/collision.d.ts +6 -2
  18. package/dist/types/element/src/comparisons.d.ts +7 -7
  19. package/dist/types/element/src/dragElements.d.ts +3 -3
  20. package/dist/types/element/src/duplicate.d.ts +3 -3
  21. package/dist/types/element/src/fractionalIndex.d.ts +2 -2
  22. package/dist/types/element/src/frame.d.ts +7 -3
  23. package/dist/types/element/src/heading.d.ts +2 -1
  24. package/dist/types/element/src/image.d.ts +1 -11
  25. package/dist/types/element/src/index.d.ts +1 -3
  26. package/dist/types/element/src/linearElementEditor.d.ts +16 -20
  27. package/dist/types/element/src/mutateElement.d.ts +3 -1
  28. package/dist/types/element/src/newElement.d.ts +6 -6
  29. package/dist/types/element/src/renderElement.d.ts +4 -7
  30. package/dist/types/element/src/resizeElements.d.ts +10 -10
  31. package/dist/types/element/src/resizeTest.d.ts +6 -5
  32. package/dist/types/element/src/selection.d.ts +3 -7
  33. package/dist/types/element/src/shape.d.ts +8 -7
  34. package/dist/types/element/src/textMeasurements.d.ts +1 -3
  35. package/dist/types/{excalidraw/data → element/src}/transform.d.ts +3 -3
  36. package/dist/types/element/src/transformHandles.d.ts +8 -27
  37. package/dist/types/element/src/typeChecks.d.ts +4 -7
  38. package/dist/types/element/src/types.d.ts +7 -11
  39. package/dist/types/element/src/utils.d.ts +5 -2
  40. package/dist/types/element/src/zindex.d.ts +7 -1
  41. package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +138 -181
  42. package/dist/types/excalidraw/actions/actionAlign.d.ts +6 -7
  43. package/dist/types/excalidraw/actions/actionBoundText.d.ts +67 -96
  44. package/dist/types/excalidraw/actions/actionCanvas.d.ts +401 -771
  45. package/dist/types/excalidraw/actions/actionClipboard.d.ts +103 -873
  46. package/dist/types/excalidraw/actions/actionCropEditor.d.ts +32 -47
  47. package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +110 -159
  48. package/dist/types/excalidraw/actions/actionDistribute.d.ts +2 -3
  49. package/dist/types/excalidraw/actions/actionDuplicateSelection.d.ts +3 -4
  50. package/dist/types/excalidraw/actions/actionElementLink.d.ts +47 -64
  51. package/dist/types/excalidraw/actions/actionElementLock.d.ts +66 -95
  52. package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +49 -64
  53. package/dist/types/excalidraw/actions/actionExport.d.ts +144 -1104
  54. package/dist/types/excalidraw/actions/actionFinalize.d.ts +10 -394
  55. package/dist/types/excalidraw/actions/actionFlip.d.ts +2 -3
  56. package/dist/types/excalidraw/actions/actionFrame.d.ts +252 -347
  57. package/dist/types/excalidraw/actions/actionGroup.d.ts +70 -107
  58. package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +165 -220
  59. package/dist/types/excalidraw/actions/actionLink.d.ts +49 -64
  60. package/dist/types/excalidraw/actions/actionMenu.d.ts +42 -425
  61. package/dist/types/excalidraw/actions/actionNavigate.d.ts +18 -359
  62. package/dist/types/excalidraw/actions/actionProperties.d.ts +129 -2488
  63. package/dist/types/excalidraw/actions/actionSelectAll.d.ts +35 -54
  64. package/dist/types/excalidraw/actions/actionStyles.d.ts +32 -47
  65. package/dist/types/excalidraw/actions/actionTextAutoResize.d.ts +3 -3
  66. package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +49 -64
  67. package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +49 -64
  68. package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +41 -58
  69. package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +1 -1
  70. package/dist/types/excalidraw/actions/actionToggleStats.d.ts +48 -63
  71. package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +49 -64
  72. package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +49 -64
  73. package/dist/types/excalidraw/actions/actionZindex.d.ts +8 -9
  74. package/dist/types/excalidraw/actions/index.d.ts +2 -2
  75. package/dist/types/excalidraw/actions/register.d.ts +2 -2
  76. package/dist/types/excalidraw/actions/types.d.ts +4 -4
  77. package/dist/types/excalidraw/appState.d.ts +20 -15
  78. package/dist/types/excalidraw/clipboard.d.ts +7 -29
  79. package/dist/types/excalidraw/components/Actions.d.ts +22 -5
  80. package/dist/types/excalidraw/components/App.d.ts +58 -59
  81. package/dist/types/excalidraw/components/Card.d.ts +0 -1
  82. package/dist/types/excalidraw/components/ColorPicker/ColorInput.d.ts +7 -4
  83. package/dist/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +0 -1
  84. package/dist/types/excalidraw/components/ColorPicker/Picker.d.ts +2 -0
  85. package/dist/types/excalidraw/components/ColorPicker/PickerColorList.d.ts +2 -1
  86. package/dist/types/excalidraw/components/ColorPicker/ShadeList.d.ts +2 -1
  87. package/dist/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +0 -1
  88. package/dist/types/excalidraw/components/CommandPalette/CommandPalette.d.ts +1 -0
  89. package/dist/types/excalidraw/components/CommandPalette/types.d.ts +1 -3
  90. package/dist/types/excalidraw/components/ConvertElementTypePopup.d.ts +2 -2
  91. package/dist/types/excalidraw/components/DarkModeToggle.d.ts +1 -1
  92. package/dist/types/excalidraw/components/DefaultSidebar.d.ts +9 -13
  93. package/dist/types/excalidraw/components/ElementLinkDialog.d.ts +1 -1
  94. package/dist/types/excalidraw/components/Ellipsify.d.ts +1 -2
  95. package/dist/types/excalidraw/components/ErrorDialog.d.ts +1 -1
  96. package/dist/types/excalidraw/components/ExcalidrawLogo.d.ts +1 -2
  97. package/dist/types/excalidraw/components/EyeDropper.d.ts +0 -1
  98. package/dist/types/excalidraw/components/FilledButton.d.ts +1 -1
  99. package/dist/types/excalidraw/components/FontPicker/FontPicker.d.ts +2 -1
  100. package/dist/types/excalidraw/components/FontPicker/FontPickerTrigger.d.ts +3 -1
  101. package/dist/types/excalidraw/components/FontPicker/keyboardNavHandlers.d.ts +0 -1
  102. package/dist/types/excalidraw/components/HelpDialog.d.ts +1 -1
  103. package/dist/types/excalidraw/components/HintViewer.d.ts +4 -3
  104. package/dist/types/excalidraw/components/InlineIcon.d.ts +3 -1
  105. package/dist/types/excalidraw/components/LayerUI.d.ts +2 -1
  106. package/dist/types/excalidraw/components/LibraryMenuControlButtons.d.ts +1 -1
  107. package/dist/types/excalidraw/components/LibraryMenuHeaderContent.d.ts +1 -2
  108. package/dist/types/excalidraw/components/LibraryMenuSection.d.ts +1 -1
  109. package/dist/types/excalidraw/components/LibraryUnit.d.ts +2 -3
  110. package/dist/types/excalidraw/components/LoadingMessage.d.ts +0 -1
  111. package/dist/types/excalidraw/components/MobileMenu.d.ts +3 -5
  112. package/dist/types/excalidraw/components/MobileToolBar.d.ts +10 -0
  113. package/dist/types/excalidraw/components/Modal.d.ts +0 -1
  114. package/dist/types/excalidraw/components/OverwriteConfirm/OverwriteConfirm.d.ts +1 -1
  115. package/dist/types/excalidraw/components/Popover.d.ts +2 -1
  116. package/dist/types/excalidraw/components/PropertiesPopover.d.ts +1 -0
  117. package/dist/types/excalidraw/components/RadioGroup.d.ts +0 -1
  118. package/dist/types/excalidraw/components/RadioSelection.d.ts +4 -4
  119. package/dist/types/excalidraw/components/ScrollableList.d.ts +0 -1
  120. package/dist/types/excalidraw/components/Sidebar/Sidebar.d.ts +15 -21
  121. package/dist/types/excalidraw/components/Sidebar/SidebarHeader.d.ts +1 -1
  122. package/dist/types/excalidraw/components/Sidebar/SidebarTab.d.ts +1 -2
  123. package/dist/types/excalidraw/components/Sidebar/SidebarTabTrigger.d.ts +1 -2
  124. package/dist/types/excalidraw/components/Sidebar/SidebarTabTriggers.d.ts +1 -2
  125. package/dist/types/excalidraw/components/Sidebar/SidebarTabs.d.ts +1 -2
  126. package/dist/types/excalidraw/components/Spinner.d.ts +4 -4
  127. package/dist/types/excalidraw/components/Stats/CanvasGrid.d.ts +0 -1
  128. package/dist/types/excalidraw/components/Stats/Collapsible.d.ts +0 -1
  129. package/dist/types/excalidraw/components/Stats/DragInput.d.ts +0 -1
  130. package/dist/types/excalidraw/components/Stats/index.d.ts +7 -8
  131. package/dist/types/excalidraw/components/Stats/utils.d.ts +1 -1
  132. package/dist/types/excalidraw/components/TTDDialog/TTDDialog.d.ts +1 -2
  133. package/dist/types/excalidraw/components/TTDDialog/TTDDialogOutput.d.ts +0 -1
  134. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTab.d.ts +1 -2
  135. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTrigger.d.ts +1 -2
  136. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTriggers.d.ts +1 -2
  137. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +2 -3
  138. package/dist/types/excalidraw/components/TTDDialog/common.d.ts +2 -3
  139. package/dist/types/excalidraw/components/TextField.d.ts +1 -0
  140. package/dist/types/excalidraw/components/Toast.d.ts +3 -3
  141. package/dist/types/excalidraw/components/ToolPopover.d.ts +25 -0
  142. package/dist/types/excalidraw/components/Trans.d.ts +2 -2
  143. package/dist/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +6 -3
  144. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +30 -32
  145. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +6 -5
  146. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuGroup.d.ts +3 -3
  147. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItem.d.ts +10 -18
  148. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContent.d.ts +3 -3
  149. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContentRadio.d.ts +0 -1
  150. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCustom.d.ts +2 -2
  151. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemLink.d.ts +6 -6
  152. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuTrigger.d.ts +3 -4
  153. package/dist/types/excalidraw/components/dropdownMenu/common.d.ts +1 -1
  154. package/dist/types/excalidraw/components/hoc/withInternalFallback.d.ts +1 -1
  155. package/dist/types/excalidraw/components/hyperlink/helpers.d.ts +1 -1
  156. package/dist/types/excalidraw/components/icons.d.ts +21 -11
  157. package/dist/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +4 -3
  158. package/dist/types/excalidraw/components/main-menu/DefaultItems.d.ts +2 -2
  159. package/dist/types/excalidraw/components/main-menu/MainMenu.d.ts +25 -30
  160. package/dist/types/excalidraw/components/shapes.d.ts +1 -1
  161. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.Center.d.ts +6 -6
  162. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.d.ts +15 -16
  163. package/dist/types/excalidraw/data/blob.d.ts +323 -5
  164. package/dist/types/excalidraw/data/encode.d.ts +4 -4
  165. package/dist/types/excalidraw/data/encryption.d.ts +5 -5
  166. package/dist/types/excalidraw/data/filesystem.d.ts +2 -2
  167. package/dist/types/excalidraw/data/index.d.ts +3 -3
  168. package/dist/types/excalidraw/data/json.d.ts +159 -2
  169. package/dist/types/excalidraw/data/library.d.ts +24 -9
  170. package/dist/types/excalidraw/data/restore.d.ts +25 -10
  171. package/dist/types/excalidraw/data/types.d.ts +4 -1
  172. package/dist/types/excalidraw/editor-jotai.d.ts +11 -11
  173. package/dist/types/excalidraw/hooks/useLibraryItemSvg.d.ts +1 -1
  174. package/dist/types/excalidraw/hooks/useOutsideClick.d.ts +4 -3
  175. package/dist/types/excalidraw/hooks/useScrollPosition.d.ts +1 -2
  176. package/dist/types/excalidraw/hooks/useTextEditorFocus.d.ts +14 -0
  177. package/dist/types/excalidraw/i18n.d.ts +2 -2
  178. package/dist/types/excalidraw/index.d.ts +4 -7
  179. package/dist/types/excalidraw/renderer/animation.d.ts +12 -0
  180. package/dist/types/excalidraw/renderer/helpers.d.ts +6 -8
  181. package/dist/types/excalidraw/renderer/interactiveScene.d.ts +8 -14
  182. package/dist/types/excalidraw/scene/Renderer.d.ts +5 -2
  183. package/dist/types/excalidraw/scene/export.d.ts +2 -2
  184. package/dist/types/excalidraw/scene/scroll.d.ts +1 -6
  185. package/dist/types/excalidraw/scene/types.d.ts +22 -5
  186. package/dist/types/excalidraw/shortcut.d.ts +1 -0
  187. package/dist/types/excalidraw/snapping.d.ts +5 -5
  188. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-bindings.d.ts +1 -1
  189. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-loader.d.ts +1 -1
  190. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-wasm.d.ts +1 -1
  191. package/dist/types/excalidraw/subset/woff2/woff2-loader.d.ts +2 -2
  192. package/dist/types/excalidraw/subset/woff2/woff2-wasm.d.ts +1 -1
  193. package/dist/types/excalidraw/types.d.ts +31 -21
  194. package/dist/types/excalidraw/wysiwyg/textWysiwyg.d.ts +2 -2
  195. package/dist/types/math/src/polygon.d.ts +2 -2
  196. package/dist/types/math/src/range.d.ts +1 -3
  197. package/dist/types/math/src/segment.d.ts +4 -3
  198. package/dist/types/utils/src/bbox.d.ts +1 -1
  199. package/dist/types/utils/src/export.d.ts +5 -5
  200. package/dist/types/utils/src/shape.d.ts +6 -6
  201. package/dist/types/utils/src/withinBounds.d.ts +2 -2
  202. 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 (this.scoreFunction(node) < this.scoreFunction(parent)) {
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 child2N = idx + 1 << 1;
302
- const child1N = child2N - 1;
303
- let swap = null;
304
- let child1Score = 0;
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 child1 = this.content[child1N];
307
- child1Score = this.scoreFunction(child1);
308
- if (child1Score < score) {
309
- swap = child1N;
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 child2 = this.content[child2N];
314
- const child2Score = this.scoreFunction(child2);
315
- if (child2Score < (swap === null ? score : child1Score)) {
316
- swap = child2N;
314
+ const child2Score = this.scoreFunction(this.content[child2N]);
315
+ if (child2Score < smallestScore) {
316
+ smallestIdx = child2N;
317
317
  }
318
318
  }
319
- if (swap !== null) {
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,6 +363,10 @@ 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
 
@@ -529,7 +532,1051 @@ var open_color_default = {
529
532
  ]
530
533
  };
531
534
 
535
+ // ../../node_modules/tinycolor2/esm/tinycolor.js
536
+ init_define_import_meta_env();
537
+ function _typeof(obj) {
538
+ "@babel/helpers - typeof";
539
+ return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(obj2) {
540
+ return typeof obj2;
541
+ } : function(obj2) {
542
+ return obj2 && "function" == typeof Symbol && obj2.constructor === Symbol && obj2 !== Symbol.prototype ? "symbol" : typeof obj2;
543
+ }, _typeof(obj);
544
+ }
545
+ var trimLeft = /^\s+/;
546
+ var trimRight = /\s+$/;
547
+ function tinycolor(color, opts) {
548
+ color = color ? color : "";
549
+ opts = opts || {};
550
+ if (color instanceof tinycolor) {
551
+ return color;
552
+ }
553
+ if (!(this instanceof tinycolor)) {
554
+ return new tinycolor(color, opts);
555
+ }
556
+ var rgb = inputToRGB(color);
557
+ 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;
558
+ this._gradientType = opts.gradientType;
559
+ if (this._r < 1)
560
+ this._r = Math.round(this._r);
561
+ if (this._g < 1)
562
+ this._g = Math.round(this._g);
563
+ if (this._b < 1)
564
+ this._b = Math.round(this._b);
565
+ this._ok = rgb.ok;
566
+ }
567
+ tinycolor.prototype = {
568
+ isDark: function isDark() {
569
+ return this.getBrightness() < 128;
570
+ },
571
+ isLight: function isLight() {
572
+ return !this.isDark();
573
+ },
574
+ isValid: function isValid() {
575
+ return this._ok;
576
+ },
577
+ getOriginalInput: function getOriginalInput() {
578
+ return this._originalInput;
579
+ },
580
+ getFormat: function getFormat() {
581
+ return this._format;
582
+ },
583
+ getAlpha: function getAlpha() {
584
+ return this._a;
585
+ },
586
+ getBrightness: function getBrightness() {
587
+ var rgb = this.toRgb();
588
+ return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1e3;
589
+ },
590
+ getLuminance: function getLuminance() {
591
+ var rgb = this.toRgb();
592
+ var RsRGB, GsRGB, BsRGB, R, G, B;
593
+ RsRGB = rgb.r / 255;
594
+ GsRGB = rgb.g / 255;
595
+ BsRGB = rgb.b / 255;
596
+ if (RsRGB <= 0.03928)
597
+ R = RsRGB / 12.92;
598
+ else
599
+ R = Math.pow((RsRGB + 0.055) / 1.055, 2.4);
600
+ if (GsRGB <= 0.03928)
601
+ G = GsRGB / 12.92;
602
+ else
603
+ G = Math.pow((GsRGB + 0.055) / 1.055, 2.4);
604
+ if (BsRGB <= 0.03928)
605
+ B = BsRGB / 12.92;
606
+ else
607
+ B = Math.pow((BsRGB + 0.055) / 1.055, 2.4);
608
+ return 0.2126 * R + 0.7152 * G + 0.0722 * B;
609
+ },
610
+ setAlpha: function setAlpha(value) {
611
+ this._a = boundAlpha(value);
612
+ this._roundA = Math.round(100 * this._a) / 100;
613
+ return this;
614
+ },
615
+ toHsv: function toHsv() {
616
+ var hsv = rgbToHsv(this._r, this._g, this._b);
617
+ return {
618
+ h: hsv.h * 360,
619
+ s: hsv.s,
620
+ v: hsv.v,
621
+ a: this._a
622
+ };
623
+ },
624
+ toHsvString: function toHsvString() {
625
+ var hsv = rgbToHsv(this._r, this._g, this._b);
626
+ var h = Math.round(hsv.h * 360), s = Math.round(hsv.s * 100), v = Math.round(hsv.v * 100);
627
+ return this._a == 1 ? "hsv(" + h + ", " + s + "%, " + v + "%)" : "hsva(" + h + ", " + s + "%, " + v + "%, " + this._roundA + ")";
628
+ },
629
+ toHsl: function toHsl() {
630
+ var hsl = rgbToHsl(this._r, this._g, this._b);
631
+ return {
632
+ h: hsl.h * 360,
633
+ s: hsl.s,
634
+ l: hsl.l,
635
+ a: this._a
636
+ };
637
+ },
638
+ toHslString: function toHslString() {
639
+ var hsl = rgbToHsl(this._r, this._g, this._b);
640
+ var h = Math.round(hsl.h * 360), s = Math.round(hsl.s * 100), l = Math.round(hsl.l * 100);
641
+ return this._a == 1 ? "hsl(" + h + ", " + s + "%, " + l + "%)" : "hsla(" + h + ", " + s + "%, " + l + "%, " + this._roundA + ")";
642
+ },
643
+ toHex: function toHex(allow3Char) {
644
+ return rgbToHex(this._r, this._g, this._b, allow3Char);
645
+ },
646
+ toHexString: function toHexString(allow3Char) {
647
+ return "#" + this.toHex(allow3Char);
648
+ },
649
+ toHex8: function toHex8(allow4Char) {
650
+ return rgbaToHex(this._r, this._g, this._b, this._a, allow4Char);
651
+ },
652
+ toHex8String: function toHex8String(allow4Char) {
653
+ return "#" + this.toHex8(allow4Char);
654
+ },
655
+ toRgb: function toRgb() {
656
+ return {
657
+ r: Math.round(this._r),
658
+ g: Math.round(this._g),
659
+ b: Math.round(this._b),
660
+ a: this._a
661
+ };
662
+ },
663
+ toRgbString: function toRgbString() {
664
+ 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 + ")";
665
+ },
666
+ toPercentageRgb: function toPercentageRgb() {
667
+ return {
668
+ r: Math.round(bound01(this._r, 255) * 100) + "%",
669
+ g: Math.round(bound01(this._g, 255) * 100) + "%",
670
+ b: Math.round(bound01(this._b, 255) * 100) + "%",
671
+ a: this._a
672
+ };
673
+ },
674
+ toPercentageRgbString: function toPercentageRgbString() {
675
+ 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 + ")";
676
+ },
677
+ toName: function toName() {
678
+ if (this._a === 0) {
679
+ return "transparent";
680
+ }
681
+ if (this._a < 1) {
682
+ return false;
683
+ }
684
+ return hexNames[rgbToHex(this._r, this._g, this._b, true)] || false;
685
+ },
686
+ toFilter: function toFilter(secondColor) {
687
+ var hex8String = "#" + rgbaToArgbHex(this._r, this._g, this._b, this._a);
688
+ var secondHex8String = hex8String;
689
+ var gradientType = this._gradientType ? "GradientType = 1, " : "";
690
+ if (secondColor) {
691
+ var s = tinycolor(secondColor);
692
+ secondHex8String = "#" + rgbaToArgbHex(s._r, s._g, s._b, s._a);
693
+ }
694
+ return "progid:DXImageTransform.Microsoft.gradient(" + gradientType + "startColorstr=" + hex8String + ",endColorstr=" + secondHex8String + ")";
695
+ },
696
+ toString: function toString(format) {
697
+ var formatSet = !!format;
698
+ format = format || this._format;
699
+ var formattedString = false;
700
+ var hasAlpha = this._a < 1 && this._a >= 0;
701
+ var needsAlphaFormat = !formatSet && hasAlpha && (format === "hex" || format === "hex6" || format === "hex3" || format === "hex4" || format === "hex8" || format === "name");
702
+ if (needsAlphaFormat) {
703
+ if (format === "name" && this._a === 0) {
704
+ return this.toName();
705
+ }
706
+ return this.toRgbString();
707
+ }
708
+ if (format === "rgb") {
709
+ formattedString = this.toRgbString();
710
+ }
711
+ if (format === "prgb") {
712
+ formattedString = this.toPercentageRgbString();
713
+ }
714
+ if (format === "hex" || format === "hex6") {
715
+ formattedString = this.toHexString();
716
+ }
717
+ if (format === "hex3") {
718
+ formattedString = this.toHexString(true);
719
+ }
720
+ if (format === "hex4") {
721
+ formattedString = this.toHex8String(true);
722
+ }
723
+ if (format === "hex8") {
724
+ formattedString = this.toHex8String();
725
+ }
726
+ if (format === "name") {
727
+ formattedString = this.toName();
728
+ }
729
+ if (format === "hsl") {
730
+ formattedString = this.toHslString();
731
+ }
732
+ if (format === "hsv") {
733
+ formattedString = this.toHsvString();
734
+ }
735
+ return formattedString || this.toHexString();
736
+ },
737
+ clone: function clone() {
738
+ return tinycolor(this.toString());
739
+ },
740
+ _applyModification: function _applyModification(fn, args) {
741
+ var color = fn.apply(null, [this].concat([].slice.call(args)));
742
+ this._r = color._r;
743
+ this._g = color._g;
744
+ this._b = color._b;
745
+ this.setAlpha(color._a);
746
+ return this;
747
+ },
748
+ lighten: function lighten() {
749
+ return this._applyModification(_lighten, arguments);
750
+ },
751
+ brighten: function brighten() {
752
+ return this._applyModification(_brighten, arguments);
753
+ },
754
+ darken: function darken() {
755
+ return this._applyModification(_darken, arguments);
756
+ },
757
+ desaturate: function desaturate() {
758
+ return this._applyModification(_desaturate, arguments);
759
+ },
760
+ saturate: function saturate() {
761
+ return this._applyModification(_saturate, arguments);
762
+ },
763
+ greyscale: function greyscale() {
764
+ return this._applyModification(_greyscale, arguments);
765
+ },
766
+ spin: function spin() {
767
+ return this._applyModification(_spin, arguments);
768
+ },
769
+ _applyCombination: function _applyCombination(fn, args) {
770
+ return fn.apply(null, [this].concat([].slice.call(args)));
771
+ },
772
+ analogous: function analogous() {
773
+ return this._applyCombination(_analogous, arguments);
774
+ },
775
+ complement: function complement() {
776
+ return this._applyCombination(_complement, arguments);
777
+ },
778
+ monochromatic: function monochromatic() {
779
+ return this._applyCombination(_monochromatic, arguments);
780
+ },
781
+ splitcomplement: function splitcomplement() {
782
+ return this._applyCombination(_splitcomplement, arguments);
783
+ },
784
+ // Disabled until https://github.com/bgrins/TinyColor/issues/254
785
+ // polyad: function (number) {
786
+ // return this._applyCombination(polyad, [number]);
787
+ // },
788
+ triad: function triad() {
789
+ return this._applyCombination(polyad, [3]);
790
+ },
791
+ tetrad: function tetrad() {
792
+ return this._applyCombination(polyad, [4]);
793
+ }
794
+ };
795
+ tinycolor.fromRatio = function(color, opts) {
796
+ if (_typeof(color) == "object") {
797
+ var newColor = {};
798
+ for (var i in color) {
799
+ if (color.hasOwnProperty(i)) {
800
+ if (i === "a") {
801
+ newColor[i] = color[i];
802
+ } else {
803
+ newColor[i] = convertToPercentage(color[i]);
804
+ }
805
+ }
806
+ }
807
+ color = newColor;
808
+ }
809
+ return tinycolor(color, opts);
810
+ };
811
+ function inputToRGB(color) {
812
+ var rgb = {
813
+ r: 0,
814
+ g: 0,
815
+ b: 0
816
+ };
817
+ var a = 1;
818
+ var s = null;
819
+ var v = null;
820
+ var l = null;
821
+ var ok = false;
822
+ var format = false;
823
+ if (typeof color == "string") {
824
+ color = stringInputToObject(color);
825
+ }
826
+ if (_typeof(color) == "object") {
827
+ if (isValidCSSUnit(color.r) && isValidCSSUnit(color.g) && isValidCSSUnit(color.b)) {
828
+ rgb = rgbToRgb(color.r, color.g, color.b);
829
+ ok = true;
830
+ format = String(color.r).substr(-1) === "%" ? "prgb" : "rgb";
831
+ } else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.v)) {
832
+ s = convertToPercentage(color.s);
833
+ v = convertToPercentage(color.v);
834
+ rgb = hsvToRgb(color.h, s, v);
835
+ ok = true;
836
+ format = "hsv";
837
+ } else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.l)) {
838
+ s = convertToPercentage(color.s);
839
+ l = convertToPercentage(color.l);
840
+ rgb = hslToRgb(color.h, s, l);
841
+ ok = true;
842
+ format = "hsl";
843
+ }
844
+ if (color.hasOwnProperty("a")) {
845
+ a = color.a;
846
+ }
847
+ }
848
+ a = boundAlpha(a);
849
+ return {
850
+ ok,
851
+ format: color.format || format,
852
+ r: Math.min(255, Math.max(rgb.r, 0)),
853
+ g: Math.min(255, Math.max(rgb.g, 0)),
854
+ b: Math.min(255, Math.max(rgb.b, 0)),
855
+ a
856
+ };
857
+ }
858
+ function rgbToRgb(r, g, b) {
859
+ return {
860
+ r: bound01(r, 255) * 255,
861
+ g: bound01(g, 255) * 255,
862
+ b: bound01(b, 255) * 255
863
+ };
864
+ }
865
+ function rgbToHsl(r, g, b) {
866
+ r = bound01(r, 255);
867
+ g = bound01(g, 255);
868
+ b = bound01(b, 255);
869
+ var max = Math.max(r, g, b), min = Math.min(r, g, b);
870
+ var h, s, l = (max + min) / 2;
871
+ if (max == min) {
872
+ h = s = 0;
873
+ } else {
874
+ var d = max - min;
875
+ s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
876
+ switch (max) {
877
+ case r:
878
+ h = (g - b) / d + (g < b ? 6 : 0);
879
+ break;
880
+ case g:
881
+ h = (b - r) / d + 2;
882
+ break;
883
+ case b:
884
+ h = (r - g) / d + 4;
885
+ break;
886
+ }
887
+ h /= 6;
888
+ }
889
+ return {
890
+ h,
891
+ s,
892
+ l
893
+ };
894
+ }
895
+ function hslToRgb(h, s, l) {
896
+ var r, g, b;
897
+ h = bound01(h, 360);
898
+ s = bound01(s, 100);
899
+ l = bound01(l, 100);
900
+ function hue2rgb(p2, q2, t) {
901
+ if (t < 0)
902
+ t += 1;
903
+ if (t > 1)
904
+ t -= 1;
905
+ if (t < 1 / 6)
906
+ return p2 + (q2 - p2) * 6 * t;
907
+ if (t < 1 / 2)
908
+ return q2;
909
+ if (t < 2 / 3)
910
+ return p2 + (q2 - p2) * (2 / 3 - t) * 6;
911
+ return p2;
912
+ }
913
+ if (s === 0) {
914
+ r = g = b = l;
915
+ } else {
916
+ var q = l < 0.5 ? l * (1 + s) : l + s - l * s;
917
+ var p = 2 * l - q;
918
+ r = hue2rgb(p, q, h + 1 / 3);
919
+ g = hue2rgb(p, q, h);
920
+ b = hue2rgb(p, q, h - 1 / 3);
921
+ }
922
+ return {
923
+ r: r * 255,
924
+ g: g * 255,
925
+ b: b * 255
926
+ };
927
+ }
928
+ function rgbToHsv(r, g, b) {
929
+ r = bound01(r, 255);
930
+ g = bound01(g, 255);
931
+ b = bound01(b, 255);
932
+ var max = Math.max(r, g, b), min = Math.min(r, g, b);
933
+ var h, s, v = max;
934
+ var d = max - min;
935
+ s = max === 0 ? 0 : d / max;
936
+ if (max == min) {
937
+ h = 0;
938
+ } else {
939
+ switch (max) {
940
+ case r:
941
+ h = (g - b) / d + (g < b ? 6 : 0);
942
+ break;
943
+ case g:
944
+ h = (b - r) / d + 2;
945
+ break;
946
+ case b:
947
+ h = (r - g) / d + 4;
948
+ break;
949
+ }
950
+ h /= 6;
951
+ }
952
+ return {
953
+ h,
954
+ s,
955
+ v
956
+ };
957
+ }
958
+ function hsvToRgb(h, s, v) {
959
+ h = bound01(h, 360) * 6;
960
+ s = bound01(s, 100);
961
+ v = bound01(v, 100);
962
+ 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];
963
+ return {
964
+ r: r * 255,
965
+ g: g * 255,
966
+ b: b * 255
967
+ };
968
+ }
969
+ function rgbToHex(r, g, b, allow3Char) {
970
+ var hex = [pad2(Math.round(r).toString(16)), pad2(Math.round(g).toString(16)), pad2(Math.round(b).toString(16))];
971
+ 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)) {
972
+ return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0);
973
+ }
974
+ return hex.join("");
975
+ }
976
+ function rgbaToHex(r, g, b, a, allow4Char) {
977
+ var hex = [pad2(Math.round(r).toString(16)), pad2(Math.round(g).toString(16)), pad2(Math.round(b).toString(16)), pad2(convertDecimalToHex(a))];
978
+ 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)) {
979
+ return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0) + hex[3].charAt(0);
980
+ }
981
+ return hex.join("");
982
+ }
983
+ function rgbaToArgbHex(r, g, b, a) {
984
+ var hex = [pad2(convertDecimalToHex(a)), pad2(Math.round(r).toString(16)), pad2(Math.round(g).toString(16)), pad2(Math.round(b).toString(16))];
985
+ return hex.join("");
986
+ }
987
+ tinycolor.equals = function(color1, color2) {
988
+ if (!color1 || !color2)
989
+ return false;
990
+ return tinycolor(color1).toRgbString() == tinycolor(color2).toRgbString();
991
+ };
992
+ tinycolor.random = function() {
993
+ return tinycolor.fromRatio({
994
+ r: Math.random(),
995
+ g: Math.random(),
996
+ b: Math.random()
997
+ });
998
+ };
999
+ function _desaturate(color, amount) {
1000
+ amount = amount === 0 ? 0 : amount || 10;
1001
+ var hsl = tinycolor(color).toHsl();
1002
+ hsl.s -= amount / 100;
1003
+ hsl.s = clamp01(hsl.s);
1004
+ return tinycolor(hsl);
1005
+ }
1006
+ function _saturate(color, amount) {
1007
+ amount = amount === 0 ? 0 : amount || 10;
1008
+ var hsl = tinycolor(color).toHsl();
1009
+ hsl.s += amount / 100;
1010
+ hsl.s = clamp01(hsl.s);
1011
+ return tinycolor(hsl);
1012
+ }
1013
+ function _greyscale(color) {
1014
+ return tinycolor(color).desaturate(100);
1015
+ }
1016
+ function _lighten(color, amount) {
1017
+ amount = amount === 0 ? 0 : amount || 10;
1018
+ var hsl = tinycolor(color).toHsl();
1019
+ hsl.l += amount / 100;
1020
+ hsl.l = clamp01(hsl.l);
1021
+ return tinycolor(hsl);
1022
+ }
1023
+ function _brighten(color, amount) {
1024
+ amount = amount === 0 ? 0 : amount || 10;
1025
+ var rgb = tinycolor(color).toRgb();
1026
+ rgb.r = Math.max(0, Math.min(255, rgb.r - Math.round(255 * -(amount / 100))));
1027
+ rgb.g = Math.max(0, Math.min(255, rgb.g - Math.round(255 * -(amount / 100))));
1028
+ rgb.b = Math.max(0, Math.min(255, rgb.b - Math.round(255 * -(amount / 100))));
1029
+ return tinycolor(rgb);
1030
+ }
1031
+ function _darken(color, amount) {
1032
+ amount = amount === 0 ? 0 : amount || 10;
1033
+ var hsl = tinycolor(color).toHsl();
1034
+ hsl.l -= amount / 100;
1035
+ hsl.l = clamp01(hsl.l);
1036
+ return tinycolor(hsl);
1037
+ }
1038
+ function _spin(color, amount) {
1039
+ var hsl = tinycolor(color).toHsl();
1040
+ var hue = (hsl.h + amount) % 360;
1041
+ hsl.h = hue < 0 ? 360 + hue : hue;
1042
+ return tinycolor(hsl);
1043
+ }
1044
+ function _complement(color) {
1045
+ var hsl = tinycolor(color).toHsl();
1046
+ hsl.h = (hsl.h + 180) % 360;
1047
+ return tinycolor(hsl);
1048
+ }
1049
+ function polyad(color, number) {
1050
+ if (isNaN(number) || number <= 0) {
1051
+ throw new Error("Argument to polyad must be a positive number");
1052
+ }
1053
+ var hsl = tinycolor(color).toHsl();
1054
+ var result = [tinycolor(color)];
1055
+ var step = 360 / number;
1056
+ for (var i = 1; i < number; i++) {
1057
+ result.push(tinycolor({
1058
+ h: (hsl.h + i * step) % 360,
1059
+ s: hsl.s,
1060
+ l: hsl.l
1061
+ }));
1062
+ }
1063
+ return result;
1064
+ }
1065
+ function _splitcomplement(color) {
1066
+ var hsl = tinycolor(color).toHsl();
1067
+ var h = hsl.h;
1068
+ return [tinycolor(color), tinycolor({
1069
+ h: (h + 72) % 360,
1070
+ s: hsl.s,
1071
+ l: hsl.l
1072
+ }), tinycolor({
1073
+ h: (h + 216) % 360,
1074
+ s: hsl.s,
1075
+ l: hsl.l
1076
+ })];
1077
+ }
1078
+ function _analogous(color, results, slices) {
1079
+ results = results || 6;
1080
+ slices = slices || 30;
1081
+ var hsl = tinycolor(color).toHsl();
1082
+ var part = 360 / slices;
1083
+ var ret = [tinycolor(color)];
1084
+ for (hsl.h = (hsl.h - (part * results >> 1) + 720) % 360; --results; ) {
1085
+ hsl.h = (hsl.h + part) % 360;
1086
+ ret.push(tinycolor(hsl));
1087
+ }
1088
+ return ret;
1089
+ }
1090
+ function _monochromatic(color, results) {
1091
+ results = results || 6;
1092
+ var hsv = tinycolor(color).toHsv();
1093
+ var h = hsv.h, s = hsv.s, v = hsv.v;
1094
+ var ret = [];
1095
+ var modification = 1 / results;
1096
+ while (results--) {
1097
+ ret.push(tinycolor({
1098
+ h,
1099
+ s,
1100
+ v
1101
+ }));
1102
+ v = (v + modification) % 1;
1103
+ }
1104
+ return ret;
1105
+ }
1106
+ tinycolor.mix = function(color1, color2, amount) {
1107
+ amount = amount === 0 ? 0 : amount || 50;
1108
+ var rgb1 = tinycolor(color1).toRgb();
1109
+ var rgb2 = tinycolor(color2).toRgb();
1110
+ var p = amount / 100;
1111
+ var rgba = {
1112
+ r: (rgb2.r - rgb1.r) * p + rgb1.r,
1113
+ g: (rgb2.g - rgb1.g) * p + rgb1.g,
1114
+ b: (rgb2.b - rgb1.b) * p + rgb1.b,
1115
+ a: (rgb2.a - rgb1.a) * p + rgb1.a
1116
+ };
1117
+ return tinycolor(rgba);
1118
+ };
1119
+ tinycolor.readability = function(color1, color2) {
1120
+ var c1 = tinycolor(color1);
1121
+ var c2 = tinycolor(color2);
1122
+ return (Math.max(c1.getLuminance(), c2.getLuminance()) + 0.05) / (Math.min(c1.getLuminance(), c2.getLuminance()) + 0.05);
1123
+ };
1124
+ tinycolor.isReadable = function(color1, color2, wcag2) {
1125
+ var readability = tinycolor.readability(color1, color2);
1126
+ var wcag2Parms, out;
1127
+ out = false;
1128
+ wcag2Parms = validateWCAG2Parms(wcag2);
1129
+ switch (wcag2Parms.level + wcag2Parms.size) {
1130
+ case "AAsmall":
1131
+ case "AAAlarge":
1132
+ out = readability >= 4.5;
1133
+ break;
1134
+ case "AAlarge":
1135
+ out = readability >= 3;
1136
+ break;
1137
+ case "AAAsmall":
1138
+ out = readability >= 7;
1139
+ break;
1140
+ }
1141
+ return out;
1142
+ };
1143
+ tinycolor.mostReadable = function(baseColor, colorList, args) {
1144
+ var bestColor = null;
1145
+ var bestScore = 0;
1146
+ var readability;
1147
+ var includeFallbackColors, level, size;
1148
+ args = args || {};
1149
+ includeFallbackColors = args.includeFallbackColors;
1150
+ level = args.level;
1151
+ size = args.size;
1152
+ for (var i = 0; i < colorList.length; i++) {
1153
+ readability = tinycolor.readability(baseColor, colorList[i]);
1154
+ if (readability > bestScore) {
1155
+ bestScore = readability;
1156
+ bestColor = tinycolor(colorList[i]);
1157
+ }
1158
+ }
1159
+ if (tinycolor.isReadable(baseColor, bestColor, {
1160
+ level,
1161
+ size
1162
+ }) || !includeFallbackColors) {
1163
+ return bestColor;
1164
+ } else {
1165
+ args.includeFallbackColors = false;
1166
+ return tinycolor.mostReadable(baseColor, ["#fff", "#000"], args);
1167
+ }
1168
+ };
1169
+ var names = tinycolor.names = {
1170
+ aliceblue: "f0f8ff",
1171
+ antiquewhite: "faebd7",
1172
+ aqua: "0ff",
1173
+ aquamarine: "7fffd4",
1174
+ azure: "f0ffff",
1175
+ beige: "f5f5dc",
1176
+ bisque: "ffe4c4",
1177
+ black: "000",
1178
+ blanchedalmond: "ffebcd",
1179
+ blue: "00f",
1180
+ blueviolet: "8a2be2",
1181
+ brown: "a52a2a",
1182
+ burlywood: "deb887",
1183
+ burntsienna: "ea7e5d",
1184
+ cadetblue: "5f9ea0",
1185
+ chartreuse: "7fff00",
1186
+ chocolate: "d2691e",
1187
+ coral: "ff7f50",
1188
+ cornflowerblue: "6495ed",
1189
+ cornsilk: "fff8dc",
1190
+ crimson: "dc143c",
1191
+ cyan: "0ff",
1192
+ darkblue: "00008b",
1193
+ darkcyan: "008b8b",
1194
+ darkgoldenrod: "b8860b",
1195
+ darkgray: "a9a9a9",
1196
+ darkgreen: "006400",
1197
+ darkgrey: "a9a9a9",
1198
+ darkkhaki: "bdb76b",
1199
+ darkmagenta: "8b008b",
1200
+ darkolivegreen: "556b2f",
1201
+ darkorange: "ff8c00",
1202
+ darkorchid: "9932cc",
1203
+ darkred: "8b0000",
1204
+ darksalmon: "e9967a",
1205
+ darkseagreen: "8fbc8f",
1206
+ darkslateblue: "483d8b",
1207
+ darkslategray: "2f4f4f",
1208
+ darkslategrey: "2f4f4f",
1209
+ darkturquoise: "00ced1",
1210
+ darkviolet: "9400d3",
1211
+ deeppink: "ff1493",
1212
+ deepskyblue: "00bfff",
1213
+ dimgray: "696969",
1214
+ dimgrey: "696969",
1215
+ dodgerblue: "1e90ff",
1216
+ firebrick: "b22222",
1217
+ floralwhite: "fffaf0",
1218
+ forestgreen: "228b22",
1219
+ fuchsia: "f0f",
1220
+ gainsboro: "dcdcdc",
1221
+ ghostwhite: "f8f8ff",
1222
+ gold: "ffd700",
1223
+ goldenrod: "daa520",
1224
+ gray: "808080",
1225
+ green: "008000",
1226
+ greenyellow: "adff2f",
1227
+ grey: "808080",
1228
+ honeydew: "f0fff0",
1229
+ hotpink: "ff69b4",
1230
+ indianred: "cd5c5c",
1231
+ indigo: "4b0082",
1232
+ ivory: "fffff0",
1233
+ khaki: "f0e68c",
1234
+ lavender: "e6e6fa",
1235
+ lavenderblush: "fff0f5",
1236
+ lawngreen: "7cfc00",
1237
+ lemonchiffon: "fffacd",
1238
+ lightblue: "add8e6",
1239
+ lightcoral: "f08080",
1240
+ lightcyan: "e0ffff",
1241
+ lightgoldenrodyellow: "fafad2",
1242
+ lightgray: "d3d3d3",
1243
+ lightgreen: "90ee90",
1244
+ lightgrey: "d3d3d3",
1245
+ lightpink: "ffb6c1",
1246
+ lightsalmon: "ffa07a",
1247
+ lightseagreen: "20b2aa",
1248
+ lightskyblue: "87cefa",
1249
+ lightslategray: "789",
1250
+ lightslategrey: "789",
1251
+ lightsteelblue: "b0c4de",
1252
+ lightyellow: "ffffe0",
1253
+ lime: "0f0",
1254
+ limegreen: "32cd32",
1255
+ linen: "faf0e6",
1256
+ magenta: "f0f",
1257
+ maroon: "800000",
1258
+ mediumaquamarine: "66cdaa",
1259
+ mediumblue: "0000cd",
1260
+ mediumorchid: "ba55d3",
1261
+ mediumpurple: "9370db",
1262
+ mediumseagreen: "3cb371",
1263
+ mediumslateblue: "7b68ee",
1264
+ mediumspringgreen: "00fa9a",
1265
+ mediumturquoise: "48d1cc",
1266
+ mediumvioletred: "c71585",
1267
+ midnightblue: "191970",
1268
+ mintcream: "f5fffa",
1269
+ mistyrose: "ffe4e1",
1270
+ moccasin: "ffe4b5",
1271
+ navajowhite: "ffdead",
1272
+ navy: "000080",
1273
+ oldlace: "fdf5e6",
1274
+ olive: "808000",
1275
+ olivedrab: "6b8e23",
1276
+ orange: "ffa500",
1277
+ orangered: "ff4500",
1278
+ orchid: "da70d6",
1279
+ palegoldenrod: "eee8aa",
1280
+ palegreen: "98fb98",
1281
+ paleturquoise: "afeeee",
1282
+ palevioletred: "db7093",
1283
+ papayawhip: "ffefd5",
1284
+ peachpuff: "ffdab9",
1285
+ peru: "cd853f",
1286
+ pink: "ffc0cb",
1287
+ plum: "dda0dd",
1288
+ powderblue: "b0e0e6",
1289
+ purple: "800080",
1290
+ rebeccapurple: "663399",
1291
+ red: "f00",
1292
+ rosybrown: "bc8f8f",
1293
+ royalblue: "4169e1",
1294
+ saddlebrown: "8b4513",
1295
+ salmon: "fa8072",
1296
+ sandybrown: "f4a460",
1297
+ seagreen: "2e8b57",
1298
+ seashell: "fff5ee",
1299
+ sienna: "a0522d",
1300
+ silver: "c0c0c0",
1301
+ skyblue: "87ceeb",
1302
+ slateblue: "6a5acd",
1303
+ slategray: "708090",
1304
+ slategrey: "708090",
1305
+ snow: "fffafa",
1306
+ springgreen: "00ff7f",
1307
+ steelblue: "4682b4",
1308
+ tan: "d2b48c",
1309
+ teal: "008080",
1310
+ thistle: "d8bfd8",
1311
+ tomato: "ff6347",
1312
+ turquoise: "40e0d0",
1313
+ violet: "ee82ee",
1314
+ wheat: "f5deb3",
1315
+ white: "fff",
1316
+ whitesmoke: "f5f5f5",
1317
+ yellow: "ff0",
1318
+ yellowgreen: "9acd32"
1319
+ };
1320
+ var hexNames = tinycolor.hexNames = flip(names);
1321
+ function flip(o) {
1322
+ var flipped = {};
1323
+ for (var i in o) {
1324
+ if (o.hasOwnProperty(i)) {
1325
+ flipped[o[i]] = i;
1326
+ }
1327
+ }
1328
+ return flipped;
1329
+ }
1330
+ function boundAlpha(a) {
1331
+ a = parseFloat(a);
1332
+ if (isNaN(a) || a < 0 || a > 1) {
1333
+ a = 1;
1334
+ }
1335
+ return a;
1336
+ }
1337
+ function bound01(n, max) {
1338
+ if (isOnePointZero(n))
1339
+ n = "100%";
1340
+ var processPercent = isPercentage(n);
1341
+ n = Math.min(max, Math.max(0, parseFloat(n)));
1342
+ if (processPercent) {
1343
+ n = parseInt(n * max, 10) / 100;
1344
+ }
1345
+ if (Math.abs(n - max) < 1e-6) {
1346
+ return 1;
1347
+ }
1348
+ return n % max / parseFloat(max);
1349
+ }
1350
+ function clamp01(val) {
1351
+ return Math.min(1, Math.max(0, val));
1352
+ }
1353
+ function parseIntFromHex(val) {
1354
+ return parseInt(val, 16);
1355
+ }
1356
+ function isOnePointZero(n) {
1357
+ return typeof n == "string" && n.indexOf(".") != -1 && parseFloat(n) === 1;
1358
+ }
1359
+ function isPercentage(n) {
1360
+ return typeof n === "string" && n.indexOf("%") != -1;
1361
+ }
1362
+ function pad2(c) {
1363
+ return c.length == 1 ? "0" + c : "" + c;
1364
+ }
1365
+ function convertToPercentage(n) {
1366
+ if (n <= 1) {
1367
+ n = n * 100 + "%";
1368
+ }
1369
+ return n;
1370
+ }
1371
+ function convertDecimalToHex(d) {
1372
+ return Math.round(parseFloat(d) * 255).toString(16);
1373
+ }
1374
+ function convertHexToDecimal(h) {
1375
+ return parseIntFromHex(h) / 255;
1376
+ }
1377
+ var matchers = function() {
1378
+ var CSS_INTEGER = "[-\\+]?\\d+%?";
1379
+ var CSS_NUMBER = "[-\\+]?\\d*\\.\\d+%?";
1380
+ var CSS_UNIT = "(?:" + CSS_NUMBER + ")|(?:" + CSS_INTEGER + ")";
1381
+ var PERMISSIVE_MATCH3 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?";
1382
+ var PERMISSIVE_MATCH4 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?";
1383
+ return {
1384
+ CSS_UNIT: new RegExp(CSS_UNIT),
1385
+ rgb: new RegExp("rgb" + PERMISSIVE_MATCH3),
1386
+ rgba: new RegExp("rgba" + PERMISSIVE_MATCH4),
1387
+ hsl: new RegExp("hsl" + PERMISSIVE_MATCH3),
1388
+ hsla: new RegExp("hsla" + PERMISSIVE_MATCH4),
1389
+ hsv: new RegExp("hsv" + PERMISSIVE_MATCH3),
1390
+ hsva: new RegExp("hsva" + PERMISSIVE_MATCH4),
1391
+ hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,
1392
+ hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,
1393
+ hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,
1394
+ hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/
1395
+ };
1396
+ }();
1397
+ function isValidCSSUnit(color) {
1398
+ return !!matchers.CSS_UNIT.exec(color);
1399
+ }
1400
+ function stringInputToObject(color) {
1401
+ color = color.replace(trimLeft, "").replace(trimRight, "").toLowerCase();
1402
+ var named = false;
1403
+ if (names[color]) {
1404
+ color = names[color];
1405
+ named = true;
1406
+ } else if (color == "transparent") {
1407
+ return {
1408
+ r: 0,
1409
+ g: 0,
1410
+ b: 0,
1411
+ a: 0,
1412
+ format: "name"
1413
+ };
1414
+ }
1415
+ var match;
1416
+ if (match = matchers.rgb.exec(color)) {
1417
+ return {
1418
+ r: match[1],
1419
+ g: match[2],
1420
+ b: match[3]
1421
+ };
1422
+ }
1423
+ if (match = matchers.rgba.exec(color)) {
1424
+ return {
1425
+ r: match[1],
1426
+ g: match[2],
1427
+ b: match[3],
1428
+ a: match[4]
1429
+ };
1430
+ }
1431
+ if (match = matchers.hsl.exec(color)) {
1432
+ return {
1433
+ h: match[1],
1434
+ s: match[2],
1435
+ l: match[3]
1436
+ };
1437
+ }
1438
+ if (match = matchers.hsla.exec(color)) {
1439
+ return {
1440
+ h: match[1],
1441
+ s: match[2],
1442
+ l: match[3],
1443
+ a: match[4]
1444
+ };
1445
+ }
1446
+ if (match = matchers.hsv.exec(color)) {
1447
+ return {
1448
+ h: match[1],
1449
+ s: match[2],
1450
+ v: match[3]
1451
+ };
1452
+ }
1453
+ if (match = matchers.hsva.exec(color)) {
1454
+ return {
1455
+ h: match[1],
1456
+ s: match[2],
1457
+ v: match[3],
1458
+ a: match[4]
1459
+ };
1460
+ }
1461
+ if (match = matchers.hex8.exec(color)) {
1462
+ return {
1463
+ r: parseIntFromHex(match[1]),
1464
+ g: parseIntFromHex(match[2]),
1465
+ b: parseIntFromHex(match[3]),
1466
+ a: convertHexToDecimal(match[4]),
1467
+ format: named ? "name" : "hex8"
1468
+ };
1469
+ }
1470
+ if (match = matchers.hex6.exec(color)) {
1471
+ return {
1472
+ r: parseIntFromHex(match[1]),
1473
+ g: parseIntFromHex(match[2]),
1474
+ b: parseIntFromHex(match[3]),
1475
+ format: named ? "name" : "hex"
1476
+ };
1477
+ }
1478
+ if (match = matchers.hex4.exec(color)) {
1479
+ return {
1480
+ r: parseIntFromHex(match[1] + "" + match[1]),
1481
+ g: parseIntFromHex(match[2] + "" + match[2]),
1482
+ b: parseIntFromHex(match[3] + "" + match[3]),
1483
+ a: convertHexToDecimal(match[4] + "" + match[4]),
1484
+ format: named ? "name" : "hex8"
1485
+ };
1486
+ }
1487
+ if (match = matchers.hex3.exec(color)) {
1488
+ return {
1489
+ r: parseIntFromHex(match[1] + "" + match[1]),
1490
+ g: parseIntFromHex(match[2] + "" + match[2]),
1491
+ b: parseIntFromHex(match[3] + "" + match[3]),
1492
+ format: named ? "name" : "hex"
1493
+ };
1494
+ }
1495
+ return false;
1496
+ }
1497
+ function validateWCAG2Parms(parms) {
1498
+ var level, size;
1499
+ parms = parms || {
1500
+ level: "AA",
1501
+ size: "small"
1502
+ };
1503
+ level = (parms.level || "AA").toUpperCase();
1504
+ size = (parms.size || "small").toLowerCase();
1505
+ if (level !== "AA" && level !== "AAA") {
1506
+ level = "AA";
1507
+ }
1508
+ if (size !== "small" && size !== "large") {
1509
+ size = "small";
1510
+ }
1511
+ return {
1512
+ level,
1513
+ size
1514
+ };
1515
+ }
1516
+
532
1517
  // src/colors.ts
1518
+ import { clamp } from "@excalidraw/math";
1519
+ import { degreesToRadians } from "@excalidraw/math";
1520
+ var DARK_MODE_COLORS_CACHE = typeof window !== "undefined" ? /* @__PURE__ */ new Map() : null;
1521
+ function cssHueRotate(red, green, blue, degrees) {
1522
+ const r = red / 255;
1523
+ const g = green / 255;
1524
+ const b = blue / 255;
1525
+ const a = degreesToRadians(degrees);
1526
+ const c = Math.cos(a);
1527
+ const s = Math.sin(a);
1528
+ const matrix = [
1529
+ 0.213 + c * 0.787 - s * 0.213,
1530
+ 0.715 - c * 0.715 - s * 0.715,
1531
+ 0.072 - c * 0.072 + s * 0.928,
1532
+ 0.213 - c * 0.213 + s * 0.143,
1533
+ 0.715 + c * 0.285 + s * 0.14,
1534
+ 0.072 - c * 0.072 - s * 0.283,
1535
+ 0.213 - c * 0.213 - s * 0.787,
1536
+ 0.715 - c * 0.715 + s * 0.715,
1537
+ 0.072 + c * 0.928 + s * 0.072
1538
+ ];
1539
+ const newR = r * matrix[0] + g * matrix[1] + b * matrix[2];
1540
+ const newG = r * matrix[3] + g * matrix[4] + b * matrix[5];
1541
+ const newB = r * matrix[6] + g * matrix[7] + b * matrix[8];
1542
+ return {
1543
+ r: Math.round(Math.max(0, Math.min(1, newR)) * 255),
1544
+ g: Math.round(Math.max(0, Math.min(1, newG)) * 255),
1545
+ b: Math.round(Math.max(0, Math.min(1, newB)) * 255)
1546
+ };
1547
+ }
1548
+ var cssInvert = (r, g, b, percent) => {
1549
+ const p = clamp(percent, 0, 100) / 100;
1550
+ const invertComponent = (color) => {
1551
+ const inverted = color * (1 - p) + (255 - color) * p;
1552
+ return Math.round(clamp(inverted, 0, 255));
1553
+ };
1554
+ const invertedR = invertComponent(r);
1555
+ const invertedG = invertComponent(g);
1556
+ const invertedB = invertComponent(b);
1557
+ return { r: invertedR, g: invertedG, b: invertedB };
1558
+ };
1559
+ var applyDarkModeFilter = (color) => {
1560
+ const cached = DARK_MODE_COLORS_CACHE?.get(color);
1561
+ if (cached) {
1562
+ return cached;
1563
+ }
1564
+ const tc = tinycolor(color);
1565
+ const alpha = tc.getAlpha();
1566
+ const rgb = tc.toRgb();
1567
+ const inverted = cssInvert(rgb.r, rgb.g, rgb.b, 93);
1568
+ const rotated = cssHueRotate(
1569
+ inverted.r,
1570
+ inverted.g,
1571
+ inverted.b,
1572
+ 180
1573
+ );
1574
+ const result = rgbToHex2(rotated.r, rotated.g, rotated.b, alpha);
1575
+ if (DARK_MODE_COLORS_CACHE) {
1576
+ DARK_MODE_COLORS_CACHE.set(color, result);
1577
+ }
1578
+ return result;
1579
+ };
533
1580
  var COLOR_OUTLINE_CONTRAST_THRESHOLD = 240;
534
1581
  var pick = (source, keys) => {
535
1582
  return keys.reduce((acc, key) => {
@@ -637,22 +1684,17 @@ var getAllColorsSpecificShade = (index) => [
637
1684
  COLOR_PALETTE.orange[index],
638
1685
  COLOR_PALETTE.red[index]
639
1686
  ];
640
- var rgbToHex = (r, g, b) => `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1)}`;
1687
+ var rgbToHex2 = (r, g, b, a) => {
1688
+ const hex6 = `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1)}`;
1689
+ if (a !== void 0 && a < 1) {
1690
+ const alphaHex = Math.round(a * 255).toString(16).padStart(2, "0");
1691
+ return `${hex6}${alphaHex}`;
1692
+ }
1693
+ return hex6;
1694
+ };
641
1695
 
642
1696
  // src/constants.ts
643
1697
  init_define_import_meta_env();
644
- var isDarwin = /Mac|iPod|iPhone|iPad/.test(navigator.platform);
645
- var isWindows = /^Win/.test(navigator.platform);
646
- var isAndroid = /\b(android)\b/i.test(navigator.userAgent);
647
- var isFirefox = typeof window !== "undefined" && "netscape" in window && navigator.userAgent.indexOf("rv:") > 1 && navigator.userAgent.indexOf("Gecko") > 1;
648
- var isChrome = navigator.userAgent.indexOf("Chrome") !== -1;
649
- var isSafari = !isChrome && navigator.userAgent.indexOf("Safari") !== -1;
650
- var isIOS = /iPad|iPhone/i.test(navigator.platform) || // iPadOS 13+
651
- navigator.userAgent.includes("Mac") && "ontouchend" in document;
652
- var isBrave = () => navigator.brave?.isBrave?.name === "isBrave";
653
- var isMobile = isIOS || /android|webos|ipod|blackberry|iemobile|opera mini/i.test(
654
- navigator.userAgent
655
- ) || /android|ios|ipod|blackberry|windows phone/i.test(navigator.platform);
656
1698
  var supportsResizeObserver = typeof window !== "undefined" && "ResizeObserver" in window;
657
1699
  var APP_NAME = "Excalidraw";
658
1700
  var TEXT_AUTOWRAP_THRESHOLD = 36;
@@ -734,10 +1776,19 @@ var ENV = {
734
1776
  PRODUCTION: "production"
735
1777
  };
736
1778
  var CLASSES = {
1779
+ SIDEBAR: "sidebar",
737
1780
  SHAPE_ACTIONS_MENU: "App-menu__left",
738
1781
  ZOOM_ACTIONS: "zoom-actions",
739
1782
  SEARCH_MENU_INPUT_WRAPPER: "layer-ui__search-inputWrapper",
740
- CONVERT_ELEMENT_TYPE_POPUP: "ConvertElementTypePopup"
1783
+ CONVERT_ELEMENT_TYPE_POPUP: "ConvertElementTypePopup",
1784
+ SHAPE_ACTIONS_THEME_SCOPE: "shape-actions-theme-scope",
1785
+ FRAME_NAME: "frame-name"
1786
+ };
1787
+ var FONT_SIZES = {
1788
+ sm: 16,
1789
+ md: 20,
1790
+ lg: 28,
1791
+ xl: 36
741
1792
  };
742
1793
  var CJK_HAND_DRAWN_FALLBACK_FONT = "Xiaolai";
743
1794
  var WINDOWS_EMOJI_FALLBACK_FONT = "Segoe UI Emoji";
@@ -838,7 +1889,10 @@ var STRING_MIME_TYPES = {
838
1889
  json: "application/json",
839
1890
  // excalidraw data
840
1891
  excalidraw: "application/vnd.excalidraw+json",
841
- excalidrawlib: "application/vnd.excalidrawlib+json"
1892
+ // LEGACY: fully-qualified library JSON data
1893
+ excalidrawlib: "application/vnd.excalidrawlib+json",
1894
+ // list of excalidraw library item ids
1895
+ excalidrawlibIds: "application/vnd.excalidrawlib.ids+json"
842
1896
  };
843
1897
  var MIME_TYPES = {
844
1898
  ...STRING_MIME_TYPES,
@@ -879,7 +1933,6 @@ var MAX_ZOOM = 30;
879
1933
  var HYPERLINK_TOOLTIP_DELAY = 300;
880
1934
  var IDLE_THRESHOLD = 6e4;
881
1935
  var ACTIVE_THRESHOLD = 3e3;
882
- var THEME_FILTER = "invert(93%) hue-rotate(180deg)";
883
1936
  var URL_QUERY_KEYS = {
884
1937
  addLibrary: "addLibrary"
885
1938
  };
@@ -900,10 +1953,6 @@ var DEFAULT_UI_OPTIONS = {
900
1953
  image: true
901
1954
  }
902
1955
  };
903
- var MQ_MAX_WIDTH_PORTRAIT = 730;
904
- var MQ_MAX_WIDTH_LANDSCAPE = 1e3;
905
- var MQ_MAX_HEIGHT_LANDSCAPE = 500;
906
- var MQ_RIGHT_SIDEBAR_MIN_WIDTH = 1229;
907
1956
  var MAX_DECIMALS_FOR_SVG_EXPORT = 2;
908
1957
  var EXPORT_SCALES = [1, 2, 3];
909
1958
  var DEFAULT_EXPORT_PADDING = 10;
@@ -1024,6 +2073,10 @@ var UserIdleState = /* @__PURE__ */ ((UserIdleState2) => {
1024
2073
  })(UserIdleState || {});
1025
2074
  var LINE_POLYGON_POINT_MERGE_DISTANCE = 20;
1026
2075
  var DOUBLE_TAP_POSITION_THRESHOLD = 35;
2076
+ var BIND_MODE_TIMEOUT = 700;
2077
+ var MOBILE_ACTION_BUTTON_BG = {
2078
+ background: "var(--mobile-action-button-bg)"
2079
+ };
1027
2080
 
1028
2081
  // src/font-metadata.ts
1029
2082
  init_define_import_meta_env();
@@ -1179,6 +2232,133 @@ var Queue = class {
1179
2232
 
1180
2233
  // src/keys.ts
1181
2234
  init_define_import_meta_env();
2235
+
2236
+ // src/editorInterface.ts
2237
+ init_define_import_meta_env();
2238
+ var DESKTOP_UI_MODE_STORAGE_KEY = "excalidraw.desktopUIMode";
2239
+ var MQ_MAX_MOBILE = 599;
2240
+ var MQ_MAX_WIDTH_LANDSCAPE = 1e3;
2241
+ var MQ_MAX_HEIGHT_LANDSCAPE = 500;
2242
+ var MQ_MIN_TABLET = MQ_MAX_MOBILE + 1;
2243
+ var MQ_MAX_TABLET = 1400;
2244
+ var MQ_MIN_WIDTH_DESKTOP = 1440;
2245
+ var MQ_RIGHT_SIDEBAR_MIN_WIDTH = 1229;
2246
+ var isDarwin = /Mac|iPod|iPhone|iPad/.test(navigator.platform);
2247
+ var isWindows = /^Win/.test(navigator.platform);
2248
+ var isAndroid = /\b(android)\b/i.test(navigator.userAgent);
2249
+ var isFirefox = typeof window !== "undefined" && "netscape" in window && navigator.userAgent.indexOf("rv:") > 1 && navigator.userAgent.indexOf("Gecko") > 1;
2250
+ var isChrome = navigator.userAgent.indexOf("Chrome") !== -1;
2251
+ var isSafari = !isChrome && navigator.userAgent.indexOf("Safari") !== -1;
2252
+ var isIOS = /iPad|iPhone/i.test(navigator.platform) || // iPadOS 13+
2253
+ navigator.userAgent.includes("Mac") && "ontouchend" in document;
2254
+ var isBrave = () => navigator.brave?.isBrave?.name === "isBrave";
2255
+ var isMobileBreakpoint = (width, height) => {
2256
+ return width <= MQ_MAX_MOBILE || height < MQ_MAX_HEIGHT_LANDSCAPE && width < MQ_MAX_WIDTH_LANDSCAPE;
2257
+ };
2258
+ var isTabletBreakpoint = (editorWidth, editorHeight) => {
2259
+ const minSide = Math.min(editorWidth, editorHeight);
2260
+ const maxSide = Math.max(editorWidth, editorHeight);
2261
+ return minSide >= MQ_MIN_TABLET && maxSide <= MQ_MAX_TABLET;
2262
+ };
2263
+ var isMobileOrTablet = () => {
2264
+ const ua = navigator.userAgent || "";
2265
+ const platform = navigator.platform || "";
2266
+ const uaData = navigator.userAgentData;
2267
+ if (uaData) {
2268
+ const plat = (uaData.platform || "").toLowerCase();
2269
+ const isDesktopOS = plat === "windows" || plat === "macos" || plat === "linux" || plat === "chrome os";
2270
+ if (uaData.mobile === true) {
2271
+ return true;
2272
+ }
2273
+ if (uaData.mobile === false && plat === "android") {
2274
+ const looksTouchTablet = matchMedia?.("(hover: none)").matches && matchMedia?.("(pointer: coarse)").matches;
2275
+ return looksTouchTablet;
2276
+ }
2277
+ if (isDesktopOS) {
2278
+ return false;
2279
+ }
2280
+ }
2281
+ if (isIOS) {
2282
+ return true;
2283
+ }
2284
+ if (isAndroid) {
2285
+ const isAndroidPhone = /Mobile/i.test(ua);
2286
+ const isAndroidTablet = !isAndroidPhone;
2287
+ if (isAndroidPhone || isAndroidTablet) {
2288
+ const looksTouchTablet = matchMedia?.("(hover: none)").matches && matchMedia?.("(pointer: coarse)").matches;
2289
+ return looksTouchTablet;
2290
+ }
2291
+ }
2292
+ const looksDesktopPlatform = /Win|Linux|CrOS|Mac/.test(platform) || /Windows NT|X11|CrOS|Macintosh/.test(ua);
2293
+ if (looksDesktopPlatform) {
2294
+ return false;
2295
+ }
2296
+ return false;
2297
+ };
2298
+ var getFormFactor = (editorWidth, editorHeight) => {
2299
+ if (isMobileBreakpoint(editorWidth, editorHeight)) {
2300
+ return "phone";
2301
+ }
2302
+ if (isTabletBreakpoint(editorWidth, editorHeight)) {
2303
+ return "tablet";
2304
+ }
2305
+ return "desktop";
2306
+ };
2307
+ var deriveStylesPanelMode = (editorInterface) => {
2308
+ if (editorInterface.formFactor === "phone") {
2309
+ return "mobile";
2310
+ }
2311
+ if (editorInterface.formFactor === "tablet") {
2312
+ return "compact";
2313
+ }
2314
+ return editorInterface.desktopUIMode;
2315
+ };
2316
+ var createUserAgentDescriptor = (userAgentString) => {
2317
+ const normalizedUA = userAgentString ?? "";
2318
+ let platform = "unknown";
2319
+ if (isIOS) {
2320
+ platform = "ios";
2321
+ } else if (isAndroid) {
2322
+ platform = "android";
2323
+ } else if (normalizedUA) {
2324
+ platform = "other";
2325
+ }
2326
+ return {
2327
+ isMobileDevice: isMobileOrTablet(),
2328
+ platform
2329
+ };
2330
+ };
2331
+ var loadDesktopUIModePreference = () => {
2332
+ if (typeof window === "undefined") {
2333
+ return null;
2334
+ }
2335
+ try {
2336
+ const stored = window.localStorage.getItem(DESKTOP_UI_MODE_STORAGE_KEY);
2337
+ if (stored === "compact" || stored === "full") {
2338
+ return stored;
2339
+ }
2340
+ } catch (error) {
2341
+ }
2342
+ return null;
2343
+ };
2344
+ var persistDesktopUIMode = (mode) => {
2345
+ if (typeof window === "undefined") {
2346
+ return;
2347
+ }
2348
+ try {
2349
+ window.localStorage.setItem(DESKTOP_UI_MODE_STORAGE_KEY, mode);
2350
+ } catch (error) {
2351
+ }
2352
+ };
2353
+ var setDesktopUIMode = (mode) => {
2354
+ if (mode !== "compact" && mode !== "full") {
2355
+ return;
2356
+ }
2357
+ persistDesktopUIMode(mode);
2358
+ return mode;
2359
+ };
2360
+
2361
+ // src/keys.ts
1182
2362
  var CODES = {
1183
2363
  EQUAL: "Equal",
1184
2364
  MINUS: "Minus",
@@ -1424,7 +2604,7 @@ var isInteractive = (target) => {
1424
2604
  return isInputLike(target) || target instanceof Element && !!target.closest("label, button");
1425
2605
  };
1426
2606
  var isWritableElement = (target) => target instanceof HTMLElement && target.dataset.type === "wysiwyg" || target instanceof HTMLBRElement || // newline in wysiwyg
1427
- target instanceof HTMLTextAreaElement || target instanceof HTMLInputElement && (target.type === "text" || target.type === "number" || target.type === "password");
2607
+ target instanceof HTMLTextAreaElement || target instanceof HTMLInputElement && (target.type === "text" || target.type === "number" || target.type === "password" || target.type === "search");
1428
2608
  var getFontFamilyString = ({
1429
2609
  fontFamily
1430
2610
  }) => {
@@ -1441,6 +2621,9 @@ var getFontString = ({
1441
2621
  }) => {
1442
2622
  return `${fontSize}px ${getFontFamilyString({ fontFamily })}`;
1443
2623
  };
2624
+ var nextAnimationFrame = async (cb) => {
2625
+ requestAnimationFrame(() => requestAnimationFrame(cb));
2626
+ };
1444
2627
  var debounce = (fn, timeout) => {
1445
2628
  let handle = 0;
1446
2629
  let lastArgs = null;
@@ -1605,6 +2788,9 @@ var removeSelection = () => {
1605
2788
  }
1606
2789
  };
1607
2790
  var distance = (x, y) => Math.abs(x - y);
2791
+ var isSelectionLikeTool = (type) => {
2792
+ return type === "selection" || type === "lasso";
2793
+ };
1608
2794
  var updateActiveTool = (appState, data) => {
1609
2795
  if (data.type === "custom") {
1610
2796
  return {
@@ -1626,13 +2812,6 @@ var updateActiveTool = (appState, data) => {
1626
2812
  var isFullScreen = () => document.fullscreenElement?.nodeName === "HTML";
1627
2813
  var allowFullScreen = () => document.documentElement.requestFullscreen();
1628
2814
  var exitFullScreen = () => document.exitFullscreen();
1629
- var getShortcutKey = (shortcut) => {
1630
- shortcut = shortcut.replace(/\bAlt\b/i, "Alt").replace(/\bShift\b/i, "Shift").replace(/\b(Enter|Return)\b/i, "Enter");
1631
- if (isDarwin) {
1632
- return shortcut.replace(/\bCtrlOrCmd\b/gi, "Cmd").replace(/\bAlt\b/i, "Option");
1633
- }
1634
- return shortcut.replace(/\bCtrlOrCmd\b/gi, "Ctrl");
1635
- };
1636
2815
  var viewportCoordsToSceneCoords = ({ clientX, clientY }, {
1637
2816
  zoom,
1638
2817
  offsetLeft,
@@ -1707,11 +2886,8 @@ var mapFind = (collection, iteratee) => {
1707
2886
  return void 0;
1708
2887
  };
1709
2888
  var isTransparent = (color) => {
1710
- const isRGBTransparent = color.length === 5 && color.substr(4, 1) === "0";
1711
- const isRRGGBBTransparent = color.length === 9 && color.substr(7, 2) === "00";
1712
- return isRGBTransparent || isRRGGBBTransparent || color === COLOR_PALETTE.transparent;
2889
+ return tinycolor(color).getAlpha() === 0;
1713
2890
  };
1714
- var isBindingFallthroughEnabled = (el) => el.fillStyle !== "solid" || isTransparent(el.backgroundColor);
1715
2891
  var resolvablePromise = () => {
1716
2892
  let resolve;
1717
2893
  let reject;
@@ -2032,9 +3208,9 @@ function getSvgPathFromStroke(points, closed = true) {
2032
3208
  var normalizeEOL = (str) => {
2033
3209
  return str.replace(/\r?\n|\r/g, "\n");
2034
3210
  };
2035
- var toBrandedType = (value) => {
3211
+ function toBrandedType(value) {
2036
3212
  return value;
2037
- };
3213
+ }
2038
3214
  var promiseTry = async (fn, ...args) => {
2039
3215
  return new Promise((resolve) => {
2040
3216
  resolve(fn(...args));
@@ -2074,6 +3250,38 @@ var reduceToCommonValue = (collection, getValue) => {
2074
3250
  }
2075
3251
  return commonValue;
2076
3252
  };
3253
+ var FEATURE_FLAGS_STORAGE_KEY = "excalidraw-feature-flags";
3254
+ var DEFAULT_FEATURE_FLAGS = {
3255
+ COMPLEX_BINDINGS: false
3256
+ };
3257
+ var featureFlags = null;
3258
+ var getFeatureFlag = (flag) => {
3259
+ if (!featureFlags) {
3260
+ try {
3261
+ const serializedFlags = localStorage.getItem(FEATURE_FLAGS_STORAGE_KEY);
3262
+ if (serializedFlags) {
3263
+ const flags = JSON.parse(serializedFlags);
3264
+ featureFlags = flags ?? DEFAULT_FEATURE_FLAGS;
3265
+ }
3266
+ } catch {
3267
+ }
3268
+ }
3269
+ return (featureFlags || DEFAULT_FEATURE_FLAGS)[flag];
3270
+ };
3271
+ var setFeatureFlag = (flag, value) => {
3272
+ try {
3273
+ featureFlags = {
3274
+ ...featureFlags || DEFAULT_FEATURE_FLAGS,
3275
+ [flag]: value
3276
+ };
3277
+ localStorage.setItem(
3278
+ FEATURE_FLAGS_STORAGE_KEY,
3279
+ JSON.stringify(featureFlags)
3280
+ );
3281
+ } catch (e) {
3282
+ console.error("unable to set feature flag", e);
3283
+ }
3284
+ };
2077
3285
 
2078
3286
  // src/random.ts
2079
3287
  var random = new Random(Date.now());
@@ -2147,6 +3355,106 @@ var Emitter = class {
2147
3355
  this.subscribers = [];
2148
3356
  }
2149
3357
  };
3358
+
3359
+ // src/visualdebug.ts
3360
+ init_define_import_meta_env();
3361
+ import {
3362
+ isLineSegment,
3363
+ lineSegment,
3364
+ pointFrom
3365
+ } from "@excalidraw/math";
3366
+ var debugDrawCubicBezier = (c, opts) => {
3367
+ addToCurrentFrame({
3368
+ color: opts?.color ?? "purple",
3369
+ permanent: !!opts?.permanent,
3370
+ data: c
3371
+ });
3372
+ };
3373
+ var debugDrawLine = (segment, opts) => {
3374
+ const segments = isLineSegment(segment) ? [segment] : segment;
3375
+ segments.forEach(
3376
+ (data) => addToCurrentFrame({
3377
+ color: opts?.color ?? "red",
3378
+ data,
3379
+ permanent: !!opts?.permanent
3380
+ })
3381
+ );
3382
+ };
3383
+ var debugDrawPoint = (p, opts) => {
3384
+ const xOffset = opts?.fuzzy ? Math.random() * 3 : 0;
3385
+ const yOffset = opts?.fuzzy ? Math.random() * 3 : 0;
3386
+ debugDrawLine(
3387
+ lineSegment(
3388
+ pointFrom(p[0] + xOffset - 10, p[1] + yOffset - 10),
3389
+ pointFrom(p[0] + xOffset + 10, p[1] + yOffset + 10)
3390
+ ),
3391
+ {
3392
+ color: opts?.color ?? "cyan",
3393
+ permanent: opts?.permanent
3394
+ }
3395
+ );
3396
+ debugDrawLine(
3397
+ lineSegment(
3398
+ pointFrom(p[0] + xOffset - 10, p[1] + yOffset + 10),
3399
+ pointFrom(p[0] + xOffset + 10, p[1] + yOffset - 10)
3400
+ ),
3401
+ {
3402
+ color: opts?.color ?? "cyan",
3403
+ permanent: opts?.permanent
3404
+ }
3405
+ );
3406
+ };
3407
+ var debugDrawBounds = (box, opts) => {
3408
+ (isBounds(box) ? [box] : box).forEach(
3409
+ (bbox) => debugDrawLine(
3410
+ [
3411
+ lineSegment(
3412
+ pointFrom(bbox[0], bbox[1]),
3413
+ pointFrom(bbox[2], bbox[1])
3414
+ ),
3415
+ lineSegment(
3416
+ pointFrom(bbox[2], bbox[1]),
3417
+ pointFrom(bbox[2], bbox[3])
3418
+ ),
3419
+ lineSegment(
3420
+ pointFrom(bbox[2], bbox[3]),
3421
+ pointFrom(bbox[0], bbox[3])
3422
+ ),
3423
+ lineSegment(
3424
+ pointFrom(bbox[0], bbox[3]),
3425
+ pointFrom(bbox[0], bbox[1])
3426
+ )
3427
+ ],
3428
+ {
3429
+ color: opts?.color ?? "green",
3430
+ permanent: !!opts?.permanent
3431
+ }
3432
+ )
3433
+ );
3434
+ };
3435
+ var debugDrawPoints = ({
3436
+ x,
3437
+ y,
3438
+ points
3439
+ }, options) => {
3440
+ points.forEach(
3441
+ (p) => debugDrawPoint(pointFrom(x + p[0], y + p[1]), options)
3442
+ );
3443
+ };
3444
+ var debugCloseFrame = () => {
3445
+ window.visualDebug?.data.push([]);
3446
+ };
3447
+ var debugClear = () => {
3448
+ if (window.visualDebug?.data) {
3449
+ window.visualDebug.data = [];
3450
+ }
3451
+ };
3452
+ var addToCurrentFrame = (element) => {
3453
+ if (window.visualDebug?.data && window.visualDebug.data.length === 0) {
3454
+ window.visualDebug.data[0] = [];
3455
+ }
3456
+ window.visualDebug?.data && window.visualDebug.data[window.visualDebug.data.length - 1].push(element);
3457
+ };
2150
3458
  export {
2151
3459
  ACTIVE_THRESHOLD,
2152
3460
  ALLOWED_PASTE_MIME_TYPES,
@@ -2154,6 +3462,7 @@ export {
2154
3462
  ARROW_LABEL_FONT_SIZE_TO_MIN_WIDTH_RATIO,
2155
3463
  ARROW_LABEL_WIDTH_FRACTION,
2156
3464
  ARROW_TYPE,
3465
+ BIND_MODE_TIMEOUT,
2157
3466
  BOUND_TEXT_PADDING,
2158
3467
  BinaryHeap,
2159
3468
  CANVAS_ONLY_ACTIONS,
@@ -2216,6 +3525,7 @@ export {
2216
3525
  FONT_FAMILY_FALLBACKS,
2217
3526
  FONT_FAMILY_GENERIC_FALLBACKS,
2218
3527
  FONT_METADATA,
3528
+ FONT_SIZES,
2219
3529
  FRAME_STYLE,
2220
3530
  GOOGLE_FONTS_RANGES,
2221
3531
  HYPERLINK_TOOLTIP_DELAY,
@@ -2238,10 +3548,14 @@ export {
2238
3548
  MIN_FONT_SIZE,
2239
3549
  MIN_WIDTH_OR_HEIGHT,
2240
3550
  MIN_ZOOM,
3551
+ MOBILE_ACTION_BUTTON_BG,
2241
3552
  MONOSPACE_GENERIC_FONT,
2242
3553
  MQ_MAX_HEIGHT_LANDSCAPE,
3554
+ MQ_MAX_MOBILE,
3555
+ MQ_MAX_TABLET,
2243
3556
  MQ_MAX_WIDTH_LANDSCAPE,
2244
- MQ_MAX_WIDTH_PORTRAIT,
3557
+ MQ_MIN_TABLET,
3558
+ MQ_MIN_WIDTH_DESKTOP,
2245
3559
  MQ_RIGHT_SIDEBAR_MIN_WIDTH,
2246
3560
  ORIG_ID,
2247
3561
  POINTER_BUTTON,
@@ -2264,7 +3578,6 @@ export {
2264
3578
  TEXT_AUTOWRAP_THRESHOLD,
2265
3579
  TEXT_TO_CENTER_SNAP_THRESHOLD,
2266
3580
  THEME,
2267
- THEME_FILTER,
2268
3581
  TITLE_TIMEOUT,
2269
3582
  TOOL_TYPE,
2270
3583
  TOUCH_CTX_MENU_TIMEOUT,
@@ -2279,6 +3592,7 @@ export {
2279
3592
  ZOOM_STEP,
2280
3593
  addEventListener,
2281
3594
  allowFullScreen,
3595
+ applyDarkModeFilter,
2282
3596
  arrayToList,
2283
3597
  arrayToMap,
2284
3598
  arrayToMapWithIndex,
@@ -2290,7 +3604,16 @@ export {
2290
3604
  chunk,
2291
3605
  cloneJSON,
2292
3606
  composeEventHandlers,
3607
+ createUserAgentDescriptor,
2293
3608
  debounce,
3609
+ debugClear,
3610
+ debugCloseFrame,
3611
+ debugDrawBounds,
3612
+ debugDrawCubicBezier,
3613
+ debugDrawLine,
3614
+ debugDrawPoint,
3615
+ debugDrawPoints,
3616
+ deriveStylesPanelMode,
2294
3617
  distance,
2295
3618
  easeOut,
2296
3619
  easeToValuesRAF,
@@ -2302,16 +3625,17 @@ export {
2302
3625
  getAllColorsSpecificShade,
2303
3626
  getDateTime,
2304
3627
  getExportSource,
3628
+ getFeatureFlag,
2305
3629
  getFontFamilyFallbacks,
2306
3630
  getFontFamilyString,
2307
3631
  getFontString,
3632
+ getFormFactor,
2308
3633
  getFrame,
2309
3634
  getGenericFontFamilyFallback,
2310
3635
  getGlobalCSSVariable,
2311
3636
  getGridPoint,
2312
3637
  getLineHeight,
2313
3638
  getNearestScrollableContainer,
2314
- getShortcutKey,
2315
3639
  getSizeFromPoints,
2316
3640
  getSpecificColorShades,
2317
3641
  getSvgPathFromStroke,
@@ -2322,7 +3646,7 @@ export {
2322
3646
  isAndroid,
2323
3647
  isAnyTrue,
2324
3648
  isArrowKey,
2325
- isBindingFallthroughEnabled,
3649
+ isBounds,
2326
3650
  isBrave,
2327
3651
  isChrome,
2328
3652
  isDarwin,
@@ -2335,7 +3659,7 @@ export {
2335
3659
  isLatinChar,
2336
3660
  isLocalLink,
2337
3661
  isMemberOf,
2338
- isMobile,
3662
+ isMobileBreakpoint,
2339
3663
  isPrimitive,
2340
3664
  isProdEnv,
2341
3665
  isPromiseLike,
@@ -2343,18 +3667,22 @@ export {
2343
3667
  isReadonlyArray,
2344
3668
  isRunningInIframe,
2345
3669
  isSafari,
3670
+ isSelectionLikeTool,
2346
3671
  isServerEnv,
2347
3672
  isShallowEqual,
3673
+ isTabletBreakpoint,
2348
3674
  isTestEnv,
2349
3675
  isToolIcon,
2350
3676
  isTransparent,
2351
3677
  isWindows,
2352
3678
  isWritableElement,
3679
+ loadDesktopUIModePreference,
2353
3680
  mapFind,
2354
3681
  matchKey,
2355
3682
  memoize,
2356
3683
  muteFSAbortError,
2357
3684
  nFormatter,
3685
+ nextAnimationFrame,
2358
3686
  normalizeEOL,
2359
3687
  normalizeLink,
2360
3688
  preventUnload,
@@ -2367,11 +3695,13 @@ export {
2367
3695
  rescalePoints,
2368
3696
  reseed,
2369
3697
  resolvablePromise,
2370
- rgbToHex,
3698
+ rgbToHex2 as rgbToHex,
2371
3699
  safelyParseJSON,
2372
3700
  sceneCoordsToViewportCoords,
2373
3701
  selectNode,
2374
3702
  setDateTimeForTests,
3703
+ setDesktopUIMode,
3704
+ setFeatureFlag,
2375
3705
  shouldMaintainAspectRatio,
2376
3706
  shouldResizeFromCenter,
2377
3707
  shouldRotateWithDiscreteAngle,
@@ -2379,6 +3709,7 @@ export {
2379
3709
  supportsEmoji,
2380
3710
  supportsResizeObserver,
2381
3711
  throttleRAF,
3712
+ tinycolor,
2382
3713
  toArray,
2383
3714
  toBrandedType,
2384
3715
  toIterable,