@pie-lib/editable-html-tip-tap 1.0.5 → 1.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (112) hide show
  1. package/lib/constants.js +2 -5
  2. package/package.json +1 -1
  3. package/src/constants.js +0 -2
  4. package/lib/__tests__/editor.test.js +0 -470
  5. package/lib/__tests__/serialization.test.js +0 -246
  6. package/lib/block-tags.js +0 -25
  7. package/lib/components/CharacterPicker.js.map +0 -1
  8. package/lib/components/EditableHtml.js.map +0 -1
  9. package/lib/components/MenuBar.js.map +0 -1
  10. package/lib/components/TiptapContainer.js.map +0 -1
  11. package/lib/components/buttons/done-button.js +0 -53
  12. package/lib/components/characters/characterUtils.js.map +0 -1
  13. package/lib/components/characters/custom-popper.js.map +0 -1
  14. package/lib/components/common/done-button.js.map +0 -1
  15. package/lib/components/common/toolbar-buttons.js.map +0 -1
  16. package/lib/components/icons/CssIcon.js.map +0 -1
  17. package/lib/components/icons/RespArea.js.map +0 -1
  18. package/lib/components/icons/TableIcons.js.map +0 -1
  19. package/lib/components/icons/TextAlign.js.map +0 -1
  20. package/lib/components/icons/index.js +0 -194
  21. package/lib/components/image/AltDialog.js.map +0 -1
  22. package/lib/components/image/ImageToolbar.js.map +0 -1
  23. package/lib/components/image/InsertImageHandler.js.map +0 -1
  24. package/lib/components/image/alt-dialog.js +0 -2
  25. package/lib/components/media/MediaDialog.js.map +0 -1
  26. package/lib/components/media/MediaToolbar.js.map +0 -1
  27. package/lib/components/media/MediaWrapper.js.map +0 -1
  28. package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js.map +0 -1
  29. package/lib/components/respArea/DragInTheBlank/choice.js.map +0 -1
  30. package/lib/components/respArea/DragInTheBlank.js +0 -94
  31. package/lib/components/respArea/ExplicitConstructedResponse.js.map +0 -1
  32. package/lib/components/respArea/InlineDropdown.js.map +0 -1
  33. package/lib/components/respArea/ToolbarIcon.js.map +0 -1
  34. package/lib/components/respArea/choice.js +0 -2
  35. package/lib/constants.js.map +0 -1
  36. package/lib/editor.js +0 -1356
  37. package/lib/extensions/MediaView.js +0 -112
  38. package/lib/extensions/characters.js +0 -65
  39. package/lib/extensions/component.js.map +0 -1
  40. package/lib/extensions/css.js.map +0 -1
  41. package/lib/extensions/custom-toolbar-wrapper.js.map +0 -1
  42. package/lib/extensions/extended-table.js.map +0 -1
  43. package/lib/extensions/image.js.map +0 -1
  44. package/lib/extensions/index.js.map +0 -1
  45. package/lib/extensions/math.js.map +0 -1
  46. package/lib/extensions/media.js.map +0 -1
  47. package/lib/extensions/responseArea.js.map +0 -1
  48. package/lib/index.js.map +0 -1
  49. package/lib/old-index.js +0 -269
  50. package/lib/parse-html.js +0 -16
  51. package/lib/plugins/characters/custom-popper.js +0 -73
  52. package/lib/plugins/characters/index.js +0 -305
  53. package/lib/plugins/characters/utils.js +0 -381
  54. package/lib/plugins/css/icons/index.js +0 -37
  55. package/lib/plugins/css/index.js +0 -390
  56. package/lib/plugins/customPlugin/index.js +0 -114
  57. package/lib/plugins/html/icons/index.js +0 -38
  58. package/lib/plugins/html/index.js +0 -81
  59. package/lib/plugins/image/__tests__/component.test.js +0 -51
  60. package/lib/plugins/image/__tests__/image-toolbar-logic.test.js +0 -56
  61. package/lib/plugins/image/__tests__/image-toolbar.test.js +0 -26
  62. package/lib/plugins/image/__tests__/index.test.js +0 -98
  63. package/lib/plugins/image/__tests__/insert-image-handler.test.js +0 -125
  64. package/lib/plugins/image/__tests__/mock-change.js +0 -25
  65. package/lib/plugins/image/alt-dialog.js +0 -129
  66. package/lib/plugins/image/component.js +0 -419
  67. package/lib/plugins/image/image-toolbar.js +0 -177
  68. package/lib/plugins/image/index.js +0 -263
  69. package/lib/plugins/image/insert-image-handler.js +0 -117
  70. package/lib/plugins/index.js +0 -341
  71. package/lib/plugins/list/__tests__/index.test.js +0 -79
  72. package/lib/plugins/list/index.js +0 -334
  73. package/lib/plugins/math/__tests__/index.test.js +0 -300
  74. package/lib/plugins/math/index.js +0 -454
  75. package/lib/plugins/media/__tests__/index.test.js +0 -71
  76. package/lib/plugins/media/index.js +0 -387
  77. package/lib/plugins/media/media-dialog.js +0 -709
  78. package/lib/plugins/media/media-toolbar.js +0 -101
  79. package/lib/plugins/media/media-wrapper.js +0 -93
  80. package/lib/plugins/rendering/index.js +0 -46
  81. package/lib/plugins/respArea/drag-in-the-blank/choice.js +0 -289
  82. package/lib/plugins/respArea/drag-in-the-blank/index.js +0 -94
  83. package/lib/plugins/respArea/explicit-constructed-response/index.js +0 -120
  84. package/lib/plugins/respArea/icons/index.js +0 -95
  85. package/lib/plugins/respArea/index.js +0 -341
  86. package/lib/plugins/respArea/inline-dropdown/index.js +0 -126
  87. package/lib/plugins/respArea/math-templated/index.js +0 -130
  88. package/lib/plugins/respArea/utils.js +0 -125
  89. package/lib/plugins/table/CustomTablePlugin.js +0 -133
  90. package/lib/plugins/table/__tests__/index.test.js +0 -442
  91. package/lib/plugins/table/__tests__/table-toolbar.test.js +0 -54
  92. package/lib/plugins/table/icons/index.js +0 -69
  93. package/lib/plugins/table/index.js +0 -483
  94. package/lib/plugins/table/table-toolbar.js +0 -187
  95. package/lib/plugins/textAlign/icons/index.js +0 -194
  96. package/lib/plugins/textAlign/index.js +0 -34
  97. package/lib/plugins/toolbar/__tests__/default-toolbar.test.js +0 -128
  98. package/lib/plugins/toolbar/__tests__/editor-and-toolbar.test.js +0 -51
  99. package/lib/plugins/toolbar/__tests__/toolbar-buttons.test.js +0 -54
  100. package/lib/plugins/toolbar/__tests__/toolbar.test.js +0 -120
  101. package/lib/plugins/toolbar/default-toolbar.js +0 -229
  102. package/lib/plugins/toolbar/done-button.js +0 -53
  103. package/lib/plugins/toolbar/editor-and-toolbar.js +0 -286
  104. package/lib/plugins/toolbar/index.js +0 -34
  105. package/lib/plugins/toolbar/toolbar-buttons.js +0 -194
  106. package/lib/plugins/toolbar/toolbar.js +0 -376
  107. package/lib/plugins/utils.js +0 -62
  108. package/lib/serialization.js +0 -677
  109. package/lib/shared/alert-dialog.js +0 -75
  110. package/lib/styles/editorContainerStyles.js.map +0 -1
  111. package/lib/theme.js.map +0 -1
  112. package/lib/utils/size.js.map +0 -1
