@zsviczian/excalidraw 0.10.0-obsidian-30 → 0.10.0-obsidian-31

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (96) hide show
  1. package/dist/excalidraw-assets/Cascadia.woff2 +0 -0
  2. package/dist/excalidraw-assets/Virgil.woff2 +0 -0
  3. package/dist/excalidraw-assets/i18n-ar-SA-json-6fcb7979cd290e0e51d9.js +1 -0
  4. package/dist/excalidraw-assets/i18n-bg-BG-json-eb8b237a2970da7034ad.js +1 -0
  5. package/dist/excalidraw-assets/i18n-bn-BD-json-87d5cd14de43ad6ec162.js +1 -0
  6. package/dist/excalidraw-assets/i18n-ca-ES-json-93b7462bd1d0fe76d2b5.js +1 -0
  7. package/dist/excalidraw-assets/i18n-cs-CZ-json-1244df10086a058f2d41.js +1 -0
  8. package/dist/excalidraw-assets/i18n-da-DK-json-85af69d03d5a188d4d3e.js +1 -0
  9. package/dist/excalidraw-assets/i18n-de-DE-json-e676479528793fb9755f.js +1 -0
  10. package/dist/excalidraw-assets/i18n-el-GR-json-cef06f766f46d7ab798a.js +1 -0
  11. package/dist/excalidraw-assets/i18n-es-ES-json-2996f978aa8d44a1bc72.js +1 -0
  12. package/dist/excalidraw-assets/i18n-fa-IR-json-84150b1f61e3d7a0afcf.js +1 -0
  13. package/dist/excalidraw-assets/i18n-fi-FI-json-bb5e3af1d7bb005f0c7d.js +1 -0
  14. package/dist/excalidraw-assets/i18n-fr-FR-json-f470b9806c21d127df35.js +1 -0
  15. package/dist/excalidraw-assets/i18n-he-IL-json-dfc95883bf533087b673.js +1 -0
  16. package/dist/excalidraw-assets/i18n-hi-IN-json-07d3a348a9723eeb51a3.js +1 -0
  17. package/dist/excalidraw-assets/i18n-hu-HU-json-dbaf9c47430503d4a710.js +1 -0
  18. package/dist/excalidraw-assets/i18n-id-ID-json-43b313d6c7c52122220b.js +1 -0
  19. package/dist/excalidraw-assets/i18n-it-IT-json-1cd7244d3b42597e1555.js +1 -0
  20. package/dist/excalidraw-assets/i18n-ja-JP-json-c6208f4ec6ec8d61df2f.js +1 -0
  21. package/dist/excalidraw-assets/i18n-kab-KAB-json-7aaa4a5ea8484b941af2.js +1 -0
  22. package/dist/excalidraw-assets/i18n-kk-KZ-json-654dee98c29976300a26.js +1 -0
  23. package/dist/excalidraw-assets/i18n-ko-KR-json-fc3ee48a144b19bcca0d.js +1 -0
  24. package/dist/excalidraw-assets/i18n-lv-LV-json-bfb22930b5a31d1f92ee.js +1 -0
  25. package/dist/excalidraw-assets/i18n-my-MM-json-6d186d192f0024208fe2.js +1 -0
  26. package/dist/excalidraw-assets/i18n-nb-NO-json-a8b16b7360f5df195438.js +1 -0
  27. package/dist/excalidraw-assets/i18n-nl-NL-json-be44386cc68047e2da24.js +1 -0
  28. package/dist/excalidraw-assets/i18n-nn-NO-json-074a3f14a8e56d66eeb7.js +1 -0
  29. package/dist/excalidraw-assets/i18n-oc-FR-json-ad1cdc3ba675116187a4.js +1 -0
  30. package/dist/excalidraw-assets/i18n-pa-IN-json-319132bcecbfaf90ef79.js +1 -0
  31. package/dist/excalidraw-assets/i18n-pl-PL-json-2df7909ca92201d653d7.js +1 -0
  32. package/dist/excalidraw-assets/i18n-pt-BR-json-ad09ed1c16a3d2b6d4b8.js +1 -0
  33. package/dist/excalidraw-assets/i18n-pt-PT-json-73605e7eed8d224609aa.js +1 -0
  34. package/dist/excalidraw-assets/i18n-ro-RO-json-b48f7b508a0884880f63.js +1 -0
  35. package/dist/excalidraw-assets/i18n-ru-RU-json-cd5378c60549c20232c7.js +1 -0
  36. package/dist/excalidraw-assets/i18n-si-LK-json-c5e207625d8f7a06eb15.js +1 -0
  37. package/dist/excalidraw-assets/i18n-sk-SK-json-0261a2d60b0803cc8354.js +1 -0
  38. package/dist/excalidraw-assets/i18n-sv-SE-json-4b274bae10479b585716.js +1 -0
  39. package/dist/excalidraw-assets/i18n-ta-IN-json-f20bc85c68e334566d53.js +1 -0
  40. package/dist/excalidraw-assets/i18n-tr-TR-json-17f1500f11b6e08b677b.js +1 -0
  41. package/dist/excalidraw-assets/i18n-uk-UA-json-4798e5a14cecdddbfb50.js +1 -0
  42. package/dist/excalidraw-assets/i18n-zh-CN-json-a13fbd80677ff3f0122c.js +1 -0
  43. package/dist/excalidraw-assets/i18n-zh-HK-json-f82802143c7042511410.js +1 -0
  44. package/dist/excalidraw-assets/i18n-zh-TW-json-79c634b00f4602a2d9a6.js +1 -0
  45. package/dist/excalidraw-assets/image-87e58979d258cd38208c.js +1 -0
  46. package/dist/excalidraw-assets/vendor-8698157b56eb5e0ee549.js +2 -0
  47. package/dist/excalidraw-assets/vendor-8698157b56eb5e0ee549.js.LICENSE.txt +12 -0
  48. package/dist/excalidraw-assets-dev/Cascadia.woff2 +0 -0
  49. package/dist/excalidraw-assets-dev/Virgil.woff2 +0 -0
  50. package/dist/excalidraw-assets-dev/i18n-ar-SA-json-6681743eb68e3b3041cb.js +22 -0
  51. package/dist/excalidraw-assets-dev/i18n-bg-BG-json-c907a37ea9ff74c38200.js +22 -0
  52. package/dist/excalidraw-assets-dev/i18n-bn-BD-json-b02ff15ce32c21861fb1.js +22 -0
  53. package/dist/excalidraw-assets-dev/i18n-ca-ES-json-f9ecdae168e193e1819d.js +22 -0
  54. package/dist/excalidraw-assets-dev/i18n-cs-CZ-json-b0c7af8af120bd1ba4ac.js +22 -0
  55. package/dist/excalidraw-assets-dev/i18n-da-DK-json-bdae60049eb02dee741f.js +22 -0
  56. package/dist/excalidraw-assets-dev/i18n-de-DE-json-0314c69da1a79cb476ef.js +22 -0
  57. package/dist/excalidraw-assets-dev/i18n-el-GR-json-db678ec2c7b5ee5b6197.js +22 -0
  58. package/dist/excalidraw-assets-dev/i18n-es-ES-json-f960cfc72c2bce33bcd9.js +22 -0
  59. package/dist/excalidraw-assets-dev/i18n-fa-IR-json-3091ac88e5a7ad285607.js +22 -0
  60. package/dist/excalidraw-assets-dev/i18n-fi-FI-json-b3a67612e607442c8940.js +22 -0
  61. package/dist/excalidraw-assets-dev/i18n-fr-FR-json-628bf75e5684419e4522.js +22 -0
  62. package/dist/excalidraw-assets-dev/i18n-he-IL-json-9fa5f88c445c6edfb81d.js +22 -0
  63. package/dist/excalidraw-assets-dev/i18n-hi-IN-json-a398aa828f8d1bd25761.js +22 -0
  64. package/dist/excalidraw-assets-dev/i18n-hu-HU-json-8fb512cf21c00656b011.js +22 -0
  65. package/dist/excalidraw-assets-dev/i18n-id-ID-json-d18bde26a8a7165a4c7b.js +22 -0
  66. package/dist/excalidraw-assets-dev/i18n-it-IT-json-612f895e69a992314230.js +22 -0
  67. package/dist/excalidraw-assets-dev/i18n-ja-JP-json-8fb6a4429e8c4a09e6a0.js +22 -0
  68. package/dist/excalidraw-assets-dev/i18n-kab-KAB-json-01a8363dae577ccfd06c.js +22 -0
  69. package/dist/excalidraw-assets-dev/i18n-kk-KZ-json-d0fff58ffff7c34c30a2.js +22 -0
  70. package/dist/excalidraw-assets-dev/i18n-ko-KR-json-d24a9b7640741fe02d9a.js +22 -0
  71. package/dist/excalidraw-assets-dev/i18n-lv-LV-json-d9b01c32504b031e4160.js +22 -0
  72. package/dist/excalidraw-assets-dev/i18n-my-MM-json-98a11afd5a8088489b91.js +22 -0
  73. package/dist/excalidraw-assets-dev/i18n-nb-NO-json-de73a55ddde48cdff43c.js +22 -0
  74. package/dist/excalidraw-assets-dev/i18n-nl-NL-json-88ff95be82b97ffcc7f1.js +22 -0
  75. package/dist/excalidraw-assets-dev/i18n-nn-NO-json-8f60e0ec70a2e17ad33c.js +22 -0
  76. package/dist/excalidraw-assets-dev/i18n-oc-FR-json-6a0ee550cb6fb3f1b259.js +22 -0
  77. package/dist/excalidraw-assets-dev/i18n-pa-IN-json-9bde99f7eb773f876f85.js +22 -0
  78. package/dist/excalidraw-assets-dev/i18n-pl-PL-json-bb2ca88481a524fc7a5f.js +22 -0
  79. package/dist/excalidraw-assets-dev/i18n-pt-BR-json-b40463ff0ba1a0307563.js +22 -0
  80. package/dist/excalidraw-assets-dev/i18n-pt-PT-json-cb72d009cf6ba3b55e0c.js +22 -0
  81. package/dist/excalidraw-assets-dev/i18n-ro-RO-json-b516bae00ed365b97098.js +22 -0
  82. package/dist/excalidraw-assets-dev/i18n-ru-RU-json-328be001476f936e0f00.js +22 -0
  83. package/dist/excalidraw-assets-dev/i18n-si-LK-json-4be44d4d292b6dbf260e.js +22 -0
  84. package/dist/excalidraw-assets-dev/i18n-sk-SK-json-2c5b8dc8f0812e1152f1.js +22 -0
  85. package/dist/excalidraw-assets-dev/i18n-sv-SE-json-d96e772ca45119bbb532.js +22 -0
  86. package/dist/excalidraw-assets-dev/i18n-ta-IN-json-9ba773bdb3a546e68ec3.js +22 -0
  87. package/dist/excalidraw-assets-dev/i18n-tr-TR-json-d0b9b5ae9d184cffc8a2.js +22 -0
  88. package/dist/excalidraw-assets-dev/i18n-uk-UA-json-deae797b510faf78ab8e.js +22 -0
  89. package/dist/excalidraw-assets-dev/i18n-zh-CN-json-f972d84c7b7156249d21.js +22 -0
  90. package/dist/excalidraw-assets-dev/i18n-zh-HK-json-239376fabfdff19a7ebd.js +22 -0
  91. package/dist/excalidraw-assets-dev/i18n-zh-TW-json-7ea4288fed6cce43f00c.js +22 -0
  92. package/dist/excalidraw-assets-dev/image-e50a452aa26d28419e39.js +42 -0
  93. package/dist/excalidraw-assets-dev/vendor-1bc8ceaafd8623c96dd4.js +278 -0
  94. package/dist/excalidraw.development.js +2 -2
  95. package/dist/excalidraw.production.min.js +1 -1
  96. package/package.json +1 -1
@@ -2677,7 +2677,7 @@ eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */
2677
2677
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2678
2678
 
2679
2679
  "use strict";
