@zsviczian/excalidraw 0.18.0-64 → 0.18.0-66

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.
@@ -19,17 +19,6 @@
19
19
  return /******/ (() => { // webpackBootstrap
20
20
  /******/ var __webpack_modules__ = ({
21
21
 
22
- /***/ "../../node_modules/@babel/runtime/helpers/esm/extends.js":
23
- /*!****************************************************************!*\
24
- !*** ../../node_modules/@babel/runtime/helpers/esm/extends.js ***!
25
- \****************************************************************/
26
- /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
27
-
28
- "use strict";
29
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ _extends)\n/* harmony export */ });\nfunction _extends() {\n return _extends = Object.assign ? Object.assign.bind() : function (n) {\n for (var e = 1; e < arguments.length; e++) {\n var t = arguments[e];\n for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);\n }\n return n;\n }, _extends.apply(null, arguments);\n}\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/@babel/runtime/helpers/esm/extends.js?");
30
-
31
- /***/ }),
32
-
33
22
  /***/ "../../node_modules/@braintree/sanitize-url/dist/index.js":
34
23
  /*!****************************************************************!*\
35
24
  !*** ../../node_modules/@braintree/sanitize-url/dist/index.js ***!
@@ -268,18 +257,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
268
257
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
269
258
 
270
259
  "use strict";
271
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Item: () => (/* binding */ Item),\n/* harmony export */ Root: () => (/* binding */ Root),\n/* harmony export */ RovingFocusGroup: () => (/* binding */ RovingFocusGroup),\n/* harmony export */ RovingFocusGroupItem: () => (/* binding */ RovingFocusGroupItem),\n/* harmony export */ createRovingFocusGroupScope: () => (/* binding */ createRovingFocusGroupScope)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var _radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @radix-ui/primitive */ \"../../node_modules/@radix-ui/primitive/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_collection__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @radix-ui/react-collection */ \"../../node_modules/@radix-ui/react-collection/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_compose_refs__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @radix-ui/react-compose-refs */ \"../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-compose-refs/dist/index.module.js\");\n/* harmony import */ var _radix_ui_react_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @radix-ui/react-context */ \"../../node_modules/@radix-ui/react-context/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_id__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! @radix-ui/react-id */ \"../../node_modules/@radix-ui/react-id/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! @radix-ui/react-primitive */ \"../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-primitive/dist/index.module.js\");\n/* harmony import */ var _radix_ui_react_use_callback_ref__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @radix-ui/react-use-callback-ref */ \"../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-use-callback-ref/dist/index.module.js\");\n/* harmony import */ var _radix_ui_react_use_controllable_state__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @radix-ui/react-use-controllable-state */ \"../../node_modules/@radix-ui/react-use-controllable-state/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_direction__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @radix-ui/react-direction */ \"../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-direction/dist/index.mjs\");\n/* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react/jsx-runtime */ \"react/jsx-runtime\");\n\"use client\";\n\n// packages/react/roving-focus/src/roving-focus-group.tsx\n\n\n\n\n\n\n\n\n\n\n\nvar ENTRY_FOCUS = \"rovingFocusGroup.onEntryFocus\";\nvar EVENT_OPTIONS = { bubbles: false, cancelable: true };\nvar GROUP_NAME = \"RovingFocusGroup\";\nvar [Collection, useCollection, createCollectionScope] = (0,_radix_ui_react_collection__WEBPACK_IMPORTED_MODULE_2__.createCollection)(GROUP_NAME);\nvar [createRovingFocusGroupContext, createRovingFocusGroupScope] = (0,_radix_ui_react_context__WEBPACK_IMPORTED_MODULE_3__.createContextScope)(\n GROUP_NAME,\n [createCollectionScope]\n);\nvar [RovingFocusProvider, useRovingFocusContext] = createRovingFocusGroupContext(GROUP_NAME);\nvar RovingFocusGroup = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(Collection.Provider, { scope: props.__scopeRovingFocusGroup, children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(Collection.Slot, { scope: props.__scopeRovingFocusGroup, children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(RovingFocusGroupImpl, { ...props, ref: forwardedRef }) }) });\n }\n);\nRovingFocusGroup.displayName = GROUP_NAME;\nvar RovingFocusGroupImpl = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef((props, forwardedRef) => {\n const {\n __scopeRovingFocusGroup,\n orientation,\n loop = false,\n dir,\n currentTabStopId: currentTabStopIdProp,\n defaultCurrentTabStopId,\n onCurrentTabStopIdChange,\n onEntryFocus,\n preventScrollOnEntryFocus = false,\n ...groupProps\n } = props;\n const ref = react__WEBPACK_IMPORTED_MODULE_0__.useRef(null);\n const composedRefs = (0,_radix_ui_react_compose_refs__WEBPACK_IMPORTED_MODULE_4__.useComposedRefs)(forwardedRef, ref);\n const direction = (0,_radix_ui_react_direction__WEBPACK_IMPORTED_MODULE_5__.useDirection)(dir);\n const [currentTabStopId = null, setCurrentTabStopId] = (0,_radix_ui_react_use_controllable_state__WEBPACK_IMPORTED_MODULE_6__.useControllableState)({\n prop: currentTabStopIdProp,\n defaultProp: defaultCurrentTabStopId,\n onChange: onCurrentTabStopIdChange\n });\n const [isTabbingBackOut, setIsTabbingBackOut] = react__WEBPACK_IMPORTED_MODULE_0__.useState(false);\n const handleEntryFocus = (0,_radix_ui_react_use_callback_ref__WEBPACK_IMPORTED_MODULE_7__.useCallbackRef)(onEntryFocus);\n const getItems = useCollection(__scopeRovingFocusGroup);\n const isClickFocusRef = react__WEBPACK_IMPORTED_MODULE_0__.useRef(false);\n const [focusableItemsCount, setFocusableItemsCount] = react__WEBPACK_IMPORTED_MODULE_0__.useState(0);\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(() => {\n const node = ref.current;\n if (node) {\n node.addEventListener(ENTRY_FOCUS, handleEntryFocus);\n return () => node.removeEventListener(ENTRY_FOCUS, handleEntryFocus);\n }\n }, [handleEntryFocus]);\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n RovingFocusProvider,\n {\n scope: __scopeRovingFocusGroup,\n orientation,\n dir: direction,\n loop,\n currentTabStopId,\n onItemFocus: react__WEBPACK_IMPORTED_MODULE_0__.useCallback(\n (tabStopId) => setCurrentTabStopId(tabStopId),\n [setCurrentTabStopId]\n ),\n onItemShiftTab: react__WEBPACK_IMPORTED_MODULE_0__.useCallback(() => setIsTabbingBackOut(true), []),\n onFocusableItemAdd: react__WEBPACK_IMPORTED_MODULE_0__.useCallback(\n () => setFocusableItemsCount((prevCount) => prevCount + 1),\n []\n ),\n onFocusableItemRemove: react__WEBPACK_IMPORTED_MODULE_0__.useCallback(\n () => setFocusableItemsCount((prevCount) => prevCount - 1),\n []\n ),\n children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_8__.Primitive.div,\n {\n tabIndex: isTabbingBackOut || focusableItemsCount === 0 ? -1 : 0,\n \"data-orientation\": orientation,\n ...groupProps,\n ref: composedRefs,\n style: { outline: \"none\", ...props.style },\n onMouseDown: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onMouseDown, () => {\n isClickFocusRef.current = true;\n }),\n onFocus: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onFocus, (event) => {\n const isKeyboardFocus = !isClickFocusRef.current;\n if (event.target === event.currentTarget && isKeyboardFocus && !isTabbingBackOut) {\n const entryFocusEvent = new CustomEvent(ENTRY_FOCUS, EVENT_OPTIONS);\n event.currentTarget.dispatchEvent(entryFocusEvent);\n if (!entryFocusEvent.defaultPrevented) {\n const items = getItems().filter((item) => item.focusable);\n const activeItem = items.find((item) => item.active);\n const currentItem = items.find((item) => item.id === currentTabStopId);\n const candidateItems = [activeItem, currentItem, ...items].filter(\n Boolean\n );\n const candidateNodes = candidateItems.map((item) => item.ref.current);\n focusFirst(candidateNodes, preventScrollOnEntryFocus);\n }\n }\n isClickFocusRef.current = false;\n }),\n onBlur: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onBlur, () => setIsTabbingBackOut(false))\n }\n )\n }\n );\n});\nvar ITEM_NAME = \"RovingFocusGroupItem\";\nvar RovingFocusGroupItem = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeRovingFocusGroup,\n focusable = true,\n active = false,\n tabStopId,\n ...itemProps\n } = props;\n const autoId = (0,_radix_ui_react_id__WEBPACK_IMPORTED_MODULE_10__.useId)();\n const id = tabStopId || autoId;\n const context = useRovingFocusContext(ITEM_NAME, __scopeRovingFocusGroup);\n const isCurrentTabStop = context.currentTabStopId === id;\n const getItems = useCollection(__scopeRovingFocusGroup);\n const { onFocusableItemAdd, onFocusableItemRemove } = context;\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(() => {\n if (focusable) {\n onFocusableItemAdd();\n return () => onFocusableItemRemove();\n }\n }, [focusable, onFocusableItemAdd, onFocusableItemRemove]);\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n Collection.ItemSlot,\n {\n scope: __scopeRovingFocusGroup,\n id,\n focusable,\n active,\n children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_8__.Primitive.span,\n {\n tabIndex: isCurrentTabStop ? 0 : -1,\n \"data-orientation\": context.orientation,\n ...itemProps,\n ref: forwardedRef,\n onMouseDown: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onMouseDown, (event) => {\n if (!focusable) event.preventDefault();\n else context.onItemFocus(id);\n }),\n onFocus: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onFocus, () => context.onItemFocus(id)),\n onKeyDown: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onKeyDown, (event) => {\n if (event.key === \"Tab\" && event.shiftKey) {\n context.onItemShiftTab();\n return;\n }\n if (event.target !== event.currentTarget) return;\n const focusIntent = getFocusIntent(event, context.orientation, context.dir);\n if (focusIntent !== void 0) {\n if (event.metaKey || event.ctrlKey || event.altKey || event.shiftKey) return;\n event.preventDefault();\n const items = getItems().filter((item) => item.focusable);\n let candidateNodes = items.map((item) => item.ref.current);\n if (focusIntent === \"last\") candidateNodes.reverse();\n else if (focusIntent === \"prev\" || focusIntent === \"next\") {\n if (focusIntent === \"prev\") candidateNodes.reverse();\n const currentIndex = candidateNodes.indexOf(event.currentTarget);\n candidateNodes = context.loop ? wrapArray(candidateNodes, currentIndex + 1) : candidateNodes.slice(currentIndex + 1);\n }\n setTimeout(() => focusFirst(candidateNodes));\n }\n })\n }\n )\n }\n );\n }\n);\nRovingFocusGroupItem.displayName = ITEM_NAME;\nvar MAP_KEY_TO_FOCUS_INTENT = {\n ArrowLeft: \"prev\",\n ArrowUp: \"prev\",\n ArrowRight: \"next\",\n ArrowDown: \"next\",\n PageUp: \"first\",\n Home: \"first\",\n PageDown: \"last\",\n End: \"last\"\n};\nfunction getDirectionAwareKey(key, dir) {\n if (dir !== \"rtl\") return key;\n return key === \"ArrowLeft\" ? \"ArrowRight\" : key === \"ArrowRight\" ? \"ArrowLeft\" : key;\n}\nfunction getFocusIntent(event, orientation, dir) {\n const key = getDirectionAwareKey(event.key, dir);\n if (orientation === \"vertical\" && [\"ArrowLeft\", \"ArrowRight\"].includes(key)) return void 0;\n if (orientation === \"horizontal\" && [\"ArrowUp\", \"ArrowDown\"].includes(key)) return void 0;\n return MAP_KEY_TO_FOCUS_INTENT[key];\n}\nfunction focusFirst(candidates, preventScroll = false) {\n const PREVIOUSLY_FOCUSED_ELEMENT = document.activeElement;\n for (const candidate of candidates) {\n if (candidate === PREVIOUSLY_FOCUSED_ELEMENT) return;\n candidate.focus({ preventScroll });\n if (document.activeElement !== PREVIOUSLY_FOCUSED_ELEMENT) return;\n }\n}\nfunction wrapArray(array, startIndex) {\n return array.map((_, index) => array[(startIndex + index) % array.length]);\n}\nvar Root = RovingFocusGroup;\nvar Item = RovingFocusGroupItem;\n\n//# sourceMappingURL=index.mjs.map\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/@radix-ui/react-roving-focus/dist/index.mjs?");
272
-
273
- /***/ }),
274
-
275
- /***/ "../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-compose-refs/dist/index.module.js":
276
- /*!**********************************************************************************************************************!*\
277
- !*** ../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-compose-refs/dist/index.module.js ***!
278
- \**********************************************************************************************************************/
279
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
280
-
281
- "use strict";
282
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ composeRefs: () => (/* binding */ $6ed0406888f73fc4$export$43e446d32b3d21af),\n/* harmony export */ useComposedRefs: () => (/* binding */ $6ed0406888f73fc4$export$c7b2cbe3552a0d05)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n\n\n\n/**\n * Set a given ref to a given value\n * This utility takes care of different types of refs: callback refs and RefObject(s)\n */ function $6ed0406888f73fc4$var$setRef(ref, value) {\n if (typeof ref === 'function') ref(value);\n else if (ref !== null && ref !== undefined) ref.current = value;\n}\n/**\n * A utility to compose multiple refs together\n * Accepts callback refs and RefObject(s)\n */ function $6ed0406888f73fc4$export$43e446d32b3d21af(...refs) {\n return (node)=>refs.forEach((ref)=>$6ed0406888f73fc4$var$setRef(ref, node)\n )\n ;\n}\n/**\n * A custom hook that composes multiple refs\n * Accepts callback refs and RefObject(s)\n */ function $6ed0406888f73fc4$export$c7b2cbe3552a0d05(...refs) {\n // eslint-disable-next-line react-hooks/exhaustive-deps\n return (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)($6ed0406888f73fc4$export$43e446d32b3d21af(...refs), refs);\n}\n\n\n\n\n\n//# sourceMappingURL=index.module.js.map\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-compose-refs/dist/index.module.js?");
260
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Item: () => (/* binding */ Item),\n/* harmony export */ Root: () => (/* binding */ Root),\n/* harmony export */ RovingFocusGroup: () => (/* binding */ RovingFocusGroup),\n/* harmony export */ RovingFocusGroupItem: () => (/* binding */ RovingFocusGroupItem),\n/* harmony export */ createRovingFocusGroupScope: () => (/* binding */ createRovingFocusGroupScope)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var _radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @radix-ui/primitive */ \"../../node_modules/@radix-ui/primitive/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_collection__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @radix-ui/react-collection */ \"../../node_modules/@radix-ui/react-collection/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_compose_refs__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @radix-ui/react-compose-refs */ \"../../node_modules/@radix-ui/react-compose-refs/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @radix-ui/react-context */ \"../../node_modules/@radix-ui/react-context/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_id__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! @radix-ui/react-id */ \"../../node_modules/@radix-ui/react-id/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! @radix-ui/react-primitive */ \"../../node_modules/@radix-ui/react-primitive/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_use_callback_ref__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @radix-ui/react-use-callback-ref */ \"../../node_modules/@radix-ui/react-use-callback-ref/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_use_controllable_state__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @radix-ui/react-use-controllable-state */ \"../../node_modules/@radix-ui/react-use-controllable-state/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_direction__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @radix-ui/react-direction */ \"../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-direction/dist/index.mjs\");\n/* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react/jsx-runtime */ \"react/jsx-runtime\");\n\"use client\";\n\n// packages/react/roving-focus/src/roving-focus-group.tsx\n\n\n\n\n\n\n\n\n\n\n\nvar ENTRY_FOCUS = \"rovingFocusGroup.onEntryFocus\";\nvar EVENT_OPTIONS = { bubbles: false, cancelable: true };\nvar GROUP_NAME = \"RovingFocusGroup\";\nvar [Collection, useCollection, createCollectionScope] = (0,_radix_ui_react_collection__WEBPACK_IMPORTED_MODULE_2__.createCollection)(GROUP_NAME);\nvar [createRovingFocusGroupContext, createRovingFocusGroupScope] = (0,_radix_ui_react_context__WEBPACK_IMPORTED_MODULE_3__.createContextScope)(\n GROUP_NAME,\n [createCollectionScope]\n);\nvar [RovingFocusProvider, useRovingFocusContext] = createRovingFocusGroupContext(GROUP_NAME);\nvar RovingFocusGroup = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(Collection.Provider, { scope: props.__scopeRovingFocusGroup, children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(Collection.Slot, { scope: props.__scopeRovingFocusGroup, children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(RovingFocusGroupImpl, { ...props, ref: forwardedRef }) }) });\n }\n);\nRovingFocusGroup.displayName = GROUP_NAME;\nvar RovingFocusGroupImpl = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef((props, forwardedRef) => {\n const {\n __scopeRovingFocusGroup,\n orientation,\n loop = false,\n dir,\n currentTabStopId: currentTabStopIdProp,\n defaultCurrentTabStopId,\n onCurrentTabStopIdChange,\n onEntryFocus,\n preventScrollOnEntryFocus = false,\n ...groupProps\n } = props;\n const ref = react__WEBPACK_IMPORTED_MODULE_0__.useRef(null);\n const composedRefs = (0,_radix_ui_react_compose_refs__WEBPACK_IMPORTED_MODULE_4__.useComposedRefs)(forwardedRef, ref);\n const direction = (0,_radix_ui_react_direction__WEBPACK_IMPORTED_MODULE_5__.useDirection)(dir);\n const [currentTabStopId = null, setCurrentTabStopId] = (0,_radix_ui_react_use_controllable_state__WEBPACK_IMPORTED_MODULE_6__.useControllableState)({\n prop: currentTabStopIdProp,\n defaultProp: defaultCurrentTabStopId,\n onChange: onCurrentTabStopIdChange\n });\n const [isTabbingBackOut, setIsTabbingBackOut] = react__WEBPACK_IMPORTED_MODULE_0__.useState(false);\n const handleEntryFocus = (0,_radix_ui_react_use_callback_ref__WEBPACK_IMPORTED_MODULE_7__.useCallbackRef)(onEntryFocus);\n const getItems = useCollection(__scopeRovingFocusGroup);\n const isClickFocusRef = react__WEBPACK_IMPORTED_MODULE_0__.useRef(false);\n const [focusableItemsCount, setFocusableItemsCount] = react__WEBPACK_IMPORTED_MODULE_0__.useState(0);\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(() => {\n const node = ref.current;\n if (node) {\n node.addEventListener(ENTRY_FOCUS, handleEntryFocus);\n return () => node.removeEventListener(ENTRY_FOCUS, handleEntryFocus);\n }\n }, [handleEntryFocus]);\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n RovingFocusProvider,\n {\n scope: __scopeRovingFocusGroup,\n orientation,\n dir: direction,\n loop,\n currentTabStopId,\n onItemFocus: react__WEBPACK_IMPORTED_MODULE_0__.useCallback(\n (tabStopId) => setCurrentTabStopId(tabStopId),\n [setCurrentTabStopId]\n ),\n onItemShiftTab: react__WEBPACK_IMPORTED_MODULE_0__.useCallback(() => setIsTabbingBackOut(true), []),\n onFocusableItemAdd: react__WEBPACK_IMPORTED_MODULE_0__.useCallback(\n () => setFocusableItemsCount((prevCount) => prevCount + 1),\n []\n ),\n onFocusableItemRemove: react__WEBPACK_IMPORTED_MODULE_0__.useCallback(\n () => setFocusableItemsCount((prevCount) => prevCount - 1),\n []\n ),\n children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_8__.Primitive.div,\n {\n tabIndex: isTabbingBackOut || focusableItemsCount === 0 ? -1 : 0,\n \"data-orientation\": orientation,\n ...groupProps,\n ref: composedRefs,\n style: { outline: \"none\", ...props.style },\n onMouseDown: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onMouseDown, () => {\n isClickFocusRef.current = true;\n }),\n onFocus: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onFocus, (event) => {\n const isKeyboardFocus = !isClickFocusRef.current;\n if (event.target === event.currentTarget && isKeyboardFocus && !isTabbingBackOut) {\n const entryFocusEvent = new CustomEvent(ENTRY_FOCUS, EVENT_OPTIONS);\n event.currentTarget.dispatchEvent(entryFocusEvent);\n if (!entryFocusEvent.defaultPrevented) {\n const items = getItems().filter((item) => item.focusable);\n const activeItem = items.find((item) => item.active);\n const currentItem = items.find((item) => item.id === currentTabStopId);\n const candidateItems = [activeItem, currentItem, ...items].filter(\n Boolean\n );\n const candidateNodes = candidateItems.map((item) => item.ref.current);\n focusFirst(candidateNodes, preventScrollOnEntryFocus);\n }\n }\n isClickFocusRef.current = false;\n }),\n onBlur: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onBlur, () => setIsTabbingBackOut(false))\n }\n )\n }\n );\n});\nvar ITEM_NAME = \"RovingFocusGroupItem\";\nvar RovingFocusGroupItem = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeRovingFocusGroup,\n focusable = true,\n active = false,\n tabStopId,\n ...itemProps\n } = props;\n const autoId = (0,_radix_ui_react_id__WEBPACK_IMPORTED_MODULE_10__.useId)();\n const id = tabStopId || autoId;\n const context = useRovingFocusContext(ITEM_NAME, __scopeRovingFocusGroup);\n const isCurrentTabStop = context.currentTabStopId === id;\n const getItems = useCollection(__scopeRovingFocusGroup);\n const { onFocusableItemAdd, onFocusableItemRemove } = context;\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(() => {\n if (focusable) {\n onFocusableItemAdd();\n return () => onFocusableItemRemove();\n }\n }, [focusable, onFocusableItemAdd, onFocusableItemRemove]);\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n Collection.ItemSlot,\n {\n scope: __scopeRovingFocusGroup,\n id,\n focusable,\n active,\n children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_8__.Primitive.span,\n {\n tabIndex: isCurrentTabStop ? 0 : -1,\n \"data-orientation\": context.orientation,\n ...itemProps,\n ref: forwardedRef,\n onMouseDown: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onMouseDown, (event) => {\n if (!focusable) event.preventDefault();\n else context.onItemFocus(id);\n }),\n onFocus: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onFocus, () => context.onItemFocus(id)),\n onKeyDown: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_9__.composeEventHandlers)(props.onKeyDown, (event) => {\n if (event.key === \"Tab\" && event.shiftKey) {\n context.onItemShiftTab();\n return;\n }\n if (event.target !== event.currentTarget) return;\n const focusIntent = getFocusIntent(event, context.orientation, context.dir);\n if (focusIntent !== void 0) {\n if (event.metaKey || event.ctrlKey || event.altKey || event.shiftKey) return;\n event.preventDefault();\n const items = getItems().filter((item) => item.focusable);\n let candidateNodes = items.map((item) => item.ref.current);\n if (focusIntent === \"last\") candidateNodes.reverse();\n else if (focusIntent === \"prev\" || focusIntent === \"next\") {\n if (focusIntent === \"prev\") candidateNodes.reverse();\n const currentIndex = candidateNodes.indexOf(event.currentTarget);\n candidateNodes = context.loop ? wrapArray(candidateNodes, currentIndex + 1) : candidateNodes.slice(currentIndex + 1);\n }\n setTimeout(() => focusFirst(candidateNodes));\n }\n })\n }\n )\n }\n );\n }\n);\nRovingFocusGroupItem.displayName = ITEM_NAME;\nvar MAP_KEY_TO_FOCUS_INTENT = {\n ArrowLeft: \"prev\",\n ArrowUp: \"prev\",\n ArrowRight: \"next\",\n ArrowDown: \"next\",\n PageUp: \"first\",\n Home: \"first\",\n PageDown: \"last\",\n End: \"last\"\n};\nfunction getDirectionAwareKey(key, dir) {\n if (dir !== \"rtl\") return key;\n return key === \"ArrowLeft\" ? \"ArrowRight\" : key === \"ArrowRight\" ? \"ArrowLeft\" : key;\n}\nfunction getFocusIntent(event, orientation, dir) {\n const key = getDirectionAwareKey(event.key, dir);\n if (orientation === \"vertical\" && [\"ArrowLeft\", \"ArrowRight\"].includes(key)) return void 0;\n if (orientation === \"horizontal\" && [\"ArrowUp\", \"ArrowDown\"].includes(key)) return void 0;\n return MAP_KEY_TO_FOCUS_INTENT[key];\n}\nfunction focusFirst(candidates, preventScroll = false) {\n const PREVIOUSLY_FOCUSED_ELEMENT = document.activeElement;\n for (const candidate of candidates) {\n if (candidate === PREVIOUSLY_FOCUSED_ELEMENT) return;\n candidate.focus({ preventScroll });\n if (document.activeElement !== PREVIOUSLY_FOCUSED_ELEMENT) return;\n }\n}\nfunction wrapArray(array, startIndex) {\n return array.map((_, index) => array[(startIndex + index) % array.length]);\n}\nvar Root = RovingFocusGroup;\nvar Item = RovingFocusGroupItem;\n\n//# sourceMappingURL=index.mjs.map\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/@radix-ui/react-roving-focus/dist/index.mjs?");
283
261
 
284
262
  /***/ }),
285
263
 
@@ -294,28 +272,6 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
294
272
 
295
273
  /***/ }),
296
274
 
297
- /***/ "../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-primitive/dist/index.module.js":
298
- /*!*******************************************************************************************************************!*\
299
- !*** ../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-primitive/dist/index.module.js ***!
300
- \*******************************************************************************************************************/
301
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
302
-
303
- "use strict";
304
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Primitive: () => (/* binding */ $8927f6f2acc4f386$export$250ffa63cdc0d034),\n/* harmony export */ Root: () => (/* binding */ $8927f6f2acc4f386$export$be92b6f5f03c0fe9),\n/* harmony export */ dispatchDiscreteCustomEvent: () => (/* binding */ $8927f6f2acc4f386$export$6d1a0317bde7de7f)\n/* harmony export */ });\n/* harmony import */ var _babel_runtime_helpers_esm_extends__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/extends */ \"../../node_modules/@babel/runtime/helpers/esm/extends.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react-dom */ \"react-dom\");\n/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react_dom__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _radix_ui_react_slot__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @radix-ui/react-slot */ \"../../node_modules/@radix-ui/react-slot/dist/index.mjs\");\n\n\n\n\n\n\n\n\n\nconst $8927f6f2acc4f386$var$NODES = [\n 'a',\n 'button',\n 'div',\n 'h2',\n 'h3',\n 'img',\n 'label',\n 'li',\n 'nav',\n 'ol',\n 'p',\n 'span',\n 'svg',\n 'ul'\n]; // Temporary while we await merge of this fix:\n// https://github.com/DefinitelyTyped/DefinitelyTyped/pull/55396\n// prettier-ignore\n/* -------------------------------------------------------------------------------------------------\n * Primitive\n * -----------------------------------------------------------------------------------------------*/ const $8927f6f2acc4f386$export$250ffa63cdc0d034 = $8927f6f2acc4f386$var$NODES.reduce((primitive, node)=>{\n const Node = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_1__.forwardRef)((props, forwardedRef)=>{\n const { asChild: asChild , ...primitiveProps } = props;\n const Comp = asChild ? _radix_ui_react_slot__WEBPACK_IMPORTED_MODULE_3__.Slot : node;\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n window[Symbol.for('radix-ui')] = true;\n }, []);\n return /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_1__.createElement)(Comp, (0,_babel_runtime_helpers_esm_extends__WEBPACK_IMPORTED_MODULE_0__[\"default\"])({}, primitiveProps, {\n ref: forwardedRef\n }));\n });\n Node.displayName = `Primitive.${node}`;\n return {\n ...primitive,\n [node]: Node\n };\n}, {});\n/* -------------------------------------------------------------------------------------------------\n * Utils\n * -----------------------------------------------------------------------------------------------*/ /**\n * Flush custom event dispatch\n * https://github.com/radix-ui/primitives/pull/1378\n *\n * React batches *all* event handlers since version 18, this introduces certain considerations when using custom event types.\n *\n * Internally, React prioritises events in the following order:\n * - discrete\n * - continuous\n * - default\n *\n * https://github.com/facebook/react/blob/a8a4742f1c54493df00da648a3f9d26e3db9c8b5/packages/react-dom/src/events/ReactDOMEventListener.js#L294-L350\n *\n * `discrete` is an important distinction as updates within these events are applied immediately.\n * React however, is not able to infer the priority of custom event types due to how they are detected internally.\n * Because of this, it's possible for updates from custom events to be unexpectedly batched when\n * dispatched by another `discrete` event.\n *\n * In order to ensure that updates from custom events are applied predictably, we need to manually flush the batch.\n * This utility should be used when dispatching a custom event from within another `discrete` event, this utility\n * is not nessesary when dispatching known event types, or if dispatching a custom type inside a non-discrete event.\n * For example:\n *\n * dispatching a known click 👎\n * target.dispatchEvent(new Event(‘click’))\n *\n * dispatching a custom type within a non-discrete event 👎\n * onScroll={(event) => event.target.dispatchEvent(new CustomEvent(‘customType’))}\n *\n * dispatching a custom type within a `discrete` event 👍\n * onPointerDown={(event) => dispatchDiscreteCustomEvent(event.target, new CustomEvent(‘customType’))}\n *\n * Note: though React classifies `focus`, `focusin` and `focusout` events as `discrete`, it's not recommended to use\n * this utility with them. This is because it's possible for those handlers to be called implicitly during render\n * e.g. when focus is within a component as it is unmounted, or when managing focus on mount.\n */ function $8927f6f2acc4f386$export$6d1a0317bde7de7f(target, event) {\n if (target) (0,react_dom__WEBPACK_IMPORTED_MODULE_2__.flushSync)(()=>target.dispatchEvent(event)\n );\n}\n/* -----------------------------------------------------------------------------------------------*/ const $8927f6f2acc4f386$export$be92b6f5f03c0fe9 = $8927f6f2acc4f386$export$250ffa63cdc0d034;\n\n\n\n\n\n//# sourceMappingURL=index.module.js.map\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-primitive/dist/index.module.js?");
305
-
306
- /***/ }),
307
-
308
- /***/ "../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-use-callback-ref/dist/index.module.js":
309
- /*!**************************************************************************************************************************!*\
310
- !*** ../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-use-callback-ref/dist/index.module.js ***!
311
- \**************************************************************************************************************************/
312
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
313
-
314
- "use strict";
315
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useCallbackRef: () => (/* binding */ $b1b2314f5f9a1d84$export$25bec8c6f54ee79a)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n\n\n\n/**\n * A custom hook that converts a callback to a ref to avoid triggering re-renders when passed as a\n * prop or avoid re-executing effects when passed as a dependency\n */ function $b1b2314f5f9a1d84$export$25bec8c6f54ee79a(callback) {\n const callbackRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(callback);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n callbackRef.current = callback;\n }); // https://github.com/facebook/react/issues/19240\n return (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(()=>(...args)=>{\n var _callbackRef$current;\n return (_callbackRef$current = callbackRef.current) === null || _callbackRef$current === void 0 ? void 0 : _callbackRef$current.call(callbackRef, ...args);\n }\n , []);\n}\n\n\n\n\n\n//# sourceMappingURL=index.module.js.map\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/@radix-ui/react-roving-focus/node_modules/@radix-ui/react-use-callback-ref/dist/index.module.js?");
316
-
317
- /***/ }),
318
-
319
275
  /***/ "../../node_modules/@radix-ui/react-slot/dist/index.mjs":
