@pie-lib/editable-html 11.1.1 → 11.3.0-beta.0

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 (194) hide show
  1. package/CHANGELOG.md +8 -4
  2. package/NEXT.CHANGELOG.json +1 -0
  3. package/lib/__tests__/editor.test.js +470 -0
  4. package/lib/__tests__/serialization.test.js +246 -0
  5. package/lib/__tests__/utils.js +106 -0
  6. package/lib/block-tags.js +25 -0
  7. package/lib/constants.js +16 -0
  8. package/lib/editor.js +349 -88
  9. package/lib/index.js +26 -10
  10. package/lib/parse-html.js +1 -1
  11. package/lib/plugins/characters/custom-popper.js +1 -1
  12. package/lib/plugins/characters/index.js +9 -4
  13. package/lib/plugins/characters/utils.js +13 -13
  14. package/lib/plugins/css/icons/index.js +37 -0
  15. package/lib/plugins/css/index.js +397 -0
  16. package/lib/plugins/customPlugin/index.js +114 -0
  17. package/lib/plugins/html/icons/index.js +1 -1
  18. package/lib/plugins/html/index.js +12 -8
  19. package/lib/plugins/image/__tests__/component.test.js +51 -0
  20. package/lib/plugins/image/__tests__/image-toolbar-logic.test.js +56 -0
  21. package/lib/plugins/image/__tests__/image-toolbar.test.js +26 -0
  22. package/lib/plugins/image/__tests__/index.test.js +98 -0
  23. package/lib/plugins/image/__tests__/insert-image-handler.test.js +125 -0
  24. package/lib/plugins/image/__tests__/mock-change.js +25 -0
  25. package/lib/plugins/image/alt-dialog.js +1 -1
  26. package/lib/plugins/image/component.js +1 -1
  27. package/lib/plugins/image/image-toolbar.js +1 -1
  28. package/lib/plugins/image/index.js +3 -2
  29. package/lib/plugins/image/insert-image-handler.js +14 -5
  30. package/lib/plugins/index.js +271 -12
  31. package/lib/plugins/list/__tests__/index.test.js +79 -0
  32. package/lib/plugins/list/index.js +131 -1
  33. package/lib/plugins/math/__tests__/index.test.js +300 -0
  34. package/lib/plugins/math/index.js +92 -57
  35. package/lib/plugins/media/__tests__/index.test.js +71 -0
  36. package/lib/plugins/media/index.js +6 -3
  37. package/lib/plugins/media/media-dialog.js +99 -58
  38. package/lib/plugins/media/media-toolbar.js +1 -1
  39. package/lib/plugins/media/media-wrapper.js +1 -1
  40. package/lib/plugins/rendering/index.js +46 -0
  41. package/lib/plugins/respArea/drag-in-the-blank/choice.js +6 -3
  42. package/lib/plugins/respArea/drag-in-the-blank/index.js +1 -1
  43. package/lib/plugins/respArea/explicit-constructed-response/index.js +12 -10
  44. package/lib/plugins/respArea/icons/index.js +1 -1
  45. package/lib/plugins/respArea/index.js +70 -22
  46. package/lib/plugins/respArea/inline-dropdown/index.js +11 -6
  47. package/lib/plugins/respArea/math-templated/index.js +130 -0
  48. package/lib/plugins/respArea/utils.js +17 -2
  49. package/lib/plugins/table/CustomTablePlugin.js +133 -0
  50. package/lib/plugins/table/__tests__/index.test.js +442 -0
  51. package/lib/plugins/table/__tests__/table-toolbar.test.js +54 -0
  52. package/lib/plugins/table/icons/index.js +1 -1
  53. package/lib/plugins/table/index.js +44 -60
  54. package/lib/plugins/table/table-toolbar.js +34 -5
  55. package/lib/plugins/textAlign/icons/index.js +226 -0
  56. package/lib/plugins/textAlign/index.js +34 -0
  57. package/lib/plugins/toolbar/__tests__/default-toolbar.test.js +128 -0
  58. package/lib/plugins/toolbar/__tests__/editor-and-toolbar.test.js +51 -0
  59. package/lib/plugins/toolbar/__tests__/toolbar-buttons.test.js +54 -0
  60. package/lib/plugins/toolbar/__tests__/toolbar.test.js +120 -0
  61. package/lib/plugins/toolbar/default-toolbar.js +83 -28
  62. package/lib/plugins/toolbar/done-button.js +6 -3
  63. package/lib/plugins/toolbar/editor-and-toolbar.js +19 -20
  64. package/lib/plugins/toolbar/index.js +1 -1
  65. package/lib/plugins/toolbar/toolbar-buttons.js +45 -12
  66. package/lib/plugins/toolbar/toolbar.js +36 -12
  67. package/lib/plugins/utils.js +1 -1
  68. package/lib/serialization.js +234 -45
  69. package/lib/theme.js +1 -1
  70. package/package.json +6 -6
  71. package/src/__tests__/editor.test.jsx +363 -0
  72. package/src/__tests__/serialization.test.js +291 -0
  73. package/src/__tests__/utils.js +36 -0
  74. package/src/block-tags.js +17 -0
  75. package/src/constants.js +7 -0
  76. package/src/editor.jsx +303 -49
  77. package/src/index.jsx +19 -10
  78. package/src/plugins/characters/index.jsx +11 -3
  79. package/src/plugins/characters/utils.js +12 -12
  80. package/src/plugins/css/icons/index.jsx +17 -0
  81. package/src/plugins/css/index.jsx +346 -0
  82. package/src/plugins/customPlugin/index.jsx +85 -0
  83. package/src/plugins/html/index.jsx +9 -6
  84. package/src/plugins/image/__tests__/__snapshots__/component.test.jsx.snap +51 -0
  85. package/src/plugins/image/__tests__/__snapshots__/image-toolbar-logic.test.jsx.snap +27 -0
  86. package/src/plugins/image/__tests__/__snapshots__/image-toolbar.test.jsx.snap +44 -0
  87. package/src/plugins/image/__tests__/component.test.jsx +41 -0
  88. package/src/plugins/image/__tests__/image-toolbar-logic.test.jsx +42 -0
  89. package/src/plugins/image/__tests__/image-toolbar.test.jsx +11 -0
  90. package/src/plugins/image/__tests__/index.test.js +95 -0
  91. package/src/plugins/image/__tests__/insert-image-handler.test.js +113 -0
  92. package/src/plugins/image/__tests__/mock-change.js +15 -0
  93. package/src/plugins/image/index.jsx +2 -1
  94. package/src/plugins/image/insert-image-handler.js +13 -6
  95. package/src/plugins/index.jsx +248 -5
  96. package/src/plugins/list/__tests__/index.test.js +54 -0
  97. package/src/plugins/list/index.jsx +130 -0
  98. package/src/plugins/math/__tests__/__snapshots__/index.test.jsx.snap +48 -0
  99. package/src/plugins/math/__tests__/index.test.jsx +245 -0
  100. package/src/plugins/math/index.jsx +87 -56
  101. package/src/plugins/media/__tests__/index.test.js +75 -0
  102. package/src/plugins/media/index.jsx +3 -2
  103. package/src/plugins/media/media-dialog.js +106 -57
  104. package/src/plugins/rendering/index.js +31 -0
  105. package/src/plugins/respArea/drag-in-the-blank/choice.jsx +4 -1
  106. package/src/plugins/respArea/explicit-constructed-response/index.jsx +10 -8
  107. package/src/plugins/respArea/index.jsx +53 -7
  108. package/src/plugins/respArea/inline-dropdown/index.jsx +13 -6
  109. package/src/plugins/respArea/math-templated/index.jsx +104 -0
  110. package/src/plugins/respArea/utils.jsx +11 -0
  111. package/src/plugins/table/CustomTablePlugin.js +113 -0
  112. package/src/plugins/table/__tests__/__snapshots__/table-toolbar.test.jsx.snap +44 -0
  113. package/src/plugins/table/__tests__/index.test.jsx +401 -0
  114. package/src/plugins/table/__tests__/table-toolbar.test.jsx +42 -0
  115. package/src/plugins/table/index.jsx +46 -59
  116. package/src/plugins/table/table-toolbar.jsx +39 -2
  117. package/src/plugins/textAlign/icons/index.jsx +139 -0
  118. package/src/plugins/textAlign/index.jsx +23 -0
  119. package/src/plugins/toolbar/__tests__/__snapshots__/default-toolbar.test.jsx.snap +923 -0
  120. package/src/plugins/toolbar/__tests__/__snapshots__/editor-and-toolbar.test.jsx.snap +20 -0
  121. package/src/plugins/toolbar/__tests__/__snapshots__/toolbar-buttons.test.jsx.snap +36 -0
  122. package/src/plugins/toolbar/__tests__/__snapshots__/toolbar.test.jsx.snap +46 -0
  123. package/src/plugins/toolbar/__tests__/default-toolbar.test.jsx +94 -0
  124. package/src/plugins/toolbar/__tests__/editor-and-toolbar.test.jsx +37 -0
  125. package/src/plugins/toolbar/__tests__/toolbar-buttons.test.jsx +51 -0
  126. package/src/plugins/toolbar/__tests__/toolbar.test.jsx +106 -0
  127. package/src/plugins/toolbar/default-toolbar.jsx +80 -20
  128. package/src/plugins/toolbar/done-button.jsx +3 -1
  129. package/src/plugins/toolbar/editor-and-toolbar.jsx +18 -13
  130. package/src/plugins/toolbar/toolbar-buttons.jsx +52 -11
  131. package/src/plugins/toolbar/toolbar.jsx +31 -8
  132. package/src/serialization.jsx +213 -38
  133. package/README.md +0 -45
  134. package/deploy.sh +0 -16
  135. package/lib/editor.js.map +0 -1
  136. package/lib/index.js.map +0 -1
  137. package/lib/parse-html.js.map +0 -1
  138. package/lib/plugins/characters/custom-popper.js.map +0 -1
  139. package/lib/plugins/characters/index.js.map +0 -1
  140. package/lib/plugins/characters/utils.js.map +0 -1
  141. package/lib/plugins/html/icons/index.js.map +0 -1
  142. package/lib/plugins/html/index.js.map +0 -1
  143. package/lib/plugins/image/alt-dialog.js.map +0 -1
  144. package/lib/plugins/image/component.js.map +0 -1
  145. package/lib/plugins/image/image-toolbar.js.map +0 -1
  146. package/lib/plugins/image/index.js.map +0 -1
  147. package/lib/plugins/image/insert-image-handler.js.map +0 -1
  148. package/lib/plugins/index.js.map +0 -1
  149. package/lib/plugins/list/index.js.map +0 -1
  150. package/lib/plugins/math/index.js.map +0 -1
  151. package/lib/plugins/media/index.js.map +0 -1
  152. package/lib/plugins/media/media-dialog.js.map +0 -1
  153. package/lib/plugins/media/media-toolbar.js.map +0 -1
  154. package/lib/plugins/media/media-wrapper.js.map +0 -1
  155. package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +0 -1
  156. package/lib/plugins/respArea/drag-in-the-blank/index.js.map +0 -1
  157. package/lib/plugins/respArea/explicit-constructed-response/index.js.map +0 -1
  158. package/lib/plugins/respArea/icons/index.js.map +0 -1
  159. package/lib/plugins/respArea/index.js.map +0 -1
  160. package/lib/plugins/respArea/inline-dropdown/index.js.map +0 -1
  161. package/lib/plugins/respArea/utils.js.map +0 -1
  162. package/lib/plugins/table/icons/index.js.map +0 -1
  163. package/lib/plugins/table/index.js.map +0 -1
  164. package/lib/plugins/table/table-toolbar.js.map +0 -1
  165. package/lib/plugins/toolbar/default-toolbar.js.map +0 -1
  166. package/lib/plugins/toolbar/done-button.js.map +0 -1
  167. package/lib/plugins/toolbar/editor-and-toolbar.js.map +0 -1
  168. package/lib/plugins/toolbar/index.js.map +0 -1
  169. package/lib/plugins/toolbar/toolbar-buttons.js.map +0 -1
  170. package/lib/plugins/toolbar/toolbar.js.map +0 -1
  171. package/lib/plugins/utils.js.map +0 -1
  172. package/lib/serialization.js.map +0 -1
  173. package/lib/theme.js.map +0 -1
  174. package/playground/image/data.js +0 -59
  175. package/playground/image/index.html +0 -22
  176. package/playground/image/index.jsx +0 -81
  177. package/playground/index.html +0 -25
  178. package/playground/mathquill/index.html +0 -22
  179. package/playground/mathquill/index.jsx +0 -155
  180. package/playground/package.json +0 -15
  181. package/playground/prod-test/index.html +0 -22
  182. package/playground/prod-test/index.jsx +0 -28
  183. package/playground/schema-override/data.js +0 -29
  184. package/playground/schema-override/image-plugin.jsx +0 -41
  185. package/playground/schema-override/index.html +0 -21
  186. package/playground/schema-override/index.jsx +0 -97
  187. package/playground/serialization/data.js +0 -29
  188. package/playground/serialization/image-plugin.jsx +0 -41
  189. package/playground/serialization/index.html +0 -22
  190. package/playground/serialization/index.jsx +0 -12
  191. package/playground/static.json +0 -3
  192. package/playground/table-examples.html +0 -70
  193. package/playground/webpack.config.js +0 -42
  194. package/static.json +0 -1