2680
- eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */ \\\"textWysiwyg\\\": () => (/* binding */ textWysiwyg)\\n/* harmony export */ });\\n/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ \\\"../../../node_modules/@babel/runtime/helpers/esm/defineProperty.js\\\");\\n/* harmony import */ var _keys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../keys */ \\\"../../keys.ts\\\");\\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ \\\"../../utils.ts\\\");\\n/* harmony import */ var _scene_Scene__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../scene/Scene */ \\\"../../scene/Scene.ts\\\");\\n/* harmony import */ var _typeChecks__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./typeChecks */ \\\"../../element/typeChecks.ts\\\");\\n/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../constants */ \\\"../../constants.ts\\\");\\n/* harmony import */ var _mutateElement__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./mutateElement */ \\\"../../element/mutateElement.ts\\\");\\n/* harmony import */ var _textElement__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./textElement */ \\\"../../element/textElement.ts\\\");\\n\\r\\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) {\\r\\n var symbols = Object.getOwnPropertySymbols(object);\\r\\n if (enumerableOnly) {\\r\\n symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; });\\r\\n }\\r\\n keys.push.apply(keys, symbols);\\r\\n} return keys; }\\r\\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) {\\r\\n var source = arguments[i] != null ? arguments[i] : {};\\r\\n if (i % 2) {\\r\\n ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__[\\\"default\\\"])(target, key, source[key]); });\\r\\n }\\r\\n else if (Object.getOwnPropertyDescriptors) {\\r\\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\\r\\n }\\r\\n else {\\r\\n ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); });\\r\\n }\\r\\n} return target; }\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\nconst normalizeText = function (text) {\\r\\n return text // replace tabs with spaces so they render and measure correctly\\r\\n .replace(/\\\\t/g, \\\" \\\") // normalize newlines\\r\\n .replace(/\\\\r?\\\\n|\\\\r/g, \\\"\\\\n\\\");\\r\\n};\\r\\nconst getTransform = function (width, height, angle, appState, maxWidth, maxHeight) {\\r\\n const { zoom, offsetTop, offsetLeft } = appState;\\r\\n const degree = 180 * angle / Math.PI; // offsets must be multiplied by 2 to account for the division by 2 of\\r\\n // the whole expression afterwards\\r\\n let translateX = (width - offsetLeft * 2) * (zoom.value - 1) / 2;\\r\\n let translateY = (height - offsetTop * 2) * (zoom.value - 1) / 2;\\r\\n if (width > maxWidth && zoom.value !== 1) {\\r\\n translateX = (maxWidth - offsetLeft * 2) * (zoom.value - 1) / 2;\\r\\n }\\r\\n if (height > maxHeight) {\\r\\n translateY = maxHeight / 2 * (zoom.value - 1);\\r\\n }\\r\\n if (height > maxHeight && zoom.value !== 1) {\\r\\n translateY = (maxHeight - offsetTop * 2) * (zoom.value - 1) / 2;\\r\\n }\\r\\n if (height > maxHeight && zoom.value !== 1) {\\r\\n translateY = (maxHeight - offsetTop * 2) * (zoom.value - 1) / 2;\\r\\n }\\r\\n return `translate(${translateX}px, ${translateY}px) scale(${zoom.value}) rotate(${degree}deg)`;\\r\\n};\\r\\nconst textWysiwyg = function (_ref) {\\r\\n let { id, appState, onChange, onSubmit, getViewportCoords, element, canvas, excalidrawContainer } = _ref;\\r\\n const textPropertiesUpdated = function (updatedElement, editable) {\\r\\n const currentFont = editable.style.fontFamily.replaceAll('\\\"', \\\"\\\");\\r\\n if ((0,_utils__WEBPACK_IMPORTED_MODULE_2__.getFontFamilyString)({\\r\\n fontFamily: updatedElement.fontFamily\\r\\n }) !== currentFont) {\\r\\n return true;\\r\\n }\\r\\n if (`${updatedElement.fontSize}px` !== editable.style.fontSize) {\\r\\n return true;\\r\\n }\\r\\n return false;\\r\\n };\\r\\n let originalContainerHeight;\\r\\n let approxLineHeight = (0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isTextElement)(element) ? (0,_textElement__WEBPACK_IMPORTED_MODULE_7__.getApproxLineHeight)((0,_utils__WEBPACK_IMPORTED_MODULE_2__.getFontString)(element)) : 0;\\r\\n const updateWysiwygStyle = function () {\\r\\n var _a, _b;\\r\\n const updatedElement = (_a = _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(element)) === null || _a === void 0 ? void 0 : _a.getElement(id);\\r\\n if (updatedElement && (0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isTextElement)(updatedElement)) {\\r\\n let coordX = updatedElement.x;\\r\\n let coordY = updatedElement.y;\\r\\n let container = (updatedElement === null || updatedElement === void 0 ? void 0 : updatedElement.containerId) ? _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(updatedElement).getElement(updatedElement.containerId) : null;\\r\\n let maxWidth = updatedElement.width;\\r\\n let maxHeight = updatedElement.height;\\r\\n let width = updatedElement.width;\\r\\n const height = editable.scrollHeight === 0 ? updatedElement.height : editable.scrollHeight;\\r\\n if (container && updatedElement.containerId) {\\r\\n const propertiesUpdated = textPropertiesUpdated(updatedElement, editable);\\r\\n if (propertiesUpdated) {\\r\\n const currentContainer = (_b = _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(updatedElement)) === null || _b === void 0 ? void 0 : _b.getElement(updatedElement.containerId);\\r\\n approxLineHeight = (0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isTextElement)(updatedElement) ? (0,_textElement__WEBPACK_IMPORTED_MODULE_7__.getApproxLineHeight)((0,_utils__WEBPACK_IMPORTED_MODULE_2__.getFontString)(updatedElement)) : 0;\\r\\n if (updatedElement.height > currentContainer.height - _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING * 2) {\\r\\n const nextHeight = updatedElement.height + _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING * 2;\\r\\n originalContainerHeight = nextHeight;\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(container, {\\r\\n height: nextHeight\\r\\n });\\r\\n container = _objectSpread(_objectSpread({}, container), {}, {\\r\\n height: nextHeight\\r\\n });\\r\\n }\\r\\n editable.style.height = `${updatedElement.height}px`;\\r\\n }\\r\\n if (!originalContainerHeight) {\\r\\n originalContainerHeight = container.height;\\r\\n }\\r\\n maxWidth = container.width - _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING * 2;\\r\\n maxHeight = container.height - _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING * 2;\\r\\n width = maxWidth; // The coordinates of text box set a distance of\\r\\n // 30px to preserve padding\\r\\n coordX = container.x + _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING; // autogrow container height if text exceeds\\r\\n if (editable.scrollHeight > maxHeight) {\\r\\n const diff = Math.min(editable.scrollHeight - maxHeight, approxLineHeight);\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(container, {\\r\\n height: container.height + diff\\r\\n });\\r\\n return;\\r\\n }\\r\\n else if ( // autoshrink container height until original container height\\r\\n // is reached when text is removed\\r\\n container.height > originalContainerHeight && editable.scrollHeight < maxHeight) {\\r\\n const diff = Math.min(maxHeight - editable.scrollHeight, approxLineHeight);\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(container, {\\r\\n height: container.height - diff\\r\\n });\\r\\n } // Start pushing text upward until a diff of 30px (padding)\\r\\n // is reached\\r\\n else {\\r\\n const lines = editable.scrollHeight / approxLineHeight;\\r\\n if (lines > 1 || propertiesUpdated) {\\r\\n // vertically center align the text\\r\\n coordY = container.y + container.height / 2 - editable.scrollHeight / 2;\\r\\n }\\r\\n }\\r\\n }\\r\\n const [viewportX, viewportY] = getViewportCoords(coordX, coordY);\\r\\n const { textAlign, angle } = updatedElement;\\r\\n editable.value = updatedElement.originalText || updatedElement.text;\\r\\n const lines = updatedElement.originalText.split(\\\"\\\\n\\\");\\r\\n const lineHeight = updatedElement.containerId ? approxLineHeight : updatedElement.height / lines.length;\\r\\n if (!container) {\\r\\n maxWidth = (appState.width - 8 - ((appState.scrollX + updatedElement.x) * appState.zoom.value + appState.zoom.translation.x)) / appState.zoom.value - // margin-right of parent if any\\r\\n Number(getComputedStyle(excalidrawContainer === null || excalidrawContainer === void 0 ? void 0 : excalidrawContainer.parentNode).marginRight.slice(0, -2));\\r\\n } // Make sure text editor height doesn't go beyond viewport\\r\\n const editorMaxHeight = (appState.height - viewportY - ( // There is a ~14px difference which keeps on increasing\\r\\n // with every zoom step when offset present hence I am subtracting it here\\r\\n // However this is not the best fix and breaks in\\r\\n // few scenarios\\r\\n appState.offsetTop ? (appState.zoom.value * 100 - 100) / 10 * 14 : 0)) / appState.zoom.value;\\r\\n Object.assign(editable.style, {\\r\\n font: (0,_utils__WEBPACK_IMPORTED_MODULE_2__.getFontString)(updatedElement),\\r\\n // must be defined *after* font ¯\\\\_(ツ)_/¯\\r\\n lineHeight: `${lineHeight}px`,\\r\\n width: `${width}px`,\\r\\n height: `${height}px`,\\r\\n left: `${viewportX}px`,\\r\\n top: `${viewportY}px`,\\r\\n transform: getTransform(width, height, angle, appState, maxWidth, editorMaxHeight),\\r\\n textAlign,\\r\\n color: updatedElement.strokeColor,\\r\\n opacity: updatedElement.opacity / 100,\\r\\n filter: \\\"var(--theme-filter)\\\",\\r\\n maxWidth: `${maxWidth}px`,\\r\\n maxHeight: `${editorMaxHeight}px`\\r\\n });\\r\\n }\\r\\n };\\r\\n const editable = document.createElement(\\\"textarea\\\");\\r\\n editable.dir = \\\"auto\\\";\\r\\n editable.tabIndex = 0;\\r\\n editable.dataset.type = \\\"wysiwyg\\\"; // prevent line wrapping on Safari\\r\\n editable.wrap = \\\"off\\\";\\r\\n editable.classList.add(\\\"excalidraw-wysiwyg\\\");\\r\\n let whiteSpace = \\\"pre\\\";\\r\\n let wordBreak = \\\"normal\\\";\\r\\n if ((0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isBoundToContainer)(element)) {\\r\\n whiteSpace = \\\"pre-wrap\\\";\\r\\n wordBreak = \\\"break-word\\\";\\r\\n }\\r\\n Object.assign(editable.style, {\\r\\n position: \\\"absolute\\\",\\r\\n display: \\\"inline-block\\\",\\r\\n minHeight: \\\"1em\\\",\\r\\n backfaceVisibility: \\\"hidden\\\",\\r\\n margin: 0,\\r\\n padding: 0,\\r\\n border: 0,\\r\\n outline: 0,\\r\\n resize: \\\"none\\\",\\r\\n background: \\\"transparent\\\",\\r\\n overflow: \\\"hidden\\\",\\r\\n // must be specified because in dark mode canvas creates a stacking context\\r\\n zIndex: \\\"var(--zIndex-wysiwyg)\\\",\\r\\n wordBreak,\\r\\n // prevent line wrapping (`whitespace: nowrap` doesn't work on FF)\\r\\n whiteSpace,\\r\\n overflowWrap: \\\"break-word\\\"\\r\\n });\\r\\n updateWysiwygStyle();\\r\\n if (onChange) {\\r\\n editable.oninput = function () {\\r\\n const lines = editable.scrollHeight / approxLineHeight; // auto increase height only when lines > 1 so its\\r\\n // measured correctly and vertically alignes for\\r\\n // first line as well as setting height to \\\"auto\\\"\\r\\n // doubles the height as soon as user starts typing\\r\\n if ((0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isBoundToContainer)(element) && lines > 1) {\\r\\n editable.style.height = \\\"auto\\\";\\r\\n editable.style.height = `${editable.scrollHeight}px`;\\r\\n }\\r\\n onChange(normalizeText(editable.value));\\r\\n };\\r\\n }\\r\\n editable.onkeydown = function (event) {\\r\\n event.stopPropagation();\\r\\n if (event.key === _keys__WEBPACK_IMPORTED_MODULE_1__.KEYS.ESCAPE) {\\r\\n event.preventDefault();\\r\\n submittedViaKeyboard = true;\\r\\n handleSubmit();\\r\\n }\\r\\n else if (event.key === _keys__WEBPACK_IMPORTED_MODULE_1__.KEYS.ENTER && event[_keys__WEBPACK_IMPORTED_MODULE_1__.KEYS.CTRL_OR_CMD]) {\\r\\n event.preventDefault();\\r\\n if (event.isComposing || event.keyCode === 229) {\\r\\n return;\\r\\n }\\r\\n submittedViaKeyboard = true;\\r\\n handleSubmit();\\r\\n }\\r\\n else if (event.key === _keys__WEBPACK_IMPORTED_MODULE_1__.KEYS.TAB || event[_keys__WEBPACK_IMPORTED_MODULE_1__.KEYS.CTRL_OR_CMD] && (event.code === _keys__WEBPACK_IMPORTED_MODULE_1__.CODES.BRACKET_LEFT || event.code === _keys__WEBPACK_IMPORTED_MODULE_1__.CODES.BRACKET_RIGHT)) {\\r\\n event.preventDefault();\\r\\n if (event.shiftKey || event.code === _keys__WEBPACK_IMPORTED_MODULE_1__.CODES.BRACKET_LEFT) {\\r\\n outdent();\\r\\n }\\r\\n else {\\r\\n indent();\\r\\n } // We must send an input event to resize the element\\r\\n editable.dispatchEvent(new Event(\\\"input\\\"));\\r\\n }\\r\\n };\\r\\n const TAB_SIZE = 4;\\r\\n const TAB = \\\" \\\".repeat(TAB_SIZE);\\r\\n const RE_LEADING_TAB = new RegExp(`^ {1,${TAB_SIZE}}`);\\r\\n const indent = function () {\\r\\n const { selectionStart, selectionEnd } = editable;\\r\\n const linesStartIndices = getSelectedLinesStartIndices();\\r\\n let value = editable.value;\\r\\n linesStartIndices.forEach(function (startIndex) {\\r\\n const startValue = value.slice(0, startIndex);\\r\\n const endValue = value.slice(startIndex);\\r\\n value = `${startValue}${TAB}${endValue}`;\\r\\n });\\r\\n editable.value = value;\\r\\n editable.selectionStart = selectionStart + TAB_SIZE;\\r\\n editable.selectionEnd = selectionEnd + TAB_SIZE * linesStartIndices.length;\\r\\n };\\r\\n const outdent = function () {\\r\\n const { selectionStart, selectionEnd } = editable;\\r\\n const linesStartIndices = getSelectedLinesStartIndices();\\r\\n const removedTabs = [];\\r\\n let value = editable.value;\\r\\n linesStartIndices.forEach(function (startIndex) {\\r\\n const tabMatch = value.slice(startIndex, startIndex + TAB_SIZE).match(RE_LEADING_TAB);\\r\\n if (tabMatch) {\\r\\n const startValue = value.slice(0, startIndex);\\r\\n const endValue = value.slice(startIndex + tabMatch[0].length); // Delete a tab from the line\\r\\n value = `${startValue}${endValue}`;\\r\\n removedTabs.push(startIndex);\\r\\n }\\r\\n });\\r\\n editable.value = value;\\r\\n if (removedTabs.length) {\\r\\n if (selectionStart > removedTabs[removedTabs.length - 1]) {\\r\\n editable.selectionStart = Math.max(selectionStart - TAB_SIZE, removedTabs[removedTabs.length - 1]);\\r\\n }\\r\\n else {\\r\\n // If the cursor is before the first tab removed, ex:\\r\\n // Line| #1\\r\\n // Line #2\\r\\n // Lin|e #3\\r\\n // we should reset the selectionStart to his initial value.\\r\\n editable.selectionStart = selectionStart;\\r\\n }\\r\\n editable.selectionEnd = Math.max(editable.selectionStart, selectionEnd - TAB_SIZE * removedTabs.length);\\r\\n }\\r\\n };\\r\\n /**\\r\\n * @returns indeces of start positions of selected lines, in reverse order\\r\\n */\\r\\n const getSelectedLinesStartIndices = function () {\\r\\n let { selectionStart, selectionEnd, value } = editable; // chars before selectionStart on the same line\\r\\n const startOffset = value.slice(0, selectionStart).match(/[^\\\\n]*$/)[0].length; // put caret at the start of the line\\r\\n selectionStart = selectionStart - startOffset;\\r\\n const selected = value.slice(selectionStart, selectionEnd);\\r\\n return selected.split(\\\"\\\\n\\\").reduce(function (startIndices, line, idx, lines) {\\r\\n return startIndices.concat(idx ? // curr line index is prev line's start + prev line's length + \\\\n\\r\\n startIndices[idx - 1] + lines[idx - 1].length + 1 : // first selected line\\r\\n selectionStart);\\r\\n }, []).reverse();\\r\\n };\\r\\n const stopEvent = function (event) {\\r\\n event.preventDefault();\\r\\n event.stopPropagation();\\r\\n }; // using a state variable instead of passing it to the handleSubmit callback\\r\\n // so that we don't need to create separate a callback for event handlers\\r\\n let submittedViaKeyboard = false;\\r\\n const handleSubmit = function () {\\r\\n var _a, _b;\\r\\n // cleanup must be run before onSubmit otherwise when app blurs the wysiwyg\\r\\n // it'd get stuck in an infinite loop of blur→onSubmit after we re-focus the\\r\\n // wysiwyg on update\\r\\n cleanup();\\r\\n const updateElement = (_a = _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(element)) === null || _a === void 0 ? void 0 : _a.getElement(element.id);\\r\\n if (!updateElement) {\\r\\n return;\\r\\n }\\r\\n let wrappedText = \\\"\\\";\\r\\n if ((0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isTextElement)(updateElement) && (updateElement === null || updateElement === void 0 ? void 0 : updateElement.containerId)) {\\r\\n const container = _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(updateElement).getElement(updateElement.containerId);\\r\\n if (container) {\\r\\n wrappedText = (0,_textElement__WEBPACK_IMPORTED_MODULE_7__.wrapText)(editable.value, (0,_utils__WEBPACK_IMPORTED_MODULE_2__.getFontString)(updateElement), container.width);\\r\\n if ((0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isTextElement)(updateElement) && updateElement.containerId) {\\r\\n const editorHeight = Number(editable.style.height.slice(0, -2));\\r\\n if (editable.value) {\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(updateElement, {\\r\\n // vertically center align\\r\\n y: container.y + container.height / 2 - editorHeight / 2,\\r\\n height: editorHeight,\\r\\n width: Number(editable.style.width.slice(0, -2)),\\r\\n // preserve padding\\r\\n x: container.x + _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING\\r\\n });\\r\\n const boundTextElementId = (0,_textElement__WEBPACK_IMPORTED_MODULE_7__.getBoundTextElementId)(container);\\r\\n if (!boundTextElementId || boundTextElementId !== element.id) {\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(container, {\\r\\n boundElements: (container.boundElements || []).concat({\\r\\n type: \\\"text\\\",\\r\\n id: element.id\\r\\n })\\r\\n });\\r\\n }\\r\\n }\\r\\n else {\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(container, {\\r\\n boundElements: (_b = container.boundElements) === null || _b === void 0 ? void 0 : _b.filter(function (ele) {\\r\\n return ele.type !== \\\"text\\\";\\r\\n })\\r\\n });\\r\\n }\\r\\n }\\r\\n }\\r\\n }\\r\\n else {\\r\\n wrappedText = editable.value;\\r\\n }\\r\\n onSubmit({\\r\\n text: normalizeText(wrappedText),\\r\\n viaKeyboard: submittedViaKeyboard,\\r\\n originalText: editable.value\\r\\n });\\r\\n };\\r\\n const cleanup = function () {\\r\\n if (isDestroyed) {\\r\\n return;\\r\\n }\\r\\n isDestroyed = true; // remove events to ensure they don't late-fire\\r\\n editable.onblur = null;\\r\\n editable.oninput = null;\\r\\n editable.onkeydown = null;\\r\\n if (observer) {\\r\\n observer.disconnect();\\r\\n }\\r\\n window.removeEventListener(\\\"resize\\\", updateWysiwygStyle);\\r\\n window.removeEventListener(\\\"wheel\\\", stopEvent, true);\\r\\n window.removeEventListener(\\\"pointerdown\\\", onPointerDown);\\r\\n window.removeEventListener(\\\"pointerup\\\", bindBlurEvent);\\r\\n window.removeEventListener(\\\"blur\\\", handleSubmit);\\r\\n unbindUpdate();\\r\\n editable.remove();\\r\\n };\\r\\n const bindBlurEvent = function (event) {\\r\\n window.removeEventListener(\\\"pointerup\\\", bindBlurEvent); // Deferred so that the pointerdown that initiates the wysiwyg doesn't\\r\\n // trigger the blur on ensuing pointerup.\\r\\n // Also to handle cases such as picking a color which would trigger a blur\\r\\n // in that same tick.\\r\\n const target = event === null || event === void 0 ? void 0 : event.target;\\r\\n const isTargetColorPicker = target instanceof HTMLInputElement && target.closest(\\\".color-picker-input\\\") && (0,_utils__WEBPACK_IMPORTED_MODULE_2__.isWritableElement)(target);\\r\\n setTimeout(function () {\\r\\n editable.onblur = handleSubmit;\\r\\n if (target && isTargetColorPicker) {\\r\\n target.onblur = function () {\\r\\n editable.focus();\\r\\n };\\r\\n } // case: clicking on the same property → no change → no update → no focus\\r\\n if (!isTargetColorPicker) {\\r\\n editable.focus();\\r\\n }\\r\\n });\\r\\n }; // prevent blur when changing properties from the menu\\r\\n const onPointerDown = function (event) {\\r\\n const isTargetColorPicker = event.target instanceof HTMLInputElement && event.target.closest(\\\".color-picker-input\\\") && (0,_utils__WEBPACK_IMPORTED_MODULE_2__.isWritableElement)(event.target);\\r\\n if ((event.target instanceof HTMLElement || event.target instanceof SVGElement) && event.target.closest(`.${_constants__WEBPACK_IMPORTED_MODULE_5__.CLASSES.SHAPE_ACTIONS_MENU}`) && !(0,_utils__WEBPACK_IMPORTED_MODULE_2__.isWritableElement)(event.target) || isTargetColorPicker) {\\r\\n editable.onblur = null;\\r\\n window.addEventListener(\\\"pointerup\\\", bindBlurEvent); // handle edge-case where pointerup doesn't fire e.g. due to user\\r\\n // alt-tabbing away\\r\\n window.addEventListener(\\\"blur\\\", handleSubmit);\\r\\n }\\r\\n }; // handle updates of textElement properties of editing element\\r\\n const unbindUpdate = _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(element).addCallback(function () {\\r\\n var _a;\\r\\n updateWysiwygStyle();\\r\\n const isColorPickerActive = !!((_a = document.activeElement) === null || _a === void 0 ? void 0 : _a.closest(\\\".color-picker-input\\\"));\\r\\n if (!isColorPickerActive) {\\r\\n editable.focus();\\r\\n }\\r\\n }); // ---------------------------------------------------------------------------\\r\\n let isDestroyed = false; // select on init (focusing is done separately inside the bindBlurEvent()\\r\\n // because we need it to happen *after* the blur event from `pointerdown`)\\r\\n editable.select();\\r\\n bindBlurEvent(); // reposition wysiwyg in case of canvas is resized. Using ResizeObserver\\r\\n // is preferred so we catch changes from host, where window may not resize.\\r\\n let observer = null;\\r\\n if (canvas && \\\"ResizeObserver\\\" in window) {\\r\\n observer = new window.ResizeObserver(function () {\\r\\n updateWysiwygStyle();\\r\\n });\\r\\n observer.observe(canvas);\\r\\n }\\r\\n else {\\r\\n window.addEventListener(\\\"resize\\\", updateWysiwygStyle);\\r\\n }\\r\\n window.addEventListener(\\\"pointerdown\\\", onPointerDown);\\r\\n window.addEventListener(\\\"wheel\\\", stopEvent, {\\r\\n passive: false,\\r\\n capture: true\\r\\n });\\r\\n excalidrawContainer === null || excalidrawContainer === void 0 ? void 0 : excalidrawContainer.querySelector(\\\".excalidraw-textEditorContainer\\\").appendChild(editable);\\r\\n};\\r\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../element/textWysiwyg.tsx.js","mappings":"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","sources":["webpack:///../../element/textWysiwyg.tsx?57fd"],"sourcesContent":["import _defineProperty from \"@babel/runtime/helpers/defineProperty\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { CODES, KEYS } from \"../keys\";\nimport { isWritableElement, getFontString, getFontFamilyString } from \"../utils\";\nimport Scene from \"../scene/Scene\";\nimport { isBoundToContainer, isTextElement } from \"./typeChecks\";\nimport { CLASSES, PADDING } from \"../constants\";\nimport { mutateElement } from \"./mutateElement\";\nimport { getApproxLineHeight, getBoundTextElementId, wrapText } from \"./textElement\";\n\nconst normalizeText = function (text) {\n  return text // replace tabs with spaces so they render and measure correctly\n  .replace(/\\t/g, \"        \") // normalize newlines\n  .replace(/\\r?\\n|\\r/g, \"\\n\");\n};\n\nconst getTransform = function (width, height, angle, appState, maxWidth, maxHeight) {\n  const {\n    zoom,\n    offsetTop,\n    offsetLeft\n  } = appState;\n  const degree = 180 * angle / Math.PI; // offsets must be multiplied by 2 to account for the division by 2 of\n  // the whole expression afterwards\n\n  let translateX = (width - offsetLeft * 2) * (zoom.value - 1) / 2;\n  let translateY = (height - offsetTop * 2) * (zoom.value - 1) / 2;\n\n  if (width > maxWidth && zoom.value !== 1) {\n    translateX = (maxWidth - offsetLeft * 2) * (zoom.value - 1) / 2;\n  }\n\n  if (height > maxHeight) {\n    translateY = maxHeight / 2 * (zoom.value - 1);\n  }\n\n  if (height > maxHeight && zoom.value !== 1) {\n    translateY = (maxHeight - offsetTop * 2) * (zoom.value - 1) / 2;\n  }\n\n  if (height > maxHeight && zoom.value !== 1) {\n    translateY = (maxHeight - offsetTop * 2) * (zoom.value - 1) / 2;\n  }\n\n  return `translate(${translateX}px, ${translateY}px) scale(${zoom.value}) rotate(${degree}deg)`;\n};\n\nexport const textWysiwyg = function (_ref) {\n  let {\n    id,\n    appState,\n    onChange,\n    onSubmit,\n    getViewportCoords,\n    element,\n    canvas,\n    excalidrawContainer\n  } = _ref;\n\n  const textPropertiesUpdated = function (updatedElement, editable) {\n    const currentFont = editable.style.fontFamily.replaceAll('\"', \"\");\n\n    if (getFontFamilyString({\n      fontFamily: updatedElement.fontFamily\n    }) !== currentFont) {\n      return true;\n    }\n\n    if (`${updatedElement.fontSize}px` !== editable.style.fontSize) {\n      return true;\n    }\n\n    return false;\n  };\n\n  let originalContainerHeight;\n  let approxLineHeight = isTextElement(element) ? getApproxLineHeight(getFontString(element)) : 0;\n\n  const updateWysiwygStyle = function () {\n    const updatedElement = Scene.getScene(element)?.getElement(id);\n\n    if (updatedElement && isTextElement(updatedElement)) {\n      let coordX = updatedElement.x;\n      let coordY = updatedElement.y;\n      let container = updatedElement?.containerId ? Scene.getScene(updatedElement).getElement(updatedElement.containerId) : null;\n      let maxWidth = updatedElement.width;\n      let maxHeight = updatedElement.height;\n      let width = updatedElement.width;\n      const height = editable.scrollHeight === 0 ? updatedElement.height : editable.scrollHeight;\n\n      if (container && updatedElement.containerId) {\n        const propertiesUpdated = textPropertiesUpdated(updatedElement, editable);\n\n        if (propertiesUpdated) {\n          const currentContainer = Scene.getScene(updatedElement)?.getElement(updatedElement.containerId);\n          approxLineHeight = isTextElement(updatedElement) ? getApproxLineHeight(getFontString(updatedElement)) : 0;\n\n          if (updatedElement.height > currentContainer.height - PADDING * 2) {\n            const nextHeight = updatedElement.height + PADDING * 2;\n            originalContainerHeight = nextHeight;\n            mutateElement(container, {\n              height: nextHeight\n            });\n            container = _objectSpread(_objectSpread({}, container), {}, {\n              height: nextHeight\n            });\n          }\n\n          editable.style.height = `${updatedElement.height}px`;\n        }\n\n        if (!originalContainerHeight) {\n          originalContainerHeight = container.height;\n        }\n\n        maxWidth = container.width - PADDING * 2;\n        maxHeight = container.height - PADDING * 2;\n        width = maxWidth; // The coordinates of text box set a distance of\n        // 30px to preserve padding\n\n        coordX = container.x + PADDING; // autogrow container height if text exceeds\n\n        if (editable.scrollHeight > maxHeight) {\n          const diff = Math.min(editable.scrollHeight - maxHeight, approxLineHeight);\n          mutateElement(container, {\n            height: container.height + diff\n          });\n          return;\n        } else if ( // autoshrink container height until original container height\n        // is reached when text is removed\n        container.height > originalContainerHeight && editable.scrollHeight < maxHeight) {\n          const diff = Math.min(maxHeight - editable.scrollHeight, approxLineHeight);\n          mutateElement(container, {\n            height: container.height - diff\n          });\n        } // Start pushing text upward until a diff of 30px (padding)\n        // is reached\n        else {\n          const lines = editable.scrollHeight / approxLineHeight;\n\n          if (lines > 1 || propertiesUpdated) {\n            // vertically center align the text\n            coordY = container.y + container.height / 2 - editable.scrollHeight / 2;\n          }\n        }\n      }\n\n      const [viewportX, viewportY] = getViewportCoords(coordX, coordY);\n      const {\n        textAlign,\n        angle\n      } = updatedElement;\n      editable.value = updatedElement.originalText || updatedElement.text;\n      const lines = updatedElement.originalText.split(\"\\n\");\n      const lineHeight = updatedElement.containerId ? approxLineHeight : updatedElement.height / lines.length;\n\n      if (!container) {\n        maxWidth = (appState.width - 8 - ((appState.scrollX + updatedElement.x) * appState.zoom.value + appState.zoom.translation.x)) / appState.zoom.value - // margin-right of parent if any\n        Number(getComputedStyle(excalidrawContainer?.parentNode).marginRight.slice(0, -2));\n      } // Make sure text editor height doesn't go beyond viewport\n\n\n      const editorMaxHeight = (appState.height - viewportY - ( // There is a ~14px difference which keeps on increasing\n      // with every zoom step when offset present hence I am subtracting it here\n      // However this is not the best fix and breaks in\n      // few scenarios\n      appState.offsetTop ? (appState.zoom.value * 100 - 100) / 10 * 14 : 0)) / appState.zoom.value;\n      Object.assign(editable.style, {\n        font: getFontString(updatedElement),\n        // must be defined *after* font ¯\\_(ツ)_/¯\n        lineHeight: `${lineHeight}px`,\n        width: `${width}px`,\n        height: `${height}px`,\n        left: `${viewportX}px`,\n        top: `${viewportY}px`,\n        transform: getTransform(width, height, angle, appState, maxWidth, editorMaxHeight),\n        textAlign,\n        color: updatedElement.strokeColor,\n        opacity: updatedElement.opacity / 100,\n        filter: \"var(--theme-filter)\",\n        maxWidth: `${maxWidth}px`,\n        maxHeight: `${editorMaxHeight}px`\n      });\n    }\n  };\n\n  const editable = document.createElement(\"textarea\");\n  editable.dir = \"auto\";\n  editable.tabIndex = 0;\n  editable.dataset.type = \"wysiwyg\"; // prevent line wrapping on Safari\n\n  editable.wrap = \"off\";\n  editable.classList.add(\"excalidraw-wysiwyg\");\n  let whiteSpace = \"pre\";\n  let wordBreak = \"normal\";\n\n  if (isBoundToContainer(element)) {\n    whiteSpace = \"pre-wrap\";\n    wordBreak = \"break-word\";\n  }\n\n  Object.assign(editable.style, {\n    position: \"absolute\",\n    display: \"inline-block\",\n    minHeight: \"1em\",\n    backfaceVisibility: \"hidden\",\n    margin: 0,\n    padding: 0,\n    border: 0,\n    outline: 0,\n    resize: \"none\",\n    background: \"transparent\",\n    overflow: \"hidden\",\n    // must be specified because in dark mode canvas creates a stacking context\n    zIndex: \"var(--zIndex-wysiwyg)\",\n    wordBreak,\n    // prevent line wrapping (`whitespace: nowrap` doesn't work on FF)\n    whiteSpace,\n    overflowWrap: \"break-word\"\n  });\n  updateWysiwygStyle();\n\n  if (onChange) {\n    editable.oninput = function () {\n      const lines = editable.scrollHeight / approxLineHeight; // auto increase height only when lines  > 1 so its\n      // measured correctly and vertically alignes for\n      // first line as well as setting height to \"auto\"\n      // doubles the height as soon as user starts typing\n\n      if (isBoundToContainer(element) && lines > 1) {\n        editable.style.height = \"auto\";\n        editable.style.height = `${editable.scrollHeight}px`;\n      }\n\n      onChange(normalizeText(editable.value));\n    };\n  }\n\n  editable.onkeydown = function (event) {\n    event.stopPropagation();\n\n    if (event.key === KEYS.ESCAPE) {\n      event.preventDefault();\n      submittedViaKeyboard = true;\n      handleSubmit();\n    } else if (event.key === KEYS.ENTER && event[KEYS.CTRL_OR_CMD]) {\n      event.preventDefault();\n\n      if (event.isComposing || event.keyCode === 229) {\n        return;\n      }\n\n      submittedViaKeyboard = true;\n      handleSubmit();\n    } else if (event.key === KEYS.TAB || event[KEYS.CTRL_OR_CMD] && (event.code === CODES.BRACKET_LEFT || event.code === CODES.BRACKET_RIGHT)) {\n      event.preventDefault();\n\n      if (event.shiftKey || event.code === CODES.BRACKET_LEFT) {\n        outdent();\n      } else {\n        indent();\n      } // We must send an input event to resize the element\n\n\n      editable.dispatchEvent(new Event(\"input\"));\n    }\n  };\n\n  const TAB_SIZE = 4;\n  const TAB = \" \".repeat(TAB_SIZE);\n  const RE_LEADING_TAB = new RegExp(`^ {1,${TAB_SIZE}}`);\n\n  const indent = function () {\n    const {\n      selectionStart,\n      selectionEnd\n    } = editable;\n    const linesStartIndices = getSelectedLinesStartIndices();\n    let value = editable.value;\n    linesStartIndices.forEach(function (startIndex) {\n      const startValue = value.slice(0, startIndex);\n      const endValue = value.slice(startIndex);\n      value = `${startValue}${TAB}${endValue}`;\n    });\n    editable.value = value;\n    editable.selectionStart = selectionStart + TAB_SIZE;\n    editable.selectionEnd = selectionEnd + TAB_SIZE * linesStartIndices.length;\n  };\n\n  const outdent = function () {\n    const {\n      selectionStart,\n      selectionEnd\n    } = editable;\n    const linesStartIndices = getSelectedLinesStartIndices();\n    const removedTabs = [];\n    let value = editable.value;\n    linesStartIndices.forEach(function (startIndex) {\n      const tabMatch = value.slice(startIndex, startIndex + TAB_SIZE).match(RE_LEADING_TAB);\n\n      if (tabMatch) {\n        const startValue = value.slice(0, startIndex);\n        const endValue = value.slice(startIndex + tabMatch[0].length); // Delete a tab from the line\n\n        value = `${startValue}${endValue}`;\n        removedTabs.push(startIndex);\n      }\n    });\n    editable.value = value;\n\n    if (removedTabs.length) {\n      if (selectionStart > removedTabs[removedTabs.length - 1]) {\n        editable.selectionStart = Math.max(selectionStart - TAB_SIZE, removedTabs[removedTabs.length - 1]);\n      } else {\n        // If the cursor is before the first tab removed, ex:\n        // Line| #1\n        //     Line #2\n        // Lin|e #3\n        // we should reset the selectionStart to his initial value.\n        editable.selectionStart = selectionStart;\n      }\n\n      editable.selectionEnd = Math.max(editable.selectionStart, selectionEnd - TAB_SIZE * removedTabs.length);\n    }\n  };\n  /**\n   * @returns indeces of start positions of selected lines, in reverse order\n   */\n\n\n  const getSelectedLinesStartIndices = function () {\n    let {\n      selectionStart,\n      selectionEnd,\n      value\n    } = editable; // chars before selectionStart on the same line\n\n    const startOffset = value.slice(0, selectionStart).match(/[^\\n]*$/)[0].length; // put caret at the start of the line\n\n    selectionStart = selectionStart - startOffset;\n    const selected = value.slice(selectionStart, selectionEnd);\n    return selected.split(\"\\n\").reduce(function (startIndices, line, idx, lines) {\n      return startIndices.concat(idx ? // curr line index is prev line's start + prev line's length + \\n\n      startIndices[idx - 1] + lines[idx - 1].length + 1 : // first selected line\n      selectionStart);\n    }, []).reverse();\n  };\n\n  const stopEvent = function (event) {\n    event.preventDefault();\n    event.stopPropagation();\n  }; // using a state variable instead of passing it to the handleSubmit callback\n  // so that we don't need to create separate a callback for event handlers\n\n\n  let submittedViaKeyboard = false;\n\n  const handleSubmit = function () {\n    // cleanup must be run before onSubmit otherwise when app blurs the wysiwyg\n    // it'd get stuck in an infinite loop of blur→onSubmit after we re-focus the\n    // wysiwyg on update\n    cleanup();\n    const updateElement = Scene.getScene(element)?.getElement(element.id);\n\n    if (!updateElement) {\n      return;\n    }\n\n    let wrappedText = \"\";\n\n    if (isTextElement(updateElement) && updateElement?.containerId) {\n      const container = Scene.getScene(updateElement).getElement(updateElement.containerId);\n\n      if (container) {\n        wrappedText = wrapText(editable.value, getFontString(updateElement), container.width);\n\n        if (isTextElement(updateElement) && updateElement.containerId) {\n          const editorHeight = Number(editable.style.height.slice(0, -2));\n\n          if (editable.value) {\n            mutateElement(updateElement, {\n              // vertically center align\n              y: container.y + container.height / 2 - editorHeight / 2,\n              height: editorHeight,\n              width: Number(editable.style.width.slice(0, -2)),\n              // preserve padding\n              x: container.x + PADDING\n            });\n            const boundTextElementId = getBoundTextElementId(container);\n\n            if (!boundTextElementId || boundTextElementId !== element.id) {\n              mutateElement(container, {\n                boundElements: (container.boundElements || []).concat({\n                  type: \"text\",\n                  id: element.id\n                })\n              });\n            }\n          } else {\n            mutateElement(container, {\n              boundElements: container.boundElements?.filter(function (ele) {\n                return ele.type !== \"text\";\n              })\n            });\n          }\n        }\n      }\n    } else {\n      wrappedText = editable.value;\n    }\n\n    onSubmit({\n      text: normalizeText(wrappedText),\n      viaKeyboard: submittedViaKeyboard,\n      originalText: editable.value\n    });\n  };\n\n  const cleanup = function () {\n    if (isDestroyed) {\n      return;\n    }\n\n    isDestroyed = true; // remove events to ensure they don't late-fire\n\n    editable.onblur = null;\n    editable.oninput = null;\n    editable.onkeydown = null;\n\n    if (observer) {\n      observer.disconnect();\n    }\n\n    window.removeEventListener(\"resize\", updateWysiwygStyle);\n    window.removeEventListener(\"wheel\", stopEvent, true);\n    window.removeEventListener(\"pointerdown\", onPointerDown);\n    window.removeEventListener(\"pointerup\", bindBlurEvent);\n    window.removeEventListener(\"blur\", handleSubmit);\n    unbindUpdate();\n    editable.remove();\n  };\n\n  const bindBlurEvent = function (event) {\n    window.removeEventListener(\"pointerup\", bindBlurEvent); // Deferred so that the pointerdown that initiates the wysiwyg doesn't\n    // trigger the blur on ensuing pointerup.\n    // Also to handle cases such as picking a color which would trigger a blur\n    // in that same tick.\n\n    const target = event?.target;\n    const isTargetColorPicker = target instanceof HTMLInputElement && target.closest(\".color-picker-input\") && isWritableElement(target);\n    setTimeout(function () {\n      editable.onblur = handleSubmit;\n\n      if (target && isTargetColorPicker) {\n        target.onblur = function () {\n          editable.focus();\n        };\n      } // case: clicking on the same property → no change → no update → no focus\n\n\n      if (!isTargetColorPicker) {\n        editable.focus();\n      }\n    });\n  }; // prevent blur when changing properties from the menu\n\n\n  const onPointerDown = function (event) {\n    const isTargetColorPicker = event.target instanceof HTMLInputElement && event.target.closest(\".color-picker-input\") && isWritableElement(event.target);\n\n    if ((event.target instanceof HTMLElement || event.target instanceof SVGElement) && event.target.closest(`.${CLASSES.SHAPE_ACTIONS_MENU}`) && !isWritableElement(event.target) || isTargetColorPicker) {\n      editable.onblur = null;\n      window.addEventListener(\"pointerup\", bindBlurEvent); // handle edge-case where pointerup doesn't fire e.g. due to user\n      // alt-tabbing away\n\n      window.addEventListener(\"blur\", handleSubmit);\n    }\n  }; // handle updates of textElement properties of editing element\n\n\n  const unbindUpdate = Scene.getScene(element).addCallback(function () {\n    updateWysiwygStyle();\n    const isColorPickerActive = !!document.activeElement?.closest(\".color-picker-input\");\n\n    if (!isColorPickerActive) {\n      editable.focus();\n    }\n  }); // ---------------------------------------------------------------------------\n\n  let isDestroyed = false; // select on init (focusing is done separately inside the bindBlurEvent()\n  // because we need it to happen *after* the blur event from `pointerdown`)\n\n  editable.select();\n  bindBlurEvent(); // reposition wysiwyg in case of canvas is resized. Using ResizeObserver\n  // is preferred so we catch changes from host, where window may not resize.\n\n  let observer = null;\n\n  if (canvas && \"ResizeObserver\" in window) {\n    observer = new window.ResizeObserver(function () {\n      updateWysiwygStyle();\n    });\n    observer.observe(canvas);\n  } else {\n    window.addEventListener(\"resize\", updateWysiwygStyle);\n  }\n\n  window.addEventListener(\"pointerdown\", onPointerDown);\n  window.addEventListener(\"wheel\", stopEvent, {\n    passive: false,\n    capture: true\n  });\n  excalidrawContainer?.querySelector(\".excalidraw-textEditorContainer\").appendChild(editable);\n};"],"names":[],"sourceRoot":""}\\n//# sourceURL=webpack-internal:///../../element/textWysiwyg.tsx\\n\");\n\n//# sourceURL=webpack://Excalidraw/../../element/textWysiwyg.tsx?");
2680
+ eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */ \\\"textWysiwyg\\\": () => (/* binding */ textWysiwyg)\\n/* harmony export */ });\\n/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ \\\"../../../node_modules/@babel/runtime/helpers/esm/defineProperty.js\\\");\\n/* harmony import */ var _keys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../keys */ \\\"../../keys.ts\\\");\\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ \\\"../../utils.ts\\\");\\n/* harmony import */ var _scene_Scene__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../scene/Scene */ \\\"../../scene/Scene.ts\\\");\\n/* harmony import */ var _typeChecks__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./typeChecks */ \\\"../../element/typeChecks.ts\\\");\\n/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../constants */ \\\"../../constants.ts\\\");\\n/* harmony import */ var _mutateElement__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./mutateElement */ \\\"../../element/mutateElement.ts\\\");\\n/* harmony import */ var _textElement__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./textElement */ \\\"../../element/textElement.ts\\\");\\n\\r\\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) {\\r\\n var symbols = Object.getOwnPropertySymbols(object);\\r\\n if (enumerableOnly) {\\r\\n symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; });\\r\\n }\\r\\n keys.push.apply(keys, symbols);\\r\\n} return keys; }\\r\\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) {\\r\\n var source = arguments[i] != null ? arguments[i] : {};\\r\\n if (i % 2) {\\r\\n ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__[\\\"default\\\"])(target, key, source[key]); });\\r\\n }\\r\\n else if (Object.getOwnPropertyDescriptors) {\\r\\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\\r\\n }\\r\\n else {\\r\\n ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); });\\r\\n }\\r\\n} return target; }\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\nconst normalizeText = function (text) {\\r\\n return text // replace tabs with spaces so they render and measure correctly\\r\\n .replace(/\\\\t/g, \\\" \\\") // normalize newlines\\r\\n .replace(/\\\\r?\\\\n|\\\\r/g, \\\"\\\\n\\\");\\r\\n};\\r\\nconst getTransform = function (width, height, angle, appState, maxWidth, maxHeight) {\\r\\n const { zoom, offsetTop, offsetLeft } = appState;\\r\\n const degree = 180 * angle / Math.PI; // offsets must be multiplied by 2 to account for the division by 2 of\\r\\n // the whole expression afterwards\\r\\n let translateX = (width - offsetLeft * 2) * (zoom.value - 1) / 2;\\r\\n let translateY = (height - offsetTop * 2) * (zoom.value - 1) / 2;\\r\\n if (width > maxWidth && zoom.value !== 1) {\\r\\n translateX = (maxWidth - offsetLeft * 2) * (zoom.value - 1) / 2;\\r\\n }\\r\\n if (height > maxHeight && zoom.value !== 1) {\\r\\n translateY = (maxHeight - offsetTop * 2) * (zoom.value - 1) / 2;\\r\\n }\\r\\n return `translate(${translateX}px, ${translateY}px) scale(${zoom.value}) rotate(${degree}deg)`;\\r\\n};\\r\\nconst textWysiwyg = function (_ref) {\\r\\n let { id, appState, onChange, onSubmit, getViewportCoords, element, canvas, excalidrawContainer } = _ref;\\r\\n const textPropertiesUpdated = function (updatedElement, editable) {\\r\\n const currentFont = editable.style.fontFamily.replaceAll('\\\"', \\\"\\\");\\r\\n if ((0,_utils__WEBPACK_IMPORTED_MODULE_2__.getFontFamilyString)({\\r\\n fontFamily: updatedElement.fontFamily\\r\\n }) !== currentFont) {\\r\\n return true;\\r\\n }\\r\\n if (`${updatedElement.fontSize}px` !== editable.style.fontSize) {\\r\\n return true;\\r\\n }\\r\\n return false;\\r\\n };\\r\\n let originalContainerHeight;\\r\\n let approxLineHeight = (0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isTextElement)(element) ? (0,_textElement__WEBPACK_IMPORTED_MODULE_7__.getApproxLineHeight)((0,_utils__WEBPACK_IMPORTED_MODULE_2__.getFontString)(element)) : 0;\\r\\n const updateWysiwygStyle = function () {\\r\\n var _a, _b;\\r\\n const updatedElement = (_a = _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(element)) === null || _a === void 0 ? void 0 : _a.getElement(id);\\r\\n if (updatedElement && (0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isTextElement)(updatedElement)) {\\r\\n let coordX = updatedElement.x;\\r\\n let coordY = updatedElement.y;\\r\\n let container = (updatedElement === null || updatedElement === void 0 ? void 0 : updatedElement.containerId) ? _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(updatedElement).getElement(updatedElement.containerId) : null;\\r\\n let maxWidth = updatedElement.width;\\r\\n let maxHeight = updatedElement.height;\\r\\n let width = updatedElement.width; // Set to element height by default since thats\\r\\n // what is going to be used for unbounded text\\r\\n let height = updatedElement.height;\\r\\n if (container && updatedElement.containerId) {\\r\\n const propertiesUpdated = textPropertiesUpdated(updatedElement, editable); // using editor.style.height to get the accurate height of text editor\\r\\n const editorHeight = Number(editable.style.height.slice(0, -2));\\r\\n if (editorHeight > 0) {\\r\\n height = editorHeight;\\r\\n }\\r\\n if (propertiesUpdated) {\\r\\n const currentContainer = (_b = _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(updatedElement)) === null || _b === void 0 ? void 0 : _b.getElement(updatedElement.containerId);\\r\\n approxLineHeight = (0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isTextElement)(updatedElement) ? (0,_textElement__WEBPACK_IMPORTED_MODULE_7__.getApproxLineHeight)((0,_utils__WEBPACK_IMPORTED_MODULE_2__.getFontString)(updatedElement)) : 0;\\r\\n if (updatedElement.height > currentContainer.height - _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING * 2) {\\r\\n const nextHeight = updatedElement.height + _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING * 2;\\r\\n originalContainerHeight = nextHeight;\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(container, {\\r\\n height: nextHeight\\r\\n });\\r\\n container = _objectSpread(_objectSpread({}, container), {}, {\\r\\n height: nextHeight\\r\\n });\\r\\n } // update height of the editor after properties updated\\r\\n height = updatedElement.height;\\r\\n }\\r\\n if (!originalContainerHeight) {\\r\\n originalContainerHeight = container.height;\\r\\n }\\r\\n maxWidth = container.width - _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING * 2;\\r\\n maxHeight = container.height - _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING * 2;\\r\\n width = maxWidth; // The coordinates of text box set a distance of\\r\\n // 30px to preserve padding\\r\\n coordX = container.x + _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING; // autogrow container height if text exceeds\\r\\n if (height > maxHeight) {\\r\\n const diff = Math.min(height - maxHeight, approxLineHeight);\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(container, {\\r\\n height: container.height + diff\\r\\n });\\r\\n return;\\r\\n }\\r\\n else if ( // autoshrink container height until original container height\\r\\n // is reached when text is removed\\r\\n container.height > originalContainerHeight && height < maxHeight) {\\r\\n const diff = Math.min(maxHeight - height, approxLineHeight);\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(container, {\\r\\n height: container.height - diff\\r\\n });\\r\\n } // Start pushing text upward until a diff of 30px (padding)\\r\\n // is reached\\r\\n else {\\r\\n // vertically center align the text\\r\\n coordY = container.y + container.height / 2 - height / 2;\\r\\n }\\r\\n }\\r\\n const [viewportX, viewportY] = getViewportCoords(coordX, coordY);\\r\\n const { textAlign, angle } = updatedElement;\\r\\n editable.value = updatedElement.originalText || updatedElement.text;\\r\\n const lines = updatedElement.originalText.split(\\\"\\\\n\\\");\\r\\n const lineHeight = updatedElement.containerId ? approxLineHeight : updatedElement.height / lines.length;\\r\\n if (!container) {\\r\\n maxWidth = (appState.width - 8 - ((appState.scrollX + updatedElement.x) * appState.zoom.value + appState.zoom.translation.x)) / appState.zoom.value - // margin-right of parent if any\\r\\n Number(getComputedStyle(excalidrawContainer === null || excalidrawContainer === void 0 ? void 0 : excalidrawContainer.parentNode).marginRight.slice(0, -2));\\r\\n } // Make sure text editor height doesn't go beyond viewport\\r\\n const editorMaxHeight = (appState.height - viewportY - ( // There is a ~14px difference which keeps on increasing\\r\\n // with every zoom step when offset present hence I am subtracting it here\\r\\n // However this is not the best fix and breaks in\\r\\n // few scenarios\\r\\n appState.offsetTop ? (appState.zoom.value * 100 - 100) / 10 * 14 : 0)) / appState.zoom.value;\\r\\n Object.assign(editable.style, {\\r\\n font: (0,_utils__WEBPACK_IMPORTED_MODULE_2__.getFontString)(updatedElement),\\r\\n // must be defined *after* font ¯\\\\_(ツ)_/¯\\r\\n lineHeight: `${lineHeight}px`,\\r\\n width: `${width}px`,\\r\\n height: `${height}px`,\\r\\n left: `${viewportX}px`,\\r\\n top: `${viewportY}px`,\\r\\n transform: getTransform(width, height, angle, appState, maxWidth, editorMaxHeight),\\r\\n textAlign,\\r\\n color: updatedElement.strokeColor,\\r\\n opacity: updatedElement.opacity / 100,\\r\\n filter: \\\"var(--theme-filter)\\\",\\r\\n maxWidth: `${maxWidth}px`,\\r\\n maxHeight: `${editorMaxHeight}px`\\r\\n });\\r\\n }\\r\\n };\\r\\n const editable = document.createElement(\\\"textarea\\\");\\r\\n editable.dir = \\\"auto\\\";\\r\\n editable.tabIndex = 0;\\r\\n editable.dataset.type = \\\"wysiwyg\\\"; // prevent line wrapping on Safari\\r\\n editable.wrap = \\\"off\\\";\\r\\n editable.classList.add(\\\"excalidraw-wysiwyg\\\");\\r\\n let whiteSpace = \\\"pre\\\";\\r\\n let wordBreak = \\\"normal\\\";\\r\\n if ((0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isBoundToContainer)(element)) {\\r\\n whiteSpace = \\\"pre-wrap\\\";\\r\\n wordBreak = \\\"break-word\\\";\\r\\n }\\r\\n Object.assign(editable.style, {\\r\\n position: \\\"absolute\\\",\\r\\n display: \\\"inline-block\\\",\\r\\n minHeight: \\\"1em\\\",\\r\\n backfaceVisibility: \\\"hidden\\\",\\r\\n margin: 0,\\r\\n padding: 0,\\r\\n border: 0,\\r\\n outline: 0,\\r\\n resize: \\\"none\\\",\\r\\n background: \\\"transparent\\\",\\r\\n overflow: \\\"hidden\\\",\\r\\n // must be specified because in dark mode canvas creates a stacking context\\r\\n zIndex: \\\"var(--zIndex-wysiwyg)\\\",\\r\\n wordBreak,\\r\\n // prevent line wrapping (`whitespace: nowrap` doesn't work on FF)\\r\\n whiteSpace,\\r\\n overflowWrap: \\\"break-word\\\"\\r\\n });\\r\\n updateWysiwygStyle();\\r\\n if (onChange) {\\r\\n editable.oninput = function () {\\r\\n // using scrollHeight here since we need to calculate\\r\\n // number of lines so cannot use editable.style.height\\r\\n // as that gets updated below\\r\\n const lines = editable.scrollHeight / approxLineHeight; // auto increase height only when lines > 1 so its\\r\\n // measured correctly and vertically alignes for\\r\\n // first line as well as setting height to \\\"auto\\\"\\r\\n // doubles the height as soon as user starts typing\\r\\n if ((0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isBoundToContainer)(element) && lines > 1) {\\r\\n let height = \\\"auto\\\";\\r\\n if (lines === 2) {\\r\\n const container = _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(element).getElement(element.containerId);\\r\\n const actualLineCount = (0,_textElement__WEBPACK_IMPORTED_MODULE_7__.wrapText)(editable.value, (0,_utils__WEBPACK_IMPORTED_MODULE_2__.getFontString)(element), container.width).split(\\\"\\\\n\\\").length; // This is browser behaviour when setting height to \\\"auto\\\"\\r\\n // It sets the height needed for 2 lines even if actual\\r\\n // line count is 1 as mentioned above as well\\r\\n // hence reducing the height by half if actual line count is 1\\r\\n // so single line aligns vertically when deleting\\r\\n if (actualLineCount === 1) {\\r\\n height = `${editable.scrollHeight / 2}px`;\\r\\n }\\r\\n }\\r\\n editable.style.height = height;\\r\\n editable.style.height = `${editable.scrollHeight}px`;\\r\\n }\\r\\n onChange(normalizeText(editable.value));\\r\\n };\\r\\n }\\r\\n editable.onkeydown = function (event) {\\r\\n event.stopPropagation();\\r\\n if (event.key === _keys__WEBPACK_IMPORTED_MODULE_1__.KEYS.ESCAPE) {\\r\\n event.preventDefault();\\r\\n submittedViaKeyboard = true;\\r\\n handleSubmit();\\r\\n }\\r\\n else if (event.key === _keys__WEBPACK_IMPORTED_MODULE_1__.KEYS.ENTER && event[_keys__WEBPACK_IMPORTED_MODULE_1__.KEYS.CTRL_OR_CMD]) {\\r\\n event.preventDefault();\\r\\n if (event.isComposing || event.keyCode === 229) {\\r\\n return;\\r\\n }\\r\\n submittedViaKeyboard = true;\\r\\n handleSubmit();\\r\\n }\\r\\n else if (event.key === _keys__WEBPACK_IMPORTED_MODULE_1__.KEYS.TAB || event[_keys__WEBPACK_IMPORTED_MODULE_1__.KEYS.CTRL_OR_CMD] && (event.code === _keys__WEBPACK_IMPORTED_MODULE_1__.CODES.BRACKET_LEFT || event.code === _keys__WEBPACK_IMPORTED_MODULE_1__.CODES.BRACKET_RIGHT)) {\\r\\n event.preventDefault();\\r\\n if (event.shiftKey || event.code === _keys__WEBPACK_IMPORTED_MODULE_1__.CODES.BRACKET_LEFT) {\\r\\n outdent();\\r\\n }\\r\\n else {\\r\\n indent();\\r\\n } // We must send an input event to resize the element\\r\\n editable.dispatchEvent(new Event(\\\"input\\\"));\\r\\n }\\r\\n };\\r\\n const TAB_SIZE = 4;\\r\\n const TAB = \\\" \\\".repeat(TAB_SIZE);\\r\\n const RE_LEADING_TAB = new RegExp(`^ {1,${TAB_SIZE}}`);\\r\\n const indent = function () {\\r\\n const { selectionStart, selectionEnd } = editable;\\r\\n const linesStartIndices = getSelectedLinesStartIndices();\\r\\n let value = editable.value;\\r\\n linesStartIndices.forEach(function (startIndex) {\\r\\n const startValue = value.slice(0, startIndex);\\r\\n const endValue = value.slice(startIndex);\\r\\n value = `${startValue}${TAB}${endValue}`;\\r\\n });\\r\\n editable.value = value;\\r\\n editable.selectionStart = selectionStart + TAB_SIZE;\\r\\n editable.selectionEnd = selectionEnd + TAB_SIZE * linesStartIndices.length;\\r\\n };\\r\\n const outdent = function () {\\r\\n const { selectionStart, selectionEnd } = editable;\\r\\n const linesStartIndices = getSelectedLinesStartIndices();\\r\\n const removedTabs = [];\\r\\n let value = editable.value;\\r\\n linesStartIndices.forEach(function (startIndex) {\\r\\n const tabMatch = value.slice(startIndex, startIndex + TAB_SIZE).match(RE_LEADING_TAB);\\r\\n if (tabMatch) {\\r\\n const startValue = value.slice(0, startIndex);\\r\\n const endValue = value.slice(startIndex + tabMatch[0].length); // Delete a tab from the line\\r\\n value = `${startValue}${endValue}`;\\r\\n removedTabs.push(startIndex);\\r\\n }\\r\\n });\\r\\n editable.value = value;\\r\\n if (removedTabs.length) {\\r\\n if (selectionStart > removedTabs[removedTabs.length - 1]) {\\r\\n editable.selectionStart = Math.max(selectionStart - TAB_SIZE, removedTabs[removedTabs.length - 1]);\\r\\n }\\r\\n else {\\r\\n // If the cursor is before the first tab removed, ex:\\r\\n // Line| #1\\r\\n // Line #2\\r\\n // Lin|e #3\\r\\n // we should reset the selectionStart to his initial value.\\r\\n editable.selectionStart = selectionStart;\\r\\n }\\r\\n editable.selectionEnd = Math.max(editable.selectionStart, selectionEnd - TAB_SIZE * removedTabs.length);\\r\\n }\\r\\n };\\r\\n /**\\r\\n * @returns indeces of start positions of selected lines, in reverse order\\r\\n */\\r\\n const getSelectedLinesStartIndices = function () {\\r\\n let { selectionStart, selectionEnd, value } = editable; // chars before selectionStart on the same line\\r\\n const startOffset = value.slice(0, selectionStart).match(/[^\\\\n]*$/)[0].length; // put caret at the start of the line\\r\\n selectionStart = selectionStart - startOffset;\\r\\n const selected = value.slice(selectionStart, selectionEnd);\\r\\n return selected.split(\\\"\\\\n\\\").reduce(function (startIndices, line, idx, lines) {\\r\\n return startIndices.concat(idx ? // curr line index is prev line's start + prev line's length + \\\\n\\r\\n startIndices[idx - 1] + lines[idx - 1].length + 1 : // first selected line\\r\\n selectionStart);\\r\\n }, []).reverse();\\r\\n };\\r\\n const stopEvent = function (event) {\\r\\n event.preventDefault();\\r\\n event.stopPropagation();\\r\\n }; // using a state variable instead of passing it to the handleSubmit callback\\r\\n // so that we don't need to create separate a callback for event handlers\\r\\n let submittedViaKeyboard = false;\\r\\n const handleSubmit = function () {\\r\\n var _a, _b;\\r\\n // cleanup must be run before onSubmit otherwise when app blurs the wysiwyg\\r\\n // it'd get stuck in an infinite loop of blur→onSubmit after we re-focus the\\r\\n // wysiwyg on update\\r\\n cleanup();\\r\\n const updateElement = (_a = _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(element)) === null || _a === void 0 ? void 0 : _a.getElement(element.id);\\r\\n if (!updateElement) {\\r\\n return;\\r\\n }\\r\\n let wrappedText = \\\"\\\";\\r\\n if ((0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isTextElement)(updateElement) && (updateElement === null || updateElement === void 0 ? void 0 : updateElement.containerId)) {\\r\\n const container = _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(updateElement).getElement(updateElement.containerId);\\r\\n if (container) {\\r\\n wrappedText = (0,_textElement__WEBPACK_IMPORTED_MODULE_7__.wrapText)(editable.value, (0,_utils__WEBPACK_IMPORTED_MODULE_2__.getFontString)(updateElement), container.width);\\r\\n if ((0,_typeChecks__WEBPACK_IMPORTED_MODULE_4__.isTextElement)(updateElement) && updateElement.containerId) {\\r\\n const editorHeight = Number(editable.style.height.slice(0, -2));\\r\\n if (editable.value) {\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(updateElement, {\\r\\n // vertically center align\\r\\n y: container.y + container.height / 2 - editorHeight / 2,\\r\\n height: editorHeight,\\r\\n width: Number(editable.style.width.slice(0, -2)),\\r\\n // preserve padding\\r\\n x: container.x + _constants__WEBPACK_IMPORTED_MODULE_5__.PADDING\\r\\n });\\r\\n const boundTextElementId = (0,_textElement__WEBPACK_IMPORTED_MODULE_7__.getBoundTextElementId)(container);\\r\\n if (!boundTextElementId || boundTextElementId !== element.id) {\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(container, {\\r\\n boundElements: (container.boundElements || []).concat({\\r\\n type: \\\"text\\\",\\r\\n id: element.id\\r\\n })\\r\\n });\\r\\n }\\r\\n }\\r\\n else {\\r\\n (0,_mutateElement__WEBPACK_IMPORTED_MODULE_6__.mutateElement)(container, {\\r\\n boundElements: (_b = container.boundElements) === null || _b === void 0 ? void 0 : _b.filter(function (ele) {\\r\\n return ele.type !== \\\"text\\\";\\r\\n })\\r\\n });\\r\\n }\\r\\n }\\r\\n }\\r\\n }\\r\\n else {\\r\\n wrappedText = editable.value;\\r\\n }\\r\\n onSubmit({\\r\\n text: normalizeText(wrappedText),\\r\\n viaKeyboard: submittedViaKeyboard,\\r\\n originalText: editable.value\\r\\n });\\r\\n };\\r\\n const cleanup = function () {\\r\\n if (isDestroyed) {\\r\\n return;\\r\\n }\\r\\n isDestroyed = true; // remove events to ensure they don't late-fire\\r\\n editable.onblur = null;\\r\\n editable.oninput = null;\\r\\n editable.onkeydown = null;\\r\\n if (observer) {\\r\\n observer.disconnect();\\r\\n }\\r\\n window.removeEventListener(\\\"resize\\\", updateWysiwygStyle);\\r\\n window.removeEventListener(\\\"wheel\\\", stopEvent, true);\\r\\n window.removeEventListener(\\\"pointerdown\\\", onPointerDown);\\r\\n window.removeEventListener(\\\"pointerup\\\", bindBlurEvent);\\r\\n window.removeEventListener(\\\"blur\\\", handleSubmit);\\r\\n unbindUpdate();\\r\\n editable.remove();\\r\\n };\\r\\n const bindBlurEvent = function (event) {\\r\\n window.removeEventListener(\\\"pointerup\\\", bindBlurEvent); // Deferred so that the pointerdown that initiates the wysiwyg doesn't\\r\\n // trigger the blur on ensuing pointerup.\\r\\n // Also to handle cases such as picking a color which would trigger a blur\\r\\n // in that same tick.\\r\\n const target = event === null || event === void 0 ? void 0 : event.target;\\r\\n const isTargetColorPicker = target instanceof HTMLInputElement && target.closest(\\\".color-picker-input\\\") && (0,_utils__WEBPACK_IMPORTED_MODULE_2__.isWritableElement)(target);\\r\\n setTimeout(function () {\\r\\n editable.onblur = handleSubmit;\\r\\n if (target && isTargetColorPicker) {\\r\\n target.onblur = function () {\\r\\n editable.focus();\\r\\n };\\r\\n } // case: clicking on the same property → no change → no update → no focus\\r\\n if (!isTargetColorPicker) {\\r\\n editable.focus();\\r\\n }\\r\\n });\\r\\n }; // prevent blur when changing properties from the menu\\r\\n const onPointerDown = function (event) {\\r\\n const isTargetColorPicker = event.target instanceof HTMLInputElement && event.target.closest(\\\".color-picker-input\\\") && (0,_utils__WEBPACK_IMPORTED_MODULE_2__.isWritableElement)(event.target);\\r\\n if ((event.target instanceof HTMLElement || event.target instanceof SVGElement) && event.target.closest(`.${_constants__WEBPACK_IMPORTED_MODULE_5__.CLASSES.SHAPE_ACTIONS_MENU}`) && !(0,_utils__WEBPACK_IMPORTED_MODULE_2__.isWritableElement)(event.target) || isTargetColorPicker) {\\r\\n editable.onblur = null;\\r\\n window.addEventListener(\\\"pointerup\\\", bindBlurEvent); // handle edge-case where pointerup doesn't fire e.g. due to user\\r\\n // alt-tabbing away\\r\\n window.addEventListener(\\\"blur\\\", handleSubmit);\\r\\n }\\r\\n }; // handle updates of textElement properties of editing element\\r\\n const unbindUpdate = _scene_Scene__WEBPACK_IMPORTED_MODULE_3__[\\\"default\\\"].getScene(element).addCallback(function () {\\r\\n var _a;\\r\\n updateWysiwygStyle();\\r\\n const isColorPickerActive = !!((_a = document.activeElement) === null || _a === void 0 ? void 0 : _a.closest(\\\".color-picker-input\\\"));\\r\\n if (!isColorPickerActive) {\\r\\n editable.focus();\\r\\n }\\r\\n }); // ---------------------------------------------------------------------------\\r\\n let isDestroyed = false; // select on init (focusing is done separately inside the bindBlurEvent()\\r\\n // because we need it to happen *after* the blur event from `pointerdown`)\\r\\n editable.select();\\r\\n bindBlurEvent(); // reposition wysiwyg in case of canvas is resized. Using ResizeObserver\\r\\n // is preferred so we catch changes from host, where window may not resize.\\r\\n let observer = null;\\r\\n if (canvas && \\\"ResizeObserver\\\" in window) {\\r\\n observer = new window.ResizeObserver(function () {\\r\\n updateWysiwygStyle();\\r\\n });\\r\\n observer.observe(canvas);\\r\\n }\\r\\n else {\\r\\n window.addEventListener(\\\"resize\\\", updateWysiwygStyle);\\r\\n }\\r\\n window.addEventListener(\\\"pointerdown\\\", onPointerDown);\\r\\n window.addEventListener(\\\"wheel\\\", stopEvent, {\\r\\n passive: false,\\r\\n capture: true\\r\\n });\\r\\n excalidrawContainer === null || excalidrawContainer === void 0 ? void 0 : excalidrawContainer.querySelector(\\\".excalidraw-textEditorContainer\\\").appendChild(editable);\\r\\n};\\r\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../element/textWysiwyg.tsx.js","mappings":";;;;;;;;;;;;AAAoE;AAEpE,SAAS,OAAO,CAAC,MAAM,EAAE,cAAc,IAAI,IAAI,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,qBAAqB,EAAE;IAAE,IAAI,OAAO,GAAG,MAAM,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;IAAC,IAAI,cAAc,EAAE;QAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,UAAU,GAAG,IAAI,OAAO,MAAM,CAAC,wBAAwB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;KAAE;IAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;CAAE,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC;AAEzV,SAAS,aAAa,CAAC,MAAM,IAAI,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;IAAE,IAAI,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAAC,IAAI,CAAC,GAAG,CAAC,EAAE;QAAE,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,CAAC,OAAO,CAAC,UAAU,GAAG,IAAI,iFAAe,CAAC,MAAM,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KAAE;SAAM,IAAI,MAAM,CAAC,yBAAyB,EAAE;QAAE,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,MAAM,CAAC,yBAAyB,CAAC,MAAM,CAAC,CAAC,CAAC;KAAE;SAAM;QAAE,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,GAAG,IAAI,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,GAAG,EAAE,MAAM,CAAC,wBAAwB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KAAE;CAAE,CAAC,OAAO,MAAM,CAAC,CAAC,CAAC;AAEhf;AAC2C;AAC9C;AAC8B;AACjB;AACA;AACqC;AAErF,MAAM,aAAa,GAAG,UAAU,IAAI;IAClC,OAAO,IAAI,CAAC,gEAAgE;SAC3E,OAAO,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,qBAAqB;SAChD,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;AAC9B,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,UAAU,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS;IAChF,MAAM,EACJ,IAAI,EACJ,SAAS,EACT,UAAU,EACX,GAAG,QAAQ,CAAC;IACb,MAAM,MAAM,GAAG,GAAG,GAAG,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,sEAAsE;IAC5G,kCAAkC;IAElC,IAAI,UAAU,GAAG,CAAC,KAAK,GAAG,UAAU,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IACjE,IAAI,UAAU,GAAG,CAAC,MAAM,GAAG,SAAS,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IAEjE,IAAI,KAAK,GAAG,QAAQ,IAAI,IAAI,CAAC,KAAK,KAAK,CAAC,EAAE;QACxC,UAAU,GAAG,CAAC,QAAQ,GAAG,UAAU,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;KACjE;IAED,IAAI,MAAM,GAAG,SAAS,IAAI,IAAI,CAAC,KAAK,KAAK,CAAC,EAAE;QAC1C,UAAU,GAAG,CAAC,SAAS,GAAG,SAAS,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;KACjE;IAED,OAAO,aAAa,UAAU,OAAO,UAAU,aAAa,IAAI,CAAC,KAAK,YAAY,MAAM,MAAM,CAAC;AACjG,CAAC,CAAC;AAEK,MAAM,WAAW,GAAG,UAAU,IAAI;IACvC,IAAI,EACF,EAAE,EACF,QAAQ,EACR,QAAQ,EACR,QAAQ,EACR,iBAAiB,EACjB,OAAO,EACP,MAAM,EACN,mBAAmB,EACpB,GAAG,IAAI,CAAC;IAET,MAAM,qBAAqB,GAAG,UAAU,cAAc,EAAE,QAAQ;QAC9D,MAAM,WAAW,GAAG,QAAQ,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QAElE,IAAI,2DAAmB,CAAC;YACtB,UAAU,EAAE,cAAc,CAAC,UAAU;SACtC,CAAC,KAAK,WAAW,EAAE;YAClB,OAAO,IAAI,CAAC;SACb;QAED,IAAI,GAAG,cAAc,CAAC,QAAQ,IAAI,KAAK,QAAQ,CAAC,KAAK,CAAC,QAAQ,EAAE;YAC9D,OAAO,IAAI,CAAC;SACb;QAED,OAAO,KAAK,CAAC;IACf,CAAC,CAAC;IAEF,IAAI,uBAAuB,CAAC;IAC5B,IAAI,gBAAgB,GAAG,0DAAa,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,iEAAmB,CAAC,qDAAa,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAEhG,MAAM,kBAAkB,GAAG;;QACzB,MAAM,cAAc,GAAG,mEAAc,CAAC,OAAO,CAAC,0CAAE,UAAU,CAAC,EAAE,CAAC,CAAC;QAE/D,IAAI,cAAc,IAAI,0DAAa,CAAC,cAAc,CAAC,EAAE;YACnD,IAAI,MAAM,GAAG,cAAc,CAAC,CAAC,CAAC;YAC9B,IAAI,MAAM,GAAG,cAAc,CAAC,CAAC,CAAC;YAC9B,IAAI,SAAS,GAAG,eAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,WAAW,EAAC,CAAC,CAAC,6DAAc,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YAC3H,IAAI,QAAQ,GAAG,cAAc,CAAC,KAAK,CAAC;YACpC,IAAI,SAAS,GAAG,cAAc,CAAC,MAAM,CAAC;YACtC,IAAI,KAAK,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC,+CAA+C;YACjF,8CAA8C;YAE9C,IAAI,MAAM,GAAG,cAAc,CAAC,MAAM,CAAC;YAEnC,IAAI,SAAS,IAAI,cAAc,CAAC,WAAW,EAAE;gBAC3C,MAAM,iBAAiB,GAAG,qBAAqB,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC,CAAC,sEAAsE;gBAEjJ,MAAM,YAAY,GAAG,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;gBAEhE,IAAI,YAAY,GAAG,CAAC,EAAE;oBACpB,MAAM,GAAG,YAAY,CAAC;iBACvB;gBAED,IAAI,iBAAiB,EAAE;oBACrB,MAAM,gBAAgB,GAAG,mEAAc,CAAC,cAAc,CAAC,0CAAE,UAAU,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;oBAChG,gBAAgB,GAAG,0DAAa,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,iEAAmB,CAAC,qDAAa,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBAE1G,IAAI,cAAc,CAAC,MAAM,GAAG,gBAAgB,CAAC,MAAM,GAAG,+CAAO,GAAG,CAAC,EAAE;wBACjE,MAAM,UAAU,GAAG,cAAc,CAAC,MAAM,GAAG,+CAAO,GAAG,CAAC,CAAC;wBACvD,uBAAuB,GAAG,UAAU,CAAC;wBACrC,6DAAa,CAAC,SAAS,EAAE;4BACvB,MAAM,EAAE,UAAU;yBACnB,CAAC,CAAC;wBACH,SAAS,GAAG,aAAa,CAAC,aAAa,CAAC,EAAE,EAAE,SAAS,CAAC,EAAE,EAAE,EAAE;4BAC1D,MAAM,EAAE,UAAU;yBACnB,CAAC,CAAC;qBACJ,CAAC,uDAAuD;oBAGzD,MAAM,GAAG,cAAc,CAAC,MAAM,CAAC;iBAChC;gBAED,IAAI,CAAC,uBAAuB,EAAE;oBAC5B,uBAAuB,GAAG,SAAS,CAAC,MAAM,CAAC;iBAC5C;gBAED,QAAQ,GAAG,SAAS,CAAC,KAAK,GAAG,+CAAO,GAAG,CAAC,CAAC;gBACzC,SAAS,GAAG,SAAS,CAAC,MAAM,GAAG,+CAAO,GAAG,CAAC,CAAC;gBAC3C,KAAK,GAAG,QAAQ,CAAC,CAAC,gDAAgD;gBAClE,2BAA2B;gBAE3B,MAAM,GAAG,SAAS,CAAC,CAAC,GAAG,+CAAO,CAAC,CAAC,4CAA4C;gBAE5E,IAAI,MAAM,GAAG,SAAS,EAAE;oBACtB,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,SAAS,EAAE,gBAAgB,CAAC,CAAC;oBAC5D,6DAAa,CAAC,SAAS,EAAE;wBACvB,MAAM,EAAE,SAAS,CAAC,MAAM,GAAG,IAAI;qBAChC,CAAC,CAAC;oBACH,OAAO;iBACR;qBAAM,KAAK,8DAA8D;gBAC1E,kCAAkC;gBAClC,SAAS,CAAC,MAAM,GAAG,uBAAuB,IAAI,MAAM,GAAG,SAAS,EAAE;oBAChE,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,MAAM,EAAE,gBAAgB,CAAC,CAAC;oBAC5D,6DAAa,CAAC,SAAS,EAAE;wBACvB,MAAM,EAAE,SAAS,CAAC,MAAM,GAAG,IAAI;qBAChC,CAAC,CAAC;iBACJ,CAAC,2DAA2D;gBAC7D,aAAa;qBACR;oBACH,mCAAmC;oBACnC,MAAM,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,MAAM,GAAG,CAAC,GAAG,MAAM,GAAG,CAAC,CAAC;iBAC1D;aACF;YAED,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,GAAG,iBAAiB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;YACjE,MAAM,EACJ,SAAS,EACT,KAAK,EACN,GAAG,cAAc,CAAC;YACnB,QAAQ,CAAC,KAAK,GAAG,cAAc,CAAC,YAAY,IAAI,cAAc,CAAC,IAAI,CAAC;YACpE,MAAM,KAAK,GAAG,cAAc,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACtD,MAAM,UAAU,GAAG,cAAc,CAAC,WAAW,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,cAAc,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;YAExG,IAAI,CAAC,SAAS,EAAE;gBACd,QAAQ,GAAG,CAAC,QAAQ,CAAC,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,OAAO,GAAG,cAAc,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,GAAG,gCAAgC;oBACtL,MAAM,CAAC,gBAAgB,CAAC,mBAAmB,aAAnB,mBAAmB,uBAAnB,mBAAmB,CAAE,UAAU,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;aACpF,CAAC,0DAA0D;YAG5D,MAAM,eAAe,GAAG,CAAC,QAAQ,CAAC,MAAM,GAAG,SAAS,GAAG,EAAE,wDAAwD;YACjH,0EAA0E;YAC1E,iDAAiD;YACjD,gBAAgB;YAChB,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC;YAC7F,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE;gBAC5B,IAAI,EAAE,qDAAa,CAAC,cAAc,CAAC;gBACnC,yCAAyC;gBACzC,UAAU,EAAE,GAAG,UAAU,IAAI;gBAC7B,KAAK,EAAE,GAAG,KAAK,IAAI;gBACnB,MAAM,EAAE,GAAG,MAAM,IAAI;gBACrB,IAAI,EAAE,GAAG,SAAS,IAAI;gBACtB,GAAG,EAAE,GAAG,SAAS,IAAI;gBACrB,SAAS,EAAE,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,eAAe,CAAC;gBAClF,SAAS;gBACT,KAAK,EAAE,cAAc,CAAC,WAAW;gBACjC,OAAO,EAAE,cAAc,CAAC,OAAO,GAAG,GAAG;gBACrC,MAAM,EAAE,qBAAqB;gBAC7B,QAAQ,EAAE,GAAG,QAAQ,IAAI;gBACzB,SAAS,EAAE,GAAG,eAAe,IAAI;aAClC,CAAC,CAAC;SACJ;IACH,CAAC,CAAC;IAEF,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IACpD,QAAQ,CAAC,GAAG,GAAG,MAAM,CAAC;IACtB,QAAQ,CAAC,QAAQ,GAAG,CAAC,CAAC;IACtB,QAAQ,CAAC,OAAO,CAAC,IAAI,GAAG,SAAS,CAAC,CAAC,kCAAkC;IAErE,QAAQ,CAAC,IAAI,GAAG,KAAK,CAAC;IACtB,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;IAC7C,IAAI,UAAU,GAAG,KAAK,CAAC;IACvB,IAAI,SAAS,GAAG,QAAQ,CAAC;IAEzB,IAAI,+DAAkB,CAAC,OAAO,CAAC,EAAE;QAC/B,UAAU,GAAG,UAAU,CAAC;QACxB,SAAS,GAAG,YAAY,CAAC;KAC1B;IAED,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE;QAC5B,QAAQ,EAAE,UAAU;QACpB,OAAO,EAAE,cAAc;QACvB,SAAS,EAAE,KAAK;QAChB,kBAAkB,EAAE,QAAQ;QAC5B,MAAM,EAAE,CAAC;QACT,OAAO,EAAE,CAAC;QACV,MAAM,EAAE,CAAC;QACT,OAAO,EAAE,CAAC;QACV,MAAM,EAAE,MAAM;QACd,UAAU,EAAE,aAAa;QACzB,QAAQ,EAAE,QAAQ;QAClB,2EAA2E;QAC3E,MAAM,EAAE,uBAAuB;QAC/B,SAAS;QACT,kEAAkE;QAClE,UAAU;QACV,YAAY,EAAE,YAAY;KAC3B,CAAC,CAAC;IACH,kBAAkB,EAAE,CAAC;IAErB,IAAI,QAAQ,EAAE;QACZ,QAAQ,CAAC,OAAO,GAAG;YACjB,qDAAqD;YACrD,sDAAsD;YACtD,6BAA6B;YAC7B,MAAM,KAAK,GAAG,QAAQ,CAAC,YAAY,GAAG,gBAAgB,CAAC,CAAC,mDAAmD;YAC3G,gDAAgD;YAChD,iDAAiD;YACjD,mDAAmD;YAEnD,IAAI,+DAAkB,CAAC,OAAO,CAAC,IAAI,KAAK,GAAG,CAAC,EAAE;gBAC5C,IAAI,MAAM,GAAG,MAAM,CAAC;gBAEpB,IAAI,KAAK,KAAK,CAAC,EAAE;oBACf,MAAM,SAAS,GAAG,6DAAc,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;oBAC1E,MAAM,eAAe,GAAG,sDAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE,qDAAa,CAAC,OAAO,CAAC,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,0DAA0D;oBACxK,uDAAuD;oBACvD,6CAA6C;oBAC7C,8DAA8D;oBAC9D,iDAAiD;oBAEjD,IAAI,eAAe,KAAK,CAAC,EAAE;wBACzB,MAAM,GAAG,GAAG,QAAQ,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC;qBAC3C;iBACF;gBAED,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;gBAC/B,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,QAAQ,CAAC,YAAY,IAAI,CAAC;aACtD;YAED,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAC1C,CAAC,CAAC;KACH;IAED,QAAQ,CAAC,SAAS,GAAG,UAAU,KAAK;QAClC,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,KAAK,CAAC,GAAG,KAAK,8CAAW,EAAE;YAC7B,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,oBAAoB,GAAG,IAAI,CAAC;YAC5B,YAAY,EAAE,CAAC;SAChB;aAAM,IAAI,KAAK,CAAC,GAAG,KAAK,6CAAU,IAAI,KAAK,CAAC,mDAAgB,CAAC,EAAE;YAC9D,KAAK,CAAC,cAAc,EAAE,CAAC;YAEvB,IAAI,KAAK,CAAC,WAAW,IAAI,KAAK,CAAC,OAAO,KAAK,GAAG,EAAE;gBAC9C,OAAO;aACR;YAED,oBAAoB,GAAG,IAAI,CAAC;YAC5B,YAAY,EAAE,CAAC;SAChB;aAAM,IAAI,KAAK,CAAC,GAAG,KAAK,2CAAQ,IAAI,KAAK,CAAC,mDAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,KAAK,qDAAkB,IAAI,KAAK,CAAC,IAAI,KAAK,sDAAmB,CAAC,EAAE;YACzI,KAAK,CAAC,cAAc,EAAE,CAAC;YAEvB,IAAI,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,IAAI,KAAK,qDAAkB,EAAE;gBACvD,OAAO,EAAE,CAAC;aACX;iBAAM;gBACL,MAAM,EAAE,CAAC;aACV,CAAC,oDAAoD;YAGtD,QAAQ,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;SAC5C;IACH,CAAC,CAAC;IAEF,MAAM,QAAQ,GAAG,CAAC,CAAC;IACnB,MAAM,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACjC,MAAM,cAAc,GAAG,IAAI,MAAM,CAAC,QAAQ,QAAQ,GAAG,CAAC,CAAC;IAEvD,MAAM,MAAM,GAAG;QACb,MAAM,EACJ,cAAc,EACd,YAAY,EACb,GAAG,QAAQ,CAAC;QACb,MAAM,iBAAiB,GAAG,4BAA4B,EAAE,CAAC;QACzD,IAAI,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC;QAC3B,iBAAiB,CAAC,OAAO,CAAC,UAAU,UAAU;YAC5C,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;YAC9C,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YACzC,KAAK,GAAG,GAAG,UAAU,GAAG,GAAG,GAAG,QAAQ,EAAE,CAAC;QAC3C,CAAC,CAAC,CAAC;QACH,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;QACvB,QAAQ,CAAC,cAAc,GAAG,cAAc,GAAG,QAAQ,CAAC;QACpD,QAAQ,CAAC,YAAY,GAAG,YAAY,GAAG,QAAQ,GAAG,iBAAiB,CAAC,MAAM,CAAC;IAC7E,CAAC,CAAC;IAEF,MAAM,OAAO,GAAG;QACd,MAAM,EACJ,cAAc,EACd,YAAY,EACb,GAAG,QAAQ,CAAC;QACb,MAAM,iBAAiB,GAAG,4BAA4B,EAAE,CAAC;QACzD,MAAM,WAAW,GAAG,EAAE,CAAC;QACvB,IAAI,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC;QAC3B,iBAAiB,CAAC,OAAO,CAAC,UAAU,UAAU;YAC5C,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,UAAU,EAAE,UAAU,GAAG,QAAQ,CAAC,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;YAEtF,IAAI,QAAQ,EAAE;gBACZ,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;gBAC9C,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,6BAA6B;gBAE5F,KAAK,GAAG,GAAG,UAAU,GAAG,QAAQ,EAAE,CAAC;gBACnC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aAC9B;QACH,CAAC,CAAC,CAAC;QACH,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;QAEvB,IAAI,WAAW,CAAC,MAAM,EAAE;YACtB,IAAI,cAAc,GAAG,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE;gBACxD,QAAQ,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,cAAc,GAAG,QAAQ,EAAE,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;aACpG;iBAAM;gBACL,qDAAqD;gBACrD,WAAW;gBACX,cAAc;gBACd,WAAW;gBACX,2DAA2D;gBAC3D,QAAQ,CAAC,cAAc,GAAG,cAAc,CAAC;aAC1C;YAED,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAc,EAAE,YAAY,GAAG,QAAQ,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC;SACzG;IACH,CAAC,CAAC;IACF;;OAEG;IAGH,MAAM,4BAA4B,GAAG;QACnC,IAAI,EACF,cAAc,EACd,YAAY,EACZ,KAAK,EACN,GAAG,QAAQ,CAAC,CAAC,+CAA+C;QAE7D,MAAM,WAAW,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,cAAc,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,qCAAqC;QAEpH,cAAc,GAAG,cAAc,GAAG,WAAW,CAAC;QAC9C,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,cAAc,EAAE,YAAY,CAAC,CAAC;QAC3D,OAAO,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,UAAU,YAAY,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK;YACzE,OAAO,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,iEAAiE;gBAClG,YAAY,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,sBAAsB;gBAC1E,cAAc,CAAC,CAAC;QAClB,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC,CAAC;IAEF,MAAM,SAAS,GAAG,UAAU,KAAK;QAC/B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC,CAAC,CAAC,4EAA4E;IAC/E,yEAAyE;IAGzE,IAAI,oBAAoB,GAAG,KAAK,CAAC;IAEjC,MAAM,YAAY,GAAG;;QACnB,2EAA2E;QAC3E,4EAA4E;QAC5E,oBAAoB;QACpB,OAAO,EAAE,CAAC;QACV,MAAM,aAAa,GAAG,mEAAc,CAAC,OAAO,CAAC,0CAAE,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAEtE,IAAI,CAAC,aAAa,EAAE;YAClB,OAAO;SACR;QAED,IAAI,WAAW,GAAG,EAAE,CAAC;QAErB,IAAI,0DAAa,CAAC,aAAa,CAAC,KAAI,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,WAAW,GAAE;YAC9D,MAAM,SAAS,GAAG,6DAAc,CAAC,aAAa,CAAC,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;YAEtF,IAAI,SAAS,EAAE;gBACb,WAAW,GAAG,sDAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE,qDAAa,CAAC,aAAa,CAAC,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC;gBAEtF,IAAI,0DAAa,CAAC,aAAa,CAAC,IAAI,aAAa,CAAC,WAAW,EAAE;oBAC7D,MAAM,YAAY,GAAG,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;oBAEhE,IAAI,QAAQ,CAAC,KAAK,EAAE;wBAClB,6DAAa,CAAC,aAAa,EAAE;4BAC3B,0BAA0B;4BAC1B,CAAC,EAAE,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,MAAM,GAAG,CAAC,GAAG,YAAY,GAAG,CAAC;4BACxD,MAAM,EAAE,YAAY;4BACpB,KAAK,EAAE,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;4BAChD,mBAAmB;4BACnB,CAAC,EAAE,SAAS,CAAC,CAAC,GAAG,+CAAO;yBACzB,CAAC,CAAC;wBACH,MAAM,kBAAkB,GAAG,mEAAqB,CAAC,SAAS,CAAC,CAAC;wBAE5D,IAAI,CAAC,kBAAkB,IAAI,kBAAkB,KAAK,OAAO,CAAC,EAAE,EAAE;4BAC5D,6DAAa,CAAC,SAAS,EAAE;gCACvB,aAAa,EAAE,CAAC,SAAS,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC;oCACpD,IAAI,EAAE,MAAM;oCACZ,EAAE,EAAE,OAAO,CAAC,EAAE;iCACf,CAAC;6BACH,CAAC,CAAC;yBACJ;qBACF;yBAAM;wBACL,6DAAa,CAAC,SAAS,EAAE;4BACvB,aAAa,EAAE,eAAS,CAAC,aAAa,0CAAE,MAAM,CAAC,UAAU,GAAG;gCAC1D,OAAO,GAAG,CAAC,IAAI,KAAK,MAAM,CAAC;4BAC7B,CAAC,CAAC;yBACH,CAAC,CAAC;qBACJ;iBACF;aACF;SACF;aAAM;YACL,WAAW,GAAG,QAAQ,CAAC,KAAK,CAAC;SAC9B;QAED,QAAQ,CAAC;YACP,IAAI,EAAE,aAAa,CAAC,WAAW,CAAC;YAChC,WAAW,EAAE,oBAAoB;YACjC,YAAY,EAAE,QAAQ,CAAC,KAAK;SAC7B,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,MAAM,OAAO,GAAG;QACd,IAAI,WAAW,EAAE;YACf,OAAO;SACR;QAED,WAAW,GAAG,IAAI,CAAC,CAAC,+CAA+C;QAEnE,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC;QACvB,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC;QACxB,QAAQ,CAAC,SAAS,GAAG,IAAI,CAAC;QAE1B,IAAI,QAAQ,EAAE;YACZ,QAAQ,CAAC,UAAU,EAAE,CAAC;SACvB;QAED,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,kBAAkB,CAAC,CAAC;QACzD,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;QACrD,MAAM,CAAC,mBAAmB,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;QACzD,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;QACvD,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;QACjD,YAAY,EAAE,CAAC;QACf,QAAQ,CAAC,MAAM,EAAE,CAAC;IACpB,CAAC,CAAC;IAEF,MAAM,aAAa,GAAG,UAAU,KAAK;QACnC,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC,CAAC,sEAAsE;QAC9H,yCAAyC;QACzC,0EAA0E;QAC1E,qBAAqB;QAErB,MAAM,MAAM,GAAG,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,MAAM,CAAC;QAC7B,MAAM,mBAAmB,GAAG,MAAM,YAAY,gBAAgB,IAAI,MAAM,CAAC,OAAO,CAAC,qBAAqB,CAAC,IAAI,yDAAiB,CAAC,MAAM,CAAC,CAAC;QACrI,UAAU,CAAC;YACT,QAAQ,CAAC,MAAM,GAAG,YAAY,CAAC;YAE/B,IAAI,MAAM,IAAI,mBAAmB,EAAE;gBACjC,MAAM,CAAC,MAAM,GAAG;oBACd,QAAQ,CAAC,KAAK,EAAE,CAAC;gBACnB,CAAC,CAAC;aACH,CAAC,yEAAyE;YAG3E,IAAI,CAAC,mBAAmB,EAAE;gBACxB,QAAQ,CAAC,KAAK,EAAE,CAAC;aAClB;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC,sDAAsD;IAGzD,MAAM,aAAa,GAAG,UAAU,KAAK;QACnC,MAAM,mBAAmB,GAAG,KAAK,CAAC,MAAM,YAAY,gBAAgB,IAAI,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,qBAAqB,CAAC,IAAI,yDAAiB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAEvJ,IAAI,CAAC,KAAK,CAAC,MAAM,YAAY,WAAW,IAAI,KAAK,CAAC,MAAM,YAAY,UAAU,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,kEAA0B,EAAE,CAAC,IAAI,CAAC,yDAAiB,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,mBAAmB,EAAE;YACpM,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC;YACvB,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC,CAAC,iEAAiE;YACtH,mBAAmB;YAEnB,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;SAC/C;IACH,CAAC,CAAC,CAAC,8DAA8D;IAGjE,MAAM,YAAY,GAAG,6DAAc,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC;;QACvD,kBAAkB,EAAE,CAAC;QACrB,MAAM,mBAAmB,GAAG,CAAC,CAAC,eAAQ,CAAC,aAAa,0CAAE,OAAO,CAAC,qBAAqB,CAAC,EAAC;QAErF,IAAI,CAAC,mBAAmB,EAAE;YACxB,QAAQ,CAAC,KAAK,EAAE,CAAC;SAClB;IACH,CAAC,CAAC,CAAC,CAAC,8EAA8E;IAElF,IAAI,WAAW,GAAG,KAAK,CAAC,CAAC,yEAAyE;IAClG,0EAA0E;IAE1E,QAAQ,CAAC,MAAM,EAAE,CAAC;IAClB,aAAa,EAAE,CAAC,CAAC,wEAAwE;IACzF,2EAA2E;IAE3E,IAAI,QAAQ,GAAG,IAAI,CAAC;IAEpB,IAAI,MAAM,IAAI,gBAAgB,IAAI,MAAM,EAAE;QACxC,QAAQ,GAAG,IAAI,MAAM,CAAC,cAAc,CAAC;YACnC,kBAAkB,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QACH,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;KAC1B;SAAM;QACL,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,kBAAkB,CAAC,CAAC;KACvD;IAED,MAAM,CAAC,gBAAgB,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;IACtD,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,SAAS,EAAE;QAC1C,OAAO,EAAE,KAAK;QACd,OAAO,EAAE,IAAI;KACd,CAAC,CAAC;IACH,mBAAmB,aAAnB,mBAAmB,uBAAnB,mBAAmB,CAAE,aAAa,CAAC,iCAAiC,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;AAC9F,CAAC,CAAC","sources":["webpack:///../../element/textWysiwyg.tsx?57fd"],"sourcesContent":["import _defineProperty from \"@babel/runtime/helpers/defineProperty\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { CODES, KEYS } from \"../keys\";\nimport { isWritableElement, getFontString, getFontFamilyString } from \"../utils\";\nimport Scene from \"../scene/Scene\";\nimport { isBoundToContainer, isTextElement } from \"./typeChecks\";\nimport { CLASSES, PADDING } from \"../constants\";\nimport { mutateElement } from \"./mutateElement\";\nimport { getApproxLineHeight, getBoundTextElementId, wrapText } from \"./textElement\";\n\nconst normalizeText = function (text) {\n  return text // replace tabs with spaces so they render and measure correctly\n  .replace(/\\t/g, \"        \") // normalize newlines\n  .replace(/\\r?\\n|\\r/g, \"\\n\");\n};\n\nconst getTransform = function (width, height, angle, appState, maxWidth, maxHeight) {\n  const {\n    zoom,\n    offsetTop,\n    offsetLeft\n  } = appState;\n  const degree = 180 * angle / Math.PI; // offsets must be multiplied by 2 to account for the division by 2 of\n  // the whole expression afterwards\n\n  let translateX = (width - offsetLeft * 2) * (zoom.value - 1) / 2;\n  let translateY = (height - offsetTop * 2) * (zoom.value - 1) / 2;\n\n  if (width > maxWidth && zoom.value !== 1) {\n    translateX = (maxWidth - offsetLeft * 2) * (zoom.value - 1) / 2;\n  }\n\n  if (height > maxHeight && zoom.value !== 1) {\n    translateY = (maxHeight - offsetTop * 2) * (zoom.value - 1) / 2;\n  }\n\n  return `translate(${translateX}px, ${translateY}px) scale(${zoom.value}) rotate(${degree}deg)`;\n};\n\nexport const textWysiwyg = function (_ref) {\n  let {\n    id,\n    appState,\n    onChange,\n    onSubmit,\n    getViewportCoords,\n    element,\n    canvas,\n    excalidrawContainer\n  } = _ref;\n\n  const textPropertiesUpdated = function (updatedElement, editable) {\n    const currentFont = editable.style.fontFamily.replaceAll('\"', \"\");\n\n    if (getFontFamilyString({\n      fontFamily: updatedElement.fontFamily\n    }) !== currentFont) {\n      return true;\n    }\n\n    if (`${updatedElement.fontSize}px` !== editable.style.fontSize) {\n      return true;\n    }\n\n    return false;\n  };\n\n  let originalContainerHeight;\n  let approxLineHeight = isTextElement(element) ? getApproxLineHeight(getFontString(element)) : 0;\n\n  const updateWysiwygStyle = function () {\n    const updatedElement = Scene.getScene(element)?.getElement(id);\n\n    if (updatedElement && isTextElement(updatedElement)) {\n      let coordX = updatedElement.x;\n      let coordY = updatedElement.y;\n      let container = updatedElement?.containerId ? Scene.getScene(updatedElement).getElement(updatedElement.containerId) : null;\n      let maxWidth = updatedElement.width;\n      let maxHeight = updatedElement.height;\n      let width = updatedElement.width; // Set to element height by default since thats\n      // what is going to be used for unbounded text\n\n      let height = updatedElement.height;\n\n      if (container && updatedElement.containerId) {\n        const propertiesUpdated = textPropertiesUpdated(updatedElement, editable); // using editor.style.height to get the accurate height of text editor\n\n        const editorHeight = Number(editable.style.height.slice(0, -2));\n\n        if (editorHeight > 0) {\n          height = editorHeight;\n        }\n\n        if (propertiesUpdated) {\n          const currentContainer = Scene.getScene(updatedElement)?.getElement(updatedElement.containerId);\n          approxLineHeight = isTextElement(updatedElement) ? getApproxLineHeight(getFontString(updatedElement)) : 0;\n\n          if (updatedElement.height > currentContainer.height - PADDING * 2) {\n            const nextHeight = updatedElement.height + PADDING * 2;\n            originalContainerHeight = nextHeight;\n            mutateElement(container, {\n              height: nextHeight\n            });\n            container = _objectSpread(_objectSpread({}, container), {}, {\n              height: nextHeight\n            });\n          } // update height of the editor after properties updated\n\n\n          height = updatedElement.height;\n        }\n\n        if (!originalContainerHeight) {\n          originalContainerHeight = container.height;\n        }\n\n        maxWidth = container.width - PADDING * 2;\n        maxHeight = container.height - PADDING * 2;\n        width = maxWidth; // The coordinates of text box set a distance of\n        // 30px to preserve padding\n\n        coordX = container.x + PADDING; // autogrow container height if text exceeds\n\n        if (height > maxHeight) {\n          const diff = Math.min(height - maxHeight, approxLineHeight);\n          mutateElement(container, {\n            height: container.height + diff\n          });\n          return;\n        } else if ( // autoshrink container height until original container height\n        // is reached when text is removed\n        container.height > originalContainerHeight && height < maxHeight) {\n          const diff = Math.min(maxHeight - height, approxLineHeight);\n          mutateElement(container, {\n            height: container.height - diff\n          });\n        } // Start pushing text upward until a diff of 30px (padding)\n        // is reached\n        else {\n          // vertically center align the text\n          coordY = container.y + container.height / 2 - height / 2;\n        }\n      }\n\n      const [viewportX, viewportY] = getViewportCoords(coordX, coordY);\n      const {\n        textAlign,\n        angle\n      } = updatedElement;\n      editable.value = updatedElement.originalText || updatedElement.text;\n      const lines = updatedElement.originalText.split(\"\\n\");\n      const lineHeight = updatedElement.containerId ? approxLineHeight : updatedElement.height / lines.length;\n\n      if (!container) {\n        maxWidth = (appState.width - 8 - ((appState.scrollX + updatedElement.x) * appState.zoom.value + appState.zoom.translation.x)) / appState.zoom.value - // margin-right of parent if any\n        Number(getComputedStyle(excalidrawContainer?.parentNode).marginRight.slice(0, -2));\n      } // Make sure text editor height doesn't go beyond viewport\n\n\n      const editorMaxHeight = (appState.height - viewportY - ( // There is a ~14px difference which keeps on increasing\n      // with every zoom step when offset present hence I am subtracting it here\n      // However this is not the best fix and breaks in\n      // few scenarios\n      appState.offsetTop ? (appState.zoom.value * 100 - 100) / 10 * 14 : 0)) / appState.zoom.value;\n      Object.assign(editable.style, {\n        font: getFontString(updatedElement),\n        // must be defined *after* font ¯\\_(ツ)_/¯\n        lineHeight: `${lineHeight}px`,\n        width: `${width}px`,\n        height: `${height}px`,\n        left: `${viewportX}px`,\n        top: `${viewportY}px`,\n        transform: getTransform(width, height, angle, appState, maxWidth, editorMaxHeight),\n        textAlign,\n        color: updatedElement.strokeColor,\n        opacity: updatedElement.opacity / 100,\n        filter: \"var(--theme-filter)\",\n        maxWidth: `${maxWidth}px`,\n        maxHeight: `${editorMaxHeight}px`\n      });\n    }\n  };\n\n  const editable = document.createElement(\"textarea\");\n  editable.dir = \"auto\";\n  editable.tabIndex = 0;\n  editable.dataset.type = \"wysiwyg\"; // prevent line wrapping on Safari\n\n  editable.wrap = \"off\";\n  editable.classList.add(\"excalidraw-wysiwyg\");\n  let whiteSpace = \"pre\";\n  let wordBreak = \"normal\";\n\n  if (isBoundToContainer(element)) {\n    whiteSpace = \"pre-wrap\";\n    wordBreak = \"break-word\";\n  }\n\n  Object.assign(editable.style, {\n    position: \"absolute\",\n    display: \"inline-block\",\n    minHeight: \"1em\",\n    backfaceVisibility: \"hidden\",\n    margin: 0,\n    padding: 0,\n    border: 0,\n    outline: 0,\n    resize: \"none\",\n    background: \"transparent\",\n    overflow: \"hidden\",\n    // must be specified because in dark mode canvas creates a stacking context\n    zIndex: \"var(--zIndex-wysiwyg)\",\n    wordBreak,\n    // prevent line wrapping (`whitespace: nowrap` doesn't work on FF)\n    whiteSpace,\n    overflowWrap: \"break-word\"\n  });\n  updateWysiwygStyle();\n\n  if (onChange) {\n    editable.oninput = function () {\n      // using scrollHeight here since we need to calculate\n      // number of lines so cannot use editable.style.height\n      // as that gets updated below\n      const lines = editable.scrollHeight / approxLineHeight; // auto increase height only when lines  > 1 so its\n      // measured correctly and vertically alignes for\n      // first line as well as setting height to \"auto\"\n      // doubles the height as soon as user starts typing\n\n      if (isBoundToContainer(element) && lines > 1) {\n        let height = \"auto\";\n\n        if (lines === 2) {\n          const container = Scene.getScene(element).getElement(element.containerId);\n          const actualLineCount = wrapText(editable.value, getFontString(element), container.width).split(\"\\n\").length; // This is browser behaviour when setting height to \"auto\"\n          // It sets the height needed for 2 lines even if actual\n          // line count is 1 as mentioned above as well\n          // hence reducing the height by half if actual line count is 1\n          // so single line aligns vertically when deleting\n\n          if (actualLineCount === 1) {\n            height = `${editable.scrollHeight / 2}px`;\n          }\n        }\n\n        editable.style.height = height;\n        editable.style.height = `${editable.scrollHeight}px`;\n      }\n\n      onChange(normalizeText(editable.value));\n    };\n  }\n\n  editable.onkeydown = function (event) {\n    event.stopPropagation();\n\n    if (event.key === KEYS.ESCAPE) {\n      event.preventDefault();\n      submittedViaKeyboard = true;\n      handleSubmit();\n    } else if (event.key === KEYS.ENTER && event[KEYS.CTRL_OR_CMD]) {\n      event.preventDefault();\n\n      if (event.isComposing || event.keyCode === 229) {\n        return;\n      }\n\n      submittedViaKeyboard = true;\n      handleSubmit();\n    } else if (event.key === KEYS.TAB || event[KEYS.CTRL_OR_CMD] && (event.code === CODES.BRACKET_LEFT || event.code === CODES.BRACKET_RIGHT)) {\n      event.preventDefault();\n\n      if (event.shiftKey || event.code === CODES.BRACKET_LEFT) {\n        outdent();\n      } else {\n        indent();\n      } // We must send an input event to resize the element\n\n\n      editable.dispatchEvent(new Event(\"input\"));\n    }\n  };\n\n  const TAB_SIZE = 4;\n  const TAB = \" \".repeat(TAB_SIZE);\n  const RE_LEADING_TAB = new RegExp(`^ {1,${TAB_SIZE}}`);\n\n  const indent = function () {\n    const {\n      selectionStart,\n      selectionEnd\n    } = editable;\n    const linesStartIndices = getSelectedLinesStartIndices();\n    let value = editable.value;\n    linesStartIndices.forEach(function (startIndex) {\n      const startValue = value.slice(0, startIndex);\n      const endValue = value.slice(startIndex);\n      value = `${startValue}${TAB}${endValue}`;\n    });\n    editable.value = value;\n    editable.selectionStart = selectionStart + TAB_SIZE;\n    editable.selectionEnd = selectionEnd + TAB_SIZE * linesStartIndices.length;\n  };\n\n  const outdent = function () {\n    const {\n      selectionStart,\n      selectionEnd\n    } = editable;\n    const linesStartIndices = getSelectedLinesStartIndices();\n    const removedTabs = [];\n    let value = editable.value;\n    linesStartIndices.forEach(function (startIndex) {\n      const tabMatch = value.slice(startIndex, startIndex + TAB_SIZE).match(RE_LEADING_TAB);\n\n      if (tabMatch) {\n        const startValue = value.slice(0, startIndex);\n        const endValue = value.slice(startIndex + tabMatch[0].length); // Delete a tab from the line\n\n        value = `${startValue}${endValue}`;\n        removedTabs.push(startIndex);\n      }\n    });\n    editable.value = value;\n\n    if (removedTabs.length) {\n      if (selectionStart > removedTabs[removedTabs.length - 1]) {\n        editable.selectionStart = Math.max(selectionStart - TAB_SIZE, removedTabs[removedTabs.length - 1]);\n      } else {\n        // If the cursor is before the first tab removed, ex:\n        // Line| #1\n        //     Line #2\n        // Lin|e #3\n        // we should reset the selectionStart to his initial value.\n        editable.selectionStart = selectionStart;\n      }\n\n      editable.selectionEnd = Math.max(editable.selectionStart, selectionEnd - TAB_SIZE * removedTabs.length);\n    }\n  };\n  /**\n   * @returns indeces of start positions of selected lines, in reverse order\n   */\n\n\n  const getSelectedLinesStartIndices = function () {\n    let {\n      selectionStart,\n      selectionEnd,\n      value\n    } = editable; // chars before selectionStart on the same line\n\n    const startOffset = value.slice(0, selectionStart).match(/[^\\n]*$/)[0].length; // put caret at the start of the line\n\n    selectionStart = selectionStart - startOffset;\n    const selected = value.slice(selectionStart, selectionEnd);\n    return selected.split(\"\\n\").reduce(function (startIndices, line, idx, lines) {\n      return startIndices.concat(idx ? // curr line index is prev line's start + prev line's length + \\n\n      startIndices[idx - 1] + lines[idx - 1].length + 1 : // first selected line\n      selectionStart);\n    }, []).reverse();\n  };\n\n  const stopEvent = function (event) {\n    event.preventDefault();\n    event.stopPropagation();\n  }; // using a state variable instead of passing it to the handleSubmit callback\n  // so that we don't need to create separate a callback for event handlers\n\n\n  let submittedViaKeyboard = false;\n\n  const handleSubmit = function () {\n    // cleanup must be run before onSubmit otherwise when app blurs the wysiwyg\n    // it'd get stuck in an infinite loop of blur→onSubmit after we re-focus the\n    // wysiwyg on update\n    cleanup();\n    const updateElement = Scene.getScene(element)?.getElement(element.id);\n\n    if (!updateElement) {\n      return;\n    }\n\n    let wrappedText = \"\";\n\n    if (isTextElement(updateElement) && updateElement?.containerId) {\n      const container = Scene.getScene(updateElement).getElement(updateElement.containerId);\n\n      if (container) {\n        wrappedText = wrapText(editable.value, getFontString(updateElement), container.width);\n\n        if (isTextElement(updateElement) && updateElement.containerId) {\n          const editorHeight = Number(editable.style.height.slice(0, -2));\n\n          if (editable.value) {\n            mutateElement(updateElement, {\n              // vertically center align\n              y: container.y + container.height / 2 - editorHeight / 2,\n              height: editorHeight,\n              width: Number(editable.style.width.slice(0, -2)),\n              // preserve padding\n              x: container.x + PADDING\n            });\n            const boundTextElementId = getBoundTextElementId(container);\n\n            if (!boundTextElementId || boundTextElementId !== element.id) {\n              mutateElement(container, {\n                boundElements: (container.boundElements || []).concat({\n                  type: \"text\",\n                  id: element.id\n                })\n              });\n            }\n          } else {\n            mutateElement(container, {\n              boundElements: container.boundElements?.filter(function (ele) {\n                return ele.type !== \"text\";\n              })\n            });\n          }\n        }\n      }\n    } else {\n      wrappedText = editable.value;\n    }\n\n    onSubmit({\n      text: normalizeText(wrappedText),\n      viaKeyboard: submittedViaKeyboard,\n      originalText: editable.value\n    });\n  };\n\n  const cleanup = function () {\n    if (isDestroyed) {\n      return;\n    }\n\n    isDestroyed = true; // remove events to ensure they don't late-fire\n\n    editable.onblur = null;\n    editable.oninput = null;\n    editable.onkeydown = null;\n\n    if (observer) {\n      observer.disconnect();\n    }\n\n    window.removeEventListener(\"resize\", updateWysiwygStyle);\n    window.removeEventListener(\"wheel\", stopEvent, true);\n    window.removeEventListener(\"pointerdown\", onPointerDown);\n    window.removeEventListener(\"pointerup\", bindBlurEvent);\n    window.removeEventListener(\"blur\", handleSubmit);\n    unbindUpdate();\n    editable.remove();\n  };\n\n  const bindBlurEvent = function (event) {\n    window.removeEventListener(\"pointerup\", bindBlurEvent); // Deferred so that the pointerdown that initiates the wysiwyg doesn't\n    // trigger the blur on ensuing pointerup.\n    // Also to handle cases such as picking a color which would trigger a blur\n    // in that same tick.\n\n    const target = event?.target;\n    const isTargetColorPicker = target instanceof HTMLInputElement && target.closest(\".color-picker-input\") && isWritableElement(target);\n    setTimeout(function () {\n      editable.onblur = handleSubmit;\n\n      if (target && isTargetColorPicker) {\n        target.onblur = function () {\n          editable.focus();\n        };\n      } // case: clicking on the same property → no change → no update → no focus\n\n\n      if (!isTargetColorPicker) {\n        editable.focus();\n      }\n    });\n  }; // prevent blur when changing properties from the menu\n\n\n  const onPointerDown = function (event) {\n    const isTargetColorPicker = event.target instanceof HTMLInputElement && event.target.closest(\".color-picker-input\") && isWritableElement(event.target);\n\n    if ((event.target instanceof HTMLElement || event.target instanceof SVGElement) && event.target.closest(`.${CLASSES.SHAPE_ACTIONS_MENU}`) && !isWritableElement(event.target) || isTargetColorPicker) {\n      editable.onblur = null;\n      window.addEventListener(\"pointerup\", bindBlurEvent); // handle edge-case where pointerup doesn't fire e.g. due to user\n      // alt-tabbing away\n\n      window.addEventListener(\"blur\", handleSubmit);\n    }\n  }; // handle updates of textElement properties of editing element\n\n\n  const unbindUpdate = Scene.getScene(element).addCallback(function () {\n    updateWysiwygStyle();\n    const isColorPickerActive = !!document.activeElement?.closest(\".color-picker-input\");\n\n    if (!isColorPickerActive) {\n      editable.focus();\n    }\n  }); // ---------------------------------------------------------------------------\n\n  let isDestroyed = false; // select on init (focusing is done separately inside the bindBlurEvent()\n  // because we need it to happen *after* the blur event from `pointerdown`)\n\n  editable.select();\n  bindBlurEvent(); // reposition wysiwyg in case of canvas is resized. Using ResizeObserver\n  // is preferred so we catch changes from host, where window may not resize.\n\n  let observer = null;\n\n  if (canvas && \"ResizeObserver\" in window) {\n    observer = new window.ResizeObserver(function () {\n      updateWysiwygStyle();\n    });\n    observer.observe(canvas);\n  } else {\n    window.addEventListener(\"resize\", updateWysiwygStyle);\n  }\n\n  window.addEventListener(\"pointerdown\", onPointerDown);\n  window.addEventListener(\"wheel\", stopEvent, {\n    passive: false,\n    capture: true\n  });\n  excalidrawContainer?.querySelector(\".excalidraw-textEditorContainer\").appendChild(editable);\n};"],"names":[],"sourceRoot":""}\\n//# sourceURL=webpack-internal:///../../element/textWysiwyg.tsx\\n\");\n\n//# sourceURL=webpack://Excalidraw/../../element/textWysiwyg.tsx?");
2681
2681
 