320
276
  /*!**************************************************************!*\
321
277
  !*** ../../node_modules/@radix-ui/react-slot/dist/index.mjs ***!
@@ -334,7 +290,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
334
290
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
335
291
 
336
292
  "use strict";
337
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Content: () => (/* binding */ Content),\n/* harmony export */ List: () => (/* binding */ List),\n/* harmony export */ Root: () => (/* binding */ Root2),\n/* harmony export */ Tabs: () => (/* binding */ Tabs),\n/* harmony export */ TabsContent: () => (/* binding */ TabsContent),\n/* harmony export */ TabsList: () => (/* binding */ TabsList),\n/* harmony export */ TabsTrigger: () => (/* binding */ TabsTrigger),\n/* harmony export */ Trigger: () => (/* binding */ Trigger),\n/* harmony export */ createTabsScope: () => (/* binding */ createTabsScope)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var _radix_ui_primitive__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! @radix-ui/primitive */ \"../../node_modules/@radix-ui/primitive/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @radix-ui/react-context */ \"../../node_modules/@radix-ui/react-context/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_roving_focus__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @radix-ui/react-roving-focus */ \"../../node_modules/@radix-ui/react-roving-focus/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_presence__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @radix-ui/react-presence */ \"../../node_modules/@radix-ui/react-presence/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @radix-ui/react-primitive */ \"../../node_modules/@radix-ui/react-tabs/node_modules/@radix-ui/react-primitive/dist/index.module.js\");\n/* harmony import */ var _radix_ui_react_direction__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @radix-ui/react-direction */ \"../../node_modules/@radix-ui/react-tabs/node_modules/@radix-ui/react-direction/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_use_controllable_state__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @radix-ui/react-use-controllable-state */ \"../../node_modules/@radix-ui/react-use-controllable-state/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_id__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @radix-ui/react-id */ \"../../node_modules/@radix-ui/react-id/dist/index.mjs\");\n/* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react/jsx-runtime */ \"react/jsx-runtime\");\n\"use client\";\n\n// packages/react/tabs/src/tabs.tsx\n\n\n\n\n\n\n\n\n\n\n\nvar TABS_NAME = \"Tabs\";\nvar [createTabsContext, createTabsScope] = (0,_radix_ui_react_context__WEBPACK_IMPORTED_MODULE_2__.createContextScope)(TABS_NAME, [\n _radix_ui_react_roving_focus__WEBPACK_IMPORTED_MODULE_3__.createRovingFocusGroupScope\n]);\nvar useRovingFocusGroupScope = (0,_radix_ui_react_roving_focus__WEBPACK_IMPORTED_MODULE_3__.createRovingFocusGroupScope)();\nvar [TabsProvider, useTabsContext] = createTabsContext(TABS_NAME);\nvar Tabs = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeTabs,\n value: valueProp,\n onValueChange,\n defaultValue,\n orientation = \"horizontal\",\n dir,\n activationMode = \"automatic\",\n ...tabsProps\n } = props;\n const direction = (0,_radix_ui_react_direction__WEBPACK_IMPORTED_MODULE_4__.useDirection)(dir);\n const [value, setValue] = (0,_radix_ui_react_use_controllable_state__WEBPACK_IMPORTED_MODULE_5__.useControllableState)({\n prop: valueProp,\n onChange: onValueChange,\n defaultProp: defaultValue\n });\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n TabsProvider,\n {\n scope: __scopeTabs,\n baseId: (0,_radix_ui_react_id__WEBPACK_IMPORTED_MODULE_6__.useId)(),\n value,\n onValueChange: setValue,\n orientation,\n dir: direction,\n activationMode,\n children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_7__.Primitive.div,\n {\n dir: direction,\n \"data-orientation\": orientation,\n ...tabsProps,\n ref: forwardedRef\n }\n )\n }\n );\n }\n);\nTabs.displayName = TABS_NAME;\nvar TAB_LIST_NAME = \"TabsList\";\nvar TabsList = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTabs, loop = true, ...listProps } = props;\n const context = useTabsContext(TAB_LIST_NAME, __scopeTabs);\n const rovingFocusGroupScope = useRovingFocusGroupScope(__scopeTabs);\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_roving_focus__WEBPACK_IMPORTED_MODULE_3__.Root,\n {\n asChild: true,\n ...rovingFocusGroupScope,\n orientation: context.orientation,\n dir: context.dir,\n loop,\n children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_7__.Primitive.div,\n {\n role: \"tablist\",\n \"aria-orientation\": context.orientation,\n ...listProps,\n ref: forwardedRef\n }\n )\n }\n );\n }\n);\nTabsList.displayName = TAB_LIST_NAME;\nvar TRIGGER_NAME = \"TabsTrigger\";\nvar TabsTrigger = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTabs, value, disabled = false, ...triggerProps } = props;\n const context = useTabsContext(TRIGGER_NAME, __scopeTabs);\n const rovingFocusGroupScope = useRovingFocusGroupScope(__scopeTabs);\n const triggerId = makeTriggerId(context.baseId, value);\n const contentId = makeContentId(context.baseId, value);\n const isSelected = value === context.value;\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_roving_focus__WEBPACK_IMPORTED_MODULE_3__.Item,\n {\n asChild: true,\n ...rovingFocusGroupScope,\n focusable: !disabled,\n active: isSelected,\n children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_7__.Primitive.button,\n {\n type: \"button\",\n role: \"tab\",\n \"aria-selected\": isSelected,\n \"aria-controls\": contentId,\n \"data-state\": isSelected ? \"active\" : \"inactive\",\n \"data-disabled\": disabled ? \"\" : void 0,\n disabled,\n id: triggerId,\n ...triggerProps,\n ref: forwardedRef,\n onMouseDown: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_8__.composeEventHandlers)(props.onMouseDown, (event) => {\n if (!disabled && event.button === 0 && event.ctrlKey === false) {\n context.onValueChange(value);\n } else {\n event.preventDefault();\n }\n }),\n onKeyDown: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_8__.composeEventHandlers)(props.onKeyDown, (event) => {\n if ([\" \", \"Enter\"].includes(event.key)) context.onValueChange(value);\n }),\n onFocus: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_8__.composeEventHandlers)(props.onFocus, () => {\n const isAutomaticActivation = context.activationMode !== \"manual\";\n if (!isSelected && !disabled && isAutomaticActivation) {\n context.onValueChange(value);\n }\n })\n }\n )\n }\n );\n }\n);\nTabsTrigger.displayName = TRIGGER_NAME;\nvar CONTENT_NAME = \"TabsContent\";\nvar TabsContent = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTabs, value, forceMount, children, ...contentProps } = props;\n const context = useTabsContext(CONTENT_NAME, __scopeTabs);\n const triggerId = makeTriggerId(context.baseId, value);\n const contentId = makeContentId(context.baseId, value);\n const isSelected = value === context.value;\n const isMountAnimationPreventedRef = react__WEBPACK_IMPORTED_MODULE_0__.useRef(isSelected);\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(() => {\n const rAF = requestAnimationFrame(() => isMountAnimationPreventedRef.current = false);\n return () => cancelAnimationFrame(rAF);\n }, []);\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(_radix_ui_react_presence__WEBPACK_IMPORTED_MODULE_9__.Presence, { present: forceMount || isSelected, children: ({ present }) => /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_7__.Primitive.div,\n {\n \"data-state\": isSelected ? \"active\" : \"inactive\",\n \"data-orientation\": context.orientation,\n role: \"tabpanel\",\n \"aria-labelledby\": triggerId,\n hidden: !present,\n id: contentId,\n tabIndex: 0,\n ...contentProps,\n ref: forwardedRef,\n style: {\n ...props.style,\n animationDuration: isMountAnimationPreventedRef.current ? \"0s\" : void 0\n },\n children: present && children\n }\n ) });\n }\n);\nTabsContent.displayName = CONTENT_NAME;\nfunction makeTriggerId(baseId, value) {\n return `${baseId}-trigger-${value}`;\n}\nfunction makeContentId(baseId, value) {\n return `${baseId}-content-${value}`;\n}\nvar Root2 = Tabs;\nvar List = TabsList;\nvar Trigger = TabsTrigger;\nvar Content = TabsContent;\n\n//# sourceMappingURL=index.mjs.map\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/@radix-ui/react-tabs/dist/index.mjs?");
293
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Content: () => (/* binding */ Content),\n/* harmony export */ List: () => (/* binding */ List),\n/* harmony export */ Root: () => (/* binding */ Root2),\n/* harmony export */ Tabs: () => (/* binding */ Tabs),\n/* harmony export */ TabsContent: () => (/* binding */ TabsContent),\n/* harmony export */ TabsList: () => (/* binding */ TabsList),\n/* harmony export */ TabsTrigger: () => (/* binding */ TabsTrigger),\n/* harmony export */ Trigger: () => (/* binding */ Trigger),\n/* harmony export */ createTabsScope: () => (/* binding */ createTabsScope)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var _radix_ui_primitive__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! @radix-ui/primitive */ \"../../node_modules/@radix-ui/primitive/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @radix-ui/react-context */ \"../../node_modules/@radix-ui/react-context/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_roving_focus__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @radix-ui/react-roving-focus */ \"../../node_modules/@radix-ui/react-roving-focus/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_presence__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @radix-ui/react-presence */ \"../../node_modules/@radix-ui/react-presence/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @radix-ui/react-primitive */ \"../../node_modules/@radix-ui/react-primitive/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_direction__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @radix-ui/react-direction */ \"../../node_modules/@radix-ui/react-tabs/node_modules/@radix-ui/react-direction/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_use_controllable_state__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @radix-ui/react-use-controllable-state */ \"../../node_modules/@radix-ui/react-use-controllable-state/dist/index.mjs\");\n/* harmony import */ var _radix_ui_react_id__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @radix-ui/react-id */ \"../../node_modules/@radix-ui/react-id/dist/index.mjs\");\n/* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react/jsx-runtime */ \"react/jsx-runtime\");\n\"use client\";\n\n// packages/react/tabs/src/tabs.tsx\n\n\n\n\n\n\n\n\n\n\n\nvar TABS_NAME = \"Tabs\";\nvar [createTabsContext, createTabsScope] = (0,_radix_ui_react_context__WEBPACK_IMPORTED_MODULE_2__.createContextScope)(TABS_NAME, [\n _radix_ui_react_roving_focus__WEBPACK_IMPORTED_MODULE_3__.createRovingFocusGroupScope\n]);\nvar useRovingFocusGroupScope = (0,_radix_ui_react_roving_focus__WEBPACK_IMPORTED_MODULE_3__.createRovingFocusGroupScope)();\nvar [TabsProvider, useTabsContext] = createTabsContext(TABS_NAME);\nvar Tabs = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeTabs,\n value: valueProp,\n onValueChange,\n defaultValue,\n orientation = \"horizontal\",\n dir,\n activationMode = \"automatic\",\n ...tabsProps\n } = props;\n const direction = (0,_radix_ui_react_direction__WEBPACK_IMPORTED_MODULE_4__.useDirection)(dir);\n const [value, setValue] = (0,_radix_ui_react_use_controllable_state__WEBPACK_IMPORTED_MODULE_5__.useControllableState)({\n prop: valueProp,\n onChange: onValueChange,\n defaultProp: defaultValue\n });\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n TabsProvider,\n {\n scope: __scopeTabs,\n baseId: (0,_radix_ui_react_id__WEBPACK_IMPORTED_MODULE_6__.useId)(),\n value,\n onValueChange: setValue,\n orientation,\n dir: direction,\n activationMode,\n children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_7__.Primitive.div,\n {\n dir: direction,\n \"data-orientation\": orientation,\n ...tabsProps,\n ref: forwardedRef\n }\n )\n }\n );\n }\n);\nTabs.displayName = TABS_NAME;\nvar TAB_LIST_NAME = \"TabsList\";\nvar TabsList = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTabs, loop = true, ...listProps } = props;\n const context = useTabsContext(TAB_LIST_NAME, __scopeTabs);\n const rovingFocusGroupScope = useRovingFocusGroupScope(__scopeTabs);\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_roving_focus__WEBPACK_IMPORTED_MODULE_3__.Root,\n {\n asChild: true,\n ...rovingFocusGroupScope,\n orientation: context.orientation,\n dir: context.dir,\n loop,\n children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_7__.Primitive.div,\n {\n role: \"tablist\",\n \"aria-orientation\": context.orientation,\n ...listProps,\n ref: forwardedRef\n }\n )\n }\n );\n }\n);\nTabsList.displayName = TAB_LIST_NAME;\nvar TRIGGER_NAME = \"TabsTrigger\";\nvar TabsTrigger = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTabs, value, disabled = false, ...triggerProps } = props;\n const context = useTabsContext(TRIGGER_NAME, __scopeTabs);\n const rovingFocusGroupScope = useRovingFocusGroupScope(__scopeTabs);\n const triggerId = makeTriggerId(context.baseId, value);\n const contentId = makeContentId(context.baseId, value);\n const isSelected = value === context.value;\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_roving_focus__WEBPACK_IMPORTED_MODULE_3__.Item,\n {\n asChild: true,\n ...rovingFocusGroupScope,\n focusable: !disabled,\n active: isSelected,\n children: /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_7__.Primitive.button,\n {\n type: \"button\",\n role: \"tab\",\n \"aria-selected\": isSelected,\n \"aria-controls\": contentId,\n \"data-state\": isSelected ? \"active\" : \"inactive\",\n \"data-disabled\": disabled ? \"\" : void 0,\n disabled,\n id: triggerId,\n ...triggerProps,\n ref: forwardedRef,\n onMouseDown: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_8__.composeEventHandlers)(props.onMouseDown, (event) => {\n if (!disabled && event.button === 0 && event.ctrlKey === false) {\n context.onValueChange(value);\n } else {\n event.preventDefault();\n }\n }),\n onKeyDown: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_8__.composeEventHandlers)(props.onKeyDown, (event) => {\n if ([\" \", \"Enter\"].includes(event.key)) context.onValueChange(value);\n }),\n onFocus: (0,_radix_ui_primitive__WEBPACK_IMPORTED_MODULE_8__.composeEventHandlers)(props.onFocus, () => {\n const isAutomaticActivation = context.activationMode !== \"manual\";\n if (!isSelected && !disabled && isAutomaticActivation) {\n context.onValueChange(value);\n }\n })\n }\n )\n }\n );\n }\n);\nTabsTrigger.displayName = TRIGGER_NAME;\nvar CONTENT_NAME = \"TabsContent\";\nvar TabsContent = react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTabs, value, forceMount, children, ...contentProps } = props;\n const context = useTabsContext(CONTENT_NAME, __scopeTabs);\n const triggerId = makeTriggerId(context.baseId, value);\n const contentId = makeContentId(context.baseId, value);\n const isSelected = value === context.value;\n const isMountAnimationPreventedRef = react__WEBPACK_IMPORTED_MODULE_0__.useRef(isSelected);\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(() => {\n const rAF = requestAnimationFrame(() => isMountAnimationPreventedRef.current = false);\n return () => cancelAnimationFrame(rAF);\n }, []);\n return /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(_radix_ui_react_presence__WEBPACK_IMPORTED_MODULE_9__.Presence, { present: forceMount || isSelected, children: ({ present }) => /* @__PURE__ */ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_1__.jsx)(\n _radix_ui_react_primitive__WEBPACK_IMPORTED_MODULE_7__.Primitive.div,\n {\n \"data-state\": isSelected ? \"active\" : \"inactive\",\n \"data-orientation\": context.orientation,\n role: \"tabpanel\",\n \"aria-labelledby\": triggerId,\n hidden: !present,\n id: contentId,\n tabIndex: 0,\n ...contentProps,\n ref: forwardedRef,\n style: {\n ...props.style,\n animationDuration: isMountAnimationPreventedRef.current ? \"0s\" : void 0\n },\n children: present && children\n }\n ) });\n }\n);\nTabsContent.displayName = CONTENT_NAME;\nfunction makeTriggerId(baseId, value) {\n return `${baseId}-trigger-${value}`;\n}\nfunction makeContentId(baseId, value) {\n return `${baseId}-content-${value}`;\n}\nvar Root2 = Tabs;\nvar List = TabsList;\nvar Trigger = TabsTrigger;\nvar Content = TabsContent;\n\n//# sourceMappingURL=index.mjs.map\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/@radix-ui/react-tabs/dist/index.mjs?");
338
294
 
339
295
  /***/ }),
340
296
 
@@ -349,17 +305,6 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
349
305
 
350
306
  /***/ }),
351
307
 
352
- /***/ "../../node_modules/@radix-ui/react-tabs/node_modules/@radix-ui/react-primitive/dist/index.module.js":
353
- /*!***********************************************************************************************************!*\
354
- !*** ../../node_modules/@radix-ui/react-tabs/node_modules/@radix-ui/react-primitive/dist/index.module.js ***!
355
- \***********************************************************************************************************/
356
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
357
-
358
- "use strict";
359
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Primitive: () => (/* binding */ $8927f6f2acc4f386$export$250ffa63cdc0d034),\n/* harmony export */ Root: () => (/* binding */ $8927f6f2acc4f386$export$be92b6f5f03c0fe9),\n/* harmony export */ dispatchDiscreteCustomEvent: () => (/* binding */ $8927f6f2acc4f386$export$6d1a0317bde7de7f)\n/* harmony export */ });\n/* harmony import */ var _babel_runtime_helpers_esm_extends__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/extends */ \"../../node_modules/@babel/runtime/helpers/esm/extends.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react-dom */ \"react-dom\");\n/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react_dom__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _radix_ui_react_slot__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @radix-ui/react-slot */ \"../../node_modules/@radix-ui/react-slot/dist/index.mjs\");\n\n\n\n\n\n\n\n\n\nconst $8927f6f2acc4f386$var$NODES = [\n 'a',\n 'button',\n 'div',\n 'h2',\n 'h3',\n 'img',\n 'label',\n 'li',\n 'nav',\n 'ol',\n 'p',\n 'span',\n 'svg',\n 'ul'\n]; // Temporary while we await merge of this fix:\n// https://github.com/DefinitelyTyped/DefinitelyTyped/pull/55396\n// prettier-ignore\n/* -------------------------------------------------------------------------------------------------\n * Primitive\n * -----------------------------------------------------------------------------------------------*/ const $8927f6f2acc4f386$export$250ffa63cdc0d034 = $8927f6f2acc4f386$var$NODES.reduce((primitive, node)=>{\n const Node = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_1__.forwardRef)((props, forwardedRef)=>{\n const { asChild: asChild , ...primitiveProps } = props;\n const Comp = asChild ? _radix_ui_react_slot__WEBPACK_IMPORTED_MODULE_3__.Slot : node;\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n window[Symbol.for('radix-ui')] = true;\n }, []);\n return /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_1__.createElement)(Comp, (0,_babel_runtime_helpers_esm_extends__WEBPACK_IMPORTED_MODULE_0__[\"default\"])({}, primitiveProps, {\n ref: forwardedRef\n }));\n });\n Node.displayName = `Primitive.${node}`;\n return {\n ...primitive,\n [node]: Node\n };\n}, {});\n/* -------------------------------------------------------------------------------------------------\n * Utils\n * -----------------------------------------------------------------------------------------------*/ /**\n * Flush custom event dispatch\n * https://github.com/radix-ui/primitives/pull/1378\n *\n * React batches *all* event handlers since version 18, this introduces certain considerations when using custom event types.\n *\n * Internally, React prioritises events in the following order:\n * - discrete\n * - continuous\n * - default\n *\n * https://github.com/facebook/react/blob/a8a4742f1c54493df00da648a3f9d26e3db9c8b5/packages/react-dom/src/events/ReactDOMEventListener.js#L294-L350\n *\n * `discrete` is an important distinction as updates within these events are applied immediately.\n * React however, is not able to infer the priority of custom event types due to how they are detected internally.\n * Because of this, it's possible for updates from custom events to be unexpectedly batched when\n * dispatched by another `discrete` event.\n *\n * In order to ensure that updates from custom events are applied predictably, we need to manually flush the batch.\n * This utility should be used when dispatching a custom event from within another `discrete` event, this utility\n * is not nessesary when dispatching known event types, or if dispatching a custom type inside a non-discrete event.\n * For example:\n *\n * dispatching a known click 👎\n * target.dispatchEvent(new Event(‘click’))\n *\n * dispatching a custom type within a non-discrete event 👎\n * onScroll={(event) => event.target.dispatchEvent(new CustomEvent(‘customType’))}\n *\n * dispatching a custom type within a `discrete` event 👍\n * onPointerDown={(event) => dispatchDiscreteCustomEvent(event.target, new CustomEvent(‘customType’))}\n *\n * Note: though React classifies `focus`, `focusin` and `focusout` events as `discrete`, it's not recommended to use\n * this utility with them. This is because it's possible for those handlers to be called implicitly during render\n * e.g. when focus is within a component as it is unmounted, or when managing focus on mount.\n */ function $8927f6f2acc4f386$export$6d1a0317bde7de7f(target, event) {\n if (target) (0,react_dom__WEBPACK_IMPORTED_MODULE_2__.flushSync)(()=>target.dispatchEvent(event)\n );\n}\n/* -----------------------------------------------------------------------------------------------*/ const $8927f6f2acc4f386$export$be92b6f5f03c0fe9 = $8927f6f2acc4f386$export$250ffa63cdc0d034;\n\n\n\n\n\n//# sourceMappingURL=index.module.js.map\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/@radix-ui/react-tabs/node_modules/@radix-ui/react-primitive/dist/index.module.js?");
360
-
361
- /***/ }),
362
-
363
308
  /***/ "../../node_modules/@radix-ui/react-use-callback-ref/dist/index.mjs":
364
309
  /*!**************************************************************************!*\
365
310
  !*** ../../node_modules/@radix-ui/react-use-callback-ref/dist/index.mjs ***!
@@ -8363,7 +8308,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
8363
8308
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
8364
8309
 
8365
8310
  "use strict";
8366
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n\n\nlet FORCE_COLOR, NODE_DISABLE_COLORS, NO_COLOR, TERM, isTTY=true;\nif (typeof process !== 'undefined') {\n\t({ FORCE_COLOR, NODE_DISABLE_COLORS, NO_COLOR, TERM } = ({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-64\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}) || 0);\n\tisTTY = process.stdout && process.stdout.isTTY;\n}\n\nconst $ = {\n\tenabled: !NODE_DISABLE_COLORS && NO_COLOR == null && TERM !== 'dumb' && (\n\t\tFORCE_COLOR != null && FORCE_COLOR !== '0' || isTTY\n\t),\n\n\t// modifiers\n\treset: init(0, 0),\n\tbold: init(1, 22),\n\tdim: init(2, 22),\n\titalic: init(3, 23),\n\tunderline: init(4, 24),\n\tinverse: init(7, 27),\n\thidden: init(8, 28),\n\tstrikethrough: init(9, 29),\n\n\t// colors\n\tblack: init(30, 39),\n\tred: init(31, 39),\n\tgreen: init(32, 39),\n\tyellow: init(33, 39),\n\tblue: init(34, 39),\n\tmagenta: init(35, 39),\n\tcyan: init(36, 39),\n\twhite: init(37, 39),\n\tgray: init(90, 39),\n\tgrey: init(90, 39),\n\n\t// background colors\n\tbgBlack: init(40, 49),\n\tbgRed: init(41, 49),\n\tbgGreen: init(42, 49),\n\tbgYellow: init(43, 49),\n\tbgBlue: init(44, 49),\n\tbgMagenta: init(45, 49),\n\tbgCyan: init(46, 49),\n\tbgWhite: init(47, 49)\n};\n\nfunction run(arr, str) {\n\tlet i=0, tmp, beg='', end='';\n\tfor (; i < arr.length; i++) {\n\t\ttmp = arr[i];\n\t\tbeg += tmp.open;\n\t\tend += tmp.close;\n\t\tif (!!~str.indexOf(tmp.close)) {\n\t\t\tstr = str.replace(tmp.rgx, tmp.close + tmp.open);\n\t\t}\n\t}\n\treturn beg + str + end;\n}\n\nfunction chain(has, keys) {\n\tlet ctx = { has, keys };\n\n\tctx.reset = $.reset.bind(ctx);\n\tctx.bold = $.bold.bind(ctx);\n\tctx.dim = $.dim.bind(ctx);\n\tctx.italic = $.italic.bind(ctx);\n\tctx.underline = $.underline.bind(ctx);\n\tctx.inverse = $.inverse.bind(ctx);\n\tctx.hidden = $.hidden.bind(ctx);\n\tctx.strikethrough = $.strikethrough.bind(ctx);\n\n\tctx.black = $.black.bind(ctx);\n\tctx.red = $.red.bind(ctx);\n\tctx.green = $.green.bind(ctx);\n\tctx.yellow = $.yellow.bind(ctx);\n\tctx.blue = $.blue.bind(ctx);\n\tctx.magenta = $.magenta.bind(ctx);\n\tctx.cyan = $.cyan.bind(ctx);\n\tctx.white = $.white.bind(ctx);\n\tctx.gray = $.gray.bind(ctx);\n\tctx.grey = $.grey.bind(ctx);\n\n\tctx.bgBlack = $.bgBlack.bind(ctx);\n\tctx.bgRed = $.bgRed.bind(ctx);\n\tctx.bgGreen = $.bgGreen.bind(ctx);\n\tctx.bgYellow = $.bgYellow.bind(ctx);\n\tctx.bgBlue = $.bgBlue.bind(ctx);\n\tctx.bgMagenta = $.bgMagenta.bind(ctx);\n\tctx.bgCyan = $.bgCyan.bind(ctx);\n\tctx.bgWhite = $.bgWhite.bind(ctx);\n\n\treturn ctx;\n}\n\nfunction init(open, close) {\n\tlet blk = {\n\t\topen: `\\x1b[${open}m`,\n\t\tclose: `\\x1b[${close}m`,\n\t\trgx: new RegExp(`\\\\x1b\\\\[${close}m`, 'g')\n\t};\n\treturn function (txt) {\n\t\tif (this !== void 0 && this.has !== void 0) {\n\t\t\t!!~this.has.indexOf(open) || (this.has.push(open),this.keys.push(blk));\n\t\t\treturn txt === void 0 ? this : $.enabled ? run(this.keys, txt+'') : txt+'';\n\t\t}\n\t\treturn txt === void 0 ? chain([open], [blk]) : $.enabled ? run([blk], txt+'') : txt+'';\n\t};\n}\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ($);\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/kleur/index.mjs?");
8311
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n\n\nlet FORCE_COLOR, NODE_DISABLE_COLORS, NO_COLOR, TERM, isTTY=true;\nif (typeof process !== 'undefined') {\n\t({ FORCE_COLOR, NODE_DISABLE_COLORS, NO_COLOR, TERM } = ({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-66\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}) || 0);\n\tisTTY = process.stdout && process.stdout.isTTY;\n}\n\nconst $ = {\n\tenabled: !NODE_DISABLE_COLORS && NO_COLOR == null && TERM !== 'dumb' && (\n\t\tFORCE_COLOR != null && FORCE_COLOR !== '0' || isTTY\n\t),\n\n\t// modifiers\n\treset: init(0, 0),\n\tbold: init(1, 22),\n\tdim: init(2, 22),\n\titalic: init(3, 23),\n\tunderline: init(4, 24),\n\tinverse: init(7, 27),\n\thidden: init(8, 28),\n\tstrikethrough: init(9, 29),\n\n\t// colors\n\tblack: init(30, 39),\n\tred: init(31, 39),\n\tgreen: init(32, 39),\n\tyellow: init(33, 39),\n\tblue: init(34, 39),\n\tmagenta: init(35, 39),\n\tcyan: init(36, 39),\n\twhite: init(37, 39),\n\tgray: init(90, 39),\n\tgrey: init(90, 39),\n\n\t// background colors\n\tbgBlack: init(40, 49),\n\tbgRed: init(41, 49),\n\tbgGreen: init(42, 49),\n\tbgYellow: init(43, 49),\n\tbgBlue: init(44, 49),\n\tbgMagenta: init(45, 49),\n\tbgCyan: init(46, 49),\n\tbgWhite: init(47, 49)\n};\n\nfunction run(arr, str) {\n\tlet i=0, tmp, beg='', end='';\n\tfor (; i < arr.length; i++) {\n\t\ttmp = arr[i];\n\t\tbeg += tmp.open;\n\t\tend += tmp.close;\n\t\tif (!!~str.indexOf(tmp.close)) {\n\t\t\tstr = str.replace(tmp.rgx, tmp.close + tmp.open);\n\t\t}\n\t}\n\treturn beg + str + end;\n}\n\nfunction chain(has, keys) {\n\tlet ctx = { has, keys };\n\n\tctx.reset = $.reset.bind(ctx);\n\tctx.bold = $.bold.bind(ctx);\n\tctx.dim = $.dim.bind(ctx);\n\tctx.italic = $.italic.bind(ctx);\n\tctx.underline = $.underline.bind(ctx);\n\tctx.inverse = $.inverse.bind(ctx);\n\tctx.hidden = $.hidden.bind(ctx);\n\tctx.strikethrough = $.strikethrough.bind(ctx);\n\n\tctx.black = $.black.bind(ctx);\n\tctx.red = $.red.bind(ctx);\n\tctx.green = $.green.bind(ctx);\n\tctx.yellow = $.yellow.bind(ctx);\n\tctx.blue = $.blue.bind(ctx);\n\tctx.magenta = $.magenta.bind(ctx);\n\tctx.cyan = $.cyan.bind(ctx);\n\tctx.white = $.white.bind(ctx);\n\tctx.gray = $.gray.bind(ctx);\n\tctx.grey = $.grey.bind(ctx);\n\n\tctx.bgBlack = $.bgBlack.bind(ctx);\n\tctx.bgRed = $.bgRed.bind(ctx);\n\tctx.bgGreen = $.bgGreen.bind(ctx);\n\tctx.bgYellow = $.bgYellow.bind(ctx);\n\tctx.bgBlue = $.bgBlue.bind(ctx);\n\tctx.bgMagenta = $.bgMagenta.bind(ctx);\n\tctx.bgCyan = $.bgCyan.bind(ctx);\n\tctx.bgWhite = $.bgWhite.bind(ctx);\n\n\treturn ctx;\n}\n\nfunction init(open, close) {\n\tlet blk = {\n\t\topen: `\\x1b[${open}m`,\n\t\tclose: `\\x1b[${close}m`,\n\t\trgx: new RegExp(`\\\\x1b\\\\[${close}m`, 'g')\n\t};\n\treturn function (txt) {\n\t\tif (this !== void 0 && this.has !== void 0) {\n\t\t\t!!~this.has.indexOf(open) || (this.has.push(open),this.keys.push(blk));\n\t\t\treturn txt === void 0 ? this : $.enabled ? run(this.keys, txt+'') : txt+'';\n\t\t}\n\t\treturn txt === void 0 ? chain([open], [blk]) : $.enabled ? run([blk], txt+'') : txt+'';\n\t};\n}\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ($);\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/kleur/index.mjs?");
8367
8312
 
8368
8313
  /***/ }),
8369
8314
 
@@ -11978,7 +11923,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
11978
11923
  \**********************************************************************/
11979
11924
  /***/ ((module, exports, __webpack_require__) => {
11980
11925
 
11981
- eval("/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\tlet m;\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\t// eslint-disable-next-line no-return-assign\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && (m = navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/)) && parseInt(m[1], 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug');\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = ({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-64\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}).DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = __webpack_require__(/*! ./common */ \"../../node_modules/micromark/node_modules/debug/src/common.js\")(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/micromark/node_modules/debug/src/browser.js?");
11926
+ eval("/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\tlet m;\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\t// eslint-disable-next-line no-return-assign\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && (m = navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/)) && parseInt(m[1], 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug');\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = ({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-66\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}).DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = __webpack_require__(/*! ./common */ \"../../node_modules/micromark/node_modules/debug/src/common.js\")(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n\n\n//# sourceURL=webpack://ExcalidrawLib/../../node_modules/micromark/node_modules/debug/src/browser.js?");
11982
11927
 
11983
11928
  /***/ }),
11984
11929
 
@@ -13102,7 +13047,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
13102
13047
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
13103
13048
 
13104
13049
  "use strict";