package/lib/editor.js CHANGED
@@ -21,6 +21,8 @@ Object.defineProperty(exports, "DEFAULT_PLUGINS", {
21
21
  });
22
22
  exports.serialization = exports["default"] = exports.Editor = void 0;
23
23
 
24
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
25
+
24
26
  var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
25
27
 
26
28
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
@@ -41,38 +43,40 @@ var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/ge
41
43
 
42
44
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
43
45
 
46
+ var _react = _interopRequireDefault(require("react"));
47
+
44
48
  var _slateReact = require("slate-react");
45
49
 
46
50
  var _slatePropTypes = _interopRequireDefault(require("slate-prop-types"));
47
51
 
48
- var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
49
-
50
- var serialization = _interopRequireWildcard(require("./serialization"));
52
+ var _slate = require("slate");
51
53
 
52
- exports.serialization = serialization;
54
+ var _slatePlainSerializer = _interopRequireDefault(require("slate-plain-serializer"));
53
55
 
54
56
  var _propTypes = _interopRequireDefault(require("prop-types"));
55
57
 
56
- var _react = _interopRequireDefault(require("react"));
57
-
58
- var _slate = require("slate");
58
+ var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
59
59
 
60
- var _plugins = require("./plugins");
60
+ var _classnames = _interopRequireDefault(require("classnames"));
61
61
 