package/lib/editor.js DELETED
@@ -1,1356 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
- Object.defineProperty(exports, "__esModule", {
8
- value: true
9
- });
10
- Object.defineProperty(exports, "ALL_PLUGINS", {
11
- enumerable: true,
12
- get: function get() {
13
- return _plugins.ALL_PLUGINS;
14
- }
15
- });
16
- Object.defineProperty(exports, "DEFAULT_PLUGINS", {
17
- enumerable: true,
18
- get: function get() {
19
- return _plugins.DEFAULT_PLUGINS;
20
- }
21
- });
22
- exports.serialization = exports["default"] = exports.Editor = void 0;
23
-
24
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
25
-
26
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
27
-
28
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
29
-
30
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
31
-
32
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
33
-
34
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
35
-
36
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
37
-
38
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
39
-
40
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
41
-
42
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
43
-
44
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
45
-
46
- var _react = _interopRequireDefault(require("react"));
47
-
48
- var _slateReact = require("slate-react");
49
-
50
- var _slatePropTypes = _interopRequireDefault(require("slate-prop-types"));
51
-
52
- var _slate = require("slate");
53
-
54
- var _slatePlainSerializer = _interopRequireDefault(require("slate-plain-serializer"));
55
-
56
- var _propTypes = _interopRequireDefault(require("prop-types"));
57
-
58
- var _debounce = _interopRequireDefault(require("lodash/debounce"));
59
-
60
- var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
61
-
62
- var _classnames = _interopRequireDefault(require("classnames"));
63
-
64
- var _debug = _interopRequireDefault(require("debug"));
65
-
66
- var _styles = require("@material-ui/core/styles");
67
-
68
- var _renderUi = require("@pie-lib/render-ui");
69
-
70
- var _alertDialog = _interopRequireDefault(require("./shared/alert-dialog"));
71
-
72
- var serialization = _interopRequireWildcard(require("./serialization"));
73
-
74
- exports.serialization = serialization;
75
-
76
- var _insertImageHandler = _interopRequireDefault(require("./plugins/image/insert-image-handler"));
77
-
78
- var _plugins = require("./plugins");
79
-
80
- var _excluded = ["customPlugins", "showParagraphs", "separateParagraphs"];
81
-
82
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
83
-
84
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
85
-
86
- function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
87
-
88
- function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
89
-
90
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
91
-
92
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
93
-
94
- var log = (0, _debug["default"])('editable-html:editor');
95
- var defaultToolbarOpts = {
96
- position: 'bottom',
97
- alignment: 'left',
98
- alwaysVisible: false,
99
- showDone: true,
100
- doneOn: 'blur'
101
- };
102
- var defaultResponseAreaProps = {
103
- options: {},
104
- respAreaToolbar: function respAreaToolbar() {},
105
- onHandleAreaChange: function onHandleAreaChange() {}
106
- };
107
- var defaultLanguageCharactersProps = [];
108
-
109
- var createToolbarOpts = function createToolbarOpts(toolbarOpts, error, isHtmlMode) {
110
- return _objectSpread(_objectSpread(_objectSpread({}, defaultToolbarOpts), toolbarOpts), {}, {
111
- error: error,
112
- isHtmlMode: isHtmlMode
113
- });
114
- };
115
- /**
116
- * The maximum number of characters the editor can support
117
- * @type {number}
118
- */
119
-
120
-
121
- var MAX_CHARACTERS_LIMIT = 1000000;
122
-
123
- var Editor = /*#__PURE__*/function (_React$Component) {
124
- (0, _inherits2["default"])(Editor, _React$Component);
125
-
126
- var _super = _createSuper(Editor);
127
-
128
- function Editor(_props) {
129
- var _this;
130
-
131
- (0, _classCallCheck2["default"])(this, Editor);
132
- _this = _super.call(this, _props);
133
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "setKeypadInteraction", function (interacted) {
134
- _this.keypadInteractionDetected = interacted;
135
- });
136
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["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
-
140
- _this.setState({
141
- dialog: _objectSpread({
142
- open: open
143
- }, extraDialogProps)
144
- }, callback);
145
- });
146
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "toggleHtmlMode", function () {
147
- _this.setState(function (prevState) {
148
- return {
149
- isHtmlMode: !prevState.isHtmlMode,
150
- isEditedInHtmlMode: false
151
- };
152
- }, function () {
153
- var error = _this.props.error;
154
- var toolbarOpts = _this.state.toolbarOpts;
155
- var newToolbarOpts = createToolbarOpts(toolbarOpts, error, _this.state.isHtmlMode);
156
-
157
- _this.setState({
158
- toolbarOpts: newToolbarOpts
159
- });
160
- });
161
- });
162
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handlePlugins", function (props) {
163
- var normalizedResponseAreaProps = _objectSpread(_objectSpread({}, defaultResponseAreaProps), props.responseAreaProps);
164
-
165
- var htmlPluginOpts = {
166
- currentValue: _this.props.value,
167
- isHtmlMode: _this.state.isHtmlMode,
168
- isEditedInHtmlMode: _this.state.isEditedInHtmlMode,
169
- toggleHtmlMode: _this.toggleHtmlMode,
170
- handleAlertDialog: _this.handleDialog
171
- };
172
-
173
- var _ref = props.pluginProps || {},
174
- customPlugins = _ref.customPlugins;
175
-
176
- customPlugins = customPlugins || [];
177
- _this.plugins = (0, _plugins.buildPlugins)(props.activePlugins, customPlugins, {
178
- math: _objectSpread({
179
- onClick: _this.onMathClick,
180
- onFocus: _this.onPluginFocus,
181
- onBlur: _this.onPluginBlur
182
- }, props.mathMlOptions),
183
- textAlign: {
184
- getValue: function getValue() {
185
- return _this.state.value;
186
- },
187
- onChange: _this.onChange
188
- },
189
- html: htmlPluginOpts,
190
- extraCSSRules: props.extraCSSRules || {},
191
- image: {
192
- disableImageAlignmentButtons: props.disableImageAlignmentButtons,
193
- onDelete: props.imageSupport && props.imageSupport["delete"] && function (node, done) {
194
- var src = node.data.get('src');
195
- props.imageSupport["delete"](src, function (e) {
196
- var newPendingImages = _this.state.pendingImages.filter(function (img) {
197
- return img.key !== node.key;
198
- });
199
-
200
- var oldScheduled = _this.state.scheduled;
201
- var newState = {
202
- pendingImages: newPendingImages,
203
- scheduled: oldScheduled && newPendingImages.length === 0 ? false : oldScheduled
204
- };
205
-
206
- _this.setState(newState, function () {
207
- return done(e, _this.state.value);
208
- });
209
- });
210
- },
211
- insertImageRequested: props.imageSupport && function (addedImage, getHandler) {
212
- var pendingImages = _this.state.pendingImages;
213
-
214
- var onFinish = function onFinish(result) {
215
- var cb;
216
-
217
- if (_this.state.scheduled && result) {
218
- // finish editing only on success
219
- cb = _this.onEditingDone.bind((0, _assertThisInitialized2["default"])(_this));
220
- }
221
-
222
- var newPendingImages = _this.state.pendingImages.filter(function (img) {
223
- return img.key !== addedImage.key;
224
- });
225
-
226
- var newState = {
227
- pendingImages: newPendingImages
228
- };
229
-
230
- if (newPendingImages.length === 0) {
231
- newState.scheduled = false;
232
- }
233
-
234
- _this.setState(newState, cb);
235
- };
236
-
237
- var callback = function callback() {
238
- /**
239
- * The handler is the object through which the outer context
240
- * communicates file upload events like: fileChosen, cancel, progress
241
- */
242
- var handler = getHandler(onFinish, function () {
243
- return _this.state.value;
244
- });
245
- props.imageSupport.add(handler);
246
- };
247
-
248
- _this.setState({
249
- pendingImages: [].concat((0, _toConsumableArray2["default"])(pendingImages), [addedImage])
250
- }, callback);
251
- },
252
- onFocus: _this.onPluginFocus,
253
- onBlur: _this.onPluginBlur,
254
- maxImageWidth: props.maxImageWidth,
255
- maxImageHeight: props.maxImageHeight
256
- },
257
- toolbar: {
258
- /**
259
- * To minimize converting html -> state -> html
260
- * We only emit markup once 'done' is clicked.
261
- */
262
- disableScrollbar: !!props.disableScrollbar,
263
- disableUnderline: props.disableUnderline,
264
- autoWidth: props.autoWidthToolbar,
265
- onDone: function onDone() {
266
- var _this$state$value$sta, _this$state$value$sta2;
267
-
268
- var nonEmpty = props.nonEmpty;
269
- log('[onDone]');
270
-
271
- _this.setState({
272
- toolbarInFocus: false,
273
- focusedNode: null,
274
- focusToolbar: false
275
- });
276
-
277
- _this.editor.blur();
278
-
279
- if (nonEmpty && ((_this$state$value$sta = _this.state.value.startText) === null || _this$state$value$sta === void 0 ? void 0 : (_this$state$value$sta2 = _this$state$value$sta.text) === null || _this$state$value$sta2 === void 0 ? void 0 : _this$state$value$sta2.length) === 0) {
280
- _this.resetValue(true).then(function () {
281
- _this.onEditingDone();
282
- });
283
- } else {
284
- _this.onEditingDone();
285
- }
286
- }
287
- },
288
- table: {
289
- onFocus: function onFocus() {
290
- log('[table:onFocus]...');
291
-
292
- _this.onPluginFocus();
293
- },
294
- onBlur: function onBlur() {
295
- log('[table:onBlur]...');
296
-
297
- _this.onPluginBlur();
298
- }
299
- },
300
- responseArea: {
301
- type: normalizedResponseAreaProps.type,
302
- options: normalizedResponseAreaProps.options,
303
- maxResponseAreas: normalizedResponseAreaProps.maxResponseAreas,
304
- respAreaToolbar: normalizedResponseAreaProps.respAreaToolbar,
305
- onHandleAreaChange: normalizedResponseAreaProps.onHandleAreaChange,
306
- error: normalizedResponseAreaProps.error,
307
- onFocus: function onFocus() {
308
- log('[table:onFocus]...');
309
-
310
- _this.onPluginFocus();
311
- },
312
- onBlur: function onBlur() {
313
- log('[table:onBlur]...');
314
-
315
- _this.onPluginBlur();
316
- }
317
- },
318
- languageCharacters: props.languageCharactersProps,
319
- keyPadCharacterRef: _this.keyPadCharacterRef,
320
- setKeypadInteraction: _this.setKeypadInteraction,
321
- media: {
322
- focus: _this.focus,
323
- createChange: function createChange() {
324
- return _this.state.value.change();
325
- },
326
- onChange: _this.onChange,
327
- uploadSoundSupport: props.uploadSoundSupport
328
- }
329
- });
330
-
331
- if (props.mathMlOptions.mmlOutput || props.mathMlOptions.mmlEditing) {
332
- _this.props.runSerializationOnMarkup();
333
- }
334
- });
335
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onPluginBlur", function (e) {
336
- log('[onPluginBlur]', e && e.relatedTarget);
337
- var target = e && e.relatedTarget;
338
- var node = target ? (0, _slateReact.findNode)(target, _this.state.value) : null;
339
- log('[onPluginBlur] node: ', node);
340
-
341
- _this.setState({
342
- focusedNode: node
343
- }, function () {
344
- _this.resetValue();
345
- });
346
- });
347
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onPluginFocus", function (e) {
348
- log('[onPluginFocus]', e && e.target);
349
- var target = e && e.target;
350
-
351
- if (target) {
352
- var node = (0, _slateReact.findNode)(target, _this.state.value);
353
- log('[onPluginFocus] node: ', node);
354
- var stashedValue = _this.state.stashedValue || _this.state.value;
355
-
356
- _this.setState({
357
- focusedNode: node,
358
- stashedValue: stashedValue
359
- });
360
- } else {
361
- _this.setState({
362
- focusedNode: null
363
- });
364
- }
365
-
366
- _this.stashValue();
367
- });
368
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onMathClick", function (node) {
369
- _this.editor.change(function (c) {
370
- return c.collapseToStartOf(node);
371
- });
372
-
373
- _this.setState({
374
- selectedNode: node
375
- });
376
- });
377
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onEditingDone", function () {
378
- var _this$state = _this.state,
379
- isHtmlMode = _this$state.isHtmlMode,
380
- dialog = _this$state.dialog,
381
- value = _this$state.value,
382
- pendingImages = _this$state.pendingImages; // Handling HTML mode and dialog state
383
-
384
- if (isHtmlMode) {
385
- // Early return if HTML mode is enabled
386
- if (dialog !== null && dialog !== void 0 && dialog.open) return;
387
- var currentValue = (0, serialization.htmlToValue)(value.document.text);
388
-
389
- var previewText = _this.renderHtmlPreviewContent();
390
-
391
- _this.openHtmlModeConfirmationDialog(currentValue, previewText);
392
-
393
- return;
394
- }
395
-
396
- if (pendingImages.length) {
397
- // schedule image processing
398
- _this.setState({
399
- scheduled: true
400
- });
401
-
402
- return;
403
- } // Finalizing editing
404
-
405
-
406
- log('[onEditingDone]');
407
-
408
- _this.setState({
409
- pendingImages: [],
410
- stashedValue: null,
411
- focusedNode: null
412
- });
413
-
414
- log('[onEditingDone] value: ', _this.state.value);
415
-
416
- _this.props.onChange(_this.state.value, true);
417
- });
418
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "renderHtmlPreviewContent", function () {
419
- var classes = _this.props.classes;
420
- return /*#__PURE__*/_react["default"].createElement("div", {
421
- ref: function ref(_ref2) {
422
- return _this.elementRef = _ref2;
423
- }
424
- }, /*#__PURE__*/_react["default"].createElement("div", null, "Preview of Edited Html:"), /*#__PURE__*/_react["default"].createElement(_renderUi.PreviewPrompt, {
425
- defaultClassName: classes.previewText,
426
- prompt: _this.state.value.document.text
427
- }), /*#__PURE__*/_react["default"].createElement("div", null, "Would you like to save these changes ?"));
428
- });
429
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "openHtmlModeConfirmationDialog", function (currentValue, previewText) {
430
- _this.setState({
431
- dialog: {
432
- open: true,
433
- title: 'Content Preview & Save',
434
- text: previewText,
435
- onConfirmText: 'Save changes',
436
- onCloseText: 'Continue editing',
437
- onConfirm: function onConfirm() {
438
- _this.handleHtmlModeSaveConfirmation(currentValue);
439
- },
440
- onClose: _this.htmlModeContinueEditing
441
- }
442
- });
443
- });
444
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleHtmlModeSaveConfirmation", function (currentValue) {
445
- _this.setState({
446
- value: currentValue
447
- });
448
-
449
- _this.props.onChange(currentValue, true);
450
-
451
- _this.handleDialog(false);
452
-
453
- _this.toggleHtmlMode();
454
- });
455
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "htmlModeContinueEditing", function () {
456
- _this.handleDialog(false);
457
- });
458
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleBlur", function (resolve) {
459
- var nonEmpty = _this.props.nonEmpty;
460
- var doneOn = _this.state.toolbarOpts.doneOn;
461
-
462
- _this.setState({
463
- toolbarInFocus: false,
464
- focusedNode: null
465
- });
466
-
467
- if (_this.editor) {
468
- _this.editor.blur();
469
- }
470
-
471
- if (doneOn === 'blur') {
472
- var _this$state$value$sta3, _this$state$value$sta4;
473
-
474
- if (nonEmpty && ((_this$state$value$sta3 = _this.state.value.startText) === null || _this$state$value$sta3 === void 0 ? void 0 : (_this$state$value$sta4 = _this$state$value$sta3.text) === null || _this$state$value$sta4 === void 0 ? void 0 : _this$state$value$sta4.length) === 0) {
475
- _this.resetValue(true).then(function () {
476
- _this.onEditingDone();
477
-
478
- resolve();
479
- });
480
- } else {
481
- _this.onEditingDone();
482
-
483
- resolve();
484
- }
485
- }
486
- });
487
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onBlur", function (event) {
488
- var _this$doneButtonRef$c;
489
-
490
- log('[onBlur]');
491
- var relatedTarget = event.relatedTarget;
492
- var toolbarElement = _this.toolbarRef && (relatedTarget === null || relatedTarget === void 0 ? void 0 : relatedTarget.closest("[class*=\"".concat(_this.toolbarRef.className, "\"]"))); // Check if relatedTarget is a done button
493
-
494
- 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, "\"]"))); // Skip onBlur handling if relatedTarget is a button from the KeyPad characters
495
-
496
- _this.skipBlurHandling = _this.keypadInteractionDetected && relatedTarget !== null;
497
-
498
- if (toolbarElement && !isRawDoneButton && !_this.state.focusToolbar) {
499
- _this.setState({
500
- focusToolbar: true
501
- });
502
- }
503
-
504
- var node = relatedTarget ? (0, _slateReact.findNode)(relatedTarget, _this.state.value) : null;
505
- log('[onBlur] node: ', node);
506
- return new Promise(function (resolve) {
507
- if (!_this.skipBlurHandling) {
508
- _this.setKeypadInteraction(false);
509
-
510
- _this.setState({
511
- preBlurValue: _this.state.value,
512
- focusedNode: !node ? null : node
513
- }, _this.handleBlur.bind((0, _assertThisInitialized2["default"])(_this), resolve));
514
- }
515
-
516
- _this.props.onBlur(event);
517
- });
518
- });
519
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleDomBlur", function (e) {
520
- var editorDOM = document.querySelector("[data-key=\"".concat(_this.state.value.document.key, "\"]"));
521
- setTimeout(function () {
522
- var stateValue = _this.state.value;
523
-
524
- if (!_this.wrapperRef) {
525
- return;
526
- }
527
-
528
- var editorElement = !editorDOM || document.activeElement.closest("[class*=\"".concat(editorDOM.className, "\"]"));
529
- var toolbarElement = !_this.toolbarRef || document.activeElement.closest("[class*=\"".concat(_this.toolbarRef.className, "\"]"));
530
-
531
- var isInCurrentComponent = _this.wrapperRef.contains(editorElement) || _this.wrapperRef.contains(toolbarElement);
532
-
533
- if (!isInCurrentComponent) {
534
- editorDOM.removeEventListener('blur', _this.handleDomBlur);
535
-
536
- if (stateValue.isFocused) {
537
- _this.onBlur(e);
538
- }
539
- }
540
- }, 50);
541
- });
542
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onFocus", function (event, change) {
543
- return new Promise(function (resolve) {
544
- var _navigator;
545
-
546
- var editorDOM = document.querySelector("[data-key=\"".concat(_this.state.value.document.key, "\"]"));
547
- var isTouchDevice = typeof window !== 'undefined' && ('ontouchstart' in window || ((_navigator = navigator) === null || _navigator === void 0 ? void 0 : _navigator.maxTouchPoints) > 0);
548
- log('[onFocus]', document.activeElement);
549
-
550
- if (_this.keypadInteractionDetected && _this.__TEMPORARY_CHANGE_DATA) {
551
- _this.__TEMPORARY_CHANGE_DATA = null;
552
- }
553
- /**
554
- * This is a temporary hack - @see changeData below for some more information.
555
- */
556
-
557
-
558
- if (_this.__TEMPORARY_CHANGE_DATA) {
559
- var _this$__TEMPORARY_CHA = _this.__TEMPORARY_CHANGE_DATA,
560
- key = _this$__TEMPORARY_CHA.key,
561
- data = _this$__TEMPORARY_CHA.data;
562
- var domEl = document.querySelector("[data-key=\"".concat(key, "\"]"));
563
-
564
- if (domEl) {
565
- var _change = _this.state.value.change().setNodeByKey(key, {
566
- data: data
567
- });
568
-
569
- _this.setState({
570
- value: _change.value
571
- }, function () {
572
- _this.__TEMPORARY_CHANGE_DATA = null;
573
- });
574
- }
575
- }
576
- /**
577
- * This is needed just in case the browser decides to make the editor
578
- * lose focus without triggering the onBlur event (can happen in a few cases).
579
- * This will also trigger onBlur if the user clicks outside of the page when the editor
580
- * is focused.
581
- */
582
-
583
-
584
- if (editorDOM === document.activeElement) {
585
- editorDOM.removeEventListener('blur', _this.handleDomBlur);
586
- editorDOM.addEventListener('blur', _this.handleDomBlur);
587
- }
588
-
589
- _this.stashValue();
590
-
591
- _this.props.onFocus(); // Added for accessibility: Ensures the editor gains focus when tabbed to for improved keyboard navigation
592
-
593
-
594
- var shouldFocusEditor = !_this.keypadInteractionDetected && !isTouchDevice;
595
-
596
- if (shouldFocusEditor) {
597
- change === null || change === void 0 ? void 0 : change.focus();
598
- }
599
-
600
- resolve();
601
- });
602
- });
603
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "stashValue", function () {
604
- log('[stashValue]');
605
-
606
- if (!_this.state.stashedValue) {
607
- _this.setState({
608
- stashedValue: _this.state.value
609
- });
610
- }
611
- });
612
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "resetValue", function (force) {
613
- var _this$state2 = _this.state,
614
- value = _this$state2.value,
615
- focusedNode = _this$state2.focusedNode;
616
-
617
- var stopReset = _this.plugins.reduce(function (s, p) {
618
- return s || p.stopReset && p.stopReset(_this.state.value);
619
- }, false);
620
-
621
- log('[resetValue]', value.isFocused, focusedNode, 'stopReset: ', stopReset);
622
-
623
- if (_this.state.stashedValue && !value.isFocused && !focusedNode && !stopReset || force) {
624
- log('[resetValue] resetting...');
625
- log('stashed', _this.state.stashedValue.document.toObject());
626
- log('current', _this.state.value.document.toObject());
627
-
628
- var newValue = _slate.Value.fromJSON(_this.state.stashedValue.toJSON());
629
-
630
- log('newValue: ', newValue.document);
631
- return new Promise(function (resolve) {
632
- setTimeout(function () {
633
- _this.setState({
634
- value: newValue,
635
- stashedValue: null
636
- }, function () {
637
- log('value now: ', _this.state.value.document.toJSON());
638
- resolve();
639
- });
640
- }, 50);
641
- });
642
- } else {
643
- return Promise.resolve({});
644
- }
645
- });
646
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onChange", function (change, done) {
647
- log('[onChange]');
648
- window.me = (0, _assertThisInitialized2["default"])(_this);
649
- var value = change.value;
650
- var charactersLimit = _this.props.charactersLimit;
651
- var limit = charactersLimit;
652
-
653
- if (!limit || limit > MAX_CHARACTERS_LIMIT) {
654
- limit = MAX_CHARACTERS_LIMIT;
655
- }
656
-
657
- if (value && value.document && value.document.text && value.document.text.length > limit) {
658
- return;
659
- } // Mark the editor as edited when in HTML mode and its content has changed.
660
- // This status will later be used to decide whether to prompt a warning to the user when exiting HTML mode.
661
-
662
-
663
- var isEditedInHtmlMode = !_this.state.isHtmlMode ? false : _this.state.value.document.text !== value.document.text ? true : _this.state.isEditedInHtmlMode;
664
-
665
- if (isEditedInHtmlMode != _this.state.isEditedInHtmlMode) {
666
- _this.handlePlugins(_this.props);
667
- }
668
-
669
- _this.setState({
670
- value: value,
671
- isEditedInHtmlMode: isEditedInHtmlMode
672
- }, function () {
673
- log('[onChange], call done()');
674
-
675
- if (done) {
676
- done();
677
- }
678
- });
679
- });
680
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "getFocusedValue", function () {
681
- if (_this.state.value.isFocused) {
682
- return _this.state.value;
683
- }
684
-
685
- return _this.state.preBlurValue;
686
- });
687
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "valueToSize", function (v) {
688
- if (!v) {
689
- return;
690
- }
691
-
692
- var calcRegex = /^calc\((.*)\)$/;
693
-
694
- if (typeof v === 'string') {
695
- if (v.endsWith('%')) {
696
- return undefined;
697
- } else if (v.endsWith('px') || v.endsWith('vh') || v.endsWith('vw') || v.endsWith('ch') || v.endsWith('em') || v.match(calcRegex)) {
698
- return v;
699
- } else {
700
- var value = parseInt(v, 10);
701
- return isNaN(value) ? value : "".concat(value, "px");
702
- }
703
- }
704
-
705
- if (typeof v === 'number') {
706
- return "".concat(v, "px");
707
- }
708
- });
709
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "validateNode", function (node) {
710
- if (node.object !== 'block') return;
711
- var last = node.nodes.last();
712
- if (!last) return;
713
- if (last.type !== 'image') return;
714
- log('[validateNode] last is image..');
715
- var parent = last.getParent(last.key);
716
-
717
- var p = _slate.Block.getParent(last.key);
718
-
719
- log('[validateNode] parent:', parent, p);
720
- return undefined;
721
- });
722
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeData", function (key, data) {
723
- log('[changeData]. .. ', key, data);
724
- /**
725
- * HACK ALERT: We should be calling setState here and storing the change data:
726
- *
727
- * <code>this.setState({changeData: { key, data}})</code>
728
- * However this is causing issues with the Mathquill instance. The 'input' event stops firing on the element and no
729
- * more changes get through. The issues seem to be related to the promises in onBlur/onFocus. But removing these
730
- * brings it's own problems. A major clean up is planned for this component so I've decided to temporarily settle
731
- * on this hack rather than spend more time on this.
732
- */
733
- // Uncomment this line to see the bug described above.
734
- // this.setState({changeData: {key, data}})
735
-
736
- _this.__TEMPORARY_CHANGE_DATA = {
737
- key: key,
738
- data: data
739
- };
740
- });
741
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "focus", function (pos, node) {
742
- var position = pos || 'end';
743
-
744
- _this.props.focus(position, node);
745
- });
746
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onDropPaste", /*#__PURE__*/function () {
747
- var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(event, change, dropContext) {
748
- var editor, transfer, file, type, fragment, text, src, inline, range, ch, handler, _change$value, _document, selection, startBlock, defaultBlock, defaultMarks, frag;
749
-
750
- return _regenerator["default"].wrap(function _callee$(_context) {
751
- while (1) {
752
- switch (_context.prev = _context.next) {
753
- case 0:
754
- editor = change.editor;
755
- transfer = (0, _slateReact.getEventTransfer)(event);
756
- file = transfer.files && transfer.files[0];
757
- type = transfer.type;
758
- fragment = transfer.fragment;
759
- text = transfer.text;
760
-
761
- if (!(file && (file.type === 'image/jpeg' || file.type === 'image/jpg' || file.type === 'image/png'))) {
762
- _context.next = 28;
763
- break;
764
- }
765
-
766
- if (_this.props.imageSupport) {
767
- _context.next = 9;
768
- break;
769
- }
770
-
771
- return _context.abrupt("return");
772
-
773
- case 9:
774
- _context.prev = 9;
775
- log('[onDropPaste]');
776
- _context.next = 13;
777
- return (0, serialization.getBase64)(file);
778
-
779
- case 13:
780
- src = _context.sent;
781
- inline = _slate.Inline.create({
782
- type: 'image',
783
- isVoid: true,
784
- data: {
785
- loading: false,
786
- src: src
787
- }
788
- });
789
-
790
- if (dropContext) {
791
- _this.focus();
792
- } else {
793
- range = (0, _slateReact.getEventRange)(event, editor);
794
-
795
- if (range) {
796
- change.select(range);
797
- }
798
- }
799
-
800
- ch = change.insertInline(inline);
801
-
802
- _this.onChange(ch);
803
-
804
- handler = new _insertImageHandler["default"](inline, function () {}, function () {
805
- return _this.state.value;
806
- }, _this.onChange, true);
807
- handler.fileChosen(file);
808
-
809
- _this.props.imageSupport.add(handler);
810
-
811
- _context.next = 26;
812
- break;
813
-
814
- case 23:
815
- _context.prev = 23;
816
- _context.t0 = _context["catch"](9);
817
- log('[onDropPaste] error: ', _context.t0);
818
-
819
- case 26:
820
- _context.next = 42;
821
- break;
822
-
823
- case 28:
824
- if (!(type === 'fragment')) {
825
- _context.next = 32;
826
- break;
827
- }
828
-
829
- change.insertFragment(fragment);
830
- _context.next = 42;
831
- break;
832
-
833
- case 32:
834
- if (!(type === 'text' || type === 'html')) {
835
- _context.next = 42;
836
- break;
837
- }
838
-
839
- if (text) {
840
- _context.next = 35;
841
- break;
842
- }
843
-
844
- return _context.abrupt("return");
845
-
846
- case 35:
847
- _change$value = change.value, _document = _change$value.document, selection = _change$value.selection, startBlock = _change$value.startBlock;
848
-
849
- if (!startBlock.isVoid) {
850
- _context.next = 38;
851
- break;
852
- }
853
-
854
- return _context.abrupt("return");
855
-
856
- case 38:
857
- defaultBlock = startBlock;
858
- defaultMarks = _document.getInsertMarksAtRange(selection);
859
- frag = _slatePlainSerializer["default"].deserialize(text, {
860
- defaultBlock: defaultBlock,
861
- defaultMarks: defaultMarks
862
- }).document;
863
- change.insertFragment(frag);
864
-
865
- case 42:
866
- case "end":
867
- return _context.stop();
868
- }
869
- }
870
- }, _callee, null, [[9, 23]]);
871
- }));
872
-
873
- return function (_x, _x2, _x3) {
874
- return _ref3.apply(this, arguments);
875
- };
876
- }());
877
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "renderPlaceholder", function (props) {
878
- var editor = props.editor;
879
- var document = editor.value.document;
880
-
881
- if (!editor.props.placeholder || document.text !== '' || document.nodes.size !== 1 || !document.isEmpty) {
882
- return false;
883
- }
884
-
885
- return /*#__PURE__*/_react["default"].createElement("span", {
886
- contentEditable: false,
887
- style: {
888
- display: 'inline-block',
889
- width: 'fit-content',
890
- // for centering the placeholder if text-align is set to center
891
- maxWidth: '100%',
892
- whiteSpace: 'nowrap',
893
- opacity: '0.33',
894
- pointerEvents: 'none',
895
- userSelect: 'none'
896
- }
897
- }, editor.props.placeholder);
898
- });
899
- _this.state = {
900
- value: _props.value,
901
- toolbarOpts: createToolbarOpts(_props.toolbarOpts, _props.error),
902
- pendingImages: [],
903
- isHtmlMode: false,
904
- isEditedInHtmlMode: false,
905
- focusToolbar: false,
906
- dialog: {
907
- open: false
908
- }
909
- };
910
- _this.keyPadCharacterRef = /*#__PURE__*/_react["default"].createRef();
911
- _this.doneButtonRef = /*#__PURE__*/_react["default"].createRef();
912
- _this.keypadInteractionDetected = false;
913
- _this.toggleHtmlMode = _this.toggleHtmlMode.bind((0, _assertThisInitialized2["default"])(_this));
914
- _this.handleToolbarFocus = _this.handleToolbarFocus.bind((0, _assertThisInitialized2["default"])(_this));
915
- _this.handleToolbarBlur = _this.handleToolbarBlur.bind((0, _assertThisInitialized2["default"])(_this));
916
- _this.onResize = (0, _debounce["default"])(function () {
917
- if (!_this.state.isHtmlMode && _props.onChange) {
918
- _props.onChange(_this.state.value, true);
919
- }
920
- }, 50);
921
-
922
- _this.handlePlugins(_this.props);
923
-
924
- return _this;
925
- }
926
-
927
- (0, _createClass2["default"])(Editor, [{
928
- key: "handleToolbarFocus",
929
- value: function handleToolbarFocus() {
930
- if (this.state.focusToolbar) {
931
- return;
932
- }
933
-
934
- this.setState({
935
- focusToolbar: true
936
- });
937
- }
938
- }, {
939
- key: "handleToolbarBlur",
940
- value: function handleToolbarBlur() {
941
- var _this2 = this;
942
-
943
- setTimeout(function () {
944
- if (!_this2.toolbarContainsFocus()) {
945
- _this2.setState({
946
- focusToolbar: false
947
- });
948
- }
949
- }, 0);
950
- }
951
- }, {
952
- key: "toolbarContainsFocus",
953
- value: function toolbarContainsFocus() {
954
- if (!this.toolbarRef) return false;
955
- var toolbarElement = this.toolbarRef;
956
- var activeElement = document.activeElement;
957
- return toolbarElement && toolbarElement.contains(activeElement);
958
- }
959
- }, {
960
- key: "componentDidMount",
961
- value: function componentDidMount() {
962
- var _this$props$className,
963
- _this3 = this;
964
-
965
- // onRef is needed to get the ref of the component because we export it using withStyles
966
- this.props.onRef(this);
967
- window.addEventListener('resize', this.onResize);
968
- var isResponseAreaEditor = (_this$props$className = this.props.className) === null || _this$props$className === void 0 ? void 0 : _this$props$className.includes('response-area-editor');
969
-
970
- if (isResponseAreaEditor && this.editor) {
971
- var responseAreaEditor = document.querySelector("[data-key=\"".concat(this.editor.value.document.key, "\"]"));
972
-
973
- if (responseAreaEditor) {
974
- responseAreaEditor.setAttribute('aria-label', 'Answer');
975
- }
976
- }
977
-
978
- if (this.editor && this.props.autoFocus) {
979
- Promise.resolve().then(function () {
980
- if (_this3.editor) {
981
- var editorDOM = document.querySelector("[data-key=\"".concat(_this3.editor.value.document.key, "\"]"));
982
-
983
- _this3.editor.focus();
984
-
985
- if (editorDOM) {
986
- editorDOM.focus();
987
- }
988
- }
989
- });
990
- }
991
- }
992
- }, {
993
- key: "UNSAFE_componentWillReceiveProps",
994
- value: function UNSAFE_componentWillReceiveProps(nextProps) {
995
- var _nextProps$value, _nextProps$value$docu, _this$props$value;
996
-
997
- var _this$state3 = this.state,
998
- isHtmlMode = _this$state3.isHtmlMode,
999
- toolbarOpts = _this$state3.toolbarOpts;
1000
- var newToolbarOpts = createToolbarOpts(nextProps.toolbarOpts, nextProps.error, isHtmlMode);
1001
-
1002
- if (!(0, _isEqual["default"])(newToolbarOpts, toolbarOpts)) {
1003
- this.setState({
1004
- toolbarOpts: newToolbarOpts
1005
- });
1006
- }
1007
-
1008
- var differentCharacterProps = !(0, _isEqual["default"])(nextProps.languageCharactersProps, this.props.languageCharactersProps);
1009
- var differentMathMlProps = !(0, _isEqual["default"])(nextProps.mathMlOptions, this.props.mathMlOptions);
1010
- var differentImageMaxDimensionsProps = !(0, _isEqual["default"])(nextProps.maxImageWidth, this.props.maxImageWidth) || !(0, _isEqual["default"])(nextProps.maxImageHeight, this.props.maxImageHeight);
1011
-
1012
- if (differentCharacterProps || differentMathMlProps || differentImageMaxDimensionsProps) {
1013
- this.handlePlugins(nextProps);
1014
- }
1015
-
1016
- if (!((_nextProps$value = nextProps.value) !== null && _nextProps$value !== void 0 && (_nextProps$value$docu = _nextProps$value.document) !== null && _nextProps$value$docu !== void 0 && _nextProps$value$docu.equals((_this$props$value = this.props.value) === null || _this$props$value === void 0 ? void 0 : _this$props$value.document))) {
1017
- this.setState({
1018
- focus: false,
1019
- value: nextProps.value
1020
- });
1021
- }
1022
- }
1023
- }, {
1024
- key: "componentDidUpdate",
1025
- value: function componentDidUpdate(prevProps, prevState) {
1026
- // The cursor is on a zero width element and when that is placed near void elements, it is not visible
1027
- // so we increase the width to at least 2px in order for the user to see it
1028
- // Trigger plugins and finish editing if:
1029
- // 1. The 'isHtmlMode' state has been toggled.
1030
- // 2. We're currently in 'isHtmlMode' and the editor value has been modified.
1031
- if (this.state.isHtmlMode !== prevState.isHtmlMode || this.state.isHtmlMode && !prevState.isEditedInHtmlMode && this.state.isEditedInHtmlMode) {
1032
- this.handlePlugins(this.props);
1033
- }
1034
-
1035
- var zeroWidthEls = document.querySelectorAll('[data-slate-zero-width="z"]');
1036
- Array.from(zeroWidthEls).forEach(function (el) {
1037
- el.style.minWidth = '2px';
1038
- el.style.display = 'inline-block';
1039
- });
1040
- }
1041
- }, {
1042
- key: "componentWillUnmount",
1043
- value:
1044
- /**
1045
- * Remove onResize event listener
1046
- */
1047
- function componentWillUnmount() {
1048
- window.removeEventListener('resize', this.onResize);
1049
- } // Allowing time for onChange to take effect if it is called
1050
-
1051
- }, {
1052
- key: "buildSizeStyle",
1053
- value: function buildSizeStyle() {
1054
- var _this$props = this.props,
1055
- minWidth = _this$props.minWidth,
1056
- width = _this$props.width,
1057
- maxWidth = _this$props.maxWidth,
1058
- minHeight = _this$props.minHeight,
1059
- height = _this$props.height,
1060
- maxHeight = _this$props.maxHeight;
1061
- return {
1062
- width: this.valueToSize(width),
1063
- minWidth: this.valueToSize(minWidth),
1064
- maxWidth: this.valueToSize(maxWidth),
1065
- height: this.valueToSize(height),
1066
- minHeight: this.valueToSize(minHeight),
1067
- maxHeight: this.valueToSize(maxHeight)
1068
- };
1069
- }
1070
- }, {
1071
- key: "render",
1072
- value: function render() {
1073
- var _classNames,
1074
- _this4 = this,
1075
- _value$document,
1076
- _classNames2;
1077
-
1078
- var _this$props2 = this.props,
1079
- disabled = _this$props2.disabled,
1080
- spellCheck = _this$props2.spellCheck,
1081
- highlightShape = _this$props2.highlightShape,
1082
- classes = _this$props2.classes,
1083
- className = _this$props2.className,
1084
- isEditor = _this$props2.isEditor,
1085
- placeholder = _this$props2.placeholder,
1086
- pluginProps = _this$props2.pluginProps,
1087
- onKeyDown = _this$props2.onKeyDown; // We don't want to send customPlugins to slate.
1088
- // Not sure if they would do any harm, but I think it's better to not send them.
1089
- // We use custom plugins to be able to add custom buttons
1090
- // eslint-disable-next-line no-unused-vars
1091
-
1092
- var _ref4 = pluginProps || {},
1093
- customPlugins = _ref4.customPlugins,
1094
- showParagraphs = _ref4.showParagraphs,
1095
- separateParagraphs = _ref4.separateParagraphs,
1096
- otherPluginProps = (0, _objectWithoutProperties2["default"])(_ref4, _excluded);
1097
-
1098
- var _this$state4 = this.state,
1099
- value = _this$state4.value,
1100
- focusedNode = _this$state4.focusedNode,
1101
- toolbarOpts = _this$state4.toolbarOpts,
1102
- dialog = _this$state4.dialog,
1103
- scheduled = _this$state4.scheduled;
1104
- log('[render] value: ', value);
1105
- var sizeStyle = this.buildSizeStyle();
1106
- var names = (0, _classnames["default"])((_classNames = {}, (0, _defineProperty2["default"])(_classNames, classes.withBg, highlightShape), (0, _defineProperty2["default"])(_classNames, classes.toolbarOnTop, toolbarOpts.alwaysVisible && toolbarOpts.position === 'top'), (0, _defineProperty2["default"])(_classNames, classes.scheduled, scheduled), _classNames), className);
1107
- return /*#__PURE__*/_react["default"].createElement("div", {
1108
- ref: function ref(_ref5) {
1109
- return _this4.wrapperRef = _ref5;
1110
- },
1111
- style: {
1112
- width: sizeStyle.width,
1113
- minWidth: sizeStyle.minWidth,
1114
- maxWidth: sizeStyle.maxWidth
1115
- },
1116
- className: names,
1117
- id: "editor-".concat(value === null || value === void 0 ? void 0 : (_value$document = value.document) === null || _value$document === void 0 ? void 0 : _value$document.key)
1118
- }, scheduled && /*#__PURE__*/_react["default"].createElement("div", {
1119
- className: classes.uploading
1120
- }, "Uploading image and then saving..."), /*#__PURE__*/_react["default"].createElement(_slateReact.Editor, {
1121
- plugins: this.plugins,
1122
- innerRef: function innerRef(r) {
1123
- if (r) {
1124
- _this4.slateEditor = r;
1125
- }
1126
- },
1127
- ref: function ref(r) {
1128
- return _this4.editor = r && _this4.props.editorRef(r);
1129
- },
1130
- toolbarRef: function toolbarRef(r) {
1131
- if (r) {
1132
- _this4.toolbarRef = r;
1133
- }
1134
- },
1135
- doneButtonRef: this.doneButtonRef,
1136
- value: value,
1137
- focusToolbar: this.state.focusToolbar,
1138
- onToolbarFocus: this.handleToolbarFocus,
1139
- onToolbarBlur: this.handleToolbarBlur,
1140
- focus: this.focus,
1141
- onKeyDown: onKeyDown,
1142
- onChange: this.onChange,
1143
- getFocusedValue: this.getFocusedValue,
1144
- onBlur: this.onBlur,
1145
- onDrop: function onDrop(event, editor) {
1146
- return _this4.onDropPaste(event, editor, true);
1147
- },
1148
- onPaste: function onPaste(event, editor) {
1149
- return _this4.onDropPaste(event, editor);
1150
- },
1151
- onFocus: this.onFocus,
1152
- onEditingDone: this.onEditingDone,
1153
- focusedNode: focusedNode,
1154
- normalize: this.normalize,
1155
- readOnly: disabled,
1156
- spellCheck: spellCheck,
1157
- autoCorrect: spellCheck,
1158
- className: (0, _classnames["default"])((_classNames2 = {}, (0, _defineProperty2["default"])(_classNames2, classes.noPadding, toolbarOpts === null || toolbarOpts === void 0 ? void 0 : toolbarOpts.noPadding), (0, _defineProperty2["default"])(_classNames2, classes.showParagraph, showParagraphs && !showParagraphs.disabled), (0, _defineProperty2["default"])(_classNames2, classes.separateParagraph, separateParagraphs && !separateParagraphs.disabled), _classNames2), classes.slateEditor),
1159
- style: {
1160
- minHeight: sizeStyle.minHeight,
1161
- height: sizeStyle.height,
1162
- maxHeight: sizeStyle.maxHeight
1163
- },
1164
- pluginProps: otherPluginProps,
1165
- toolbarOpts: toolbarOpts,
1166
- placeholder: placeholder,
1167
- renderPlaceholder: this.renderPlaceholder,
1168
- onDataChange: this.changeData
1169
- }), /*#__PURE__*/_react["default"].createElement(_alertDialog["default"], {
1170
- open: dialog.open,
1171
- title: dialog.title,
1172
- text: dialog.text,
1173
- onClose: dialog.onClose,
1174
- onConfirm: dialog.onConfirm,
1175
- onConfirmText: dialog.onConfirmText,
1176
- onCloseText: dialog.onCloseText
1177
- }));
1178
- }
1179
- }]);
1180
- return Editor;
1181
- }(_react["default"].Component); // TODO color - hardcoded gray background and keypad colors will need to change too
1182
-
1183
-
1184
- exports.Editor = Editor;
1185
- (0, _defineProperty2["default"])(Editor, "propTypes", {
1186
- autoFocus: _propTypes["default"].bool,
1187
- editorRef: _propTypes["default"].func.isRequired,
1188
- error: _propTypes["default"].any,
1189
- onRef: _propTypes["default"].func.isRequired,
1190
- onChange: _propTypes["default"].func.isRequired,
1191
- onFocus: _propTypes["default"].func,
1192
- onBlur: _propTypes["default"].func,
1193
- onKeyDown: _propTypes["default"].func,
1194
- focus: _propTypes["default"].func.isRequired,
1195
- value: _slatePropTypes["default"].value.isRequired,
1196
- imageSupport: _propTypes["default"].object,
1197
- mathMlOptions: _propTypes["default"].shape({
1198
- mmlOutput: _propTypes["default"].bool,
1199
- mmlEditing: _propTypes["default"].bool
1200
- }),
1201
- disableImageAlignmentButtons: _propTypes["default"].bool,
1202
- uploadSoundSupport: _propTypes["default"].shape({
1203
- add: _propTypes["default"].func,
1204
- "delete": _propTypes["default"].func
1205
- }),
1206
- charactersLimit: _propTypes["default"].number,
1207
- width: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
1208
- minWidth: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
1209
- maxWidth: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
1210
- height: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
1211
- minHeight: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
1212
- maxHeight: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
1213
- classes: _propTypes["default"].object.isRequired,
1214
- highlightShape: _propTypes["default"].bool,
1215
- disabled: _propTypes["default"].bool,
1216
- spellCheck: _propTypes["default"].bool,
1217
- nonEmpty: _propTypes["default"].bool,
1218
- disableScrollbar: _propTypes["default"].bool,
1219
- disableUnderline: _propTypes["default"].bool,
1220
- autoWidthToolbar: _propTypes["default"].bool,
1221
- pluginProps: _propTypes["default"].any,
1222
- // customPlugins should be inside pluginProps (a property inside pluginProps)
1223
- // customPlugins: PropTypes.arrayOf(
1224
- // PropTypes.shape({
1225
- // event: PropTypes.string,
1226
- // icon: PropTypes.string,
1227
- // iconType: PropTypes.string,
1228
- // iconAlt: PropTypes.string
1229
- // }),
1230
- // ),
1231
- placeholder: _propTypes["default"].string,
1232
- isEditor: _propTypes["default"].bool,
1233
- responseAreaProps: _propTypes["default"].shape({
1234
- type: _propTypes["default"].oneOf(['explicit-constructed-response', 'inline-dropdown', 'drag-in-the-blank', 'math-templated']),
1235
- options: _propTypes["default"].object,
1236
- respAreaToolbar: _propTypes["default"].func,
1237
- onHandleAreaChange: _propTypes["default"].func,
1238
- maxResponseAreas: _propTypes["default"].number,
1239
- error: _propTypes["default"].any
1240
- }),
1241
- extraCSSRules: _propTypes["default"].shape({
1242
- names: _propTypes["default"].arrayOf(_propTypes["default"].string),
1243
- rules: _propTypes["default"].string
1244
- }),
1245
- languageCharactersProps: _propTypes["default"].arrayOf(_propTypes["default"].shape({
1246
- language: _propTypes["default"].string,
1247
- characterIcon: _propTypes["default"].string,
1248
- characters: _propTypes["default"].arrayOf(_propTypes["default"].arrayOf(_propTypes["default"].string))
1249
- })),
1250
- runSerializationOnMarkup: _propTypes["default"].func,
1251
- toolbarOpts: _propTypes["default"].shape({
1252
- position: _propTypes["default"].oneOf(['bottom', 'top']),
1253
- alignment: _propTypes["default"].oneOf(['left', 'right']),
1254
- alwaysVisible: _propTypes["default"].bool,
1255
- showDone: _propTypes["default"].bool,
1256
- doneOn: _propTypes["default"].string,
1257
- minWidth: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number])
1258
- }),
1259
- activePlugins: _propTypes["default"].arrayOf(function (values) {
1260
- var allValid = values.every(function (v) {
1261
- return _plugins.ALL_PLUGINS.includes(v);
1262
- });
1263
- return !allValid && new Error("Invalid values: ".concat(values, ", values must be one of [").concat(_plugins.ALL_PLUGINS.join(','), "]"));
1264
- }),
1265
- className: _propTypes["default"].string,
1266
- maxImageWidth: _propTypes["default"].number,
1267
- maxImageHeight: _propTypes["default"].number
1268
- });
1269
- (0, _defineProperty2["default"])(Editor, "defaultProps", {
1270
- disableUnderline: true,
1271
- onFocus: function onFocus() {},
1272
- onBlur: function onBlur() {},
1273
- onKeyDown: function onKeyDown() {},
1274
- runSerializationOnMarkup: function runSerializationOnMarkup() {},
1275
- mathMlOptions: {
1276
- mmlOutput: false,
1277
- mmlEditing: false
1278
- },
1279
- toolbarOpts: defaultToolbarOpts,
1280
- responseAreaProps: defaultResponseAreaProps,
1281
- languageCharactersProps: defaultLanguageCharactersProps,
1282
- extraCSSRules: null,
1283
- isEditor: false
1284
- });
1285
- var styles = {
1286
- withBg: {
1287
- backgroundColor: 'rgba(0,0,0,0.06)'
1288
- },
1289
- scheduled: {
1290
- opacity: 0.5,
1291
- pointerEvents: 'none',
1292
- position: 'relative'
1293
- },
1294
- uploading: {
1295
- position: 'absolute',
1296
- top: '50%',
1297
- left: '50%',
1298
- transform: 'translate(-50%, -50%)'
1299
- },
1300
- slateEditor: {
1301
- fontFamily: 'Roboto, sans-serif',
1302
- '& table': {
1303
- tableLayout: 'fixed',
1304
- width: '100%',
1305
- borderCollapse: 'collapse',
1306
- color: _renderUi.color.text(),
1307
- backgroundColor: _renderUi.color.background()
1308
- },
1309
- '& table:not([border="1"]) tr': {
1310
- borderTop: '1px solid #dfe2e5' // TODO perhaps secondary color for background, for now disable
1311
- // '&:nth-child(2n)': {
1312
- // backgroundColor: '#f6f8fa'
1313
- // }
1314
-
1315
- },
1316
- '& td, th': {
1317
- padding: '.6em 1em',
1318
- textAlign: 'center'
1319
- },
1320
- '& table:not([border="1"]) td, th': {
1321
- border: '1px solid #dfe2e5'
1322
- }
1323
- },
1324
- showParagraph: {
1325
- // a div that has a div after it
1326
- '& > div:has(+ div)::after': {
1327
- display: 'block',
1328
- content: '"¶"',
1329
- fontSize: '1em',
1330
- color: '#146EB3'
1331
- }
1332
- },
1333
- separateParagraph: {
1334
- // a div that has a div after it
1335
- '& > div:has(+ div)': {
1336
- marginBottom: '1em'
1337
- }
1338
- },
1339
- toolbarOnTop: {
1340
- marginTop: '45px'
1341
- },
1342
- noPadding: {
1343
- padding: '0 !important'
1344
- },
1345
- previewText: {
1346
- marginBottom: '36px',
1347
- marginTop: '6px',
1348
- padding: '20px',
1349
- backgroundColor: 'rgba(0,0,0,0.06)'
1350
- }
1351
- };
1352
-
1353
- var _default = (0, _styles.withStyles)(styles)(Editor);
1354
-
1355
- exports["default"] = _default;
1356
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/editor.jsx"],"names":["log","defaultToolbarOpts","position","alignment","alwaysVisible","showDone","doneOn","defaultResponseAreaProps","options","respAreaToolbar","onHandleAreaChange","defaultLanguageCharactersProps","createToolbarOpts","toolbarOpts","error","isHtmlMode","MAX_CHARACTERS_LIMIT","Editor","props","interacted","keypadInteractionDetected","open","extraDialogProps","callback","setState","dialog","prevState","isEditedInHtmlMode","state","newToolbarOpts","normalizedResponseAreaProps","responseAreaProps","htmlPluginOpts","currentValue","value","toggleHtmlMode","handleAlertDialog","handleDialog","pluginProps","customPlugins","plugins","activePlugins","math","onClick","onMathClick","onFocus","onPluginFocus","onBlur","onPluginBlur","mathMlOptions","textAlign","getValue","onChange","html","extraCSSRules","image","disableImageAlignmentButtons","onDelete","imageSupport","node","done","src","data","get","e","newPendingImages","pendingImages","filter","img","key","oldScheduled","scheduled","newState","length","insertImageRequested","addedImage","getHandler","onFinish","result","cb","onEditingDone","bind","handler","add","maxImageWidth","maxImageHeight","toolbar","disableScrollbar","disableUnderline","autoWidth","autoWidthToolbar","onDone","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","stashedValue","stashValue","c","collapseToStartOf","selectedNode","document","previewText","renderHtmlPreviewContent","openHtmlModeConfirmationDialog","classes","ref","elementRef","title","onConfirmText","onCloseText","onConfirm","handleHtmlModeSaveConfirmation","onClose","htmlModeContinueEditing","resolve","event","toolbarElement","toolbarRef","closest","className","isRawDoneButton","doneButtonRef","current","skipBlurHandling","Promise","preBlurValue","handleBlur","editorDOM","querySelector","setTimeout","stateValue","wrapperRef","editorElement","activeElement","isInCurrentComponent","contains","removeEventListener","handleDomBlur","isFocused","isTouchDevice","window","navigator","maxTouchPoints","__TEMPORARY_CHANGE_DATA","domEl","setNodeByKey","addEventListener","shouldFocusEditor","force","stopReset","reduce","s","p","toObject","newValue","Value","fromJSON","toJSON","me","charactersLimit","limit","handlePlugins","v","calcRegex","endsWith","undefined","match","parseInt","isNaN","object","last","nodes","parent","getParent","Block","pos","dropContext","transfer","file","files","fragment","inline","Inline","create","isVoid","loading","range","select","ch","insertInline","InsertImageHandler","fileChosen","insertFragment","selection","startBlock","defaultBlock","defaultMarks","getInsertMarksAtRange","frag","Plain","deserialize","placeholder","size","isEmpty","display","width","maxWidth","whiteSpace","opacity","pointerEvents","userSelect","React","createRef","handleToolbarFocus","handleToolbarBlur","onResize","toolbarContainsFocus","onRef","isResponseAreaEditor","includes","responseAreaEditor","setAttribute","autoFocus","nextProps","differentCharacterProps","differentMathMlProps","differentImageMaxDimensionsProps","equals","prevProps","zeroWidthEls","querySelectorAll","Array","from","forEach","el","style","minWidth","minHeight","height","maxHeight","valueToSize","disabled","spellCheck","highlightShape","isEditor","onKeyDown","showParagraphs","separateParagraphs","otherPluginProps","sizeStyle","buildSizeStyle","names","withBg","toolbarOnTop","uploading","r","slateEditor","editorRef","getFocusedValue","onDropPaste","normalize","noPadding","showParagraph","separateParagraph","renderPlaceholder","changeData","Component","PropTypes","bool","func","isRequired","any","SlateTypes","shape","number","oneOfType","string","oneOf","arrayOf","rules","language","characterIcon","characters","values","allValid","every","ALL_PLUGINS","Error","join","styles","backgroundColor","top","left","transform","fontFamily","tableLayout","borderCollapse","color","background","borderTop","padding","border","content","fontSize","marginBottom","marginTop"],"mappings":"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","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 { withStyles } from '@material-ui/core/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 * 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    classes: PropTypes.object.isRequired,\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 because we export it using withStyles\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    const { classes } = this.props;\n    return (\n      <div ref={(ref) => (this.elementRef = ref)}>\n        <div>Preview of Edited Html:</div>\n        <PreviewPrompt defaultClassName={classes.previewText} prompt={this.state.value.document.text} />\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  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  buildSizeStyle() {\n    const { minWidth, width, maxWidth, minHeight, height, maxHeight } = this.props;\n\n    return {\n      width: this.valueToSize(width),\n      minWidth: this.valueToSize(minWidth),\n      maxWidth: this.valueToSize(maxWidth),\n      height: this.valueToSize(height),\n      minHeight: this.valueToSize(minHeight),\n      maxHeight: this.valueToSize(maxHeight),\n    };\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      classes,\n      className,\n      isEditor,\n      placeholder,\n      pluginProps,\n      onKeyDown,\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 names = classNames(\n      {\n        [classes.withBg]: highlightShape,\n        [classes.toolbarOnTop]: toolbarOpts.alwaysVisible && toolbarOpts.position === 'top',\n        [classes.scheduled]: scheduled,\n      },\n      className,\n    );\n\n    return (\n      <div\n        ref={(ref) => (this.wrapperRef = ref)}\n        style={{ width: sizeStyle.width, minWidth: sizeStyle.minWidth, maxWidth: sizeStyle.maxWidth }}\n        className={names}\n        id={`editor-${value?.document?.key}`}\n      >\n        {scheduled && <div className={classes.uploading}>Uploading image and then saving...</div>}\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          className={classNames(\n            {\n              [classes.noPadding]: toolbarOpts?.noPadding,\n              [classes.showParagraph]: showParagraphs && !showParagraphs.disabled,\n              [classes.separateParagraph]: separateParagraphs && !separateParagraphs.disabled,\n            },\n            classes.slateEditor,\n          )}\n          style={{\n            minHeight: sizeStyle.minHeight,\n            height: sizeStyle.height,\n            maxHeight: sizeStyle.maxHeight,\n          }}\n          pluginProps={otherPluginProps}\n          toolbarOpts={toolbarOpts}\n          placeholder={placeholder}\n          renderPlaceholder={this.renderPlaceholder}\n          onDataChange={this.changeData}\n        />\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      </div>\n    );\n  }\n}\n\n// TODO color - hardcoded gray background and keypad colors will need to change too\nconst styles = {\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  uploading: {\n    position: 'absolute',\n    top: '50%',\n    left: '50%',\n    transform: 'translate(-50%, -50%)',\n  },\n  slateEditor: {\n    fontFamily: 'Roboto, sans-serif',\n\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  },\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  toolbarOnTop: {\n    marginTop: '45px',\n  },\n  noPadding: {\n    padding: '0 !important',\n  },\n  previewText: {\n    marginBottom: '36px',\n    marginTop: '6px',\n    padding: '20px',\n    backgroundColor: 'rgba(0,0,0,0.06)',\n  },\n};\n\nexport default withStyles(styles)(Editor);\n"]}