13105
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ addEventListener: () => (/* binding */ addEventListener),\n/* harmony export */ allowFullScreen: () => (/* binding */ allowFullScreen),\n/* harmony export */ arrayToList: () => (/* binding */ arrayToList),\n/* harmony export */ arrayToMap: () => (/* binding */ arrayToMap),\n/* harmony export */ arrayToMapWithIndex: () => (/* binding */ arrayToMapWithIndex),\n/* harmony export */ arrayToObject: () => (/* binding */ arrayToObject),\n/* harmony export */ assertNever: () => (/* binding */ assertNever),\n/* harmony export */ bytesToHexString: () => (/* binding */ bytesToHexString),\n/* harmony export */ capitalizeString: () => (/* binding */ capitalizeString),\n/* harmony export */ castArray: () => (/* binding */ castArray),\n/* harmony export */ chunk: () => (/* binding */ chunk),\n/* harmony export */ cloneJSON: () => (/* binding */ cloneJSON),\n/* harmony export */ composeEventHandlers: () => (/* binding */ composeEventHandlers),\n/* harmony export */ debounce: () => (/* binding */ debounce),\n/* harmony export */ distance: () => (/* binding */ distance),\n/* harmony export */ easeOut: () => (/* binding */ easeOut),\n/* harmony export */ easeToValuesRAF: () => (/* binding */ easeToValuesRAF),\n/* harmony export */ escapeDoubleQuotes: () => (/* binding */ escapeDoubleQuotes),\n/* harmony export */ exitFullScreen: () => (/* binding */ exitFullScreen),\n/* harmony export */ findIndex: () => (/* binding */ findIndex),\n/* harmony export */ findLastIndex: () => (/* binding */ findLastIndex),\n/* harmony export */ focusNearestParent: () => (/* binding */ focusNearestParent),\n/* harmony export */ getDateTime: () => (/* binding */ getDateTime),\n/* harmony export */ getFeatureFlag: () => (/* binding */ getFeatureFlag),\n/* harmony export */ getFontFamilyString: () => (/* binding */ getFontFamilyString),\n/* harmony export */ getFontString: () => (/* binding */ getFontString),\n/* harmony export */ getFrame: () => (/* binding */ getFrame),\n/* harmony export */ getGlobalCSSVariable: () => (/* binding */ getGlobalCSSVariable),\n/* harmony export */ getNearestScrollableContainer: () => (/* binding */ getNearestScrollableContainer),\n/* harmony export */ getSvgPathFromStroke: () => (/* binding */ getSvgPathFromStroke),\n/* harmony export */ getUpdatedTimestamp: () => (/* binding */ getUpdatedTimestamp),\n/* harmony export */ getVersion: () => (/* binding */ getVersion),\n/* harmony export */ invariant: () => (/* binding */ invariant),\n/* harmony export */ isAnyTrue: () => (/* binding */ isAnyTrue),\n/* harmony export */ isDevEnv: () => (/* binding */ isDevEnv),\n/* harmony export */ isFullScreen: () => (/* binding */ isFullScreen),\n/* harmony export */ isInputLike: () => (/* binding */ isInputLike),\n/* harmony export */ isInteractive: () => (/* binding */ isInteractive),\n/* harmony export */ isMemberOf: () => (/* binding */ isMemberOf),\n/* harmony export */ isPrimitive: () => (/* binding */ isPrimitive),\n/* harmony export */ isProdEnv: () => (/* binding */ isProdEnv),\n/* harmony export */ isPromiseLike: () => (/* binding */ isPromiseLike),\n/* harmony export */ isRTL: () => (/* binding */ isRTL),\n/* harmony export */ isReadonlyArray: () => (/* binding */ isReadonlyArray),\n/* harmony export */ isRunningInIframe: () => (/* binding */ isRunningInIframe),\n/* harmony export */ isSelectionLikeTool: () => (/* binding */ isSelectionLikeTool),\n/* harmony export */ isServerEnv: () => (/* binding */ isServerEnv),\n/* harmony export */ isShallowEqual: () => (/* binding */ isShallowEqual),\n/* harmony export */ isTestEnv: () => (/* binding */ isTestEnv),\n/* harmony export */ isToolIcon: () => (/* binding */ isToolIcon),\n/* harmony export */ isTransparent: () => (/* binding */ isTransparent),\n/* harmony export */ isWritableElement: () => (/* binding */ isWritableElement),\n/* harmony export */ mapFind: () => (/* binding */ mapFind),\n/* harmony export */ memoize: () => (/* binding */ memoize),\n/* harmony export */ muteFSAbortError: () => (/* binding */ muteFSAbortError),\n/* harmony export */ nFormatter: () => (/* binding */ nFormatter),\n/* harmony export */ nextAnimationFrame: () => (/* binding */ nextAnimationFrame),\n/* harmony export */ normalizeEOL: () => (/* binding */ normalizeEOL),\n/* harmony export */ preventUnload: () => (/* binding */ preventUnload),\n/* harmony export */ promiseTry: () => (/* binding */ promiseTry),\n/* harmony export */ queryFocusableElements: () => (/* binding */ queryFocusableElements),\n/* harmony export */ reduceToCommonValue: () => (/* binding */ reduceToCommonValue),\n/* harmony export */ removeSelection: () => (/* binding */ removeSelection),\n/* harmony export */ resolvablePromise: () => (/* binding */ resolvablePromise),\n/* harmony export */ safelyParseJSON: () => (/* binding */ safelyParseJSON),\n/* harmony export */ sceneCoordsToViewportCoords: () => (/* binding */ sceneCoordsToViewportCoords),\n/* harmony export */ selectNode: () => (/* binding */ selectNode),\n/* harmony export */ setDateTimeForTests: () => (/* binding */ setDateTimeForTests),\n/* harmony export */ setFeatureFlag: () => (/* binding */ setFeatureFlag),\n/* harmony export */ sizeOf: () => (/* binding */ sizeOf),\n/* harmony export */ supportsEmoji: () => (/* binding */ supportsEmoji),\n/* harmony export */ throttleRAF: () => (/* binding */ throttleRAF),\n/* harmony export */ toArray: () => (/* binding */ toArray),\n/* harmony export */ toBrandedType: () => (/* binding */ toBrandedType),\n/* harmony export */ toIterable: () => (/* binding */ toIterable),\n/* harmony export */ tupleToCoors: () => (/* binding */ tupleToCoors),\n/* harmony export */ updateActiveTool: () => (/* binding */ updateActiveTool),\n/* harmony export */ updateObject: () => (/* binding */ updateObject),\n/* harmony export */ updateStable: () => (/* binding */ updateStable),\n/* harmony export */ viewportCoordsToSceneCoords: () => (/* binding */ viewportCoordsToSceneCoords),\n/* harmony export */ wrapEvent: () => (/* binding */ wrapEvent)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_math__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/math */ \"../math/src/index.ts\");\n/* harmony import */ var _colors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./colors */ \"../common/src/colors.ts\");\n/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ \"../common/src/constants.ts\");\n\n\n\nlet mockDateTime = null;\nconst setDateTimeForTests = dateTime => {\n mockDateTime = dateTime;\n};\nconst getDateTime = () => {\n if (mockDateTime) {\n return mockDateTime;\n }\n\n const date = new Date();\n const year = date.getFullYear();\n const month = `${date.getMonth() + 1}`.padStart(2, \"0\");\n const day = `${date.getDate()}`.padStart(2, \"0\");\n const hr = `${date.getHours()}`.padStart(2, \"0\");\n const min = `${date.getMinutes()}`.padStart(2, \"0\");\n return `${year}-${month}-${day}-${hr}${min}`;\n};\nconst capitalizeString = str => str.charAt(0).toUpperCase() + str.slice(1);\nconst isToolIcon = target => target instanceof HTMLElement && target.className.includes(\"ToolIcon\");\nconst isInputLike = target => target instanceof HTMLElement && target.dataset.type === \"wysiwyg\" || target instanceof HTMLBRElement || // newline in wysiwyg\ntarget instanceof HTMLInputElement || target instanceof HTMLTextAreaElement || target instanceof HTMLSelectElement;\nconst isInteractive = target => {\n return isInputLike(target) || target instanceof Element && !!target.closest(\"label, button\");\n};\nconst isWritableElement = target => target instanceof HTMLElement && target.dataset.type === \"wysiwyg\" || target instanceof HTMLBRElement || // newline in wysiwyg\ntarget instanceof HTMLTextAreaElement || target instanceof HTMLInputElement && (target.type === \"text\" || target.type === \"number\" || target.type === \"password\" || target.type === \"search\");\nconst getFontFamilyString = ({\n fontFamily\n}) => {\n for (const [fontFamilyString, id] of Object.entries(_constants__WEBPACK_IMPORTED_MODULE_2__.FONT_FAMILY)) {\n if (id === fontFamily) {\n return `${fontFamilyString}${(0,_constants__WEBPACK_IMPORTED_MODULE_2__.getFontFamilyFallbacks)(id).map(x => `, ${x}`).join(\"\")}`;\n }\n }\n\n return _constants__WEBPACK_IMPORTED_MODULE_2__.WINDOWS_EMOJI_FALLBACK_FONT;\n};\n/** returns fontSize+fontFamily string for assignment to DOM elements */\n\nconst getFontString = ({\n fontSize,\n fontFamily\n}) => {\n return `${fontSize}px ${getFontFamilyString({\n fontFamily\n })}`;\n};\n/** executes callback in the frame that's after the current one */\n\nconst nextAnimationFrame = async cb => {\n requestAnimationFrame(() => requestAnimationFrame(cb));\n};\nconst debounce = (fn, timeout) => {\n let handle = 0;\n let lastArgs = null;\n\n const ret = (...args) => {\n lastArgs = args;\n clearTimeout(handle);\n handle = window.setTimeout(() => {\n lastArgs = null;\n fn(...args);\n }, timeout);\n };\n\n ret.flush = () => {\n clearTimeout(handle);\n\n if (lastArgs) {\n const _lastArgs = lastArgs;\n lastArgs = null;\n fn(..._lastArgs);\n }\n };\n\n ret.cancel = () => {\n lastArgs = null;\n clearTimeout(handle);\n };\n\n return ret;\n}; // throttle callback to execute once per animation frame\n\nconst throttleRAF = (fn, opts) => {\n let timerId = null;\n let lastArgs = null;\n let lastArgsTrailing = null;\n\n const scheduleFunc = args => {\n timerId = window.requestAnimationFrame(() => {\n timerId = null;\n fn(...args);\n lastArgs = null;\n\n if (lastArgsTrailing) {\n lastArgs = lastArgsTrailing;\n lastArgsTrailing = null;\n scheduleFunc(lastArgs);\n }\n });\n };\n\n const ret = (...args) => {\n if (isTestEnv()) {\n fn(...args);\n return;\n }\n\n lastArgs = args;\n\n if (timerId === null) {\n scheduleFunc(lastArgs);\n } else if (opts === null || opts === void 0 ? void 0 : opts.trailing) {\n lastArgsTrailing = args;\n }\n };\n\n ret.flush = () => {\n if (timerId !== null) {\n cancelAnimationFrame(timerId);\n timerId = null;\n }\n\n if (lastArgs) {\n fn(...(lastArgsTrailing || lastArgs));\n lastArgs = lastArgsTrailing = null;\n }\n };\n\n ret.cancel = () => {\n lastArgs = lastArgsTrailing = null;\n\n if (timerId !== null) {\n cancelAnimationFrame(timerId);\n timerId = null;\n }\n };\n\n return ret;\n};\n/**\n * Exponential ease-out method\n *\n * @param {number} k - The value to be tweened.\n * @returns {number} The tweened value.\n */\n\nconst easeOut = k => {\n return 1 - Math.pow(1 - k, 4);\n};\n\nconst easeOutInterpolate = (from, to, progress) => {\n return (to - from) * easeOut(progress) + from;\n};\n/**\n * Animates values from `fromValues` to `toValues` using the requestAnimationFrame API.\n * Executes the `onStep` callback on each step with the interpolated values.\n * Returns a function that can be called to cancel the animation.\n *\n * @example\n * // Example usage:\n * const fromValues = { x: 0, y: 0 };\n * const toValues = { x: 100, y: 200 };\n * const onStep = ({x, y}) => {\n * setState(x, y)\n * };\n * const onCancel = () => {\n * console.log(\"Animation canceled\");\n * };\n *\n * const cancelAnimation = easeToValuesRAF({\n * fromValues,\n * toValues,\n * onStep,\n * onCancel,\n * });\n *\n * // To cancel the animation:\n * cancelAnimation();\n */\n\n\nconst easeToValuesRAF = ({\n fromValues,\n toValues,\n onStep,\n duration = 250,\n interpolateValue,\n onStart,\n onEnd,\n onCancel\n}) => {\n let canceled = false;\n let frameId = 0;\n let startTime;\n\n function step(timestamp) {\n if (canceled) {\n return;\n }\n\n if (startTime === undefined) {\n startTime = timestamp;\n onStart === null || onStart === void 0 ? void 0 : onStart();\n }\n\n const elapsed = Math.min(timestamp - startTime, duration);\n const factor = easeOut(elapsed / duration);\n const newValues = {};\n Object.keys(fromValues).forEach(key => {\n const _key = key;\n const result = (toValues[_key] - fromValues[_key]) * factor + fromValues[_key];\n newValues[_key] = result;\n });\n onStep(newValues);\n\n if (elapsed < duration) {\n const progress = elapsed / duration;\n const newValues = {};\n Object.keys(fromValues).forEach(key => {\n const _key = key;\n const startValue = fromValues[_key];\n const endValue = toValues[_key];\n let result;\n result = interpolateValue ? interpolateValue(startValue, endValue, progress, _key) : easeOutInterpolate(startValue, endValue, progress);\n\n if (result == null) {\n result = easeOutInterpolate(startValue, endValue, progress);\n }\n\n newValues[_key] = result;\n });\n onStep(newValues);\n frameId = window.requestAnimationFrame(step);\n } else {\n onStep(toValues);\n onEnd === null || onEnd === void 0 ? void 0 : onEnd();\n }\n }\n\n frameId = window.requestAnimationFrame(step);\n return () => {\n onCancel === null || onCancel === void 0 ? void 0 : onCancel();\n canceled = true;\n window.cancelAnimationFrame(frameId);\n };\n}; // https://github.com/lodash/lodash/blob/es/chunk.js\n\nconst chunk = (array, size) => {\n if (!array.length || size < 1) {\n return [];\n }\n\n let index = 0;\n let resIndex = 0;\n const result = Array(Math.ceil(array.length / size));\n\n while (index < array.length) {\n result[resIndex++] = array.slice(index, index += size);\n }\n\n return result;\n};\nconst selectNode = node => {\n const selection = window.getSelection();\n\n if (selection) {\n const range = document.createRange();\n range.selectNodeContents(node);\n selection.removeAllRanges();\n selection.addRange(range);\n }\n};\nconst removeSelection = () => {\n const selection = window.getSelection();\n\n if (selection) {\n selection.removeAllRanges();\n }\n};\nconst distance = (x, y) => Math.abs(x - y);\nconst isSelectionLikeTool = type => {\n return type === \"selection\" || type === \"lasso\";\n};\nconst updateActiveTool = (appState, data) => {\n var _a, _b, _c;\n\n if (data.type === \"custom\") {\n return Object.assign(Object.assign({}, appState.activeTool), {\n type: \"custom\",\n customType: data.customType,\n locked: (_a = data.locked) !== null && _a !== void 0 ? _a : appState.activeTool.locked\n });\n }\n\n return Object.assign(Object.assign({}, appState.activeTool), {\n lastActiveTool: data.lastActiveToolBeforeEraser === undefined ? appState.activeTool.lastActiveTool : data.lastActiveToolBeforeEraser,\n type: data.type,\n customType: null,\n locked: (_b = data.locked) !== null && _b !== void 0 ? _b : appState.activeTool.locked,\n fromSelection: (_c = data.fromSelection) !== null && _c !== void 0 ? _c : false\n });\n};\nconst isFullScreen = () => {\n var _a;\n\n return ((_a = document.fullscreenElement) === null || _a === void 0 ? void 0 : _a.nodeName) === \"HTML\";\n};\nconst allowFullScreen = () => document.documentElement.requestFullscreen();\nconst exitFullScreen = () => document.exitFullscreen();\nconst viewportCoordsToSceneCoords = ({\n clientX,\n clientY\n}, {\n zoom,\n offsetLeft,\n offsetTop,\n scrollX,\n scrollY\n}) => {\n const x = (clientX - offsetLeft) / zoom.value - scrollX;\n const y = (clientY - offsetTop) / zoom.value - scrollY;\n return {\n x,\n y\n };\n};\nconst sceneCoordsToViewportCoords = ({\n sceneX,\n sceneY\n}, {\n zoom,\n offsetLeft,\n offsetTop,\n scrollX,\n scrollY\n}) => {\n const x = (sceneX + scrollX) * zoom.value + offsetLeft;\n const y = (sceneY + scrollY) * zoom.value + offsetTop;\n return {\n x,\n y\n };\n};\nconst getGlobalCSSVariable = name => getComputedStyle(document.documentElement).getPropertyValue(`--${name}`);\nconst RS_LTR_CHARS = \"A-Za-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02B8\\u0300-\\u0590\\u0800-\\u1FFF\" + \"\\u2C00-\\uFB1C\\uFDFE-\\uFE6F\\uFEFD-\\uFFFF\";\nconst RS_RTL_CHARS = \"\\u0591-\\u07FF\\uFB1D-\\uFDFD\\uFE70-\\uFEFC\";\nconst RE_RTL_CHECK = new RegExp(`^[^${RS_LTR_CHARS}]*[${RS_RTL_CHARS}]`);\n/**\n * Checks whether first directional character is RTL. Meaning whether it starts\n * with RTL characters, or indeterminate (numbers etc.) characters followed by\n * RTL.\n * See https://github.com/excalidraw/excalidraw/pull/1722#discussion_r436340171\n */\n\nconst isRTL = text => RE_RTL_CHECK.test(text);\nconst tupleToCoors = xyTuple => {\n const [x, y] = xyTuple;\n return {\n x,\n y\n };\n};\n/** use as a rejectionHandler to mute filesystem Abort errors */\n\nconst muteFSAbortError = error => {\n if ((error === null || error === void 0 ? void 0 : error.name) === \"AbortError\") {\n console.warn(error);\n return;\n }\n\n throw error;\n};\nconst findIndex = (array, cb, fromIndex = 0) => {\n if (fromIndex < 0) {\n fromIndex = array.length + fromIndex;\n }\n\n fromIndex = Math.min(array.length, Math.max(fromIndex, 0));\n let index = fromIndex - 1;\n\n while (++index < array.length) {\n if (cb(array[index], index, array)) {\n return index;\n }\n }\n\n return -1;\n};\nconst findLastIndex = (array, cb, fromIndex = array.length - 1) => {\n if (fromIndex < 0) {\n fromIndex = array.length + fromIndex;\n }\n\n fromIndex = Math.min(array.length - 1, Math.max(fromIndex, 0));\n let index = fromIndex + 1;\n\n while (--index > -1) {\n if (cb(array[index], index, array)) {\n return index;\n }\n }\n\n return -1;\n};\n/** returns the first non-null mapped value */\n\nconst mapFind = (collection, iteratee) => {\n for (let idx = 0; idx < collection.length; idx++) {\n const result = iteratee(collection[idx], idx);\n\n if (result != null) {\n return result;\n }\n }\n\n return undefined;\n};\nconst isTransparent = color => {\n const isRGBTransparent = color.length === 5 && color.substr(4, 1) === \"0\";\n const isRRGGBBTransparent = color.length === 9 && color.substr(7, 2) === \"00\";\n return isRGBTransparent || isRRGGBBTransparent || color === _colors__WEBPACK_IMPORTED_MODULE_1__.COLOR_PALETTE.transparent;\n};\nconst resolvablePromise = () => {\n let resolve;\n let reject;\n const promise = new Promise((_resolve, _reject) => {\n resolve = _resolve;\n reject = _reject;\n });\n promise.resolve = resolve;\n promise.reject = reject;\n return promise;\n}; //https://stackoverflow.com/a/9462382/8418\n\nconst nFormatter = (num, digits) => {\n const si = [{\n value: 1,\n symbol: \"b\"\n }, {\n value: 1e3,\n symbol: \"k\"\n }, {\n value: 1e6,\n symbol: \"M\"\n }, {\n value: 1e9,\n symbol: \"G\"\n }];\n const rx = /\\.0+$|(\\.[0-9]*[1-9])0+$/;\n let index;\n\n for (index = si.length - 1; index > 0; index--) {\n if (num >= si[index].value) {\n break;\n }\n }\n\n return (num / si[index].value).toFixed(digits).replace(rx, \"$1\") + si[index].symbol;\n};\nconst getVersion = () => {\n var _a;\n\n return ((_a = document.querySelector('meta[name=\"version\"]')) === null || _a === void 0 ? void 0 : _a.content) || _constants__WEBPACK_IMPORTED_MODULE_2__.DEFAULT_VERSION;\n}; // Adapted from https://github.com/Modernizr/Modernizr/blob/master/feature-detects/emoji.js\n\nconst supportsEmoji = () => {\n const canvas = document.createElement(\"canvas\");\n const ctx = canvas.getContext(\"2d\");\n\n if (!ctx) {\n return false;\n }\n\n const offset = 12;\n ctx.fillStyle = \"#f00\";\n ctx.textBaseline = \"top\";\n ctx.font = \"32px Arial\"; // Modernizr used 🐨, but it is sort of supported on Windows 7.\n // Luckily 😀 isn't supported.\n\n ctx.fillText(\"😀\", 0, 0);\n return ctx.getImageData(offset, offset, 1, 1).data[0] !== 0;\n};\nconst getNearestScrollableContainer = element => {\n let parent = element.parentElement;\n\n while (parent) {\n if (parent === document.body) {\n return document;\n }\n\n const {\n overflowY\n } = window.getComputedStyle(parent);\n const hasScrollableContent = parent.scrollHeight > parent.clientHeight;\n\n if (hasScrollableContent && (overflowY === \"auto\" || overflowY === \"scroll\" || overflowY === \"overlay\")) {\n return parent;\n }\n\n parent = parent.parentElement;\n }\n\n return document;\n};\nconst focusNearestParent = element => {\n let parent = element.parentElement;\n\n while (parent) {\n if (parent.tabIndex > -1) {\n parent.focus();\n return;\n }\n\n parent = parent.parentElement;\n }\n};\nconst preventUnload = event => {\n event.preventDefault(); // NOTE: modern browsers no longer allow showing a custom message here\n\n event.returnValue = \"\";\n};\nconst bytesToHexString = bytes => {\n return Array.from(bytes).map(byte => `0${byte.toString(16)}`.slice(-2)).join(\"\");\n};\nconst getUpdatedTimestamp = () => isTestEnv() ? 1 : Date.now();\n/**\n * Transforms array of objects containing `id` attribute,\n * or array of ids (strings), into a Map, keyd by `id`.\n */\n\nconst arrayToMap = items => {\n if (items instanceof Map) {\n return items;\n }\n\n return items.reduce((acc, element) => {\n acc.set(typeof element === \"string\" ? element : element.id, element);\n return acc;\n }, new Map());\n};\nconst arrayToMapWithIndex = elements => elements.reduce((acc, element, idx) => {\n acc.set(element.id, [element, idx]);\n return acc;\n}, new Map());\n/**\n * Transform array into an object, use only when array order is irrelevant.\n */\n\nconst arrayToObject = (array, groupBy) => array.reduce((acc, value, idx) => {\n acc[groupBy ? groupBy(value) : idx] = value;\n return acc;\n}, {});\n/**\n * Creates a circular doubly linked list by adding `prev` and `next` props to the existing array nodes.\n */\n\nconst arrayToList = array => array.reduce((acc, curr, index) => {\n const node = Object.assign(Object.assign({}, curr), {\n prev: null,\n next: null\n }); // no-op for first item, we don't want circular references on a single item\n\n if (index !== 0) {\n const prevNode = acc[index - 1];\n node.prev = prevNode;\n prevNode.next = node;\n\n if (index === array.length - 1) {\n // make the references circular and connect head & tail\n const firstNode = acc[0];\n node.next = firstNode;\n firstNode.prev = node;\n }\n }\n\n acc.push(node);\n return acc;\n}, []);\n/**\n * Converts a readonly array or map into an iterable.\n * Useful for avoiding entry allocations when iterating object / map on each iteration.\n */\n\nconst toIterable = values => {\n return Array.isArray(values) ? values : values.values();\n};\n/**\n * Converts a readonly array or map into an array.\n */\n\nconst toArray = values => {\n return Array.isArray(values) ? values : Array.from(toIterable(values));\n};\nconst isTestEnv = () => \"development\" === _constants__WEBPACK_IMPORTED_MODULE_2__.ENV.TEST;\nconst isDevEnv = () => \"development\" === _constants__WEBPACK_IMPORTED_MODULE_2__.ENV.DEVELOPMENT;\nconst isProdEnv = () => \"development\" === _constants__WEBPACK_IMPORTED_MODULE_2__.ENV.PRODUCTION;\nconst isServerEnv = () => {\n var _a;\n\n return typeof process !== \"undefined\" && !!((_a = process === null || process === void 0 ? void 0 : ({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-64\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true})) === null || _a === void 0 ? void 0 : _a.NODE_ENV);\n};\nconst wrapEvent = (name, nativeEvent) => {\n return new CustomEvent(name, {\n detail: {\n nativeEvent\n },\n cancelable: true\n });\n};\nconst updateObject = (obj, updates) => {\n let didChange = false;\n\n for (const key in updates) {\n const value = updates[key];\n\n if (typeof value !== \"undefined\") {\n if (obj[key] === value && ( // if object, always update because its attrs could have changed\n typeof value !== \"object\" || value === null)) {\n continue;\n }\n\n didChange = true;\n }\n }\n\n if (!didChange) {\n return obj;\n }\n\n return Object.assign(Object.assign({}, obj), updates);\n};\nconst isPrimitive = val => {\n const type = typeof val;\n return val == null || type !== \"object\" && type !== \"function\";\n};\nconst getFrame = () => {\n try {\n return window.self === window.top ? \"top\" : \"iframe\";\n } catch (error) {\n return \"iframe\";\n }\n};\nconst isRunningInIframe = () => getFrame() === \"iframe\";\nconst isPromiseLike = value => {\n return !!value && typeof value === \"object\" && \"then\" in value && \"catch\" in value && \"finally\" in value;\n};\nconst queryFocusableElements = container => {\n const focusableElements = container === null || container === void 0 ? void 0 : container.querySelectorAll(\"button, a, input, select, textarea, div[tabindex], label[tabindex]\");\n return focusableElements ? Array.from(focusableElements).filter(element => element.tabIndex > -1 && !element.disabled) : [];\n};\n/** use as a fallback after identity check (for perf reasons) */\n\nconst _defaultIsShallowComparatorFallback = (a, b) => {\n // consider two empty arrays equal\n if (Array.isArray(a) && Array.isArray(b) && a.length === 0 && b.length === 0) {\n return true;\n }\n\n return a === b;\n};\n/**\n * Returns whether object/array is shallow equal.\n * Considers empty object/arrays as equal (whether top-level or second-level).\n */\n\n\nconst isShallowEqual = (objA, objB, comparators, debug = false) => {\n const aKeys = Object.keys(objA);\n const bKeys = Object.keys(objB);\n\n if (aKeys.length !== bKeys.length) {\n if (debug) {\n console.warn(`%cisShallowEqual: objects don't have same properties ->`, \"color: #8B4000\", objA, objB);\n }\n\n return false;\n }\n\n if (comparators && Array.isArray(comparators)) {\n for (const key of comparators) {\n const ret = objA[key] === objB[key] || _defaultIsShallowComparatorFallback(objA[key], objB[key]);\n\n if (!ret) {\n if (debug) {\n console.warn(`%cisShallowEqual: ${key} not equal ->`, \"color: #8B4000\", objA[key], objB[key]);\n }\n\n return false;\n }\n }\n\n return true;\n }\n\n return aKeys.every(key => {\n const comparator = comparators === null || comparators === void 0 ? void 0 : comparators[key];\n const ret = comparator ? comparator(objA[key], objB[key]) : objA[key] === objB[key] || _defaultIsShallowComparatorFallback(objA[key], objB[key]);\n\n if (!ret && debug) {\n console.warn(`%cisShallowEqual: ${key} not equal ->`, \"color: #8B4000\", objA[key], objB[key]);\n }\n\n return ret;\n });\n}; // taken from Radix UI\n// https://github.com/radix-ui/primitives/blob/main/packages/core/primitive/src/primitive.tsx\n\nconst composeEventHandlers = (originalEventHandler, ourEventHandler, {\n checkForDefaultPrevented = true\n} = {}) => {\n return function handleEvent(event) {\n originalEventHandler === null || originalEventHandler === void 0 ? void 0 : originalEventHandler(event);\n\n if (!checkForDefaultPrevented || !(event === null || event === void 0 ? void 0 : event.defaultPrevented)) {\n return ourEventHandler === null || ourEventHandler === void 0 ? void 0 : ourEventHandler(event);\n }\n };\n};\n/**\n * supply `null` as message if non-never value is valid, you just need to\n * typecheck against it\n */\n\nconst assertNever = (value, message, softAssert) => {\n if (!message) {\n return value;\n }\n\n if (softAssert) {\n console.error(message);\n return value;\n }\n\n throw new Error(message);\n};\nfunction invariant(condition, message) {\n if (!condition) {\n throw new Error(message);\n }\n}\n/**\n * Memoizes on values of `opts` object (strict equality).\n */\n\nconst memoize = func => {\n let lastArgs;\n let lastResult;\n\n const ret = function (opts) {\n const currentArgs = Object.entries(opts);\n\n if (lastArgs) {\n let argsAreEqual = true;\n\n for (const [key, value] of currentArgs) {\n if (lastArgs.get(key) !== value) {\n argsAreEqual = false;\n break;\n }\n }\n\n if (argsAreEqual) {\n return lastResult;\n }\n }\n\n const result = func(opts);\n lastArgs = new Map(currentArgs);\n lastResult = result;\n return result;\n };\n\n ret.clear = () => {\n lastArgs = undefined;\n lastResult = undefined;\n };\n\n return ret;\n};\n/** Checks if value is inside given collection. Useful for type-safety. */\n\nconst isMemberOf = (\n/** Set/Map/Array/Object */\ncollection,\n/** value to look for */\nvalue) => {\n return collection instanceof Set || collection instanceof Map ? collection.has(value) : \"includes\" in collection ? collection.includes(value) : collection.hasOwnProperty(value);\n};\nconst cloneJSON = obj => JSON.parse(JSON.stringify(obj));\nconst updateStable = (prevValue, nextValue) => {\n if (isShallowEqual(prevValue, nextValue)) {\n return prevValue;\n }\n\n return nextValue;\n}; // implem\n\nfunction addEventListener(\n/**\n * allows for falsy values so you don't have to type check when adding\n * event listeners to optional elements\n */\ntarget, type, listener, options) {\n var _a;\n\n if (!target) {\n return () => {};\n }\n\n (_a = target === null || target === void 0 ? void 0 : target.addEventListener) === null || _a === void 0 ? void 0 : _a.call(target, type, listener, options);\n return () => {\n var _a;\n\n (_a = target === null || target === void 0 ? void 0 : target.removeEventListener) === null || _a === void 0 ? void 0 : _a.call(target, type, listener, options);\n };\n}\nfunction getSvgPathFromStroke(points, closed = true) {\n const len = points.length;\n\n if (len < 4) {\n return ``;\n }\n\n let a = points[0];\n let b = points[1];\n const c = points[2];\n let result = `M${a[0].toFixed(2)},${a[1].toFixed(2)} Q${b[0].toFixed(2)},${b[1].toFixed(2)} ${(0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.average)(b[0], c[0]).toFixed(2)},${(0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.average)(b[1], c[1]).toFixed(2)} T`;\n\n for (let i = 2, max = len - 1; i < max; i++) {\n a = points[i];\n b = points[i + 1];\n result += `${(0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.average)(a[0], b[0]).toFixed(2)},${(0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.average)(a[1], b[1]).toFixed(2)} `;\n }\n\n if (closed) {\n result += \"Z\";\n }\n\n return result;\n}\nconst normalizeEOL = str => {\n return str.replace(/\\r?\\n|\\r/g, \"\\n\");\n};\n/**\n * Makes type into a branded type, ensuring that value is assignable to\n * the base ubranded type. Optionally you can explicitly supply current value\n * type to combine both (useful for composite branded types. Make sure you\n * compose branded types which are not composite themselves.)\n */\n\nconst toBrandedType = value => {\n return value;\n}; // -----------------------------------------------------------------------------\n// Promise.try, adapted from https://github.com/sindresorhus/p-try\n\nconst promiseTry = async (fn, ...args) => {\n return new Promise(resolve => {\n resolve(fn(...args));\n });\n};\nconst isAnyTrue = (...args) => Math.max(...args.map(arg => arg ? 1 : 0)) > 0;\nconst safelyParseJSON = json => {\n try {\n return JSON.parse(json);\n } catch (_a) {\n return null;\n }\n};\n/**\n * use when you need to render unsafe string as HTML attribute, but MAKE SURE\n * the attribute is double-quoted when constructing the HTML string\n */\n\nconst escapeDoubleQuotes = str => {\n return str.replace(/\"/g, \"&quot;\");\n};\nconst castArray = value => Array.isArray(value) ? value : [value];\n/** hack for Array.isArray type guard not working with readonly value[] */\n\nconst isReadonlyArray = value => {\n return Array.isArray(value);\n};\nconst sizeOf = value => {\n return isReadonlyArray(value) ? value.length : value instanceof Map || value instanceof Set ? value.size : Object.keys(value).length;\n};\nconst reduceToCommonValue = (collection, getValue) => {\n if (sizeOf(collection) === 0) {\n return null;\n }\n\n const valueExtractor = getValue || (item => item);\n\n let commonValue = null;\n\n for (const item of collection) {\n const value = valueExtractor(item);\n\n if ((commonValue === null || commonValue === value) && value != null) {\n commonValue = value;\n } else {\n return null;\n }\n }\n\n return commonValue;\n};\nconst FEATURE_FLAGS_STORAGE_KEY = \"excalidraw-feature-flags\";\nconst DEFAULT_FEATURE_FLAGS = {\n COMPLEX_BINDINGS: false\n};\nlet featureFlags = null;\nconst getFeatureFlag = flag => {\n if (!featureFlags) {\n try {\n const serializedFlags = localStorage.getItem(FEATURE_FLAGS_STORAGE_KEY);\n\n if (serializedFlags) {\n const flags = JSON.parse(serializedFlags);\n featureFlags = flags !== null && flags !== void 0 ? flags : DEFAULT_FEATURE_FLAGS;\n }\n } catch (_a) {}\n }\n\n return (featureFlags || DEFAULT_FEATURE_FLAGS)[flag];\n};\nconst setFeatureFlag = (flag, value) => {\n try {\n featureFlags = Object.assign(Object.assign({}, featureFlags || DEFAULT_FEATURE_FLAGS), {\n [flag]: value\n });\n localStorage.setItem(FEATURE_FLAGS_STORAGE_KEY, JSON.stringify(featureFlags));\n } catch (e) {\n console.error(\"unable to set feature flag\", e);\n }\n};\n\n//# sourceURL=webpack://ExcalidrawLib/../common/src/utils.ts?");
13050
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ addEventListener: () => (/* binding */ addEventListener),\n/* harmony export */ allowFullScreen: () => (/* binding */ allowFullScreen),\n/* harmony export */ arrayToList: () => (/* binding */ arrayToList),\n/* harmony export */ arrayToMap: () => (/* binding */ arrayToMap),\n/* harmony export */ arrayToMapWithIndex: () => (/* binding */ arrayToMapWithIndex),\n/* harmony export */ arrayToObject: () => (/* binding */ arrayToObject),\n/* harmony export */ assertNever: () => (/* binding */ assertNever),\n/* harmony export */ bytesToHexString: () => (/* binding */ bytesToHexString),\n/* harmony export */ capitalizeString: () => (/* binding */ capitalizeString),\n/* harmony export */ castArray: () => (/* binding */ castArray),\n/* harmony export */ chunk: () => (/* binding */ chunk),\n/* harmony export */ cloneJSON: () => (/* binding */ cloneJSON),\n/* harmony export */ composeEventHandlers: () => (/* binding */ composeEventHandlers),\n/* harmony export */ debounce: () => (/* binding */ debounce),\n/* harmony export */ distance: () => (/* binding */ distance),\n/* harmony export */ easeOut: () => (/* binding */ easeOut),\n/* harmony export */ easeToValuesRAF: () => (/* binding */ easeToValuesRAF),\n/* harmony export */ escapeDoubleQuotes: () => (/* binding */ escapeDoubleQuotes),\n/* harmony export */ exitFullScreen: () => (/* binding */ exitFullScreen),\n/* harmony export */ findIndex: () => (/* binding */ findIndex),\n/* harmony export */ findLastIndex: () => (/* binding */ findLastIndex),\n/* harmony export */ focusNearestParent: () => (/* binding */ focusNearestParent),\n/* harmony export */ getDateTime: () => (/* binding */ getDateTime),\n/* harmony export */ getFeatureFlag: () => (/* binding */ getFeatureFlag),\n/* harmony export */ getFontFamilyString: () => (/* binding */ getFontFamilyString),\n/* harmony export */ getFontString: () => (/* binding */ getFontString),\n/* harmony export */ getFrame: () => (/* binding */ getFrame),\n/* harmony export */ getGlobalCSSVariable: () => (/* binding */ getGlobalCSSVariable),\n/* harmony export */ getNearestScrollableContainer: () => (/* binding */ getNearestScrollableContainer),\n/* harmony export */ getSvgPathFromStroke: () => (/* binding */ getSvgPathFromStroke),\n/* harmony export */ getUpdatedTimestamp: () => (/* binding */ getUpdatedTimestamp),\n/* harmony export */ getVersion: () => (/* binding */ getVersion),\n/* harmony export */ invariant: () => (/* binding */ invariant),\n/* harmony export */ isAnyTrue: () => (/* binding */ isAnyTrue),\n/* harmony export */ isDevEnv: () => (/* binding */ isDevEnv),\n/* harmony export */ isFullScreen: () => (/* binding */ isFullScreen),\n/* harmony export */ isInputLike: () => (/* binding */ isInputLike),\n/* harmony export */ isInteractive: () => (/* binding */ isInteractive),\n/* harmony export */ isMemberOf: () => (/* binding */ isMemberOf),\n/* harmony export */ isPrimitive: () => (/* binding */ isPrimitive),\n/* harmony export */ isProdEnv: () => (/* binding */ isProdEnv),\n/* harmony export */ isPromiseLike: () => (/* binding */ isPromiseLike),\n/* harmony export */ isRTL: () => (/* binding */ isRTL),\n/* harmony export */ isReadonlyArray: () => (/* binding */ isReadonlyArray),\n/* harmony export */ isRunningInIframe: () => (/* binding */ isRunningInIframe),\n/* harmony export */ isSelectionLikeTool: () => (/* binding */ isSelectionLikeTool),\n/* harmony export */ isServerEnv: () => (/* binding */ isServerEnv),\n/* harmony export */ isShallowEqual: () => (/* binding */ isShallowEqual),\n/* harmony export */ isTestEnv: () => (/* binding */ isTestEnv),\n/* harmony export */ isToolIcon: () => (/* binding */ isToolIcon),\n/* harmony export */ isTransparent: () => (/* binding */ isTransparent),\n/* harmony export */ isWritableElement: () => (/* binding */ isWritableElement),\n/* harmony export */ mapFind: () => (/* binding */ mapFind),\n/* harmony export */ memoize: () => (/* binding */ memoize),\n/* harmony export */ muteFSAbortError: () => (/* binding */ muteFSAbortError),\n/* harmony export */ nFormatter: () => (/* binding */ nFormatter),\n/* harmony export */ nextAnimationFrame: () => (/* binding */ nextAnimationFrame),\n/* harmony export */ normalizeEOL: () => (/* binding */ normalizeEOL),\n/* harmony export */ preventUnload: () => (/* binding */ preventUnload),\n/* harmony export */ promiseTry: () => (/* binding */ promiseTry),\n/* harmony export */ queryFocusableElements: () => (/* binding */ queryFocusableElements),\n/* harmony export */ reduceToCommonValue: () => (/* binding */ reduceToCommonValue),\n/* harmony export */ removeSelection: () => (/* binding */ removeSelection),\n/* harmony export */ resolvablePromise: () => (/* binding */ resolvablePromise),\n/* harmony export */ safelyParseJSON: () => (/* binding */ safelyParseJSON),\n/* harmony export */ sceneCoordsToViewportCoords: () => (/* binding */ sceneCoordsToViewportCoords),\n/* harmony export */ selectNode: () => (/* binding */ selectNode),\n/* harmony export */ setDateTimeForTests: () => (/* binding */ setDateTimeForTests),\n/* harmony export */ setFeatureFlag: () => (/* binding */ setFeatureFlag),\n/* harmony export */ sizeOf: () => (/* binding */ sizeOf),\n/* harmony export */ supportsEmoji: () => (/* binding */ supportsEmoji),\n/* harmony export */ throttleRAF: () => (/* binding */ throttleRAF),\n/* harmony export */ toArray: () => (/* binding */ toArray),\n/* harmony export */ toBrandedType: () => (/* binding */ toBrandedType),\n/* harmony export */ toIterable: () => (/* binding */ toIterable),\n/* harmony export */ tupleToCoors: () => (/* binding */ tupleToCoors),\n/* harmony export */ updateActiveTool: () => (/* binding */ updateActiveTool),\n/* harmony export */ updateObject: () => (/* binding */ updateObject),\n/* harmony export */ updateStable: () => (/* binding */ updateStable),\n/* harmony export */ viewportCoordsToSceneCoords: () => (/* binding */ viewportCoordsToSceneCoords),\n/* harmony export */ wrapEvent: () => (/* binding */ wrapEvent)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_math__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/math */ \"../math/src/index.ts\");\n/* harmony import */ var _colors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./colors */ \"../common/src/colors.ts\");\n/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ \"../common/src/constants.ts\");\n\n\n\nlet mockDateTime = null;\nconst setDateTimeForTests = dateTime => {\n mockDateTime = dateTime;\n};\nconst getDateTime = () => {\n if (mockDateTime) {\n return mockDateTime;\n }\n\n const date = new Date();\n const year = date.getFullYear();\n const month = `${date.getMonth() + 1}`.padStart(2, \"0\");\n const day = `${date.getDate()}`.padStart(2, \"0\");\n const hr = `${date.getHours()}`.padStart(2, \"0\");\n const min = `${date.getMinutes()}`.padStart(2, \"0\");\n return `${year}-${month}-${day}-${hr}${min}`;\n};\nconst capitalizeString = str => str.charAt(0).toUpperCase() + str.slice(1);\nconst isToolIcon = target => target instanceof HTMLElement && target.className.includes(\"ToolIcon\");\nconst isInputLike = target => target instanceof HTMLElement && target.dataset.type === \"wysiwyg\" || target instanceof HTMLBRElement || // newline in wysiwyg\ntarget instanceof HTMLInputElement || target instanceof HTMLTextAreaElement || target instanceof HTMLSelectElement;\nconst isInteractive = target => {\n return isInputLike(target) || target instanceof Element && !!target.closest(\"label, button\");\n};\nconst isWritableElement = target => target instanceof HTMLElement && target.dataset.type === \"wysiwyg\" || target instanceof HTMLBRElement || // newline in wysiwyg\ntarget instanceof HTMLTextAreaElement || target instanceof HTMLInputElement && (target.type === \"text\" || target.type === \"number\" || target.type === \"password\" || target.type === \"search\");\nconst getFontFamilyString = ({\n fontFamily\n}) => {\n for (const [fontFamilyString, id] of Object.entries(_constants__WEBPACK_IMPORTED_MODULE_2__.FONT_FAMILY)) {\n if (id === fontFamily) {\n return `${fontFamilyString}${(0,_constants__WEBPACK_IMPORTED_MODULE_2__.getFontFamilyFallbacks)(id).map(x => `, ${x}`).join(\"\")}`;\n }\n }\n\n return _constants__WEBPACK_IMPORTED_MODULE_2__.WINDOWS_EMOJI_FALLBACK_FONT;\n};\n/** returns fontSize+fontFamily string for assignment to DOM elements */\n\nconst getFontString = ({\n fontSize,\n fontFamily\n}) => {\n return `${fontSize}px ${getFontFamilyString({\n fontFamily\n })}`;\n};\n/** executes callback in the frame that's after the current one */\n\nconst nextAnimationFrame = async cb => {\n requestAnimationFrame(() => requestAnimationFrame(cb));\n};\nconst debounce = (fn, timeout) => {\n let handle = 0;\n let lastArgs = null;\n\n const ret = (...args) => {\n lastArgs = args;\n clearTimeout(handle);\n handle = window.setTimeout(() => {\n lastArgs = null;\n fn(...args);\n }, timeout);\n };\n\n ret.flush = () => {\n clearTimeout(handle);\n\n if (lastArgs) {\n const _lastArgs = lastArgs;\n lastArgs = null;\n fn(..._lastArgs);\n }\n };\n\n ret.cancel = () => {\n lastArgs = null;\n clearTimeout(handle);\n };\n\n return ret;\n}; // throttle callback to execute once per animation frame\n\nconst throttleRAF = (fn, opts) => {\n let timerId = null;\n let lastArgs = null;\n let lastArgsTrailing = null;\n\n const scheduleFunc = args => {\n timerId = window.requestAnimationFrame(() => {\n timerId = null;\n fn(...args);\n lastArgs = null;\n\n if (lastArgsTrailing) {\n lastArgs = lastArgsTrailing;\n lastArgsTrailing = null;\n scheduleFunc(lastArgs);\n }\n });\n };\n\n const ret = (...args) => {\n if (isTestEnv()) {\n fn(...args);\n return;\n }\n\n lastArgs = args;\n\n if (timerId === null) {\n scheduleFunc(lastArgs);\n } else if (opts === null || opts === void 0 ? void 0 : opts.trailing) {\n lastArgsTrailing = args;\n }\n };\n\n ret.flush = () => {\n if (timerId !== null) {\n cancelAnimationFrame(timerId);\n timerId = null;\n }\n\n if (lastArgs) {\n fn(...(lastArgsTrailing || lastArgs));\n lastArgs = lastArgsTrailing = null;\n }\n };\n\n ret.cancel = () => {\n lastArgs = lastArgsTrailing = null;\n\n if (timerId !== null) {\n cancelAnimationFrame(timerId);\n timerId = null;\n }\n };\n\n return ret;\n};\n/**\n * Exponential ease-out method\n *\n * @param {number} k - The value to be tweened.\n * @returns {number} The tweened value.\n */\n\nconst easeOut = k => {\n return 1 - Math.pow(1 - k, 4);\n};\n\nconst easeOutInterpolate = (from, to, progress) => {\n return (to - from) * easeOut(progress) + from;\n};\n/**\n * Animates values from `fromValues` to `toValues` using the requestAnimationFrame API.\n * Executes the `onStep` callback on each step with the interpolated values.\n * Returns a function that can be called to cancel the animation.\n *\n * @example\n * // Example usage:\n * const fromValues = { x: 0, y: 0 };\n * const toValues = { x: 100, y: 200 };\n * const onStep = ({x, y}) => {\n * setState(x, y)\n * };\n * const onCancel = () => {\n * console.log(\"Animation canceled\");\n * };\n *\n * const cancelAnimation = easeToValuesRAF({\n * fromValues,\n * toValues,\n * onStep,\n * onCancel,\n * });\n *\n * // To cancel the animation:\n * cancelAnimation();\n */\n\n\nconst easeToValuesRAF = ({\n fromValues,\n toValues,\n onStep,\n duration = 250,\n interpolateValue,\n onStart,\n onEnd,\n onCancel\n}) => {\n let canceled = false;\n let frameId = 0;\n let startTime;\n\n function step(timestamp) {\n if (canceled) {\n return;\n }\n\n if (startTime === undefined) {\n startTime = timestamp;\n onStart === null || onStart === void 0 ? void 0 : onStart();\n }\n\n const elapsed = Math.min(timestamp - startTime, duration);\n const factor = easeOut(elapsed / duration);\n const newValues = {};\n Object.keys(fromValues).forEach(key => {\n const _key = key;\n const result = (toValues[_key] - fromValues[_key]) * factor + fromValues[_key];\n newValues[_key] = result;\n });\n onStep(newValues);\n\n if (elapsed < duration) {\n const progress = elapsed / duration;\n const newValues = {};\n Object.keys(fromValues).forEach(key => {\n const _key = key;\n const startValue = fromValues[_key];\n const endValue = toValues[_key];\n let result;\n result = interpolateValue ? interpolateValue(startValue, endValue, progress, _key) : easeOutInterpolate(startValue, endValue, progress);\n\n if (result == null) {\n result = easeOutInterpolate(startValue, endValue, progress);\n }\n\n newValues[_key] = result;\n });\n onStep(newValues);\n frameId = window.requestAnimationFrame(step);\n } else {\n onStep(toValues);\n onEnd === null || onEnd === void 0 ? void 0 : onEnd();\n }\n }\n\n frameId = window.requestAnimationFrame(step);\n return () => {\n onCancel === null || onCancel === void 0 ? void 0 : onCancel();\n canceled = true;\n window.cancelAnimationFrame(frameId);\n };\n}; // https://github.com/lodash/lodash/blob/es/chunk.js\n\nconst chunk = (array, size) => {\n if (!array.length || size < 1) {\n return [];\n }\n\n let index = 0;\n let resIndex = 0;\n const result = Array(Math.ceil(array.length / size));\n\n while (index < array.length) {\n result[resIndex++] = array.slice(index, index += size);\n }\n\n return result;\n};\nconst selectNode = node => {\n const selection = window.getSelection();\n\n if (selection) {\n const range = document.createRange();\n range.selectNodeContents(node);\n selection.removeAllRanges();\n selection.addRange(range);\n }\n};\nconst removeSelection = () => {\n const selection = window.getSelection();\n\n if (selection) {\n selection.removeAllRanges();\n }\n};\nconst distance = (x, y) => Math.abs(x - y);\nconst isSelectionLikeTool = type => {\n return type === \"selection\" || type === \"lasso\";\n};\nconst updateActiveTool = (appState, data) => {\n var _a, _b, _c;\n\n if (data.type === \"custom\") {\n return Object.assign(Object.assign({}, appState.activeTool), {\n type: \"custom\",\n customType: data.customType,\n locked: (_a = data.locked) !== null && _a !== void 0 ? _a : appState.activeTool.locked\n });\n }\n\n return Object.assign(Object.assign({}, appState.activeTool), {\n lastActiveTool: data.lastActiveToolBeforeEraser === undefined ? appState.activeTool.lastActiveTool : data.lastActiveToolBeforeEraser,\n type: data.type,\n customType: null,\n locked: (_b = data.locked) !== null && _b !== void 0 ? _b : appState.activeTool.locked,\n fromSelection: (_c = data.fromSelection) !== null && _c !== void 0 ? _c : false\n });\n};\nconst isFullScreen = () => {\n var _a;\n\n return ((_a = document.fullscreenElement) === null || _a === void 0 ? void 0 : _a.nodeName) === \"HTML\";\n};\nconst allowFullScreen = () => document.documentElement.requestFullscreen();\nconst exitFullScreen = () => document.exitFullscreen();\nconst viewportCoordsToSceneCoords = ({\n clientX,\n clientY\n}, {\n zoom,\n offsetLeft,\n offsetTop,\n scrollX,\n scrollY\n}) => {\n const x = (clientX - offsetLeft) / zoom.value - scrollX;\n const y = (clientY - offsetTop) / zoom.value - scrollY;\n return {\n x,\n y\n };\n};\nconst sceneCoordsToViewportCoords = ({\n sceneX,\n sceneY\n}, {\n zoom,\n offsetLeft,\n offsetTop,\n scrollX,\n scrollY\n}) => {\n const x = (sceneX + scrollX) * zoom.value + offsetLeft;\n const y = (sceneY + scrollY) * zoom.value + offsetTop;\n return {\n x,\n y\n };\n};\nconst getGlobalCSSVariable = name => getComputedStyle(document.documentElement).getPropertyValue(`--${name}`);\nconst RS_LTR_CHARS = \"A-Za-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02B8\\u0300-\\u0590\\u0800-\\u1FFF\" + \"\\u2C00-\\uFB1C\\uFDFE-\\uFE6F\\uFEFD-\\uFFFF\";\nconst RS_RTL_CHARS = \"\\u0591-\\u07FF\\uFB1D-\\uFDFD\\uFE70-\\uFEFC\";\nconst RE_RTL_CHECK = new RegExp(`^[^${RS_LTR_CHARS}]*[${RS_RTL_CHARS}]`);\n/**\n * Checks whether first directional character is RTL. Meaning whether it starts\n * with RTL characters, or indeterminate (numbers etc.) characters followed by\n * RTL.\n * See https://github.com/excalidraw/excalidraw/pull/1722#discussion_r436340171\n */\n\nconst isRTL = text => RE_RTL_CHECK.test(text);\nconst tupleToCoors = xyTuple => {\n const [x, y] = xyTuple;\n return {\n x,\n y\n };\n};\n/** use as a rejectionHandler to mute filesystem Abort errors */\n\nconst muteFSAbortError = error => {\n if ((error === null || error === void 0 ? void 0 : error.name) === \"AbortError\") {\n console.warn(error);\n return;\n }\n\n throw error;\n};\nconst findIndex = (array, cb, fromIndex = 0) => {\n if (fromIndex < 0) {\n fromIndex = array.length + fromIndex;\n }\n\n fromIndex = Math.min(array.length, Math.max(fromIndex, 0));\n let index = fromIndex - 1;\n\n while (++index < array.length) {\n if (cb(array[index], index, array)) {\n return index;\n }\n }\n\n return -1;\n};\nconst findLastIndex = (array, cb, fromIndex = array.length - 1) => {\n if (fromIndex < 0) {\n fromIndex = array.length + fromIndex;\n }\n\n fromIndex = Math.min(array.length - 1, Math.max(fromIndex, 0));\n let index = fromIndex + 1;\n\n while (--index > -1) {\n if (cb(array[index], index, array)) {\n return index;\n }\n }\n\n return -1;\n};\n/** returns the first non-null mapped value */\n\nconst mapFind = (collection, iteratee) => {\n for (let idx = 0; idx < collection.length; idx++) {\n const result = iteratee(collection[idx], idx);\n\n if (result != null) {\n return result;\n }\n }\n\n return undefined;\n};\nconst isTransparent = color => {\n const isRGBTransparent = color.length === 5 && color.substr(4, 1) === \"0\";\n const isRRGGBBTransparent = color.length === 9 && color.substr(7, 2) === \"00\";\n return isRGBTransparent || isRRGGBBTransparent || color === _colors__WEBPACK_IMPORTED_MODULE_1__.COLOR_PALETTE.transparent;\n};\nconst resolvablePromise = () => {\n let resolve;\n let reject;\n const promise = new Promise((_resolve, _reject) => {\n resolve = _resolve;\n reject = _reject;\n });\n promise.resolve = resolve;\n promise.reject = reject;\n return promise;\n}; //https://stackoverflow.com/a/9462382/8418\n\nconst nFormatter = (num, digits) => {\n const si = [{\n value: 1,\n symbol: \"b\"\n }, {\n value: 1e3,\n symbol: \"k\"\n }, {\n value: 1e6,\n symbol: \"M\"\n }, {\n value: 1e9,\n symbol: \"G\"\n }];\n const rx = /\\.0+$|(\\.[0-9]*[1-9])0+$/;\n let index;\n\n for (index = si.length - 1; index > 0; index--) {\n if (num >= si[index].value) {\n break;\n }\n }\n\n return (num / si[index].value).toFixed(digits).replace(rx, \"$1\") + si[index].symbol;\n};\nconst getVersion = () => {\n var _a;\n\n return ((_a = document.querySelector('meta[name=\"version\"]')) === null || _a === void 0 ? void 0 : _a.content) || _constants__WEBPACK_IMPORTED_MODULE_2__.DEFAULT_VERSION;\n}; // Adapted from https://github.com/Modernizr/Modernizr/blob/master/feature-detects/emoji.js\n\nconst supportsEmoji = () => {\n const canvas = document.createElement(\"canvas\");\n const ctx = canvas.getContext(\"2d\");\n\n if (!ctx) {\n return false;\n }\n\n const offset = 12;\n ctx.fillStyle = \"#f00\";\n ctx.textBaseline = \"top\";\n ctx.font = \"32px Arial\"; // Modernizr used 🐨, but it is sort of supported on Windows 7.\n // Luckily 😀 isn't supported.\n\n ctx.fillText(\"😀\", 0, 0);\n return ctx.getImageData(offset, offset, 1, 1).data[0] !== 0;\n};\nconst getNearestScrollableContainer = element => {\n let parent = element.parentElement;\n\n while (parent) {\n if (parent === document.body) {\n return document;\n }\n\n const {\n overflowY\n } = window.getComputedStyle(parent);\n const hasScrollableContent = parent.scrollHeight > parent.clientHeight;\n\n if (hasScrollableContent && (overflowY === \"auto\" || overflowY === \"scroll\" || overflowY === \"overlay\")) {\n return parent;\n }\n\n parent = parent.parentElement;\n }\n\n return document;\n};\nconst focusNearestParent = element => {\n let parent = element.parentElement;\n\n while (parent) {\n if (parent.tabIndex > -1) {\n parent.focus();\n return;\n }\n\n parent = parent.parentElement;\n }\n};\nconst preventUnload = event => {\n event.preventDefault(); // NOTE: modern browsers no longer allow showing a custom message here\n\n event.returnValue = \"\";\n};\nconst bytesToHexString = bytes => {\n return Array.from(bytes).map(byte => `0${byte.toString(16)}`.slice(-2)).join(\"\");\n};\nconst getUpdatedTimestamp = () => isTestEnv() ? 1 : Date.now();\n/**\n * Transforms array of objects containing `id` attribute,\n * or array of ids (strings), into a Map, keyd by `id`.\n */\n\nconst arrayToMap = items => {\n if (items instanceof Map) {\n return items;\n }\n\n return items.reduce((acc, element) => {\n acc.set(typeof element === \"string\" ? element : element.id, element);\n return acc;\n }, new Map());\n};\nconst arrayToMapWithIndex = elements => elements.reduce((acc, element, idx) => {\n acc.set(element.id, [element, idx]);\n return acc;\n}, new Map());\n/**\n * Transform array into an object, use only when array order is irrelevant.\n */\n\nconst arrayToObject = (array, groupBy) => array.reduce((acc, value, idx) => {\n acc[groupBy ? groupBy(value) : idx] = value;\n return acc;\n}, {});\n/**\n * Creates a circular doubly linked list by adding `prev` and `next` props to the existing array nodes.\n */\n\nconst arrayToList = array => array.reduce((acc, curr, index) => {\n const node = Object.assign(Object.assign({}, curr), {\n prev: null,\n next: null\n }); // no-op for first item, we don't want circular references on a single item\n\n if (index !== 0) {\n const prevNode = acc[index - 1];\n node.prev = prevNode;\n prevNode.next = node;\n\n if (index === array.length - 1) {\n // make the references circular and connect head & tail\n const firstNode = acc[0];\n node.next = firstNode;\n firstNode.prev = node;\n }\n }\n\n acc.push(node);\n return acc;\n}, []);\n/**\n * Converts a readonly array or map into an iterable.\n * Useful for avoiding entry allocations when iterating object / map on each iteration.\n */\n\nconst toIterable = values => {\n return Array.isArray(values) ? values : values.values();\n};\n/**\n * Converts a readonly array or map into an array.\n */\n\nconst toArray = values => {\n return Array.isArray(values) ? values : Array.from(toIterable(values));\n};\nconst isTestEnv = () => \"development\" === _constants__WEBPACK_IMPORTED_MODULE_2__.ENV.TEST;\nconst isDevEnv = () => \"development\" === _constants__WEBPACK_IMPORTED_MODULE_2__.ENV.DEVELOPMENT;\nconst isProdEnv = () => \"development\" === _constants__WEBPACK_IMPORTED_MODULE_2__.ENV.PRODUCTION;\nconst isServerEnv = () => {\n var _a;\n\n return typeof process !== \"undefined\" && !!((_a = process === null || process === void 0 ? void 0 : ({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-66\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true})) === null || _a === void 0 ? void 0 : _a.NODE_ENV);\n};\nconst wrapEvent = (name, nativeEvent) => {\n return new CustomEvent(name, {\n detail: {\n nativeEvent\n },\n cancelable: true\n });\n};\nconst updateObject = (obj, updates) => {\n let didChange = false;\n\n for (const key in updates) {\n const value = updates[key];\n\n if (typeof value !== \"undefined\") {\n if (obj[key] === value && ( // if object, always update because its attrs could have changed\n typeof value !== \"object\" || value === null)) {\n continue;\n }\n\n didChange = true;\n }\n }\n\n if (!didChange) {\n return obj;\n }\n\n return Object.assign(Object.assign({}, obj), updates);\n};\nconst isPrimitive = val => {\n const type = typeof val;\n return val == null || type !== \"object\" && type !== \"function\";\n};\nconst getFrame = () => {\n try {\n return window.self === window.top ? \"top\" : \"iframe\";\n } catch (error) {\n return \"iframe\";\n }\n};\nconst isRunningInIframe = () => getFrame() === \"iframe\";\nconst isPromiseLike = value => {\n return !!value && typeof value === \"object\" && \"then\" in value && \"catch\" in value && \"finally\" in value;\n};\nconst queryFocusableElements = container => {\n const focusableElements = container === null || container === void 0 ? void 0 : container.querySelectorAll(\"button, a, input, select, textarea, div[tabindex], label[tabindex]\");\n return focusableElements ? Array.from(focusableElements).filter(element => element.tabIndex > -1 && !element.disabled) : [];\n};\n/** use as a fallback after identity check (for perf reasons) */\n\nconst _defaultIsShallowComparatorFallback = (a, b) => {\n // consider two empty arrays equal\n if (Array.isArray(a) && Array.isArray(b) && a.length === 0 && b.length === 0) {\n return true;\n }\n\n return a === b;\n};\n/**\n * Returns whether object/array is shallow equal.\n * Considers empty object/arrays as equal (whether top-level or second-level).\n */\n\n\nconst isShallowEqual = (objA, objB, comparators, debug = false) => {\n const aKeys = Object.keys(objA);\n const bKeys = Object.keys(objB);\n\n if (aKeys.length !== bKeys.length) {\n if (debug) {\n console.warn(`%cisShallowEqual: objects don't have same properties ->`, \"color: #8B4000\", objA, objB);\n }\n\n return false;\n }\n\n if (comparators && Array.isArray(comparators)) {\n for (const key of comparators) {\n const ret = objA[key] === objB[key] || _defaultIsShallowComparatorFallback(objA[key], objB[key]);\n\n if (!ret) {\n if (debug) {\n console.warn(`%cisShallowEqual: ${key} not equal ->`, \"color: #8B4000\", objA[key], objB[key]);\n }\n\n return false;\n }\n }\n\n return true;\n }\n\n return aKeys.every(key => {\n const comparator = comparators === null || comparators === void 0 ? void 0 : comparators[key];\n const ret = comparator ? comparator(objA[key], objB[key]) : objA[key] === objB[key] || _defaultIsShallowComparatorFallback(objA[key], objB[key]);\n\n if (!ret && debug) {\n console.warn(`%cisShallowEqual: ${key} not equal ->`, \"color: #8B4000\", objA[key], objB[key]);\n }\n\n return ret;\n });\n}; // taken from Radix UI\n// https://github.com/radix-ui/primitives/blob/main/packages/core/primitive/src/primitive.tsx\n\nconst composeEventHandlers = (originalEventHandler, ourEventHandler, {\n checkForDefaultPrevented = true\n} = {}) => {\n return function handleEvent(event) {\n originalEventHandler === null || originalEventHandler === void 0 ? void 0 : originalEventHandler(event);\n\n if (!checkForDefaultPrevented || !(event === null || event === void 0 ? void 0 : event.defaultPrevented)) {\n return ourEventHandler === null || ourEventHandler === void 0 ? void 0 : ourEventHandler(event);\n }\n };\n};\n/**\n * supply `null` as message if non-never value is valid, you just need to\n * typecheck against it\n */\n\nconst assertNever = (value, message, softAssert) => {\n if (!message) {\n return value;\n }\n\n if (softAssert) {\n console.error(message);\n return value;\n }\n\n throw new Error(message);\n};\nfunction invariant(condition, message) {\n if (!condition) {\n throw new Error(message);\n }\n}\n/**\n * Memoizes on values of `opts` object (strict equality).\n */\n\nconst memoize = func => {\n let lastArgs;\n let lastResult;\n\n const ret = function (opts) {\n const currentArgs = Object.entries(opts);\n\n if (lastArgs) {\n let argsAreEqual = true;\n\n for (const [key, value] of currentArgs) {\n if (lastArgs.get(key) !== value) {\n argsAreEqual = false;\n break;\n }\n }\n\n if (argsAreEqual) {\n return lastResult;\n }\n }\n\n const result = func(opts);\n lastArgs = new Map(currentArgs);\n lastResult = result;\n return result;\n };\n\n ret.clear = () => {\n lastArgs = undefined;\n lastResult = undefined;\n };\n\n return ret;\n};\n/** Checks if value is inside given collection. Useful for type-safety. */\n\nconst isMemberOf = (\n/** Set/Map/Array/Object */\ncollection,\n/** value to look for */\nvalue) => {\n return collection instanceof Set || collection instanceof Map ? collection.has(value) : \"includes\" in collection ? collection.includes(value) : collection.hasOwnProperty(value);\n};\nconst cloneJSON = obj => JSON.parse(JSON.stringify(obj));\nconst updateStable = (prevValue, nextValue) => {\n if (isShallowEqual(prevValue, nextValue)) {\n return prevValue;\n }\n\n return nextValue;\n}; // implem\n\nfunction addEventListener(\n/**\n * allows for falsy values so you don't have to type check when adding\n * event listeners to optional elements\n */\ntarget, type, listener, options) {\n var _a;\n\n if (!target) {\n return () => {};\n }\n\n (_a = target === null || target === void 0 ? void 0 : target.addEventListener) === null || _a === void 0 ? void 0 : _a.call(target, type, listener, options);\n return () => {\n var _a;\n\n (_a = target === null || target === void 0 ? void 0 : target.removeEventListener) === null || _a === void 0 ? void 0 : _a.call(target, type, listener, options);\n };\n}\nfunction getSvgPathFromStroke(points, closed = true) {\n const len = points.length;\n\n if (len < 4) {\n return ``;\n }\n\n let a = points[0];\n let b = points[1];\n const c = points[2];\n let result = `M${a[0].toFixed(2)},${a[1].toFixed(2)} Q${b[0].toFixed(2)},${b[1].toFixed(2)} ${(0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.average)(b[0], c[0]).toFixed(2)},${(0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.average)(b[1], c[1]).toFixed(2)} T`;\n\n for (let i = 2, max = len - 1; i < max; i++) {\n a = points[i];\n b = points[i + 1];\n result += `${(0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.average)(a[0], b[0]).toFixed(2)},${(0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.average)(a[1], b[1]).toFixed(2)} `;\n }\n\n if (closed) {\n result += \"Z\";\n }\n\n return result;\n}\nconst normalizeEOL = str => {\n return str.replace(/\\r?\\n|\\r/g, \"\\n\");\n};\n/**\n * Makes type into a branded type, ensuring that value is assignable to\n * the base ubranded type. Optionally you can explicitly supply current value\n * type to combine both (useful for composite branded types. Make sure you\n * compose branded types which are not composite themselves.)\n */\n\nconst toBrandedType = value => {\n return value;\n}; // -----------------------------------------------------------------------------\n// Promise.try, adapted from https://github.com/sindresorhus/p-try\n\nconst promiseTry = async (fn, ...args) => {\n return new Promise(resolve => {\n resolve(fn(...args));\n });\n};\nconst isAnyTrue = (...args) => Math.max(...args.map(arg => arg ? 1 : 0)) > 0;\nconst safelyParseJSON = json => {\n try {\n return JSON.parse(json);\n } catch (_a) {\n return null;\n }\n};\n/**\n * use when you need to render unsafe string as HTML attribute, but MAKE SURE\n * the attribute is double-quoted when constructing the HTML string\n */\n\nconst escapeDoubleQuotes = str => {\n return str.replace(/\"/g, \"&quot;\");\n};\nconst castArray = value => Array.isArray(value) ? value : [value];\n/** hack for Array.isArray type guard not working with readonly value[] */\n\nconst isReadonlyArray = value => {\n return Array.isArray(value);\n};\nconst sizeOf = value => {\n return isReadonlyArray(value) ? value.length : value instanceof Map || value instanceof Set ? value.size : Object.keys(value).length;\n};\nconst reduceToCommonValue = (collection, getValue) => {\n if (sizeOf(collection) === 0) {\n return null;\n }\n\n const valueExtractor = getValue || (item => item);\n\n let commonValue = null;\n\n for (const item of collection) {\n const value = valueExtractor(item);\n\n if ((commonValue === null || commonValue === value) && value != null) {\n commonValue = value;\n } else {\n return null;\n }\n }\n\n return commonValue;\n};\nconst FEATURE_FLAGS_STORAGE_KEY = \"excalidraw-feature-flags\";\nconst DEFAULT_FEATURE_FLAGS = {\n COMPLEX_BINDINGS: false\n};\nlet featureFlags = null;\nconst getFeatureFlag = flag => {\n if (!featureFlags) {\n try {\n const serializedFlags = localStorage.getItem(FEATURE_FLAGS_STORAGE_KEY);\n\n if (serializedFlags) {\n const flags = JSON.parse(serializedFlags);\n featureFlags = flags !== null && flags !== void 0 ? flags : DEFAULT_FEATURE_FLAGS;\n }\n } catch (_a) {}\n }\n\n return (featureFlags || DEFAULT_FEATURE_FLAGS)[flag];\n};\nconst setFeatureFlag = (flag, value) => {\n try {\n featureFlags = Object.assign(Object.assign({}, featureFlags || DEFAULT_FEATURE_FLAGS), {\n [flag]: value\n });\n localStorage.setItem(FEATURE_FLAGS_STORAGE_KEY, JSON.stringify(featureFlags));\n } catch (e) {\n console.error(\"unable to set feature flag\", e);\n }\n};\n\n//# sourceURL=webpack://ExcalidrawLib/../common/src/utils.ts?");
13106
13051
 