62
62
  var _debug = _interopRequireDefault(require("debug"));
63
63
 
64
64
  var _styles = require("@material-ui/core/styles");
65
65
 
66
- var _classnames = _interopRequireDefault(require("classnames"));
67
-
68
66
  var _renderUi = require("@pie-lib/render-ui");
69
67
 
70
- var _slatePlainSerializer = _interopRequireDefault(require("slate-plain-serializer"));
71
-
72
68
  var _configUi = require("@pie-lib/config-ui");
73
69
 
70
+ var serialization = _interopRequireWildcard(require("./serialization"));
71
+
72
+ exports.serialization = serialization;
73
+
74
74
  var _insertImageHandler = _interopRequireDefault(require("./plugins/image/insert-image-handler"));
75
75
 
76
+ var _plugins = require("./plugins");
77
+
78
+ var _excluded = ["customPlugins", "showParagraphs", "separateParagraphs"];
79
+
76
80
  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); }
77
81
 
78
82
  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; }
@@ -106,6 +110,13 @@ var createToolbarOpts = function createToolbarOpts(toolbarOpts, error, isHtmlMod
106
110
  isHtmlMode: isHtmlMode
107
111
  });
108
112
  };
113
+ /**
114
+ * The maximum number of characters the editor can support
115
+ * @type {number}
116
+ */
117
+
118
+
119
+ var MAX_CHARACTERS_LIMIT = 1000000;
109
120
 
110
121
  var Editor = /*#__PURE__*/function (_React$Component) {
111
122
  (0, _inherits2["default"])(Editor, _React$Component);
@@ -117,18 +128,24 @@ var Editor = /*#__PURE__*/function (_React$Component) {
117
128
 
118
129
  (0, _classCallCheck2["default"])(this, Editor);
119
130
  _this = _super.call(this, _props);
120
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleAlertDialog", function (open, extraDialogProps, callback) {
131
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "setKeypadInteraction", function (interacted) {
132
+ _this.keypadInteractionDetected = interacted;
133
+ });
134
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleDialog", function (open) {
135
+ var extraDialogProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
136
+ var callback = arguments.length > 2 ? arguments[2] : undefined;
137
+
121
138
  _this.setState({
122
139
  dialog: _objectSpread({
123
140
  open: open
124
- }, extraDialogProps),
125
- isEdited: false
141
+ }, extraDialogProps)
126
142
  }, callback);
127
143
  });
