@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.
Files changed (241) hide show
  1. package/dist/dev/index.js +1524 -239
  2. package/dist/dev/index.js.map +4 -4
  3. package/dist/prod/index.js +3 -3
  4. package/dist/types/common/debug.d.ts +21 -0
  5. package/dist/types/common/src/bounds.d.ts +10 -0
  6. package/dist/types/common/src/colors.d.ts +59 -39
  7. package/dist/types/common/src/constants.d.ts +39 -27
  8. package/dist/types/common/src/editorInterface.d.ts +34 -0
  9. package/dist/types/common/src/font-metadata.d.ts +1 -3
  10. package/dist/types/common/src/index.d.ts +3 -0
  11. package/dist/types/common/src/keys.d.ts +1 -1
  12. package/dist/types/common/src/utility-types.d.ts +0 -1
  13. package/dist/types/common/src/utils.d.ts +53 -39
  14. package/dist/types/element/src/Scene.d.ts +10 -6
  15. package/dist/types/element/src/arrows/focus.d.ts +27 -0
  16. package/dist/types/element/src/arrows/helpers.d.ts +5 -0
  17. package/dist/types/element/src/binding.d.ts +66 -46
  18. package/dist/types/element/src/bounds.d.ts +3 -11
  19. package/dist/types/element/src/collision.d.ts +7 -2
  20. package/dist/types/element/src/comparisons.d.ts +7 -7
  21. package/dist/types/element/src/delta.d.ts +16 -4
  22. package/dist/types/element/src/distribute.d.ts +2 -1
  23. package/dist/types/element/src/dragElements.d.ts +3 -3
  24. package/dist/types/element/src/duplicate.d.ts +3 -3
  25. package/dist/types/element/src/fractionalIndex.d.ts +2 -2
  26. package/dist/types/element/src/frame.d.ts +7 -3
  27. package/dist/types/element/src/heading.d.ts +2 -1
  28. package/dist/types/element/src/image.d.ts +1 -11
  29. package/dist/types/element/src/index.d.ts +4 -3
  30. package/dist/types/element/src/linearElementEditor.d.ts +20 -21
  31. package/dist/types/element/src/mutateElement.d.ts +3 -1
  32. package/dist/types/element/src/newElement.d.ts +6 -6
  33. package/dist/types/element/src/positionElementsOnGrid.d.ts +2 -0
  34. package/dist/types/element/src/renderElement.d.ts +4 -7
  35. package/dist/types/element/src/resizeElements.d.ts +10 -10
  36. package/dist/types/element/src/resizeTest.d.ts +6 -5
  37. package/dist/types/element/src/selection.d.ts +3 -7
  38. package/dist/types/element/src/shape.d.ts +8 -7
  39. package/dist/types/element/src/store.d.ts +6 -1
  40. package/dist/types/element/src/textElement.d.ts +1 -1
  41. package/dist/types/element/src/textMeasurements.d.ts +1 -3
  42. package/dist/types/{excalidraw/data → element/src}/transform.d.ts +3 -3
  43. package/dist/types/element/src/transformHandles.d.ts +8 -27
  44. package/dist/types/element/src/typeChecks.d.ts +4 -7
  45. package/dist/types/element/src/types.d.ts +7 -11
  46. package/dist/types/element/src/utils.d.ts +8 -3
  47. package/dist/types/element/src/zindex.d.ts +7 -1
  48. package/dist/types/excalidraw/actions/actionAddToLibrary.d.ts +147 -184
  49. package/dist/types/excalidraw/actions/actionAlign.d.ts +6 -7
  50. package/dist/types/excalidraw/actions/actionBoundText.d.ts +73 -98
  51. package/dist/types/excalidraw/actions/actionCanvas.d.ts +438 -771
  52. package/dist/types/excalidraw/actions/actionClipboard.d.ts +109 -878
  53. package/dist/types/excalidraw/actions/actionCropEditor.d.ts +35 -48
  54. package/dist/types/excalidraw/actions/actionDeleteSelected.d.ts +124 -165
  55. package/dist/types/excalidraw/actions/actionDistribute.d.ts +2 -3
  56. package/dist/types/excalidraw/actions/actionDuplicateSelection.d.ts +3 -4
  57. package/dist/types/excalidraw/actions/actionElementLink.d.ts +50 -65
  58. package/dist/types/excalidraw/actions/actionElementLock.d.ts +72 -97
  59. package/dist/types/excalidraw/actions/actionEmbeddable.d.ts +52 -65
  60. package/dist/types/excalidraw/actions/actionExport.d.ts +161 -1118
  61. package/dist/types/excalidraw/actions/actionFinalize.d.ts +10 -395
  62. package/dist/types/excalidraw/actions/actionFlip.d.ts +2 -3
  63. package/dist/types/excalidraw/actions/actionFrame.d.ts +264 -351
  64. package/dist/types/excalidraw/actions/actionGroup.d.ts +76 -109
  65. package/dist/types/excalidraw/actions/actionLinearEditor.d.ts +191 -211
  66. package/dist/types/excalidraw/actions/actionLink.d.ts +52 -65
  67. package/dist/types/excalidraw/actions/actionMenu.d.ts +45 -428
  68. package/dist/types/excalidraw/actions/actionNavigate.d.ts +18 -361
  69. package/dist/types/excalidraw/actions/actionProperties.d.ts +135 -2503
  70. package/dist/types/excalidraw/actions/actionSelectAll.d.ts +38 -55
  71. package/dist/types/excalidraw/actions/actionStyles.d.ts +35 -48
  72. package/dist/types/excalidraw/actions/actionTextAutoResize.d.ts +3 -3
  73. package/dist/types/excalidraw/actions/actionToggleGridMode.d.ts +52 -65
  74. package/dist/types/excalidraw/actions/actionToggleObjectsSnapMode.d.ts +52 -65
  75. package/dist/types/excalidraw/actions/actionToggleSearchMenu.d.ts +44 -59
  76. package/dist/types/excalidraw/actions/actionToggleShapeSwitch.d.ts +1 -1
  77. package/dist/types/excalidraw/actions/actionToggleStats.d.ts +51 -64
  78. package/dist/types/excalidraw/actions/actionToggleViewMode.d.ts +52 -65
  79. package/dist/types/excalidraw/actions/actionToggleZenMode.d.ts +52 -65
  80. package/dist/types/excalidraw/actions/actionZindex.d.ts +8 -9
  81. package/dist/types/excalidraw/actions/index.d.ts +2 -2
  82. package/dist/types/excalidraw/actions/register.d.ts +2 -2
  83. package/dist/types/excalidraw/actions/shortcuts.d.ts +1 -1
  84. package/dist/types/excalidraw/actions/types.d.ts +4 -4
  85. package/dist/types/excalidraw/appState.d.ts +26 -21
  86. package/dist/types/excalidraw/clipboard.d.ts +58 -17
  87. package/dist/types/excalidraw/components/Actions.d.ts +21 -8
  88. package/dist/types/excalidraw/components/App.d.ts +77 -67
  89. package/dist/types/excalidraw/components/Card.d.ts +1 -3
  90. package/dist/types/excalidraw/components/ColorPicker/ColorInput.d.ts +2 -4
  91. package/dist/types/excalidraw/components/ColorPicker/ColorPicker.d.ts +0 -1
  92. package/dist/types/excalidraw/components/ColorPicker/Picker.d.ts +2 -0
  93. package/dist/types/excalidraw/components/ColorPicker/PickerColorList.d.ts +2 -1
  94. package/dist/types/excalidraw/components/ColorPicker/ShadeList.d.ts +2 -1
  95. package/dist/types/excalidraw/components/ColorPicker/colorPickerUtils.d.ts +0 -1
  96. package/dist/types/excalidraw/components/ColorPicker/keyboardNavHandlers.d.ts +0 -1
  97. package/dist/types/excalidraw/components/CommandPalette/CommandPalette.d.ts +1 -0
  98. package/dist/types/excalidraw/components/CommandPalette/types.d.ts +2 -4
  99. package/dist/types/excalidraw/components/ConvertElementTypePopup.d.ts +2 -2
  100. package/dist/types/excalidraw/components/DarkModeToggle.d.ts +1 -1
  101. package/dist/types/excalidraw/components/DefaultSidebar.d.ts +9 -13
  102. package/dist/types/excalidraw/components/ElementLinkDialog.d.ts +1 -1
  103. package/dist/types/excalidraw/components/Ellipsify.d.ts +1 -2
  104. package/dist/types/excalidraw/components/ErrorDialog.d.ts +1 -1
  105. package/dist/types/excalidraw/components/ExcalidrawLogo.d.ts +1 -2
  106. package/dist/types/excalidraw/components/EyeDropper.d.ts +0 -1
  107. package/dist/types/excalidraw/components/FilledButton.d.ts +2 -1
  108. package/dist/types/excalidraw/components/FontPicker/FontPicker.d.ts +2 -1
  109. package/dist/types/excalidraw/components/FontPicker/FontPickerTrigger.d.ts +3 -1
  110. package/dist/types/excalidraw/components/FontPicker/keyboardNavHandlers.d.ts +0 -1
  111. package/dist/types/excalidraw/components/HelpDialog.d.ts +1 -1
  112. package/dist/types/excalidraw/components/HintViewer.d.ts +4 -3
  113. package/dist/types/excalidraw/components/InlineIcon.d.ts +3 -1
  114. package/dist/types/excalidraw/components/LayerUI.d.ts +2 -1
  115. package/dist/types/excalidraw/components/LibraryMenuControlButtons.d.ts +1 -1
  116. package/dist/types/excalidraw/components/LibraryMenuHeaderContent.d.ts +1 -2
  117. package/dist/types/excalidraw/components/LibraryMenuSection.d.ts +1 -1
  118. package/dist/types/excalidraw/components/LibraryUnit.d.ts +2 -3
  119. package/dist/types/excalidraw/components/LoadingMessage.d.ts +0 -1
  120. package/dist/types/excalidraw/components/MobileMenu.d.ts +3 -5
  121. package/dist/types/excalidraw/components/MobileToolBar.d.ts +10 -0
  122. package/dist/types/excalidraw/components/Modal.d.ts +0 -1
  123. package/dist/types/excalidraw/components/OverwriteConfirm/OverwriteConfirm.d.ts +1 -1
  124. package/dist/types/excalidraw/components/Popover.d.ts +2 -1
  125. package/dist/types/excalidraw/components/PropertiesPopover.d.ts +2 -1
  126. package/dist/types/excalidraw/components/RadioGroup.d.ts +0 -1
  127. package/dist/types/excalidraw/components/RadioSelection.d.ts +4 -4
  128. package/dist/types/excalidraw/components/ScrollableList.d.ts +0 -1
  129. package/dist/types/excalidraw/components/Sidebar/Sidebar.d.ts +15 -21
  130. package/dist/types/excalidraw/components/Sidebar/SidebarHeader.d.ts +1 -1
  131. package/dist/types/excalidraw/components/Sidebar/SidebarTab.d.ts +1 -2
  132. package/dist/types/excalidraw/components/Sidebar/SidebarTabTrigger.d.ts +1 -2
  133. package/dist/types/excalidraw/components/Sidebar/SidebarTabTriggers.d.ts +1 -2
  134. package/dist/types/excalidraw/components/Sidebar/SidebarTabs.d.ts +1 -2
  135. package/dist/types/excalidraw/components/Spinner.d.ts +4 -4
  136. package/dist/types/excalidraw/components/Stats/CanvasGrid.d.ts +0 -1
  137. package/dist/types/excalidraw/components/Stats/Collapsible.d.ts +0 -1
  138. package/dist/types/excalidraw/components/Stats/DragInput.d.ts +0 -1
  139. package/dist/types/excalidraw/components/Stats/index.d.ts +7 -8
  140. package/dist/types/excalidraw/components/Stats/utils.d.ts +1 -1
  141. package/dist/types/excalidraw/components/TTDDialog/Chat/ChatHistoryMenu.d.ts +15 -0
  142. package/dist/types/excalidraw/components/TTDDialog/Chat/ChatInterface.d.ts +23 -0
  143. package/dist/types/excalidraw/components/TTDDialog/Chat/ChatMessage.d.ts +14 -0
  144. package/dist/types/excalidraw/components/TTDDialog/Chat/TTDChatPanel.d.ts +27 -0
  145. package/dist/types/excalidraw/components/TTDDialog/Chat/index.d.ts +3 -0
  146. package/dist/types/excalidraw/components/TTDDialog/Chat/useChatAgent.d.ts +8 -0
  147. package/dist/types/excalidraw/components/TTDDialog/MermaidToExcalidraw.d.ts +3 -2
  148. package/dist/types/excalidraw/components/TTDDialog/TTDContext.d.ts +13 -0
  149. package/dist/types/excalidraw/components/TTDDialog/TTDDialog.d.ts +12 -29
  150. package/dist/types/excalidraw/components/TTDDialog/TTDDialogOutput.d.ts +2 -2
  151. package/dist/types/excalidraw/components/TTDDialog/TTDDialogPanel.d.ts +13 -9
  152. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTab.d.ts +1 -2
  153. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTrigger.d.ts +1 -2
  154. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTabTriggers.d.ts +1 -2
  155. package/dist/types/excalidraw/components/TTDDialog/TTDDialogTrigger.d.ts +2 -3
  156. package/dist/types/excalidraw/components/TTDDialog/TTDPreviewPanel.d.ts +9 -0
  157. package/dist/types/excalidraw/components/TTDDialog/TTDWelcomeMessage.d.ts +1 -0
  158. package/dist/types/excalidraw/components/TTDDialog/TextToDiagram.d.ts +9 -0
  159. package/dist/types/excalidraw/components/TTDDialog/common.d.ts +16 -16
  160. package/dist/types/excalidraw/components/TTDDialog/hooks/useChatManagement.d.ts +13 -0
  161. package/dist/types/excalidraw/components/TTDDialog/hooks/useMermaidRenderer.d.ts +14 -0
  162. package/dist/types/excalidraw/components/TTDDialog/hooks/useTextGeneration.d.ts +7 -0
  163. package/dist/types/excalidraw/components/TTDDialog/types.d.ts +95 -0
  164. package/dist/types/excalidraw/components/TTDDialog/useTTDChatStorage.d.ts +22 -0
  165. package/dist/types/excalidraw/components/TTDDialog/utils/TTDStreamFetch.d.ts +24 -0
  166. package/dist/types/excalidraw/components/TTDDialog/utils/chat.d.ts +10 -0
  167. package/dist/types/excalidraw/components/TTDDialog/utils/mermaidValidation.d.ts +1 -0
  168. package/dist/types/excalidraw/components/TextField.d.ts +1 -0
  169. package/dist/types/excalidraw/components/Toast.d.ts +3 -3
  170. package/dist/types/excalidraw/components/ToolPopover.d.ts +25 -0
  171. package/dist/types/excalidraw/components/Trans.d.ts +2 -2
  172. package/dist/types/excalidraw/components/canvases/InteractiveCanvas.d.ts +6 -3
  173. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenu.d.ts +47 -35
  174. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuContent.d.ts +7 -5
  175. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuGroup.d.ts +3 -3
  176. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItem.d.ts +13 -22
  177. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCheckbox.d.ts +5 -0
  178. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContent.d.ts +5 -4
  179. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemContentRadio.d.ts +0 -1
  180. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemCustom.d.ts +2 -2
  181. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuItemLink.d.ts +6 -6
  182. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSub.d.ts +23 -0
  183. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSubContent.d.ts +8 -0
  184. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuSubTrigger.d.ts +12 -0
  185. package/dist/types/excalidraw/components/dropdownMenu/DropdownMenuTrigger.d.ts +3 -4
  186. package/dist/types/excalidraw/components/dropdownMenu/common.d.ts +2 -2
  187. package/dist/types/excalidraw/components/dropdownMenu/dropdownMenuUtils.d.ts +2 -0
  188. package/dist/types/excalidraw/components/hoc/withInternalFallback.d.ts +1 -1
  189. package/dist/types/excalidraw/components/hyperlink/helpers.d.ts +1 -1
  190. package/dist/types/excalidraw/components/icons.d.ts +32 -13
  191. package/dist/types/excalidraw/components/live-collaboration/LiveCollaborationTrigger.d.ts +4 -3
  192. package/dist/types/excalidraw/components/main-menu/DefaultItems.d.ts +17 -2
  193. package/dist/types/excalidraw/components/main-menu/MainMenu.d.ts +39 -35
  194. package/dist/types/excalidraw/components/shapes.d.ts +202 -1
  195. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.Center.d.ts +6 -6
  196. package/dist/types/excalidraw/components/welcome-screen/WelcomeScreen.d.ts +15 -16
  197. package/dist/types/excalidraw/data/blob.d.ts +330 -10
  198. package/dist/types/excalidraw/data/encode.d.ts +4 -4
  199. package/dist/types/excalidraw/data/encryption.d.ts +5 -5
  200. package/dist/types/excalidraw/data/filesystem.d.ts +2 -2
  201. package/dist/types/excalidraw/data/index.d.ts +3 -3
  202. package/dist/types/excalidraw/data/json.d.ts +162 -2
  203. package/dist/types/excalidraw/data/library.d.ts +24 -9
  204. package/dist/types/excalidraw/data/reconcile.d.ts +1 -0
  205. package/dist/types/excalidraw/data/restore.d.ts +27 -7
  206. package/dist/types/excalidraw/data/types.d.ts +4 -1
  207. package/dist/types/excalidraw/editor-jotai.d.ts +11 -11
  208. package/dist/types/excalidraw/errors.d.ts +14 -0
  209. package/dist/types/excalidraw/hooks/useLibraryItemSvg.d.ts +1 -1
  210. package/dist/types/excalidraw/hooks/useOutsideClick.d.ts +4 -3
  211. package/dist/types/excalidraw/hooks/useScrollPosition.d.ts +1 -2
  212. package/dist/types/excalidraw/hooks/useTextEditorFocus.d.ts +14 -0
  213. package/dist/types/excalidraw/i18n.d.ts +2 -2
  214. package/dist/types/excalidraw/index.d.ts +7 -7
  215. package/dist/types/excalidraw/renderer/animation.d.ts +12 -0
  216. package/dist/types/excalidraw/renderer/helpers.d.ts +6 -8
  217. package/dist/types/excalidraw/renderer/interactiveScene.d.ts +8 -14
  218. package/dist/types/excalidraw/renderer/staticScene.d.ts +4 -1
  219. package/dist/types/excalidraw/scene/Renderer.d.ts +5 -2
  220. package/dist/types/excalidraw/scene/export.d.ts +2 -2
  221. package/dist/types/excalidraw/scene/scroll.d.ts +1 -6
  222. package/dist/types/excalidraw/scene/types.d.ts +22 -5
  223. package/dist/types/excalidraw/shortcut.d.ts +1 -0
  224. package/dist/types/excalidraw/snapping.d.ts +5 -5
  225. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-bindings.d.ts +1 -1
  226. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-loader.d.ts +1 -1
  227. package/dist/types/excalidraw/subset/harfbuzz/harfbuzz-wasm.d.ts +1 -1
  228. package/dist/types/excalidraw/subset/woff2/woff2-loader.d.ts +2 -2
  229. package/dist/types/excalidraw/subset/woff2/woff2-wasm.d.ts +1 -1
  230. package/dist/types/excalidraw/types.d.ts +44 -25
  231. package/dist/types/excalidraw/wysiwyg/textWysiwyg.d.ts +2 -2
  232. package/dist/types/math/src/point.d.ts +6 -1
  233. package/dist/types/math/src/polygon.d.ts +2 -2
  234. package/dist/types/math/src/range.d.ts +1 -3
  235. package/dist/types/math/src/segment.d.ts +4 -3
  236. package/dist/types/math/src/types.d.ts +25 -1
  237. package/dist/types/utils/src/bbox.d.ts +1 -1
  238. package/dist/types/utils/src/export.d.ts +5 -5
  239. package/dist/types/utils/src/shape.d.ts +6 -6
  240. package/dist/types/utils/src/withinBounds.d.ts +2 -2
  241. 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,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/open-color/open-color.json