13107
13052
  /***/ }),
13108
13053
 
@@ -14257,7 +14202,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
14257
14202
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
14258
14203
 
14259
14204
  "use strict";
14260
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ trackEvent: () => (/* binding */ trackEvent)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n// place here categories that you want to track. We want to track just a\n // small subset of categories at a given time.\n\nconst ALLOWED_CATEGORIES_TO_TRACK = new Set([\"command_palette\", \"export\"]);\nconst trackEvent = (category, action, label, value) => {\n try {\n if (typeof window === \"undefined\" || ({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-64\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}).VITE_WORKER_ID || \"true\" !== \"true\") {\n return;\n }\n\n if (!ALLOWED_CATEGORIES_TO_TRACK.has(category)) {\n return;\n }\n\n if ((0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.isDevEnv)()) {\n // comment out to debug in dev\n return;\n }\n\n if (true) {\n console.info(\"trackEvent\", {\n category,\n action,\n label,\n value\n });\n }\n\n if (window.sa_event) {\n window.sa_event(action, {\n category,\n label,\n value\n });\n }\n } catch (error) {\n console.error(\"error during analytics\", error);\n }\n};\n\n//# sourceURL=webpack://ExcalidrawLib/./analytics.ts?");
14205
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ trackEvent: () => (/* binding */ trackEvent)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n// place here categories that you want to track. We want to track just a\n // small subset of categories at a given time.\n\nconst ALLOWED_CATEGORIES_TO_TRACK = new Set([\"command_palette\", \"export\"]);\nconst trackEvent = (category, action, label, value) => {\n try {\n if (typeof window === \"undefined\" || ({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-66\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}).VITE_WORKER_ID || \"true\" !== \"true\") {\n return;\n }\n\n if (!ALLOWED_CATEGORIES_TO_TRACK.has(category)) {\n return;\n }\n\n if ((0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.isDevEnv)()) {\n // comment out to debug in dev\n return;\n }\n\n if (true) {\n console.info(\"trackEvent\", {\n category,\n action,\n label,\n value\n });\n }\n\n if (window.sa_event) {\n window.sa_event(action, {\n category,\n label,\n value\n });\n }\n } catch (error) {\n console.error(\"error during analytics\", error);\n }\n};\n\n//# sourceURL=webpack://ExcalidrawLib/./analytics.ts?");
14261
14206
 
14262
14207
  /***/ }),
14263
14208
 
@@ -16732,7 +16677,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n// extracted by mini-css-extr
16732
16677
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
16733
16678
 
16734
16679
  "use strict";