128
144
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "toggleHtmlMode", function () {
129
145
  _this.setState(function (prevState) {
130
146
  return {
131
- isHtmlMode: !prevState.isHtmlMode
147
+ isHtmlMode: !prevState.isHtmlMode,
148
+ isEditedInHtmlMode: false
132
149
  };
133
150
  }, function () {
134
151
  var error = _this.props.error;
@@ -144,23 +161,49 @@ var Editor = /*#__PURE__*/function (_React$Component) {
144
161
  var normalizedResponseAreaProps = _objectSpread(_objectSpread({}, defaultResponseAreaProps), props.responseAreaProps);
145
162
 
146
163
  var htmlPluginOpts = {
164
+ currentValue: _this.props.value,
147
165
  isHtmlMode: _this.state.isHtmlMode,
148
- isEdited: _this.state.isEdited,
166
+ isEditedInHtmlMode: _this.state.isEditedInHtmlMode,
149
167
  toggleHtmlMode: _this.toggleHtmlMode,
150
- handleAlertDialog: _this.handleAlertDialog
168
+ handleAlertDialog: _this.handleDialog
151
169
  };
152
- _this.plugins = (0, _plugins.buildPlugins)(props.activePlugins, {
170
+
171
+ var _ref = props.pluginProps || {},
172
+ customPlugins = _ref.customPlugins;
173
+
174
+ customPlugins = customPlugins || [];
175
+ _this.plugins = (0, _plugins.buildPlugins)(props.activePlugins, customPlugins, {
153
176
  math: _objectSpread({
154
177
  onClick: _this.onMathClick,
155
178
  onFocus: _this.onPluginFocus,
156
179
  onBlur: _this.onPluginBlur
157
180
  }, props.mathMlOptions),
181
+ textAlign: {
182
+ getValue: function getValue() {
183
+ return _this.state.value;
184
+ },
185
+ onChange: _this.onChange
186
+ },
158
187
  html: htmlPluginOpts,
188
+ extraCSSRules: props.extraCSSRules || {},
159
189
  image: {
160
190
  disableImageAlignmentButtons: props.disableImageAlignmentButtons,
161
- onDelete: props.imageSupport && props.imageSupport["delete"] && function (src, done) {
191
+ onDelete: props.imageSupport && props.imageSupport["delete"] && function (node, done) {
192
+ var src = node.data.get('src');
162
193
  props.imageSupport["delete"](src, function (e) {
163
- done(e, _this.state.value);
194
+ var newPendingImages = _this.state.pendingImages.filter(function (img) {
195
+ return img.key !== node.key;
196
+ });
197
+
198
+ var oldScheduled = _this.state.scheduled;
199
+ var newState = {
200
+ pendingImages: newPendingImages,
201
+ scheduled: oldScheduled && newPendingImages.length === 0 ? false : oldScheduled
202
+ };
203
+
204
+ _this.setState(newState, function () {
205
+ return done(e, _this.state.value);
206
+ });
164
207
  });
165
208
  },
166
209
  insertImageRequested: props.imageSupport && function (addedImage, getHandler) {
@@ -206,8 +249,8 @@ var Editor = /*#__PURE__*/function (_React$Component) {
206
249
  },
207
250
  onFocus: _this.onPluginFocus,
208
251
  onBlur: _this.onPluginBlur,
209
- maxImageWidth: _this.props.maxImageWidth,
210
- maxImageHeight: _this.props.maxImageHeight
252
+ maxImageWidth: props.maxImageWidth,
253
+ maxImageHeight: props.maxImageHeight
211
254
  },
212
255
  toolbar: {
213
256
  /**
@@ -225,7 +268,8 @@ var Editor = /*#__PURE__*/function (_React$Component) {
225
268
 
226
269
  _this.setState({
227
270
  toolbarInFocus: false,
228
- focusedNode: null
271
+ focusedNode: null,
272
+ focusToolbar: false
229
273
  });
230
274
 
231
275
  _this.editor.blur();
@@ -270,6 +314,8 @@ var Editor = /*#__PURE__*/function (_React$Component) {
270
314
  }
271
315
  },
272
316
  languageCharacters: props.languageCharactersProps,
317
+ keyPadCharacterRef: _this.keyPadCharacterRef,
318
+ setKeypadInteraction: _this.setKeypadInteraction,
273
319
  media: {
274
320
  focus: _this.focus,
275
321
  createChange: function createChange() {
@@ -327,19 +373,33 @@ var Editor = /*#__PURE__*/function (_React$Component) {
327
373
  });
328
374
  });
329
375
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onEditingDone", function () {
330
- if (_this.state.isHtmlMode) {
376
+ var _this$state = _this.state,
377
+ isHtmlMode = _this$state.isHtmlMode,
378
+ dialog = _this$state.dialog,
379
+ value = _this$state.value,
380
+ pendingImages = _this$state.pendingImages; // Handling HTML mode and dialog state
381
+
382
+ if (isHtmlMode) {
383
+ // Early return if HTML mode is enabled
384
+ if (dialog !== null && dialog !== void 0 && dialog.open) return;
385
+ var currentValue = (0, serialization.htmlToValue)(value.document.text);
386
+
387
+ var previewText = _this.renderHtmlPreviewContent();
388
+
389
+ _this.openHtmlModeConfirmationDialog(currentValue, previewText);
390
+
331
391
  return;
332
392
  }
333
393
 
334
- var pendingImages = _this.state.pendingImages;
335
-
336
394
  if (pendingImages.length) {
395
+ // schedule image processing
337
396
  _this.setState({
338
397
  scheduled: true
339
398
  });
340
399
 
341
400
  return;
342
- }
401
+ } // Finalizing editing
402
+
343
403
 
344
404
  log('[onEditingDone]');
345
405
 
@@ -353,6 +413,46 @@ var Editor = /*#__PURE__*/function (_React$Component) {
353
413
 
354
414
  _this.props.onChange(_this.state.value, true);
355
415
  });
416
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "renderHtmlPreviewContent", function () {
417
+ var classes = _this.props.classes;
418
+ return /*#__PURE__*/_react["default"].createElement("div", {
419
+ ref: function ref(_ref2) {
420
+ return _this.elementRef = _ref2;
421
+ }
422
+ }, /*#__PURE__*/_react["default"].createElement("div", null, "Preview of Edited Html:"), /*#__PURE__*/_react["default"].createElement(_renderUi.PreviewPrompt, {
423
+ defaultClassName: classes.previewText,
424
+ prompt: _this.state.value.document.text
425
+ }), /*#__PURE__*/_react["default"].createElement("div", null, "Would you like to save these changes ?"));
426
+ });
427
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "openHtmlModeConfirmationDialog", function (currentValue, previewText) {
428
+ _this.setState({
429
+ dialog: {
430
+ open: true,
431
+ title: 'Content Preview & Save',
432
+ text: previewText,
433
+ onConfirmText: 'Save changes',
434
+ onCloseText: 'Continue editing',
435
+ onConfirm: function onConfirm() {
436
+ _this.handleHtmlModeSaveConfirmation(currentValue);
437
+ },
438
+ onClose: _this.htmlModeContinueEditing
439
+ }
440
+ });
441
+ });
442
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleHtmlModeSaveConfirmation", function (currentValue) {
443
+ _this.setState({
444
+ value: currentValue
445
+ });
446
+
447
+ _this.props.onChange(currentValue, true);
448
+
449
+ _this.handleDialog(false);
450
+
451
+ _this.toggleHtmlMode();
452
+ });
453
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "htmlModeContinueEditing", function () {
454
+ _this.handleDialog(false);
455
+ });
356
456
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleBlur", function (resolve) {
357
457
  var nonEmpty = _this.props.nonEmpty;
358
458
  var doneOn = _this.state.toolbarOpts.doneOn;
@@ -383,15 +483,33 @@ var Editor = /*#__PURE__*/function (_React$Component) {
383
483
  }
384
484
  });
385
485
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onBlur", function (event) {
486
+ var _this$doneButtonRef$c;
487
+
386
488
  log('[onBlur]');
387
- var target = event.relatedTarget;
388
- var node = target ? (0, _slateReact.findNode)(target, _this.state.value) : null;
489
+ var relatedTarget = event.relatedTarget;
490
+ 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
491
+
492
+ 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
493
+
494
+ _this.skipBlurHandling = _this.keypadInteractionDetected && relatedTarget !== null;
495
+
496
+ if (toolbarElement && !isRawDoneButton && !_this.state.focusToolbar) {
497
+ _this.setState({
498
+ focusToolbar: true
499
+ });
500
+ }
501
+
502
+ var node = relatedTarget ? (0, _slateReact.findNode)(relatedTarget, _this.state.value) : null;
389
503
  log('[onBlur] node: ', node);
390
504
  return new Promise(function (resolve) {
391
- _this.setState({
392
- preBlurValue: _this.state.value,
393
- focusedNode: !node ? null : node
394
- }, _this.handleBlur.bind((0, _assertThisInitialized2["default"])(_this), resolve));
505
+ if (!_this.skipBlurHandling) {
506
+ _this.setKeypadInteraction(false);
507
+
508
+ _this.setState({
509
+ preBlurValue: _this.state.value,
510
+ focusedNode: !node ? null : node
511
+ }, _this.handleBlur.bind((0, _assertThisInitialized2["default"])(_this), resolve));
512
+ }
395
513
 
396
514
  _this.props.onBlur(event);
397
515
  });
@@ -419,14 +537,22 @@ var Editor = /*#__PURE__*/function (_React$Component) {
419
537
  }
420
538
  }, 50);