371
- var open_color_default = {
372
- white: "#ffffff",
373
- black: "#000000",
374
- gray: [
375
- "#f8f9fa",
376
- "#f1f3f5",
377
- "#e9ecef",
378
- "#dee2e6",
379
- "#ced4da",
380
- "#adb5bd",
381
- "#868e96",
382
- "#495057",
383
- "#343a40",
384
- "#212529"
385
- ],
386
- red: [
387
- "#fff5f5",
388
- "#ffe3e3",
389
- "#ffc9c9",
390
- "#ffa8a8",
391
- "#ff8787",
392
- "#ff6b6b",
393
- "#fa5252",
394
- "#f03e3e",
395
- "#e03131",
396
- "#c92a2a"
397
- ],
398
- pink: [
399
- "#fff0f6",
400
- "#ffdeeb",
401
- "#fcc2d7",
402
- "#faa2c1",
403
- "#f783ac",
404
- "#f06595",
405
- "#e64980",
406
- "#d6336c",
407
- "#c2255c",
408
- "#a61e4d"
409
- ],
410
- grape: [
411
- "#f8f0fc",
412
- "#f3d9fa",
413
- "#eebefa",
414
- "#e599f7",
415
- "#da77f2",
416
- "#cc5de8",
417
- "#be4bdb",
418
- "#ae3ec9",
419
- "#9c36b5",
420
- "#862e9c"
421
- ],
422
- violet: [
423
- "#f3f0ff",
424
- "#e5dbff",
425
- "#d0bfff",
426
- "#b197fc",
427
- "#9775fa",
428
- "#845ef7",
429
- "#7950f2",
430
- "#7048e8",
431
- "#6741d9",
432
- "#5f3dc4"
433
- ],
434
- indigo: [
435
- "#edf2ff",
436
- "#dbe4ff",
437
- "#bac8ff",
438
- "#91a7ff",
439
- "#748ffc",
440
- "#5c7cfa",
441
- "#4c6ef5",
442
- "#4263eb",
443
- "#3b5bdb",
444
- "#364fc7"
445
- ],
446
- blue: [
447
- "#e7f5ff",
448
- "#d0ebff",
449
- "#a5d8ff",
450
- "#74c0fc",
451
- "#4dabf7",
452
- "#339af0",
453
- "#228be6",
454
- "#1c7ed6",
455
- "#1971c2",
456
- "#1864ab"
457
- ],
458
- cyan: [
459
- "#e3fafc",
460
- "#c5f6fa",
461
- "#99e9f2",
462
- "#66d9e8",
463
- "#3bc9db",
464
- "#22b8cf",
465
- "#15aabf",
466
- "#1098ad",
467
- "#0c8599",
468
- "#0b7285"
469
- ],
470
- teal: [
471
- "#e6fcf5",
472
- "#c3fae8",
473
- "#96f2d7",
474
- "#63e6be",
475
- "#38d9a9",
476
- "#20c997",
477
- "#12b886",
478
- "#0ca678",
479
- "#099268",
480
- "#087f5b"
481
- ],
482
- green: [
483
- "#ebfbee",
484
- "#d3f9d8",
485
- "#b2f2bb",
486
- "#8ce99a",
487
- "#69db7c",
488
- "#51cf66",
489
- "#40c057",
490
- "#37b24d",
491
- "#2f9e44",
492
- "#2b8a3e"
493
- ],
494
- lime: [
495
- "#f4fce3",
496
- "#e9fac8",
497
- "#d8f5a2",
498
- "#c0eb75",
499
- "#a9e34b",
500
- "#94d82d",
501
- "#82c91e",
502
- "#74b816",
503
- "#66a80f",
504
- "#5c940d"
505
- ],
506
- yellow: [
507
- "#fff9db",
508
- "#fff3bf",
509
- "#ffec99",
510
- "#ffe066",
511
- "#ffd43b",
512
- "#fcc419",
513
- "#fab005",
514
- "#f59f00",
515
- "#f08c00",
516
- "#e67700"
517
- ],
518
- orange: [
519
- "#fff4e6",
520
- "#ffe8cc",
521
- "#ffd8a8",
522
- "#ffc078",
523
- "#ffa94d",
524
- "#ff922b",
525
- "#fd7e14",
526
- "#f76707",
527
- "#e8590c",
528
- "#d9480f"
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
- var COLOR_OUTLINE_CONTRAST_THRESHOLD = 240;
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-colors
557
- gray: getSpecificColorShades("gray", ELEMENTS_PALETTE_SHADE_INDEXES),
558
- red: getSpecificColorShades("red", ELEMENTS_PALETTE_SHADE_INDEXES),
559
- pink: getSpecificColorShades("pink", ELEMENTS_PALETTE_SHADE_INDEXES),
560
- grape: getSpecificColorShades("grape", ELEMENTS_PALETTE_SHADE_INDEXES),
561
- violet: getSpecificColorShades("violet", ELEMENTS_PALETTE_SHADE_INDEXES),
562
- blue: getSpecificColorShades("blue", ELEMENTS_PALETTE_SHADE_INDEXES),
563
- cyan: getSpecificColorShades("cyan", ELEMENTS_PALETTE_SHADE_INDEXES),
564
- teal: getSpecificColorShades("teal", ELEMENTS_PALETTE_SHADE_INDEXES),
565
- green: getSpecificColorShades("green", ELEMENTS_PALETTE_SHADE_INDEXES),
566
- yellow: getSpecificColorShades("yellow", ELEMENTS_PALETTE_SHADE_INDEXES),
567
- orange: getSpecificColorShades("orange", ELEMENTS_PALETTE_SHADE_INDEXES),
568
- // radix bronze shades 3,5,7,9,11
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 rgbToHex = (r, g, b) => `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1)}`;
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 MIME_TYPES = {
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
- var toBrandedType = (value) => {
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
- MQ_MAX_WIDTH_PORTRAIT,
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
- isBindingFallthroughEnabled,
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,