16735
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Hyperlink: () => (/* binding */ Hyperlink),\n/* harmony export */ getContextMenuLabel: () => (/* binding */ getContextMenuLabel),\n/* harmony export */ hideHyperlinkToolip: () => (/* binding */ hideHyperlinkToolip),\n/* harmony export */ showHyperlinkTooltip: () => (/* binding */ showHyperlinkTooltip)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_math__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/math */ \"../math/src/index.ts\");\n/* harmony import */ var clsx__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! clsx */ \"../../node_modules/clsx/dist/clsx.m.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n/* harmony import */ var _excalidraw_element__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @excalidraw/element */ \"../element/src/index.ts\");\n/* harmony import */ var _analytics__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../analytics */ \"./analytics.ts\");\n/* harmony import */ var _components_Tooltip__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../components/Tooltip */ \"./components/Tooltip.tsx\");\n/* harmony import */ var _i18n__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../../i18n */ \"./i18n.ts\");\n/* harmony import */ var _App__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../App */ \"./components/App.tsx\");\n/* harmony import */ var _ToolButton__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../ToolButton */ \"./components/ToolButton.tsx\");\n/* harmony import */ var _icons__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../icons */ \"./components/icons.tsx\");\n/* harmony import */ var _scene__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../../scene */ \"./scene/index.ts\");\n/* harmony import */ var _helpers__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./helpers */ \"./components/hyperlink/helpers.ts\");\n/* harmony import */ var _obsidianUtils__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ../../obsidianUtils */ \"./obsidianUtils.ts\");\n/* harmony import */ var _Hyperlink_scss__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./Hyperlink.scss */ \"./components/hyperlink/Hyperlink.scss\");\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n //zsviczian\n\n\nconst POPUP_WIDTH = 380;\nconst POPUP_HEIGHT = 42;\nconst POPUP_PADDING = 5;\nconst SPACE_BOTTOM = 85;\nconst AUTO_HIDE_TIMEOUT = 500;\nlet IS_HYPERLINK_TOOLTIP_VISIBLE = false;\nconst embeddableLinkCache = new Map();\nconst Hyperlink = ({\n element,\n scene,\n setAppState,\n onLinkOpen,\n setToast,\n updateEmbedValidationStatus\n}) => {\n const elementsMap = scene.getNonDeletedElementsMap();\n const appState = (0,_App__WEBPACK_IMPORTED_MODULE_8__.useExcalidrawAppState)();\n const appProps = (0,_App__WEBPACK_IMPORTED_MODULE_8__.useAppProps)();\n const editorInterface = (0,_App__WEBPACK_IMPORTED_MODULE_8__.useEditorInterface)();\n const linkVal = element.link || \"\";\n const [inputVal, setInputVal] = (0,react__WEBPACK_IMPORTED_MODULE_2__.useState)(linkVal);\n const inputRef = (0,react__WEBPACK_IMPORTED_MODULE_2__.useRef)(null);\n const isEditing = appState.showHyperlinkPopup === \"editor\";\n const handleSubmit = (0,react__WEBPACK_IMPORTED_MODULE_2__.useCallback)(() => {\n var _a;\n\n if (!inputRef.current) {\n return;\n }\n\n const link = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.normalizeLink)(inputRef.current.value) || null;\n\n if (!element.link && link) {\n (0,_analytics__WEBPACK_IMPORTED_MODULE_5__.trackEvent)(\"hyperlink\", \"create\");\n }\n\n if ((0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.isEmbeddableElement)(element)) {\n if (((_a = appState.activeEmbeddable) === null || _a === void 0 ? void 0 : _a.element) === element) {\n setAppState({\n activeEmbeddable: null\n });\n }\n\n if (!link) {\n scene.mutateElement(element, {\n link: null\n });\n updateEmbedValidationStatus(element, false);\n return;\n }\n\n if (!(0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.embeddableURLValidator)(link, appProps.validateEmbeddable)) {\n if (link) {\n setToast({\n message: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"toast.unableToEmbed\"),\n closable: true\n });\n }\n\n element.link && embeddableLinkCache.set(element.id, element.link);\n scene.mutateElement(element, {\n link\n });\n updateEmbedValidationStatus(element, false);\n } else {\n const {\n width,\n height\n } = element;\n const embedLink = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.getEmbedLink)(link);\n\n if ((embedLink === null || embedLink === void 0 ? void 0 : embedLink.error) instanceof URIError) {\n setToast({\n message: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"toast.unrecognizedLinkFormat\"),\n closable: true\n });\n }\n\n const ar = embedLink ? embedLink.intrinsicSize.w / embedLink.intrinsicSize.h : 1;\n const hasLinkChanged = embeddableLinkCache.get(element.id) !== element.link;\n scene.mutateElement(element, Object.assign(Object.assign({}, hasLinkChanged ? {\n width: (embedLink === null || embedLink === void 0 ? void 0 : embedLink.type) === \"video\" ? width > height ? width : height * ar : width,\n height: (embedLink === null || embedLink === void 0 ? void 0 : embedLink.type) === \"video\" ? width > height ? width / ar : height : height\n } : {}), {\n link\n }));\n updateEmbedValidationStatus(element, true);\n\n if (embeddableLinkCache.has(element.id)) {\n embeddableLinkCache.delete(element.id);\n }\n }\n } else {\n scene.mutateElement(element, {\n link\n });\n }\n }, [element, scene, setToast, appProps.validateEmbeddable, appState.activeEmbeddable, setAppState, updateEmbedValidationStatus]);\n (0,react__WEBPACK_IMPORTED_MODULE_2__.useLayoutEffect)(() => {\n return () => {\n handleSubmit();\n };\n }, [handleSubmit]);\n (0,react__WEBPACK_IMPORTED_MODULE_2__.useEffect)(() => {\n if (isEditing && (inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) && !(editorInterface.formFactor === \"phone\" || editorInterface.isTouchScreen)) {\n inputRef.current.select();\n }\n }, [isEditing, editorInterface.formFactor, editorInterface.isTouchScreen]); //zsviczian - attach link suggester\n\n (0,react__WEBPACK_IMPORTED_MODULE_2__.useEffect)(() => {\n if (!isEditing || !inputRef.current) {\n return;\n }\n\n const keyBlocker = (0,_obsidianUtils__WEBPACK_IMPORTED_MODULE_13__.attachInlineLinkSuggester)(inputRef.current);\n return () => keyBlocker === null || keyBlocker === void 0 ? void 0 : keyBlocker.close();\n }, [isEditing]); //zsviczian - end\n\n (0,react__WEBPACK_IMPORTED_MODULE_2__.useEffect)(() => {\n let timeoutId = null;\n\n const handlePointerMove = event => {\n if (isEditing) {\n return;\n }\n\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n\n const shouldHide = shouldHideLinkPopup(element, elementsMap, appState, (0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.pointFrom)(event.clientX, event.clientY));\n\n if (shouldHide) {\n timeoutId = window.setTimeout(() => {\n setAppState({\n showHyperlinkPopup: false\n });\n }, AUTO_HIDE_TIMEOUT);\n }\n };\n\n window.addEventListener(_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.EVENT.POINTER_MOVE, handlePointerMove, false);\n return () => {\n window.removeEventListener(_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.EVENT.POINTER_MOVE, handlePointerMove, false);\n\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n };\n }, [appState, element, isEditing, setAppState, elementsMap]);\n const handleRemove = (0,react__WEBPACK_IMPORTED_MODULE_2__.useCallback)(() => {\n (0,_analytics__WEBPACK_IMPORTED_MODULE_5__.trackEvent)(\"hyperlink\", \"delete\");\n scene.mutateElement(element, {\n link: null\n });\n setAppState({\n showHyperlinkPopup: false\n });\n }, [setAppState, element, scene]);\n\n const onEdit = () => {\n (0,_analytics__WEBPACK_IMPORTED_MODULE_5__.trackEvent)(\"hyperlink\", \"edit\", \"popup-ui\");\n setAppState({\n showHyperlinkPopup: \"editor\"\n });\n };\n\n const {\n x,\n y\n } = getCoordsForPopover(element, appState, elementsMap);\n\n if (appState.contextMenu || appState.selectedElementsAreBeingDragged || appState.resizingElement || appState.isRotating || appState.openMenu || appState.viewModeEnabled) {\n return null;\n }\n\n return React.createElement(\"div\", {\n className: \"excalidraw-hyperlinkContainer\",\n style: {\n top: `${y}px`,\n left: `${x}px`,\n width: POPUP_WIDTH,\n padding: POPUP_PADDING\n }\n }, isEditing ? React.createElement(\"input\", {\n className: (0,clsx__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(\"excalidraw-hyperlinkContainer-input\"),\n placeholder: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"labels.link.hint\"),\n ref: inputRef,\n value: inputVal,\n onChange: event => setInputVal(event.target.value),\n autoFocus: true,\n onKeyDown: event => {\n event.stopPropagation(); // prevent cmd/ctrl+k shortcut when editing link\n\n if (event[_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.KEYS.CTRL_OR_CMD] && event.key === _excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.KEYS.K) {\n event.preventDefault();\n }\n\n if (event.key === _excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.KEYS.ENTER || event.key === _excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.KEYS.ESCAPE) {\n handleSubmit();\n setAppState({\n showHyperlinkPopup: \"info\"\n });\n }\n }\n }) : element.link ? React.createElement(\"a\", {\n href: (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.normalizeLink)(element.link || \"\"),\n className: \"excalidraw-hyperlinkContainer-link\",\n target: (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.isLocalLink)(element.link) ? \"_self\" : \"_blank\",\n onClick: event => {\n if (element.link && onLinkOpen) {\n const customEvent = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.wrapEvent)(_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.EVENT.EXCALIDRAW_LINK, event.nativeEvent);\n onLinkOpen(Object.assign(Object.assign({}, element), {\n link: (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.normalizeLink)(element.link)\n }), customEvent);\n\n if (customEvent.defaultPrevented) {\n event.preventDefault();\n }\n }\n },\n rel: \"noopener noreferrer\"\n }, element.link) : React.createElement(\"div\", {\n className: \"excalidraw-hyperlinkContainer-link\"\n }, (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"labels.link.empty\")), React.createElement(\"div\", {\n className: \"excalidraw-hyperlinkContainer__buttons\"\n }, !isEditing && React.createElement(_ToolButton__WEBPACK_IMPORTED_MODULE_9__.ToolButton, {\n type: \"button\",\n title: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.edit\"),\n \"aria-label\": (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.edit\"),\n label: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.edit\"),\n onClick: onEdit,\n className: \"excalidraw-hyperlinkContainer--edit\",\n icon: _icons__WEBPACK_IMPORTED_MODULE_10__.FreedrawIcon\n }), linkVal && !(0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.isEmbeddableElement)(element) && React.createElement(_ToolButton__WEBPACK_IMPORTED_MODULE_9__.ToolButton, {\n type: \"button\",\n title: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.remove\"),\n \"aria-label\": (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.remove\"),\n label: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.remove\"),\n onClick: handleRemove,\n className: \"excalidraw-hyperlinkContainer--remove\",\n icon: _icons__WEBPACK_IMPORTED_MODULE_10__.TrashIcon\n })));\n};\n\nconst getCoordsForPopover = (element, appState, elementsMap) => {\n const [x1, y1] = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.getElementAbsoluteCoords)(element, elementsMap);\n const {\n x: viewportX,\n y: viewportY\n } = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.sceneCoordsToViewportCoords)({\n sceneX: x1 + element.width / 2,\n sceneY: y1\n }, appState);\n const x = viewportX - appState.offsetLeft - POPUP_WIDTH / 2;\n const y = viewportY - appState.offsetTop - SPACE_BOTTOM;\n return {\n x,\n y\n };\n};\n\nconst getContextMenuLabel = (elements, appState) => {\n var _a;\n\n const selectedElements = (0,_scene__WEBPACK_IMPORTED_MODULE_11__.getSelectedElements)(elements, appState);\n const label = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.isEmbeddableElement)(selectedElements[0]) ? \"labels.link.editEmbed\" : ((_a = selectedElements[0]) === null || _a === void 0 ? void 0 : _a.link) ? \"labels.link.edit\" : \"labels.link.create\";\n return label;\n};\nlet HYPERLINK_TOOLTIP_TIMEOUT_ID = null;\nconst showHyperlinkTooltip = (element, appState, elementsMap) => {\n if (HYPERLINK_TOOLTIP_TIMEOUT_ID) {\n clearTimeout(HYPERLINK_TOOLTIP_TIMEOUT_ID);\n }\n\n HYPERLINK_TOOLTIP_TIMEOUT_ID = window.setTimeout(() => renderTooltip(element, appState, elementsMap), _excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.HYPERLINK_TOOLTIP_DELAY);\n};\n\nconst renderTooltip = (element, appState, elementsMap) => {\n if (!element.link) {\n return;\n }\n\n const tooltipDiv = (0,_components_Tooltip__WEBPACK_IMPORTED_MODULE_6__.getTooltipDiv)();\n tooltipDiv.classList.add(\"excalidraw-tooltip--visible\");\n tooltipDiv.style.maxWidth = \"20rem\";\n tooltipDiv.textContent = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.isElementLink)(element.link) ? (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"labels.link.goToElement\") : element.link;\n const [x1, y1, x2, y2] = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.getElementAbsoluteCoords)(element, elementsMap);\n const [linkX, linkY, linkWidth, linkHeight] = (0,_helpers__WEBPACK_IMPORTED_MODULE_12__.getLinkHandleFromCoords)([x1, y1, x2, y2], element.angle, appState);\n const linkViewportCoords = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.sceneCoordsToViewportCoords)({\n sceneX: linkX,\n sceneY: linkY\n }, appState);\n (0,_components_Tooltip__WEBPACK_IMPORTED_MODULE_6__.updateTooltipPosition)(tooltipDiv, {\n left: linkViewportCoords.x,\n top: linkViewportCoords.y,\n width: linkWidth,\n height: linkHeight\n }, \"top\");\n (0,_analytics__WEBPACK_IMPORTED_MODULE_5__.trackEvent)(\"hyperlink\", \"tooltip\", \"link-icon\");\n IS_HYPERLINK_TOOLTIP_VISIBLE = true;\n};\n\nconst hideHyperlinkToolip = () => {\n if (HYPERLINK_TOOLTIP_TIMEOUT_ID) {\n clearTimeout(HYPERLINK_TOOLTIP_TIMEOUT_ID);\n }\n\n if (IS_HYPERLINK_TOOLTIP_VISIBLE) {\n IS_HYPERLINK_TOOLTIP_VISIBLE = false;\n (0,_components_Tooltip__WEBPACK_IMPORTED_MODULE_6__.getTooltipDiv)().classList.remove(\"excalidraw-tooltip--visible\");\n }\n};\n\nconst shouldHideLinkPopup = (element, elementsMap, appState, [clientX, clientY]) => {\n const {\n x: sceneX,\n y: sceneY\n } = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.viewportCoordsToSceneCoords)({\n clientX,\n clientY\n }, appState);\n const threshold = 15 / appState.zoom.value; // hitbox to prevent hiding when hovered in element bounding box\n\n if ((0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.hitElementBoundingBox)((0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.pointFrom)(sceneX, sceneY), element, elementsMap)) {\n return false;\n }\n\n const [x1, y1, x2] = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.getElementAbsoluteCoords)(element, elementsMap); // hit box to prevent hiding when hovered in the vertical area between element and popover\n\n if (sceneX >= x1 && sceneX <= x2 && sceneY >= y1 - SPACE_BOTTOM && sceneY <= y1) {\n return false;\n } // hit box to prevent hiding when hovered around popover within threshold\n\n\n const {\n x: popoverX,\n y: popoverY\n } = getCoordsForPopover(element, appState, elementsMap);\n\n if (clientX >= popoverX - threshold && clientX <= popoverX + POPUP_WIDTH + POPUP_PADDING * 2 + threshold && clientY >= popoverY - threshold && clientY <= popoverY + threshold + POPUP_PADDING * 2 + POPUP_HEIGHT) {\n return false;\n }\n\n return true;\n};\n\n//# sourceURL=webpack://ExcalidrawLib/./components/hyperlink/Hyperlink.tsx?");
16680
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Hyperlink: () => (/* binding */ Hyperlink),\n/* harmony export */ getContextMenuLabel: () => (/* binding */ getContextMenuLabel),\n/* harmony export */ hideHyperlinkToolip: () => (/* binding */ hideHyperlinkToolip),\n/* harmony export */ showHyperlinkTooltip: () => (/* binding */ showHyperlinkTooltip)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_math__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/math */ \"../math/src/index.ts\");\n/* harmony import */ var clsx__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! clsx */ \"../../node_modules/clsx/dist/clsx.m.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n/* harmony import */ var _excalidraw_element__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @excalidraw/element */ \"../element/src/index.ts\");\n/* harmony import */ var _analytics__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../analytics */ \"./analytics.ts\");\n/* harmony import */ var _components_Tooltip__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../components/Tooltip */ \"./components/Tooltip.tsx\");\n/* harmony import */ var _i18n__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../../i18n */ \"./i18n.ts\");\n/* harmony import */ var _App__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../App */ \"./components/App.tsx\");\n/* harmony import */ var _ToolButton__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../ToolButton */ \"./components/ToolButton.tsx\");\n/* harmony import */ var _icons__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../icons */ \"./components/icons.tsx\");\n/* harmony import */ var _scene__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../../scene */ \"./scene/index.ts\");\n/* harmony import */ var _helpers__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./helpers */ \"./components/hyperlink/helpers.ts\");\n/* harmony import */ var _obsidianUtils__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ../../obsidianUtils */ \"./obsidianUtils.ts\");\n/* harmony import */ var _Hyperlink_scss__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./Hyperlink.scss */ \"./components/hyperlink/Hyperlink.scss\");\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n //zsviczian\n\n\nconst POPUP_WIDTH = 380;\nconst POPUP_HEIGHT = 42;\nconst POPUP_PADDING = 5;\nconst SPACE_BOTTOM = 85;\nconst AUTO_HIDE_TIMEOUT = 500;\nlet IS_HYPERLINK_TOOLTIP_VISIBLE = false;\nconst embeddableLinkCache = new Map();\nconst Hyperlink = ({\n element,\n scene,\n setAppState,\n onLinkOpen,\n setToast,\n updateEmbedValidationStatus\n}) => {\n const elementsMap = scene.getNonDeletedElementsMap();\n const appState = (0,_App__WEBPACK_IMPORTED_MODULE_8__.useExcalidrawAppState)();\n const appProps = (0,_App__WEBPACK_IMPORTED_MODULE_8__.useAppProps)();\n const editorInterface = (0,_App__WEBPACK_IMPORTED_MODULE_8__.useEditorInterface)();\n const linkVal = element.link || \"\";\n const [inputVal, setInputVal] = (0,react__WEBPACK_IMPORTED_MODULE_2__.useState)(linkVal);\n const inputRef = (0,react__WEBPACK_IMPORTED_MODULE_2__.useRef)(null);\n const isEditing = appState.showHyperlinkPopup === \"editor\";\n const handleSubmit = (0,react__WEBPACK_IMPORTED_MODULE_2__.useCallback)(() => {\n var _a;\n\n if (!inputRef.current) {\n return;\n }\n\n const link = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.normalizeLink)(inputRef.current.value) || null;\n\n if (!element.link && link) {\n (0,_analytics__WEBPACK_IMPORTED_MODULE_5__.trackEvent)(\"hyperlink\", \"create\");\n }\n\n if ((0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.isEmbeddableElement)(element)) {\n if (((_a = appState.activeEmbeddable) === null || _a === void 0 ? void 0 : _a.element) === element) {\n setAppState({\n activeEmbeddable: null\n });\n }\n\n if (!link) {\n scene.mutateElement(element, {\n link: null\n });\n updateEmbedValidationStatus(element, false);\n return;\n }\n\n if (!(0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.embeddableURLValidator)(link, appProps.validateEmbeddable)) {\n if (link) {\n setToast({\n message: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"toast.unableToEmbed\"),\n closable: true\n });\n }\n\n element.link && embeddableLinkCache.set(element.id, element.link);\n scene.mutateElement(element, {\n link\n });\n updateEmbedValidationStatus(element, false);\n } else {\n const {\n width,\n height\n } = element;\n const embedLink = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.getEmbedLink)(link);\n\n if ((embedLink === null || embedLink === void 0 ? void 0 : embedLink.error) instanceof URIError) {\n setToast({\n message: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"toast.unrecognizedLinkFormat\"),\n closable: true\n });\n }\n\n const ar = embedLink ? embedLink.intrinsicSize.w / embedLink.intrinsicSize.h : 1;\n const hasLinkChanged = embeddableLinkCache.get(element.id) !== element.link;\n scene.mutateElement(element, Object.assign(Object.assign({}, hasLinkChanged ? {\n width: (embedLink === null || embedLink === void 0 ? void 0 : embedLink.type) === \"video\" ? width > height ? width : height * ar : width,\n height: (embedLink === null || embedLink === void 0 ? void 0 : embedLink.type) === \"video\" ? width > height ? width / ar : height : height\n } : {}), {\n link\n }));\n updateEmbedValidationStatus(element, true);\n\n if (embeddableLinkCache.has(element.id)) {\n embeddableLinkCache.delete(element.id);\n }\n }\n } else {\n scene.mutateElement(element, {\n link\n });\n }\n }, [element, scene, setToast, appProps.validateEmbeddable, appState.activeEmbeddable, setAppState, updateEmbedValidationStatus]);\n (0,react__WEBPACK_IMPORTED_MODULE_2__.useLayoutEffect)(() => {\n return () => {\n handleSubmit();\n };\n }, [handleSubmit]);\n (0,react__WEBPACK_IMPORTED_MODULE_2__.useEffect)(() => {\n if (isEditing && (inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) && !(editorInterface.formFactor === \"phone\" || editorInterface.isTouchScreen)) {\n inputRef.current.select();\n }\n }, [isEditing, editorInterface.formFactor, editorInterface.isTouchScreen]); //zsviczian - attach link suggester\n\n (0,react__WEBPACK_IMPORTED_MODULE_2__.useEffect)(() => {\n if (!isEditing || !inputRef.current) {\n return;\n }\n\n const keyBlocker = (0,_obsidianUtils__WEBPACK_IMPORTED_MODULE_13__.attachInlineLinkSuggester)(inputRef.current);\n return () => keyBlocker === null || keyBlocker === void 0 ? void 0 : keyBlocker.close();\n }, [isEditing]); //zsviczian - end\n\n (0,react__WEBPACK_IMPORTED_MODULE_2__.useEffect)(() => {\n let timeoutId = null;\n\n const handlePointerMove = event => {\n if (isEditing) {\n return;\n }\n\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n\n const shouldHide = shouldHideLinkPopup(element, elementsMap, appState, (0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.pointFrom)(event.clientX, event.clientY));\n\n if (shouldHide) {\n timeoutId = window.setTimeout(() => {\n setAppState({\n showHyperlinkPopup: false\n });\n }, AUTO_HIDE_TIMEOUT);\n }\n };\n\n window.addEventListener(_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.EVENT.POINTER_MOVE, handlePointerMove, false);\n return () => {\n window.removeEventListener(_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.EVENT.POINTER_MOVE, handlePointerMove, false);\n\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n };\n }, [appState, element, isEditing, setAppState, elementsMap]);\n const handleRemove = (0,react__WEBPACK_IMPORTED_MODULE_2__.useCallback)(() => {\n (0,_analytics__WEBPACK_IMPORTED_MODULE_5__.trackEvent)(\"hyperlink\", \"delete\");\n scene.mutateElement(element, {\n link: null\n });\n setAppState({\n showHyperlinkPopup: false\n });\n }, [setAppState, element, scene]);\n\n const onEdit = () => {\n (0,_analytics__WEBPACK_IMPORTED_MODULE_5__.trackEvent)(\"hyperlink\", \"edit\", \"popup-ui\");\n setAppState({\n showHyperlinkPopup: \"editor\"\n });\n };\n\n const {\n x,\n y\n } = getCoordsForPopover(element, appState, elementsMap);\n\n if (appState.contextMenu || appState.selectedElementsAreBeingDragged || appState.resizingElement || appState.isRotating || appState.openMenu || appState.viewModeEnabled) {\n return null;\n }\n\n return React.createElement(\"div\", {\n className: \"excalidraw-hyperlinkContainer\",\n style: {\n top: `${y}px`,\n left: `${x}px`,\n width: POPUP_WIDTH,\n padding: POPUP_PADDING\n }\n }, isEditing ? React.createElement(\"input\", {\n className: (0,clsx__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(\"excalidraw-hyperlinkContainer-input\"),\n placeholder: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"labels.link.hint\"),\n ref: inputRef,\n value: inputVal,\n onChange: event => setInputVal(event.target.value),\n autoFocus: true,\n onKeyDown: event => {\n event.stopPropagation(); // prevent cmd/ctrl+k shortcut when editing link\n\n if (event[_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.KEYS.CTRL_OR_CMD] && event.key === _excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.KEYS.K) {\n event.preventDefault();\n }\n\n if (event.key === _excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.KEYS.ENTER || event.key === _excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.KEYS.ESCAPE) {\n handleSubmit();\n setAppState({\n showHyperlinkPopup: \"info\"\n });\n }\n }\n }) : element.link ? React.createElement(\"a\", {\n href: (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.normalizeLink)(element.link || \"\"),\n className: \"excalidraw-hyperlinkContainer-link\",\n target: (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.isLocalLink)(element.link) ? \"_self\" : \"_blank\",\n onClick: event => {\n if (element.link && onLinkOpen) {\n const customEvent = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.wrapEvent)(_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.EVENT.EXCALIDRAW_LINK, event.nativeEvent);\n onLinkOpen(Object.assign(Object.assign({}, element), {\n link: (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.normalizeLink)(element.link)\n }), customEvent);\n\n if (customEvent.defaultPrevented) {\n event.preventDefault();\n }\n }\n },\n rel: \"noopener noreferrer\"\n }, element.link) : React.createElement(\"div\", {\n className: \"excalidraw-hyperlinkContainer-link\"\n }, (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"labels.link.empty\")), React.createElement(\"div\", {\n className: \"excalidraw-hyperlinkContainer__buttons\"\n }, !isEditing && React.createElement(_ToolButton__WEBPACK_IMPORTED_MODULE_9__.ToolButton, {\n type: \"button\",\n title: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.edit\"),\n \"aria-label\": (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.edit\"),\n label: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.edit\"),\n onClick: onEdit,\n className: \"excalidraw-hyperlinkContainer--edit\",\n icon: _icons__WEBPACK_IMPORTED_MODULE_10__.FreedrawIcon\n }), //zsviczian - show the Obsidian search button\n Boolean(appProps.insertLinkAction) && React.createElement(_ToolButton__WEBPACK_IMPORTED_MODULE_9__.ToolButton, {\n type: \"button\",\n title: \"Obsidian Search\",\n \"aria-label\": \"Obsidian Search\",\n label: \"Obsidian Search\",\n onClick: () => {\n if (appProps.insertLinkAction) {\n setAppState({\n showHyperlinkPopup: false\n });\n appProps.insertLinkAction(inputVal);\n }\n },\n icon: _icons__WEBPACK_IMPORTED_MODULE_10__.searchIcon\n }), linkVal && !(0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.isEmbeddableElement)(element) && React.createElement(_ToolButton__WEBPACK_IMPORTED_MODULE_9__.ToolButton, {\n type: \"button\",\n title: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.remove\"),\n \"aria-label\": (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.remove\"),\n label: (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"buttons.remove\"),\n onClick: handleRemove,\n className: \"excalidraw-hyperlinkContainer--remove\",\n icon: _icons__WEBPACK_IMPORTED_MODULE_10__.TrashIcon\n })));\n};\n\nconst getCoordsForPopover = (element, appState, elementsMap) => {\n const [x1, y1] = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.getElementAbsoluteCoords)(element, elementsMap);\n const {\n x: viewportX,\n y: viewportY\n } = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.sceneCoordsToViewportCoords)({\n sceneX: x1 + element.width / 2,\n sceneY: y1\n }, appState);\n const x = viewportX - appState.offsetLeft - POPUP_WIDTH / 2;\n const y = viewportY - appState.offsetTop - SPACE_BOTTOM;\n return {\n x,\n y\n };\n};\n\nconst getContextMenuLabel = (elements, appState) => {\n var _a;\n\n const selectedElements = (0,_scene__WEBPACK_IMPORTED_MODULE_11__.getSelectedElements)(elements, appState);\n const label = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.isEmbeddableElement)(selectedElements[0]) ? \"labels.link.editEmbed\" : ((_a = selectedElements[0]) === null || _a === void 0 ? void 0 : _a.link) ? \"labels.link.edit\" : \"labels.link.create\";\n return label;\n};\nlet HYPERLINK_TOOLTIP_TIMEOUT_ID = null;\nconst showHyperlinkTooltip = (element, appState, elementsMap) => {\n if (HYPERLINK_TOOLTIP_TIMEOUT_ID) {\n clearTimeout(HYPERLINK_TOOLTIP_TIMEOUT_ID);\n }\n\n HYPERLINK_TOOLTIP_TIMEOUT_ID = window.setTimeout(() => renderTooltip(element, appState, elementsMap), _excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.HYPERLINK_TOOLTIP_DELAY);\n};\n\nconst renderTooltip = (element, appState, elementsMap) => {\n if (!element.link) {\n return;\n }\n\n const tooltipDiv = (0,_components_Tooltip__WEBPACK_IMPORTED_MODULE_6__.getTooltipDiv)();\n tooltipDiv.classList.add(\"excalidraw-tooltip--visible\");\n tooltipDiv.style.maxWidth = \"20rem\";\n tooltipDiv.textContent = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.isElementLink)(element.link) ? (0,_i18n__WEBPACK_IMPORTED_MODULE_7__.t)(\"labels.link.goToElement\") : element.link;\n const [x1, y1, x2, y2] = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.getElementAbsoluteCoords)(element, elementsMap);\n const [linkX, linkY, linkWidth, linkHeight] = (0,_helpers__WEBPACK_IMPORTED_MODULE_12__.getLinkHandleFromCoords)([x1, y1, x2, y2], element.angle, appState);\n const linkViewportCoords = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.sceneCoordsToViewportCoords)({\n sceneX: linkX,\n sceneY: linkY\n }, appState);\n (0,_components_Tooltip__WEBPACK_IMPORTED_MODULE_6__.updateTooltipPosition)(tooltipDiv, {\n left: linkViewportCoords.x,\n top: linkViewportCoords.y,\n width: linkWidth,\n height: linkHeight\n }, \"top\");\n (0,_analytics__WEBPACK_IMPORTED_MODULE_5__.trackEvent)(\"hyperlink\", \"tooltip\", \"link-icon\");\n IS_HYPERLINK_TOOLTIP_VISIBLE = true;\n};\n\nconst hideHyperlinkToolip = () => {\n if (HYPERLINK_TOOLTIP_TIMEOUT_ID) {\n clearTimeout(HYPERLINK_TOOLTIP_TIMEOUT_ID);\n }\n\n if (IS_HYPERLINK_TOOLTIP_VISIBLE) {\n IS_HYPERLINK_TOOLTIP_VISIBLE = false;\n (0,_components_Tooltip__WEBPACK_IMPORTED_MODULE_6__.getTooltipDiv)().classList.remove(\"excalidraw-tooltip--visible\");\n }\n};\n\nconst shouldHideLinkPopup = (element, elementsMap, appState, [clientX, clientY]) => {\n const {\n x: sceneX,\n y: sceneY\n } = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_3__.viewportCoordsToSceneCoords)({\n clientX,\n clientY\n }, appState);\n const threshold = 15 / appState.zoom.value; // hitbox to prevent hiding when hovered in element bounding box\n\n if ((0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.hitElementBoundingBox)((0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_0__.pointFrom)(sceneX, sceneY), element, elementsMap)) {\n return false;\n }\n\n const [x1, y1, x2] = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_4__.getElementAbsoluteCoords)(element, elementsMap); // hit box to prevent hiding when hovered in the vertical area between element and popover\n\n if (sceneX >= x1 && sceneX <= x2 && sceneY >= y1 - SPACE_BOTTOM && sceneY <= y1) {\n return false;\n } // hit box to prevent hiding when hovered around popover within threshold\n\n\n const {\n x: popoverX,\n y: popoverY\n } = getCoordsForPopover(element, appState, elementsMap);\n\n if (clientX >= popoverX - threshold && clientX <= popoverX + POPUP_WIDTH + POPUP_PADDING * 2 + threshold && clientY >= popoverY - threshold && clientY <= popoverY + threshold + POPUP_PADDING * 2 + POPUP_HEIGHT) {\n return false;\n }\n\n return true;\n};\n\n//# sourceURL=webpack://ExcalidrawLib/./components/hyperlink/Hyperlink.tsx?");
16736
16681
 
16737
16682
  /***/ }),
16738
16683
 
@@ -17095,7 +17040,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
17095
17040
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
17096
17041
 
17097
17042
  "use strict";
17098
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Button: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Button),\n/* harmony export */ CaptureUpdateAction: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.CaptureUpdateAction),\n/* harmony export */ DEFAULT_LASER_COLOR: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.DEFAULT_LASER_COLOR),\n/* harmony export */ DefaultSidebar: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.DefaultSidebar),\n/* harmony export */ DiagramToCodePlugin: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.DiagramToCodePlugin),\n/* harmony export */ Ellipsify: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Ellipsify),\n/* harmony export */ Excalidraw: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Excalidraw),\n/* harmony export */ FONT_FAMILY: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.FONT_FAMILY),\n/* harmony export */ Footer: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Footer),\n/* harmony export */ LiveCollaborationTrigger: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.LiveCollaborationTrigger),\n/* harmony export */ MIME_TYPES: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.MIME_TYPES),\n/* harmony export */ MainMenu: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.MainMenu),\n/* harmony export */ ROUNDNESS: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.ROUNDNESS),\n/* harmony export */ Sidebar: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Sidebar),\n/* harmony export */ Stats: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Stats),\n/* harmony export */ THEME: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.THEME),\n/* harmony export */ TTDDialog: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.TTDDialog),\n/* harmony export */ TTDDialogTrigger: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.TTDDialogTrigger),\n/* harmony export */ UserIdleState: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.UserIdleState),\n/* harmony export */ WelcomeScreen: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.WelcomeScreen),\n/* harmony export */ bumpVersion: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.bumpVersion),\n/* harmony export */ convertToExcalidrawElements: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.convertToExcalidrawElements),\n/* harmony export */ defaultLang: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.defaultLang),\n/* harmony export */ destroyObsidianUtils: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.destroyObsidianUtils),\n/* harmony export */ elementPartiallyOverlapsWithOrContainsBBox: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.elementPartiallyOverlapsWithOrContainsBBox),\n/* harmony export */ elementsOverlappingBBox: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.elementsOverlappingBBox),\n/* harmony export */ exportToBlob: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.exportToBlob),\n/* harmony export */ exportToCanvas: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.exportToCanvas),\n/* harmony export */ exportToClipboard: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.exportToClipboard),\n/* harmony export */ exportToSvg: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.exportToSvg),\n/* harmony export */ getBoundTextMaxWidth: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getBoundTextMaxWidth),\n/* harmony export */ getCSSFontDefinition: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getCSSFontDefinition),\n/* harmony export */ getCommonBoundingBox: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getCommonBoundingBox),\n/* harmony export */ getCommonBounds: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getCommonBounds),\n/* harmony export */ getContainerElement: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getContainerElement),\n/* harmony export */ getDataURL: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getDataURL),\n/* harmony export */ getEmbedLink: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getEmbedLink),\n/* harmony export */ getFontFamilies: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFontFamilies),\n/* harmony export */ getFontFamilyString: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFontFamilyString),\n/* harmony export */ getFontMetrics: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFontMetrics),\n/* harmony export */ getFontString: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFontString),\n/* harmony export */ getFormFactor: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFormFactor),\n/* harmony export */ getFreeDrawSvgPath: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFreeDrawSvgPath),\n/* harmony export */ getLibraryItemsHash: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getLibraryItemsHash),\n/* harmony export */ getLineHeight: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getLineHeight),\n/* harmony export */ getMaximumGroups: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getMaximumGroups),\n/* harmony export */ getNonDeletedElements: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getNonDeletedElements),\n/* harmony export */ getSceneVersion: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getSceneVersion),\n/* harmony export */ getSharedMermaidInstance: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getSharedMermaidInstance),\n/* harmony export */ getTextFromElements: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getTextFromElements),\n/* harmony export */ getVisibleSceneBounds: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getVisibleSceneBounds),\n/* harmony export */ hashElementsVersion: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.hashElementsVersion),\n/* harmony export */ hashString: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.hashString),\n/* harmony export */ intersectElementWithLine: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.intersectElementWithLine),\n/* harmony export */ isElementInsideBBox: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.isElementInsideBBox),\n/* harmony export */ isElementLink: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.isElementLink),\n/* harmony export */ isInvisiblySmallElement: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.isInvisiblySmallElement),\n/* harmony export */ isLinearElement: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.isLinearElement),\n/* harmony export */ languages: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.languages),\n/* harmony export */ loadFromBlob: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.loadFromBlob),\n/* harmony export */ loadLibraryFromBlob: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.loadLibraryFromBlob),\n/* harmony export */ loadMermaid: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.loadMermaid),\n/* harmony export */ loadSceneFonts: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.loadSceneFonts),\n/* harmony export */ loadSceneOrLibraryFromBlob: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.loadSceneOrLibraryFromBlob),\n/* harmony export */ measureText: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.measureText),\n/* harmony export */ mergeLibraryItems: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.mergeLibraryItems),\n/* harmony export */ mermaidToExcalidraw: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.mermaidToExcalidraw),\n/* harmony export */ mutateElement: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.mutateElement),\n/* harmony export */ newElementWith: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.newElementWith),\n/* harmony export */ normalizeLink: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.normalizeLink),\n/* harmony export */ parseLibraryTokensFromUrl: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.parseLibraryTokensFromUrl),\n/* harmony export */ reconcileElements: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.reconcileElements),\n/* harmony export */ refreshTextDimensions: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.refreshTextDimensions),\n/* harmony export */ registerFontsInCSS: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.registerFontsInCSS),\n/* harmony export */ registerLocalFont: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.registerLocalFont),\n/* harmony export */ restore: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.restore),\n/* harmony export */ restoreAppState: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.restoreAppState),\n/* harmony export */ restoreElement: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.restoreElement),\n/* harmony export */ restoreElements: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.restoreElements),\n/* harmony export */ restoreLibraryItems: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.restoreLibraryItems),\n/* harmony export */ safelyParseJSON: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.safelyParseJSON),\n/* harmony export */ sceneCoordsToViewportCoords: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.sceneCoordsToViewportCoords),\n/* harmony export */ serializeAsJSON: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.serializeAsJSON),\n/* harmony export */ serializeLibraryAsJSON: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.serializeLibraryAsJSON),\n/* harmony export */ setCustomTextMetricsProvider: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.setCustomTextMetricsProvider),\n/* harmony export */ syncInvalidIndices: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.syncInvalidIndices),\n/* harmony export */ syncMovedIndices: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.syncMovedIndices),\n/* harmony export */ useEditorInterface: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.useEditorInterface),\n/* harmony export */ useHandleLibrary: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.useHandleLibrary),\n/* harmony export */ useI18n: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.useI18n),\n/* harmony export */ useStylesPanelMode: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.useStylesPanelMode),\n/* harmony export */ viewportCoordsToSceneCoords: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.viewportCoordsToSceneCoords),\n/* harmony export */ wrapText: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.wrapText),\n/* harmony export */ zoomToFitBounds: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.zoomToFitBounds)\n/* harmony export */ });\n/* harmony import */ var _publicPath__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./publicPath */ \"./publicPath.js\");\n/* harmony import */ var _polyfill__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./polyfill */ \"./polyfill.ts\");\n/* harmony import */ var _fonts_fonts_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./fonts/fonts.css */ \"./fonts/fonts.css\");\n/* harmony import */ var _index__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./index */ \"./index.tsx\");\n\n\n\n(0,_polyfill__WEBPACK_IMPORTED_MODULE_1__[\"default\"])();\n\n\n//# sourceURL=webpack://ExcalidrawLib/./entry.js?");
17043
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Button: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Button),\n/* harmony export */ CaptureUpdateAction: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.CaptureUpdateAction),\n/* harmony export */ DEFAULT_LASER_COLOR: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.DEFAULT_LASER_COLOR),\n/* harmony export */ DefaultSidebar: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.DefaultSidebar),\n/* harmony export */ DiagramToCodePlugin: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.DiagramToCodePlugin),\n/* harmony export */ Ellipsify: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Ellipsify),\n/* harmony export */ Excalidraw: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Excalidraw),\n/* harmony export */ FONT_FAMILY: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.FONT_FAMILY),\n/* harmony export */ Footer: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Footer),\n/* harmony export */ LiveCollaborationTrigger: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.LiveCollaborationTrigger),\n/* harmony export */ MIME_TYPES: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.MIME_TYPES),\n/* harmony export */ MainMenu: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.MainMenu),\n/* harmony export */ ROUNDNESS: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.ROUNDNESS),\n/* harmony export */ Sidebar: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Sidebar),\n/* harmony export */ Stats: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.Stats),\n/* harmony export */ THEME: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.THEME),\n/* harmony export */ TTDDialog: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.TTDDialog),\n/* harmony export */ TTDDialogTrigger: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.TTDDialogTrigger),\n/* harmony export */ UserIdleState: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.UserIdleState),\n/* harmony export */ WelcomeScreen: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.WelcomeScreen),\n/* harmony export */ bumpVersion: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.bumpVersion),\n/* harmony export */ convertToExcalidrawElements: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.convertToExcalidrawElements),\n/* harmony export */ defaultLang: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.defaultLang),\n/* harmony export */ destroyObsidianUtils: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.destroyObsidianUtils),\n/* harmony export */ elementPartiallyOverlapsWithOrContainsBBox: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.elementPartiallyOverlapsWithOrContainsBBox),\n/* harmony export */ elementsOverlappingBBox: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.elementsOverlappingBBox),\n/* harmony export */ exportToBlob: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.exportToBlob),\n/* harmony export */ exportToCanvas: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.exportToCanvas),\n/* harmony export */ exportToClipboard: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.exportToClipboard),\n/* harmony export */ exportToSvg: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.exportToSvg),\n/* harmony export */ getBoundTextMaxWidth: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getBoundTextMaxWidth),\n/* harmony export */ getCSSFontDefinition: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getCSSFontDefinition),\n/* harmony export */ getCommonBoundingBox: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getCommonBoundingBox),\n/* harmony export */ getCommonBounds: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getCommonBounds),\n/* harmony export */ getContainerElement: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getContainerElement),\n/* harmony export */ getDataURL: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getDataURL),\n/* harmony export */ getDefaultColorPalette: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getDefaultColorPalette),\n/* harmony export */ getEmbedLink: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getEmbedLink),\n/* harmony export */ getFontFamilies: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFontFamilies),\n/* harmony export */ getFontFamilyString: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFontFamilyString),\n/* harmony export */ getFontMetrics: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFontMetrics),\n/* harmony export */ getFontString: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFontString),\n/* harmony export */ getFormFactor: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFormFactor),\n/* harmony export */ getFreeDrawSvgPath: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getFreeDrawSvgPath),\n/* harmony export */ getLibraryItemsHash: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getLibraryItemsHash),\n/* harmony export */ getLineHeight: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getLineHeight),\n/* harmony export */ getMaximumGroups: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getMaximumGroups),\n/* harmony export */ getNonDeletedElements: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getNonDeletedElements),\n/* harmony export */ getSceneVersion: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getSceneVersion),\n/* harmony export */ getSharedMermaidInstance: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getSharedMermaidInstance),\n/* harmony export */ getTextFromElements: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getTextFromElements),\n/* harmony export */ getVisibleSceneBounds: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.getVisibleSceneBounds),\n/* harmony export */ hashElementsVersion: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.hashElementsVersion),\n/* harmony export */ hashString: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.hashString),\n/* harmony export */ intersectElementWithLine: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.intersectElementWithLine),\n/* harmony export */ isElementInsideBBox: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.isElementInsideBBox),\n/* harmony export */ isElementLink: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.isElementLink),\n/* harmony export */ isInvisiblySmallElement: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.isInvisiblySmallElement),\n/* harmony export */ isLinearElement: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.isLinearElement),\n/* harmony export */ languages: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.languages),\n/* harmony export */ loadFromBlob: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.loadFromBlob),\n/* harmony export */ loadLibraryFromBlob: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.loadLibraryFromBlob),\n/* harmony export */ loadMermaid: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.loadMermaid),\n/* harmony export */ loadSceneFonts: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.loadSceneFonts),\n/* harmony export */ loadSceneOrLibraryFromBlob: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.loadSceneOrLibraryFromBlob),\n/* harmony export */ measureText: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.measureText),\n/* harmony export */ mergeLibraryItems: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.mergeLibraryItems),\n/* harmony export */ mermaidToExcalidraw: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.mermaidToExcalidraw),\n/* harmony export */ mutateElement: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.mutateElement),\n/* harmony export */ newElementWith: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.newElementWith),\n/* harmony export */ normalizeLink: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.normalizeLink),\n/* harmony export */ parseLibraryTokensFromUrl: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.parseLibraryTokensFromUrl),\n/* harmony export */ reconcileElements: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.reconcileElements),\n/* harmony export */ refreshTextDimensions: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.refreshTextDimensions),\n/* harmony export */ registerFontsInCSS: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.registerFontsInCSS),\n/* harmony export */ registerLocalFont: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.registerLocalFont),\n/* harmony export */ restore: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.restore),\n/* harmony export */ restoreAppState: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.restoreAppState),\n/* harmony export */ restoreElement: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.restoreElement),\n/* harmony export */ restoreElements: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.restoreElements),\n/* harmony export */ restoreLibraryItems: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.restoreLibraryItems),\n/* harmony export */ safelyParseJSON: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.safelyParseJSON),\n/* harmony export */ sceneCoordsToViewportCoords: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.sceneCoordsToViewportCoords),\n/* harmony export */ serializeAsJSON: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.serializeAsJSON),\n/* harmony export */ serializeLibraryAsJSON: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.serializeLibraryAsJSON),\n/* harmony export */ setCustomTextMetricsProvider: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.setCustomTextMetricsProvider),\n/* harmony export */ syncInvalidIndices: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.syncInvalidIndices),\n/* harmony export */ syncMovedIndices: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.syncMovedIndices),\n/* harmony export */ useEditorInterface: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.useEditorInterface),\n/* harmony export */ useHandleLibrary: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.useHandleLibrary),\n/* harmony export */ useI18n: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.useI18n),\n/* harmony export */ useStylesPanelMode: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.useStylesPanelMode),\n/* harmony export */ viewportCoordsToSceneCoords: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.viewportCoordsToSceneCoords),\n/* harmony export */ wrapText: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.wrapText),\n/* harmony export */ zoomToFitBounds: () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_3__.zoomToFitBounds)\n/* harmony export */ });\n/* harmony import */ var _publicPath__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./publicPath */ \"./publicPath.js\");\n/* harmony import */ var _polyfill__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./polyfill */ \"./polyfill.ts\");\n/* harmony import */ var _fonts_fonts_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./fonts/fonts.css */ \"./fonts/fonts.css\");\n/* harmony import */ var _index__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./index */ \"./index.tsx\");\n\n\n\n(0,_polyfill__WEBPACK_IMPORTED_MODULE_1__[\"default\"])();\n\n\n//# sourceURL=webpack://ExcalidrawLib/./entry.js?");
17099
17044
 
17100
17045
  /***/ }),
17101
17046
 
@@ -17216,7 +17161,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
17216
17161
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
17217
17162
 
17218
17163
  "use strict";
