@pie-lib/editable-html 12.1.0-next.0 → 12.1.0-next.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +40 -0
- package/package.json +7 -7
- package/lib/__tests__/editor-utils.test.js +0 -164
- package/lib/__tests__/serialization.test.js +0 -242
- package/lib/__tests__/utils.js +0 -79
- package/lib/block-tags.js +0 -24
- package/lib/block-tags.js.map +0 -1
- package/lib/constants.js +0 -11
- package/lib/constants.js.map +0 -1
- package/lib/editor.js +0 -1224
- package/lib/editor.js.map +0 -1
- package/lib/index.js +0 -208
- package/lib/index.js.map +0 -1
- package/lib/parse-html.js +0 -16
- package/lib/parse-html.js.map +0 -1
- package/lib/plugins/characters/custom-popper.js +0 -57
- package/lib/plugins/characters/custom-popper.js.map +0 -1
- package/lib/plugins/characters/index.js +0 -265
- package/lib/plugins/characters/index.js.map +0 -1
- package/lib/plugins/characters/utils.js +0 -378
- package/lib/plugins/characters/utils.js.map +0 -1
- package/lib/plugins/css/icons/index.js +0 -25
- package/lib/plugins/css/icons/index.js.map +0 -1
- package/lib/plugins/css/index.js +0 -338
- package/lib/plugins/css/index.js.map +0 -1
- package/lib/plugins/customPlugin/index.js +0 -98
- package/lib/plugins/customPlugin/index.js.map +0 -1
- package/lib/plugins/html/icons/index.js +0 -30
- package/lib/plugins/html/icons/index.js.map +0 -1
- package/lib/plugins/html/index.js +0 -71
- package/lib/plugins/html/index.js.map +0 -1
- package/lib/plugins/image/__tests__/component.test.js +0 -96
- package/lib/plugins/image/__tests__/image-toolbar-logic.test.js +0 -131
- package/lib/plugins/image/__tests__/image-toolbar.test.js +0 -22
- package/lib/plugins/image/__tests__/index.test.js +0 -90
- package/lib/plugins/image/__tests__/insert-image-handler.test.js +0 -112
- package/lib/plugins/image/__tests__/mock-change.js +0 -22
- package/lib/plugins/image/alt-dialog.js +0 -100
- package/lib/plugins/image/alt-dialog.js.map +0 -1
- package/lib/plugins/image/component.js +0 -343
- package/lib/plugins/image/component.js.map +0 -1
- package/lib/plugins/image/image-toolbar.js +0 -137
- package/lib/plugins/image/image-toolbar.js.map +0 -1
- package/lib/plugins/image/index.js +0 -223
- package/lib/plugins/image/index.js.map +0 -1
- package/lib/plugins/image/insert-image-handler.js +0 -140
- package/lib/plugins/image/insert-image-handler.js.map +0 -1
- package/lib/plugins/index.js +0 -342
- package/lib/plugins/index.js.map +0 -1
- package/lib/plugins/list/__tests__/index.test.js +0 -64
- package/lib/plugins/list/index.js +0 -288
- package/lib/plugins/list/index.js.map +0 -1
- package/lib/plugins/math/__tests__/index.test.js +0 -284
- package/lib/plugins/math/index.js +0 -402
- package/lib/plugins/math/index.js.map +0 -1
- package/lib/plugins/media/__tests__/index.test.js +0 -69
- package/lib/plugins/media/index.js +0 -330
- package/lib/plugins/media/index.js.map +0 -1
- package/lib/plugins/media/media-dialog.js +0 -594
- package/lib/plugins/media/media-dialog.js.map +0 -1
- package/lib/plugins/media/media-toolbar.js +0 -76
- package/lib/plugins/media/media-toolbar.js.map +0 -1
- package/lib/plugins/media/media-wrapper.js +0 -64
- package/lib/plugins/media/media-wrapper.js.map +0 -1
- package/lib/plugins/rendering/index.js +0 -36
- package/lib/plugins/rendering/index.js.map +0 -1
- package/lib/plugins/respArea/drag-in-the-blank/choice.js +0 -271
- package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +0 -1
- package/lib/plugins/respArea/drag-in-the-blank/index.js +0 -55
- package/lib/plugins/respArea/drag-in-the-blank/index.js.map +0 -1
- package/lib/plugins/respArea/drag-in-the-blank/utils.js +0 -38
- package/lib/plugins/respArea/drag-in-the-blank/utils.js.map +0 -1
- package/lib/plugins/respArea/explicit-constructed-response/index.js +0 -50
- package/lib/plugins/respArea/explicit-constructed-response/index.js.map +0 -1
- package/lib/plugins/respArea/icons/index.js +0 -72
- package/lib/plugins/respArea/icons/index.js.map +0 -1
- package/lib/plugins/respArea/index.js +0 -287
- package/lib/plugins/respArea/index.js.map +0 -1
- package/lib/plugins/respArea/inline-dropdown/index.js +0 -67
- package/lib/plugins/respArea/inline-dropdown/index.js.map +0 -1
- package/lib/plugins/respArea/math-templated/index.js +0 -112
- package/lib/plugins/respArea/math-templated/index.js.map +0 -1
- package/lib/plugins/respArea/utils.js +0 -95
- package/lib/plugins/respArea/utils.js.map +0 -1
- package/lib/plugins/table/CustomTablePlugin.js +0 -116
- package/lib/plugins/table/CustomTablePlugin.js.map +0 -1
- package/lib/plugins/table/__tests__/index.test.js +0 -416
- package/lib/plugins/table/__tests__/table-toolbar.test.js +0 -81
- package/lib/plugins/table/icons/index.js +0 -55
- package/lib/plugins/table/icons/index.js.map +0 -1
- package/lib/plugins/table/index.js +0 -413
- package/lib/plugins/table/index.js.map +0 -1
- package/lib/plugins/table/table-toolbar.js +0 -138
- package/lib/plugins/table/table-toolbar.js.map +0 -1
- package/lib/plugins/textAlign/icons/index.js +0 -187
- package/lib/plugins/textAlign/icons/index.js.map +0 -1
- package/lib/plugins/textAlign/index.js +0 -26
- package/lib/plugins/textAlign/index.js.map +0 -1
- package/lib/plugins/toolbar/__tests__/default-toolbar.test.js +0 -154
- package/lib/plugins/toolbar/__tests__/editor-and-toolbar.test.js +0 -47
- package/lib/plugins/toolbar/__tests__/toolbar-buttons.test.js +0 -112
- package/lib/plugins/toolbar/__tests__/toolbar.test.js +0 -118
- package/lib/plugins/toolbar/default-toolbar.js +0 -180
- package/lib/plugins/toolbar/default-toolbar.js.map +0 -1
- package/lib/plugins/toolbar/done-button.js +0 -35
- package/lib/plugins/toolbar/done-button.js.map +0 -1
- package/lib/plugins/toolbar/editor-and-toolbar.js +0 -258
- package/lib/plugins/toolbar/editor-and-toolbar.js.map +0 -1
- package/lib/plugins/toolbar/index.js +0 -29
- package/lib/plugins/toolbar/index.js.map +0 -1
- package/lib/plugins/toolbar/toolbar-buttons.js +0 -145
- package/lib/plugins/toolbar/toolbar-buttons.js.map +0 -1
- package/lib/plugins/toolbar/toolbar.js +0 -307
- package/lib/plugins/toolbar/toolbar.js.map +0 -1
- package/lib/plugins/utils.js +0 -42
- package/lib/plugins/utils.js.map +0 -1
- package/lib/serialization.js +0 -571
- package/lib/serialization.js.map +0 -1
- package/lib/shared/alert-dialog.js +0 -68
- package/lib/theme.js +0 -8
- package/lib/theme.js.map +0 -1
package/lib/editor.js
DELETED
|
@@ -1,1224 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
-
Object.defineProperty(exports, "__esModule", {
|
|
6
|
-
value: true
|
|
7
|
-
});
|
|
8
|
-
Object.defineProperty(exports, "ALL_PLUGINS", {
|
|
9
|
-
enumerable: true,
|
|
10
|
-
get: function get() {
|
|
11
|
-
return _plugins.ALL_PLUGINS;
|
|
12
|
-
}
|
|
13
|
-
});
|
|
14
|
-
Object.defineProperty(exports, "DEFAULT_PLUGINS", {
|
|
15
|
-
enumerable: true,
|
|
16
|
-
get: function get() {
|
|
17
|
-
return _plugins.DEFAULT_PLUGINS;
|
|
18
|
-
}
|
|
19
|
-
});
|
|
20
|
-
exports.valueToSize = exports.serialization = exports["default"] = exports.buildSizeStyle = exports.Editor = void 0;
|
|
21
|
-
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
22
|
-
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
23
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
24
|
-
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
25
|
-
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
26
|
-
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
27
|
-
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
28
|
-
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
29
|
-
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
30
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
31
|
-
var _react = _interopRequireDefault(require("react"));
|
|
32
|
-
var _slateReact = require("slate-react");
|
|
33
|
-
var _slatePropTypes = _interopRequireDefault(require("slate-prop-types"));
|
|
34
|
-
var _slate = require("slate");
|
|
35
|
-
var _slatePlainSerializer = _interopRequireDefault(require("slate-plain-serializer"));
|
|
36
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
37
|
-
var _debounce = _interopRequireDefault(require("lodash/debounce"));
|
|
38
|
-
var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
|
|
39
|
-
var _classnames = _interopRequireDefault(require("classnames"));
|
|
40
|
-
var _debug = _interopRequireDefault(require("debug"));
|
|
41
|
-
var _styles = require("@mui/material/styles");
|
|
42
|
-
var _renderUi = require("@pie-lib/render-ui");
|
|
43
|
-
var _alertDialog = _interopRequireDefault(require("./shared/alert-dialog"));
|
|
44
|
-
var _serialization = _interopRequireWildcard(require("./serialization"));
|
|
45
|
-
var serialization = _serialization;
|
|
46
|
-
exports.serialization = _serialization;
|
|
47
|
-
var _insertImageHandler = _interopRequireDefault(require("./plugins/image/insert-image-handler"));
|
|
48
|
-
var _plugins = require("./plugins");
|
|
49
|
-
var _excluded = ["customPlugins", "showParagraphs", "separateParagraphs"];
|
|
50
|
-
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
|
|
51
|
-
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
|
|
52
|
-
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
53
|
-
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
54
|
-
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
55
|
-
var log = (0, _debug["default"])('editable-html:editor');
|
|
56
|
-
var defaultToolbarOpts = {
|
|
57
|
-
position: 'bottom',
|
|
58
|
-
alignment: 'left',
|
|
59
|
-
alwaysVisible: false,
|
|
60
|
-
showDone: true,
|
|
61
|
-
doneOn: 'blur'
|
|
62
|
-
};
|
|
63
|
-
var defaultResponseAreaProps = {
|
|
64
|
-
options: {},
|
|
65
|
-
respAreaToolbar: function respAreaToolbar() {},
|
|
66
|
-
onHandleAreaChange: function onHandleAreaChange() {}
|
|
67
|
-
};
|
|
68
|
-
var defaultLanguageCharactersProps = [];
|
|
69
|
-
var createToolbarOpts = function createToolbarOpts(toolbarOpts, error, isHtmlMode) {
|
|
70
|
-
return _objectSpread(_objectSpread(_objectSpread({}, defaultToolbarOpts), toolbarOpts), {}, {
|
|
71
|
-
error: error,
|
|
72
|
-
isHtmlMode: isHtmlMode
|
|
73
|
-
});
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
/**
|
|
77
|
-
* Converts a value to a CSS size string
|
|
78
|
-
* @param {string|number} v - The value to convert
|
|
79
|
-
* @returns {string|undefined} CSS size string or undefined
|
|
80
|
-
*/
|
|
81
|
-
var valueToSize = exports.valueToSize = function valueToSize(v) {
|
|
82
|
-
if (!v) {
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
var calcRegex = /^calc\((.*)\)$/;
|
|
86
|
-
if (typeof v === 'string') {
|
|
87
|
-
if (v.endsWith('%')) {
|
|
88
|
-
return undefined;
|
|
89
|
-
} else if (v.endsWith('px') || v.endsWith('vh') || v.endsWith('vw') || v.endsWith('ch') || v.endsWith('em') || v.match(calcRegex)) {
|
|
90
|
-
return v;
|
|
91
|
-
} else {
|
|
92
|
-
var value = parseInt(v, 10);
|
|
93
|
-
return isNaN(value) ? value : "".concat(value, "px");
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
if (typeof v === 'number') {
|
|
97
|
-
return "".concat(v, "px");
|
|
98
|
-
}
|
|
99
|
-
};
|
|
100
|
-
|
|
101
|
-
/**
|
|
102
|
-
* Builds a style object for editor size constraints
|
|
103
|
-
* @param {Object} props - Editor props containing size values
|
|
104
|
-
* @returns {Object} Style object with width/height constraints
|
|
105
|
-
*/
|
|
106
|
-
var _buildSizeStyle = exports.buildSizeStyle = function buildSizeStyle(props) {
|
|
107
|
-
var minWidth = props.minWidth,
|
|
108
|
-
width = props.width,
|
|
109
|
-
maxWidth = props.maxWidth,
|
|
110
|
-
minHeight = props.minHeight,
|
|
111
|
-
height = props.height,
|
|
112
|
-
maxHeight = props.maxHeight;
|
|
113
|
-
return {
|
|
114
|
-
width: valueToSize(width),
|
|
115
|
-
minWidth: valueToSize(minWidth),
|
|
116
|
-
maxWidth: valueToSize(maxWidth),
|
|
117
|
-
height: valueToSize(height),
|
|
118
|
-
minHeight: valueToSize(minHeight),
|
|
119
|
-
maxHeight: valueToSize(maxHeight)
|
|
120
|
-
};
|
|
121
|
-
};
|
|
122
|
-
|
|
123
|
-
/**
|
|
124
|
-
* The maximum number of characters the editor can support
|
|
125
|
-
* @type {number}
|
|
126
|
-
*/
|
|
127
|
-
var MAX_CHARACTERS_LIMIT = 1000000;
|
|
128
|
-
var Editor = exports.Editor = /*#__PURE__*/function (_React$Component) {
|
|
129
|
-
function Editor(_props) {
|
|
130
|
-
var _this;
|
|
131
|
-
(0, _classCallCheck2["default"])(this, Editor);
|
|
132
|
-
_this = _callSuper(this, Editor, [_props]);
|
|
133
|
-
(0, _defineProperty2["default"])(_this, "setKeypadInteraction", function (interacted) {
|
|
134
|
-
_this.keypadInteractionDetected = interacted;
|
|
135
|
-
});
|
|
136
|
-
(0, _defineProperty2["default"])(_this, "handleDialog", function (open) {
|
|
137
|
-
var extraDialogProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
138
|
-
var callback = arguments.length > 2 ? arguments[2] : undefined;
|
|
139
|
-
_this.setState({
|
|
140
|
-
dialog: _objectSpread({
|
|
141
|
-
open: open
|
|
142
|
-
}, extraDialogProps)
|
|
143
|
-
}, callback);
|
|
144
|
-
});
|
|
145
|
-
(0, _defineProperty2["default"])(_this, "toggleHtmlMode", function () {
|
|
146
|
-
_this.setState(function (prevState) {
|
|
147
|
-
return {
|
|
148
|
-
isHtmlMode: !prevState.isHtmlMode,
|
|
149
|
-
isEditedInHtmlMode: false
|
|
150
|
-
};
|
|
151
|
-
}, function () {
|
|
152
|
-
var error = _this.props.error;
|
|
153
|
-
var toolbarOpts = _this.state.toolbarOpts;
|
|
154
|
-
var newToolbarOpts = createToolbarOpts(toolbarOpts, error, _this.state.isHtmlMode);
|
|
155
|
-
_this.setState({
|
|
156
|
-
toolbarOpts: newToolbarOpts
|
|
157
|
-
});
|
|
158
|
-
});
|
|
159
|
-
});
|
|
160
|
-
(0, _defineProperty2["default"])(_this, "handlePlugins", function (props) {
|
|
161
|
-
var normalizedResponseAreaProps = _objectSpread(_objectSpread({}, defaultResponseAreaProps), props.responseAreaProps);
|
|
162
|
-
var htmlPluginOpts = {
|
|
163
|
-
currentValue: _this.props.value,
|
|
164
|
-
isHtmlMode: _this.state.isHtmlMode,
|
|
165
|
-
isEditedInHtmlMode: _this.state.isEditedInHtmlMode,
|
|
166
|
-
toggleHtmlMode: _this.toggleHtmlMode,
|
|
167
|
-
handleAlertDialog: _this.handleDialog
|
|
168
|
-
};
|
|
169
|
-
var _ref = props.pluginProps || {},
|
|
170
|
-
customPlugins = _ref.customPlugins;
|
|
171
|
-
customPlugins = customPlugins || [];
|
|
172
|
-
_this.plugins = (0, _plugins.buildPlugins)(props.activePlugins, customPlugins, {
|
|
173
|
-
math: _objectSpread({
|
|
174
|
-
onClick: _this.onMathClick,
|
|
175
|
-
onFocus: _this.onPluginFocus,
|
|
176
|
-
onBlur: _this.onPluginBlur
|
|
177
|
-
}, props.mathMlOptions),
|
|
178
|
-
textAlign: {
|
|
179
|
-
getValue: function getValue() {
|
|
180
|
-
return _this.state.value;
|
|
181
|
-
},
|
|
182
|
-
onChange: _this.onChange
|
|
183
|
-
},
|
|
184
|
-
html: htmlPluginOpts,
|
|
185
|
-
extraCSSRules: props.extraCSSRules || {},
|
|
186
|
-
image: {
|
|
187
|
-
disableImageAlignmentButtons: props.disableImageAlignmentButtons,
|
|
188
|
-
onDelete: props.imageSupport && props.imageSupport["delete"] && function (node, done) {
|
|
189
|
-
var src = node.data.get('src');
|
|
190
|
-
props.imageSupport["delete"](src, function (e) {
|
|
191
|
-
var newPendingImages = _this.state.pendingImages.filter(function (img) {
|
|
192
|
-
return img.key !== node.key;
|
|
193
|
-
});
|
|
194
|
-
var oldScheduled = _this.state.scheduled;
|
|
195
|
-
var newState = {
|
|
196
|
-
pendingImages: newPendingImages,
|
|
197
|
-
scheduled: oldScheduled && newPendingImages.length === 0 ? false : oldScheduled
|
|
198
|
-
};
|
|
199
|
-
_this.setState(newState, function () {
|
|
200
|
-
return done(e, _this.state.value);
|
|
201
|
-
});
|
|
202
|
-
});
|
|
203
|
-
},
|
|
204
|
-
insertImageRequested: props.imageSupport && function (addedImage, getHandler) {
|
|
205
|
-
var pendingImages = _this.state.pendingImages;
|
|
206
|
-
var onFinish = function onFinish(result) {
|
|
207
|
-
var cb;
|
|
208
|
-
if (_this.state.scheduled && result) {
|
|
209
|
-
// finish editing only on success
|
|
210
|
-
cb = _this.onEditingDone.bind(_this);
|
|
211
|
-
}
|
|
212
|
-
var newPendingImages = _this.state.pendingImages.filter(function (img) {
|
|
213
|
-
return img.key !== addedImage.key;
|
|
214
|
-
});
|
|
215
|
-
var newState = {
|
|
216
|
-
pendingImages: newPendingImages
|
|
217
|
-
};
|
|
218
|
-
if (newPendingImages.length === 0) {
|
|
219
|
-
newState.scheduled = false;
|
|
220
|
-
}
|
|
221
|
-
_this.setState(newState, cb);
|
|
222
|
-
};
|
|
223
|
-
var callback = function callback() {
|
|
224
|
-
/**
|
|
225
|
-
* The handler is the object through which the outer context
|
|
226
|
-
* communicates file upload events like: fileChosen, cancel, progress
|
|
227
|
-
*/
|
|
228
|
-
var handler = getHandler(onFinish, function () {
|
|
229
|
-
return _this.state.value;
|
|
230
|
-
});
|
|
231
|
-
props.imageSupport.add(handler);
|
|
232
|
-
};
|
|
233
|
-
_this.setState({
|
|
234
|
-
pendingImages: [].concat((0, _toConsumableArray2["default"])(pendingImages), [addedImage])
|
|
235
|
-
}, callback);
|
|
236
|
-
},
|
|
237
|
-
onFocus: _this.onPluginFocus,
|
|
238
|
-
onBlur: _this.onPluginBlur,
|
|
239
|
-
maxImageWidth: props.maxImageWidth,
|
|
240
|
-
maxImageHeight: props.maxImageHeight
|
|
241
|
-
},
|
|
242
|
-
toolbar: {
|
|
243
|
-
/**
|
|
244
|
-
* To minimize converting html -> state -> html
|
|
245
|
-
* We only emit markup once 'done' is clicked.
|
|
246
|
-
*/
|
|
247
|
-
disableScrollbar: !!props.disableScrollbar,
|
|
248
|
-
disableUnderline: props.disableUnderline,
|
|
249
|
-
autoWidth: props.autoWidthToolbar,
|
|
250
|
-
onDone: function onDone() {
|
|
251
|
-
var _this$state$value$sta;
|
|
252
|
-
var nonEmpty = props.nonEmpty;
|
|
253
|
-
log('[onDone]');
|
|
254
|
-
_this.setState({
|
|
255
|
-
toolbarInFocus: false,
|
|
256
|
-
focusedNode: null,
|
|
257
|
-
focusToolbar: false
|
|
258
|
-
});
|
|
259
|
-
_this.editor.blur();
|
|
260
|
-
if (nonEmpty && ((_this$state$value$sta = _this.state.value.startText) === null || _this$state$value$sta === void 0 || (_this$state$value$sta = _this$state$value$sta.text) === null || _this$state$value$sta === void 0 ? void 0 : _this$state$value$sta.length) === 0) {
|
|
261
|
-
_this.resetValue(true).then(function () {
|
|
262
|
-
_this.onEditingDone();
|
|
263
|
-
});
|
|
264
|
-
} else {
|
|
265
|
-
_this.onEditingDone();
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
},
|
|
269
|
-
table: {
|
|
270
|
-
onFocus: function onFocus() {
|
|
271
|
-
log('[table:onFocus]...');
|
|
272
|
-
_this.onPluginFocus();
|
|
273
|
-
},
|
|
274
|
-
onBlur: function onBlur() {
|
|
275
|
-
log('[table:onBlur]...');
|
|
276
|
-
_this.onPluginBlur();
|
|
277
|
-
}
|
|
278
|
-
},
|
|
279
|
-
responseArea: {
|
|
280
|
-
type: normalizedResponseAreaProps.type,
|
|
281
|
-
options: normalizedResponseAreaProps.options,
|
|
282
|
-
maxResponseAreas: normalizedResponseAreaProps.maxResponseAreas,
|
|
283
|
-
respAreaToolbar: normalizedResponseAreaProps.respAreaToolbar,
|
|
284
|
-
onHandleAreaChange: normalizedResponseAreaProps.onHandleAreaChange,
|
|
285
|
-
error: normalizedResponseAreaProps.error,
|
|
286
|
-
onFocus: function onFocus() {
|
|
287
|
-
log('[table:onFocus]...');
|
|
288
|
-
_this.onPluginFocus();
|
|
289
|
-
},
|
|
290
|
-
onBlur: function onBlur() {
|
|
291
|
-
log('[table:onBlur]...');
|
|
292
|
-
_this.onPluginBlur();
|
|
293
|
-
}
|
|
294
|
-
},
|
|
295
|
-
languageCharacters: props.languageCharactersProps,
|
|
296
|
-
keyPadCharacterRef: _this.keyPadCharacterRef,
|
|
297
|
-
setKeypadInteraction: _this.setKeypadInteraction,
|
|
298
|
-
media: {
|
|
299
|
-
focus: _this.focus,
|
|
300
|
-
createChange: function createChange() {
|
|
301
|
-
return _this.state.value.change();
|
|
302
|
-
},
|
|
303
|
-
onChange: _this.onChange,
|
|
304
|
-
uploadSoundSupport: props.uploadSoundSupport
|
|
305
|
-
}
|
|
306
|
-
});
|
|
307
|
-
if (props.mathMlOptions.mmlOutput || props.mathMlOptions.mmlEditing) {
|
|
308
|
-
_this.props.runSerializationOnMarkup();
|
|
309
|
-
}
|
|
310
|
-
});
|
|
311
|
-
(0, _defineProperty2["default"])(_this, "onPluginBlur", function (e) {
|
|
312
|
-
log('[onPluginBlur]', e && e.relatedTarget);
|
|
313
|
-
var target = e && e.relatedTarget;
|
|
314
|
-
var node = target ? (0, _slateReact.findNode)(target, _this.state.value) : null;
|
|
315
|
-
log('[onPluginBlur] node: ', node);
|
|
316
|
-
_this.setState({
|
|
317
|
-
focusedNode: node
|
|
318
|
-
}, function () {
|
|
319
|
-
_this.resetValue();
|
|
320
|
-
});
|
|
321
|
-
});
|
|
322
|
-
(0, _defineProperty2["default"])(_this, "onPluginFocus", function (e) {
|
|
323
|
-
log('[onPluginFocus]', e && e.target);
|
|
324
|
-
var target = e && e.target;
|
|
325
|
-
if (target) {
|
|
326
|
-
var node = (0, _slateReact.findNode)(target, _this.state.value);
|
|
327
|
-
log('[onPluginFocus] node: ', node);
|
|
328
|
-
var stashedValue = _this.state.stashedValue || _this.state.value;
|
|
329
|
-
_this.setState({
|
|
330
|
-
focusedNode: node,
|
|
331
|
-
stashedValue: stashedValue
|
|
332
|
-
});
|
|
333
|
-
} else {
|
|
334
|
-
_this.setState({
|
|
335
|
-
focusedNode: null
|
|
336
|
-
});
|
|
337
|
-
}
|
|
338
|
-
_this.stashValue();
|
|
339
|
-
});
|
|
340
|
-
(0, _defineProperty2["default"])(_this, "onMathClick", function (node) {
|
|
341
|
-
_this.editor.change(function (c) {
|
|
342
|
-
return c.collapseToStartOf(node);
|
|
343
|
-
});
|
|
344
|
-
_this.setState({
|
|
345
|
-
selectedNode: node
|
|
346
|
-
});
|
|
347
|
-
});
|
|
348
|
-
(0, _defineProperty2["default"])(_this, "onEditingDone", function () {
|
|
349
|
-
var _this$state = _this.state,
|
|
350
|
-
isHtmlMode = _this$state.isHtmlMode,
|
|
351
|
-
dialog = _this$state.dialog,
|
|
352
|
-
value = _this$state.value,
|
|
353
|
-
pendingImages = _this$state.pendingImages;
|
|
354
|
-
|
|
355
|
-
// Handling HTML mode and dialog state
|
|
356
|
-
if (isHtmlMode) {
|
|
357
|
-
// Early return if HTML mode is enabled
|
|
358
|
-
if (dialog !== null && dialog !== void 0 && dialog.open) return;
|
|
359
|
-
var currentValue = (0, _serialization.htmlToValue)(value.document.text);
|
|
360
|
-
var previewText = _this.renderHtmlPreviewContent();
|
|
361
|
-
_this.openHtmlModeConfirmationDialog(currentValue, previewText);
|
|
362
|
-
return;
|
|
363
|
-
}
|
|
364
|
-
if (pendingImages.length) {
|
|
365
|
-
// schedule image processing
|
|
366
|
-
_this.setState({
|
|
367
|
-
scheduled: true
|
|
368
|
-
});
|
|
369
|
-
return;
|
|
370
|
-
}
|
|
371
|
-
|
|
372
|
-
// Finalizing editing
|
|
373
|
-
log('[onEditingDone]');
|
|
374
|
-
_this.setState({
|
|
375
|
-
pendingImages: [],
|
|
376
|
-
stashedValue: null,
|
|
377
|
-
focusedNode: null
|
|
378
|
-
});
|
|
379
|
-
log('[onEditingDone] value: ', _this.state.value);
|
|
380
|
-
_this.props.onChange(_this.state.value, true);
|
|
381
|
-
});
|
|
382
|
-
/**
|
|
383
|
-
* Renders the HTML preview content to be displayed inside the dialog.
|
|
384
|
-
* This content includes the edited HTML and a prompt for the user.
|
|
385
|
-
*/
|
|
386
|
-
(0, _defineProperty2["default"])(_this, "renderHtmlPreviewContent", function () {
|
|
387
|
-
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
388
|
-
ref: function ref(_ref2) {
|
|
389
|
-
return _this.elementRef = _ref2;
|
|
390
|
-
}
|
|
391
|
-
}, /*#__PURE__*/_react["default"].createElement("div", null, "Preview of Edited Html:"), /*#__PURE__*/_react["default"].createElement(StyledPreviewText, null, /*#__PURE__*/_react["default"].createElement(_renderUi.PreviewPrompt, {
|
|
392
|
-
prompt: _this.state.value.document.text
|
|
393
|
-
})), /*#__PURE__*/_react["default"].createElement("div", null, "Would you like to save these changes ?"));
|
|
394
|
-
});
|
|
395
|
-
/**
|
|
396
|
-
* Opens a confirmation dialog in HTML mode, displaying the preview of the current HTML content
|
|
397
|
-
* and offering options to save or continue editing.
|
|
398
|
-
*/
|
|
399
|
-
(0, _defineProperty2["default"])(_this, "openHtmlModeConfirmationDialog", function (currentValue, previewText) {
|
|
400
|
-
_this.setState({
|
|
401
|
-
dialog: {
|
|
402
|
-
open: true,
|
|
403
|
-
title: 'Content Preview & Save',
|
|
404
|
-
text: previewText,
|
|
405
|
-
onConfirmText: 'Save changes',
|
|
406
|
-
onCloseText: 'Continue editing',
|
|
407
|
-
onConfirm: function onConfirm() {
|
|
408
|
-
_this.handleHtmlModeSaveConfirmation(currentValue);
|
|
409
|
-
},
|
|
410
|
-
onClose: _this.htmlModeContinueEditing
|
|
411
|
-
}
|
|
412
|
-
});
|
|
413
|
-
});
|
|
414
|
-
/**
|
|
415
|
-
* Handles the save confirmation action in HTML mode. This updates the value to the confirmed
|
|
416
|
-
* content, updates value on props, and exits the HTML mode.
|
|
417
|
-
* @param {string} currentValue - The confirmed value of the HTML content to save.
|
|
418
|
-
*/
|
|
419
|
-
(0, _defineProperty2["default"])(_this, "handleHtmlModeSaveConfirmation", function (currentValue) {
|
|
420
|
-
_this.setState({
|
|
421
|
-
value: currentValue
|
|
422
|
-
});
|
|
423
|
-
_this.props.onChange(currentValue, true);
|
|
424
|
-
_this.handleDialog(false);
|
|
425
|
-
_this.toggleHtmlMode();
|
|
426
|
-
});
|
|
427
|
-
/**
|
|
428
|
-
* Closes the dialog in HTML mode and allows the user to continue editing the html content.
|
|
429
|
-
* This function is invoked when the user opts to not save the current changes.
|
|
430
|
-
*/
|
|
431
|
-
(0, _defineProperty2["default"])(_this, "htmlModeContinueEditing", function () {
|
|
432
|
-
_this.handleDialog(false);
|
|
433
|
-
});
|
|
434
|
-
// Allowing time for onChange to take effect if it is called
|
|
435
|
-
(0, _defineProperty2["default"])(_this, "handleBlur", function (resolve) {
|
|
436
|
-
var nonEmpty = _this.props.nonEmpty;
|
|
437
|
-
var doneOn = _this.state.toolbarOpts.doneOn;
|
|
438
|
-
_this.setState({
|
|
439
|
-
toolbarInFocus: false,
|
|
440
|
-
focusedNode: null
|
|
441
|
-
});
|
|
442
|
-
if (_this.editor) {
|
|
443
|
-
_this.editor.blur();
|
|
444
|
-
}
|
|
445
|
-
if (doneOn === 'blur') {
|
|
446
|
-
var _this$state$value$sta2;
|
|
447
|
-
if (nonEmpty && ((_this$state$value$sta2 = _this.state.value.startText) === null || _this$state$value$sta2 === void 0 || (_this$state$value$sta2 = _this$state$value$sta2.text) === null || _this$state$value$sta2 === void 0 ? void 0 : _this$state$value$sta2.length) === 0) {
|
|
448
|
-
_this.resetValue(true).then(function () {
|
|
449
|
-
_this.onEditingDone();
|
|
450
|
-
resolve();
|
|
451
|
-
});
|
|
452
|
-
} else {
|
|
453
|
-
_this.onEditingDone();
|
|
454
|
-
resolve();
|
|
455
|
-
}
|
|
456
|
-
}
|
|
457
|
-
});
|
|
458
|
-
(0, _defineProperty2["default"])(_this, "onBlur", function (event) {
|
|
459
|
-
var _this$doneButtonRef$c;
|
|
460
|
-
log('[onBlur]');
|
|
461
|
-
var relatedTarget = event.relatedTarget;
|
|
462
|
-
var toolbarElement = _this.toolbarRef && (relatedTarget === null || relatedTarget === void 0 ? void 0 : relatedTarget.closest("[class*=\"".concat(_this.toolbarRef.className, "\"]")));
|
|
463
|
-
|
|
464
|
-
// Check if relatedTarget is a done button
|
|
465
|
-
var isRawDoneButton = _this.doneButtonRef && (relatedTarget === null || relatedTarget === void 0 ? void 0 : relatedTarget.closest("[class*=\"".concat((_this$doneButtonRef$c = _this.doneButtonRef.current) === null || _this$doneButtonRef$c === void 0 ? void 0 : _this$doneButtonRef$c.className, "\"]")));
|
|
466
|
-
|
|
467
|
-
// Skip onBlur handling if relatedTarget is a button from the KeyPad characters
|
|
468
|
-
_this.skipBlurHandling = _this.keypadInteractionDetected && relatedTarget !== null;
|
|
469
|
-
if (toolbarElement && !isRawDoneButton && !_this.state.focusToolbar) {
|
|
470
|
-
_this.setState({
|
|
471
|
-
focusToolbar: true
|
|
472
|
-
});
|
|
473
|
-
}
|
|
474
|
-
var node = relatedTarget ? (0, _slateReact.findNode)(relatedTarget, _this.state.value) : null;
|
|
475
|
-
log('[onBlur] node: ', node);
|
|
476
|
-
return new Promise(function (resolve) {
|
|
477
|
-
if (!_this.skipBlurHandling) {
|
|
478
|
-
_this.setKeypadInteraction(false);
|
|
479
|
-
_this.setState({
|
|
480
|
-
preBlurValue: _this.state.value,
|
|
481
|
-
focusedNode: !node ? null : node
|
|
482
|
-
}, _this.handleBlur.bind(_this, resolve));
|
|
483
|
-
}
|
|
484
|
-
_this.props.onBlur(event);
|
|
485
|
-
});
|
|
486
|
-
});
|
|
487
|
-
(0, _defineProperty2["default"])(_this, "handleDomBlur", function (e) {
|
|
488
|
-
var editorDOM = document.querySelector("[data-key=\"".concat(_this.state.value.document.key, "\"]"));
|
|
489
|
-
setTimeout(function () {
|
|
490
|
-
var stateValue = _this.state.value;
|
|
491
|
-
if (!_this.wrapperRef) {
|
|
492
|
-
return;
|
|
493
|
-
}
|
|
494
|
-
var editorElement = !editorDOM || document.activeElement.closest("[class*=\"".concat(editorDOM.className, "\"]"));
|
|
495
|
-
var toolbarElement = !_this.toolbarRef || document.activeElement.closest("[class*=\"".concat(_this.toolbarRef.className, "\"]"));
|
|
496
|
-
var isInCurrentComponent = _this.wrapperRef.contains(editorElement) || _this.wrapperRef.contains(toolbarElement);
|
|
497
|
-
if (!isInCurrentComponent) {
|
|
498
|
-
editorDOM.removeEventListener('blur', _this.handleDomBlur);
|
|
499
|
-
if (stateValue.isFocused) {
|
|
500
|
-
_this.onBlur(e);
|
|
501
|
-
}
|
|
502
|
-
}
|
|
503
|
-
}, 50);
|
|
504
|
-
});
|
|
505
|
-
/*
|
|
506
|
-
* Needs to be wrapped otherwise it causes issues because of race conditions
|
|
507
|
-
* Known issue for slatejs. See: https://github.com/ianstormtaylor/slate/issues/2097
|
|
508
|
-
* Using timeout I wasn't able to test this
|
|
509
|
-
*
|
|
510
|
-
* Note: The use of promises has been causing issues with MathQuill
|
|
511
|
-
* */
|
|
512
|
-
(0, _defineProperty2["default"])(_this, "onFocus", function (event, change) {
|
|
513
|
-
return new Promise(function (resolve) {
|
|
514
|
-
var _navigator;
|
|
515
|
-
var editorDOM = document.querySelector("[data-key=\"".concat(_this.state.value.document.key, "\"]"));
|
|
516
|
-
var isTouchDevice = typeof window !== 'undefined' && ('ontouchstart' in window || ((_navigator = navigator) === null || _navigator === void 0 ? void 0 : _navigator.maxTouchPoints) > 0);
|
|
517
|
-
log('[onFocus]', document.activeElement);
|
|
518
|
-
if (_this.keypadInteractionDetected && _this.__TEMPORARY_CHANGE_DATA) {
|
|
519
|
-
_this.__TEMPORARY_CHANGE_DATA = null;
|
|
520
|
-
}
|
|
521
|
-
|
|
522
|
-
/**
|
|
523
|
-
* This is a temporary hack - @see changeData below for some more information.
|
|
524
|
-
*/
|
|
525
|
-
if (_this.__TEMPORARY_CHANGE_DATA) {
|
|
526
|
-
var _this$__TEMPORARY_CHA = _this.__TEMPORARY_CHANGE_DATA,
|
|
527
|
-
key = _this$__TEMPORARY_CHA.key,
|
|
528
|
-
data = _this$__TEMPORARY_CHA.data;
|
|
529
|
-
var domEl = document.querySelector("[data-key=\"".concat(key, "\"]"));
|
|
530
|
-
if (domEl) {
|
|
531
|
-
var _change = _this.state.value.change().setNodeByKey(key, {
|
|
532
|
-
data: data
|
|
533
|
-
});
|
|
534
|
-
_this.setState({
|
|
535
|
-
value: _change.value
|
|
536
|
-
}, function () {
|
|
537
|
-
_this.__TEMPORARY_CHANGE_DATA = null;
|
|
538
|
-
});
|
|
539
|
-
}
|
|
540
|
-
}
|
|
541
|
-
|
|
542
|
-
/**
|
|
543
|
-
* This is needed just in case the browser decides to make the editor
|
|
544
|
-
* lose focus without triggering the onBlur event (can happen in a few cases).
|
|
545
|
-
* This will also trigger onBlur if the user clicks outside of the page when the editor
|
|
546
|
-
* is focused.
|
|
547
|
-
*/
|
|
548
|
-
if (editorDOM === document.activeElement) {
|
|
549
|
-
editorDOM.removeEventListener('blur', _this.handleDomBlur);
|
|
550
|
-
editorDOM.addEventListener('blur', _this.handleDomBlur);
|
|
551
|
-
}
|
|
552
|
-
_this.stashValue();
|
|
553
|
-
_this.props.onFocus();
|
|
554
|
-
|
|
555
|
-
// Added for accessibility: Ensures the editor gains focus when tabbed to for improved keyboard navigation
|
|
556
|
-
var shouldFocusEditor = !_this.keypadInteractionDetected && !isTouchDevice;
|
|
557
|
-
if (shouldFocusEditor) {
|
|
558
|
-
change === null || change === void 0 || change.focus();
|
|
559
|
-
}
|
|
560
|
-
resolve();
|
|
561
|
-
});
|
|
562
|
-
});
|
|
563
|
-
(0, _defineProperty2["default"])(_this, "stashValue", function () {
|
|
564
|
-
log('[stashValue]');
|
|
565
|
-
if (!_this.state.stashedValue) {
|
|
566
|
-
_this.setState({
|
|
567
|
-
stashedValue: _this.state.value
|
|
568
|
-
});
|
|
569
|
-
}
|
|
570
|
-
});
|
|
571
|
-
/**
|
|
572
|
-
* Reset the value if the user didn't click done.
|
|
573
|
-
*/
|
|
574
|
-
(0, _defineProperty2["default"])(_this, "resetValue", function (force) {
|
|
575
|
-
var _this$state2 = _this.state,
|
|
576
|
-
value = _this$state2.value,
|
|
577
|
-
focusedNode = _this$state2.focusedNode;
|
|
578
|
-
var stopReset = _this.plugins.reduce(function (s, p) {
|
|
579
|
-
return s || p.stopReset && p.stopReset(_this.state.value);
|
|
580
|
-
}, false);
|
|
581
|
-
log('[resetValue]', value.isFocused, focusedNode, 'stopReset: ', stopReset);
|
|
582
|
-
if (_this.state.stashedValue && !value.isFocused && !focusedNode && !stopReset || force) {
|
|
583
|
-
log('[resetValue] resetting...');
|
|
584
|
-
log('stashed', _this.state.stashedValue.document.toObject());
|
|
585
|
-
log('current', _this.state.value.document.toObject());
|
|
586
|
-
var newValue = _slate.Value.fromJSON(_this.state.stashedValue.toJSON());
|
|
587
|
-
log('newValue: ', newValue.document);
|
|
588
|
-
return new Promise(function (resolve) {
|
|
589
|
-
setTimeout(function () {
|
|
590
|
-
_this.setState({
|
|
591
|
-
value: newValue,
|
|
592
|
-
stashedValue: null
|
|
593
|
-
}, function () {
|
|
594
|
-
log('value now: ', _this.state.value.document.toJSON());
|
|
595
|
-
resolve();
|
|
596
|
-
});
|
|
597
|
-
}, 50);
|
|
598
|
-
});
|
|
599
|
-
} else {
|
|
600
|
-
return Promise.resolve({});
|
|
601
|
-
}
|
|
602
|
-
});
|
|
603
|
-
(0, _defineProperty2["default"])(_this, "onChange", function (change, done) {
|
|
604
|
-
log('[onChange]');
|
|
605
|
-
window.me = _this;
|
|
606
|
-
var value = change.value;
|
|
607
|
-
var charactersLimit = _this.props.charactersLimit;
|
|
608
|
-
var limit = charactersLimit;
|
|
609
|
-
if (!limit || limit > MAX_CHARACTERS_LIMIT) {
|
|
610
|
-
limit = MAX_CHARACTERS_LIMIT;
|
|
611
|
-
}
|
|
612
|
-
if (value && value.document && value.document.text && value.document.text.length > limit) {
|
|
613
|
-
return;
|
|
614
|
-
}
|
|
615
|
-
|
|
616
|
-
// Mark the editor as edited when in HTML mode and its content has changed.
|
|
617
|
-
// This status will later be used to decide whether to prompt a warning to the user when exiting HTML mode.
|
|
618
|
-
var isEditedInHtmlMode = !_this.state.isHtmlMode ? false : _this.state.value.document.text !== value.document.text ? true : _this.state.isEditedInHtmlMode;
|
|
619
|
-
if (isEditedInHtmlMode != _this.state.isEditedInHtmlMode) {
|
|
620
|
-
_this.handlePlugins(_this.props);
|
|
621
|
-
}
|
|
622
|
-
_this.setState({
|
|
623
|
-
value: value,
|
|
624
|
-
isEditedInHtmlMode: isEditedInHtmlMode
|
|
625
|
-
}, function () {
|
|
626
|
-
log('[onChange], call done()');
|
|
627
|
-
if (done) {
|
|
628
|
-
done();
|
|
629
|
-
}
|
|
630
|
-
});
|
|
631
|
-
});
|
|
632
|
-
(0, _defineProperty2["default"])(_this, "getFocusedValue", function () {
|
|
633
|
-
if (_this.state.value.isFocused) {
|
|
634
|
-
return _this.state.value;
|
|
635
|
-
}
|
|
636
|
-
return _this.state.preBlurValue;
|
|
637
|
-
});
|
|
638
|
-
(0, _defineProperty2["default"])(_this, "validateNode", function (node) {
|
|
639
|
-
if (node.object !== 'block') return;
|
|
640
|
-
var last = node.nodes.last();
|
|
641
|
-
if (!last) return;
|
|
642
|
-
if (last.type !== 'image') return;
|
|
643
|
-
log('[validateNode] last is image..');
|
|
644
|
-
var parent = last.getParent(last.key);
|
|
645
|
-
var p = _slate.Block.getParent(last.key);
|
|
646
|
-
log('[validateNode] parent:', parent, p);
|
|
647
|
-
return undefined;
|
|
648
|
-
});
|
|
649
|
-
(0, _defineProperty2["default"])(_this, "changeData", function (key, data) {
|
|
650
|
-
log('[changeData]. .. ', key, data);
|
|
651
|
-
|
|
652
|
-
/**
|
|
653
|
-
* HACK ALERT: We should be calling setState here and storing the change data:
|
|
654
|
-
*
|
|
655
|
-
* <code>this.setState({changeData: { key, data}})</code>
|
|
656
|
-
* However this is causing issues with the Mathquill instance. The 'input' event stops firing on the element and no
|
|
657
|
-
* more changes get through. The issues seem to be related to the promises in onBlur/onFocus. But removing these
|
|
658
|
-
* brings it's own problems. A major clean up is planned for this component so I've decided to temporarily settle
|
|
659
|
-
* on this hack rather than spend more time on this.
|
|
660
|
-
*/
|
|
661
|
-
|
|
662
|
-
// Uncomment this line to see the bug described above.
|
|
663
|
-
// this.setState({changeData: {key, data}})
|
|
664
|
-
|
|
665
|
-
_this.__TEMPORARY_CHANGE_DATA = {
|
|
666
|
-
key: key,
|
|
667
|
-
data: data
|
|
668
|
-
};
|
|
669
|
-
});
|
|
670
|
-
(0, _defineProperty2["default"])(_this, "focus", function (pos, node) {
|
|
671
|
-
var position = pos || 'end';
|
|
672
|
-
_this.props.focus(position, node);
|
|
673
|
-
});
|
|
674
|
-
(0, _defineProperty2["default"])(_this, "onDropPaste", /*#__PURE__*/function () {
|
|
675
|
-
var _ref3 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee(event, change, dropContext) {
|
|
676
|
-
var editor, transfer, file, type, fragment, text, src, inline, range, ch, handler, _change$value, _document, selection, startBlock, defaultBlock, defaultMarks, frag, _t;
|
|
677
|
-
return _regenerator["default"].wrap(function (_context) {
|
|
678
|
-
while (1) switch (_context.prev = _context.next) {
|
|
679
|
-
case 0:
|
|
680
|
-
editor = change.editor;
|
|
681
|
-
transfer = (0, _slateReact.getEventTransfer)(event);
|
|
682
|
-
file = transfer.files && transfer.files[0];
|
|
683
|
-
type = transfer.type;
|
|
684
|
-
fragment = transfer.fragment;
|
|
685
|
-
text = transfer.text;
|
|
686
|
-
if (!(file && (file.type === 'image/jpeg' || file.type === 'image/jpg' || file.type === 'image/png'))) {
|
|
687
|
-
_context.next = 5;
|
|
688
|
-
break;
|
|
689
|
-
}
|
|
690
|
-
if (_this.props.imageSupport) {
|
|
691
|
-
_context.next = 1;
|
|
692
|
-
break;
|
|
693
|
-
}
|
|
694
|
-
return _context.abrupt("return");
|
|
695
|
-
case 1:
|
|
696
|
-
_context.prev = 1;
|
|
697
|
-
log('[onDropPaste]');
|
|
698
|
-
_context.next = 2;
|
|
699
|
-
return (0, _serialization.getBase64)(file);
|
|
700
|
-
case 2:
|
|
701
|
-
src = _context.sent;
|
|
702
|
-
inline = _slate.Inline.create({
|
|
703
|
-
type: 'image',
|
|
704
|
-
isVoid: true,
|
|
705
|
-
data: {
|
|
706
|
-
loading: false,
|
|
707
|
-
src: src
|
|
708
|
-
}
|
|
709
|
-
});
|
|
710
|
-
if (dropContext) {
|
|
711
|
-
_this.focus();
|
|
712
|
-
} else {
|
|
713
|
-
range = (0, _slateReact.getEventRange)(event, editor);
|
|
714
|
-
if (range) {
|
|
715
|
-
change.select(range);
|
|
716
|
-
}
|
|
717
|
-
}
|
|
718
|
-
ch = change.insertInline(inline);
|
|
719
|
-
_this.onChange(ch);
|
|
720
|
-
handler = new _insertImageHandler["default"](inline, function () {}, function () {
|
|
721
|
-
return _this.state.value;
|
|
722
|
-
}, _this.onChange, true);
|
|
723
|
-
handler.fileChosen(file);
|
|
724
|
-
_this.props.imageSupport.add(handler);
|
|
725
|
-
_context.next = 4;
|
|
726
|
-
break;
|
|
727
|
-
case 3:
|
|
728
|
-
_context.prev = 3;
|
|
729
|
-
_t = _context["catch"](1);
|
|
730
|
-
log('[onDropPaste] error: ', _t);
|
|
731
|
-
case 4:
|
|
732
|
-
_context.next = 9;
|
|
733
|
-
break;
|
|
734
|
-
case 5:
|
|
735
|
-
if (!(type === 'fragment')) {
|
|
736
|
-
_context.next = 6;
|
|
737
|
-
break;
|
|
738
|
-
}
|
|
739
|
-
change.insertFragment(fragment);
|
|
740
|
-
_context.next = 9;
|
|
741
|
-
break;
|
|
742
|
-
case 6:
|
|
743
|
-
if (!(type === 'text' || type === 'html')) {
|
|
744
|
-
_context.next = 9;
|
|
745
|
-
break;
|
|
746
|
-
}
|
|
747
|
-
if (text) {
|
|
748
|
-
_context.next = 7;
|
|
749
|
-
break;
|
|
750
|
-
}
|
|
751
|
-
return _context.abrupt("return");
|
|
752
|
-
case 7:
|
|
753
|
-
_change$value = change.value, _document = _change$value.document, selection = _change$value.selection, startBlock = _change$value.startBlock;
|
|
754
|
-
if (!startBlock.isVoid) {
|
|
755
|
-
_context.next = 8;
|
|
756
|
-
break;
|
|
757
|
-
}
|
|
758
|
-
return _context.abrupt("return");
|
|
759
|
-
case 8:
|
|
760
|
-
defaultBlock = startBlock;
|
|
761
|
-
defaultMarks = _document.getInsertMarksAtRange(selection);
|
|
762
|
-
frag = _slatePlainSerializer["default"].deserialize(text, {
|
|
763
|
-
defaultBlock: defaultBlock,
|
|
764
|
-
defaultMarks: defaultMarks
|
|
765
|
-
}).document;
|
|
766
|
-
change.insertFragment(frag);
|
|
767
|
-
case 9:
|
|
768
|
-
case "end":
|
|
769
|
-
return _context.stop();
|
|
770
|
-
}
|
|
771
|
-
}, _callee, null, [[1, 3]]);
|
|
772
|
-
}));
|
|
773
|
-
return function (_x, _x2, _x3) {
|
|
774
|
-
return _ref3.apply(this, arguments);
|
|
775
|
-
};
|
|
776
|
-
}());
|
|
777
|
-
(0, _defineProperty2["default"])(_this, "renderPlaceholder", function (props) {
|
|
778
|
-
var editor = props.editor;
|
|
779
|
-
var document = editor.value.document;
|
|
780
|
-
if (!editor.props.placeholder || document.text !== '' || document.nodes.size !== 1 || !document.isEmpty) {
|
|
781
|
-
return false;
|
|
782
|
-
}
|
|
783
|
-
return /*#__PURE__*/_react["default"].createElement("span", {
|
|
784
|
-
contentEditable: false,
|
|
785
|
-
style: {
|
|
786
|
-
display: 'inline-block',
|
|
787
|
-
width: 'fit-content',
|
|
788
|
-
// for centering the placeholder if text-align is set to center
|
|
789
|
-
maxWidth: '100%',
|
|
790
|
-
whiteSpace: 'nowrap',
|
|
791
|
-
opacity: '0.33',
|
|
792
|
-
pointerEvents: 'none',
|
|
793
|
-
userSelect: 'none'
|
|
794
|
-
}
|
|
795
|
-
}, editor.props.placeholder);
|
|
796
|
-
});
|
|
797
|
-
_this.state = {
|
|
798
|
-
value: _props.value,
|
|
799
|
-
toolbarOpts: createToolbarOpts(_props.toolbarOpts, _props.error),
|
|
800
|
-
pendingImages: [],
|
|
801
|
-
isHtmlMode: false,
|
|
802
|
-
isEditedInHtmlMode: false,
|
|
803
|
-
focusToolbar: false,
|
|
804
|
-
dialog: {
|
|
805
|
-
open: false
|
|
806
|
-
}
|
|
807
|
-
};
|
|
808
|
-
_this.keyPadCharacterRef = /*#__PURE__*/_react["default"].createRef();
|
|
809
|
-
_this.doneButtonRef = /*#__PURE__*/_react["default"].createRef();
|
|
810
|
-
_this.keypadInteractionDetected = false;
|
|
811
|
-
_this.toggleHtmlMode = _this.toggleHtmlMode.bind(_this);
|
|
812
|
-
_this.handleToolbarFocus = _this.handleToolbarFocus.bind(_this);
|
|
813
|
-
_this.handleToolbarBlur = _this.handleToolbarBlur.bind(_this);
|
|
814
|
-
_this.onResize = (0, _debounce["default"])(function () {
|
|
815
|
-
if (!_this.state.isHtmlMode && _props.onChange) {
|
|
816
|
-
_props.onChange(_this.state.value, true);
|
|
817
|
-
}
|
|
818
|
-
}, 50);
|
|
819
|
-
_this.handlePlugins(_this.props);
|
|
820
|
-
return _this;
|
|
821
|
-
}
|
|
822
|
-
(0, _inherits2["default"])(Editor, _React$Component);
|
|
823
|
-
return (0, _createClass2["default"])(Editor, [{
|
|
824
|
-
key: "handleToolbarFocus",
|
|
825
|
-
value: function handleToolbarFocus() {
|
|
826
|
-
if (this.state.focusToolbar) {
|
|
827
|
-
return;
|
|
828
|
-
}
|
|
829
|
-
this.setState({
|
|
830
|
-
focusToolbar: true
|
|
831
|
-
});
|
|
832
|
-
}
|
|
833
|
-
}, {
|
|
834
|
-
key: "handleToolbarBlur",
|
|
835
|
-
value: function handleToolbarBlur() {
|
|
836
|
-
var _this2 = this;
|
|
837
|
-
setTimeout(function () {
|
|
838
|
-
if (!_this2.toolbarContainsFocus()) {
|
|
839
|
-
_this2.setState({
|
|
840
|
-
focusToolbar: false
|
|
841
|
-
});
|
|
842
|
-
}
|
|
843
|
-
}, 0);
|
|
844
|
-
}
|
|
845
|
-
}, {
|
|
846
|
-
key: "toolbarContainsFocus",
|
|
847
|
-
value: function toolbarContainsFocus() {
|
|
848
|
-
if (!this.toolbarRef) return false;
|
|
849
|
-
var toolbarElement = this.toolbarRef;
|
|
850
|
-
var activeElement = document.activeElement;
|
|
851
|
-
return toolbarElement && toolbarElement.contains(activeElement);
|
|
852
|
-
}
|
|
853
|
-
}, {
|
|
854
|
-
key: "componentDidMount",
|
|
855
|
-
value: function componentDidMount() {
|
|
856
|
-
var _this$props$className,
|
|
857
|
-
_this3 = this;
|
|
858
|
-
// onRef is needed to get the ref of the component
|
|
859
|
-
this.props.onRef(this);
|
|
860
|
-
window.addEventListener('resize', this.onResize);
|
|
861
|
-
var isResponseAreaEditor = (_this$props$className = this.props.className) === null || _this$props$className === void 0 ? void 0 : _this$props$className.includes('response-area-editor');
|
|
862
|
-
if (isResponseAreaEditor && this.editor) {
|
|
863
|
-
var responseAreaEditor = document.querySelector("[data-key=\"".concat(this.editor.value.document.key, "\"]"));
|
|
864
|
-
if (responseAreaEditor) {
|
|
865
|
-
responseAreaEditor.setAttribute('aria-label', 'Answer');
|
|
866
|
-
}
|
|
867
|
-
}
|
|
868
|
-
if (this.editor && this.props.autoFocus) {
|
|
869
|
-
Promise.resolve().then(function () {
|
|
870
|
-
if (_this3.editor) {
|
|
871
|
-
var editorDOM = document.querySelector("[data-key=\"".concat(_this3.editor.value.document.key, "\"]"));
|
|
872
|
-
_this3.editor.focus();
|
|
873
|
-
if (editorDOM) {
|
|
874
|
-
editorDOM.focus();
|
|
875
|
-
}
|
|
876
|
-
}
|
|
877
|
-
});
|
|
878
|
-
}
|
|
879
|
-
}
|
|
880
|
-
}, {
|
|
881
|
-
key: "UNSAFE_componentWillReceiveProps",
|
|
882
|
-
value: function UNSAFE_componentWillReceiveProps(nextProps) {
|
|
883
|
-
var _nextProps$value, _this$props$value;
|
|
884
|
-
var _this$state3 = this.state,
|
|
885
|
-
isHtmlMode = _this$state3.isHtmlMode,
|
|
886
|
-
toolbarOpts = _this$state3.toolbarOpts;
|
|
887
|
-
var newToolbarOpts = createToolbarOpts(nextProps.toolbarOpts, nextProps.error, isHtmlMode);
|
|
888
|
-
if (!(0, _isEqual["default"])(newToolbarOpts, toolbarOpts)) {
|
|
889
|
-
this.setState({
|
|
890
|
-
toolbarOpts: newToolbarOpts
|
|
891
|
-
});
|
|
892
|
-
}
|
|
893
|
-
var differentCharacterProps = !(0, _isEqual["default"])(nextProps.languageCharactersProps, this.props.languageCharactersProps);
|
|
894
|
-
var differentMathMlProps = !(0, _isEqual["default"])(nextProps.mathMlOptions, this.props.mathMlOptions);
|
|
895
|
-
var differentImageMaxDimensionsProps = !(0, _isEqual["default"])(nextProps.maxImageWidth, this.props.maxImageWidth) || !(0, _isEqual["default"])(nextProps.maxImageHeight, this.props.maxImageHeight);
|
|
896
|
-
if (differentCharacterProps || differentMathMlProps || differentImageMaxDimensionsProps) {
|
|
897
|
-
this.handlePlugins(nextProps);
|
|
898
|
-
}
|
|
899
|
-
if (!((_nextProps$value = nextProps.value) !== null && _nextProps$value !== void 0 && (_nextProps$value = _nextProps$value.document) !== null && _nextProps$value !== void 0 && _nextProps$value.equals((_this$props$value = this.props.value) === null || _this$props$value === void 0 ? void 0 : _this$props$value.document))) {
|
|
900
|
-
this.setState({
|
|
901
|
-
focus: false,
|
|
902
|
-
value: nextProps.value
|
|
903
|
-
});
|
|
904
|
-
}
|
|
905
|
-
}
|
|
906
|
-
}, {
|
|
907
|
-
key: "componentDidUpdate",
|
|
908
|
-
value: function componentDidUpdate(prevProps, prevState) {
|
|
909
|
-
// The cursor is on a zero width element and when that is placed near void elements, it is not visible
|
|
910
|
-
// so we increase the width to at least 2px in order for the user to see it
|
|
911
|
-
|
|
912
|
-
// Trigger plugins and finish editing if:
|
|
913
|
-
// 1. The 'isHtmlMode' state has been toggled.
|
|
914
|
-
// 2. We're currently in 'isHtmlMode' and the editor value has been modified.
|
|
915
|
-
if (this.state.isHtmlMode !== prevState.isHtmlMode || this.state.isHtmlMode && !prevState.isEditedInHtmlMode && this.state.isEditedInHtmlMode) {
|
|
916
|
-
this.handlePlugins(this.props);
|
|
917
|
-
}
|
|
918
|
-
var zeroWidthEls = document.querySelectorAll('[data-slate-zero-width="z"]');
|
|
919
|
-
Array.from(zeroWidthEls).forEach(function (el) {
|
|
920
|
-
el.style.minWidth = '2px';
|
|
921
|
-
el.style.display = 'inline-block';
|
|
922
|
-
});
|
|
923
|
-
}
|
|
924
|
-
}, {
|
|
925
|
-
key: "componentWillUnmount",
|
|
926
|
-
value:
|
|
927
|
-
/**
|
|
928
|
-
* Remove onResize event listener
|
|
929
|
-
*/
|
|
930
|
-
function componentWillUnmount() {
|
|
931
|
-
window.removeEventListener('resize', this.onResize);
|
|
932
|
-
}
|
|
933
|
-
}, {
|
|
934
|
-
key: "buildSizeStyle",
|
|
935
|
-
value:
|
|
936
|
-
// Use the exported utility functions
|
|
937
|
-
function buildSizeStyle() {
|
|
938
|
-
return _buildSizeStyle(this.props);
|
|
939
|
-
}
|
|
940
|
-
}, {
|
|
941
|
-
key: "render",
|
|
942
|
-
value: function render() {
|
|
943
|
-
var _this4 = this,
|
|
944
|
-
_value$document;
|
|
945
|
-
var _this$props = this.props,
|
|
946
|
-
disabled = _this$props.disabled,
|
|
947
|
-
spellCheck = _this$props.spellCheck,
|
|
948
|
-
highlightShape = _this$props.highlightShape,
|
|
949
|
-
className = _this$props.className,
|
|
950
|
-
placeholder = _this$props.placeholder,
|
|
951
|
-
pluginProps = _this$props.pluginProps,
|
|
952
|
-
onKeyDown = _this$props.onKeyDown,
|
|
953
|
-
slateEditorExtraStyles = _this$props.slateEditorExtraStyles;
|
|
954
|
-
// We don't want to send customPlugins to slate.
|
|
955
|
-
// Not sure if they would do any harm, but I think it's better to not send them.
|
|
956
|
-
// We use custom plugins to be able to add custom buttons
|
|
957
|
-
// eslint-disable-next-line no-unused-vars
|
|
958
|
-
var _ref4 = pluginProps || {},
|
|
959
|
-
customPlugins = _ref4.customPlugins,
|
|
960
|
-
showParagraphs = _ref4.showParagraphs,
|
|
961
|
-
separateParagraphs = _ref4.separateParagraphs,
|
|
962
|
-
otherPluginProps = (0, _objectWithoutProperties2["default"])(_ref4, _excluded);
|
|
963
|
-
var _this$state4 = this.state,
|
|
964
|
-
value = _this$state4.value,
|
|
965
|
-
focusedNode = _this$state4.focusedNode,
|
|
966
|
-
toolbarOpts = _this$state4.toolbarOpts,
|
|
967
|
-
dialog = _this$state4.dialog,
|
|
968
|
-
scheduled = _this$state4.scheduled;
|
|
969
|
-
log('[render] value: ', value);
|
|
970
|
-
var sizeStyle = this.buildSizeStyle();
|
|
971
|
-
var wrapperClassNames = (0, _classnames["default"])({
|
|
972
|
-
withBg: highlightShape,
|
|
973
|
-
toolbarOnTop: toolbarOpts.alwaysVisible && toolbarOpts.position === 'top',
|
|
974
|
-
scheduled: scheduled
|
|
975
|
-
}, className);
|
|
976
|
-
return /*#__PURE__*/_react["default"].createElement(StyledEditorWrapper, {
|
|
977
|
-
ref: function ref(_ref5) {
|
|
978
|
-
return _this4.wrapperRef = _ref5;
|
|
979
|
-
},
|
|
980
|
-
style: {
|
|
981
|
-
width: sizeStyle.width,
|
|
982
|
-
minWidth: sizeStyle.minWidth,
|
|
983
|
-
maxWidth: sizeStyle.maxWidth
|
|
984
|
-
},
|
|
985
|
-
className: wrapperClassNames,
|
|
986
|
-
id: "editor-".concat(value === null || value === void 0 || (_value$document = value.document) === null || _value$document === void 0 ? void 0 : _value$document.key)
|
|
987
|
-
}, scheduled && /*#__PURE__*/_react["default"].createElement(StyledUploadingMessage, null, "Uploading image and then saving..."), /*#__PURE__*/_react["default"].createElement(StyledSlateEditor, {
|
|
988
|
-
className: (0, _classnames["default"])({
|
|
989
|
-
noPadding: toolbarOpts === null || toolbarOpts === void 0 ? void 0 : toolbarOpts.noPadding,
|
|
990
|
-
showParagraph: showParagraphs && !showParagraphs.disabled,
|
|
991
|
-
separateParagraph: separateParagraphs && !separateParagraphs.disabled
|
|
992
|
-
})
|
|
993
|
-
}, /*#__PURE__*/_react["default"].createElement(_slateReact.Editor, {
|
|
994
|
-
plugins: this.plugins,
|
|
995
|
-
innerRef: function innerRef(r) {
|
|
996
|
-
if (r) {
|
|
997
|
-
_this4.slateEditor = r;
|
|
998
|
-
}
|
|
999
|
-
},
|
|
1000
|
-
ref: function ref(r) {
|
|
1001
|
-
return _this4.editor = r && _this4.props.editorRef(r);
|
|
1002
|
-
},
|
|
1003
|
-
toolbarRef: function toolbarRef(r) {
|
|
1004
|
-
if (r) {
|
|
1005
|
-
_this4.toolbarRef = r;
|
|
1006
|
-
}
|
|
1007
|
-
},
|
|
1008
|
-
doneButtonRef: this.doneButtonRef,
|
|
1009
|
-
value: value,
|
|
1010
|
-
focusToolbar: this.state.focusToolbar,
|
|
1011
|
-
onToolbarFocus: this.handleToolbarFocus,
|
|
1012
|
-
onToolbarBlur: this.handleToolbarBlur,
|
|
1013
|
-
focus: this.focus,
|
|
1014
|
-
onKeyDown: onKeyDown,
|
|
1015
|
-
onChange: this.onChange,
|
|
1016
|
-
getFocusedValue: this.getFocusedValue,
|
|
1017
|
-
onBlur: this.onBlur,
|
|
1018
|
-
onDrop: function onDrop(event, editor) {
|
|
1019
|
-
return _this4.onDropPaste(event, editor, true);
|
|
1020
|
-
},
|
|
1021
|
-
onPaste: function onPaste(event, editor) {
|
|
1022
|
-
return _this4.onDropPaste(event, editor);
|
|
1023
|
-
},
|
|
1024
|
-
onFocus: this.onFocus,
|
|
1025
|
-
onEditingDone: this.onEditingDone,
|
|
1026
|
-
focusedNode: focusedNode,
|
|
1027
|
-
normalize: this.normalize,
|
|
1028
|
-
readOnly: disabled,
|
|
1029
|
-
spellCheck: spellCheck,
|
|
1030
|
-
autoCorrect: spellCheck,
|
|
1031
|
-
style: _objectSpread({
|
|
1032
|
-
minHeight: sizeStyle.minHeight,
|
|
1033
|
-
height: sizeStyle.height,
|
|
1034
|
-
maxHeight: sizeStyle.maxHeight
|
|
1035
|
-
}, slateEditorExtraStyles),
|
|
1036
|
-
pluginProps: otherPluginProps,
|
|
1037
|
-
toolbarOpts: toolbarOpts,
|
|
1038
|
-
placeholder: placeholder,
|
|
1039
|
-
renderPlaceholder: this.renderPlaceholder,
|
|
1040
|
-
onDataChange: this.changeData
|
|
1041
|
-
})), /*#__PURE__*/_react["default"].createElement(_alertDialog["default"], {
|
|
1042
|
-
open: dialog.open,
|
|
1043
|
-
title: dialog.title,
|
|
1044
|
-
text: dialog.text,
|
|
1045
|
-
onClose: dialog.onClose,
|
|
1046
|
-
onConfirm: dialog.onConfirm,
|
|
1047
|
-
onConfirmText: dialog.onConfirmText,
|
|
1048
|
-
onCloseText: dialog.onCloseText
|
|
1049
|
-
}));
|
|
1050
|
-
}
|
|
1051
|
-
}]);
|
|
1052
|
-
}(_react["default"].Component); // TODO color - hardcoded gray background and keypad colors will need to change too
|
|
1053
|
-
(0, _defineProperty2["default"])(Editor, "propTypes", {
|
|
1054
|
-
autoFocus: _propTypes["default"].bool,
|
|
1055
|
-
editorRef: _propTypes["default"].func.isRequired,
|
|
1056
|
-
error: _propTypes["default"].any,
|
|
1057
|
-
onRef: _propTypes["default"].func.isRequired,
|
|
1058
|
-
onChange: _propTypes["default"].func.isRequired,
|
|
1059
|
-
onFocus: _propTypes["default"].func,
|
|
1060
|
-
onBlur: _propTypes["default"].func,
|
|
1061
|
-
onKeyDown: _propTypes["default"].func,
|
|
1062
|
-
focus: _propTypes["default"].func.isRequired,
|
|
1063
|
-
value: _slatePropTypes["default"].value.isRequired,
|
|
1064
|
-
imageSupport: _propTypes["default"].object,
|
|
1065
|
-
mathMlOptions: _propTypes["default"].shape({
|
|
1066
|
-
mmlOutput: _propTypes["default"].bool,
|
|
1067
|
-
mmlEditing: _propTypes["default"].bool
|
|
1068
|
-
}),
|
|
1069
|
-
disableImageAlignmentButtons: _propTypes["default"].bool,
|
|
1070
|
-
uploadSoundSupport: _propTypes["default"].shape({
|
|
1071
|
-
add: _propTypes["default"].func,
|
|
1072
|
-
"delete": _propTypes["default"].func
|
|
1073
|
-
}),
|
|
1074
|
-
charactersLimit: _propTypes["default"].number,
|
|
1075
|
-
width: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
|
|
1076
|
-
minWidth: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
|
|
1077
|
-
maxWidth: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
|
|
1078
|
-
height: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
|
|
1079
|
-
minHeight: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
|
|
1080
|
-
maxHeight: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
|
|
1081
|
-
slateEditorExtraStyles: _propTypes["default"].object,
|
|
1082
|
-
highlightShape: _propTypes["default"].bool,
|
|
1083
|
-
disabled: _propTypes["default"].bool,
|
|
1084
|
-
spellCheck: _propTypes["default"].bool,
|
|
1085
|
-
nonEmpty: _propTypes["default"].bool,
|
|
1086
|
-
disableScrollbar: _propTypes["default"].bool,
|
|
1087
|
-
disableUnderline: _propTypes["default"].bool,
|
|
1088
|
-
autoWidthToolbar: _propTypes["default"].bool,
|
|
1089
|
-
pluginProps: _propTypes["default"].any,
|
|
1090
|
-
// customPlugins should be inside pluginProps (a property inside pluginProps)
|
|
1091
|
-
// customPlugins: PropTypes.arrayOf(
|
|
1092
|
-
// PropTypes.shape({
|
|
1093
|
-
// event: PropTypes.string,
|
|
1094
|
-
// icon: PropTypes.string,
|
|
1095
|
-
// iconType: PropTypes.string,
|
|
1096
|
-
// iconAlt: PropTypes.string
|
|
1097
|
-
// }),
|
|
1098
|
-
// ),
|
|
1099
|
-
placeholder: _propTypes["default"].string,
|
|
1100
|
-
isEditor: _propTypes["default"].bool,
|
|
1101
|
-
responseAreaProps: _propTypes["default"].shape({
|
|
1102
|
-
type: _propTypes["default"].oneOf(['explicit-constructed-response', 'inline-dropdown', 'drag-in-the-blank', 'math-templated']),
|
|
1103
|
-
options: _propTypes["default"].object,
|
|
1104
|
-
respAreaToolbar: _propTypes["default"].func,
|
|
1105
|
-
onHandleAreaChange: _propTypes["default"].func,
|
|
1106
|
-
maxResponseAreas: _propTypes["default"].number,
|
|
1107
|
-
error: _propTypes["default"].any
|
|
1108
|
-
}),
|
|
1109
|
-
extraCSSRules: _propTypes["default"].shape({
|
|
1110
|
-
names: _propTypes["default"].arrayOf(_propTypes["default"].string),
|
|
1111
|
-
rules: _propTypes["default"].string
|
|
1112
|
-
}),
|
|
1113
|
-
languageCharactersProps: _propTypes["default"].arrayOf(_propTypes["default"].shape({
|
|
1114
|
-
language: _propTypes["default"].string,
|
|
1115
|
-
characterIcon: _propTypes["default"].string,
|
|
1116
|
-
characters: _propTypes["default"].arrayOf(_propTypes["default"].arrayOf(_propTypes["default"].string))
|
|
1117
|
-
})),
|
|
1118
|
-
runSerializationOnMarkup: _propTypes["default"].func,
|
|
1119
|
-
toolbarOpts: _propTypes["default"].shape({
|
|
1120
|
-
position: _propTypes["default"].oneOf(['bottom', 'top']),
|
|
1121
|
-
alignment: _propTypes["default"].oneOf(['left', 'right']),
|
|
1122
|
-
alwaysVisible: _propTypes["default"].bool,
|
|
1123
|
-
showDone: _propTypes["default"].bool,
|
|
1124
|
-
doneOn: _propTypes["default"].string,
|
|
1125
|
-
minWidth: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number])
|
|
1126
|
-
}),
|
|
1127
|
-
activePlugins: _propTypes["default"].arrayOf(function (values) {
|
|
1128
|
-
var allValid = values.every(function (v) {
|
|
1129
|
-
return _plugins.ALL_PLUGINS.includes(v);
|
|
1130
|
-
});
|
|
1131
|
-
return !allValid && new Error("Invalid values: ".concat(values, ", values must be one of [").concat(_plugins.ALL_PLUGINS.join(','), "]"));
|
|
1132
|
-
}),
|
|
1133
|
-
className: _propTypes["default"].string,
|
|
1134
|
-
maxImageWidth: _propTypes["default"].number,
|
|
1135
|
-
maxImageHeight: _propTypes["default"].number
|
|
1136
|
-
});
|
|
1137
|
-
(0, _defineProperty2["default"])(Editor, "defaultProps", {
|
|
1138
|
-
disableUnderline: true,
|
|
1139
|
-
onFocus: function onFocus() {},
|
|
1140
|
-
onBlur: function onBlur() {},
|
|
1141
|
-
onKeyDown: function onKeyDown() {},
|
|
1142
|
-
runSerializationOnMarkup: function runSerializationOnMarkup() {},
|
|
1143
|
-
mathMlOptions: {
|
|
1144
|
-
mmlOutput: false,
|
|
1145
|
-
mmlEditing: false
|
|
1146
|
-
},
|
|
1147
|
-
toolbarOpts: defaultToolbarOpts,
|
|
1148
|
-
responseAreaProps: defaultResponseAreaProps,
|
|
1149
|
-
languageCharactersProps: defaultLanguageCharactersProps,
|
|
1150
|
-
extraCSSRules: null,
|
|
1151
|
-
isEditor: false
|
|
1152
|
-
});
|
|
1153
|
-
var StyledEditorWrapper = (0, _styles.styled)('div')(function () {
|
|
1154
|
-
return {
|
|
1155
|
-
'&.withBg': {
|
|
1156
|
-
backgroundColor: 'rgba(0,0,0,0.06)'
|
|
1157
|
-
},
|
|
1158
|
-
'&.scheduled': {
|
|
1159
|
-
opacity: 0.5,
|
|
1160
|
-
pointerEvents: 'none',
|
|
1161
|
-
position: 'relative'
|
|
1162
|
-
},
|
|
1163
|
-
'&.toolbarOnTop': {
|
|
1164
|
-
marginTop: '45px'
|
|
1165
|
-
}
|
|
1166
|
-
};
|
|
1167
|
-
});
|
|
1168
|
-
var StyledUploadingMessage = (0, _styles.styled)('div')({
|
|
1169
|
-
position: 'absolute',
|
|
1170
|
-
top: '50%',
|
|
1171
|
-
left: '50%',
|
|
1172
|
-
transform: 'translate(-50%, -50%)'
|
|
1173
|
-
});
|
|
1174
|
-
var StyledSlateEditor = (0, _styles.styled)('div')(function () {
|
|
1175
|
-
return {
|
|
1176
|
-
'& table': {
|
|
1177
|
-
tableLayout: 'fixed',
|
|
1178
|
-
width: '100%',
|
|
1179
|
-
borderCollapse: 'collapse',
|
|
1180
|
-
color: _renderUi.color.text(),
|
|
1181
|
-
backgroundColor: _renderUi.color.background()
|
|
1182
|
-
},
|
|
1183
|
-
'& table:not([border="1"]) tr': {
|
|
1184
|
-
borderTop: '1px solid #dfe2e5'
|
|
1185
|
-
// TODO perhaps secondary color for background, for now disable
|
|
1186
|
-
// '&:nth-child(2n)': {
|
|
1187
|
-
// backgroundColor: '#f6f8fa'
|
|
1188
|
-
// }
|
|
1189
|
-
},
|
|
1190
|
-
'& td, th': {
|
|
1191
|
-
padding: '.6em 1em',
|
|
1192
|
-
textAlign: 'center'
|
|
1193
|
-
},
|
|
1194
|
-
'& table:not([border="1"]) td, th': {
|
|
1195
|
-
border: '1px solid #dfe2e5'
|
|
1196
|
-
},
|
|
1197
|
-
'&.showParagraph': {
|
|
1198
|
-
// a div that has a div after it
|
|
1199
|
-
'& > div:has(+ div)::after': {
|
|
1200
|
-
display: 'block',
|
|
1201
|
-
content: '"¶"',
|
|
1202
|
-
fontSize: '1em',
|
|
1203
|
-
color: '#146EB3'
|
|
1204
|
-
}
|
|
1205
|
-
},
|
|
1206
|
-
'&.separateParagraph': {
|
|
1207
|
-
// a div that has a div after it
|
|
1208
|
-
'& > div:has(+ div)': {
|
|
1209
|
-
marginBottom: '1em'
|
|
1210
|
-
}
|
|
1211
|
-
},
|
|
1212
|
-
'&.noPadding': {
|
|
1213
|
-
padding: '0 !important'
|
|
1214
|
-
}
|
|
1215
|
-
};
|
|
1216
|
-
});
|
|
1217
|
-
var StyledPreviewText = (0, _styles.styled)('div')({
|
|
1218
|
-
marginBottom: '36px',
|
|
1219
|
-
marginTop: '6px',
|
|
1220
|
-
padding: '20px',
|
|
1221
|
-
backgroundColor: 'rgba(0,0,0,0.06)'
|
|
1222
|
-
});
|
|
1223
|
-
var _default = exports["default"] = Editor;
|
|
1224
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_slateReact","_slatePropTypes","_slate","_slatePlainSerializer","_propTypes","_debounce","_isEqual","_classnames","_debug","_styles","_renderUi","_alertDialog","_serialization","_interopRequireWildcard","serialization","exports","_insertImageHandler","_plugins","_excluded","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t2","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","ownKeys","keys","getOwnPropertySymbols","filter","enumerable","push","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","log","debug","defaultToolbarOpts","position","alignment","alwaysVisible","showDone","doneOn","defaultResponseAreaProps","options","respAreaToolbar","onHandleAreaChange","defaultLanguageCharactersProps","createToolbarOpts","toolbarOpts","error","isHtmlMode","valueToSize","v","calcRegex","endsWith","undefined","match","value","parseInt","isNaN","concat","buildSizeStyle","props","minWidth","width","maxWidth","minHeight","height","maxHeight","MAX_CHARACTERS_LIMIT","Editor","_React$Component","_this","_classCallCheck2","interacted","keypadInteractionDetected","open","extraDialogProps","callback","setState","dialog","prevState","isEditedInHtmlMode","state","newToolbarOpts","normalizedResponseAreaProps","responseAreaProps","htmlPluginOpts","currentValue","toggleHtmlMode","handleAlertDialog","handleDialog","_ref","pluginProps","customPlugins","plugins","buildPlugins","activePlugins","math","onClick","onMathClick","onFocus","onPluginFocus","onBlur","onPluginBlur","mathMlOptions","textAlign","getValue","onChange","html","extraCSSRules","image","disableImageAlignmentButtons","onDelete","imageSupport","node","done","src","data","newPendingImages","pendingImages","img","key","oldScheduled","scheduled","newState","insertImageRequested","addedImage","getHandler","onFinish","result","cb","onEditingDone","bind","handler","add","_toConsumableArray2","maxImageWidth","maxImageHeight","toolbar","disableScrollbar","disableUnderline","autoWidth","autoWidthToolbar","onDone","_this$state$value$sta","nonEmpty","toolbarInFocus","focusedNode","focusToolbar","editor","blur","startText","text","resetValue","then","table","responseArea","type","maxResponseAreas","languageCharacters","languageCharactersProps","keyPadCharacterRef","setKeypadInteraction","media","focus","createChange","change","uploadSoundSupport","mmlOutput","mmlEditing","runSerializationOnMarkup","relatedTarget","target","findNode","stashedValue","stashValue","c","collapseToStartOf","selectedNode","_this$state","htmlToValue","document","previewText","renderHtmlPreviewContent","openHtmlModeConfirmationDialog","createElement","ref","elementRef","StyledPreviewText","PreviewPrompt","prompt","title","onConfirmText","onCloseText","onConfirm","handleHtmlModeSaveConfirmation","onClose","htmlModeContinueEditing","resolve","_this$state$value$sta2","event","_this$doneButtonRef$c","toolbarElement","toolbarRef","closest","className","isRawDoneButton","doneButtonRef","current","skipBlurHandling","Promise","preBlurValue","handleBlur","editorDOM","querySelector","setTimeout","stateValue","wrapperRef","editorElement","activeElement","isInCurrentComponent","contains","removeEventListener","handleDomBlur","isFocused","_navigator","isTouchDevice","window","navigator","maxTouchPoints","__TEMPORARY_CHANGE_DATA","_this$__TEMPORARY_CHA","domEl","setNodeByKey","addEventListener","shouldFocusEditor","force","_this$state2","stopReset","reduce","s","p","toObject","newValue","Value","fromJSON","toJSON","me","charactersLimit","limit","handlePlugins","object","last","nodes","parent","getParent","Block","pos","_ref3","_asyncToGenerator2","_regenerator","mark","_callee","dropContext","transfer","file","fragment","inline","range","ch","_change$value","_document","selection","startBlock","defaultBlock","defaultMarks","frag","_t","wrap","_context","prev","next","getEventTransfer","files","abrupt","getBase64","sent","Inline","create","isVoid","loading","getEventRange","select","insertInline","InsertImageHandler","fileChosen","insertFragment","getInsertMarksAtRange","Plain","deserialize","stop","_x","_x2","_x3","placeholder","size","isEmpty","contentEditable","style","display","whiteSpace","opacity","pointerEvents","userSelect","React","createRef","handleToolbarFocus","handleToolbarBlur","onResize","debounce","_inherits2","_createClass2","_this2","toolbarContainsFocus","componentDidMount","_this$props$className","_this3","onRef","isResponseAreaEditor","includes","responseAreaEditor","setAttribute","autoFocus","UNSAFE_componentWillReceiveProps","nextProps","_nextProps$value","_this$props$value","_this$state3","isEqual","differentCharacterProps","differentMathMlProps","differentImageMaxDimensionsProps","equals","componentDidUpdate","prevProps","zeroWidthEls","querySelectorAll","Array","from","el","componentWillUnmount","render","_this4","_value$document","_this$props","disabled","spellCheck","highlightShape","onKeyDown","slateEditorExtraStyles","_ref4","showParagraphs","separateParagraphs","otherPluginProps","_objectWithoutProperties2","_this$state4","sizeStyle","wrapperClassNames","classNames","withBg","toolbarOnTop","StyledEditorWrapper","id","StyledUploadingMessage","StyledSlateEditor","noPadding","showParagraph","separateParagraph","innerRef","slateEditor","editorRef","onToolbarFocus","onToolbarBlur","getFocusedValue","onDrop","onDropPaste","onPaste","normalize","readOnly","autoCorrect","renderPlaceholder","onDataChange","changeData","Component","PropTypes","bool","func","isRequired","any","SlateTypes","shape","number","oneOfType","string","isEditor","oneOf","names","arrayOf","rules","language","characterIcon","characters","values","allValid","every","ALL_PLUGINS","Error","join","styled","backgroundColor","marginTop","top","left","transform","tableLayout","borderCollapse","color","background","borderTop","padding","border","content","fontSize","marginBottom","_default"],"sources":["../src/editor.jsx"],"sourcesContent":["import React from 'react';\nimport { Editor as SlateEditor, findNode, getEventRange, getEventTransfer } from 'slate-react';\nimport SlateTypes from 'slate-prop-types';\nimport { Value, Block, Inline } from 'slate';\nimport Plain from 'slate-plain-serializer';\nimport PropTypes from 'prop-types';\nimport debounce from 'lodash/debounce';\nimport isEqual from 'lodash/isEqual';\nimport classNames from 'classnames';\nimport debug from 'debug';\nimport { styled } from '@mui/material/styles';\n\nimport { color } from '@pie-lib/render-ui';\nimport AlertDialog from '../../config-ui/src/alert-dialog';\nimport { PreviewPrompt } from '@pie-lib/render-ui';\n\nimport { getBase64, htmlToValue } from './serialization';\nimport InsertImageHandler from './plugins/image/insert-image-handler';\nimport * as serialization from './serialization';\nimport { buildPlugins, ALL_PLUGINS, DEFAULT_PLUGINS } from './plugins';\n\nexport { ALL_PLUGINS, DEFAULT_PLUGINS, serialization };\n\nconst log = debug('editable-html:editor');\n\nconst defaultToolbarOpts = {\n  position: 'bottom',\n  alignment: 'left',\n  alwaysVisible: false,\n  showDone: true,\n  doneOn: 'blur',\n};\n\nconst defaultResponseAreaProps = {\n  options: {},\n  respAreaToolbar: () => { },\n  onHandleAreaChange: () => { },\n};\n\nconst defaultLanguageCharactersProps = [];\n\nconst createToolbarOpts = (toolbarOpts, error, isHtmlMode) => {\n  return {\n    ...defaultToolbarOpts,\n    ...toolbarOpts,\n    error,\n    isHtmlMode,\n  };\n};\n\n/**\n * Converts a value to a CSS size string\n * @param {string|number} v - The value to convert\n * @returns {string|undefined} CSS size string or undefined\n */\nexport const valueToSize = (v) => {\n  if (!v) {\n    return;\n  }\n  const calcRegex = /^calc\\((.*)\\)$/;\n\n  if (typeof v === 'string') {\n    if (v.endsWith('%')) {\n      return undefined;\n    } else if (\n      v.endsWith('px') ||\n      v.endsWith('vh') ||\n      v.endsWith('vw') ||\n      v.endsWith('ch') ||\n      v.endsWith('em') ||\n      v.match(calcRegex)\n    ) {\n      return v;\n    } else {\n      const value = parseInt(v, 10);\n      return isNaN(value) ? value : `${value}px`;\n    }\n  }\n  if (typeof v === 'number') {\n    return `${v}px`;\n  }\n};\n\n/**\n * Builds a style object for editor size constraints\n * @param {Object} props - Editor props containing size values\n * @returns {Object} Style object with width/height constraints\n */\nexport const buildSizeStyle = (props) => {\n  const { minWidth, width, maxWidth, minHeight, height, maxHeight } = props;\n\n  return {\n    width: valueToSize(width),\n    minWidth: valueToSize(minWidth),\n    maxWidth: valueToSize(maxWidth),\n    height: valueToSize(height),\n    minHeight: valueToSize(minHeight),\n    maxHeight: valueToSize(maxHeight),\n  };\n};\n\n/**\n * The maximum number of characters the editor can support\n * @type {number}\n */\nconst MAX_CHARACTERS_LIMIT = 1000000;\n\nexport class Editor extends React.Component {\n  static propTypes = {\n    autoFocus: PropTypes.bool,\n    editorRef: PropTypes.func.isRequired,\n    error: PropTypes.any,\n    onRef: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    onFocus: PropTypes.func,\n    onBlur: PropTypes.func,\n    onKeyDown: PropTypes.func,\n    focus: PropTypes.func.isRequired,\n    value: SlateTypes.value.isRequired,\n    imageSupport: PropTypes.object,\n    mathMlOptions: PropTypes.shape({\n      mmlOutput: PropTypes.bool,\n      mmlEditing: PropTypes.bool,\n    }),\n    disableImageAlignmentButtons: PropTypes.bool,\n    uploadSoundSupport: PropTypes.shape({\n      add: PropTypes.func,\n      delete: PropTypes.func,\n    }),\n    charactersLimit: PropTypes.number,\n    width: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    minWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    maxWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    height: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    minHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    maxHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    slateEditorExtraStyles: PropTypes.object,\n    highlightShape: PropTypes.bool,\n    disabled: PropTypes.bool,\n    spellCheck: PropTypes.bool,\n    nonEmpty: PropTypes.bool,\n    disableScrollbar: PropTypes.bool,\n    disableUnderline: PropTypes.bool,\n    autoWidthToolbar: PropTypes.bool,\n    pluginProps: PropTypes.any,\n    // customPlugins should be inside pluginProps (a property inside pluginProps)\n    //   customPlugins: PropTypes.arrayOf(\n    //       PropTypes.shape({\n    //         event: PropTypes.string,\n    //         icon: PropTypes.string,\n    //         iconType: PropTypes.string,\n    //         iconAlt: PropTypes.string\n    //       }),\n    //   ),\n    placeholder: PropTypes.string,\n    isEditor: PropTypes.bool,\n    responseAreaProps: PropTypes.shape({\n      type: PropTypes.oneOf([\n        'explicit-constructed-response',\n        'inline-dropdown',\n        'drag-in-the-blank',\n        'math-templated',\n      ]),\n      options: PropTypes.object,\n      respAreaToolbar: PropTypes.func,\n      onHandleAreaChange: PropTypes.func,\n      maxResponseAreas: PropTypes.number,\n      error: PropTypes.any,\n    }),\n    extraCSSRules: PropTypes.shape({\n      names: PropTypes.arrayOf(PropTypes.string),\n      rules: PropTypes.string,\n    }),\n    languageCharactersProps: PropTypes.arrayOf(\n      PropTypes.shape({\n        language: PropTypes.string,\n        characterIcon: PropTypes.string,\n        characters: PropTypes.arrayOf(PropTypes.arrayOf(PropTypes.string)),\n      }),\n    ),\n    runSerializationOnMarkup: PropTypes.func,\n    toolbarOpts: PropTypes.shape({\n      position: PropTypes.oneOf(['bottom', 'top']),\n      alignment: PropTypes.oneOf(['left', 'right']),\n      alwaysVisible: PropTypes.bool,\n      showDone: PropTypes.bool,\n      doneOn: PropTypes.string,\n      minWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    }),\n    activePlugins: PropTypes.arrayOf((values) => {\n      const allValid = values.every((v) => ALL_PLUGINS.includes(v));\n\n      return !allValid && new Error(`Invalid values: ${values}, values must be one of [${ALL_PLUGINS.join(',')}]`);\n    }),\n    className: PropTypes.string,\n    maxImageWidth: PropTypes.number,\n    maxImageHeight: PropTypes.number,\n  };\n\n  static defaultProps = {\n    disableUnderline: true,\n    onFocus: () => { },\n    onBlur: () => { },\n    onKeyDown: () => { },\n    runSerializationOnMarkup: () => { },\n    mathMlOptions: {\n      mmlOutput: false,\n      mmlEditing: false,\n    },\n    toolbarOpts: defaultToolbarOpts,\n    responseAreaProps: defaultResponseAreaProps,\n    languageCharactersProps: defaultLanguageCharactersProps,\n    extraCSSRules: null,\n    isEditor: false,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      value: props.value,\n      toolbarOpts: createToolbarOpts(props.toolbarOpts, props.error),\n      pendingImages: [],\n      isHtmlMode: false,\n      isEditedInHtmlMode: false,\n      focusToolbar: false,\n      dialog: {\n        open: false,\n      },\n    };\n\n    this.keyPadCharacterRef = React.createRef();\n    this.doneButtonRef = React.createRef();\n    this.keypadInteractionDetected = false;\n\n    this.toggleHtmlMode = this.toggleHtmlMode.bind(this);\n    this.handleToolbarFocus = this.handleToolbarFocus.bind(this);\n    this.handleToolbarBlur = this.handleToolbarBlur.bind(this);\n\n    this.onResize = debounce(() => {\n      if (!this.state.isHtmlMode && props.onChange) {\n        props.onChange(this.state.value, true);\n      }\n    }, 50);\n\n    this.handlePlugins(this.props);\n  }\n\n  handleToolbarFocus() {\n    if (this.state.focusToolbar) {\n      return;\n    }\n\n    this.setState({ focusToolbar: true });\n  }\n\n  setKeypadInteraction = (interacted) => {\n    this.keypadInteractionDetected = interacted;\n  };\n\n  handleToolbarBlur() {\n    setTimeout(() => {\n      if (!this.toolbarContainsFocus()) {\n        this.setState({ focusToolbar: false });\n      }\n    }, 0);\n  }\n\n  toolbarContainsFocus() {\n    if (!this.toolbarRef) return false;\n    const toolbarElement = this.toolbarRef;\n    const activeElement = document.activeElement;\n\n    return toolbarElement && toolbarElement.contains(activeElement);\n  }\n\n  handleDialog = (open, extraDialogProps = {}, callback) => {\n    this.setState(\n      {\n        dialog: {\n          open,\n          ...extraDialogProps,\n        },\n      },\n      callback,\n    );\n  };\n\n  toggleHtmlMode = () => {\n    this.setState(\n      (prevState) => ({\n        isHtmlMode: !prevState.isHtmlMode,\n        isEditedInHtmlMode: false,\n      }),\n      () => {\n        const { error } = this.props;\n        const { toolbarOpts } = this.state;\n        const newToolbarOpts = createToolbarOpts(toolbarOpts, error, this.state.isHtmlMode);\n        this.setState({\n          toolbarOpts: newToolbarOpts,\n        });\n      },\n    );\n  };\n\n  handlePlugins = (props) => {\n    const normalizedResponseAreaProps = {\n      ...defaultResponseAreaProps,\n      ...props.responseAreaProps,\n    };\n\n    const htmlPluginOpts = {\n      currentValue: this.props.value,\n      isHtmlMode: this.state.isHtmlMode,\n      isEditedInHtmlMode: this.state.isEditedInHtmlMode,\n      toggleHtmlMode: this.toggleHtmlMode,\n      handleAlertDialog: this.handleDialog,\n    };\n    let { customPlugins } = props.pluginProps || {};\n    customPlugins = customPlugins || [];\n\n    this.plugins = buildPlugins(props.activePlugins, customPlugins, {\n      math: {\n        onClick: this.onMathClick,\n        onFocus: this.onPluginFocus,\n        onBlur: this.onPluginBlur,\n        ...props.mathMlOptions,\n      },\n      textAlign: {\n        getValue: () => this.state.value,\n        onChange: this.onChange,\n      },\n      html: htmlPluginOpts,\n      extraCSSRules: props.extraCSSRules || {},\n      image: {\n        disableImageAlignmentButtons: props.disableImageAlignmentButtons,\n        onDelete:\n          props.imageSupport &&\n          props.imageSupport.delete &&\n          ((node, done) => {\n            const src = node.data.get('src');\n\n            props.imageSupport.delete(src, (e) => {\n              const newPendingImages = this.state.pendingImages.filter((img) => img.key !== node.key);\n              const { scheduled: oldScheduled } = this.state;\n              const newState = {\n                pendingImages: newPendingImages,\n                scheduled: oldScheduled && newPendingImages.length === 0 ? false : oldScheduled,\n              };\n\n              this.setState(newState, () => done(e, this.state.value));\n            });\n          }),\n        insertImageRequested:\n          props.imageSupport &&\n          ((addedImage, getHandler) => {\n            const { pendingImages } = this.state;\n            const onFinish = (result) => {\n              let cb;\n\n              if (this.state.scheduled && result) {\n                // finish editing only on success\n                cb = this.onEditingDone.bind(this);\n              }\n\n              const newPendingImages = this.state.pendingImages.filter((img) => img.key !== addedImage.key);\n              const newState = {\n                pendingImages: newPendingImages,\n              };\n\n              if (newPendingImages.length === 0) {\n                newState.scheduled = false;\n              }\n\n              this.setState(newState, cb);\n            };\n            const callback = () => {\n              /**\n               * The handler is the object through which the outer context\n               * communicates file upload events like: fileChosen, cancel, progress\n               */\n              const handler = getHandler(onFinish, () => this.state.value);\n              props.imageSupport.add(handler);\n            };\n\n            this.setState(\n              {\n                pendingImages: [...pendingImages, addedImage],\n              },\n              callback,\n            );\n          }),\n        onFocus: this.onPluginFocus,\n        onBlur: this.onPluginBlur,\n        maxImageWidth: props.maxImageWidth,\n        maxImageHeight: props.maxImageHeight,\n      },\n      toolbar: {\n        /**\n         * To minimize converting html -> state -> html\n         * We only emit markup once 'done' is clicked.\n         */\n        disableScrollbar: !!props.disableScrollbar,\n        disableUnderline: props.disableUnderline,\n        autoWidth: props.autoWidthToolbar,\n        onDone: () => {\n          const { nonEmpty } = props;\n\n          log('[onDone]');\n          this.setState({ toolbarInFocus: false, focusedNode: null, focusToolbar: false });\n          this.editor.blur();\n\n          if (nonEmpty && this.state.value.startText?.text?.length === 0) {\n            this.resetValue(true).then(() => {\n              this.onEditingDone();\n            });\n          } else {\n            this.onEditingDone();\n          }\n        },\n      },\n      table: {\n        onFocus: () => {\n          log('[table:onFocus]...');\n          this.onPluginFocus();\n        },\n        onBlur: () => {\n          log('[table:onBlur]...');\n          this.onPluginBlur();\n        },\n      },\n      responseArea: {\n        type: normalizedResponseAreaProps.type,\n        options: normalizedResponseAreaProps.options,\n        maxResponseAreas: normalizedResponseAreaProps.maxResponseAreas,\n        respAreaToolbar: normalizedResponseAreaProps.respAreaToolbar,\n        onHandleAreaChange: normalizedResponseAreaProps.onHandleAreaChange,\n        error: normalizedResponseAreaProps.error,\n        onFocus: () => {\n          log('[table:onFocus]...');\n          this.onPluginFocus();\n        },\n        onBlur: () => {\n          log('[table:onBlur]...');\n          this.onPluginBlur();\n        },\n      },\n      languageCharacters: props.languageCharactersProps,\n      keyPadCharacterRef: this.keyPadCharacterRef,\n      setKeypadInteraction: this.setKeypadInteraction,\n      media: {\n        focus: this.focus,\n        createChange: () => this.state.value.change(),\n        onChange: this.onChange,\n        uploadSoundSupport: props.uploadSoundSupport,\n      },\n    });\n\n    if (props.mathMlOptions.mmlOutput || props.mathMlOptions.mmlEditing) {\n      this.props.runSerializationOnMarkup();\n    }\n  };\n\n  componentDidMount() {\n    // onRef is needed to get the ref of the component\n    this.props.onRef(this);\n\n    window.addEventListener('resize', this.onResize);\n\n    const isResponseAreaEditor = this.props.className?.includes('response-area-editor');\n\n    if (isResponseAreaEditor && this.editor) {\n      const responseAreaEditor = document.querySelector(`[data-key=\"${this.editor.value.document.key}\"]`);\n\n      if (responseAreaEditor) {\n        responseAreaEditor.setAttribute('aria-label', 'Answer');\n      }\n    }\n\n    if (this.editor && this.props.autoFocus) {\n      Promise.resolve().then(() => {\n        if (this.editor) {\n          const editorDOM = document.querySelector(`[data-key=\"${this.editor.value.document.key}\"]`);\n\n          this.editor.focus();\n\n          if (editorDOM) {\n            editorDOM.focus();\n          }\n        }\n      });\n    }\n  }\n\n  UNSAFE_componentWillReceiveProps(nextProps) {\n    const { isHtmlMode, toolbarOpts } = this.state;\n    const newToolbarOpts = createToolbarOpts(nextProps.toolbarOpts, nextProps.error, isHtmlMode);\n\n    if (!isEqual(newToolbarOpts, toolbarOpts)) {\n      this.setState({\n        toolbarOpts: newToolbarOpts,\n      });\n    }\n\n    const differentCharacterProps = !isEqual(nextProps.languageCharactersProps, this.props.languageCharactersProps);\n    const differentMathMlProps = !isEqual(nextProps.mathMlOptions, this.props.mathMlOptions);\n    const differentImageMaxDimensionsProps =\n      !isEqual(nextProps.maxImageWidth, this.props.maxImageWidth) ||\n      !isEqual(nextProps.maxImageHeight, this.props.maxImageHeight);\n\n    if (differentCharacterProps || differentMathMlProps || differentImageMaxDimensionsProps) {\n      this.handlePlugins(nextProps);\n    }\n\n    if (!nextProps.value?.document?.equals(this.props.value?.document)) {\n      this.setState({\n        focus: false,\n        value: nextProps.value,\n      });\n    }\n  }\n\n  componentDidUpdate(prevProps, prevState) {\n    // The cursor is on a zero width element and when that is placed near void elements, it is not visible\n    // so we increase the width to at least 2px in order for the user to see it\n\n    // Trigger plugins and finish editing if:\n    // 1. The 'isHtmlMode' state has been toggled.\n    // 2. We're currently in 'isHtmlMode' and the editor value has been modified.\n    if (\n      this.state.isHtmlMode !== prevState.isHtmlMode ||\n      (this.state.isHtmlMode && !prevState.isEditedInHtmlMode && this.state.isEditedInHtmlMode)\n    ) {\n      this.handlePlugins(this.props);\n    }\n\n    const zeroWidthEls = document.querySelectorAll('[data-slate-zero-width=\"z\"]');\n\n    Array.from(zeroWidthEls).forEach((el) => {\n      el.style.minWidth = '2px';\n      el.style.display = 'inline-block';\n    });\n  }\n\n  onPluginBlur = (e) => {\n    log('[onPluginBlur]', e && e.relatedTarget);\n    const target = e && e.relatedTarget;\n\n    const node = target ? findNode(target, this.state.value) : null;\n    log('[onPluginBlur] node: ', node);\n    this.setState({ focusedNode: node }, () => {\n      this.resetValue();\n    });\n  };\n\n  onPluginFocus = (e) => {\n    log('[onPluginFocus]', e && e.target);\n    const target = e && e.target;\n    if (target) {\n      const node = findNode(target, this.state.value);\n      log('[onPluginFocus] node: ', node);\n\n      const stashedValue = this.state.stashedValue || this.state.value;\n      this.setState({ focusedNode: node, stashedValue });\n    } else {\n      this.setState({ focusedNode: null });\n    }\n    this.stashValue();\n  };\n\n  onMathClick = (node) => {\n    this.editor.change((c) => c.collapseToStartOf(node));\n    this.setState({ selectedNode: node });\n  };\n\n  onEditingDone = () => {\n    const { isHtmlMode, dialog, value, pendingImages } = this.state;\n\n    // Handling HTML mode and dialog state\n    if (isHtmlMode) {\n      // Early return if HTML mode is enabled\n      if (dialog?.open) return;\n\n      const currentValue = htmlToValue(value.document.text);\n      const previewText = this.renderHtmlPreviewContent();\n\n      this.openHtmlModeConfirmationDialog(currentValue, previewText);\n      return;\n    }\n\n    if (pendingImages.length) {\n      // schedule image processing\n      this.setState({ scheduled: true });\n      return;\n    }\n\n    // Finalizing editing\n    log('[onEditingDone]');\n    this.setState({ pendingImages: [], stashedValue: null, focusedNode: null });\n    log('[onEditingDone] value: ', this.state.value);\n    this.props.onChange(this.state.value, true);\n  };\n\n  /**\n   * Renders the HTML preview content to be displayed inside the dialog.\n   * This content includes the edited HTML and a prompt for the user.\n   */\n  renderHtmlPreviewContent = () => {\n    return (\n      <div ref={(ref) => (this.elementRef = ref)}>\n        <div>Preview of Edited Html:</div>\n        {/* TODO: check if this works and we don't need to send style over to preview prompt */}\n        <StyledPreviewText>\n          <PreviewPrompt prompt={this.state.value.document.text} />\n        </StyledPreviewText>\n        <div>Would you like to save these changes ?</div>\n      </div>\n    );\n  };\n\n  /**\n   * Opens a confirmation dialog in HTML mode, displaying the preview of the current HTML content\n   * and offering options to save or continue editing.\n   */\n  openHtmlModeConfirmationDialog = (currentValue, previewText) => {\n    this.setState({\n      dialog: {\n        open: true,\n        title: 'Content Preview & Save',\n        text: previewText,\n        onConfirmText: 'Save changes',\n        onCloseText: 'Continue editing',\n        onConfirm: () => {\n          this.handleHtmlModeSaveConfirmation(currentValue);\n        },\n        onClose: this.htmlModeContinueEditing,\n      },\n    });\n  };\n\n  /**\n   * Handles the save confirmation action in HTML mode. This updates the value to the confirmed\n   * content, updates value on props, and exits the HTML mode.\n   * @param {string} currentValue - The confirmed value of the HTML content to save.\n   */\n  handleHtmlModeSaveConfirmation = (currentValue) => {\n    this.setState({ value: currentValue });\n    this.props.onChange(currentValue, true);\n    this.handleDialog(false);\n    this.toggleHtmlMode();\n  };\n\n  /**\n   * Closes the dialog in HTML mode and allows the user to continue editing the html content.\n   * This function is invoked when the user opts to not save the current changes.\n   */\n  htmlModeContinueEditing = () => {\n    this.handleDialog(false);\n  };\n\n  /**\n   * Remove onResize event listener\n   */\n  componentWillUnmount() {\n    window.removeEventListener('resize', this.onResize);\n  }\n\n  // Allowing time for onChange to take effect if it is called\n  handleBlur = (resolve) => {\n    const { nonEmpty } = this.props;\n    const {\n      toolbarOpts: { doneOn },\n    } = this.state;\n\n    this.setState({ toolbarInFocus: false, focusedNode: null });\n\n    if (this.editor) {\n      this.editor.blur();\n    }\n\n    if (doneOn === 'blur') {\n      if (nonEmpty && this.state.value.startText?.text?.length === 0) {\n        this.resetValue(true).then(() => {\n          this.onEditingDone();\n          resolve();\n        });\n      } else {\n        this.onEditingDone();\n        resolve();\n      }\n    }\n  };\n\n  onBlur = (event) => {\n    log('[onBlur]');\n    const relatedTarget = event.relatedTarget;\n    const toolbarElement = this.toolbarRef && relatedTarget?.closest(`[class*=\"${this.toolbarRef.className}\"]`);\n\n    // Check if relatedTarget is a done button\n    const isRawDoneButton =\n      this.doneButtonRef && relatedTarget?.closest(`[class*=\"${this.doneButtonRef.current?.className}\"]`);\n\n    // Skip onBlur handling if relatedTarget is a button from the KeyPad characters\n    this.skipBlurHandling = this.keypadInteractionDetected && relatedTarget !== null;\n\n    if (toolbarElement && !isRawDoneButton && !this.state.focusToolbar) {\n      this.setState({\n        focusToolbar: true,\n      });\n    }\n\n    const node = relatedTarget ? findNode(relatedTarget, this.state.value) : null;\n\n    log('[onBlur] node: ', node);\n\n    return new Promise((resolve) => {\n      if (!this.skipBlurHandling) {\n        this.setKeypadInteraction(false);\n        this.setState(\n          { preBlurValue: this.state.value, focusedNode: !node ? null : node },\n          this.handleBlur.bind(this, resolve),\n        );\n      }\n\n      this.props.onBlur(event);\n    });\n  };\n\n  handleDomBlur = (e) => {\n    const editorDOM = document.querySelector(`[data-key=\"${this.state.value.document.key}\"]`);\n\n    setTimeout(() => {\n      const { value: stateValue } = this.state;\n\n      if (!this.wrapperRef) {\n        return;\n      }\n\n      const editorElement = !editorDOM || document.activeElement.closest(`[class*=\"${editorDOM.className}\"]`);\n      const toolbarElement =\n        !this.toolbarRef || document.activeElement.closest(`[class*=\"${this.toolbarRef.className}\"]`);\n      const isInCurrentComponent = this.wrapperRef.contains(editorElement) || this.wrapperRef.contains(toolbarElement);\n\n      if (!isInCurrentComponent) {\n        editorDOM.removeEventListener('blur', this.handleDomBlur);\n\n        if (stateValue.isFocused) {\n          this.onBlur(e);\n        }\n      }\n    }, 50);\n  };\n\n  /*\n   * Needs to be wrapped otherwise it causes issues because of race conditions\n   * Known issue for slatejs. See: https://github.com/ianstormtaylor/slate/issues/2097\n   * Using timeout I wasn't able to test this\n   *\n   * Note: The use of promises has been causing issues with MathQuill\n   * */\n  onFocus = (event, change) =>\n    new Promise((resolve) => {\n      const editorDOM = document.querySelector(`[data-key=\"${this.state.value.document.key}\"]`);\n      const isTouchDevice =\n        typeof window !== 'undefined' && ('ontouchstart' in window || navigator?.maxTouchPoints > 0);\n\n      log('[onFocus]', document.activeElement);\n\n      if (this.keypadInteractionDetected && this.__TEMPORARY_CHANGE_DATA) {\n        this.__TEMPORARY_CHANGE_DATA = null;\n      }\n\n      /**\n       * This is a temporary hack - @see changeData below for some more information.\n       */\n      if (this.__TEMPORARY_CHANGE_DATA) {\n        const { key, data } = this.__TEMPORARY_CHANGE_DATA;\n        const domEl = document.querySelector(`[data-key=\"${key}\"]`);\n\n        if (domEl) {\n          let change = this.state.value.change().setNodeByKey(key, { data });\n          this.setState({ value: change.value }, () => {\n            this.__TEMPORARY_CHANGE_DATA = null;\n          });\n        }\n      }\n\n      /**\n       * This is needed just in case the browser decides to make the editor\n       * lose focus without triggering the onBlur event (can happen in a few cases).\n       * This will also trigger onBlur if the user clicks outside of the page when the editor\n       * is focused.\n       */\n      if (editorDOM === document.activeElement) {\n        editorDOM.removeEventListener('blur', this.handleDomBlur);\n        editorDOM.addEventListener('blur', this.handleDomBlur);\n      }\n\n      this.stashValue();\n      this.props.onFocus();\n\n      // Added for accessibility: Ensures the editor gains focus when tabbed to for improved keyboard navigation\n      const shouldFocusEditor = !this.keypadInteractionDetected && !isTouchDevice;\n\n      if (shouldFocusEditor) {\n        change?.focus();\n      }\n\n      resolve();\n    });\n\n  stashValue = () => {\n    log('[stashValue]');\n\n    if (!this.state.stashedValue) {\n      this.setState({ stashedValue: this.state.value });\n    }\n  };\n\n  /**\n   * Reset the value if the user didn't click done.\n   */\n  resetValue = (force) => {\n    const { value, focusedNode } = this.state;\n\n    const stopReset = this.plugins.reduce((s, p) => {\n      return s || (p.stopReset && p.stopReset(this.state.value));\n    }, false);\n\n    log('[resetValue]', value.isFocused, focusedNode, 'stopReset: ', stopReset);\n    if ((this.state.stashedValue && !value.isFocused && !focusedNode && !stopReset) || force) {\n      log('[resetValue] resetting...');\n      log('stashed', this.state.stashedValue.document.toObject());\n      log('current', this.state.value.document.toObject());\n\n      const newValue = Value.fromJSON(this.state.stashedValue.toJSON());\n\n      log('newValue: ', newValue.document);\n      return new Promise((resolve) => {\n        setTimeout(() => {\n          this.setState({ value: newValue, stashedValue: null }, () => {\n            log('value now: ', this.state.value.document.toJSON());\n            resolve();\n          });\n        }, 50);\n      });\n    } else {\n      return Promise.resolve({});\n    }\n  };\n\n  onChange = (change, done) => {\n    log('[onChange]');\n    window.me = this;\n\n    const { value } = change;\n    const { charactersLimit } = this.props;\n    let limit = charactersLimit;\n    if (!limit || limit > MAX_CHARACTERS_LIMIT) {\n      limit = MAX_CHARACTERS_LIMIT;\n    }\n\n    if (value && value.document && value.document.text && value.document.text.length > limit) {\n      return;\n    }\n\n    // Mark the editor as edited when in HTML mode and its content has changed.\n    // This status will later be used to decide whether to prompt a warning to the user when exiting HTML mode.\n    const isEditedInHtmlMode = !this.state.isHtmlMode\n      ? false\n      : this.state.value.document.text !== value.document.text\n        ? true\n        : this.state.isEditedInHtmlMode;\n\n    if (isEditedInHtmlMode != this.state.isEditedInHtmlMode) {\n      this.handlePlugins(this.props);\n    }\n\n    this.setState({ value, isEditedInHtmlMode }, () => {\n      log('[onChange], call done()');\n\n      if (done) {\n        done();\n      }\n    });\n  };\n\n  getFocusedValue = () => {\n    if (this.state.value.isFocused) {\n      return this.state.value;\n    }\n\n    return this.state.preBlurValue;\n  };\n\n  // Use the exported utility functions\n  buildSizeStyle() {\n    return buildSizeStyle(this.props);\n  }\n\n  validateNode = (node) => {\n    if (node.object !== 'block') return;\n\n    const last = node.nodes.last();\n    if (!last) return;\n\n    if (last.type !== 'image') return;\n\n    log('[validateNode] last is image..');\n\n    const parent = last.getParent(last.key);\n    const p = Block.getParent(last.key);\n    log('[validateNode] parent:', parent, p);\n\n    return undefined;\n  };\n\n  changeData = (key, data) => {\n    log('[changeData]. .. ', key, data);\n\n    /**\n     * HACK ALERT: We should be calling setState here and storing the change data:\n     *\n     * <code>this.setState({changeData: { key, data}})</code>\n     * However this is causing issues with the Mathquill instance. The 'input' event stops firing on the element and no\n     * more changes get through. The issues seem to be related to the promises in onBlur/onFocus. But removing these\n     * brings it's own problems. A major clean up is planned for this component so I've decided to temporarily settle\n     * on this hack rather than spend more time on this.\n     */\n\n    // Uncomment this line to see the bug described above.\n    //    this.setState({changeData: {key, data}})\n\n    this.__TEMPORARY_CHANGE_DATA = { key, data };\n  };\n\n  focus = (pos, node) => {\n    const position = pos || 'end';\n\n    this.props.focus(position, node);\n  };\n\n  onDropPaste = async (event, change, dropContext) => {\n    const editor = change.editor;\n    const transfer = getEventTransfer(event);\n    const file = transfer.files && transfer.files[0];\n\n    const type = transfer.type;\n    const fragment = transfer.fragment;\n    const text = transfer.text;\n\n    if (file && (file.type === 'image/jpeg' || file.type === 'image/jpg' || file.type === 'image/png')) {\n      if (!this.props.imageSupport) {\n        return;\n      }\n      try {\n        log('[onDropPaste]');\n        const src = await getBase64(file);\n        const inline = Inline.create({\n          type: 'image',\n          isVoid: true,\n          data: {\n            loading: false,\n            src,\n          },\n        });\n\n        if (dropContext) {\n          this.focus();\n        } else {\n          const range = getEventRange(event, editor);\n          if (range) {\n            change.select(range);\n          }\n        }\n\n        const ch = change.insertInline(inline);\n        this.onChange(ch);\n        const handler = new InsertImageHandler(\n          inline,\n          () => { },\n          () => this.state.value,\n          this.onChange,\n          true,\n        );\n        handler.fileChosen(file);\n        this.props.imageSupport.add(handler);\n      } catch (err) {\n        log('[onDropPaste] error: ', err);\n      }\n    } else if (type === 'fragment') {\n      change.insertFragment(fragment);\n    } else if (type === 'text' || type === 'html') {\n      if (!text) {\n        return;\n      }\n      const {\n        value: { document, selection, startBlock },\n      } = change;\n\n      if (startBlock.isVoid) {\n        return;\n      }\n\n      const defaultBlock = startBlock;\n      const defaultMarks = document.getInsertMarksAtRange(selection);\n      const frag = Plain.deserialize(text, {\n        defaultBlock,\n        defaultMarks,\n      }).document;\n      change.insertFragment(frag);\n    }\n  };\n\n  renderPlaceholder = (props) => {\n    const { editor } = props;\n    const { document } = editor.value;\n\n    if (!editor.props.placeholder || document.text !== '' || document.nodes.size !== 1 || !document.isEmpty) {\n      return false;\n    }\n\n    return (\n      <span\n        contentEditable={false}\n        style={{\n          display: 'inline-block',\n          width: 'fit-content', // for centering the placeholder if text-align is set to center\n          maxWidth: '100%',\n          whiteSpace: 'nowrap',\n          opacity: '0.33',\n          pointerEvents: 'none',\n          userSelect: 'none',\n        }}\n      >\n        {editor.props.placeholder}\n      </span>\n    );\n  };\n\n  render() {\n    const {\n      disabled,\n      spellCheck,\n      highlightShape,\n      className,\n      placeholder,\n      pluginProps,\n      onKeyDown,\n      slateEditorExtraStyles,\n    } = this.props;\n    // We don't want to send customPlugins to slate.\n    // Not sure if they would do any harm, but I think it's better to not send them.\n    // We use custom plugins to be able to add custom buttons\n    // eslint-disable-next-line no-unused-vars\n    const { customPlugins, showParagraphs, separateParagraphs, ...otherPluginProps } = pluginProps || {};\n\n    const { value, focusedNode, toolbarOpts, dialog, scheduled } = this.state;\n\n    log('[render] value: ', value);\n    const sizeStyle = this.buildSizeStyle();\n    const wrapperClassNames = classNames(\n      {\n        withBg: highlightShape,\n        toolbarOnTop: toolbarOpts.alwaysVisible && toolbarOpts.position === 'top',\n        scheduled: scheduled,\n      },\n      className,\n    );\n\n    return (\n      <StyledEditorWrapper\n        ref={(ref) => (this.wrapperRef = ref)}\n        style={{ width: sizeStyle.width, minWidth: sizeStyle.minWidth, maxWidth: sizeStyle.maxWidth }}\n        className={wrapperClassNames}\n        id={`editor-${value?.document?.key}`}\n      >\n        {scheduled && <StyledUploadingMessage>Uploading image and then saving...</StyledUploadingMessage>}\n        <StyledSlateEditor\n          className={classNames(\n            {\n              noPadding: toolbarOpts?.noPadding,\n              showParagraph: showParagraphs && !showParagraphs.disabled,\n              separateParagraph: separateParagraphs && !separateParagraphs.disabled,\n            },\n          )}\n        >\n          <SlateEditor\n            plugins={this.plugins}\n            innerRef={(r) => {\n              if (r) {\n                this.slateEditor = r;\n              }\n            }}\n            ref={(r) => (this.editor = r && this.props.editorRef(r))}\n            toolbarRef={(r) => {\n              if (r) {\n                this.toolbarRef = r;\n              }\n            }}\n            doneButtonRef={this.doneButtonRef}\n            value={value}\n            focusToolbar={this.state.focusToolbar}\n            onToolbarFocus={this.handleToolbarFocus}\n            onToolbarBlur={this.handleToolbarBlur}\n            focus={this.focus}\n            onKeyDown={onKeyDown}\n            onChange={this.onChange}\n            getFocusedValue={this.getFocusedValue}\n            onBlur={this.onBlur}\n            onDrop={(event, editor) => this.onDropPaste(event, editor, true)}\n            onPaste={(event, editor) => this.onDropPaste(event, editor)}\n            onFocus={this.onFocus}\n            onEditingDone={this.onEditingDone}\n            focusedNode={focusedNode}\n            normalize={this.normalize}\n            readOnly={disabled}\n            spellCheck={spellCheck}\n            autoCorrect={spellCheck}\n            style={{\n              minHeight: sizeStyle.minHeight,\n              height: sizeStyle.height,\n              maxHeight: sizeStyle.maxHeight,\n              ...slateEditorExtraStyles\n            }}\n            pluginProps={otherPluginProps}\n            toolbarOpts={toolbarOpts}\n            placeholder={placeholder}\n            renderPlaceholder={this.renderPlaceholder}\n            onDataChange={this.changeData}\n          />\n        </StyledSlateEditor>\n        <AlertDialog\n          open={dialog.open}\n          title={dialog.title}\n          text={dialog.text}\n          onClose={dialog.onClose}\n          onConfirm={dialog.onConfirm}\n          onConfirmText={dialog.onConfirmText}\n          onCloseText={dialog.onCloseText}\n        />\n      </StyledEditorWrapper>\n    );\n  }\n}\n\n// TODO color - hardcoded gray background and keypad colors will need to change too\nconst StyledEditorWrapper = styled('div')(() => ({\n  '&.withBg': {\n    backgroundColor: 'rgba(0,0,0,0.06)',\n  },\n  '&.scheduled': {\n    opacity: 0.5,\n    pointerEvents: 'none',\n    position: 'relative',\n  },\n  '&.toolbarOnTop': {\n    marginTop: '45px',\n  },\n}));\n\nconst StyledUploadingMessage = styled('div')({\n  position: 'absolute',\n  top: '50%',\n  left: '50%',\n  transform: 'translate(-50%, -50%)',\n});\n\nconst StyledSlateEditor = styled('div')(() => ({\n  '& table': {\n    tableLayout: 'fixed',\n    width: '100%',\n    borderCollapse: 'collapse',\n    color: color.text(),\n    backgroundColor: color.background(),\n  },\n  '& table:not([border=\"1\"]) tr': {\n    borderTop: '1px solid #dfe2e5',\n    // TODO perhaps secondary color for background, for now disable\n    // '&:nth-child(2n)': {\n    //   backgroundColor: '#f6f8fa'\n    // }\n  },\n  '& td, th': {\n    padding: '.6em 1em',\n    textAlign: 'center',\n  },\n  '& table:not([border=\"1\"]) td, th': {\n    border: '1px solid #dfe2e5',\n  },\n  '&.showParagraph': {\n    // a div that has a div after it\n    '& > div:has(+ div)::after': {\n      display: 'block',\n      content: '\"¶\"',\n      fontSize: '1em',\n      color: '#146EB3',\n    },\n  },\n  '&.separateParagraph': {\n    // a div that has a div after it\n    '& > div:has(+ div)': {\n      marginBottom: '1em',\n    },\n  },\n  '&.noPadding': {\n    padding: '0 !important',\n  },\n}));\n\nconst StyledPreviewText = styled('div')({\n  marginBottom: '36px',\n  marginTop: '6px',\n  padding: '20px',\n  backgroundColor: 'rgba(0,0,0,0.06)',\n});\n\nexport default Editor;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAD,OAAA;AACA,IAAAE,eAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,MAAA,GAAAH,OAAA;AACA,IAAAI,qBAAA,GAAAL,sBAAA,CAAAC,OAAA;AACA,IAAAK,UAAA,GAAAN,sBAAA,CAAAC,OAAA;AACA,IAAAM,SAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,QAAA,GAAAR,sBAAA,CAAAC,OAAA;AACA,IAAAQ,WAAA,GAAAT,sBAAA,CAAAC,OAAA;AACA,IAAAS,MAAA,GAAAV,sBAAA,CAAAC,OAAA;AACA,IAAAU,OAAA,GAAAV,OAAA;AAEA,IAAAW,SAAA,GAAAX,OAAA;AACA,IAAAY,YAAA,GAAAb,sBAAA,CAAAC,OAAA;AAGA,IAAAa,cAAA,GAAAC,uBAAA,CAAAd,OAAA;AAAyD,IAAAe,aAAA,GAAAF,cAAA;AAAAG,OAAA,CAAAD,aAAA,GAAAF,cAAA;AACzD,IAAAI,mBAAA,GAAAlB,sBAAA,CAAAC,OAAA;AAEA,IAAAkB,QAAA,GAAAlB,OAAA;AAAuE,IAAAmB,SAAA;AAAA,SAAAL,wBAAAM,CAAA,EAAAC,CAAA,6BAAAC,OAAA,MAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAR,uBAAA,YAAAA,wBAAAM,CAAA,EAAAC,CAAA,SAAAA,CAAA,IAAAD,CAAA,IAAAA,CAAA,CAAAK,UAAA,SAAAL,CAAA,MAAAM,CAAA,EAAAC,CAAA,EAAAC,CAAA,KAAAC,SAAA,mBAAAT,CAAA,iBAAAA,CAAA,gBAAAU,OAAA,CAAAV,CAAA,0BAAAA,CAAA,SAAAQ,CAAA,MAAAF,CAAA,GAAAL,CAAA,GAAAG,CAAA,GAAAD,CAAA,QAAAG,CAAA,CAAAK,GAAA,CAAAX,CAAA,UAAAM,CAAA,CAAAM,GAAA,CAAAZ,CAAA,GAAAM,CAAA,CAAAO,GAAA,CAAAb,CAAA,EAAAQ,CAAA,cAAAM,GAAA,IAAAd,CAAA,gBAAAc,GAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,GAAA,OAAAP,CAAA,IAAAD,CAAA,GAAAW,MAAA,CAAAC,cAAA,KAAAD,MAAA,CAAAE,wBAAA,CAAAnB,CAAA,EAAAc,GAAA,OAAAP,CAAA,CAAAK,GAAA,IAAAL,CAAA,CAAAM,GAAA,IAAAP,CAAA,CAAAE,CAAA,EAAAM,GAAA,EAAAP,CAAA,IAAAC,CAAA,CAAAM,GAAA,IAAAd,CAAA,CAAAc,GAAA,WAAAN,CAAA,KAAAR,CAAA,EAAAC,CAAA;AAAA,SAAAmB,WAAAnB,CAAA,EAAAK,CAAA,EAAAN,CAAA,WAAAM,CAAA,OAAAe,gBAAA,aAAAf,CAAA,OAAAgB,2BAAA,aAAArB,CAAA,EAAAsB,yBAAA,KAAAC,OAAA,CAAAC,SAAA,CAAAnB,CAAA,EAAAN,CAAA,YAAAqB,gBAAA,aAAApB,CAAA,EAAAyB,WAAA,IAAApB,CAAA,CAAAqB,KAAA,CAAA1B,CAAA,EAAAD,CAAA;AAAA,SAAAuB,0BAAA,cAAAtB,CAAA,IAAA2B,OAAA,CAAAC,SAAA,CAAAC,OAAA,CAAAd,IAAA,CAAAQ,OAAA,CAAAC,SAAA,CAAAG,OAAA,iCAAA3B,CAAA,aAAAsB,yBAAA,YAAAA,0BAAA,aAAAtB,CAAA;AAAA,SAAA8B,QAAA/B,CAAA,EAAAG,CAAA,QAAAF,CAAA,GAAAgB,MAAA,CAAAe,IAAA,CAAAhC,CAAA,OAAAiB,MAAA,CAAAgB,qBAAA,QAAA3B,CAAA,GAAAW,MAAA,CAAAgB,qBAAA,CAAAjC,CAAA,GAAAG,CAAA,KAAAG,CAAA,GAAAA,CAAA,CAAA4B,MAAA,WAAA/B,CAAA,WAAAc,MAAA,CAAAE,wBAAA,CAAAnB,CAAA,EAAAG,CAAA,EAAAgC,UAAA,OAAAlC,CAAA,CAAAmC,IAAA,CAAAT,KAAA,CAAA1B,CAAA,EAAAK,CAAA,YAAAL,CAAA;AAAA,SAAAoC,cAAArC,CAAA,aAAAG,CAAA,MAAAA,CAAA,GAAAmC,SAAA,CAAAC,MAAA,EAAApC,CAAA,UAAAF,CAAA,WAAAqC,SAAA,CAAAnC,CAAA,IAAAmC,SAAA,CAAAnC,CAAA,QAAAA,CAAA,OAAA4B,OAAA,CAAAd,MAAA,CAAAhB,CAAA,OAAAuC,OAAA,WAAArC,CAAA,QAAAsC,gBAAA,aAAAzC,CAAA,EAAAG,CAAA,EAAAF,CAAA,CAAAE,CAAA,SAAAc,MAAA,CAAAyB,yBAAA,GAAAzB,MAAA,CAAA0B,gBAAA,CAAA3C,CAAA,EAAAiB,MAAA,CAAAyB,yBAAA,CAAAzC,CAAA,KAAA8B,OAAA,CAAAd,MAAA,CAAAhB,CAAA,GAAAuC,OAAA,WAAArC,CAAA,IAAAc,MAAA,CAAAC,cAAA,CAAAlB,CAAA,EAAAG,CAAA,EAAAc,MAAA,CAAAE,wBAAA,CAAAlB,CAAA,EAAAE,CAAA,iBAAAH,CAAA;AAIvE,IAAM4C,GAAG,GAAG,IAAAC,iBAAK,EAAC,sBAAsB,CAAC;AAEzC,IAAMC,kBAAkB,GAAG;EACzBC,QAAQ,EAAE,QAAQ;EAClBC,SAAS,EAAE,MAAM;EACjBC,aAAa,EAAE,KAAK;EACpBC,QAAQ,EAAE,IAAI;EACdC,MAAM,EAAE;AACV,CAAC;AAED,IAAMC,wBAAwB,GAAG;EAC/BC,OAAO,EAAE,CAAC,CAAC;EACXC,eAAe,EAAE,SAAjBA,eAAeA,CAAA,EAAQ,CAAE,CAAC;EAC1BC,kBAAkB,EAAE,SAApBA,kBAAkBA,CAAA,EAAQ,CAAE;AAC9B,CAAC;AAED,IAAMC,8BAA8B,GAAG,EAAE;AAEzC,IAAMC,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIC,WAAW,EAAEC,KAAK,EAAEC,UAAU,EAAK;EAC5D,OAAAvB,aAAA,CAAAA,aAAA,CAAAA,aAAA,KACKS,kBAAkB,GAClBY,WAAW;IACdC,KAAK,EAALA,KAAK;IACLC,UAAU,EAAVA;EAAU;AAEd,CAAC;;AAED;AACA;AACA;AACA;AACA;AACO,IAAMC,WAAW,GAAAjE,OAAA,CAAAiE,WAAA,GAAG,SAAdA,WAAWA,CAAIC,CAAC,EAAK;EAChC,IAAI,CAACA,CAAC,EAAE;IACN;EACF;EACA,IAAMC,SAAS,GAAG,gBAAgB;EAElC,IAAI,OAAOD,CAAC,KAAK,QAAQ,EAAE;IACzB,IAAIA,CAAC,CAACE,QAAQ,CAAC,GAAG,CAAC,EAAE;MACnB,OAAOC,SAAS;IAClB,CAAC,MAAM,IACLH,CAAC,CAACE,QAAQ,CAAC,IAAI,CAAC,IAChBF,CAAC,CAACE,QAAQ,CAAC,IAAI,CAAC,IAChBF,CAAC,CAACE,QAAQ,CAAC,IAAI,CAAC,IAChBF,CAAC,CAACE,QAAQ,CAAC,IAAI,CAAC,IAChBF,CAAC,CAACE,QAAQ,CAAC,IAAI,CAAC,IAChBF,CAAC,CAACI,KAAK,CAACH,SAAS,CAAC,EAClB;MACA,OAAOD,CAAC;IACV,CAAC,MAAM;MACL,IAAMK,KAAK,GAAGC,QAAQ,CAACN,CAAC,EAAE,EAAE,CAAC;MAC7B,OAAOO,KAAK,CAACF,KAAK,CAAC,GAAGA,KAAK,MAAAG,MAAA,CAAMH,KAAK,OAAI;IAC5C;EACF;EACA,IAAI,OAAOL,CAAC,KAAK,QAAQ,EAAE;IACzB,UAAAQ,MAAA,CAAUR,CAAC;EACb;AACF,CAAC;;AAED;AACA;AACA;AACA;AACA;AACO,IAAMS,eAAc,GAAA3E,OAAA,CAAA2E,cAAA,GAAG,SAAjBA,cAAcA,CAAIC,KAAK,EAAK;EACvC,IAAQC,QAAQ,GAAoDD,KAAK,CAAjEC,QAAQ;IAAEC,KAAK,GAA6CF,KAAK,CAAvDE,KAAK;IAAEC,QAAQ,GAAmCH,KAAK,CAAhDG,QAAQ;IAAEC,SAAS,GAAwBJ,KAAK,CAAtCI,SAAS;IAAEC,MAAM,GAAgBL,KAAK,CAA3BK,MAAM;IAAEC,SAAS,GAAKN,KAAK,CAAnBM,SAAS;EAE/D,OAAO;IACLJ,KAAK,EAAEb,WAAW,CAACa,KAAK,CAAC;IACzBD,QAAQ,EAAEZ,WAAW,CAACY,QAAQ,CAAC;IAC/BE,QAAQ,EAAEd,WAAW,CAACc,QAAQ,CAAC;IAC/BE,MAAM,EAAEhB,WAAW,CAACgB,MAAM,CAAC;IAC3BD,SAAS,EAAEf,WAAW,CAACe,SAAS,CAAC;IACjCE,SAAS,EAAEjB,WAAW,CAACiB,SAAS;EAClC,CAAC;AACH,CAAC;;AAED;AACA;AACA;AACA;AACA,IAAMC,oBAAoB,GAAG,OAAO;AAAC,IAExBC,MAAM,GAAApF,OAAA,CAAAoF,MAAA,0BAAAC,gBAAA;EA6GjB,SAAAD,OAAYR,MAAK,EAAE;IAAA,IAAAU,KAAA;IAAA,IAAAC,gBAAA,mBAAAH,MAAA;IACjBE,KAAA,GAAA9D,UAAA,OAAA4D,MAAA,GAAMR,MAAK;IAAE,IAAA/B,gBAAA,aAAAyC,KAAA,0BAsCQ,UAACE,UAAU,EAAK;MACrCF,KAAA,CAAKG,yBAAyB,GAAGD,UAAU;IAC7C,CAAC;IAAA,IAAA3C,gBAAA,aAAAyC,KAAA,kBAkBc,UAACI,IAAI,EAAsC;MAAA,IAApCC,gBAAgB,GAAAjD,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAA2B,SAAA,GAAA3B,SAAA,MAAG,CAAC,CAAC;MAAA,IAAEkD,QAAQ,GAAAlD,SAAA,CAAAC,MAAA,OAAAD,SAAA,MAAA2B,SAAA;MACnDiB,KAAA,CAAKO,QAAQ,CACX;QACEC,MAAM,EAAArD,aAAA;UACJiD,IAAI,EAAJA;QAAI,GACDC,gBAAgB;MAEvB,CAAC,EACDC,QACF,CAAC;IACH,CAAC;IAAA,IAAA/C,gBAAA,aAAAyC,KAAA,oBAEgB,YAAM;MACrBA,KAAA,CAAKO,QAAQ,CACX,UAACE,SAAS;QAAA,OAAM;UACd/B,UAAU,EAAE,CAAC+B,SAAS,CAAC/B,UAAU;UACjCgC,kBAAkB,EAAE;QACtB,CAAC;MAAA,CAAC,EACF,YAAM;QACJ,IAAQjC,KAAK,GAAKuB,KAAA,CAAKV,KAAK,CAApBb,KAAK;QACb,IAAQD,WAAW,GAAKwB,KAAA,CAAKW,KAAK,CAA1BnC,WAAW;QACnB,IAAMoC,cAAc,GAAGrC,iBAAiB,CAACC,WAAW,EAAEC,KAAK,EAAEuB,KAAA,CAAKW,KAAK,CAACjC,UAAU,CAAC;QACnFsB,KAAA,CAAKO,QAAQ,CAAC;UACZ/B,WAAW,EAAEoC;QACf,CAAC,CAAC;MACJ,CACF,CAAC;IACH,CAAC;IAAA,IAAArD,gBAAA,aAAAyC,KAAA,mBAEe,UAACV,KAAK,EAAK;MACzB,IAAMuB,2BAA2B,GAAA1D,aAAA,CAAAA,aAAA,KAC5Be,wBAAwB,GACxBoB,KAAK,CAACwB,iBAAiB,CAC3B;MAED,IAAMC,cAAc,GAAG;QACrBC,YAAY,EAAEhB,KAAA,CAAKV,KAAK,CAACL,KAAK;QAC9BP,UAAU,EAAEsB,KAAA,CAAKW,KAAK,CAACjC,UAAU;QACjCgC,kBAAkB,EAAEV,KAAA,CAAKW,KAAK,CAACD,kBAAkB;QACjDO,cAAc,EAAEjB,KAAA,CAAKiB,cAAc;QACnCC,iBAAiB,EAAElB,KAAA,CAAKmB;MAC1B,CAAC;MACD,IAAAC,IAAA,GAAwB9B,KAAK,CAAC+B,WAAW,IAAI,CAAC,CAAC;QAAzCC,aAAa,GAAAF,IAAA,CAAbE,aAAa;MACnBA,aAAa,GAAGA,aAAa,IAAI,EAAE;MAEnCtB,KAAA,CAAKuB,OAAO,GAAG,IAAAC,qBAAY,EAAClC,KAAK,CAACmC,aAAa,EAAEH,aAAa,EAAE;QAC9DI,IAAI,EAAAvE,aAAA;UACFwE,OAAO,EAAE3B,KAAA,CAAK4B,WAAW;UACzBC,OAAO,EAAE7B,KAAA,CAAK8B,aAAa;UAC3BC,MAAM,EAAE/B,KAAA,CAAKgC;QAAY,GACtB1C,KAAK,CAAC2C,aAAa,CACvB;QACDC,SAAS,EAAE;UACTC,QAAQ,EAAE,SAAVA,QAAQA,CAAA;YAAA,OAAQnC,KAAA,CAAKW,KAAK,CAAC1B,KAAK;UAAA;UAChCmD,QAAQ,EAAEpC,KAAA,CAAKoC;QACjB,CAAC;QACDC,IAAI,EAAEtB,cAAc;QACpBuB,aAAa,EAAEhD,KAAK,CAACgD,aAAa,IAAI,CAAC,CAAC;QACxCC,KAAK,EAAE;UACLC,4BAA4B,EAAElD,KAAK,CAACkD,4BAA4B;UAChEC,QAAQ,EACNnD,KAAK,CAACoD,YAAY,IAClBpD,KAAK,CAACoD,YAAY,UAAO,IACxB,UAACC,IAAI,EAAEC,IAAI,EAAK;YACf,IAAMC,GAAG,GAAGF,IAAI,CAACG,IAAI,CAACpH,GAAG,CAAC,KAAK,CAAC;YAEhC4D,KAAK,CAACoD,YAAY,UAAO,CAACG,GAAG,EAAE,UAAC/H,CAAC,EAAK;cACpC,IAAMiI,gBAAgB,GAAG/C,KAAA,CAAKW,KAAK,CAACqC,aAAa,CAAChG,MAAM,CAAC,UAACiG,GAAG;gBAAA,OAAKA,GAAG,CAACC,GAAG,KAAKP,IAAI,CAACO,GAAG;cAAA,EAAC;cACvF,IAAmBC,YAAY,GAAKnD,KAAA,CAAKW,KAAK,CAAtCyC,SAAS;cACjB,IAAMC,QAAQ,GAAG;gBACfL,aAAa,EAAED,gBAAgB;gBAC/BK,SAAS,EAAED,YAAY,IAAIJ,gBAAgB,CAAC1F,MAAM,KAAK,CAAC,GAAG,KAAK,GAAG8F;cACrE,CAAC;cAEDnD,KAAA,CAAKO,QAAQ,CAAC8C,QAAQ,EAAE;gBAAA,OAAMT,IAAI,CAAC9H,CAAC,EAAEkF,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC;cAAA,EAAC;YAC1D,CAAC,CAAC;UACJ,CAAE;UACJqE,oBAAoB,EAClBhE,KAAK,CAACoD,YAAY,IACjB,UAACa,UAAU,EAAEC,UAAU,EAAK;YAC3B,IAAQR,aAAa,GAAKhD,KAAA,CAAKW,KAAK,CAA5BqC,aAAa;YACrB,IAAMS,QAAQ,GAAG,SAAXA,QAAQA,CAAIC,MAAM,EAAK;cAC3B,IAAIC,EAAE;cAEN,IAAI3D,KAAA,CAAKW,KAAK,CAACyC,SAAS,IAAIM,MAAM,EAAE;gBAClC;gBACAC,EAAE,GAAG3D,KAAA,CAAK4D,aAAa,CAACC,IAAI,CAAA7D,KAAK,CAAC;cACpC;cAEA,IAAM+C,gBAAgB,GAAG/C,KAAA,CAAKW,KAAK,CAACqC,aAAa,CAAChG,MAAM,CAAC,UAACiG,GAAG;gBAAA,OAAKA,GAAG,CAACC,GAAG,KAAKK,UAAU,CAACL,GAAG;cAAA,EAAC;cAC7F,IAAMG,QAAQ,GAAG;gBACfL,aAAa,EAAED;cACjB,CAAC;cAED,IAAIA,gBAAgB,CAAC1F,MAAM,KAAK,CAAC,EAAE;gBACjCgG,QAAQ,CAACD,SAAS,GAAG,KAAK;cAC5B;cAEApD,KAAA,CAAKO,QAAQ,CAAC8C,QAAQ,EAAEM,EAAE,CAAC;YAC7B,CAAC;YACD,IAAMrD,QAAQ,GAAG,SAAXA,QAAQA,CAAA,EAAS;cACrB;AACd;AACA;AACA;cACc,IAAMwD,OAAO,GAAGN,UAAU,CAACC,QAAQ,EAAE;gBAAA,OAAMzD,KAAA,CAAKW,KAAK,CAAC1B,KAAK;cAAA,EAAC;cAC5DK,KAAK,CAACoD,YAAY,CAACqB,GAAG,CAACD,OAAO,CAAC;YACjC,CAAC;YAED9D,KAAA,CAAKO,QAAQ,CACX;cACEyC,aAAa,KAAA5D,MAAA,KAAA4E,mBAAA,aAAMhB,aAAa,IAAEO,UAAU;YAC9C,CAAC,EACDjD,QACF,CAAC;UACH,CAAE;UACJuB,OAAO,EAAE7B,KAAA,CAAK8B,aAAa;UAC3BC,MAAM,EAAE/B,KAAA,CAAKgC,YAAY;UACzBiC,aAAa,EAAE3E,KAAK,CAAC2E,aAAa;UAClCC,cAAc,EAAE5E,KAAK,CAAC4E;QACxB,CAAC;QACDC,OAAO,EAAE;UACP;AACR;AACA;AACA;UACQC,gBAAgB,EAAE,CAAC,CAAC9E,KAAK,CAAC8E,gBAAgB;UAC1CC,gBAAgB,EAAE/E,KAAK,CAAC+E,gBAAgB;UACxCC,SAAS,EAAEhF,KAAK,CAACiF,gBAAgB;UACjCC,MAAM,EAAE,SAARA,MAAMA,CAAA,EAAQ;YAAA,IAAAC,qBAAA;YACZ,IAAQC,QAAQ,GAAKpF,KAAK,CAAlBoF,QAAQ;YAEhBhH,GAAG,CAAC,UAAU,CAAC;YACfsC,KAAA,CAAKO,QAAQ,CAAC;cAAEoE,cAAc,EAAE,KAAK;cAAEC,WAAW,EAAE,IAAI;cAAEC,YAAY,EAAE;YAAM,CAAC,CAAC;YAChF7E,KAAA,CAAK8E,MAAM,CAACC,IAAI,CAAC,CAAC;YAElB,IAAIL,QAAQ,IAAI,EAAAD,qBAAA,GAAAzE,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC+F,SAAS,cAAAP,qBAAA,gBAAAA,qBAAA,GAA1BA,qBAAA,CAA4BQ,IAAI,cAAAR,qBAAA,uBAAhCA,qBAAA,CAAkCpH,MAAM,MAAK,CAAC,EAAE;cAC9D2C,KAAA,CAAKkF,UAAU,CAAC,IAAI,CAAC,CAACC,IAAI,CAAC,YAAM;gBAC/BnF,KAAA,CAAK4D,aAAa,CAAC,CAAC;cACtB,CAAC,CAAC;YACJ,CAAC,MAAM;cACL5D,KAAA,CAAK4D,aAAa,CAAC,CAAC;YACtB;UACF;QACF,CAAC;QACDwB,KAAK,EAAE;UACLvD,OAAO,EAAE,SAATA,OAAOA,CAAA,EAAQ;YACbnE,GAAG,CAAC,oBAAoB,CAAC;YACzBsC,KAAA,CAAK8B,aAAa,CAAC,CAAC;UACtB,CAAC;UACDC,MAAM,EAAE,SAARA,MAAMA,CAAA,EAAQ;YACZrE,GAAG,CAAC,mBAAmB,CAAC;YACxBsC,KAAA,CAAKgC,YAAY,CAAC,CAAC;UACrB;QACF,CAAC;QACDqD,YAAY,EAAE;UACZC,IAAI,EAAEzE,2BAA2B,CAACyE,IAAI;UACtCnH,OAAO,EAAE0C,2BAA2B,CAAC1C,OAAO;UAC5CoH,gBAAgB,EAAE1E,2BAA2B,CAAC0E,gBAAgB;UAC9DnH,eAAe,EAAEyC,2BAA2B,CAACzC,eAAe;UAC5DC,kBAAkB,EAAEwC,2BAA2B,CAACxC,kBAAkB;UAClEI,KAAK,EAAEoC,2BAA2B,CAACpC,KAAK;UACxCoD,OAAO,EAAE,SAATA,OAAOA,CAAA,EAAQ;YACbnE,GAAG,CAAC,oBAAoB,CAAC;YACzBsC,KAAA,CAAK8B,aAAa,CAAC,CAAC;UACtB,CAAC;UACDC,MAAM,EAAE,SAARA,MAAMA,CAAA,EAAQ;YACZrE,GAAG,CAAC,mBAAmB,CAAC;YACxBsC,KAAA,CAAKgC,YAAY,CAAC,CAAC;UACrB;QACF,CAAC;QACDwD,kBAAkB,EAAElG,KAAK,CAACmG,uBAAuB;QACjDC,kBAAkB,EAAE1F,KAAA,CAAK0F,kBAAkB;QAC3CC,oBAAoB,EAAE3F,KAAA,CAAK2F,oBAAoB;QAC/CC,KAAK,EAAE;UACLC,KAAK,EAAE7F,KAAA,CAAK6F,KAAK;UACjBC,YAAY,EAAE,SAAdA,YAAYA,CAAA;YAAA,OAAQ9F,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC8G,MAAM,CAAC,CAAC;UAAA;UAC7C3D,QAAQ,EAAEpC,KAAA,CAAKoC,QAAQ;UACvB4D,kBAAkB,EAAE1G,KAAK,CAAC0G;QAC5B;MACF,CAAC,CAAC;MAEF,IAAI1G,KAAK,CAAC2C,aAAa,CAACgE,SAAS,IAAI3G,KAAK,CAAC2C,aAAa,CAACiE,UAAU,EAAE;QACnElG,KAAA,CAAKV,KAAK,CAAC6G,wBAAwB,CAAC,CAAC;MACvC;IACF,CAAC;IAAA,IAAA5I,gBAAA,aAAAyC,KAAA,kBAmFc,UAAClF,CAAC,EAAK;MACpB4C,GAAG,CAAC,gBAAgB,EAAE5C,CAAC,IAAIA,CAAC,CAACsL,aAAa,CAAC;MAC3C,IAAMC,MAAM,GAAGvL,CAAC,IAAIA,CAAC,CAACsL,aAAa;MAEnC,IAAMzD,IAAI,GAAG0D,MAAM,GAAG,IAAAC,oBAAQ,EAACD,MAAM,EAAErG,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC,GAAG,IAAI;MAC/DvB,GAAG,CAAC,uBAAuB,EAAEiF,IAAI,CAAC;MAClC3C,KAAA,CAAKO,QAAQ,CAAC;QAAEqE,WAAW,EAAEjC;MAAK,CAAC,EAAE,YAAM;QACzC3C,KAAA,CAAKkF,UAAU,CAAC,CAAC;MACnB,CAAC,CAAC;IACJ,CAAC;IAAA,IAAA3H,gBAAA,aAAAyC,KAAA,mBAEe,UAAClF,CAAC,EAAK;MACrB4C,GAAG,CAAC,iBAAiB,EAAE5C,CAAC,IAAIA,CAAC,CAACuL,MAAM,CAAC;MACrC,IAAMA,MAAM,GAAGvL,CAAC,IAAIA,CAAC,CAACuL,MAAM;MAC5B,IAAIA,MAAM,EAAE;QACV,IAAM1D,IAAI,GAAG,IAAA2D,oBAAQ,EAACD,MAAM,EAAErG,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC;QAC/CvB,GAAG,CAAC,wBAAwB,EAAEiF,IAAI,CAAC;QAEnC,IAAM4D,YAAY,GAAGvG,KAAA,CAAKW,KAAK,CAAC4F,YAAY,IAAIvG,KAAA,CAAKW,KAAK,CAAC1B,KAAK;QAChEe,KAAA,CAAKO,QAAQ,CAAC;UAAEqE,WAAW,EAAEjC,IAAI;UAAE4D,YAAY,EAAZA;QAAa,CAAC,CAAC;MACpD,CAAC,MAAM;QACLvG,KAAA,CAAKO,QAAQ,CAAC;UAAEqE,WAAW,EAAE;QAAK,CAAC,CAAC;MACtC;MACA5E,KAAA,CAAKwG,UAAU,CAAC,CAAC;IACnB,CAAC;IAAA,IAAAjJ,gBAAA,aAAAyC,KAAA,iBAEa,UAAC2C,IAAI,EAAK;MACtB3C,KAAA,CAAK8E,MAAM,CAACiB,MAAM,CAAC,UAACU,CAAC;QAAA,OAAKA,CAAC,CAACC,iBAAiB,CAAC/D,IAAI,CAAC;MAAA,EAAC;MACpD3C,KAAA,CAAKO,QAAQ,CAAC;QAAEoG,YAAY,EAAEhE;MAAK,CAAC,CAAC;IACvC,CAAC;IAAA,IAAApF,gBAAA,aAAAyC,KAAA,mBAEe,YAAM;MACpB,IAAA4G,WAAA,GAAqD5G,KAAA,CAAKW,KAAK;QAAvDjC,UAAU,GAAAkI,WAAA,CAAVlI,UAAU;QAAE8B,MAAM,GAAAoG,WAAA,CAANpG,MAAM;QAAEvB,KAAK,GAAA2H,WAAA,CAAL3H,KAAK;QAAE+D,aAAa,GAAA4D,WAAA,CAAb5D,aAAa;;MAEhD;MACA,IAAItE,UAAU,EAAE;QACd;QACA,IAAI8B,MAAM,aAANA,MAAM,eAANA,MAAM,CAAEJ,IAAI,EAAE;QAElB,IAAMY,YAAY,GAAG,IAAA6F,0BAAW,EAAC5H,KAAK,CAAC6H,QAAQ,CAAC7B,IAAI,CAAC;QACrD,IAAM8B,WAAW,GAAG/G,KAAA,CAAKgH,wBAAwB,CAAC,CAAC;QAEnDhH,KAAA,CAAKiH,8BAA8B,CAACjG,YAAY,EAAE+F,WAAW,CAAC;QAC9D;MACF;MAEA,IAAI/D,aAAa,CAAC3F,MAAM,EAAE;QACxB;QACA2C,KAAA,CAAKO,QAAQ,CAAC;UAAE6C,SAAS,EAAE;QAAK,CAAC,CAAC;QAClC;MACF;;MAEA;MACA1F,GAAG,CAAC,iBAAiB,CAAC;MACtBsC,KAAA,CAAKO,QAAQ,CAAC;QAAEyC,aAAa,EAAE,EAAE;QAAEuD,YAAY,EAAE,IAAI;QAAE3B,WAAW,EAAE;MAAK,CAAC,CAAC;MAC3ElH,GAAG,CAAC,yBAAyB,EAAEsC,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC;MAChDe,KAAA,CAAKV,KAAK,CAAC8C,QAAQ,CAACpC,KAAA,CAAKW,KAAK,CAAC1B,KAAK,EAAE,IAAI,CAAC;IAC7C,CAAC;IAED;AACF;AACA;AACA;IAHE,IAAA1B,gBAAA,aAAAyC,KAAA,8BAI2B,YAAM;MAC/B,oBACExG,MAAA,YAAA0N,aAAA;QAAKC,GAAG,EAAE,SAALA,GAAGA,CAAGA,KAAG;UAAA,OAAMnH,KAAA,CAAKoH,UAAU,GAAGD,KAAG;QAAA;MAAE,gBACzC3N,MAAA,YAAA0N,aAAA,cAAK,yBAA4B,CAAC,eAElC1N,MAAA,YAAA0N,aAAA,CAACG,iBAAiB,qBAChB7N,MAAA,YAAA0N,aAAA,CAAC7M,SAAA,CAAAiN,aAAa;QAACC,MAAM,EAAEvH,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC6H,QAAQ,CAAC7B;MAAK,CAAE,CACvC,CAAC,eACpBzL,MAAA,YAAA0N,aAAA,cAAK,wCAA2C,CAC7C,CAAC;IAEV,CAAC;IAED;AACF;AACA;AACA;IAHE,IAAA3J,gBAAA,aAAAyC,KAAA,oCAIiC,UAACgB,YAAY,EAAE+F,WAAW,EAAK;MAC9D/G,KAAA,CAAKO,QAAQ,CAAC;QACZC,MAAM,EAAE;UACNJ,IAAI,EAAE,IAAI;UACVoH,KAAK,EAAE,wBAAwB;UAC/BvC,IAAI,EAAE8B,WAAW;UACjBU,aAAa,EAAE,cAAc;UAC7BC,WAAW,EAAE,kBAAkB;UAC/BC,SAAS,EAAE,SAAXA,SAASA,CAAA,EAAQ;YACf3H,KAAA,CAAK4H,8BAA8B,CAAC5G,YAAY,CAAC;UACnD,CAAC;UACD6G,OAAO,EAAE7H,KAAA,CAAK8H;QAChB;MACF,CAAC,CAAC;IACJ,CAAC;IAED;AACF;AACA;AACA;AACA;IAJE,IAAAvK,gBAAA,aAAAyC,KAAA,oCAKiC,UAACgB,YAAY,EAAK;MACjDhB,KAAA,CAAKO,QAAQ,CAAC;QAAEtB,KAAK,EAAE+B;MAAa,CAAC,CAAC;MACtChB,KAAA,CAAKV,KAAK,CAAC8C,QAAQ,CAACpB,YAAY,EAAE,IAAI,CAAC;MACvChB,KAAA,CAAKmB,YAAY,CAAC,KAAK,CAAC;MACxBnB,KAAA,CAAKiB,cAAc,CAAC,CAAC;IACvB,CAAC;IAED;AACF;AACA;AACA;IAHE,IAAA1D,gBAAA,aAAAyC,KAAA,6BAI0B,YAAM;MAC9BA,KAAA,CAAKmB,YAAY,CAAC,KAAK,CAAC;IAC1B,CAAC;IASD;IAAA,IAAA5D,gBAAA,aAAAyC,KAAA,gBACa,UAAC+H,OAAO,EAAK;MACxB,IAAQrD,QAAQ,GAAK1E,KAAA,CAAKV,KAAK,CAAvBoF,QAAQ;MAChB,IACiBzG,MAAM,GACnB+B,KAAA,CAAKW,KAAK,CADZnC,WAAW,CAAIP,MAAM;MAGvB+B,KAAA,CAAKO,QAAQ,CAAC;QAAEoE,cAAc,EAAE,KAAK;QAAEC,WAAW,EAAE;MAAK,CAAC,CAAC;MAE3D,IAAI5E,KAAA,CAAK8E,MAAM,EAAE;QACf9E,KAAA,CAAK8E,MAAM,CAACC,IAAI,CAAC,CAAC;MACpB;MAEA,IAAI9G,MAAM,KAAK,MAAM,EAAE;QAAA,IAAA+J,sBAAA;QACrB,IAAItD,QAAQ,IAAI,EAAAsD,sBAAA,GAAAhI,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC+F,SAAS,cAAAgD,sBAAA,gBAAAA,sBAAA,GAA1BA,sBAAA,CAA4B/C,IAAI,cAAA+C,sBAAA,uBAAhCA,sBAAA,CAAkC3K,MAAM,MAAK,CAAC,EAAE;UAC9D2C,KAAA,CAAKkF,UAAU,CAAC,IAAI,CAAC,CAACC,IAAI,CAAC,YAAM;YAC/BnF,KAAA,CAAK4D,aAAa,CAAC,CAAC;YACpBmE,OAAO,CAAC,CAAC;UACX,CAAC,CAAC;QACJ,CAAC,MAAM;UACL/H,KAAA,CAAK4D,aAAa,CAAC,CAAC;UACpBmE,OAAO,CAAC,CAAC;QACX;MACF;IACF,CAAC;IAAA,IAAAxK,gBAAA,aAAAyC,KAAA,YAEQ,UAACiI,KAAK,EAAK;MAAA,IAAAC,qBAAA;MAClBxK,GAAG,CAAC,UAAU,CAAC;MACf,IAAM0I,aAAa,GAAG6B,KAAK,CAAC7B,aAAa;MACzC,IAAM+B,cAAc,GAAGnI,KAAA,CAAKoI,UAAU,KAAIhC,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEiC,OAAO,cAAAjJ,MAAA,CAAaY,KAAA,CAAKoI,UAAU,CAACE,SAAS,QAAI,CAAC;;MAE3G;MACA,IAAMC,eAAe,GACnBvI,KAAA,CAAKwI,aAAa,KAAIpC,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEiC,OAAO,cAAAjJ,MAAA,EAAA8I,qBAAA,GAAalI,KAAA,CAAKwI,aAAa,CAACC,OAAO,cAAAP,qBAAA,uBAA1BA,qBAAA,CAA4BI,SAAS,QAAI,CAAC;;MAErG;MACAtI,KAAA,CAAK0I,gBAAgB,GAAG1I,KAAA,CAAKG,yBAAyB,IAAIiG,aAAa,KAAK,IAAI;MAEhF,IAAI+B,cAAc,IAAI,CAACI,eAAe,IAAI,CAACvI,KAAA,CAAKW,KAAK,CAACkE,YAAY,EAAE;QAClE7E,KAAA,CAAKO,QAAQ,CAAC;UACZsE,YAAY,EAAE;QAChB,CAAC,CAAC;MACJ;MAEA,IAAMlC,IAAI,GAAGyD,aAAa,GAAG,IAAAE,oBAAQ,EAACF,aAAa,EAAEpG,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC,GAAG,IAAI;MAE7EvB,GAAG,CAAC,iBAAiB,EAAEiF,IAAI,CAAC;MAE5B,OAAO,IAAIgG,OAAO,CAAC,UAACZ,OAAO,EAAK;QAC9B,IAAI,CAAC/H,KAAA,CAAK0I,gBAAgB,EAAE;UAC1B1I,KAAA,CAAK2F,oBAAoB,CAAC,KAAK,CAAC;UAChC3F,KAAA,CAAKO,QAAQ,CACX;YAAEqI,YAAY,EAAE5I,KAAA,CAAKW,KAAK,CAAC1B,KAAK;YAAE2F,WAAW,EAAE,CAACjC,IAAI,GAAG,IAAI,GAAGA;UAAK,CAAC,EACpE3C,KAAA,CAAK6I,UAAU,CAAChF,IAAI,CAAA7D,KAAA,EAAO+H,OAAO,CACpC,CAAC;QACH;QAEA/H,KAAA,CAAKV,KAAK,CAACyC,MAAM,CAACkG,KAAK,CAAC;MAC1B,CAAC,CAAC;IACJ,CAAC;IAAA,IAAA1K,gBAAA,aAAAyC,KAAA,mBAEe,UAAClF,CAAC,EAAK;MACrB,IAAMgO,SAAS,GAAGhC,QAAQ,CAACiC,aAAa,gBAAA3J,MAAA,CAAeY,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC6H,QAAQ,CAAC5D,GAAG,QAAI,CAAC;MAEzF8F,UAAU,CAAC,YAAM;QACf,IAAeC,UAAU,GAAKjJ,KAAA,CAAKW,KAAK,CAAhC1B,KAAK;QAEb,IAAI,CAACe,KAAA,CAAKkJ,UAAU,EAAE;UACpB;QACF;QAEA,IAAMC,aAAa,GAAG,CAACL,SAAS,IAAIhC,QAAQ,CAACsC,aAAa,CAACf,OAAO,cAAAjJ,MAAA,CAAa0J,SAAS,CAACR,SAAS,QAAI,CAAC;QACvG,IAAMH,cAAc,GAClB,CAACnI,KAAA,CAAKoI,UAAU,IAAItB,QAAQ,CAACsC,aAAa,CAACf,OAAO,cAAAjJ,MAAA,CAAaY,KAAA,CAAKoI,UAAU,CAACE,SAAS,QAAI,CAAC;QAC/F,IAAMe,oBAAoB,GAAGrJ,KAAA,CAAKkJ,UAAU,CAACI,QAAQ,CAACH,aAAa,CAAC,IAAInJ,KAAA,CAAKkJ,UAAU,CAACI,QAAQ,CAACnB,cAAc,CAAC;QAEhH,IAAI,CAACkB,oBAAoB,EAAE;UACzBP,SAAS,CAACS,mBAAmB,CAAC,MAAM,EAAEvJ,KAAA,CAAKwJ,aAAa,CAAC;UAEzD,IAAIP,UAAU,CAACQ,SAAS,EAAE;YACxBzJ,KAAA,CAAK+B,MAAM,CAACjH,CAAC,CAAC;UAChB;QACF;MACF,CAAC,EAAE,EAAE,CAAC;IACR,CAAC;IAED;AACF;AACA;AACA;AACA;AACA;AACA;IANE,IAAAyC,gBAAA,aAAAyC,KAAA,aAOU,UAACiI,KAAK,EAAElC,MAAM;MAAA,OACtB,IAAI4C,OAAO,CAAC,UAACZ,OAAO,EAAK;QAAA,IAAA2B,UAAA;QACvB,IAAMZ,SAAS,GAAGhC,QAAQ,CAACiC,aAAa,gBAAA3J,MAAA,CAAeY,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC6H,QAAQ,CAAC5D,GAAG,QAAI,CAAC;QACzF,IAAMyG,aAAa,GACjB,OAAOC,MAAM,KAAK,WAAW,KAAK,cAAc,IAAIA,MAAM,IAAI,EAAAF,UAAA,GAAAG,SAAS,cAAAH,UAAA,uBAATA,UAAA,CAAWI,cAAc,IAAG,CAAC,CAAC;QAE9FpM,GAAG,CAAC,WAAW,EAAEoJ,QAAQ,CAACsC,aAAa,CAAC;QAExC,IAAIpJ,KAAA,CAAKG,yBAAyB,IAAIH,KAAA,CAAK+J,uBAAuB,EAAE;UAClE/J,KAAA,CAAK+J,uBAAuB,GAAG,IAAI;QACrC;;QAEA;AACN;AACA;QACM,IAAI/J,KAAA,CAAK+J,uBAAuB,EAAE;UAChC,IAAAC,qBAAA,GAAsBhK,KAAA,CAAK+J,uBAAuB;YAA1C7G,GAAG,GAAA8G,qBAAA,CAAH9G,GAAG;YAAEJ,IAAI,GAAAkH,qBAAA,CAAJlH,IAAI;UACjB,IAAMmH,KAAK,GAAGnD,QAAQ,CAACiC,aAAa,gBAAA3J,MAAA,CAAe8D,GAAG,QAAI,CAAC;UAE3D,IAAI+G,KAAK,EAAE;YACT,IAAIlE,OAAM,GAAG/F,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC8G,MAAM,CAAC,CAAC,CAACmE,YAAY,CAAChH,GAAG,EAAE;cAAEJ,IAAI,EAAJA;YAAK,CAAC,CAAC;YAClE9C,KAAA,CAAKO,QAAQ,CAAC;cAAEtB,KAAK,EAAE8G,OAAM,CAAC9G;YAAM,CAAC,EAAE,YAAM;cAC3Ce,KAAA,CAAK+J,uBAAuB,GAAG,IAAI;YACrC,CAAC,CAAC;UACJ;QACF;;QAEA;AACN;AACA;AACA;AACA;AACA;QACM,IAAIjB,SAAS,KAAKhC,QAAQ,CAACsC,aAAa,EAAE;UACxCN,SAAS,CAACS,mBAAmB,CAAC,MAAM,EAAEvJ,KAAA,CAAKwJ,aAAa,CAAC;UACzDV,SAAS,CAACqB,gBAAgB,CAAC,MAAM,EAAEnK,KAAA,CAAKwJ,aAAa,CAAC;QACxD;QAEAxJ,KAAA,CAAKwG,UAAU,CAAC,CAAC;QACjBxG,KAAA,CAAKV,KAAK,CAACuC,OAAO,CAAC,CAAC;;QAEpB;QACA,IAAMuI,iBAAiB,GAAG,CAACpK,KAAA,CAAKG,yBAAyB,IAAI,CAACwJ,aAAa;QAE3E,IAAIS,iBAAiB,EAAE;UACrBrE,MAAM,aAANA,MAAM,eAANA,MAAM,CAAEF,KAAK,CAAC,CAAC;QACjB;QAEAkC,OAAO,CAAC,CAAC;MACX,CAAC,CAAC;IAAA;IAAA,IAAAxK,gBAAA,aAAAyC,KAAA,gBAES,YAAM;MACjBtC,GAAG,CAAC,cAAc,CAAC;MAEnB,IAAI,CAACsC,KAAA,CAAKW,KAAK,CAAC4F,YAAY,EAAE;QAC5BvG,KAAA,CAAKO,QAAQ,CAAC;UAAEgG,YAAY,EAAEvG,KAAA,CAAKW,KAAK,CAAC1B;QAAM,CAAC,CAAC;MACnD;IACF,CAAC;IAED;AACF;AACA;IAFE,IAAA1B,gBAAA,aAAAyC,KAAA,gBAGa,UAACqK,KAAK,EAAK;MACtB,IAAAC,YAAA,GAA+BtK,KAAA,CAAKW,KAAK;QAAjC1B,KAAK,GAAAqL,YAAA,CAALrL,KAAK;QAAE2F,WAAW,GAAA0F,YAAA,CAAX1F,WAAW;MAE1B,IAAM2F,SAAS,GAAGvK,KAAA,CAAKuB,OAAO,CAACiJ,MAAM,CAAC,UAACC,CAAC,EAAEC,CAAC,EAAK;QAC9C,OAAOD,CAAC,IAAKC,CAAC,CAACH,SAAS,IAAIG,CAAC,CAACH,SAAS,CAACvK,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAE;MAC5D,CAAC,EAAE,KAAK,CAAC;MAETvB,GAAG,CAAC,cAAc,EAAEuB,KAAK,CAACwK,SAAS,EAAE7E,WAAW,EAAE,aAAa,EAAE2F,SAAS,CAAC;MAC3E,IAAKvK,KAAA,CAAKW,KAAK,CAAC4F,YAAY,IAAI,CAACtH,KAAK,CAACwK,SAAS,IAAI,CAAC7E,WAAW,IAAI,CAAC2F,SAAS,IAAKF,KAAK,EAAE;QACxF3M,GAAG,CAAC,2BAA2B,CAAC;QAChCA,GAAG,CAAC,SAAS,EAAEsC,KAAA,CAAKW,KAAK,CAAC4F,YAAY,CAACO,QAAQ,CAAC6D,QAAQ,CAAC,CAAC,CAAC;QAC3DjN,GAAG,CAAC,SAAS,EAAEsC,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC6H,QAAQ,CAAC6D,QAAQ,CAAC,CAAC,CAAC;QAEpD,IAAMC,QAAQ,GAAGC,YAAK,CAACC,QAAQ,CAAC9K,KAAA,CAAKW,KAAK,CAAC4F,YAAY,CAACwE,MAAM,CAAC,CAAC,CAAC;QAEjErN,GAAG,CAAC,YAAY,EAAEkN,QAAQ,CAAC9D,QAAQ,CAAC;QACpC,OAAO,IAAI6B,OAAO,CAAC,UAACZ,OAAO,EAAK;UAC9BiB,UAAU,CAAC,YAAM;YACfhJ,KAAA,CAAKO,QAAQ,CAAC;cAAEtB,KAAK,EAAE2L,QAAQ;cAAErE,YAAY,EAAE;YAAK,CAAC,EAAE,YAAM;cAC3D7I,GAAG,CAAC,aAAa,EAAEsC,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC6H,QAAQ,CAACiE,MAAM,CAAC,CAAC,CAAC;cACtDhD,OAAO,CAAC,CAAC;YACX,CAAC,CAAC;UACJ,CAAC,EAAE,EAAE,CAAC;QACR,CAAC,CAAC;MACJ,CAAC,MAAM;QACL,OAAOY,OAAO,CAACZ,OAAO,CAAC,CAAC,CAAC,CAAC;MAC5B;IACF,CAAC;IAAA,IAAAxK,gBAAA,aAAAyC,KAAA,cAEU,UAAC+F,MAAM,EAAEnD,IAAI,EAAK;MAC3BlF,GAAG,CAAC,YAAY,CAAC;MACjBkM,MAAM,CAACoB,EAAE,GAAAhL,KAAO;MAEhB,IAAQf,KAAK,GAAK8G,MAAM,CAAhB9G,KAAK;MACb,IAAQgM,eAAe,GAAKjL,KAAA,CAAKV,KAAK,CAA9B2L,eAAe;MACvB,IAAIC,KAAK,GAAGD,eAAe;MAC3B,IAAI,CAACC,KAAK,IAAIA,KAAK,GAAGrL,oBAAoB,EAAE;QAC1CqL,KAAK,GAAGrL,oBAAoB;MAC9B;MAEA,IAAIZ,KAAK,IAAIA,KAAK,CAAC6H,QAAQ,IAAI7H,KAAK,CAAC6H,QAAQ,CAAC7B,IAAI,IAAIhG,KAAK,CAAC6H,QAAQ,CAAC7B,IAAI,CAAC5H,MAAM,GAAG6N,KAAK,EAAE;QACxF;MACF;;MAEA;MACA;MACA,IAAMxK,kBAAkB,GAAG,CAACV,KAAA,CAAKW,KAAK,CAACjC,UAAU,GAC7C,KAAK,GACLsB,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAAC6H,QAAQ,CAAC7B,IAAI,KAAKhG,KAAK,CAAC6H,QAAQ,CAAC7B,IAAI,GACpD,IAAI,GACJjF,KAAA,CAAKW,KAAK,CAACD,kBAAkB;MAEnC,IAAIA,kBAAkB,IAAIV,KAAA,CAAKW,KAAK,CAACD,kBAAkB,EAAE;QACvDV,KAAA,CAAKmL,aAAa,CAACnL,KAAA,CAAKV,KAAK,CAAC;MAChC;MAEAU,KAAA,CAAKO,QAAQ,CAAC;QAAEtB,KAAK,EAALA,KAAK;QAAEyB,kBAAkB,EAAlBA;MAAmB,CAAC,EAAE,YAAM;QACjDhD,GAAG,CAAC,yBAAyB,CAAC;QAE9B,IAAIkF,IAAI,EAAE;UACRA,IAAI,CAAC,CAAC;QACR;MACF,CAAC,CAAC;IACJ,CAAC;IAAA,IAAArF,gBAAA,aAAAyC,KAAA,qBAEiB,YAAM;MACtB,IAAIA,KAAA,CAAKW,KAAK,CAAC1B,KAAK,CAACwK,SAAS,EAAE;QAC9B,OAAOzJ,KAAA,CAAKW,KAAK,CAAC1B,KAAK;MACzB;MAEA,OAAOe,KAAA,CAAKW,KAAK,CAACiI,YAAY;IAChC,CAAC;IAAA,IAAArL,gBAAA,aAAAyC,KAAA,kBAOc,UAAC2C,IAAI,EAAK;MACvB,IAAIA,IAAI,CAACyI,MAAM,KAAK,OAAO,EAAE;MAE7B,IAAMC,IAAI,GAAG1I,IAAI,CAAC2I,KAAK,CAACD,IAAI,CAAC,CAAC;MAC9B,IAAI,CAACA,IAAI,EAAE;MAEX,IAAIA,IAAI,CAAC/F,IAAI,KAAK,OAAO,EAAE;MAE3B5H,GAAG,CAAC,gCAAgC,CAAC;MAErC,IAAM6N,MAAM,GAAGF,IAAI,CAACG,SAAS,CAACH,IAAI,CAACnI,GAAG,CAAC;MACvC,IAAMwH,CAAC,GAAGe,YAAK,CAACD,SAAS,CAACH,IAAI,CAACnI,GAAG,CAAC;MACnCxF,GAAG,CAAC,wBAAwB,EAAE6N,MAAM,EAAEb,CAAC,CAAC;MAExC,OAAO3L,SAAS;IAClB,CAAC;IAAA,IAAAxB,gBAAA,aAAAyC,KAAA,gBAEY,UAACkD,GAAG,EAAEJ,IAAI,EAAK;MAC1BpF,GAAG,CAAC,mBAAmB,EAAEwF,GAAG,EAAEJ,IAAI,CAAC;;MAEnC;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;MAEI;MACA;;MAEA9C,KAAA,CAAK+J,uBAAuB,GAAG;QAAE7G,GAAG,EAAHA,GAAG;QAAEJ,IAAI,EAAJA;MAAK,CAAC;IAC9C,CAAC;IAAA,IAAAvF,gBAAA,aAAAyC,KAAA,WAEO,UAAC0L,GAAG,EAAE/I,IAAI,EAAK;MACrB,IAAM9E,QAAQ,GAAG6N,GAAG,IAAI,KAAK;MAE7B1L,KAAA,CAAKV,KAAK,CAACuG,KAAK,CAAChI,QAAQ,EAAE8E,IAAI,CAAC;IAClC,CAAC;IAAA,IAAApF,gBAAA,aAAAyC,KAAA;MAAA,IAAA2L,KAAA,OAAAC,kBAAA,0BAAAC,YAAA,YAAAC,IAAA,CAEa,SAAAC,QAAO9D,KAAK,EAAElC,MAAM,EAAEiG,WAAW;QAAA,IAAAlH,MAAA,EAAAmH,QAAA,EAAAC,IAAA,EAAA5G,IAAA,EAAA6G,QAAA,EAAAlH,IAAA,EAAApC,GAAA,EAAAuJ,MAAA,EAAAC,KAAA,EAAAC,EAAA,EAAAxI,OAAA,EAAAyI,aAAA,EAAAC,SAAA,EAAAC,SAAA,EAAAC,UAAA,EAAAC,YAAA,EAAAC,YAAA,EAAAC,IAAA,EAAAC,EAAA;QAAA,OAAAjB,YAAA,YAAAkB,IAAA,WAAAC,QAAA;UAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;YAAA;cACvCpI,MAAM,GAAGiB,MAAM,CAACjB,MAAM;cACtBmH,QAAQ,GAAG,IAAAkB,4BAAgB,EAAClF,KAAK,CAAC;cAClCiE,IAAI,GAAGD,QAAQ,CAACmB,KAAK,IAAInB,QAAQ,CAACmB,KAAK,CAAC,CAAC,CAAC;cAE1C9H,IAAI,GAAG2G,QAAQ,CAAC3G,IAAI;cACpB6G,QAAQ,GAAGF,QAAQ,CAACE,QAAQ;cAC5BlH,IAAI,GAAGgH,QAAQ,CAAChH,IAAI;cAAA,MAEtBiH,IAAI,KAAKA,IAAI,CAAC5G,IAAI,KAAK,YAAY,IAAI4G,IAAI,CAAC5G,IAAI,KAAK,WAAW,IAAI4G,IAAI,CAAC5G,IAAI,KAAK,WAAW,CAAC;gBAAA0H,QAAA,CAAAE,IAAA;gBAAA;cAAA;cAAA,IAC3FlN,KAAA,CAAKV,KAAK,CAACoD,YAAY;gBAAAsK,QAAA,CAAAE,IAAA;gBAAA;cAAA;cAAA,OAAAF,QAAA,CAAAK,MAAA;YAAA;cAAAL,QAAA,CAAAC,IAAA;cAI1BvP,GAAG,CAAC,eAAe,CAAC;cAACsP,QAAA,CAAAE,IAAA;cAAA,OACH,IAAAI,wBAAS,EAACpB,IAAI,CAAC;YAAA;cAA3BrJ,GAAG,GAAAmK,QAAA,CAAAO,IAAA;cACHnB,MAAM,GAAGoB,aAAM,CAACC,MAAM,CAAC;gBAC3BnI,IAAI,EAAE,OAAO;gBACboI,MAAM,EAAE,IAAI;gBACZ5K,IAAI,EAAE;kBACJ6K,OAAO,EAAE,KAAK;kBACd9K,GAAG,EAAHA;gBACF;cACF,CAAC,CAAC;cAEF,IAAImJ,WAAW,EAAE;gBACfhM,KAAA,CAAK6F,KAAK,CAAC,CAAC;cACd,CAAC,MAAM;gBACCwG,KAAK,GAAG,IAAAuB,yBAAa,EAAC3F,KAAK,EAAEnD,MAAM,CAAC;gBAC1C,IAAIuH,KAAK,EAAE;kBACTtG,MAAM,CAAC8H,MAAM,CAACxB,KAAK,CAAC;gBACtB;cACF;cAEMC,EAAE,GAAGvG,MAAM,CAAC+H,YAAY,CAAC1B,MAAM,CAAC;cACtCpM,KAAA,CAAKoC,QAAQ,CAACkK,EAAE,CAAC;cACXxI,OAAO,GAAG,IAAIiK,8BAAkB,CACpC3B,MAAM,EACN,YAAM,CAAE,CAAC,EACT;gBAAA,OAAMpM,KAAA,CAAKW,KAAK,CAAC1B,KAAK;cAAA,GACtBe,KAAA,CAAKoC,QAAQ,EACb,IACF,CAAC;cACD0B,OAAO,CAACkK,UAAU,CAAC9B,IAAI,CAAC;cACxBlM,KAAA,CAAKV,KAAK,CAACoD,YAAY,CAACqB,GAAG,CAACD,OAAO,CAAC;cAACkJ,QAAA,CAAAE,IAAA;cAAA;YAAA;cAAAF,QAAA,CAAAC,IAAA;cAAAH,EAAA,GAAAE,QAAA;cAErCtP,GAAG,CAAC,uBAAuB,EAAAoP,EAAK,CAAC;YAAC;cAAAE,QAAA,CAAAE,IAAA;cAAA;YAAA;cAAA,MAE3B5H,IAAI,KAAK,UAAU;gBAAA0H,QAAA,CAAAE,IAAA;gBAAA;cAAA;cAC5BnH,MAAM,CAACkI,cAAc,CAAC9B,QAAQ,CAAC;cAACa,QAAA,CAAAE,IAAA;cAAA;YAAA;cAAA,MACvB5H,IAAI,KAAK,MAAM,IAAIA,IAAI,KAAK,MAAM;gBAAA0H,QAAA,CAAAE,IAAA;gBAAA;cAAA;cAAA,IACtCjI,IAAI;gBAAA+H,QAAA,CAAAE,IAAA;gBAAA;cAAA;cAAA,OAAAF,QAAA,CAAAK,MAAA;YAAA;cAAAd,aAAA,GAKLxG,MAAM,CADR9G,KAAK,EAAI6H,SAAQ,GAAAyF,aAAA,CAARzF,QAAQ,EAAE2F,SAAS,GAAAF,aAAA,CAATE,SAAS,EAAEC,UAAU,GAAAH,aAAA,CAAVG,UAAU;cAAA,KAGtCA,UAAU,CAACgB,MAAM;gBAAAV,QAAA,CAAAE,IAAA;gBAAA;cAAA;cAAA,OAAAF,QAAA,CAAAK,MAAA;YAAA;cAIfV,YAAY,GAAGD,UAAU;cACzBE,YAAY,GAAG9F,SAAQ,CAACoH,qBAAqB,CAACzB,SAAS,CAAC;cACxDI,IAAI,GAAGsB,gCAAK,CAACC,WAAW,CAACnJ,IAAI,EAAE;gBACnC0H,YAAY,EAAZA,YAAY;gBACZC,YAAY,EAAZA;cACF,CAAC,CAAC,CAAC9F,QAAQ;cACXf,MAAM,CAACkI,cAAc,CAACpB,IAAI,CAAC;YAAC;YAAA;cAAA,OAAAG,QAAA,CAAAqB,IAAA;UAAA;QAAA,GAAAtC,OAAA;MAAA,CAE/B;MAAA,iBAAAuC,EAAA,EAAAC,GAAA,EAAAC,GAAA;QAAA,OAAA7C,KAAA,CAAAlP,KAAA,OAAAW,SAAA;MAAA;IAAA;IAAA,IAAAG,gBAAA,aAAAyC,KAAA,uBAEmB,UAACV,KAAK,EAAK;MAC7B,IAAQwF,MAAM,GAAKxF,KAAK,CAAhBwF,MAAM;MACd,IAAQgC,QAAQ,GAAKhC,MAAM,CAAC7F,KAAK,CAAzB6H,QAAQ;MAEhB,IAAI,CAAChC,MAAM,CAACxF,KAAK,CAACmP,WAAW,IAAI3H,QAAQ,CAAC7B,IAAI,KAAK,EAAE,IAAI6B,QAAQ,CAACwE,KAAK,CAACoD,IAAI,KAAK,CAAC,IAAI,CAAC5H,QAAQ,CAAC6H,OAAO,EAAE;QACvG,OAAO,KAAK;MACd;MAEA,oBACEnV,MAAA,YAAA0N,aAAA;QACE0H,eAAe,EAAE,KAAM;QACvBC,KAAK,EAAE;UACLC,OAAO,EAAE,cAAc;UACvBtP,KAAK,EAAE,aAAa;UAAE;UACtBC,QAAQ,EAAE,MAAM;UAChBsP,UAAU,EAAE,QAAQ;UACpBC,OAAO,EAAE,MAAM;UACfC,aAAa,EAAE,MAAM;UACrBC,UAAU,EAAE;QACd;MAAE,GAEDpK,MAAM,CAACxF,KAAK,CAACmP,WACV,CAAC;IAEX,CAAC;IAnzBCzO,KAAA,CAAKW,KAAK,GAAG;MACX1B,KAAK,EAAEK,MAAK,CAACL,KAAK;MAClBT,WAAW,EAAED,iBAAiB,CAACe,MAAK,CAACd,WAAW,EAAEc,MAAK,CAACb,KAAK,CAAC;MAC9DuE,aAAa,EAAE,EAAE;MACjBtE,UAAU,EAAE,KAAK;MACjBgC,kBAAkB,EAAE,KAAK;MACzBmE,YAAY,EAAE,KAAK;MACnBrE,MAAM,EAAE;QACNJ,IAAI,EAAE;MACR;IACF,CAAC;IAEDJ,KAAA,CAAK0F,kBAAkB,gBAAGyJ,iBAAK,CAACC,SAAS,CAAC,CAAC;IAC3CpP,KAAA,CAAKwI,aAAa,gBAAG2G,iBAAK,CAACC,SAAS,CAAC,CAAC;IACtCpP,KAAA,CAAKG,yBAAyB,GAAG,KAAK;IAEtCH,KAAA,CAAKiB,cAAc,GAAGjB,KAAA,CAAKiB,cAAc,CAAC4C,IAAI,CAAA7D,KAAK,CAAC;IACpDA,KAAA,CAAKqP,kBAAkB,GAAGrP,KAAA,CAAKqP,kBAAkB,CAACxL,IAAI,CAAA7D,KAAK,CAAC;IAC5DA,KAAA,CAAKsP,iBAAiB,GAAGtP,KAAA,CAAKsP,iBAAiB,CAACzL,IAAI,CAAA7D,KAAK,CAAC;IAE1DA,KAAA,CAAKuP,QAAQ,GAAG,IAAAC,oBAAQ,EAAC,YAAM;MAC7B,IAAI,CAACxP,KAAA,CAAKW,KAAK,CAACjC,UAAU,IAAIY,MAAK,CAAC8C,QAAQ,EAAE;QAC5C9C,MAAK,CAAC8C,QAAQ,CAACpC,KAAA,CAAKW,KAAK,CAAC1B,KAAK,EAAE,IAAI,CAAC;MACxC;IACF,CAAC,EAAE,EAAE,CAAC;IAENe,KAAA,CAAKmL,aAAa,CAACnL,KAAA,CAAKV,KAAK,CAAC;IAAC,OAAAU,KAAA;EACjC;EAAC,IAAAyP,UAAA,aAAA3P,MAAA,EAAAC,gBAAA;EAAA,WAAA2P,aAAA,aAAA5P,MAAA;IAAAoD,GAAA;IAAAjE,KAAA,EAED,SAAAoQ,kBAAkBA,CAAA,EAAG;MACnB,IAAI,IAAI,CAAC1O,KAAK,CAACkE,YAAY,EAAE;QAC3B;MACF;MAEA,IAAI,CAACtE,QAAQ,CAAC;QAAEsE,YAAY,EAAE;MAAK,CAAC,CAAC;IACvC;EAAC;IAAA3B,GAAA;IAAAjE,KAAA,EAMD,SAAAqQ,iBAAiBA,CAAA,EAAG;MAAA,IAAAK,MAAA;MAClB3G,UAAU,CAAC,YAAM;QACf,IAAI,CAAC2G,MAAI,CAACC,oBAAoB,CAAC,CAAC,EAAE;UAChCD,MAAI,CAACpP,QAAQ,CAAC;YAAEsE,YAAY,EAAE;UAAM,CAAC,CAAC;QACxC;MACF,CAAC,EAAE,CAAC,CAAC;IACP;EAAC;IAAA3B,GAAA;IAAAjE,KAAA,EAED,SAAA2Q,oBAAoBA,CAAA,EAAG;MACrB,IAAI,CAAC,IAAI,CAACxH,UAAU,EAAE,OAAO,KAAK;MAClC,IAAMD,cAAc,GAAG,IAAI,CAACC,UAAU;MACtC,IAAMgB,aAAa,GAAGtC,QAAQ,CAACsC,aAAa;MAE5C,OAAOjB,cAAc,IAAIA,cAAc,CAACmB,QAAQ,CAACF,aAAa,CAAC;IACjE;EAAC;IAAAlG,GAAA;IAAAjE,KAAA,EA6LD,SAAA4Q,iBAAiBA,CAAA,EAAG;MAAA,IAAAC,qBAAA;QAAAC,MAAA;MAClB;MACA,IAAI,CAACzQ,KAAK,CAAC0Q,KAAK,CAAC,IAAI,CAAC;MAEtBpG,MAAM,CAACO,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAACoF,QAAQ,CAAC;MAEhD,IAAMU,oBAAoB,IAAAH,qBAAA,GAAG,IAAI,CAACxQ,KAAK,CAACgJ,SAAS,cAAAwH,qBAAA,uBAApBA,qBAAA,CAAsBI,QAAQ,CAAC,sBAAsB,CAAC;MAEnF,IAAID,oBAAoB,IAAI,IAAI,CAACnL,MAAM,EAAE;QACvC,IAAMqL,kBAAkB,GAAGrJ,QAAQ,CAACiC,aAAa,gBAAA3J,MAAA,CAAe,IAAI,CAAC0F,MAAM,CAAC7F,KAAK,CAAC6H,QAAQ,CAAC5D,GAAG,QAAI,CAAC;QAEnG,IAAIiN,kBAAkB,EAAE;UACtBA,kBAAkB,CAACC,YAAY,CAAC,YAAY,EAAE,QAAQ,CAAC;QACzD;MACF;MAEA,IAAI,IAAI,CAACtL,MAAM,IAAI,IAAI,CAACxF,KAAK,CAAC+Q,SAAS,EAAE;QACvC1H,OAAO,CAACZ,OAAO,CAAC,CAAC,CAAC5C,IAAI,CAAC,YAAM;UAC3B,IAAI4K,MAAI,CAACjL,MAAM,EAAE;YACf,IAAMgE,SAAS,GAAGhC,QAAQ,CAACiC,aAAa,gBAAA3J,MAAA,CAAe2Q,MAAI,CAACjL,MAAM,CAAC7F,KAAK,CAAC6H,QAAQ,CAAC5D,GAAG,QAAI,CAAC;YAE1F6M,MAAI,CAACjL,MAAM,CAACe,KAAK,CAAC,CAAC;YAEnB,IAAIiD,SAAS,EAAE;cACbA,SAAS,CAACjD,KAAK,CAAC,CAAC;YACnB;UACF;QACF,CAAC,CAAC;MACJ;IACF;EAAC;IAAA3C,GAAA;IAAAjE,KAAA,EAED,SAAAqR,gCAAgCA,CAACC,SAAS,EAAE;MAAA,IAAAC,gBAAA,EAAAC,iBAAA;MAC1C,IAAAC,YAAA,GAAoC,IAAI,CAAC/P,KAAK;QAAtCjC,UAAU,GAAAgS,YAAA,CAAVhS,UAAU;QAAEF,WAAW,GAAAkS,YAAA,CAAXlS,WAAW;MAC/B,IAAMoC,cAAc,GAAGrC,iBAAiB,CAACgS,SAAS,CAAC/R,WAAW,EAAE+R,SAAS,CAAC9R,KAAK,EAAEC,UAAU,CAAC;MAE5F,IAAI,CAAC,IAAAiS,mBAAO,EAAC/P,cAAc,EAAEpC,WAAW,CAAC,EAAE;QACzC,IAAI,CAAC+B,QAAQ,CAAC;UACZ/B,WAAW,EAAEoC;QACf,CAAC,CAAC;MACJ;MAEA,IAAMgQ,uBAAuB,GAAG,CAAC,IAAAD,mBAAO,EAACJ,SAAS,CAAC9K,uBAAuB,EAAE,IAAI,CAACnG,KAAK,CAACmG,uBAAuB,CAAC;MAC/G,IAAMoL,oBAAoB,GAAG,CAAC,IAAAF,mBAAO,EAACJ,SAAS,CAACtO,aAAa,EAAE,IAAI,CAAC3C,KAAK,CAAC2C,aAAa,CAAC;MACxF,IAAM6O,gCAAgC,GACpC,CAAC,IAAAH,mBAAO,EAACJ,SAAS,CAACtM,aAAa,EAAE,IAAI,CAAC3E,KAAK,CAAC2E,aAAa,CAAC,IAC3D,CAAC,IAAA0M,mBAAO,EAACJ,SAAS,CAACrM,cAAc,EAAE,IAAI,CAAC5E,KAAK,CAAC4E,cAAc,CAAC;MAE/D,IAAI0M,uBAAuB,IAAIC,oBAAoB,IAAIC,gCAAgC,EAAE;QACvF,IAAI,CAAC3F,aAAa,CAACoF,SAAS,CAAC;MAC/B;MAEA,IAAI,GAAAC,gBAAA,GAACD,SAAS,CAACtR,KAAK,cAAAuR,gBAAA,gBAAAA,gBAAA,GAAfA,gBAAA,CAAiB1J,QAAQ,cAAA0J,gBAAA,eAAzBA,gBAAA,CAA2BO,MAAM,EAAAN,iBAAA,GAAC,IAAI,CAACnR,KAAK,CAACL,KAAK,cAAAwR,iBAAA,uBAAhBA,iBAAA,CAAkB3J,QAAQ,CAAC,GAAE;QAClE,IAAI,CAACvG,QAAQ,CAAC;UACZsF,KAAK,EAAE,KAAK;UACZ5G,KAAK,EAAEsR,SAAS,CAACtR;QACnB,CAAC,CAAC;MACJ;IACF;EAAC;IAAAiE,GAAA;IAAAjE,KAAA,EAED,SAAA+R,kBAAkBA,CAACC,SAAS,EAAExQ,SAAS,EAAE;MACvC;MACA;;MAEA;MACA;MACA;MACA,IACE,IAAI,CAACE,KAAK,CAACjC,UAAU,KAAK+B,SAAS,CAAC/B,UAAU,IAC7C,IAAI,CAACiC,KAAK,CAACjC,UAAU,IAAI,CAAC+B,SAAS,CAACC,kBAAkB,IAAI,IAAI,CAACC,KAAK,CAACD,kBAAmB,EACzF;QACA,IAAI,CAACyK,aAAa,CAAC,IAAI,CAAC7L,KAAK,CAAC;MAChC;MAEA,IAAM4R,YAAY,GAAGpK,QAAQ,CAACqK,gBAAgB,CAAC,6BAA6B,CAAC;MAE7EC,KAAK,CAACC,IAAI,CAACH,YAAY,CAAC,CAAC5T,OAAO,CAAC,UAACgU,EAAE,EAAK;QACvCA,EAAE,CAACzC,KAAK,CAACtP,QAAQ,GAAG,KAAK;QACzB+R,EAAE,CAACzC,KAAK,CAACC,OAAO,GAAG,cAAc;MACnC,CAAC,CAAC;IACJ;EAAC;IAAA5L,GAAA;IAAAjE,KAAA;IAsHD;AACF;AACA;IACE,SAAAsS,oBAAoBA,CAAA,EAAG;MACrB3H,MAAM,CAACL,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAACgG,QAAQ,CAAC;IACrD;EAAC;IAAArM,GAAA;IAAAjE,KAAA;IAsOD;IACA,SAAAI,cAAcA,CAAA,EAAG;MACf,OAAOA,eAAc,CAAC,IAAI,CAACC,KAAK,CAAC;IACnC;EAAC;IAAA4D,GAAA;IAAAjE,KAAA,EA8ID,SAAAuS,MAAMA,CAAA,EAAG;MAAA,IAAAC,MAAA;QAAAC,eAAA;MACP,IAAAC,WAAA,GASI,IAAI,CAACrS,KAAK;QARZsS,QAAQ,GAAAD,WAAA,CAARC,QAAQ;QACRC,UAAU,GAAAF,WAAA,CAAVE,UAAU;QACVC,cAAc,GAAAH,WAAA,CAAdG,cAAc;QACdxJ,SAAS,GAAAqJ,WAAA,CAATrJ,SAAS;QACTmG,WAAW,GAAAkD,WAAA,CAAXlD,WAAW;QACXpN,WAAW,GAAAsQ,WAAA,CAAXtQ,WAAW;QACX0Q,SAAS,GAAAJ,WAAA,CAATI,SAAS;QACTC,sBAAsB,GAAAL,WAAA,CAAtBK,sBAAsB;MAExB;MACA;MACA;MACA;MACA,IAAAC,KAAA,GAAmF5Q,WAAW,IAAI,CAAC,CAAC;QAA5FC,aAAa,GAAA2Q,KAAA,CAAb3Q,aAAa;QAAE4Q,cAAc,GAAAD,KAAA,CAAdC,cAAc;QAAEC,kBAAkB,GAAAF,KAAA,CAAlBE,kBAAkB;QAAKC,gBAAgB,OAAAC,yBAAA,aAAAJ,KAAA,EAAApX,SAAA;MAE9E,IAAAyX,YAAA,GAA+D,IAAI,CAAC3R,KAAK;QAAjE1B,KAAK,GAAAqT,YAAA,CAALrT,KAAK;QAAE2F,WAAW,GAAA0N,YAAA,CAAX1N,WAAW;QAAEpG,WAAW,GAAA8T,YAAA,CAAX9T,WAAW;QAAEgC,MAAM,GAAA8R,YAAA,CAAN9R,MAAM;QAAE4C,SAAS,GAAAkP,YAAA,CAATlP,SAAS;MAE1D1F,GAAG,CAAC,kBAAkB,EAAEuB,KAAK,CAAC;MAC9B,IAAMsT,SAAS,GAAG,IAAI,CAAClT,cAAc,CAAC,CAAC;MACvC,IAAMmT,iBAAiB,GAAG,IAAAC,sBAAU,EAClC;QACEC,MAAM,EAAEZ,cAAc;QACtBa,YAAY,EAAEnU,WAAW,CAACT,aAAa,IAAIS,WAAW,CAACX,QAAQ,KAAK,KAAK;QACzEuF,SAAS,EAAEA;MACb,CAAC,EACDkF,SACF,CAAC;MAED,oBACE9O,MAAA,YAAA0N,aAAA,CAAC0L,mBAAmB;QAClBzL,GAAG,EAAE,SAALA,GAAGA,CAAGA,KAAG;UAAA,OAAMsK,MAAI,CAACvI,UAAU,GAAG/B,KAAG;QAAA,CAAE;QACtC0H,KAAK,EAAE;UAAErP,KAAK,EAAE+S,SAAS,CAAC/S,KAAK;UAAED,QAAQ,EAAEgT,SAAS,CAAChT,QAAQ;UAAEE,QAAQ,EAAE8S,SAAS,CAAC9S;QAAS,CAAE;QAC9F6I,SAAS,EAAEkK,iBAAkB;QAC7BK,EAAE,YAAAzT,MAAA,CAAYH,KAAK,aAALA,KAAK,gBAAAyS,eAAA,GAALzS,KAAK,CAAE6H,QAAQ,cAAA4K,eAAA,uBAAfA,eAAA,CAAiBxO,GAAG;MAAG,GAEpCE,SAAS,iBAAI5J,MAAA,YAAA0N,aAAA,CAAC4L,sBAAsB,QAAC,oCAA0D,CAAC,eACjGtZ,MAAA,YAAA0N,aAAA,CAAC6L,iBAAiB;QAChBzK,SAAS,EAAE,IAAAmK,sBAAU,EACnB;UACEO,SAAS,EAAExU,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEwU,SAAS;UACjCC,aAAa,EAAEf,cAAc,IAAI,CAACA,cAAc,CAACN,QAAQ;UACzDsB,iBAAiB,EAAEf,kBAAkB,IAAI,CAACA,kBAAkB,CAACP;QAC/D,CACF;MAAE,gBAEFpY,MAAA,YAAA0N,aAAA,CAACvN,WAAA,CAAAmG,MAAW;QACVyB,OAAO,EAAE,IAAI,CAACA,OAAQ;QACtB4R,QAAQ,EAAE,SAAVA,QAAQA,CAAGlY,CAAC,EAAK;UACf,IAAIA,CAAC,EAAE;YACLwW,MAAI,CAAC2B,WAAW,GAAGnY,CAAC;UACtB;QACF,CAAE;QACFkM,GAAG,EAAE,SAALA,GAAGA,CAAGlM,CAAC;UAAA,OAAMwW,MAAI,CAAC3M,MAAM,GAAG7J,CAAC,IAAIwW,MAAI,CAACnS,KAAK,CAAC+T,SAAS,CAACpY,CAAC,CAAC;QAAA,CAAE;QACzDmN,UAAU,EAAE,SAAZA,UAAUA,CAAGnN,CAAC,EAAK;UACjB,IAAIA,CAAC,EAAE;YACLwW,MAAI,CAACrJ,UAAU,GAAGnN,CAAC;UACrB;QACF,CAAE;QACFuN,aAAa,EAAE,IAAI,CAACA,aAAc;QAClCvJ,KAAK,EAAEA,KAAM;QACb4F,YAAY,EAAE,IAAI,CAAClE,KAAK,CAACkE,YAAa;QACtCyO,cAAc,EAAE,IAAI,CAACjE,kBAAmB;QACxCkE,aAAa,EAAE,IAAI,CAACjE,iBAAkB;QACtCzJ,KAAK,EAAE,IAAI,CAACA,KAAM;QAClBkM,SAAS,EAAEA,SAAU;QACrB3P,QAAQ,EAAE,IAAI,CAACA,QAAS;QACxBoR,eAAe,EAAE,IAAI,CAACA,eAAgB;QACtCzR,MAAM,EAAE,IAAI,CAACA,MAAO;QACpB0R,MAAM,EAAE,SAARA,MAAMA,CAAGxL,KAAK,EAAEnD,MAAM;UAAA,OAAK2M,MAAI,CAACiC,WAAW,CAACzL,KAAK,EAAEnD,MAAM,EAAE,IAAI,CAAC;QAAA,CAAC;QACjE6O,OAAO,EAAE,SAATA,OAAOA,CAAG1L,KAAK,EAAEnD,MAAM;UAAA,OAAK2M,MAAI,CAACiC,WAAW,CAACzL,KAAK,EAAEnD,MAAM,CAAC;QAAA,CAAC;QAC5DjD,OAAO,EAAE,IAAI,CAACA,OAAQ;QACtB+B,aAAa,EAAE,IAAI,CAACA,aAAc;QAClCgB,WAAW,EAAEA,WAAY;QACzBgP,SAAS,EAAE,IAAI,CAACA,SAAU;QAC1BC,QAAQ,EAAEjC,QAAS;QACnBC,UAAU,EAAEA,UAAW;QACvBiC,WAAW,EAAEjC,UAAW;QACxBhD,KAAK,EAAA1R,aAAA;UACHuC,SAAS,EAAE6S,SAAS,CAAC7S,SAAS;UAC9BC,MAAM,EAAE4S,SAAS,CAAC5S,MAAM;UACxBC,SAAS,EAAE2S,SAAS,CAAC3S;QAAS,GAC3BoS,sBAAsB,CACzB;QACF3Q,WAAW,EAAE+Q,gBAAiB;QAC9B5T,WAAW,EAAEA,WAAY;QACzBiQ,WAAW,EAAEA,WAAY;QACzBsF,iBAAiB,EAAE,IAAI,CAACA,iBAAkB;QAC1CC,YAAY,EAAE,IAAI,CAACC;MAAW,CAC/B,CACgB,CAAC,eACpBza,MAAA,YAAA0N,aAAA,CAAC5M,YAAA,WAAW;QACV8F,IAAI,EAAEI,MAAM,CAACJ,IAAK;QAClBoH,KAAK,EAAEhH,MAAM,CAACgH,KAAM;QACpBvC,IAAI,EAAEzE,MAAM,CAACyE,IAAK;QAClB4C,OAAO,EAAErH,MAAM,CAACqH,OAAQ;QACxBF,SAAS,EAAEnH,MAAM,CAACmH,SAAU;QAC5BF,aAAa,EAAEjH,MAAM,CAACiH,aAAc;QACpCC,WAAW,EAAElH,MAAM,CAACkH;MAAY,CACjC,CACkB,CAAC;IAE1B;EAAC;AAAA,EA3gCyByH,iBAAK,CAAC+E,SAAS,GA8gC3C;AAAA,IAAA3W,gBAAA,aA9gCauC,MAAM,eACE;EACjBuQ,SAAS,EAAE8D,qBAAS,CAACC,IAAI;EACzBf,SAAS,EAAEc,qBAAS,CAACE,IAAI,CAACC,UAAU;EACpC7V,KAAK,EAAE0V,qBAAS,CAACI,GAAG;EACpBvE,KAAK,EAAEmE,qBAAS,CAACE,IAAI,CAACC,UAAU;EAChClS,QAAQ,EAAE+R,qBAAS,CAACE,IAAI,CAACC,UAAU;EACnCzS,OAAO,EAAEsS,qBAAS,CAACE,IAAI;EACvBtS,MAAM,EAAEoS,qBAAS,CAACE,IAAI;EACtBtC,SAAS,EAAEoC,qBAAS,CAACE,IAAI;EACzBxO,KAAK,EAAEsO,qBAAS,CAACE,IAAI,CAACC,UAAU;EAChCrV,KAAK,EAAEuV,0BAAU,CAACvV,KAAK,CAACqV,UAAU;EAClC5R,YAAY,EAAEyR,qBAAS,CAAC/I,MAAM;EAC9BnJ,aAAa,EAAEkS,qBAAS,CAACM,KAAK,CAAC;IAC7BxO,SAAS,EAAEkO,qBAAS,CAACC,IAAI;IACzBlO,UAAU,EAAEiO,qBAAS,CAACC;EACxB,CAAC,CAAC;EACF5R,4BAA4B,EAAE2R,qBAAS,CAACC,IAAI;EAC5CpO,kBAAkB,EAAEmO,qBAAS,CAACM,KAAK,CAAC;IAClC1Q,GAAG,EAAEoQ,qBAAS,CAACE,IAAI;IACnB,UAAQF,qBAAS,CAACE;EACpB,CAAC,CAAC;EACFpJ,eAAe,EAAEkJ,qBAAS,CAACO,MAAM;EACjClV,KAAK,EAAE2U,qBAAS,CAACQ,SAAS,CAAC,CAACR,qBAAS,CAACS,MAAM,EAAET,qBAAS,CAACO,MAAM,CAAC,CAAC;EAChEnV,QAAQ,EAAE4U,qBAAS,CAACQ,SAAS,CAAC,CAACR,qBAAS,CAACS,MAAM,EAAET,qBAAS,CAACO,MAAM,CAAC,CAAC;EACnEjV,QAAQ,EAAE0U,qBAAS,CAACQ,SAAS,CAAC,CAACR,qBAAS,CAACS,MAAM,EAAET,qBAAS,CAACO,MAAM,CAAC,CAAC;EACnE/U,MAAM,EAAEwU,qBAAS,CAACQ,SAAS,CAAC,CAACR,qBAAS,CAACS,MAAM,EAAET,qBAAS,CAACO,MAAM,CAAC,CAAC;EACjEhV,SAAS,EAAEyU,qBAAS,CAACQ,SAAS,CAAC,CAACR,qBAAS,CAACS,MAAM,EAAET,qBAAS,CAACO,MAAM,CAAC,CAAC;EACpE9U,SAAS,EAAEuU,qBAAS,CAACQ,SAAS,CAAC,CAACR,qBAAS,CAACS,MAAM,EAAET,qBAAS,CAACO,MAAM,CAAC,CAAC;EACpE1C,sBAAsB,EAAEmC,qBAAS,CAAC/I,MAAM;EACxC0G,cAAc,EAAEqC,qBAAS,CAACC,IAAI;EAC9BxC,QAAQ,EAAEuC,qBAAS,CAACC,IAAI;EACxBvC,UAAU,EAAEsC,qBAAS,CAACC,IAAI;EAC1B1P,QAAQ,EAAEyP,qBAAS,CAACC,IAAI;EACxBhQ,gBAAgB,EAAE+P,qBAAS,CAACC,IAAI;EAChC/P,gBAAgB,EAAE8P,qBAAS,CAACC,IAAI;EAChC7P,gBAAgB,EAAE4P,qBAAS,CAACC,IAAI;EAChC/S,WAAW,EAAE8S,qBAAS,CAACI,GAAG;EAC1B;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA9F,WAAW,EAAE0F,qBAAS,CAACS,MAAM;EAC7BC,QAAQ,EAAEV,qBAAS,CAACC,IAAI;EACxBtT,iBAAiB,EAAEqT,qBAAS,CAACM,KAAK,CAAC;IACjCnP,IAAI,EAAE6O,qBAAS,CAACW,KAAK,CAAC,CACpB,+BAA+B,EAC/B,iBAAiB,EACjB,mBAAmB,EACnB,gBAAgB,CACjB,CAAC;IACF3W,OAAO,EAAEgW,qBAAS,CAAC/I,MAAM;IACzBhN,eAAe,EAAE+V,qBAAS,CAACE,IAAI;IAC/BhW,kBAAkB,EAAE8V,qBAAS,CAACE,IAAI;IAClC9O,gBAAgB,EAAE4O,qBAAS,CAACO,MAAM;IAClCjW,KAAK,EAAE0V,qBAAS,CAACI;EACnB,CAAC,CAAC;EACFjS,aAAa,EAAE6R,qBAAS,CAACM,KAAK,CAAC;IAC7BM,KAAK,EAAEZ,qBAAS,CAACa,OAAO,CAACb,qBAAS,CAACS,MAAM,CAAC;IAC1CK,KAAK,EAAEd,qBAAS,CAACS;EACnB,CAAC,CAAC;EACFnP,uBAAuB,EAAE0O,qBAAS,CAACa,OAAO,CACxCb,qBAAS,CAACM,KAAK,CAAC;IACdS,QAAQ,EAAEf,qBAAS,CAACS,MAAM;IAC1BO,aAAa,EAAEhB,qBAAS,CAACS,MAAM;IAC/BQ,UAAU,EAAEjB,qBAAS,CAACa,OAAO,CAACb,qBAAS,CAACa,OAAO,CAACb,qBAAS,CAACS,MAAM,CAAC;EACnE,CAAC,CACH,CAAC;EACDzO,wBAAwB,EAAEgO,qBAAS,CAACE,IAAI;EACxC7V,WAAW,EAAE2V,qBAAS,CAACM,KAAK,CAAC;IAC3B5W,QAAQ,EAAEsW,qBAAS,CAACW,KAAK,CAAC,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IAC5ChX,SAAS,EAAEqW,qBAAS,CAACW,KAAK,CAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC7C/W,aAAa,EAAEoW,qBAAS,CAACC,IAAI;IAC7BpW,QAAQ,EAAEmW,qBAAS,CAACC,IAAI;IACxBnW,MAAM,EAAEkW,qBAAS,CAACS,MAAM;IACxBrV,QAAQ,EAAE4U,qBAAS,CAACQ,SAAS,CAAC,CAACR,qBAAS,CAACS,MAAM,EAAET,qBAAS,CAACO,MAAM,CAAC;EACpE,CAAC,CAAC;EACFjT,aAAa,EAAE0S,qBAAS,CAACa,OAAO,CAAC,UAACK,MAAM,EAAK;IAC3C,IAAMC,QAAQ,GAAGD,MAAM,CAACE,KAAK,CAAC,UAAC3W,CAAC;MAAA,OAAK4W,oBAAW,CAACtF,QAAQ,CAACtR,CAAC,CAAC;IAAA,EAAC;IAE7D,OAAO,CAAC0W,QAAQ,IAAI,IAAIG,KAAK,oBAAArW,MAAA,CAAoBiW,MAAM,+BAAAjW,MAAA,CAA4BoW,oBAAW,CAACE,IAAI,CAAC,GAAG,CAAC,MAAG,CAAC;EAC9G,CAAC,CAAC;EACFpN,SAAS,EAAE6L,qBAAS,CAACS,MAAM;EAC3B3Q,aAAa,EAAEkQ,qBAAS,CAACO,MAAM;EAC/BxQ,cAAc,EAAEiQ,qBAAS,CAACO;AAC5B,CAAC;AAAA,IAAAnX,gBAAA,aA1FUuC,MAAM,kBA4FK;EACpBuE,gBAAgB,EAAE,IAAI;EACtBxC,OAAO,EAAE,SAATA,OAAOA,CAAA,EAAQ,CAAE,CAAC;EAClBE,MAAM,EAAE,SAARA,MAAMA,CAAA,EAAQ,CAAE,CAAC;EACjBgQ,SAAS,EAAE,SAAXA,SAASA,CAAA,EAAQ,CAAE,CAAC;EACpB5L,wBAAwB,EAAE,SAA1BA,wBAAwBA,CAAA,EAAQ,CAAE,CAAC;EACnClE,aAAa,EAAE;IACbgE,SAAS,EAAE,KAAK;IAChBC,UAAU,EAAE;EACd,CAAC;EACD1H,WAAW,EAAEZ,kBAAkB;EAC/BkD,iBAAiB,EAAE5C,wBAAwB;EAC3CuH,uBAAuB,EAAEnH,8BAA8B;EACvDgE,aAAa,EAAE,IAAI;EACnBuS,QAAQ,EAAE;AACZ,CAAC;AAo6BH,IAAMjC,mBAAmB,GAAG,IAAA+C,cAAM,EAAC,KAAK,CAAC,CAAC;EAAA,OAAO;IAC/C,UAAU,EAAE;MACVC,eAAe,EAAE;IACnB,CAAC;IACD,aAAa,EAAE;MACb5G,OAAO,EAAE,GAAG;MACZC,aAAa,EAAE,MAAM;MACrBpR,QAAQ,EAAE;IACZ,CAAC;IACD,gBAAgB,EAAE;MAChBgY,SAAS,EAAE;IACb;EACF,CAAC;AAAA,CAAC,CAAC;AAEH,IAAM/C,sBAAsB,GAAG,IAAA6C,cAAM,EAAC,KAAK,CAAC,CAAC;EAC3C9X,QAAQ,EAAE,UAAU;EACpBiY,GAAG,EAAE,KAAK;EACVC,IAAI,EAAE,KAAK;EACXC,SAAS,EAAE;AACb,CAAC,CAAC;AAEF,IAAMjD,iBAAiB,GAAG,IAAA4C,cAAM,EAAC,KAAK,CAAC,CAAC;EAAA,OAAO;IAC7C,SAAS,EAAE;MACTM,WAAW,EAAE,OAAO;MACpBzW,KAAK,EAAE,MAAM;MACb0W,cAAc,EAAE,UAAU;MAC1BC,KAAK,EAAEA,eAAK,CAAClR,IAAI,CAAC,CAAC;MACnB2Q,eAAe,EAAEO,eAAK,CAACC,UAAU,CAAC;IACpC,CAAC;IACD,8BAA8B,EAAE;MAC9BC,SAAS,EAAE;MACX;MACA;MACA;MACA;IACF,CAAC;IACD,UAAU,EAAE;MACVC,OAAO,EAAE,UAAU;MACnBpU,SAAS,EAAE;IACb,CAAC;IACD,kCAAkC,EAAE;MAClCqU,MAAM,EAAE;IACV,CAAC;IACD,iBAAiB,EAAE;MACjB;MACA,2BAA2B,EAAE;QAC3BzH,OAAO,EAAE,OAAO;QAChB0H,OAAO,EAAE,KAAK;QACdC,QAAQ,EAAE,KAAK;QACfN,KAAK,EAAE;MACT;IACF,CAAC;IACD,qBAAqB,EAAE;MACrB;MACA,oBAAoB,EAAE;QACpBO,YAAY,EAAE;MAChB;IACF,CAAC;IACD,aAAa,EAAE;MACbJ,OAAO,EAAE;IACX;EACF,CAAC;AAAA,CAAC,CAAC;AAEH,IAAMjP,iBAAiB,GAAG,IAAAsO,cAAM,EAAC,KAAK,CAAC,CAAC;EACtCe,YAAY,EAAE,MAAM;EACpBb,SAAS,EAAE,KAAK;EAChBS,OAAO,EAAE,MAAM;EACfV,eAAe,EAAE;AACnB,CAAC,CAAC;AAAC,IAAAe,QAAA,GAAAjc,OAAA,cAEYoF,MAAM","ignoreList":[]}
|