2682
2682
  /***/ }),
2683
2683
 
@@ -3755,7 +3755,7 @@ eval("module.exports = JSON.parse('{\"labels\":{\"paste\":\"貼上\",\"pasteChar
3755
3755
  /***/ ((module) => {
3756
3756
 
3757
3757
  "use strict";
3758
- eval("module.exports = JSON.parse('{\"name\":\"@zsviczian/excalidraw\",\"version\":\"0.10.0-obsidian-30\",\"main\":\"main.js\",\"types\":\"types/packages/excalidraw/index.d.ts\",\"files\":[\"dist/*\",\"types/*\"],\"publishConfig\":{\"access\":\"public\"},\"description\":\"Excalidraw as a React component\",\"repository\":\"https://github.com/excalidraw/excalidraw\",\"license\":\"MIT\",\"keywords\":[\"excalidraw\",\"excalidraw-embed\",\"react\",\"npm\",\"npm excalidraw\"],\"browserslist\":{\"production\":[\">0.2%\",\"not dead\",\"not ie <= 11\",\"not op_mini all\",\"not safari < 12\",\"not kaios <= 2.5\",\"not edge < 79\",\"not chrome < 70\",\"not and_uc < 13\",\"not samsung < 10\"],\"development\":[\"last 1 chrome version\",\"last 1 firefox version\",\"last 1 safari version\"]},\"peerDependencies\":{\"react\":\"^17.0.2\",\"react-dom\":\"^17.0.2\"},\"devDependencies\":{\"@babel/core\":\"7.16.0\",\"@babel/plugin-transform-arrow-functions\":\"7.16.0\",\"@babel/plugin-transform-async-to-generator\":\"7.16.0\",\"@babel/plugin-transform-runtime\":\"7.16.4\",\"@babel/plugin-transform-typescript\":\"7.16.1\",\"@babel/preset-env\":\"7.16.4\",\"@babel/preset-react\":\"7.16.0\",\"@babel/preset-typescript\":\"7.16.0\",\"autoprefixer\":\"10.4.0\",\"babel-loader\":\"8.2.3\",\"babel-plugin-transform-class-properties\":\"6.24.1\",\"cross-env\":\"7.0.3\",\"css-loader\":\"6.5.1\",\"mini-css-extract-plugin\":\"2.4.5\",\"postcss-loader\":\"6.2.1\",\"sass-loader\":\"12.4.0\",\"terser-webpack-plugin\":\"5.2.5\",\"ts-loader\":\"9.2.6\",\"typescript\":\"4.5.3\",\"webpack\":\"5.65.0\",\"webpack-bundle-analyzer\":\"4.5.0\",\"webpack-cli\":\"4.9.1\"},\"bugs\":\"https://github.com/excalidraw/excalidraw/issues\",\"homepage\":\"https://github.com/excalidraw/excalidraw/tree/master/src/packages/excalidraw\",\"scripts\":{\"gen:types\":\"tsc --project ../../../tsconfig-types.json\",\"build:umd\":\"cross-env NODE_ENV=production webpack --config webpack.prod.config.js && cross-env NODE_ENV=development webpack --config webpack.dev.config.js && yarn gen:types\",\"build:umd:withAnalyzer\":\"cross-env NODE_ENV=production ANALYZER=true webpack --config webpack.prod.config.js\",\"pack\":\"yarn build:umd && yarn pack\"},\"dependencies\":{\"dotenv\":\"10.0.0\"}}');\n\n//# sourceURL=webpack://Excalidraw/./package.json?");
3758
+ eval("module.exports = JSON.parse('{\"name\":\"@zsviczian/excalidraw\",\"version\":\"0.10.0-obsidian-31\",\"main\":\"main.js\",\"types\":\"types/packages/excalidraw/index.d.ts\",\"files\":[\"dist/*\",\"types/*\"],\"publishConfig\":{\"access\":\"public\"},\"description\":\"Excalidraw as a React component\",\"repository\":\"https://github.com/excalidraw/excalidraw\",\"license\":\"MIT\",\"keywords\":[\"excalidraw\",\"excalidraw-embed\",\"react\",\"npm\",\"npm excalidraw\"],\"browserslist\":{\"production\":[\">0.2%\",\"not dead\",\"not ie <= 11\",\"not op_mini all\",\"not safari < 12\",\"not kaios <= 2.5\",\"not edge < 79\",\"not chrome < 70\",\"not and_uc < 13\",\"not samsung < 10\"],\"development\":[\"last 1 chrome version\",\"last 1 firefox version\",\"last 1 safari version\"]},\"peerDependencies\":{\"react\":\"^17.0.2\",\"react-dom\":\"^17.0.2\"},\"devDependencies\":{\"@babel/core\":\"7.16.0\",\"@babel/plugin-transform-arrow-functions\":\"7.16.0\",\"@babel/plugin-transform-async-to-generator\":\"7.16.0\",\"@babel/plugin-transform-runtime\":\"7.16.4\",\"@babel/plugin-transform-typescript\":\"7.16.1\",\"@babel/preset-env\":\"7.16.4\",\"@babel/preset-react\":\"7.16.0\",\"@babel/preset-typescript\":\"7.16.0\",\"autoprefixer\":\"10.4.0\",\"babel-loader\":\"8.2.3\",\"babel-plugin-transform-class-properties\":\"6.24.1\",\"cross-env\":\"7.0.3\",\"css-loader\":\"6.5.1\",\"mini-css-extract-plugin\":\"2.4.5\",\"postcss-loader\":\"6.2.1\",\"sass-loader\":\"12.4.0\",\"terser-webpack-plugin\":\"5.2.5\",\"ts-loader\":\"9.2.6\",\"typescript\":\"4.5.3\",\"webpack\":\"5.65.0\",\"webpack-bundle-analyzer\":\"4.5.0\",\"webpack-cli\":\"4.9.1\"},\"bugs\":\"https://github.com/excalidraw/excalidraw/issues\",\"homepage\":\"https://github.com/excalidraw/excalidraw/tree/master/src/packages/excalidraw\",\"scripts\":{\"gen:types\":\"tsc --project ../../../tsconfig-types.json\",\"build:umd\":\"cross-env NODE_ENV=production webpack --config webpack.prod.config.js && cross-env NODE_ENV=development webpack --config webpack.dev.config.js && yarn gen:types\",\"build:umd:withAnalyzer\":\"cross-env NODE_ENV=production ANALYZER=true webpack --config webpack.prod.config.js\",\"pack\":\"yarn build:umd && yarn pack\"},\"dependencies\":{\"dotenv\":\"10.0.0\"}}');\n\n//# sourceURL=webpack://Excalidraw/./package.json?");
3759
3759
 
3760
3760
  /***/ })
3761
3761