17219
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ExcalidrawFontFace: () => (/* binding */ ExcalidrawFontFace)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n/* harmony import */ var _subset_subset_main__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../subset/subset-main */ \"./subset/subset-main.ts\");\n/* harmony import */ var _data_encode__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../data/encode */ \"./data/encode.ts\");\n/* harmony import */ var _obsidianUtils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../obsidianUtils */ \"./obsidianUtils.ts\");\n\n\n\n\nclass ExcalidrawFontFace {\n constructor(family, uri, descriptors) {\n this.urls = ExcalidrawFontFace.createUrls(uri);\n const sources = this.urls.map(url => `url(${url}) ${ExcalidrawFontFace.getFormat(url)}`).join(\", \");\n this.fontFace = new FontFace(family, sources, Object.assign({\n display: \"swap\",\n style: \"normal\",\n weight: \"400\"\n }, descriptors));\n }\n /**\n * Generates CSS `@font-face` definition with the (subsetted) font source as a data url for the characters within the unicode range.\n *\n * Retrieves `undefined` otherwise.\n */\n\n\n toCSS(characters) {\n // quick exit in case the characters are not within this font face's unicode range\n if (!this.getUnicodeRangeRegex().test(characters)) {\n return;\n } //zsviczian - only woffs are chopped into glyphs other fonts are returned as is\n\n\n if (typeof this.urls[0] === \"string\" && !this.urls[0].startsWith(\"data:font/woff2\")) {\n return Promise.resolve(`@font-face { font-family: ${this.fontFace.family}; src: url(${this.urls[0]}); }`);\n }\n\n const codepoints = Array.from(characters).map(char => char.codePointAt(0));\n return this.getContent(codepoints).then(content => `@font-face { font-family: ${this.fontFace.family}; src: url(${content}); }`);\n }\n /**\n * Tries to fetch woff2 content, based on the registered urls (from first to last, treated as fallbacks).\n *\n * @returns base64 with subsetted glyphs based on the passed codepoint, last defined url otherwise\n */\n\n\n async getContent(codePoints) {\n let i = 0;\n const errorMessages = [];\n\n while (i < this.urls.length) {\n const url = this.urls[i];\n\n try {\n const arrayBuffer = await this.fetchFont(url);\n const base64 = await (0,_subset_subset_main__WEBPACK_IMPORTED_MODULE_1__.subsetWoff2GlyphsByCodepoints)(arrayBuffer, codePoints);\n return base64;\n } catch (e) {\n errorMessages.push(`\"${url.toString()}\" returned error \"${e}\"`);\n }\n\n i++;\n }\n\n console.error(`Failed to fetch font family \"${this.fontFace.family}\"`, JSON.stringify(errorMessages, undefined, 2)); // in case of issues, at least return the last url as a content\n // defaults to unpkg for bundled fonts (so that we don't have to host them forever) and http url for others\n\n return this.urls.length ? this.urls[this.urls.length - 1].toString() : \"\";\n }\n\n fetchFont(url) {\n return (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.promiseTry)(async () => {\n const result = await (0,_obsidianUtils__WEBPACK_IMPORTED_MODULE_3__.fetchFontFromVault)(url); //zsviczian\n\n if (result) {\n return result;\n }\n\n const response = await fetch(url, {\n // always prefer cache (even stale), otherwise it always triggers an unnecessary validation request\n // which we don't need as we are controlling freshness of the fonts with the stable hash suffix in the url\n // https://developer.mozilla.org/en-US/docs/Web/API/Request/cache\n cache: \"force-cache\",\n headers: {\n Accept: \"font/woff2\"\n }\n });\n\n if (!response.ok) {\n const urlString = url instanceof URL ? url.toString() : \"dataurl\";\n throw new Error(`Failed to fetch \"${urlString}\": ${response.statusText}`);\n }\n\n const arrayBuffer = await response.arrayBuffer();\n return arrayBuffer;\n });\n }\n\n getUnicodeRangeRegex() {\n // using \\u{h} or \\u{hhhhh} to match any number of hex digits,\n // otherwise we would get an \"Invalid Unicode escape\" error\n // e.g. U+0-1007F -> \\u{0}-\\u{1007F}\n const unicodeRangeRegex = this.fontFace.unicodeRange.split(/,\\s*/).map(range => {\n const [start, end] = range.replace(\"U+\", \"\").split(\"-\");\n\n if (end) {\n return `\\\\u{${start}}-\\\\u{${end}}`;\n }\n\n return `\\\\u{${start}}`;\n }).join(\"\");\n return new RegExp(`[${unicodeRangeRegex}]`, \"u\");\n }\n\n static createUrls(uri) {\n if (uri.startsWith(\"data\")) {\n // don't create the URL instance, as parsing the huge dataurl string is expensive\n return [uri];\n }\n\n if (uri.startsWith(_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.LOCAL_FONT_PROTOCOL)) {\n // no url for local fonts\n return [];\n }\n\n if (uri.startsWith(\"http\")) {\n // one url for http imports or data url\n return [new URL(uri)];\n } // absolute assets paths, which are found in tests and excalidraw-app build, won't work with base url, so we are stripping initial slash away\n\n\n const assetUrl = uri.replace(/^\\/+/, \"\");\n const urls = [];\n\n if (typeof window.EXCALIDRAW_ASSET_PATH === \"string\") {\n const normalizedBaseUrl = this.normalizeBaseUrl(window.EXCALIDRAW_ASSET_PATH);\n urls.push(new URL(assetUrl, normalizedBaseUrl));\n } else if (Array.isArray(window.EXCALIDRAW_ASSET_PATH)) {\n window.EXCALIDRAW_ASSET_PATH.forEach(path => {\n const normalizedBaseUrl = this.normalizeBaseUrl(path);\n urls.push(new URL(assetUrl, normalizedBaseUrl));\n });\n } // fallback url for bundled fonts\n\n\n urls.push(new URL(assetUrl, ExcalidrawFontFace.ASSETS_FALLBACK_URL));\n return urls;\n }\n\n static getFormat(url) {\n if (!(url instanceof URL)) {\n // format is irrelevant for data url\n return \"\";\n }\n\n try {\n const parts = new URL(url).pathname.split(\".\");\n\n if (parts.length === 1) {\n return \"\";\n }\n\n return `format('${parts.pop()}')`;\n } catch (error) {\n return \"\";\n }\n }\n\n static normalizeBaseUrl(baseUrl) {\n var _a;\n\n let result = baseUrl; // in case user passed a root-relative url (~absolute path),\n // like \"/\" or \"/some/path\", or relative (starts with \"./\"),\n // prepend it with `location.origin`\n\n if (/^\\.?\\//.test(result)) {\n result = new URL(result.replace(/^\\.?\\/+/, \"\"), (_a = window === null || window === void 0 ? void 0 : window.location) === null || _a === void 0 ? void 0 : _a.origin).toString();\n } // ensure there is a trailing slash, otherwise url won't be correctly concatenated\n\n\n result = `${result.replace(/\\/+$/, \"\")}/`;\n return result;\n }\n /**\n * zsviczian https://github.com/zsviczian/excalidraw/commit/b4cfaaa4b4f46ca01f94e27fb7bf651a9da99daa\n */\n\n\n async getContentLegacy() {\n let i = 0;\n const errorMessages = [];\n\n while (i < this.urls.length) {\n const url = this.urls[i];\n\n if (typeof url === \"string\" && url.startsWith(\"data:\")) {\n // it's dataurl, the font is inlined as base64, no need to fetch\n return url;\n }\n\n try {\n const result = await (0,_obsidianUtils__WEBPACK_IMPORTED_MODULE_3__.fetchFontFromVault)(url); //zsviczian\n\n if (result) {\n return `data:font/woff2;base64,${(0,_data_encode__WEBPACK_IMPORTED_MODULE_2__.stringToBase64)((0,_data_encode__WEBPACK_IMPORTED_MODULE_2__.toByteString)(result), true)}`;\n }\n\n const response = await fetch(url, {\n headers: {\n Accept: \"font/woff2\"\n }\n });\n\n if (response.ok) {\n const mimeType = response.headers.get(\"Content-Type\");\n const buffer = await response.arrayBuffer();\n return `data:${mimeType};base64,${(0,_data_encode__WEBPACK_IMPORTED_MODULE_2__.stringToBase64)((0,_data_encode__WEBPACK_IMPORTED_MODULE_2__.toByteString)(buffer), true)}`;\n } // response not ok, try to continue\n\n\n errorMessages.push(`\"${url.toString()}\" returned status \"${response.status}\"`);\n } catch (e) {\n errorMessages.push(`\"${url.toString()}\" returned error \"${e}\"`);\n }\n\n i++;\n }\n\n console.error(`Failed to fetch font \"${this.fontFace.family}\" from urls \"${this.urls.toString()}`, JSON.stringify(errorMessages, undefined, 2)); // in case of issues, at least return the last url as a content\n // defaults to unpkg for bundled fonts (so that we don't have to host them forever) and http url for others\n\n return this.urls.length ? this.urls[this.urls.length - 1].toString() : \"\";\n }\n\n}\nExcalidrawFontFace.ASSETS_FALLBACK_URL = `https://esm.sh/${({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-64\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}).PKG_NAME ? `${({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-64\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}).PKG_NAME}@${({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-64\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}).PKG_VERSION}` // is provided during package build\n: \"@excalidraw/excalidraw\" // fallback to the latest package version (i.e. for app)\n}/dist/prod/`;\n\n//# sourceURL=webpack://ExcalidrawLib/./fonts/ExcalidrawFontFace.ts?");
17164
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ExcalidrawFontFace: () => (/* binding */ ExcalidrawFontFace)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n/* harmony import */ var _subset_subset_main__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../subset/subset-main */ \"./subset/subset-main.ts\");\n/* harmony import */ var _data_encode__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../data/encode */ \"./data/encode.ts\");\n/* harmony import */ var _obsidianUtils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../obsidianUtils */ \"./obsidianUtils.ts\");\n\n\n\n\nclass ExcalidrawFontFace {\n constructor(family, uri, descriptors) {\n this.urls = ExcalidrawFontFace.createUrls(uri);\n const sources = this.urls.map(url => `url(${url}) ${ExcalidrawFontFace.getFormat(url)}`).join(\", \");\n this.fontFace = new FontFace(family, sources, Object.assign({\n display: \"swap\",\n style: \"normal\",\n weight: \"400\"\n }, descriptors));\n }\n /**\n * Generates CSS `@font-face` definition with the (subsetted) font source as a data url for the characters within the unicode range.\n *\n * Retrieves `undefined` otherwise.\n */\n\n\n toCSS(characters) {\n // quick exit in case the characters are not within this font face's unicode range\n if (!this.getUnicodeRangeRegex().test(characters)) {\n return;\n } //zsviczian - only woffs are chopped into glyphs other fonts are returned as is\n\n\n if (typeof this.urls[0] === \"string\" && !this.urls[0].startsWith(\"data:font/woff2\")) {\n return Promise.resolve(`@font-face { font-family: ${this.fontFace.family}; src: url(${this.urls[0]}); }`);\n }\n\n const codepoints = Array.from(characters).map(char => char.codePointAt(0));\n return this.getContent(codepoints).then(content => `@font-face { font-family: ${this.fontFace.family}; src: url(${content}); }`);\n }\n /**\n * Tries to fetch woff2 content, based on the registered urls (from first to last, treated as fallbacks).\n *\n * @returns base64 with subsetted glyphs based on the passed codepoint, last defined url otherwise\n */\n\n\n async getContent(codePoints) {\n let i = 0;\n const errorMessages = [];\n\n while (i < this.urls.length) {\n const url = this.urls[i];\n\n try {\n const arrayBuffer = await this.fetchFont(url);\n const base64 = await (0,_subset_subset_main__WEBPACK_IMPORTED_MODULE_1__.subsetWoff2GlyphsByCodepoints)(arrayBuffer, codePoints);\n return base64;\n } catch (e) {\n errorMessages.push(`\"${url.toString()}\" returned error \"${e}\"`);\n }\n\n i++;\n }\n\n console.error(`Failed to fetch font family \"${this.fontFace.family}\"`, JSON.stringify(errorMessages, undefined, 2)); // in case of issues, at least return the last url as a content\n // defaults to unpkg for bundled fonts (so that we don't have to host them forever) and http url for others\n\n return this.urls.length ? this.urls[this.urls.length - 1].toString() : \"\";\n }\n\n fetchFont(url) {\n return (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.promiseTry)(async () => {\n const result = await (0,_obsidianUtils__WEBPACK_IMPORTED_MODULE_3__.fetchFontFromVault)(url); //zsviczian\n\n if (result) {\n return result;\n }\n\n const response = await fetch(url, {\n // always prefer cache (even stale), otherwise it always triggers an unnecessary validation request\n // which we don't need as we are controlling freshness of the fonts with the stable hash suffix in the url\n // https://developer.mozilla.org/en-US/docs/Web/API/Request/cache\n cache: \"force-cache\",\n headers: {\n Accept: \"font/woff2\"\n }\n });\n\n if (!response.ok) {\n const urlString = url instanceof URL ? url.toString() : \"dataurl\";\n throw new Error(`Failed to fetch \"${urlString}\": ${response.statusText}`);\n }\n\n const arrayBuffer = await response.arrayBuffer();\n return arrayBuffer;\n });\n }\n\n getUnicodeRangeRegex() {\n // using \\u{h} or \\u{hhhhh} to match any number of hex digits,\n // otherwise we would get an \"Invalid Unicode escape\" error\n // e.g. U+0-1007F -> \\u{0}-\\u{1007F}\n const unicodeRangeRegex = this.fontFace.unicodeRange.split(/,\\s*/).map(range => {\n const [start, end] = range.replace(\"U+\", \"\").split(\"-\");\n\n if (end) {\n return `\\\\u{${start}}-\\\\u{${end}}`;\n }\n\n return `\\\\u{${start}}`;\n }).join(\"\");\n return new RegExp(`[${unicodeRangeRegex}]`, \"u\");\n }\n\n static createUrls(uri) {\n if (uri.startsWith(\"data\")) {\n // don't create the URL instance, as parsing the huge dataurl string is expensive\n return [uri];\n }\n\n if (uri.startsWith(_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.LOCAL_FONT_PROTOCOL)) {\n // no url for local fonts\n return [];\n }\n\n if (uri.startsWith(\"http\")) {\n // one url for http imports or data url\n return [new URL(uri)];\n } // absolute assets paths, which are found in tests and excalidraw-app build, won't work with base url, so we are stripping initial slash away\n\n\n const assetUrl = uri.replace(/^\\/+/, \"\");\n const urls = [];\n\n if (typeof window.EXCALIDRAW_ASSET_PATH === \"string\") {\n const normalizedBaseUrl = this.normalizeBaseUrl(window.EXCALIDRAW_ASSET_PATH);\n urls.push(new URL(assetUrl, normalizedBaseUrl));\n } else if (Array.isArray(window.EXCALIDRAW_ASSET_PATH)) {\n window.EXCALIDRAW_ASSET_PATH.forEach(path => {\n const normalizedBaseUrl = this.normalizeBaseUrl(path);\n urls.push(new URL(assetUrl, normalizedBaseUrl));\n });\n } // fallback url for bundled fonts\n\n\n urls.push(new URL(assetUrl, ExcalidrawFontFace.ASSETS_FALLBACK_URL));\n return urls;\n }\n\n static getFormat(url) {\n if (!(url instanceof URL)) {\n // format is irrelevant for data url\n return \"\";\n }\n\n try {\n const parts = new URL(url).pathname.split(\".\");\n\n if (parts.length === 1) {\n return \"\";\n }\n\n return `format('${parts.pop()}')`;\n } catch (error) {\n return \"\";\n }\n }\n\n static normalizeBaseUrl(baseUrl) {\n var _a;\n\n let result = baseUrl; // in case user passed a root-relative url (~absolute path),\n // like \"/\" or \"/some/path\", or relative (starts with \"./\"),\n // prepend it with `location.origin`\n\n if (/^\\.?\\//.test(result)) {\n result = new URL(result.replace(/^\\.?\\/+/, \"\"), (_a = window === null || window === void 0 ? void 0 : window.location) === null || _a === void 0 ? void 0 : _a.origin).toString();\n } // ensure there is a trailing slash, otherwise url won't be correctly concatenated\n\n\n result = `${result.replace(/\\/+$/, \"\")}/`;\n return result;\n }\n /**\n * zsviczian https://github.com/zsviczian/excalidraw/commit/b4cfaaa4b4f46ca01f94e27fb7bf651a9da99daa\n */\n\n\n async getContentLegacy() {\n let i = 0;\n const errorMessages = [];\n\n while (i < this.urls.length) {\n const url = this.urls[i];\n\n if (typeof url === \"string\" && url.startsWith(\"data:\")) {\n // it's dataurl, the font is inlined as base64, no need to fetch\n return url;\n }\n\n try {\n const result = await (0,_obsidianUtils__WEBPACK_IMPORTED_MODULE_3__.fetchFontFromVault)(url); //zsviczian\n\n if (result) {\n return `data:font/woff2;base64,${(0,_data_encode__WEBPACK_IMPORTED_MODULE_2__.stringToBase64)((0,_data_encode__WEBPACK_IMPORTED_MODULE_2__.toByteString)(result), true)}`;\n }\n\n const response = await fetch(url, {\n headers: {\n Accept: \"font/woff2\"\n }\n });\n\n if (response.ok) {\n const mimeType = response.headers.get(\"Content-Type\");\n const buffer = await response.arrayBuffer();\n return `data:${mimeType};base64,${(0,_data_encode__WEBPACK_IMPORTED_MODULE_2__.stringToBase64)((0,_data_encode__WEBPACK_IMPORTED_MODULE_2__.toByteString)(buffer), true)}`;\n } // response not ok, try to continue\n\n\n errorMessages.push(`\"${url.toString()}\" returned status \"${response.status}\"`);\n } catch (e) {\n errorMessages.push(`\"${url.toString()}\" returned error \"${e}\"`);\n }\n\n i++;\n }\n\n console.error(`Failed to fetch font \"${this.fontFace.family}\" from urls \"${this.urls.toString()}`, JSON.stringify(errorMessages, undefined, 2)); // in case of issues, at least return the last url as a content\n // defaults to unpkg for bundled fonts (so that we don't have to host them forever) and http url for others\n\n return this.urls.length ? this.urls[this.urls.length - 1].toString() : \"\";\n }\n\n}\nExcalidrawFontFace.ASSETS_FALLBACK_URL = `https://esm.sh/${({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-66\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}).PKG_NAME ? `${({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-66\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}).PKG_NAME}@${({\"MODE\":\"development\",\"VITE_APP_BACKEND_V2_GET_URL\":\"https://json-dev.excalidraw.com/api/v2/\",\"VITE_APP_BACKEND_V2_POST_URL\":\"https://json-dev.excalidraw.com/api/v2/post/\",\"VITE_APP_LIBRARY_URL\":\"https://libraries.excalidraw.com\",\"VITE_APP_LIBRARY_BACKEND\":\"https://us-central1-excalidraw-room-persistence.cloudfunctions.net/libraries\",\"VITE_APP_WS_SERVER_URL\":\"http://localhost:3002\",\"VITE_APP_PLUS_LP\":\"https://plus.excalidraw.com\",\"VITE_APP_PLUS_APP\":\"http://localhost:3000\",\"VITE_APP_AI_BACKEND\":\"http://localhost:3015\",\"VITE_APP_FIREBASE_CONFIG\":\"{\\\"apiKey\\\":\\\"AIzaSyCMkxA60XIW8KbqMYL7edC4qT5l4qHX2h8\\\",\\\"authDomain\\\":\\\"excalidraw-oss-dev.firebaseapp.com\\\",\\\"projectId\\\":\\\"excalidraw-oss-dev\\\",\\\"storageBucket\\\":\\\"excalidraw-oss-dev.appspot.com\\\",\\\"messagingSenderId\\\":\\\"664559512677\\\",\\\"appId\\\":\\\"1:664559512677:web:a385181f2928d328a7aa8c\\\"}\",\"VITE_APP_DEV_DISABLE_LIVE_RELOAD\":\"\",\"VITE_APP_ENABLE_TRACKING\":\"true\",\"FAST_REFRESH\":\"false\",\"VITE_APP_PORT\":\"3000\",\"VITE_APP_DEBUG_ENABLE_TEXT_CONTAINER_BOUNDING_BOX\":\"\",\"VITE_APP_COLLAPSE_OVERLAY\":\"true\",\"VITE_APP_ENABLE_ESLINT\":\"true\",\"VITE_APP_ENABLE_PWA\":\"false\",\"VITE_APP_PLUS_EXPORT_PUBLIC_KEY\":\"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm2g5T+Rub6Kbf1Mf57t0\\n7r2zeHuVg4dla3r5ryXMswtzz6x767octl6oLThn33mQsPSy3GKglFZoCTXJR4ij\\nba8SxB04sL/N8eRrKja7TFWjCVtRwTTfyy771NYYNFVJclkxHyE5qw4m27crHF1y\\nUNWEjuqNMi/lwAErS9fFa2oJlWyT8U7zzv/5kQREkxZI6y9v0AF3qcbsy2731FnD\\ns9ChJvOUW9toIab2gsIdrKW8ZNpu084ZFVKb6LNjvIXI1Se4oMTHeszXzNptzlot\\nkdxxjOoaQMAyfljFSot1F1FlU6MQlag7UnFGvFjRHN1JI5q4K+n3a67DX+TMyRqS\\nHQIDAQAB\",\"VITE_APP_DISABLE_PREVENT_UNLOAD\":\"\",\"VITE_PKG_NAME\":\"@zsviczian/excalidraw\",\"VITE_PKG_VERSION\":\"0.18.0-66\",\"VITE_IS_EXCALIDRAW_NPM_PACKAGE\":true}).PKG_VERSION}` // is provided during package build\n: \"@excalidraw/excalidraw\" // fallback to the latest package version (i.e. for app)\n}/dist/prod/`;\n\n//# sourceURL=webpack://ExcalidrawLib/./fonts/ExcalidrawFontFace.ts?");
17220
17165
 
17221
17166
  /***/ }),
17222
17167
 
@@ -19966,7 +19911,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
19966
19911
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
19967
19912
 
19968
19913
  "use strict";