421
539
  });
422
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onFocus", function () {
540
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onFocus", function (event, change) {
423
541
  return new Promise(function (resolve) {
542
+ var _navigator;
543
+
424
544
  var editorDOM = document.querySelector("[data-key=\"".concat(_this.state.value.document.key, "\"]"));
545
+ var isTouchDevice = typeof window !== 'undefined' && ('ontouchstart' in window || ((_navigator = navigator) === null || _navigator === void 0 ? void 0 : _navigator.maxTouchPoints) > 0);
425
546
  log('[onFocus]', document.activeElement);
547
+
548
+ if (_this.keypadInteractionDetected && _this.__TEMPORARY_CHANGE_DATA) {
549
+ _this.__TEMPORARY_CHANGE_DATA = null;
550
+ }
426
551
  /**
427
552
  * This is a temporary hack - @see changeData below for some more information.
428
553
  */
429
554
 
555
+
430
556
  if (_this.__TEMPORARY_CHANGE_DATA) {
431
557
  var _this$__TEMPORARY_CHA = _this.__TEMPORARY_CHANGE_DATA,
432
558
  key = _this$__TEMPORARY_CHA.key,
@@ -434,12 +560,12 @@ var Editor = /*#__PURE__*/function (_React$Component) {
434
560
  var domEl = document.querySelector("[data-key=\"".concat(key, "\"]"));
435
561
 
436
562
  if (domEl) {
437
- var change = _this.state.value.change().setNodeByKey(key, {
563
+ var _change = _this.state.value.change().setNodeByKey(key, {
438
564
  data: data
439
565
  });
440
566
 
441
567
  _this.setState({
442
- value: change.value
568
+ value: _change.value
443
569
  }, function () {
444
570
  _this.__TEMPORARY_CHANGE_DATA = null;
445
571
  });
@@ -460,7 +586,14 @@ var Editor = /*#__PURE__*/function (_React$Component) {
460
586
 
461
587
  _this.stashValue();
462
588
 
463
- _this.props.onFocus();
589
+ _this.props.onFocus(); // Added for accessibility: Ensures the editor gains focus when tabbed to for improved keyboard navigation
590
+
591
+
592
+ var shouldFocusEditor = !_this.keypadInteractionDetected && !isTouchDevice;
593
+
594
+ if (shouldFocusEditor) {
595
+ change === null || change === void 0 ? void 0 : change.focus();
596
+ }
464
597
 
465
598
  resolve();
466
599
  });
@@ -475,9 +608,9 @@ var Editor = /*#__PURE__*/function (_React$Component) {
475
608
  }
476
609
  });
477
610
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "resetValue", function (force) {
478
- var _this$state = _this.state,
479
- value = _this$state.value,
480
- focusedNode = _this$state.focusedNode;
611
+ var _this$state2 = _this.state,
612
+ value = _this$state2.value,
613
+ focusedNode = _this$state2.focusedNode;
481
614
 
482
615
  var stopReset = _this.plugins.reduce(function (s, p) {
483
616
  return s || p.stopReset && p.stopReset(_this.state.value);
@@ -510,20 +643,30 @@ var Editor = /*#__PURE__*/function (_React$Component) {
510
643
  });
511
644
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onChange", function (change, done) {
512
645
  log('[onChange]');
646
+ window.me = (0, _assertThisInitialized2["default"])(_this);
513
647
  var value = change.value;
514
648
  var charactersLimit = _this.props.charactersLimit;
649
+ var limit = charactersLimit;
515
650
 
516
- if (value && value.document && value.document.text && value.document.text.length > charactersLimit) {
651
+ if (!limit || limit > MAX_CHARACTERS_LIMIT) {
652
+ limit = MAX_CHARACTERS_LIMIT;
653
+ }
654
+
655
+ if (value && value.document && value.document.text && value.document.text.length > limit) {
517
656
  return;
518
657
  } // Mark the editor as edited when in HTML mode and its content has changed.
519
658
  // This status will later be used to decide whether to prompt a warning to the user when exiting HTML mode.
520
659
 
521
660
 
522
- var isEdited = !_this.state.isHtmlMode ? false : _this.state.value.document.text !== value.document.text ? true : _this.state.isEdited;
661
+ var isEditedInHtmlMode = !_this.state.isHtmlMode ? false : _this.state.value.document.text !== value.document.text ? true : _this.state.isEditedInHtmlMode;
662
+
663
+ if (isEditedInHtmlMode != _this.state.isEditedInHtmlMode) {
664
+ _this.handlePlugins(_this.props);
665
+ }
523
666
 
524
667
  _this.setState({
525
668
  value: value,
526
- isEdited: isEdited
669
+ isEditedInHtmlMode: isEditedInHtmlMode
527
670
  }, function () {
528
671
  log('[onChange], call done()');
529
672
 
@@ -544,10 +687,12 @@ var Editor = /*#__PURE__*/function (_React$Component) {
544
687
  return;
545
688
  }
546
689
 
690
+ var calcRegex = /^calc\((.*)\)$/;
691
+
547
692
  if (typeof v === 'string') {
548
693
  if (v.endsWith('%')) {
549
694
  return undefined;
550
- } else if (v.endsWith('px') || v.endsWith('vh') || v.endsWith('vw')) {
695
+ } else if (v.endsWith('px') || v.endsWith('vh') || v.endsWith('vw') || v.endsWith('ch') || v.endsWith('em') || v.match(calcRegex)) {
551
696
  return v;
552
697
  } else {
553
698
  var value = parseInt(v, 10);
@@ -558,8 +703,6 @@ var Editor = /*#__PURE__*/function (_React$Component) {
558
703
  if (typeof v === 'number') {
559
704
  return "".concat(v, "px");
560
705
  }
561
-
562
- return;
563
706
  });
564
707
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "validateNode", function (node) {
565
708
  if (node.object !== 'block') return;
@@ -586,7 +729,7 @@ var Editor = /*#__PURE__*/function (_React$Component) {
586
729
  * on this hack rather than spend more time on this.
587
730
  */
588
731
  // Uncomment this line to see the bug described above.
589
- // this.setState({changeData: {key, data}})
732
+ // this.setState({changeData: {key, data}})
590
733
 
591
734
  _this.__TEMPORARY_CHANGE_DATA = {
592
735
  key: key,
@@ -599,7 +742,7 @@ var Editor = /*#__PURE__*/function (_React$Component) {
599
742
  _this.props.focus(position, node);
600
743
  });
601
744
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onDropPaste", /*#__PURE__*/function () {
602
- var _ref = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(event, change, dropContext) {
745
+ var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(event, change, dropContext) {
603
746
  var editor, transfer, file, type, fragment, text, src, inline, range, ch, handler, _change$value, _document, selection, startBlock, defaultBlock, defaultMarks, frag;
604
747
 
605
748
  return _regenerator["default"].wrap(function _callee$(_context) {
@@ -726,14 +869,14 @@ var Editor = /*#__PURE__*/function (_React$Component) {
726
869
  }));
727
870
 
728
871
  return function (_x, _x2, _x3) {
729
- return _ref.apply(this, arguments);
872
+ return _ref3.apply(this, arguments);
730
873
  };
731
874
  }());
732
875
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "renderPlaceholder", function (props) {
733
876
  var editor = props.editor;
734
877
  var document = editor.value.document;
735
878
 
736
- if (!editor.props.placeholder || document.text !== '' || document.nodes.size !== 1) {
879
+ if (!editor.props.placeholder || document.text !== '' || document.nodes.size !== 1 || !document.isEmpty) {
737
880
  return false;
738
881
  }
739
882
 
@@ -756,15 +899,23 @@ var Editor = /*#__PURE__*/function (_React$Component) {
756
899
  toolbarOpts: createToolbarOpts(_props.toolbarOpts, _props.error),
757
900
  pendingImages: [],
758
901
  isHtmlMode: false,
759
- isEdited: false,
902
+ isEditedInHtmlMode: false,
903
+ focusToolbar: false,
760
904
  dialog: {
761
905
  open: false
762
906
  }
763
907
  };
908
+ _this.keyPadCharacterRef = /*#__PURE__*/_react["default"].createRef();
909
+ _this.doneButtonRef = /*#__PURE__*/_react["default"].createRef();
910
+ _this.keypadInteractionDetected = false;
764
911
  _this.toggleHtmlMode = _this.toggleHtmlMode.bind((0, _assertThisInitialized2["default"])(_this));
912
+ _this.handleToolbarFocus = _this.handleToolbarFocus.bind((0, _assertThisInitialized2["default"])(_this));
913
+ _this.handleToolbarBlur = _this.handleToolbarBlur.bind((0, _assertThisInitialized2["default"])(_this));
765
914
 
766
915
  _this.onResize = function () {
767
- _props.onChange(_this.state.value, true);
916
+ if (!_this.state.isHtmlMode && _props.onChange) {
917
+ _props.onChange(_this.state.value, true);
918
+ }
768
919
  };
769
920
 
770
921
  _this.handlePlugins(_this.props);
@@ -773,20 +924,62 @@ var Editor = /*#__PURE__*/function (_React$Component) {
773
924
  }
774
925
 
775
926
  (0, _createClass2["default"])(Editor, [{
927
+ key: "handleToolbarFocus",
928
+ value: function handleToolbarFocus() {
929
+ if (this.state.focusToolbar) {
930
+ return;
931
+ }
932
+
933
+ this.setState({
934
+ focusToolbar: true
935
+ });
936
+ }
937
+ }, {
938
+ key: "handleToolbarBlur",
939
+ value: function handleToolbarBlur() {
940
+ var _this2 = this;
941
+
942
+ setTimeout(function () {
943
+ if (!_this2.toolbarContainsFocus()) {
944
+ _this2.setState({
945
+ focusToolbar: false
946
+ });
947
+ }
948
+ }, 0);
949
+ }
950
+ }, {
951
+ key: "toolbarContainsFocus",
952
+ value: function toolbarContainsFocus() {
953
+ if (!this.toolbarRef) return false;
954
+ var toolbarElement = this.toolbarRef;
955
+ var activeElement = document.activeElement;
956
+ return toolbarElement && toolbarElement.contains(activeElement);
957
+ }
958
+ }, {
776
959
  key: "componentDidMount",
777
960
  value: function componentDidMount() {
778
- var _this2 = this;
961
+ var _this$props$className,
962
+ _this3 = this;
779
963
 
780
964
  // onRef is needed to get the ref of the component because we export it using withStyles
781
965
  this.props.onRef(this);
782
966
  window.addEventListener('resize', this.onResize);
967
+ var isResponseAreaEditor = (_this$props$className = this.props.className) === null || _this$props$className === void 0 ? void 0 : _this$props$className.includes('response-area-editor');
968
+
969
+ if (isResponseAreaEditor && this.editor) {
970
+ var responseAreaEditor = document.querySelector("[data-key=\"".concat(this.editor.value.document.key, "\"]"));
971
+
972
+ if (responseAreaEditor) {
973
+ responseAreaEditor.setAttribute('aria-label', 'Answer');
974
+ }
975
+ }
783
976
 
784
977
  if (this.editor && this.props.autoFocus) {
785
978
  Promise.resolve().then(function () {
786
- if (_this2.editor) {
787
- var editorDOM = document.querySelector("[data-key=\"".concat(_this2.editor.value.document.key, "\"]"));
979
+ if (_this3.editor) {
980
+ var editorDOM = document.querySelector("[data-key=\"".concat(_this3.editor.value.document.key, "\"]"));
788
981
 
789
- _this2.editor.focus();
982
+ _this3.editor.focus();
790
983
 
791
984
  if (editorDOM) {
792
985
  editorDOM.focus();
@@ -800,9 +993,9 @@ var Editor = /*#__PURE__*/function (_React$Component) {
800
993
  value: function UNSAFE_componentWillReceiveProps(nextProps) {
801
994
  var _nextProps$value, _nextProps$value$docu, _this$props$value;
802
995
 
803
- var _this$state2 = this.state,
804
- isHtmlMode = _this$state2.isHtmlMode,
805
- toolbarOpts = _this$state2.toolbarOpts;
996
+ var _this$state3 = this.state,
997
+ isHtmlMode = _this$state3.isHtmlMode,
998
+ toolbarOpts = _this$state3.toolbarOpts;
806
999
  var newToolbarOpts = createToolbarOpts(nextProps.toolbarOpts, nextProps.error, isHtmlMode);
807
1000
 
808
1001
  if (!(0, _isEqual["default"])(newToolbarOpts, toolbarOpts)) {
@@ -813,8 +1006,9 @@ var Editor = /*#__PURE__*/function (_React$Component) {
813
1006
 
814
1007
  var differentCharacterProps = !(0, _isEqual["default"])(nextProps.languageCharactersProps, this.props.languageCharactersProps);
815
1008
  var differentMathMlProps = !(0, _isEqual["default"])(nextProps.mathMlOptions, this.props.mathMlOptions);
1009
+ var differentImageMaxDimensionsProps = !(0, _isEqual["default"])(nextProps.maxImageWidth, this.props.maxImageWidth) || !(0, _isEqual["default"])(nextProps.maxImageHeight, this.props.maxImageHeight);
816
1010
 
817
- if (differentCharacterProps || differentMathMlProps) {
1011
+ if (differentCharacterProps || differentMathMlProps || differentImageMaxDimensionsProps) {
818
1012
  this.handlePlugins(nextProps);
819
1013
  }
820
1014
 
@@ -833,9 +1027,8 @@ var Editor = /*#__PURE__*/function (_React$Component) {
833
1027
  // Trigger plugins and finish editing if:
834
1028
  // 1. The 'isHtmlMode' state has been toggled.
835
1029
  // 2. We're currently in 'isHtmlMode' and the editor value has been modified.
836
- if (this.state.isHtmlMode !== prevState.isHtmlMode || this.state.isHtmlMode && !prevState.isEdited && this.state.isEdited) {
1030
+ if (this.state.isHtmlMode !== prevState.isHtmlMode || this.state.isHtmlMode && !prevState.isEditedInHtmlMode && this.state.isEditedInHtmlMode) {
837
1031
  this.handlePlugins(this.props);
838
- this.onEditingDone();
839
1032
  }
840
1033
 
841
1034
  var zeroWidthEls = document.querySelectorAll('[data-slate-zero-width="z"]');
@@ -858,12 +1051,16 @@ var Editor = /*#__PURE__*/function (_React$Component) {
858
1051
  key: "buildSizeStyle",
859
1052
  value: function buildSizeStyle() {
860
1053
  var _this$props = this.props,
1054
+ minWidth = _this$props.minWidth,
861
1055
  width = _this$props.width,
1056
+ maxWidth = _this$props.maxWidth,
862
1057
  minHeight = _this$props.minHeight,
863
1058
  height = _this$props.height,
864
1059
  maxHeight = _this$props.maxHeight;
865
1060
  return {
866
1061
  width: this.valueToSize(width),
1062
+ minWidth: this.valueToSize(minWidth),
1063
+ maxWidth: this.valueToSize(maxWidth),
867
1064
  height: this.valueToSize(height),
868
1065
  minHeight: this.valueToSize(minHeight),
869
1066
  maxHeight: this.valueToSize(maxHeight)
@@ -873,7 +1070,9 @@ var Editor = /*#__PURE__*/function (_React$Component) {
873
1070
  key: "render",
874
1071
  value: function render() {
875
1072
  var _classNames,
876
- _this3 = this;
1073
+ _this4 = this,
1074
+ _value$document,
1075
+ _classNames2;
877
1076
 
878
1077
  var _this$props2 = this.props,
879
1078
  disabled = _this$props2.disabled,
@@ -881,54 +1080,72 @@ var Editor = /*#__PURE__*/function (_React$Component) {
881
1080
  highlightShape = _this$props2.highlightShape,
882
1081
  classes = _this$props2.classes,
883
1082
  className = _this$props2.className,
1083
+ isEditor = _this$props2.isEditor,
884
1084
  placeholder = _this$props2.placeholder,
885
1085
  pluginProps = _this$props2.pluginProps,
886
- onKeyDown = _this$props2.onKeyDown;
887
- var _this$state3 = this.state,
888
- value = _this$state3.value,
889
- focusedNode = _this$state3.focusedNode,
890
- toolbarOpts = _this$state3.toolbarOpts,
891
- dialog = _this$state3.dialog,
892
- scheduled = _this$state3.scheduled;
1086
+ onKeyDown = _this$props2.onKeyDown; // We don't want to send customPlugins to slate.
1087
+ // Not sure if they would do any harm, but I think it's better to not send them.
1088
+ // We use custom plugins to be able to add custom buttons
1089
+ // eslint-disable-next-line no-unused-vars
1090
+
1091
+ var _ref4 = pluginProps || {},
1092
+ customPlugins = _ref4.customPlugins,
1093
+ showParagraphs = _ref4.showParagraphs,
1094
+ separateParagraphs = _ref4.separateParagraphs,
1095
+ otherPluginProps = (0, _objectWithoutProperties2["default"])(_ref4, _excluded);
1096
+
1097
+ var _this$state4 = this.state,
1098
+ value = _this$state4.value,
1099
+ focusedNode = _this$state4.focusedNode,
1100
+ toolbarOpts = _this$state4.toolbarOpts,
1101
+ dialog = _this$state4.dialog,
1102
+ scheduled = _this$state4.scheduled;
893
1103
  log('[render] value: ', value);
894
1104
  var sizeStyle = this.buildSizeStyle();
895
1105
  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);
896
1106
  return /*#__PURE__*/_react["default"].createElement("div", {
897
- ref: function ref(_ref2) {
898
- return _this3.wrapperRef = _ref2;
1107
+ ref: function ref(_ref5) {
1108
+ return _this4.wrapperRef = _ref5;
899
1109
  },
900
1110
  style: {
901
- width: sizeStyle.width
1111
+ width: sizeStyle.width,
1112
+ minWidth: sizeStyle.minWidth,
1113
+ maxWidth: sizeStyle.maxWidth
902
1114
  },
903
- className: names
1115
+ className: names,
1116
+ id: "editor-".concat(value === null || value === void 0 ? void 0 : (_value$document = value.document) === null || _value$document === void 0 ? void 0 : _value$document.key)
904
1117
  }, scheduled && /*#__PURE__*/_react["default"].createElement("div", {
905
1118
  className: classes.uploading
906
1119
  }, "Uploading image and then saving..."), /*#__PURE__*/_react["default"].createElement(_slateReact.Editor, {
907
1120
  plugins: this.plugins,
908
1121
  innerRef: function innerRef(r) {
909
1122
  if (r) {
910
- _this3.slateEditor = r;
1123
+ _this4.slateEditor = r;
911
1124
  }
912
1125
  },
913
1126
  ref: function ref(r) {
914
- return _this3.editor = r && _this3.props.editorRef(r);
1127
+ return _this4.editor = r && _this4.props.editorRef(r);
915
1128
  },
916
1129
  toolbarRef: function toolbarRef(r) {
917
1130
  if (r) {
918
- _this3.toolbarRef = r;
1131
+ _this4.toolbarRef = r;
919
1132
  }
920
1133
  },
1134
+ doneButtonRef: this.doneButtonRef,
921
1135
  value: value,
1136
+ focusToolbar: this.state.focusToolbar,
1137
+ onToolbarFocus: this.handleToolbarFocus,
1138
+ onToolbarBlur: this.handleToolbarBlur,
922
1139
  focus: this.focus,
923
1140
  onKeyDown: onKeyDown,
924
1141
  onChange: this.onChange,
925
1142
  getFocusedValue: this.getFocusedValue,
926
1143
  onBlur: this.onBlur,
927
1144
  onDrop: function onDrop(event, editor) {
928
- return _this3.onDropPaste(event, editor, true);
1145
+ return _this4.onDropPaste(event, editor, true);
929
1146
  },
930
1147
  onPaste: function onPaste(event, editor) {
931
- return _this3.onDropPaste(event, editor);
1148
+ return _this4.onDropPaste(event, editor);
932
1149
  },
933
1150
  onFocus: this.onFocus,
934
1151
  onEditingDone: this.onEditingDone,
@@ -937,13 +1154,13 @@ var Editor = /*#__PURE__*/function (_React$Component) {
937
1154
  readOnly: disabled,
938
1155
  spellCheck: spellCheck,
939
1156
  autoCorrect: spellCheck,
940
- className: (0, _classnames["default"])((0, _defineProperty2["default"])({}, classes.noPadding, toolbarOpts && toolbarOpts.noBorder), classes.slateEditor),
1157
+ 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),
941
1158
  style: {
942
1159
  minHeight: sizeStyle.minHeight,
943
1160
  height: sizeStyle.height,
944
1161
  maxHeight: sizeStyle.maxHeight
945
1162
  },
946
- pluginProps: pluginProps,
1163
+ pluginProps: otherPluginProps,
947
1164
  toolbarOpts: toolbarOpts,
948
1165
  placeholder: placeholder,
949
1166
  renderPlaceholder: this.renderPlaceholder,
@@ -953,7 +1170,9 @@ var Editor = /*#__PURE__*/function (_React$Component) {
953
1170
  title: dialog.title,
954
1171
  text: dialog.text,
955
1172
  onClose: dialog.onClose,
956
- onConfirm: dialog.onConfirm
1173
+ onConfirm: dialog.onConfirm,
1174
+ onConfirmText: dialog.onConfirmText,
1175
+ onCloseText: dialog.onCloseText
957
1176
  }));
958
1177
  }
959
1178
  }]);
@@ -985,6 +1204,8 @@ exports.Editor = Editor;
985
1204
  }),
986
1205
  charactersLimit: _propTypes["default"].number,
987
1206
  width: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
1207
+ minWidth: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
1208
+ maxWidth: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
988
1209
  height: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
989
1210
  minHeight: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
990
1211
  maxHeight: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]),
@@ -997,12 +1218,28 @@ exports.Editor = Editor;
997
1218
  disableUnderline: _propTypes["default"].bool,
998
1219
  autoWidthToolbar: _propTypes["default"].bool,
999
1220
  pluginProps: _propTypes["default"].any,
1221
+ // customPlugins should be inside pluginProps (a property inside pluginProps)
1222
+ // customPlugins: PropTypes.arrayOf(
1223
+ // PropTypes.shape({
1224
+ // event: PropTypes.string,
1225
+ // icon: PropTypes.string,
1226
+ // iconType: PropTypes.string,
1227
+ // iconAlt: PropTypes.string
1228
+ // }),
1229
+ // ),
1000
1230
  placeholder: _propTypes["default"].string,
1231
+ isEditor: _propTypes["default"].bool,
1001
1232
  responseAreaProps: _propTypes["default"].shape({
1002
- type: _propTypes["default"].oneOf(['explicit-constructed-response', 'inline-dropdown', 'drag-in-the-blank']),
1233
+ type: _propTypes["default"].oneOf(['explicit-constructed-response', 'inline-dropdown', 'drag-in-the-blank', 'math-templated']),
1003
1234
  options: _propTypes["default"].object,
1004
1235
  respAreaToolbar: _propTypes["default"].func,
1005
- onHandleAreaChange: _propTypes["default"].func
1236
+ onHandleAreaChange: _propTypes["default"].func,
1237
+ maxResponseAreas: _propTypes["default"].number,
1238
+ error: _propTypes["default"].any
1239
+ }),
1240
+ extraCSSRules: _propTypes["default"].shape({
1241
+ names: _propTypes["default"].arrayOf(_propTypes["default"].string),
1242
+ rules: _propTypes["default"].string
1006
1243
  }),
1007
1244
  languageCharactersProps: _propTypes["default"].arrayOf(_propTypes["default"].shape({
1008
1245
  language: _propTypes["default"].string,
@@ -1015,7 +1252,8 @@ exports.Editor = Editor;
1015
1252
  alignment: _propTypes["default"].oneOf(['left', 'right']),
1016
1253
  alwaysVisible: _propTypes["default"].bool,
1017
1254
  showDone: _propTypes["default"].bool,
1018
- doneOn: _propTypes["default"].string
1255
+ doneOn: _propTypes["default"].string,
1256
+ minWidth: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number])
1019
1257
  }),
1020
1258
  activePlugins: _propTypes["default"].arrayOf(function (values) {
1021
1259
  var allValid = values.every(function (v) {
@@ -1039,7 +1277,9 @@ exports.Editor = Editor;
1039
1277
  },
1040
1278
  toolbarOpts: defaultToolbarOpts,
1041
1279
  responseAreaProps: defaultResponseAreaProps,
1042
- languageCharactersProps: defaultLanguageCharactersProps
1280
+ languageCharactersProps: defaultLanguageCharactersProps,
1281
+ extraCSSRules: null,
1282
+ isEditor: false
1043
1283
  });
1044
1284
  var styles = {
1045
1285
  withBg: {
@@ -1080,15 +1320,36 @@ var styles = {
1080
1320
  border: '1px solid #dfe2e5'
1081
1321
  }
1082
1322
  },
1323
+ showParagraph: {
1324
+ // a div that has a div after it
1325
+ '& > div:has(+ div)::after': {
1326
+ display: 'block',
1327
+ content: '"¶"',
1328
+ fontSize: '1em',
1329
+ color: '#146EB3'
1330
+ }
1331
+ },
1332
+ separateParagraph: {
1333
+ // a div that has a div after it
1334
+ '& > div:has(+ div)': {
1335
+ marginBottom: '1em'
1336
+ }
1337
+ },
1083
1338
  toolbarOnTop: {
1084
1339
  marginTop: '45px'
1085
1340
  },
1086
1341
  noPadding: {
1087
1342
  padding: '0 !important'
1343
+ },
1344
+ previewText: {
1345
+ marginBottom: '36px',
1346
+ marginTop: '6px',
1347
+ padding: '20px',
1348
+ backgroundColor: 'rgba(0,0,0,0.06)'
1088
1349
  }
1089
1350
  };
1090
1351
 
1091
1352
  var _default = (0, _styles.withStyles)(styles)(Editor);
1092
1353
 
1093
1354
  exports["default"] = _default;
1094
- //# sourceMappingURL=editor.js.map
1355
+ //# 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 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 '@pie-lib/config-ui';\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 = () => {\n      if (!this.state.isHtmlMode && props.onChange) {\n        props.onChange(this.state.value, true);\n      }\n    };\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"]}