19969
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Button: () => (/* reexport safe */ _components_Button__WEBPACK_IMPORTED_MODULE_31__.Button),\n/* harmony export */ CaptureUpdateAction: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.CaptureUpdateAction),\n/* harmony export */ DEFAULT_LASER_COLOR: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_LASER_COLOR),\n/* harmony export */ DefaultSidebar: () => (/* reexport safe */ _components_DefaultSidebar__WEBPACK_IMPORTED_MODULE_34__.DefaultSidebar),\n/* harmony export */ DiagramToCodePlugin: () => (/* reexport safe */ _components_DiagramToCodePlugin_DiagramToCodePlugin__WEBPACK_IMPORTED_MODULE_40__.DiagramToCodePlugin),\n/* harmony export */ Ellipsify: () => (/* reexport safe */ _components_Ellipsify__WEBPACK_IMPORTED_MODULE_32__.Ellipsify),\n/* harmony export */ Excalidraw: () => (/* binding */ Excalidraw),\n/* harmony export */ FONT_FAMILY: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.FONT_FAMILY),\n/* harmony export */ Footer: () => (/* reexport safe */ _components_footer_FooterCenter__WEBPACK_IMPORTED_MODULE_4__[\"default\"]),\n/* harmony export */ LiveCollaborationTrigger: () => (/* reexport safe */ _components_live_collaboration_LiveCollaborationTrigger__WEBPACK_IMPORTED_MODULE_5__[\"default\"]),\n/* harmony export */ MIME_TYPES: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.MIME_TYPES),\n/* harmony export */ MainMenu: () => (/* reexport safe */ _components_main_menu_MainMenu__WEBPACK_IMPORTED_MODULE_6__[\"default\"]),\n/* harmony export */ ROUNDNESS: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.ROUNDNESS),\n/* harmony export */ Sidebar: () => (/* reexport safe */ _components_Sidebar_Sidebar__WEBPACK_IMPORTED_MODULE_30__.Sidebar),\n/* harmony export */ Stats: () => (/* reexport safe */ _components_Stats__WEBPACK_IMPORTED_MODULE_33__.Stats),\n/* harmony export */ THEME: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.THEME),\n/* harmony export */ TTDDialog: () => (/* reexport safe */ _components_TTDDialog_TTDDialog__WEBPACK_IMPORTED_MODULE_35__.TTDDialog),\n/* harmony export */ TTDDialogTrigger: () => (/* reexport safe */ _components_TTDDialog_TTDDialogTrigger__WEBPACK_IMPORTED_MODULE_36__.TTDDialogTrigger),\n/* harmony export */ UserIdleState: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.UserIdleState),\n/* harmony export */ WelcomeScreen: () => (/* reexport safe */ _components_welcome_screen_WelcomeScreen__WEBPACK_IMPORTED_MODULE_7__[\"default\"]),\n/* harmony export */ bumpVersion: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.bumpVersion),\n/* harmony export */ convertToExcalidrawElements: () => (/* reexport safe */ _data_transform__WEBPACK_IMPORTED_MODULE_38__.convertToExcalidrawElements),\n/* harmony export */ defaultLang: () => (/* reexport safe */ _i18n__WEBPACK_IMPORTED_MODULE_8__.defaultLang),\n/* harmony export */ destroyObsidianUtils: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.destroyObsidianUtils),\n/* harmony export */ elementPartiallyOverlapsWithOrContainsBBox: () => (/* reexport safe */ _excalidraw_utils_withinBounds__WEBPACK_IMPORTED_MODULE_39__.elementPartiallyOverlapsWithOrContainsBBox),\n/* harmony export */ elementsOverlappingBBox: () => (/* reexport safe */ _excalidraw_utils_withinBounds__WEBPACK_IMPORTED_MODULE_39__.elementsOverlappingBBox),\n/* harmony export */ exportToBlob: () => (/* reexport safe */ _excalidraw_utils_export__WEBPACK_IMPORTED_MODULE_17__.exportToBlob),\n/* harmony export */ exportToCanvas: () => (/* reexport safe */ _excalidraw_utils_export__WEBPACK_IMPORTED_MODULE_17__.exportToCanvas),\n/* harmony export */ exportToClipboard: () => (/* reexport safe */ _excalidraw_utils_export__WEBPACK_IMPORTED_MODULE_17__.exportToClipboard),\n/* harmony export */ exportToSvg: () => (/* reexport safe */ _excalidraw_utils_export__WEBPACK_IMPORTED_MODULE_17__.exportToSvg),\n/* harmony export */ getBoundTextMaxWidth: () => (/* reexport safe */ _excalidraw_element_textElement__WEBPACK_IMPORTED_MODULE_22__.getBoundTextMaxWidth),\n/* harmony export */ getCSSFontDefinition: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.getCSSFontDefinition),\n/* harmony export */ getCommonBoundingBox: () => (/* reexport safe */ _excalidraw_element_bounds__WEBPACK_IMPORTED_MODULE_18__.getCommonBoundingBox),\n/* harmony export */ getCommonBounds: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getCommonBounds),\n/* harmony export */ getContainerElement: () => (/* reexport safe */ _excalidraw_element_textElement__WEBPACK_IMPORTED_MODULE_22__.getContainerElement),\n/* harmony export */ getDataURL: () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_27__.getDataURL),\n/* harmony export */ getEmbedLink: () => (/* reexport safe */ _excalidraw_element_embeddable__WEBPACK_IMPORTED_MODULE_29__.getEmbedLink),\n/* harmony export */ getFontFamilies: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.getFontFamilies),\n/* harmony export */ getFontFamilyString: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.getFontFamilyString),\n/* harmony export */ getFontMetrics: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.getFontMetrics),\n/* harmony export */ getFontString: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.getFontString),\n/* harmony export */ getFormFactor: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.getFormFactor),\n/* harmony export */ getFreeDrawSvgPath: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getFreeDrawSvgPath),\n/* harmony export */ getLibraryItemsHash: () => (/* reexport safe */ _data_library__WEBPACK_IMPORTED_MODULE_28__.getLibraryItemsHash),\n/* harmony export */ getLineHeight: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.getLineHeight),\n/* harmony export */ getMaximumGroups: () => (/* reexport safe */ _excalidraw_element_groups__WEBPACK_IMPORTED_MODULE_19__.getMaximumGroups),\n/* harmony export */ getNonDeletedElements: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getNonDeletedElements),\n/* harmony export */ getSceneVersion: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getSceneVersion),\n/* harmony export */ getSharedMermaidInstance: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.getSharedMermaidInstance),\n/* harmony export */ getTextFromElements: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getTextFromElements),\n/* harmony export */ getVisibleSceneBounds: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getVisibleSceneBounds),\n/* harmony export */ hashElementsVersion: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.hashElementsVersion),\n/* harmony export */ hashString: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.hashString),\n/* harmony export */ intersectElementWithLine: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.intersectElementWithLine),\n/* harmony export */ isElementInsideBBox: () => (/* reexport safe */ _excalidraw_utils_withinBounds__WEBPACK_IMPORTED_MODULE_39__.isElementInsideBBox),\n/* harmony export */ isElementLink: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.isElementLink),\n/* harmony export */ isInvisiblySmallElement: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.isInvisiblySmallElement),\n/* harmony export */ isLinearElement: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.isLinearElement),\n/* harmony export */ languages: () => (/* reexport safe */ _i18n__WEBPACK_IMPORTED_MODULE_8__.languages),\n/* harmony export */ loadFromBlob: () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_27__.loadFromBlob),\n/* harmony export */ loadLibraryFromBlob: () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_27__.loadLibraryFromBlob),\n/* harmony export */ loadMermaid: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.loadMermaid),\n/* harmony export */ loadSceneFonts: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.loadSceneFonts),\n/* harmony export */ loadSceneOrLibraryFromBlob: () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_27__.loadSceneOrLibraryFromBlob),\n/* harmony export */ measureText: () => (/* reexport safe */ _excalidraw_element_textMeasurements__WEBPACK_IMPORTED_MODULE_20__.measureText),\n/* harmony export */ mergeLibraryItems: () => (/* reexport safe */ _data_library__WEBPACK_IMPORTED_MODULE_28__.mergeLibraryItems),\n/* harmony export */ mermaidToExcalidraw: () => (/* reexport safe */ _components_TTDDialog_MermaidToExcalidrawLib__WEBPACK_IMPORTED_MODULE_23__.mermaidToExcalidraw),\n/* harmony export */ mutateElement: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.mutateElement),\n/* harmony export */ newElementWith: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.newElementWith),\n/* harmony export */ normalizeLink: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.normalizeLink),\n/* harmony export */ parseLibraryTokensFromUrl: () => (/* reexport safe */ _data_library__WEBPACK_IMPORTED_MODULE_28__.parseLibraryTokensFromUrl),\n/* harmony export */ reconcileElements: () => (/* reexport safe */ _data_reconcile__WEBPACK_IMPORTED_MODULE_16__.reconcileElements),\n/* harmony export */ refreshTextDimensions: () => (/* reexport safe */ _excalidraw_element_newElement__WEBPACK_IMPORTED_MODULE_25__.refreshTextDimensions),\n/* harmony export */ registerFontsInCSS: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.registerFontsInCSS),\n/* harmony export */ registerLocalFont: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.registerLocalFont),\n/* harmony export */ restore: () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_15__.restore),\n/* harmony export */ restoreAppState: () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_15__.restoreAppState),\n/* harmony export */ restoreElement: () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_15__.restoreElement),\n/* harmony export */ restoreElements: () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_15__.restoreElements),\n/* harmony export */ restoreLibraryItems: () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_15__.restoreLibraryItems),\n/* harmony export */ safelyParseJSON: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.safelyParseJSON),\n/* harmony export */ sceneCoordsToViewportCoords: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.sceneCoordsToViewportCoords),\n/* harmony export */ serializeAsJSON: () => (/* reexport safe */ _data_json__WEBPACK_IMPORTED_MODULE_26__.serializeAsJSON),\n/* harmony export */ serializeLibraryAsJSON: () => (/* reexport safe */ _data_json__WEBPACK_IMPORTED_MODULE_26__.serializeLibraryAsJSON),\n/* harmony export */ setCustomTextMetricsProvider: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.setCustomTextMetricsProvider),\n/* harmony export */ syncInvalidIndices: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.syncInvalidIndices),\n/* harmony export */ syncMovedIndices: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.syncMovedIndices),\n/* harmony export */ useEditorInterface: () => (/* reexport safe */ _components_App__WEBPACK_IMPORTED_MODULE_2__.useEditorInterface),\n/* harmony export */ useHandleLibrary: () => (/* reexport safe */ _data_library__WEBPACK_IMPORTED_MODULE_28__.useHandleLibrary),\n/* harmony export */ useI18n: () => (/* reexport safe */ _i18n__WEBPACK_IMPORTED_MODULE_8__.useI18n),\n/* harmony export */ useStylesPanelMode: () => (/* reexport safe */ _components_App__WEBPACK_IMPORTED_MODULE_2__.useStylesPanelMode),\n/* harmony export */ viewportCoordsToSceneCoords: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.viewportCoordsToSceneCoords),\n/* harmony export */ wrapText: () => (/* reexport safe */ _excalidraw_element_textWrapping__WEBPACK_IMPORTED_MODULE_21__.wrapText),\n/* harmony export */ zoomToFitBounds: () => (/* reexport safe */ _actions_actionCanvas__WEBPACK_IMPORTED_MODULE_37__.zoomToFitBounds)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n/* harmony import */ var _components_App__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./components/App */ \"./components/App.tsx\");\n/* harmony import */ var _components_InitializeApp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./components/InitializeApp */ \"./components/InitializeApp.tsx\");\n/* harmony import */ var _components_footer_FooterCenter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./components/footer/FooterCenter */ \"./components/footer/FooterCenter.tsx\");\n/* harmony import */ var _components_live_collaboration_LiveCollaborationTrigger__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./components/live-collaboration/LiveCollaborationTrigger */ \"./components/live-collaboration/LiveCollaborationTrigger.tsx\");\n/* harmony import */ var _components_main_menu_MainMenu__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./components/main-menu/MainMenu */ \"./components/main-menu/MainMenu.tsx\");\n/* harmony import */ var _components_welcome_screen_WelcomeScreen__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./components/welcome-screen/WelcomeScreen */ \"./components/welcome-screen/WelcomeScreen.tsx\");\n/* harmony import */ var _i18n__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./i18n */ \"./i18n.ts\");\n/* harmony import */ var _editor_jotai__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./editor-jotai */ \"./editor-jotai.ts\");\n/* harmony import */ var _polyfill__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./polyfill */ \"./polyfill.ts\");\n/* harmony import */ var _css_app_scss__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./css/app.scss */ \"./css/app.scss\");\n/* harmony import */ var _css_styles_scss__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./css/styles.scss */ \"./css/styles.scss\");\n/* harmony import */ var _fonts_fonts_css__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./fonts/fonts.css */ \"./fonts/fonts.css\");\n/* harmony import */ var _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! @excalidraw/element */ \"../element/src/index.ts\");\n/* harmony import */ var _data_restore__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ./data/restore */ \"./data/restore.ts\");\n/* harmony import */ var _data_reconcile__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! ./data/reconcile */ \"./data/reconcile.ts\");\n/* harmony import */ var _excalidraw_utils_export__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(/*! @excalidraw/utils/export */ \"../utils/src/export.ts\");\n/* harmony import */ var _excalidraw_element_bounds__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(/*! @excalidraw/element/bounds */ \"../element/src/bounds.ts\");\n/* harmony import */ var _excalidraw_element_groups__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(/*! @excalidraw/element/groups */ \"../element/src/groups.ts\");\n/* harmony import */ var _excalidraw_element_textMeasurements__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(/*! @excalidraw/element/textMeasurements */ \"../element/src/textMeasurements.ts\");\n/* harmony import */ var _excalidraw_element_textWrapping__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(/*! @excalidraw/element/textWrapping */ \"../element/src/textWrapping.ts\");\n/* harmony import */ var _excalidraw_element_textElement__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(/*! @excalidraw/element/textElement */ \"../element/src/textElement.ts\");\n/* harmony import */ var _components_TTDDialog_MermaidToExcalidrawLib__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(/*! ./components/TTDDialog/MermaidToExcalidrawLib */ \"./components/TTDDialog/MermaidToExcalidrawLib.ts\");\n/* harmony import */ var _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(/*! ../excalidraw/obsidianUtils */ \"./obsidianUtils.ts\");\n/* harmony import */ var _excalidraw_element_newElement__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(/*! @excalidraw/element/newElement */ \"../element/src/newElement.ts\");\n/* harmony import */ var _data_json__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(/*! ./data/json */ \"./data/json.ts\");\n/* harmony import */ var _data_blob__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(/*! ./data/blob */ \"./data/blob.ts\");\n/* harmony import */ var _data_library__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(/*! ./data/library */ \"./data/library.ts\");\n/* harmony import */ var _excalidraw_element_embeddable__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(/*! @excalidraw/element/embeddable */ \"../element/src/embeddable.ts\");\n/* harmony import */ var _components_Sidebar_Sidebar__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(/*! ./components/Sidebar/Sidebar */ \"./components/Sidebar/Sidebar.tsx\");\n/* harmony import */ var _components_Button__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(/*! ./components/Button */ \"./components/Button.tsx\");\n/* harmony import */ var _components_Ellipsify__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(/*! ./components/Ellipsify */ \"./components/Ellipsify.tsx\");\n/* harmony import */ var _components_Stats__WEBPACK_IMPORTED_MODULE_33__ = __webpack_require__(/*! ./components/Stats */ \"./components/Stats/index.tsx\");\n/* harmony import */ var _components_DefaultSidebar__WEBPACK_IMPORTED_MODULE_34__ = __webpack_require__(/*! ./components/DefaultSidebar */ \"./components/DefaultSidebar.tsx\");\n/* harmony import */ var _components_TTDDialog_TTDDialog__WEBPACK_IMPORTED_MODULE_35__ = __webpack_require__(/*! ./components/TTDDialog/TTDDialog */ \"./components/TTDDialog/TTDDialog.tsx\");\n/* harmony import */ var _components_TTDDialog_TTDDialogTrigger__WEBPACK_IMPORTED_MODULE_36__ = __webpack_require__(/*! ./components/TTDDialog/TTDDialogTrigger */ \"./components/TTDDialog/TTDDialogTrigger.tsx\");\n/* harmony import */ var _actions_actionCanvas__WEBPACK_IMPORTED_MODULE_37__ = __webpack_require__(/*! ./actions/actionCanvas */ \"./actions/actionCanvas.tsx\");\n/* harmony import */ var _data_transform__WEBPACK_IMPORTED_MODULE_38__ = __webpack_require__(/*! ./data/transform */ \"./data/transform.ts\");\n/* harmony import */ var _excalidraw_utils_withinBounds__WEBPACK_IMPORTED_MODULE_39__ = __webpack_require__(/*! @excalidraw/utils/withinBounds */ \"../utils/src/withinBounds.ts\");\n/* harmony import */ var _components_DiagramToCodePlugin_DiagramToCodePlugin__WEBPACK_IMPORTED_MODULE_40__ = __webpack_require__(/*! ./components/DiagramToCodePlugin/DiagramToCodePlugin */ \"./components/DiagramToCodePlugin/DiagramToCodePlugin.tsx\");\nvar __rest = undefined && undefined.__rest || function (s, e) {\n var t = {};\n\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n};\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n(0,_polyfill__WEBPACK_IMPORTED_MODULE_10__[\"default\"])();\n\nconst ExcalidrawBase = props => {\n var _a, _b, _c, _d, _e, _f;\n\n const {\n onChange,\n onIncrement,\n initialData,\n excalidrawAPI,\n isCollaborating = false,\n onPointerUpdate,\n renderTopLeftUI,\n renderTopRightUI,\n langCode = _i18n__WEBPACK_IMPORTED_MODULE_8__.defaultLang.code,\n viewModeEnabled,\n zenModeEnabled,\n gridModeEnabled,\n initState,\n //zsviczian\n libraryReturnUrl,\n theme,\n name,\n renderCustomStats,\n onPaste,\n onDrop,\n //zsviczian\n detectScroll = true,\n handleKeyboardGlobally = false,\n onLibraryChange,\n autoFocus = false,\n onBeforeTextEdit,\n //zsviczian\n onBeforeTextSubmit,\n //zsviczian\n generateIdForFile,\n onThemeChange,\n //zsviczian\n onLinkOpen,\n onLinkHover,\n //zsviczian\n onViewModeChange,\n //zsviczian\n generateLinkForSelection,\n onPointerDown,\n onPointerUp,\n onScrollChange,\n onDuplicate,\n children,\n validateEmbeddable,\n renderEmbeddable,\n renderWebview,\n //zsviczian\n renderEmbeddableMenu,\n //zsviczian\n renderMermaid,\n //zsviczian\n onContextMenu,\n //zsviczian\n aiEnabled,\n showDeprecatedFonts,\n renderScrollbars\n } = props;\n const canvasActions = (_a = props.UIOptions) === null || _a === void 0 ? void 0 : _a.canvasActions; // FIXME normalize/set defaults in parent component so that the memo resolver\n // compares the same values\n\n const UIOptions = Object.assign(Object.assign({}, props.UIOptions), {\n canvasActions: Object.assign(Object.assign({}, _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_UI_OPTIONS.canvasActions), canvasActions),\n tools: {\n image: (_d = (_c = (_b = props.UIOptions) === null || _b === void 0 ? void 0 : _b.tools) === null || _c === void 0 ? void 0 : _c.image) !== null && _d !== void 0 ? _d : true\n }\n });\n\n if (canvasActions === null || canvasActions === void 0 ? void 0 : canvasActions.export) {\n UIOptions.canvasActions.export.saveFileToDisk = (_f = (_e = canvasActions.export) === null || _e === void 0 ? void 0 : _e.saveFileToDisk) !== null && _f !== void 0 ? _f : _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_UI_OPTIONS.canvasActions.export.saveFileToDisk;\n }\n\n if (UIOptions.canvasActions.toggleTheme === null && typeof theme === \"undefined\") {\n UIOptions.canvasActions.toggleTheme = true;\n }\n\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {\n const importPolyfill = async () => {\n //@ts-ignore\n await Promise.resolve(/*! import() */).then(__webpack_require__.t.bind(__webpack_require__, /*! canvas-roundrect-polyfill */ \"../../node_modules/canvas-roundrect-polyfill/roundRect.js\", 23));\n };\n\n importPolyfill(); // Block pinch-zooming on iOS outside of the content area\n\n const handleTouchMove = event => {\n // @ts-ignore\n if (typeof event.scale === \"number\" && event.scale !== 1) {\n event.preventDefault();\n }\n };\n\n document.addEventListener(\"touchmove\", handleTouchMove, {\n passive: false\n });\n return () => {\n document.removeEventListener(\"touchmove\", handleTouchMove);\n };\n }, []);\n return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_editor_jotai__WEBPACK_IMPORTED_MODULE_9__.EditorJotaiProvider, {\n store: _editor_jotai__WEBPACK_IMPORTED_MODULE_9__.editorJotaiStore\n }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_components_InitializeApp__WEBPACK_IMPORTED_MODULE_3__.InitializeApp, {\n langCode: langCode,\n theme: theme\n }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_components_App__WEBPACK_IMPORTED_MODULE_2__[\"default\"], {\n onChange: onChange,\n onIncrement: onIncrement,\n initialData: initialData,\n excalidrawAPI: excalidrawAPI,\n isCollaborating: isCollaborating,\n onPointerUpdate: onPointerUpdate,\n renderTopLeftUI: renderTopLeftUI,\n renderTopRightUI: renderTopRightUI,\n langCode: langCode,\n viewModeEnabled: viewModeEnabled,\n zenModeEnabled: zenModeEnabled,\n gridModeEnabled: gridModeEnabled,\n initState: initState,\n libraryReturnUrl: libraryReturnUrl,\n theme: theme,\n name: name,\n renderCustomStats: renderCustomStats,\n UIOptions: UIOptions,\n onPaste: onPaste,\n onDrop: onDrop,\n detectScroll: detectScroll,\n handleKeyboardGlobally: handleKeyboardGlobally,\n onLibraryChange: onLibraryChange,\n autoFocus: autoFocus,\n onBeforeTextEdit: onBeforeTextEdit,\n onBeforeTextSubmit: onBeforeTextSubmit,\n generateIdForFile: generateIdForFile,\n onThemeChange: onThemeChange,\n onLinkOpen: onLinkOpen,\n onLinkHover: onLinkHover,\n onViewModeChange: onViewModeChange,\n generateLinkForSelection: generateLinkForSelection,\n onPointerDown: onPointerDown,\n onPointerUp: onPointerUp,\n onScrollChange: onScrollChange,\n onDuplicate: onDuplicate,\n validateEmbeddable: validateEmbeddable,\n renderEmbeddable: renderEmbeddable,\n renderWebview: renderWebview,\n renderEmbeddableMenu: renderEmbeddableMenu,\n renderMermaid: renderMermaid,\n onContextMenu: onContextMenu,\n aiEnabled: aiEnabled !== false,\n showDeprecatedFonts: showDeprecatedFonts,\n renderScrollbars: renderScrollbars\n }, children)));\n};\n\nconst areEqual = (prevProps, nextProps) => {\n // short-circuit early\n if (prevProps.children !== nextProps.children) {\n return false;\n }\n\n const {\n initialData: prevInitialData,\n UIOptions: prevUIOptions = {}\n } = prevProps,\n prev = __rest(prevProps, [\"initialData\", \"UIOptions\"]);\n\n const {\n initialData: nextInitialData,\n UIOptions: nextUIOptions = {}\n } = nextProps,\n next = __rest(nextProps, [\"initialData\", \"UIOptions\"]); // comparing UIOptions\n\n\n const prevUIOptionsKeys = Object.keys(prevUIOptions);\n const nextUIOptionsKeys = Object.keys(nextUIOptions);\n\n if (prevUIOptionsKeys.length !== nextUIOptionsKeys.length) {\n return false;\n }\n\n const isUIOptionsSame = prevUIOptionsKeys.every(key => {\n if (key === \"canvasActions\") {\n const canvasOptionKeys = Object.keys(prevUIOptions.canvasActions);\n return canvasOptionKeys.every(key => {\n var _a, _b, _c, _d;\n\n if (key === \"export\" && ((_a = prevUIOptions === null || prevUIOptions === void 0 ? void 0 : prevUIOptions.canvasActions) === null || _a === void 0 ? void 0 : _a.export) && ((_b = nextUIOptions === null || nextUIOptions === void 0 ? void 0 : nextUIOptions.canvasActions) === null || _b === void 0 ? void 0 : _b.export)) {\n return prevUIOptions.canvasActions.export.saveFileToDisk === nextUIOptions.canvasActions.export.saveFileToDisk;\n }\n\n return ((_c = prevUIOptions === null || prevUIOptions === void 0 ? void 0 : prevUIOptions.canvasActions) === null || _c === void 0 ? void 0 : _c[key]) === ((_d = nextUIOptions === null || nextUIOptions === void 0 ? void 0 : nextUIOptions.canvasActions) === null || _d === void 0 ? void 0 : _d[key]);\n });\n }\n\n return prevUIOptions[key] === nextUIOptions[key];\n });\n return isUIOptionsSame && (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.isShallowEqual)(prev, next);\n};\n\nconst Excalidraw = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().memo(ExcalidrawBase, areEqual);\nExcalidraw.displayName = \"Excalidraw\";\n\n\n\n\n\n\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n\n\n\n\n\n\n\n\n\n //zsviczian - not sure if I use it any more\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//# sourceURL=webpack://ExcalidrawLib/./index.tsx?");
19914
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Button: () => (/* reexport safe */ _components_Button__WEBPACK_IMPORTED_MODULE_31__.Button),\n/* harmony export */ CaptureUpdateAction: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.CaptureUpdateAction),\n/* harmony export */ DEFAULT_LASER_COLOR: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_LASER_COLOR),\n/* harmony export */ DefaultSidebar: () => (/* reexport safe */ _components_DefaultSidebar__WEBPACK_IMPORTED_MODULE_34__.DefaultSidebar),\n/* harmony export */ DiagramToCodePlugin: () => (/* reexport safe */ _components_DiagramToCodePlugin_DiagramToCodePlugin__WEBPACK_IMPORTED_MODULE_40__.DiagramToCodePlugin),\n/* harmony export */ Ellipsify: () => (/* reexport safe */ _components_Ellipsify__WEBPACK_IMPORTED_MODULE_32__.Ellipsify),\n/* harmony export */ Excalidraw: () => (/* binding */ Excalidraw),\n/* harmony export */ FONT_FAMILY: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.FONT_FAMILY),\n/* harmony export */ Footer: () => (/* reexport safe */ _components_footer_FooterCenter__WEBPACK_IMPORTED_MODULE_4__[\"default\"]),\n/* harmony export */ LiveCollaborationTrigger: () => (/* reexport safe */ _components_live_collaboration_LiveCollaborationTrigger__WEBPACK_IMPORTED_MODULE_5__[\"default\"]),\n/* harmony export */ MIME_TYPES: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.MIME_TYPES),\n/* harmony export */ MainMenu: () => (/* reexport safe */ _components_main_menu_MainMenu__WEBPACK_IMPORTED_MODULE_6__[\"default\"]),\n/* harmony export */ ROUNDNESS: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.ROUNDNESS),\n/* harmony export */ Sidebar: () => (/* reexport safe */ _components_Sidebar_Sidebar__WEBPACK_IMPORTED_MODULE_30__.Sidebar),\n/* harmony export */ Stats: () => (/* reexport safe */ _components_Stats__WEBPACK_IMPORTED_MODULE_33__.Stats),\n/* harmony export */ THEME: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.THEME),\n/* harmony export */ TTDDialog: () => (/* reexport safe */ _components_TTDDialog_TTDDialog__WEBPACK_IMPORTED_MODULE_35__.TTDDialog),\n/* harmony export */ TTDDialogTrigger: () => (/* reexport safe */ _components_TTDDialog_TTDDialogTrigger__WEBPACK_IMPORTED_MODULE_36__.TTDDialogTrigger),\n/* harmony export */ UserIdleState: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.UserIdleState),\n/* harmony export */ WelcomeScreen: () => (/* reexport safe */ _components_welcome_screen_WelcomeScreen__WEBPACK_IMPORTED_MODULE_7__[\"default\"]),\n/* harmony export */ bumpVersion: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.bumpVersion),\n/* harmony export */ convertToExcalidrawElements: () => (/* reexport safe */ _data_transform__WEBPACK_IMPORTED_MODULE_38__.convertToExcalidrawElements),\n/* harmony export */ defaultLang: () => (/* reexport safe */ _i18n__WEBPACK_IMPORTED_MODULE_8__.defaultLang),\n/* harmony export */ destroyObsidianUtils: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.destroyObsidianUtils),\n/* harmony export */ elementPartiallyOverlapsWithOrContainsBBox: () => (/* reexport safe */ _excalidraw_utils_withinBounds__WEBPACK_IMPORTED_MODULE_39__.elementPartiallyOverlapsWithOrContainsBBox),\n/* harmony export */ elementsOverlappingBBox: () => (/* reexport safe */ _excalidraw_utils_withinBounds__WEBPACK_IMPORTED_MODULE_39__.elementsOverlappingBBox),\n/* harmony export */ exportToBlob: () => (/* reexport safe */ _excalidraw_utils_export__WEBPACK_IMPORTED_MODULE_17__.exportToBlob),\n/* harmony export */ exportToCanvas: () => (/* reexport safe */ _excalidraw_utils_export__WEBPACK_IMPORTED_MODULE_17__.exportToCanvas),\n/* harmony export */ exportToClipboard: () => (/* reexport safe */ _excalidraw_utils_export__WEBPACK_IMPORTED_MODULE_17__.exportToClipboard),\n/* harmony export */ exportToSvg: () => (/* reexport safe */ _excalidraw_utils_export__WEBPACK_IMPORTED_MODULE_17__.exportToSvg),\n/* harmony export */ getBoundTextMaxWidth: () => (/* reexport safe */ _excalidraw_element_textElement__WEBPACK_IMPORTED_MODULE_22__.getBoundTextMaxWidth),\n/* harmony export */ getCSSFontDefinition: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.getCSSFontDefinition),\n/* harmony export */ getCommonBoundingBox: () => (/* reexport safe */ _excalidraw_element_bounds__WEBPACK_IMPORTED_MODULE_18__.getCommonBoundingBox),\n/* harmony export */ getCommonBounds: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getCommonBounds),\n/* harmony export */ getContainerElement: () => (/* reexport safe */ _excalidraw_element_textElement__WEBPACK_IMPORTED_MODULE_22__.getContainerElement),\n/* harmony export */ getDataURL: () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_27__.getDataURL),\n/* harmony export */ getDefaultColorPalette: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.getDefaultColorPalette),\n/* harmony export */ getEmbedLink: () => (/* reexport safe */ _excalidraw_element_embeddable__WEBPACK_IMPORTED_MODULE_29__.getEmbedLink),\n/* harmony export */ getFontFamilies: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.getFontFamilies),\n/* harmony export */ getFontFamilyString: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.getFontFamilyString),\n/* harmony export */ getFontMetrics: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.getFontMetrics),\n/* harmony export */ getFontString: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.getFontString),\n/* harmony export */ getFormFactor: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.getFormFactor),\n/* harmony export */ getFreeDrawSvgPath: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getFreeDrawSvgPath),\n/* harmony export */ getLibraryItemsHash: () => (/* reexport safe */ _data_library__WEBPACK_IMPORTED_MODULE_28__.getLibraryItemsHash),\n/* harmony export */ getLineHeight: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.getLineHeight),\n/* harmony export */ getMaximumGroups: () => (/* reexport safe */ _excalidraw_element_groups__WEBPACK_IMPORTED_MODULE_19__.getMaximumGroups),\n/* harmony export */ getNonDeletedElements: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getNonDeletedElements),\n/* harmony export */ getSceneVersion: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getSceneVersion),\n/* harmony export */ getSharedMermaidInstance: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.getSharedMermaidInstance),\n/* harmony export */ getTextFromElements: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getTextFromElements),\n/* harmony export */ getVisibleSceneBounds: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.getVisibleSceneBounds),\n/* harmony export */ hashElementsVersion: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.hashElementsVersion),\n/* harmony export */ hashString: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.hashString),\n/* harmony export */ intersectElementWithLine: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.intersectElementWithLine),\n/* harmony export */ isElementInsideBBox: () => (/* reexport safe */ _excalidraw_utils_withinBounds__WEBPACK_IMPORTED_MODULE_39__.isElementInsideBBox),\n/* harmony export */ isElementLink: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.isElementLink),\n/* harmony export */ isInvisiblySmallElement: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.isInvisiblySmallElement),\n/* harmony export */ isLinearElement: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.isLinearElement),\n/* harmony export */ languages: () => (/* reexport safe */ _i18n__WEBPACK_IMPORTED_MODULE_8__.languages),\n/* harmony export */ loadFromBlob: () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_27__.loadFromBlob),\n/* harmony export */ loadLibraryFromBlob: () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_27__.loadLibraryFromBlob),\n/* harmony export */ loadMermaid: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.loadMermaid),\n/* harmony export */ loadSceneFonts: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.loadSceneFonts),\n/* harmony export */ loadSceneOrLibraryFromBlob: () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_27__.loadSceneOrLibraryFromBlob),\n/* harmony export */ measureText: () => (/* reexport safe */ _excalidraw_element_textMeasurements__WEBPACK_IMPORTED_MODULE_20__.measureText),\n/* harmony export */ mergeLibraryItems: () => (/* reexport safe */ _data_library__WEBPACK_IMPORTED_MODULE_28__.mergeLibraryItems),\n/* harmony export */ mermaidToExcalidraw: () => (/* reexport safe */ _components_TTDDialog_MermaidToExcalidrawLib__WEBPACK_IMPORTED_MODULE_23__.mermaidToExcalidraw),\n/* harmony export */ mutateElement: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.mutateElement),\n/* harmony export */ newElementWith: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.newElementWith),\n/* harmony export */ normalizeLink: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.normalizeLink),\n/* harmony export */ parseLibraryTokensFromUrl: () => (/* reexport safe */ _data_library__WEBPACK_IMPORTED_MODULE_28__.parseLibraryTokensFromUrl),\n/* harmony export */ reconcileElements: () => (/* reexport safe */ _data_reconcile__WEBPACK_IMPORTED_MODULE_16__.reconcileElements),\n/* harmony export */ refreshTextDimensions: () => (/* reexport safe */ _excalidraw_element_newElement__WEBPACK_IMPORTED_MODULE_25__.refreshTextDimensions),\n/* harmony export */ registerFontsInCSS: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.registerFontsInCSS),\n/* harmony export */ registerLocalFont: () => (/* reexport safe */ _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__.registerLocalFont),\n/* harmony export */ restore: () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_15__.restore),\n/* harmony export */ restoreAppState: () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_15__.restoreAppState),\n/* harmony export */ restoreElement: () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_15__.restoreElement),\n/* harmony export */ restoreElements: () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_15__.restoreElements),\n/* harmony export */ restoreLibraryItems: () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_15__.restoreLibraryItems),\n/* harmony export */ safelyParseJSON: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.safelyParseJSON),\n/* harmony export */ sceneCoordsToViewportCoords: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.sceneCoordsToViewportCoords),\n/* harmony export */ serializeAsJSON: () => (/* reexport safe */ _data_json__WEBPACK_IMPORTED_MODULE_26__.serializeAsJSON),\n/* harmony export */ serializeLibraryAsJSON: () => (/* reexport safe */ _data_json__WEBPACK_IMPORTED_MODULE_26__.serializeLibraryAsJSON),\n/* harmony export */ setCustomTextMetricsProvider: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.setCustomTextMetricsProvider),\n/* harmony export */ syncInvalidIndices: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.syncInvalidIndices),\n/* harmony export */ syncMovedIndices: () => (/* reexport safe */ _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__.syncMovedIndices),\n/* harmony export */ useEditorInterface: () => (/* reexport safe */ _components_App__WEBPACK_IMPORTED_MODULE_2__.useEditorInterface),\n/* harmony export */ useHandleLibrary: () => (/* reexport safe */ _data_library__WEBPACK_IMPORTED_MODULE_28__.useHandleLibrary),\n/* harmony export */ useI18n: () => (/* reexport safe */ _i18n__WEBPACK_IMPORTED_MODULE_8__.useI18n),\n/* harmony export */ useStylesPanelMode: () => (/* reexport safe */ _components_App__WEBPACK_IMPORTED_MODULE_2__.useStylesPanelMode),\n/* harmony export */ viewportCoordsToSceneCoords: () => (/* reexport safe */ _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.viewportCoordsToSceneCoords),\n/* harmony export */ wrapText: () => (/* reexport safe */ _excalidraw_element_textWrapping__WEBPACK_IMPORTED_MODULE_21__.wrapText),\n/* harmony export */ zoomToFitBounds: () => (/* reexport safe */ _actions_actionCanvas__WEBPACK_IMPORTED_MODULE_37__.zoomToFitBounds)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n/* harmony import */ var _components_App__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./components/App */ \"./components/App.tsx\");\n/* harmony import */ var _components_InitializeApp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./components/InitializeApp */ \"./components/InitializeApp.tsx\");\n/* harmony import */ var _components_footer_FooterCenter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./components/footer/FooterCenter */ \"./components/footer/FooterCenter.tsx\");\n/* harmony import */ var _components_live_collaboration_LiveCollaborationTrigger__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./components/live-collaboration/LiveCollaborationTrigger */ \"./components/live-collaboration/LiveCollaborationTrigger.tsx\");\n/* harmony import */ var _components_main_menu_MainMenu__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./components/main-menu/MainMenu */ \"./components/main-menu/MainMenu.tsx\");\n/* harmony import */ var _components_welcome_screen_WelcomeScreen__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./components/welcome-screen/WelcomeScreen */ \"./components/welcome-screen/WelcomeScreen.tsx\");\n/* harmony import */ var _i18n__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./i18n */ \"./i18n.ts\");\n/* harmony import */ var _editor_jotai__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./editor-jotai */ \"./editor-jotai.ts\");\n/* harmony import */ var _polyfill__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./polyfill */ \"./polyfill.ts\");\n/* harmony import */ var _css_app_scss__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./css/app.scss */ \"./css/app.scss\");\n/* harmony import */ var _css_styles_scss__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./css/styles.scss */ \"./css/styles.scss\");\n/* harmony import */ var _fonts_fonts_css__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./fonts/fonts.css */ \"./fonts/fonts.css\");\n/* harmony import */ var _excalidraw_element__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! @excalidraw/element */ \"../element/src/index.ts\");\n/* harmony import */ var _data_restore__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ./data/restore */ \"./data/restore.ts\");\n/* harmony import */ var _data_reconcile__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! ./data/reconcile */ \"./data/reconcile.ts\");\n/* harmony import */ var _excalidraw_utils_export__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(/*! @excalidraw/utils/export */ \"../utils/src/export.ts\");\n/* harmony import */ var _excalidraw_element_bounds__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(/*! @excalidraw/element/bounds */ \"../element/src/bounds.ts\");\n/* harmony import */ var _excalidraw_element_groups__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(/*! @excalidraw/element/groups */ \"../element/src/groups.ts\");\n/* harmony import */ var _excalidraw_element_textMeasurements__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(/*! @excalidraw/element/textMeasurements */ \"../element/src/textMeasurements.ts\");\n/* harmony import */ var _excalidraw_element_textWrapping__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(/*! @excalidraw/element/textWrapping */ \"../element/src/textWrapping.ts\");\n/* harmony import */ var _excalidraw_element_textElement__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(/*! @excalidraw/element/textElement */ \"../element/src/textElement.ts\");\n/* harmony import */ var _components_TTDDialog_MermaidToExcalidrawLib__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(/*! ./components/TTDDialog/MermaidToExcalidrawLib */ \"./components/TTDDialog/MermaidToExcalidrawLib.ts\");\n/* harmony import */ var _excalidraw_obsidianUtils__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(/*! ../excalidraw/obsidianUtils */ \"./obsidianUtils.ts\");\n/* harmony import */ var _excalidraw_element_newElement__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(/*! @excalidraw/element/newElement */ \"../element/src/newElement.ts\");\n/* harmony import */ var _data_json__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(/*! ./data/json */ \"./data/json.ts\");\n/* harmony import */ var _data_blob__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(/*! ./data/blob */ \"./data/blob.ts\");\n/* harmony import */ var _data_library__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(/*! ./data/library */ \"./data/library.ts\");\n/* harmony import */ var _excalidraw_element_embeddable__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(/*! @excalidraw/element/embeddable */ \"../element/src/embeddable.ts\");\n/* harmony import */ var _components_Sidebar_Sidebar__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(/*! ./components/Sidebar/Sidebar */ \"./components/Sidebar/Sidebar.tsx\");\n/* harmony import */ var _components_Button__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(/*! ./components/Button */ \"./components/Button.tsx\");\n/* harmony import */ var _components_Ellipsify__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(/*! ./components/Ellipsify */ \"./components/Ellipsify.tsx\");\n/* harmony import */ var _components_Stats__WEBPACK_IMPORTED_MODULE_33__ = __webpack_require__(/*! ./components/Stats */ \"./components/Stats/index.tsx\");\n/* harmony import */ var _components_DefaultSidebar__WEBPACK_IMPORTED_MODULE_34__ = __webpack_require__(/*! ./components/DefaultSidebar */ \"./components/DefaultSidebar.tsx\");\n/* harmony import */ var _components_TTDDialog_TTDDialog__WEBPACK_IMPORTED_MODULE_35__ = __webpack_require__(/*! ./components/TTDDialog/TTDDialog */ \"./components/TTDDialog/TTDDialog.tsx\");\n/* harmony import */ var _components_TTDDialog_TTDDialogTrigger__WEBPACK_IMPORTED_MODULE_36__ = __webpack_require__(/*! ./components/TTDDialog/TTDDialogTrigger */ \"./components/TTDDialog/TTDDialogTrigger.tsx\");\n/* harmony import */ var _actions_actionCanvas__WEBPACK_IMPORTED_MODULE_37__ = __webpack_require__(/*! ./actions/actionCanvas */ \"./actions/actionCanvas.tsx\");\n/* harmony import */ var _data_transform__WEBPACK_IMPORTED_MODULE_38__ = __webpack_require__(/*! ./data/transform */ \"./data/transform.ts\");\n/* harmony import */ var _excalidraw_utils_withinBounds__WEBPACK_IMPORTED_MODULE_39__ = __webpack_require__(/*! @excalidraw/utils/withinBounds */ \"../utils/src/withinBounds.ts\");\n/* harmony import */ var _components_DiagramToCodePlugin_DiagramToCodePlugin__WEBPACK_IMPORTED_MODULE_40__ = __webpack_require__(/*! ./components/DiagramToCodePlugin/DiagramToCodePlugin */ \"./components/DiagramToCodePlugin/DiagramToCodePlugin.tsx\");\nvar __rest = undefined && undefined.__rest || function (s, e) {\n var t = {};\n\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n};\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n(0,_polyfill__WEBPACK_IMPORTED_MODULE_10__[\"default\"])();\n\nconst ExcalidrawBase = props => {\n var _a, _b, _c, _d, _e, _f;\n\n const {\n onChange,\n onIncrement,\n initialData,\n excalidrawAPI,\n isCollaborating = false,\n onPointerUpdate,\n renderTopLeftUI,\n renderTopRightUI,\n langCode = _i18n__WEBPACK_IMPORTED_MODULE_8__.defaultLang.code,\n viewModeEnabled,\n zenModeEnabled,\n gridModeEnabled,\n initState,\n //zsviczian\n libraryReturnUrl,\n theme,\n name,\n renderCustomStats,\n onPaste,\n onDrop,\n //zsviczian\n detectScroll = true,\n handleKeyboardGlobally = false,\n onLibraryChange,\n autoFocus = false,\n onBeforeTextEdit,\n //zsviczian\n onBeforeTextSubmit,\n //zsviczian\n generateIdForFile,\n onThemeChange,\n //zsviczian\n onLinkOpen,\n onLinkHover,\n //zsviczian\n onViewModeChange,\n //zsviczian\n generateLinkForSelection,\n onPointerDown,\n onPointerUp,\n onScrollChange,\n onDuplicate,\n children,\n validateEmbeddable,\n renderEmbeddable,\n renderWebview,\n //zsviczian\n renderEmbeddableMenu,\n //zsviczian\n renderMermaid,\n //zsviczian\n onContextMenu,\n //zsviczian\n aiEnabled,\n showDeprecatedFonts,\n insertLinkAction,\n //zsviczian\n renderScrollbars\n } = props;\n const canvasActions = (_a = props.UIOptions) === null || _a === void 0 ? void 0 : _a.canvasActions; // FIXME normalize/set defaults in parent component so that the memo resolver\n // compares the same values\n\n const UIOptions = Object.assign(Object.assign({}, props.UIOptions), {\n canvasActions: Object.assign(Object.assign({}, _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_UI_OPTIONS.canvasActions), canvasActions),\n tools: {\n image: (_d = (_c = (_b = props.UIOptions) === null || _b === void 0 ? void 0 : _b.tools) === null || _c === void 0 ? void 0 : _c.image) !== null && _d !== void 0 ? _d : true\n }\n });\n\n if (canvasActions === null || canvasActions === void 0 ? void 0 : canvasActions.export) {\n UIOptions.canvasActions.export.saveFileToDisk = (_f = (_e = canvasActions.export) === null || _e === void 0 ? void 0 : _e.saveFileToDisk) !== null && _f !== void 0 ? _f : _excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.DEFAULT_UI_OPTIONS.canvasActions.export.saveFileToDisk;\n }\n\n if (UIOptions.canvasActions.toggleTheme === null && typeof theme === \"undefined\") {\n UIOptions.canvasActions.toggleTheme = true;\n }\n\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {\n const importPolyfill = async () => {\n //@ts-ignore\n await Promise.resolve(/*! import() */).then(__webpack_require__.t.bind(__webpack_require__, /*! canvas-roundrect-polyfill */ \"../../node_modules/canvas-roundrect-polyfill/roundRect.js\", 23));\n };\n\n importPolyfill(); // Block pinch-zooming on iOS outside of the content area\n\n const handleTouchMove = event => {\n // @ts-ignore\n if (typeof event.scale === \"number\" && event.scale !== 1) {\n event.preventDefault();\n }\n };\n\n document.addEventListener(\"touchmove\", handleTouchMove, {\n passive: false\n });\n return () => {\n document.removeEventListener(\"touchmove\", handleTouchMove);\n };\n }, []);\n return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_editor_jotai__WEBPACK_IMPORTED_MODULE_9__.EditorJotaiProvider, {\n store: _editor_jotai__WEBPACK_IMPORTED_MODULE_9__.editorJotaiStore\n }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_components_InitializeApp__WEBPACK_IMPORTED_MODULE_3__.InitializeApp, {\n langCode: langCode,\n theme: theme\n }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_components_App__WEBPACK_IMPORTED_MODULE_2__[\"default\"], {\n onChange: onChange,\n onIncrement: onIncrement,\n initialData: initialData,\n excalidrawAPI: excalidrawAPI,\n isCollaborating: isCollaborating,\n onPointerUpdate: onPointerUpdate,\n renderTopLeftUI: renderTopLeftUI,\n renderTopRightUI: renderTopRightUI,\n langCode: langCode,\n viewModeEnabled: viewModeEnabled,\n zenModeEnabled: zenModeEnabled,\n gridModeEnabled: gridModeEnabled,\n initState: initState,\n libraryReturnUrl: libraryReturnUrl,\n theme: theme,\n name: name,\n renderCustomStats: renderCustomStats,\n UIOptions: UIOptions,\n onPaste: onPaste,\n onDrop: onDrop,\n detectScroll: detectScroll,\n handleKeyboardGlobally: handleKeyboardGlobally,\n onLibraryChange: onLibraryChange,\n autoFocus: autoFocus,\n onBeforeTextEdit: onBeforeTextEdit,\n onBeforeTextSubmit: onBeforeTextSubmit,\n generateIdForFile: generateIdForFile,\n onThemeChange: onThemeChange,\n onLinkOpen: onLinkOpen,\n onLinkHover: onLinkHover,\n onViewModeChange: onViewModeChange,\n generateLinkForSelection: generateLinkForSelection,\n onPointerDown: onPointerDown,\n onPointerUp: onPointerUp,\n onScrollChange: onScrollChange,\n onDuplicate: onDuplicate,\n validateEmbeddable: validateEmbeddable,\n renderEmbeddable: renderEmbeddable,\n renderWebview: renderWebview,\n renderEmbeddableMenu: renderEmbeddableMenu,\n renderMermaid: renderMermaid,\n onContextMenu: onContextMenu,\n aiEnabled: aiEnabled !== false,\n showDeprecatedFonts: showDeprecatedFonts,\n insertLinkAction: insertLinkAction,\n renderScrollbars: renderScrollbars\n }, children)));\n};\n\nconst areEqual = (prevProps, nextProps) => {\n // short-circuit early\n if (prevProps.children !== nextProps.children) {\n return false;\n }\n\n const {\n initialData: prevInitialData,\n UIOptions: prevUIOptions = {}\n } = prevProps,\n prev = __rest(prevProps, [\"initialData\", \"UIOptions\"]);\n\n const {\n initialData: nextInitialData,\n UIOptions: nextUIOptions = {}\n } = nextProps,\n next = __rest(nextProps, [\"initialData\", \"UIOptions\"]); // comparing UIOptions\n\n\n const prevUIOptionsKeys = Object.keys(prevUIOptions);\n const nextUIOptionsKeys = Object.keys(nextUIOptions);\n\n if (prevUIOptionsKeys.length !== nextUIOptionsKeys.length) {\n return false;\n }\n\n const isUIOptionsSame = prevUIOptionsKeys.every(key => {\n if (key === \"canvasActions\") {\n const canvasOptionKeys = Object.keys(prevUIOptions.canvasActions);\n return canvasOptionKeys.every(key => {\n var _a, _b, _c, _d;\n\n if (key === \"export\" && ((_a = prevUIOptions === null || prevUIOptions === void 0 ? void 0 : prevUIOptions.canvasActions) === null || _a === void 0 ? void 0 : _a.export) && ((_b = nextUIOptions === null || nextUIOptions === void 0 ? void 0 : nextUIOptions.canvasActions) === null || _b === void 0 ? void 0 : _b.export)) {\n return prevUIOptions.canvasActions.export.saveFileToDisk === nextUIOptions.canvasActions.export.saveFileToDisk;\n }\n\n return ((_c = prevUIOptions === null || prevUIOptions === void 0 ? void 0 : prevUIOptions.canvasActions) === null || _c === void 0 ? void 0 : _c[key]) === ((_d = nextUIOptions === null || nextUIOptions === void 0 ? void 0 : nextUIOptions.canvasActions) === null || _d === void 0 ? void 0 : _d[key]);\n });\n }\n\n return prevUIOptions[key] === nextUIOptions[key];\n });\n return isUIOptionsSame && (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_1__.isShallowEqual)(prev, next);\n};\n\nconst Excalidraw = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().memo(ExcalidrawBase, areEqual);\nExcalidraw.displayName = \"Excalidraw\";\n\n\n\n\n\n\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n //zsviczian\n\n\n\n\n\n\n\n\n\n\n //zsviczian - not sure if I use it any more\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n//# sourceURL=webpack://ExcalidrawLib/./index.tsx?");
19970
19915
 
19971
19916
  /***/ }),
19972
19917
 
@@ -20702,7 +20647,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
20702
20647
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
20703
20648
 
20704
20649
  "use strict";
20705
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ allowDoubleTapEraser: () => (/* binding */ allowDoubleTapEraser),\n/* harmony export */ attachInlineLinkSuggester: () => (/* binding */ attachInlineLinkSuggester),\n/* harmony export */ disableDoubleClickTextEditing: () => (/* binding */ disableDoubleClickTextEditing),\n/* harmony export */ fetchFontFromVault: () => (/* binding */ fetchFontFromVault),\n/* harmony export */ getCSSFontDefinition: () => (/* binding */ getCSSFontDefinition),\n/* harmony export */ getExcalidrawContentEl: () => (/* binding */ getExcalidrawContentEl),\n/* harmony export */ getFontFamilies: () => (/* binding */ getFontFamilies),\n/* harmony export */ getFontMetrics: () => (/* binding */ getFontMetrics),\n/* harmony export */ getMaxZoom: () => (/* binding */ getMaxZoom),\n/* harmony export */ getOpenAIDefaultVisionModel: () => (/* binding */ getOpenAIDefaultVisionModel),\n/* harmony export */ getSharedMermaidInstance: () => (/* binding */ getSharedMermaidInstance),\n/* harmony export */ getZoomMax: () => (/* binding */ getZoomMax),\n/* harmony export */ getZoomMin: () => (/* binding */ getZoomMin),\n/* harmony export */ getZoomStep: () => (/* binding */ getZoomStep),\n/* harmony export */ hideFreedrawPenmodeCursor: () => (/* binding */ hideFreedrawPenmodeCursor),\n/* harmony export */ intersectElementWithLine: () => (/* binding */ intersectElementWithLine),\n/* harmony export */ isContextMenuDisabled: () => (/* binding */ isContextMenuDisabled),\n/* harmony export */ isExcaliBrainView: () => (/* binding */ isExcaliBrainView),\n/* harmony export */ isFullPanelMode: () => (/* binding */ isFullPanelMode),\n/* harmony export */ isPanWithRightMouseEnabled: () => (/* binding */ isPanWithRightMouseEnabled),\n/* harmony export */ isTouchInPenMode: () => (/* binding */ isTouchInPenMode),\n/* harmony export */ loadMermaid: () => (/* binding */ loadMermaid),\n/* harmony export */ loadSceneFonts: () => (/* binding */ loadSceneFonts),\n/* harmony export */ refreshAllArrows: () => (/* binding */ refreshAllArrows),\n/* harmony export */ registerFontsInCSS: () => (/* binding */ registerFontsInCSS),\n/* harmony export */ registerLocalFont: () => (/* binding */ registerLocalFont),\n/* harmony export */ runAction: () => (/* binding */ runAction),\n/* harmony export */ shouldDisableZoom: () => (/* binding */ shouldDisableZoom),\n/* harmony export */ syncElementLinkWithText: () => (/* binding */ syncElementLinkWithText),\n/* harmony export */ t2: () => (/* binding */ t2)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n/* harmony import */ var _excalidraw_element_collision__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @excalidraw/element/collision */ \"../element/src/collision.ts\");\n/* harmony import */ var _excalidraw_math__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @excalidraw/math */ \"../math/src/index.ts\");\n/* harmony import */ var _excalidraw_element__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @excalidraw/element */ \"../element/src/index.ts\");\n/* harmony import */ var _excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @excalidraw/common/commonObsidianUtils */ \"../common/src/commonObsidianUtils.ts\");\n/* harmony import */ var _fonts__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./fonts */ \"./fonts/index.ts\");\n/* harmony import */ var _components_TTDDialog_MermaidToExcalidrawLib__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./components/TTDDialog/MermaidToExcalidrawLib */ \"./components/TTDDialog/MermaidToExcalidrawLib.ts\");\n\n\n\n\n\n\n\n\nfunction allowDoubleTapEraser() {\n return (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.penModeDoubleTapEraser;\n} //mfuria #329. Enable panning with right mouse button if host plugin setting allows\n\nfunction isPanWithRightMouseEnabled() {\n var _a;\n\n try {\n return !!((_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings) === null || _a === void 0 ? void 0 : _a.panWithRightMouseButton);\n } catch (e) {\n return false;\n }\n}\nfunction getMaxZoom() {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.zoomToFitMaxLevel) !== null && _a !== void 0 ? _a : 1;\n}\nfunction isExcaliBrainView() {\n const excalidrawView = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().activeExcalidrawView;\n\n if (!excalidrawView) {\n return false;\n }\n\n return excalidrawView.linksAlwaysOpenInANewPane && excalidrawView.allowFrameButtonsInViewMode;\n}\nfunction getExcalidrawContentEl() {\n const excalidrawView = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().activeExcalidrawView;\n\n if (!excalidrawView) {\n return document.body;\n }\n\n return excalidrawView.contentEl;\n}\nfunction hideFreedrawPenmodeCursor() {\n return !(0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.penModeCrosshairVisible;\n}\nfunction getOpenAIDefaultVisionModel() {\n return (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.openAIDefaultVisionModel;\n}\nfunction getFontMetrics(fontFamily, fontSize = 20) {\n var _a, _b; // Get the font metadata, fallback to Excalifont if not found\n\n\n const metadata = (_a = _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_METADATA[fontFamily]) !== null && _a !== void 0 ? _a : _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_METADATA[_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_FAMILY.Excalifont];\n const {\n unitsPerEm,\n ascender,\n descender,\n lineHeight\n } = metadata.metrics; // Calculate baseline offset using the existing utility function\n\n const lineHeightPx = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.getLineHeightInPx)(fontSize, lineHeight);\n const baseline = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.getVerticalOffset)(fontFamily, fontSize, lineHeightPx); // Get the font string from registered fonts or use font family name as fallback\n\n let fontString = \"\";\n const fontFaces = _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.registered.get(fontFamily);\n\n if (fontFaces && fontFaces.fontFaces.length > 0) {\n fontString = fontFaces.fontFaces[0].fontFace.family;\n } else {\n // Fallback to font family enum name\n const fontFamilyName = (_b = Object.entries(_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_FAMILY).find(([_, value]) => value === fontFamily)) === null || _b === void 0 ? void 0 : _b[0];\n fontString = fontFamilyName || \"Excalifont\";\n }\n\n return {\n unitsPerEm,\n ascender,\n descender,\n lineHeight,\n baseline,\n fontString\n };\n}\nfunction registerLocalFont(fontMetrics, uri) {\n _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_METADATA[_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_FAMILY[\"Local Font\"]] = {\n metrics: fontMetrics.metrics\n };\n _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.register(\"Local Font\", fontMetrics, {\n uri\n });\n}\nfunction getFontFamilies() {\n const fontFamilies = new Set();\n\n for (const fontFaces of _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.registered.values()) {\n if (fontFaces.metadata.local) {\n continue;\n }\n\n for (const font of fontFaces.fontFaces) {\n if (font.fontFace.family === \"Local Font\") {\n continue;\n }\n\n fontFamilies.add(font.fontFace.family);\n }\n }\n\n return Array.from(fontFamilies);\n}\nasync function registerFontsInCSS() {\n const styleId = \"ExcalidrawFonts\";\n let styleElement = document.getElementById(styleId);\n\n if (!styleElement) {\n styleElement = document.createElement(\"style\");\n styleElement.id = styleId;\n document.head.appendChild(styleElement);\n } else {\n styleElement.textContent = \"\";\n }\n\n let cssContent = \"\";\n\n for (const fontFaces of _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.registered.values()) {\n if (fontFaces.metadata.local) {\n continue;\n }\n\n for (const font of fontFaces.fontFaces) {\n try {\n const content = await font.getContentLegacy();\n cssContent += `@font-face {font-family: ${font.fontFace.family}; src: url(${content});}\\n`;\n } catch (e) {\n console.error(`Skipped inlining font \"${font.toString()}\"`, e);\n }\n }\n }\n\n styleElement.textContent = cssContent;\n}\nasync function getCSSFontDefinition(fontFamily) {\n var _a;\n\n const fontFaces = (_a = _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.registered.get(fontFamily)) === null || _a === void 0 ? void 0 : _a.fontFaces;\n\n if (!fontFaces) {\n return \"\";\n }\n\n const fontFace = fontFaces[0];\n\n if (!fontFace) {\n return \"\";\n }\n\n const content = await fontFace.getContentLegacy();\n return `@font-face {font-family: ${fontFaces[0].fontFace.family}; src: url(${content});}`;\n}\nasync function loadSceneFonts(elements) {\n return await _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.loadElementsFonts(elements);\n}\nasync function fetchFontFromVault(url) {\n url = typeof url === \"string\" ? url : url.toString();\n\n if (typeof url === \"string\" && !url.startsWith(\"data\") && url.endsWith(\".woff2\")) {\n const filename = decodeURIComponent(url.substring(url.lastIndexOf(\"/\") + 1));\n const arrayBuffer = await (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().loadFontFromFile(filename);\n\n if (arrayBuffer) {\n return arrayBuffer;\n }\n }\n} //zsviczian (single finger panning in pen mode)\n\nfunction isTouchInPenMode(appState, event) {\n if (!(0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.penModeSingleFingerPanning) {\n return false;\n } //isReactPointerEvent typecheck is here only to please typescript, else event.pointerType === \"touch\" should be enough\n\n\n const isReactPointerEvent = (\"nativeEvent\" in event);\n return appState.penMode && (!isReactPointerEvent || event.pointerType === \"touch\") && ![\"text\"].includes(appState.activeTool.type);\n}\nasync function getSharedMermaidInstance() {\n return await (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().getMermaid();\n}\nasync function loadMermaid() {\n return await (0,_components_TTDDialog_MermaidToExcalidrawLib__WEBPACK_IMPORTED_MODULE_6__.loadMermaidLib)();\n} //moved here as part of https://github.com/zsviczian/excalidraw/pull/286\n\nconst intersectElementWithLine = (element, // Point on the line, in absolute coordinates\na, // Another point on the line, in absolute coordinates\nb, // If given, the element is inflated by this value\ngap = 0, elementsMap) => {\n return (0,_excalidraw_element_collision__WEBPACK_IMPORTED_MODULE_1__.intersectElementWithLineSegment)(element, elementsMap, (0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_2__.lineSegment)(a, b), gap);\n}; //disable double click\n\nconst disableDoubleClickTextEditing = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.disableDoubleClickTextEditing) !== null && _a !== void 0 ? _a : false;\n}; // zoomStep: number; // % increment per zoom action (e.g. mouse wheel)\n// zoomMin: number; // minimum zoom percentage\n// zoomMax: number; // maximum zoom percentage\n\nconst getZoomStep = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.zoomStep) !== null && _a !== void 0 ? _a : _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.ZOOM_STEP;\n};\nconst getZoomMin = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.zoomMin) !== null && _a !== void 0 ? _a : _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.MIN_ZOOM;\n};\nconst getZoomMax = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.zoomMax) !== null && _a !== void 0 ? _a : _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.MAX_ZOOM;\n};\nconst runAction = action => {\n var _a;\n\n (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)()) === null || _a === void 0 ? void 0 : _a.runAction(action);\n};\nconst t2 = key => {\n var _a, _b;\n\n return (_b = (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)()) === null || _a === void 0 ? void 0 : _a.getLabel(key)) !== null && _b !== void 0 ? _b : key;\n};\nconst shouldDisableZoom = appState => {\n var _a, _b, _c;\n\n if (((_a = appState.activeEmbeddable) === null || _a === void 0 ? void 0 : _a.state) !== \"active\") {\n return false;\n }\n\n if (!((_b = appState.activeEmbeddable) === null || _b === void 0 ? void 0 : _b.element)) {\n return false;\n }\n\n if ((_c = appState.activeEmbeddable.element.link) === null || _c === void 0 ? void 0 : _c.match(/\\.pdf(#[^\\]]+)?]]/i)) {\n return true;\n }\n\n return false;\n};\nconst isFullPanelMode = app => {\n const stylesPanelMode = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.deriveStylesPanelMode)(app.editorInterface);\n return stylesPanelMode === \"full\" || stylesPanelMode === \"tray\";\n};\nconst isContextMenuDisabled = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.disableContextMenu) !== null && _a !== void 0 ? _a : false;\n};\nconst refreshAllArrows = (scene, store) => {\n const elements = scene.getNonDeletedElements();\n const elementsMap = scene.getNonDeletedElementsMap();\n let didMutate = false;\n\n for (const el of elements) {\n if (!(0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.isArrowElement)(el)) {\n continue;\n }\n\n const startTargetRaw = el.startBinding && elementsMap.get(el.startBinding.elementId);\n const endTargetRaw = el.endBinding && elementsMap.get(el.endBinding.elementId);\n const startTarget = startTargetRaw && (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.isBindableElement)(startTargetRaw) ? startTargetRaw : undefined;\n const endTarget = endTargetRaw && (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.isBindableElement)(endTargetRaw) ? endTargetRaw : undefined;\n\n if (!startTarget && !endTarget) {\n continue;\n }\n\n const draft = Object.assign({}, el);\n const pointUpdates = new Map();\n\n if (draft.startBinding && startTarget) {\n const point = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.updateBoundPoint)(draft, \"startBinding\", draft.startBinding, startTarget, elementsMap);\n\n if (point) {\n pointUpdates.set(0, {\n point\n });\n }\n }\n\n if (draft.endBinding && endTarget) {\n const point = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.updateBoundPoint)(draft, \"endBinding\", draft.endBinding, endTarget, elementsMap);\n\n if (point) {\n pointUpdates.set(draft.points.length - 1, {\n point\n });\n }\n }\n\n if (!pointUpdates.size) {\n continue;\n }\n\n const startBindingElement = el.startBinding ? elementsMap.get(el.startBinding.elementId) : null;\n const endBindingElement = el.endBinding ? (startBindingElement === null || startBindingElement === void 0 ? void 0 : startBindingElement.id) === el.endBinding.elementId ? startBindingElement : elementsMap.get(el.endBinding.elementId) : null;\n _excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.LinearElementEditor.movePoints(el, scene, pointUpdates, {\n moveMidPointsWithElement: !!startBindingElement && (startBindingElement === null || startBindingElement === void 0 ? void 0 : startBindingElement.id) === (endBindingElement === null || endBindingElement === void 0 ? void 0 : endBindingElement.id)\n });\n _excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.ShapeCache.delete(el);\n didMutate = true;\n }\n\n if (didMutate) {\n store.scheduleCapture();\n scene.triggerUpdate();\n }\n};\nconst attachInlineLinkSuggester = (inputEl, widthWrapper, container = null) => (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().attachInlineLinkSuggester(inputEl, widthWrapper, container);\nconst syncElementLinkWithText = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.syncElementLinkWithText) !== null && _a !== void 0 ? _a : true;\n};\n\n//# sourceURL=webpack://ExcalidrawLib/./obsidianUtils.ts?");
20650
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ allowDoubleTapEraser: () => (/* binding */ allowDoubleTapEraser),\n/* harmony export */ attachInlineLinkSuggester: () => (/* binding */ attachInlineLinkSuggester),\n/* harmony export */ disableDoubleClickTextEditing: () => (/* binding */ disableDoubleClickTextEditing),\n/* harmony export */ fetchFontFromVault: () => (/* binding */ fetchFontFromVault),\n/* harmony export */ getCSSFontDefinition: () => (/* binding */ getCSSFontDefinition),\n/* harmony export */ getDefaultColorPalette: () => (/* binding */ getDefaultColorPalette),\n/* harmony export */ getExcalidrawContentEl: () => (/* binding */ getExcalidrawContentEl),\n/* harmony export */ getFontFamilies: () => (/* binding */ getFontFamilies),\n/* harmony export */ getFontMetrics: () => (/* binding */ getFontMetrics),\n/* harmony export */ getMaxZoom: () => (/* binding */ getMaxZoom),\n/* harmony export */ getOpenAIDefaultVisionModel: () => (/* binding */ getOpenAIDefaultVisionModel),\n/* harmony export */ getSharedMermaidInstance: () => (/* binding */ getSharedMermaidInstance),\n/* harmony export */ getZoomMax: () => (/* binding */ getZoomMax),\n/* harmony export */ getZoomMin: () => (/* binding */ getZoomMin),\n/* harmony export */ getZoomStep: () => (/* binding */ getZoomStep),\n/* harmony export */ hideFreedrawPenmodeCursor: () => (/* binding */ hideFreedrawPenmodeCursor),\n/* harmony export */ intersectElementWithLine: () => (/* binding */ intersectElementWithLine),\n/* harmony export */ isContextMenuDisabled: () => (/* binding */ isContextMenuDisabled),\n/* harmony export */ isExcaliBrainView: () => (/* binding */ isExcaliBrainView),\n/* harmony export */ isFullPanelMode: () => (/* binding */ isFullPanelMode),\n/* harmony export */ isPanWithRightMouseEnabled: () => (/* binding */ isPanWithRightMouseEnabled),\n/* harmony export */ isTouchInPenMode: () => (/* binding */ isTouchInPenMode),\n/* harmony export */ loadMermaid: () => (/* binding */ loadMermaid),\n/* harmony export */ loadSceneFonts: () => (/* binding */ loadSceneFonts),\n/* harmony export */ refreshAllArrows: () => (/* binding */ refreshAllArrows),\n/* harmony export */ registerFontsInCSS: () => (/* binding */ registerFontsInCSS),\n/* harmony export */ registerLocalFont: () => (/* binding */ registerLocalFont),\n/* harmony export */ runAction: () => (/* binding */ runAction),\n/* harmony export */ shouldDisableZoom: () => (/* binding */ shouldDisableZoom),\n/* harmony export */ syncElementLinkWithText: () => (/* binding */ syncElementLinkWithText),\n/* harmony export */ t2: () => (/* binding */ t2)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n/* harmony import */ var _excalidraw_element_collision__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @excalidraw/element/collision */ \"../element/src/collision.ts\");\n/* harmony import */ var _excalidraw_math__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @excalidraw/math */ \"../math/src/index.ts\");\n/* harmony import */ var _excalidraw_element__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @excalidraw/element */ \"../element/src/index.ts\");\n/* harmony import */ var _excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @excalidraw/common/commonObsidianUtils */ \"../common/src/commonObsidianUtils.ts\");\n/* harmony import */ var _fonts__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./fonts */ \"./fonts/index.ts\");\n/* harmony import */ var _components_TTDDialog_MermaidToExcalidrawLib__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./components/TTDDialog/MermaidToExcalidrawLib */ \"./components/TTDDialog/MermaidToExcalidrawLib.ts\");\n\n\n\n\n\n\n\n\nfunction allowDoubleTapEraser() {\n return (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.penModeDoubleTapEraser;\n} //mfuria #329. Enable panning with right mouse button if host plugin setting allows\n\nfunction isPanWithRightMouseEnabled() {\n var _a;\n\n try {\n return !!((_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings) === null || _a === void 0 ? void 0 : _a.panWithRightMouseButton);\n } catch (e) {\n return false;\n }\n}\nfunction getMaxZoom() {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.zoomToFitMaxLevel) !== null && _a !== void 0 ? _a : 1;\n}\nfunction isExcaliBrainView() {\n const excalidrawView = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().activeExcalidrawView;\n\n if (!excalidrawView) {\n return false;\n }\n\n return excalidrawView.linksAlwaysOpenInANewPane && excalidrawView.allowFrameButtonsInViewMode;\n}\nfunction getExcalidrawContentEl() {\n const excalidrawView = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().activeExcalidrawView;\n\n if (!excalidrawView) {\n return document.body;\n }\n\n return excalidrawView.contentEl;\n}\nfunction hideFreedrawPenmodeCursor() {\n return !(0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.penModeCrosshairVisible;\n}\nfunction getOpenAIDefaultVisionModel() {\n return (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.openAIDefaultVisionModel;\n}\nfunction getFontMetrics(fontFamily, fontSize = 20) {\n var _a, _b; // Get the font metadata, fallback to Excalifont if not found\n\n\n const metadata = (_a = _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_METADATA[fontFamily]) !== null && _a !== void 0 ? _a : _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_METADATA[_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_FAMILY.Excalifont];\n const {\n unitsPerEm,\n ascender,\n descender,\n lineHeight\n } = metadata.metrics; // Calculate baseline offset using the existing utility function\n\n const lineHeightPx = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.getLineHeightInPx)(fontSize, lineHeight);\n const baseline = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.getVerticalOffset)(fontFamily, fontSize, lineHeightPx); // Get the font string from registered fonts or use font family name as fallback\n\n let fontString = \"\";\n const fontFaces = _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.registered.get(fontFamily);\n\n if (fontFaces && fontFaces.fontFaces.length > 0) {\n fontString = fontFaces.fontFaces[0].fontFace.family;\n } else {\n // Fallback to font family enum name\n const fontFamilyName = (_b = Object.entries(_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_FAMILY).find(([_, value]) => value === fontFamily)) === null || _b === void 0 ? void 0 : _b[0];\n fontString = fontFamilyName || \"Excalifont\";\n }\n\n return {\n unitsPerEm,\n ascender,\n descender,\n lineHeight,\n baseline,\n fontString\n };\n}\nfunction registerLocalFont(fontMetrics, uri) {\n _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_METADATA[_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.FONT_FAMILY[\"Local Font\"]] = {\n metrics: fontMetrics.metrics\n };\n _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.register(\"Local Font\", fontMetrics, {\n uri\n });\n}\nfunction getFontFamilies() {\n const fontFamilies = new Set();\n\n for (const fontFaces of _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.registered.values()) {\n if (fontFaces.metadata.local) {\n continue;\n }\n\n for (const font of fontFaces.fontFaces) {\n if (font.fontFace.family === \"Local Font\") {\n continue;\n }\n\n fontFamilies.add(font.fontFace.family);\n }\n }\n\n return Array.from(fontFamilies);\n}\nconst getDefaultColorPalette = () => {\n const isColorTuple = value => Array.isArray(value) && value.length === 5 && value.every(entry => typeof entry === \"string\");\n\n return Object.values(_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.DEFAULT_ELEMENT_STROKE_COLOR_PALETTE).filter(isColorTuple);\n};\nasync function registerFontsInCSS() {\n const styleId = \"ExcalidrawFonts\";\n let styleElement = document.getElementById(styleId);\n\n if (!styleElement) {\n styleElement = document.createElement(\"style\");\n styleElement.id = styleId;\n document.head.appendChild(styleElement);\n } else {\n styleElement.textContent = \"\";\n }\n\n let cssContent = \"\";\n\n for (const fontFaces of _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.registered.values()) {\n if (fontFaces.metadata.local) {\n continue;\n }\n\n for (const font of fontFaces.fontFaces) {\n try {\n const content = await font.getContentLegacy();\n cssContent += `@font-face {font-family: ${font.fontFace.family}; src: url(${content});}\\n`;\n } catch (e) {\n console.error(`Skipped inlining font \"${font.toString()}\"`, e);\n }\n }\n }\n\n styleElement.textContent = cssContent;\n}\nasync function getCSSFontDefinition(fontFamily) {\n var _a;\n\n const fontFaces = (_a = _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.registered.get(fontFamily)) === null || _a === void 0 ? void 0 : _a.fontFaces;\n\n if (!fontFaces) {\n return \"\";\n }\n\n const fontFace = fontFaces[0];\n\n if (!fontFace) {\n return \"\";\n }\n\n const content = await fontFace.getContentLegacy();\n return `@font-face {font-family: ${fontFaces[0].fontFace.family}; src: url(${content});}`;\n}\nasync function loadSceneFonts(elements) {\n return await _fonts__WEBPACK_IMPORTED_MODULE_5__.Fonts.loadElementsFonts(elements);\n}\nasync function fetchFontFromVault(url) {\n url = typeof url === \"string\" ? url : url.toString();\n\n if (typeof url === \"string\" && !url.startsWith(\"data\") && url.endsWith(\".woff2\")) {\n const filename = decodeURIComponent(url.substring(url.lastIndexOf(\"/\") + 1));\n const arrayBuffer = await (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().loadFontFromFile(filename);\n\n if (arrayBuffer) {\n return arrayBuffer;\n }\n }\n} //zsviczian (single finger panning in pen mode)\n\nfunction isTouchInPenMode(appState, event) {\n if (!(0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.penModeSingleFingerPanning) {\n return false;\n } //isReactPointerEvent typecheck is here only to please typescript, else event.pointerType === \"touch\" should be enough\n\n\n const isReactPointerEvent = (\"nativeEvent\" in event);\n return appState.penMode && (!isReactPointerEvent || event.pointerType === \"touch\") && ![\"text\"].includes(appState.activeTool.type);\n}\nasync function getSharedMermaidInstance() {\n return await (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().getMermaid();\n}\nasync function loadMermaid() {\n return await (0,_components_TTDDialog_MermaidToExcalidrawLib__WEBPACK_IMPORTED_MODULE_6__.loadMermaidLib)();\n} //moved here as part of https://github.com/zsviczian/excalidraw/pull/286\n\nconst intersectElementWithLine = (element, // Point on the line, in absolute coordinates\na, // Another point on the line, in absolute coordinates\nb, // If given, the element is inflated by this value\ngap = 0, elementsMap) => {\n return (0,_excalidraw_element_collision__WEBPACK_IMPORTED_MODULE_1__.intersectElementWithLineSegment)(element, elementsMap, (0,_excalidraw_math__WEBPACK_IMPORTED_MODULE_2__.lineSegment)(a, b), gap);\n}; //disable double click\n\nconst disableDoubleClickTextEditing = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.disableDoubleClickTextEditing) !== null && _a !== void 0 ? _a : false;\n}; // zoomStep: number; // % increment per zoom action (e.g. mouse wheel)\n// zoomMin: number; // minimum zoom percentage\n// zoomMax: number; // maximum zoom percentage\n\nconst getZoomStep = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.zoomStep) !== null && _a !== void 0 ? _a : _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.ZOOM_STEP;\n};\nconst getZoomMin = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.zoomMin) !== null && _a !== void 0 ? _a : _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.MIN_ZOOM;\n};\nconst getZoomMax = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.zoomMax) !== null && _a !== void 0 ? _a : _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.MAX_ZOOM;\n};\nconst runAction = action => {\n var _a;\n\n (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)()) === null || _a === void 0 ? void 0 : _a.runAction(action);\n};\nconst t2 = key => {\n var _a, _b;\n\n return (_b = (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)()) === null || _a === void 0 ? void 0 : _a.getLabel(key)) !== null && _b !== void 0 ? _b : key;\n};\nconst shouldDisableZoom = appState => {\n var _a, _b, _c;\n\n if (((_a = appState.activeEmbeddable) === null || _a === void 0 ? void 0 : _a.state) !== \"active\") {\n return false;\n }\n\n if (!((_b = appState.activeEmbeddable) === null || _b === void 0 ? void 0 : _b.element)) {\n return false;\n }\n\n if ((_c = appState.activeEmbeddable.element.link) === null || _c === void 0 ? void 0 : _c.match(/\\.pdf(#[^\\]]+)?]]/i)) {\n return true;\n }\n\n return false;\n};\nconst isFullPanelMode = app => {\n const stylesPanelMode = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.deriveStylesPanelMode)(app.editorInterface);\n return stylesPanelMode === \"full\" || stylesPanelMode === \"tray\";\n};\nconst isContextMenuDisabled = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.disableContextMenu) !== null && _a !== void 0 ? _a : false;\n};\nconst refreshAllArrows = (scene, store) => {\n const elements = scene.getNonDeletedElements();\n const elementsMap = scene.getNonDeletedElementsMap();\n let didMutate = false;\n\n for (const el of elements) {\n if (!(0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.isArrowElement)(el)) {\n continue;\n }\n\n const startTargetRaw = el.startBinding && elementsMap.get(el.startBinding.elementId);\n const endTargetRaw = el.endBinding && elementsMap.get(el.endBinding.elementId);\n const startTarget = startTargetRaw && (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.isBindableElement)(startTargetRaw) ? startTargetRaw : undefined;\n const endTarget = endTargetRaw && (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.isBindableElement)(endTargetRaw) ? endTargetRaw : undefined;\n\n if (!startTarget && !endTarget) {\n continue;\n }\n\n const draft = Object.assign({}, el);\n const pointUpdates = new Map();\n\n if (draft.startBinding && startTarget) {\n const point = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.updateBoundPoint)(draft, \"startBinding\", draft.startBinding, startTarget, elementsMap);\n\n if (point) {\n pointUpdates.set(0, {\n point\n });\n }\n }\n\n if (draft.endBinding && endTarget) {\n const point = (0,_excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.updateBoundPoint)(draft, \"endBinding\", draft.endBinding, endTarget, elementsMap);\n\n if (point) {\n pointUpdates.set(draft.points.length - 1, {\n point\n });\n }\n }\n\n if (!pointUpdates.size) {\n continue;\n }\n\n const startBindingElement = el.startBinding ? elementsMap.get(el.startBinding.elementId) : null;\n const endBindingElement = el.endBinding ? (startBindingElement === null || startBindingElement === void 0 ? void 0 : startBindingElement.id) === el.endBinding.elementId ? startBindingElement : elementsMap.get(el.endBinding.elementId) : null;\n _excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.LinearElementEditor.movePoints(el, scene, pointUpdates, {\n moveMidPointsWithElement: !!startBindingElement && (startBindingElement === null || startBindingElement === void 0 ? void 0 : startBindingElement.id) === (endBindingElement === null || endBindingElement === void 0 ? void 0 : endBindingElement.id)\n });\n _excalidraw_element__WEBPACK_IMPORTED_MODULE_3__.ShapeCache.delete(el);\n didMutate = true;\n }\n\n if (didMutate) {\n store.scheduleCapture();\n scene.triggerUpdate();\n }\n};\nconst attachInlineLinkSuggester = (inputEl, widthWrapper, container = null) => (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().attachInlineLinkSuggester(inputEl, widthWrapper, container);\nconst syncElementLinkWithText = () => {\n var _a;\n\n return (_a = (0,_excalidraw_common_commonObsidianUtils__WEBPACK_IMPORTED_MODULE_4__.getHostPlugin)().settings.syncElementLinkWithText) !== null && _a !== void 0 ? _a : true;\n};\n\n//# sourceURL=webpack://ExcalidrawLib/./obsidianUtils.ts?");
20706
20651
 
20707
20652
  /***/ }),
20708
20653
 
@@ -20724,7 +20669,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
20724
20669
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
20725
20670
 
20726
20671
  "use strict";
20727
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _excalidraw_common_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/common/constants */ \"../common/src/constants.ts\");\n\n\nif (\"development\" !== _excalidraw_common_constants__WEBPACK_IMPORTED_MODULE_0__.ENV.TEST) {\n /* eslint-disable */\n\n /* global __webpack_public_path__:writable */\n __webpack_require__.p = window.EXCALIDRAW_ASSET_PATH || `https://unpkg.com/${\"@zsviczian/excalidraw\"}@${\"0.18.0-64\"}/dist/`;\n}\n\n//# sourceURL=webpack://ExcalidrawLib/./publicPath.js?");
20672
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _excalidraw_common_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/common/constants */ \"../common/src/constants.ts\");\n\n\nif (\"development\" !== _excalidraw_common_constants__WEBPACK_IMPORTED_MODULE_0__.ENV.TEST) {\n /* eslint-disable */\n\n /* global __webpack_public_path__:writable */\n __webpack_require__.p = window.EXCALIDRAW_ASSET_PATH || `https://unpkg.com/${\"@zsviczian/excalidraw\"}@${\"0.18.0-66\"}/dist/`;\n}\n\n//# sourceURL=webpack://ExcalidrawLib/./publicPath.js?");
20728
20673
 
20729
20674
  /***/ }),
20730
20675
 
@@ -20988,7 +20933,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
20988
20933
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
20989
20934
 
20990
20935
  "use strict";
20991
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ WorkerUrl: () => (/* binding */ WorkerUrl)\n/* harmony export */ });\n/* harmony import */ var _subset_shared_chunk__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./subset-shared.chunk */ \"./subset/subset-shared.chunk.ts\");\n/**\n * DON'T depend on anything from the outside like `promiseTry`, as this module is part of a separate lazy-loaded chunk.\n *\n * Including anything from the main chunk would include the whole chunk by default.\n * Even it it would be tree-shaken during build, it won't be tree-shaken in dev.\n *\n * In the future consider separating common utils into a separate shared chunk.\n */\n\n/**\n * Due to this export (and related dynamic import), this worker code will be included in the bundle automatically (as a separate chunk),\n * without the need for esbuild / vite /rollup plugins and special browser / server treatment.\n *\n * `import.meta.url` is undefined in nodejs\n */\n\nconst WorkerUrl = true ? new URL(\"file:///C:/Users/Zsolt/GitHub/excalidraw-textEditEvents/packages/excalidraw/subset/subset-worker.chunk.ts\") : 0; // run only in the worker context\n\nif (typeof window === \"undefined\" && typeof self !== \"undefined\") {\n self.onmessage = async e => {\n switch (e.data.command) {\n case _subset_shared_chunk__WEBPACK_IMPORTED_MODULE_0__.Commands.Subset:\n const buffer = await (0,_subset_shared_chunk__WEBPACK_IMPORTED_MODULE_0__.subsetToBinary)(e.data.arrayBuffer, e.data.codePoints);\n self.postMessage(buffer, {\n transfer: [buffer]\n });\n break;\n }\n };\n}\n\n//# sourceURL=webpack://ExcalidrawLib/./subset/subset-worker.chunk.ts?");
20936
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ WorkerUrl: () => (/* binding */ WorkerUrl)\n/* harmony export */ });\n/* harmony import */ var _subset_shared_chunk__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./subset-shared.chunk */ \"./subset/subset-shared.chunk.ts\");\n/**\n * DON'T depend on anything from the outside like `promiseTry`, as this module is part of a separate lazy-loaded chunk.\n *\n * Including anything from the main chunk would include the whole chunk by default.\n * Even it it would be tree-shaken during build, it won't be tree-shaken in dev.\n *\n * In the future consider separating common utils into a separate shared chunk.\n */\n\n/**\n * Due to this export (and related dynamic import), this worker code will be included in the bundle automatically (as a separate chunk),\n * without the need for esbuild / vite /rollup plugins and special browser / server treatment.\n *\n * `import.meta.url` is undefined in nodejs\n */\n\nconst WorkerUrl = true ? new URL(\"file:///Users/zsviczian/GitHub/excalidraw/packages/excalidraw/subset/subset-worker.chunk.ts\") : 0; // run only in the worker context\n\nif (typeof window === \"undefined\" && typeof self !== \"undefined\") {\n self.onmessage = async e => {\n switch (e.data.command) {\n case _subset_shared_chunk__WEBPACK_IMPORTED_MODULE_0__.Commands.Subset:\n const buffer = await (0,_subset_shared_chunk__WEBPACK_IMPORTED_MODULE_0__.subsetToBinary)(e.data.arrayBuffer, e.data.codePoints);\n self.postMessage(buffer, {\n transfer: [buffer]\n });\n break;\n }\n };\n}\n\n//# sourceURL=webpack://ExcalidrawLib/./subset/subset-worker.chunk.ts?");
20992
20937
 
20993
20938
  /***/ }),
20994
20939
 
@@ -21042,7 +20987,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
21042
20987
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
21043
20988
 
21044
20989
  "use strict";
21045
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ WorkerPool: () => (/* binding */ WorkerPool)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./errors */ \"./errors.ts\");\n\n\n\nclass IdleWorker {\n constructor(workerUrl) {\n this.instance = new Worker(workerUrl, {\n type: \"module\"\n });\n }\n\n}\n/**\n * Pool of idle short-lived workers.\n *\n * IMPORTANT: for simplicity it does not limit the number of newly created workers, leaving it up to the caller to manage the pool size.\n */\n\n\nclass WorkerPool {\n constructor(workerUrl, options) {\n this.idleWorkers = new Set();\n this.workerUrl = workerUrl; // by default, active & idle workers will be terminated after 1s of inactivity\n\n this.workerTTL = options.ttl || 1000;\n }\n /**\n * Create a new worker pool.\n *\n * @param workerUrl - The URL of the worker file.\n * @param options - The options for the worker pool.\n * @throws If the worker is bundled into the main chunk.\n * @returns A new worker pool instance.\n */\n\n\n static create(workerUrl, options = {}) {\n if (!workerUrl) {\n throw new _errors__WEBPACK_IMPORTED_MODULE_1__.WorkerUrlNotDefinedError();\n }\n\n if ( false || workerUrl.toString() === \"file:///C:/Users/Zsolt/GitHub/excalidraw-textEditEvents/packages/excalidraw/workers.ts\") {\n // in case the worker code is bundled into the main chunk\n throw new _errors__WEBPACK_IMPORTED_MODULE_1__.WorkerInTheMainChunkError();\n }\n\n return new WorkerPool(workerUrl, options);\n }\n /**\n * Take idle worker from the pool or create a new one and post a message to it.\n */\n\n\n async postMessage(data, options) {\n let worker;\n const idleWorker = Array.from(this.idleWorkers).shift();\n\n if (idleWorker) {\n this.idleWorkers.delete(idleWorker);\n worker = idleWorker;\n } else {\n worker = await this.createWorker();\n }\n\n return new Promise((resolve, reject) => {\n worker.instance.onmessage = this.onMessageHandler(worker, resolve);\n worker.instance.onerror = this.onErrorHandler(worker, reject);\n worker.instance.postMessage(data, options);\n worker.debounceTerminate(() => reject(new Error(`Active worker did not respond for ${this.workerTTL}ms!`)));\n });\n }\n /**\n * Terminate the idle workers in the pool.\n */\n\n\n async clear() {\n for (const worker of this.idleWorkers) {\n worker.debounceTerminate.cancel();\n worker.instance.terminate();\n }\n\n this.idleWorkers.clear();\n }\n /**\n * Used to get a worker from the pool or create a new one if there is no idle available.\n */\n\n\n async createWorker() {\n const worker = new IdleWorker(this.workerUrl);\n worker.debounceTerminate = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.debounce)(reject => {\n worker.instance.terminate();\n\n if (this.idleWorkers.has(worker)) {\n this.idleWorkers.delete(worker); // eslint-disable-next-line no-console\n\n console.debug(\"Job finished! Idle worker has been released from the pool.\");\n } else if (reject) {\n reject();\n } else {\n console.error(\"Worker has been terminated!\");\n }\n }, this.workerTTL);\n return worker;\n }\n\n onMessageHandler(worker, resolve) {\n return e => {\n worker.debounceTerminate();\n this.idleWorkers.add(worker);\n resolve(e.data);\n };\n }\n\n onErrorHandler(worker, reject) {\n return e => {\n // terminate the worker immediately before rejection\n worker.debounceTerminate(() => reject(e));\n worker.debounceTerminate.flush(); // clear the worker pool in case there are some idle workers left\n\n this.clear();\n };\n }\n\n}\n\n//# sourceURL=webpack://ExcalidrawLib/./workers.ts?");
20990
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ WorkerPool: () => (/* binding */ WorkerPool)\n/* harmony export */ });\n/* harmony import */ var _excalidraw_common__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @excalidraw/common */ \"../common/src/index.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./errors */ \"./errors.ts\");\n\n\n\nclass IdleWorker {\n constructor(workerUrl) {\n this.instance = new Worker(workerUrl, {\n type: \"module\"\n });\n }\n\n}\n/**\n * Pool of idle short-lived workers.\n *\n * IMPORTANT: for simplicity it does not limit the number of newly created workers, leaving it up to the caller to manage the pool size.\n */\n\n\nclass WorkerPool {\n constructor(workerUrl, options) {\n this.idleWorkers = new Set();\n this.workerUrl = workerUrl; // by default, active & idle workers will be terminated after 1s of inactivity\n\n this.workerTTL = options.ttl || 1000;\n }\n /**\n * Create a new worker pool.\n *\n * @param workerUrl - The URL of the worker file.\n * @param options - The options for the worker pool.\n * @throws If the worker is bundled into the main chunk.\n * @returns A new worker pool instance.\n */\n\n\n static create(workerUrl, options = {}) {\n if (!workerUrl) {\n throw new _errors__WEBPACK_IMPORTED_MODULE_1__.WorkerUrlNotDefinedError();\n }\n\n if ( false || workerUrl.toString() === \"file:///Users/zsviczian/GitHub/excalidraw/packages/excalidraw/workers.ts\") {\n // in case the worker code is bundled into the main chunk\n throw new _errors__WEBPACK_IMPORTED_MODULE_1__.WorkerInTheMainChunkError();\n }\n\n return new WorkerPool(workerUrl, options);\n }\n /**\n * Take idle worker from the pool or create a new one and post a message to it.\n */\n\n\n async postMessage(data, options) {\n let worker;\n const idleWorker = Array.from(this.idleWorkers).shift();\n\n if (idleWorker) {\n this.idleWorkers.delete(idleWorker);\n worker = idleWorker;\n } else {\n worker = await this.createWorker();\n }\n\n return new Promise((resolve, reject) => {\n worker.instance.onmessage = this.onMessageHandler(worker, resolve);\n worker.instance.onerror = this.onErrorHandler(worker, reject);\n worker.instance.postMessage(data, options);\n worker.debounceTerminate(() => reject(new Error(`Active worker did not respond for ${this.workerTTL}ms!`)));\n });\n }\n /**\n * Terminate the idle workers in the pool.\n */\n\n\n async clear() {\n for (const worker of this.idleWorkers) {\n worker.debounceTerminate.cancel();\n worker.instance.terminate();\n }\n\n this.idleWorkers.clear();\n }\n /**\n * Used to get a worker from the pool or create a new one if there is no idle available.\n */\n\n\n async createWorker() {\n const worker = new IdleWorker(this.workerUrl);\n worker.debounceTerminate = (0,_excalidraw_common__WEBPACK_IMPORTED_MODULE_0__.debounce)(reject => {\n worker.instance.terminate();\n\n if (this.idleWorkers.has(worker)) {\n this.idleWorkers.delete(worker); // eslint-disable-next-line no-console\n\n console.debug(\"Job finished! Idle worker has been released from the pool.\");\n } else if (reject) {\n reject();\n } else {\n console.error(\"Worker has been terminated!\");\n }\n }, this.workerTTL);\n return worker;\n }\n\n onMessageHandler(worker, resolve) {\n return e => {\n worker.debounceTerminate();\n this.idleWorkers.add(worker);\n resolve(e.data);\n };\n }\n\n onErrorHandler(worker, reject) {\n return e => {\n // terminate the worker immediately before rejection\n worker.debounceTerminate(() => reject(e));\n worker.debounceTerminate.flush(); // clear the worker pool in case there are some idle workers left\n\n this.clear();\n };\n }\n\n}\n\n//# sourceURL=webpack://ExcalidrawLib/./workers.ts?");
21046
20991
 
21047
20992
  /***/ }),
21048
20993