@pie-lib/editable-html 9.5.13 → 10.0.0-beta.1

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 (144) hide show
  1. package/CHANGELOG.md +0 -302
  2. package/lib/components.js +116 -0
  3. package/lib/components.js.map +1 -0
  4. package/lib/editor.js +418 -103
  5. package/lib/editor.js.map +1 -1
  6. package/lib/index.js +101 -155
  7. package/lib/index.js.map +1 -1
  8. package/lib/new-serialization.js +320 -0
  9. package/lib/new-serialization.js.map +1 -0
  10. package/lib/old-serialization.js +330 -0
  11. package/lib/parse-html.js +1 -1
  12. package/lib/parse-html.js.map +1 -1
  13. package/lib/plugins/characters/custom-popper.js +1 -1
  14. package/lib/plugins/characters/custom-popper.js.map +1 -1
  15. package/lib/plugins/characters/index.js +21 -19
  16. package/lib/plugins/characters/index.js.map +1 -1
  17. package/lib/plugins/characters/utils.js +1 -1
  18. package/lib/plugins/characters/utils.js.map +1 -1
  19. package/lib/plugins/hotKeys/index.js +67 -0
  20. package/lib/plugins/hotKeys/index.js.map +1 -0
  21. package/lib/plugins/image/alt-dialog.js +1 -6
  22. package/lib/plugins/image/alt-dialog.js.map +1 -1
  23. package/lib/plugins/image/component.js +70 -53
  24. package/lib/plugins/image/component.js.map +1 -1
  25. package/lib/plugins/image/image-toolbar.js +7 -9
  26. package/lib/plugins/image/image-toolbar.js.map +1 -1
  27. package/lib/plugins/image/index.js +83 -27
  28. package/lib/plugins/image/index.js.map +1 -1
  29. package/lib/plugins/image/insert-image-handler.js +72 -33
  30. package/lib/plugins/image/insert-image-handler.js.map +1 -1
  31. package/lib/plugins/index.js +23 -41
  32. package/lib/plugins/index.js.map +1 -1
  33. package/lib/plugins/list/index.js +64 -100
  34. package/lib/plugins/list/index.js.map +1 -1
  35. package/lib/plugins/math/index.js +86 -60
  36. package/lib/plugins/math/index.js.map +1 -1
  37. package/lib/plugins/media/index.js +202 -132
  38. package/lib/plugins/media/index.js.map +1 -1
  39. package/lib/plugins/media/media-dialog.js +17 -16
  40. package/lib/plugins/media/media-dialog.js.map +1 -1
  41. package/lib/plugins/media/media-toolbar.js +3 -3
  42. package/lib/plugins/media/media-toolbar.js.map +1 -1
  43. package/lib/plugins/media/media-wrapper.js +21 -58
  44. package/lib/plugins/media/media-wrapper.js.map +1 -1
  45. package/lib/plugins/respArea/drag-in-the-blank/choice.js +3 -3
  46. package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
  47. package/lib/plugins/respArea/drag-in-the-blank/index.js +3 -2
  48. package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
  49. package/lib/plugins/respArea/explicit-constructed-response/index.js +3 -2
  50. package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
  51. package/lib/plugins/respArea/icons/index.js +13 -15
  52. package/lib/plugins/respArea/icons/index.js.map +1 -1
  53. package/lib/plugins/respArea/index.js +87 -53
  54. package/lib/plugins/respArea/index.js.map +1 -1
  55. package/lib/plugins/respArea/inline-dropdown/index.js +4 -3
  56. package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
  57. package/lib/plugins/respArea/utils.js +17 -20
  58. package/lib/plugins/respArea/utils.js.map +1 -1
  59. package/lib/plugins/table/icons/index.js +1 -1
  60. package/lib/plugins/table/icons/index.js.map +1 -1
  61. package/lib/plugins/table/index.js +381 -212
  62. package/lib/plugins/table/index.js.map +1 -1
  63. package/lib/plugins/table/table-toolbar.js +5 -6
  64. package/lib/plugins/table/table-toolbar.js.map +1 -1
  65. package/lib/plugins/toolbar/default-toolbar.js +55 -11
  66. package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
  67. package/lib/plugins/toolbar/done-button.js +1 -1
  68. package/lib/plugins/toolbar/done-button.js.map +1 -1
  69. package/lib/plugins/toolbar/editor-and-toolbar.js +186 -232
  70. package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
  71. package/lib/plugins/toolbar/index.js +1 -2
  72. package/lib/plugins/toolbar/index.js.map +1 -1
  73. package/lib/plugins/toolbar/toolbar-buttons.js +1 -1
  74. package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
  75. package/lib/plugins/toolbar/toolbar.js +253 -239
  76. package/lib/plugins/toolbar/toolbar.js.map +1 -1
  77. package/lib/plugins/utils.js +27 -2
  78. package/lib/plugins/utils.js.map +1 -1
  79. package/lib/serialization.js +1 -1
  80. package/lib/serialization.js.map +1 -1
  81. package/lib/slate-editor.js +302 -0
  82. package/lib/test-serializer.js +189 -0
  83. package/lib/test-serializer.js.map +1 -0
  84. package/lib/theme.js +1 -1
  85. package/lib/theme.js.map +1 -1
  86. package/package.json +18 -14
  87. package/playground/image/data.js +20 -20
  88. package/playground/image/index.html +22 -20
  89. package/playground/image/index.jsx +12 -10
  90. package/playground/index.html +25 -23
  91. package/playground/mathquill/index.html +23 -20
  92. package/playground/mathquill/index.jsx +18 -22
  93. package/playground/prod-test/index.html +24 -20
  94. package/playground/prod-test/index.jsx +5 -3
  95. package/playground/schema-override/data.js +10 -10
  96. package/playground/schema-override/image-plugin.jsx +3 -4
  97. package/playground/schema-override/index.html +21 -19
  98. package/playground/schema-override/index.jsx +13 -14
  99. package/playground/serialization/data.js +10 -10
  100. package/playground/serialization/image-plugin.jsx +3 -4
  101. package/playground/serialization/index.html +22 -20
  102. package/playground/table-examples.html +5 -8
  103. package/playground/webpack.config.js +10 -10
  104. package/src/components.js +135 -0
  105. package/src/editor.jsx +478 -141
  106. package/src/index.jsx +71 -95
  107. package/src/new-serialization.jsx +291 -0
  108. package/src/parse-html.js +1 -1
  109. package/src/plugins/characters/custom-popper.js +7 -7
  110. package/src/plugins/characters/index.jsx +33 -34
  111. package/src/plugins/characters/utils.js +81 -81
  112. package/src/plugins/hotKeys/index.js +54 -0
  113. package/src/plugins/image/alt-dialog.jsx +4 -5
  114. package/src/plugins/image/component.jsx +106 -89
  115. package/src/plugins/image/image-toolbar.jsx +27 -19
  116. package/src/plugins/image/index.jsx +75 -43
  117. package/src/plugins/image/insert-image-handler.js +62 -27
  118. package/src/plugins/index.jsx +23 -41
  119. package/src/plugins/list/index.jsx +70 -95
  120. package/src/plugins/math/index.jsx +102 -82
  121. package/src/plugins/media/index.jsx +159 -124
  122. package/src/plugins/media/media-dialog.js +98 -71
  123. package/src/plugins/media/media-toolbar.jsx +8 -8
  124. package/src/plugins/media/media-wrapper.jsx +29 -30
  125. package/src/plugins/respArea/drag-in-the-blank/choice.jsx +21 -19
  126. package/src/plugins/respArea/drag-in-the-blank/index.jsx +14 -11
  127. package/src/plugins/respArea/explicit-constructed-response/index.jsx +7 -6
  128. package/src/plugins/respArea/icons/index.jsx +11 -14
  129. package/src/plugins/respArea/index.jsx +92 -52
  130. package/src/plugins/respArea/inline-dropdown/index.jsx +9 -8
  131. package/src/plugins/respArea/utils.jsx +26 -35
  132. package/src/plugins/table/icons/index.jsx +17 -11
  133. package/src/plugins/table/index.jsx +288 -231
  134. package/src/plugins/table/table-toolbar.jsx +15 -11
  135. package/src/plugins/toolbar/default-toolbar.jsx +65 -19
  136. package/src/plugins/toolbar/done-button.jsx +4 -4
  137. package/src/plugins/toolbar/editor-and-toolbar.jsx +150 -145
  138. package/src/plugins/toolbar/index.jsx +2 -3
  139. package/src/plugins/toolbar/toolbar-buttons.jsx +11 -11
  140. package/src/plugins/toolbar/toolbar.jsx +244 -221
  141. package/src/plugins/utils.js +21 -4
  142. package/src/serialization.jsx +32 -32
  143. package/src/test-serializer.js +139 -0
  144. package/src/test-serializer.js.rej +20 -0
package/lib/editor.js CHANGED
@@ -19,7 +19,7 @@ Object.defineProperty(exports, "DEFAULT_PLUGINS", {
19
19
  return _plugins.DEFAULT_PLUGINS;
20
20
  }
21
21
  });
22
- exports.serialization = exports["default"] = exports.Editor = void 0;
22
+ exports.serialization = exports["default"] = exports.EditorComponent = void 0;
23
23
 
24
24
  var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
25
25
 
@@ -39,20 +39,24 @@ var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/ge
39
39
 
40
40
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
41
41
 
42
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
43
+
44
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
45
+
46
+ var _react = _interopRequireWildcard(require("react"));
47
+
42
48
  var _slateReact = require("slate-react");
43
49
 
44
- var _slatePropTypes = _interopRequireDefault(require("slate-prop-types"));
50
+ var _RootRef = _interopRequireDefault(require("@material-ui/core/RootRef"));
45
51
 
46
52
  var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
47
53
 
48
- var serialization = _interopRequireWildcard(require("./serialization"));
54
+ var serialization = _interopRequireWildcard(require("./new-serialization"));
49
55
 
50
56
  exports.serialization = serialization;
51
57
 
52
58
  var _propTypes = _interopRequireDefault(require("prop-types"));
53
59
 
54
- var _react = _interopRequireDefault(require("react"));
55
-
56
60
  var _slate = require("slate");
57
61
 
58
62
  var _plugins = require("./plugins");
@@ -69,6 +73,16 @@ var _slatePlainSerializer = _interopRequireDefault(require("slate-plain-serializ
69
73
 
70
74
  var _insertImageHandler = _interopRequireDefault(require("./plugins/image/insert-image-handler"));
71
75
 
76
+ var _isHotkey = _interopRequireDefault(require("is-hotkey"));
77
+
78
+ var _slateHistory = require("slate-history");
79
+
80
+ var _mathToolbar = require("@pie-lib/math-toolbar");
81
+
82
+ var _components = require("./components");
83
+
84
+ var _editorAndToolbar = _interopRequireDefault(require("./plugins/toolbar/editor-and-toolbar"));
85
+
72
86
  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); }
73
87
 
74
88
  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; }
@@ -81,6 +95,310 @@ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (O
81
95
 
82
96
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
83
97
 
98
+ var HOTKEYS = {
99
+ 'mod+b': 'bold',
100
+ 'mod+i': 'italic',
101
+ 'mod+u': 'underline',
102
+ 'mod+`': 'code'
103
+ };
104
+ var LIST_TYPES = ['numbered-list', 'bulleted-list'];
105
+ var TEXT_ALIGN_TYPES = ['left', 'center', 'right', 'justify'];
106
+ var initialValue = [{
107
+ type: 'paragraph',
108
+ children: [{
109
+ type: 'math',
110
+ data: {
111
+ latex: '\\frac{1}{2}',
112
+ wrapper: 'round_brackets'
113
+ },
114
+ children: [{
115
+ text: '\\(\\frac{1}{2}\\)'
116
+ }]
117
+ }]
118
+ }];
119
+
120
+ var SlateEditor = function SlateEditor(editorProps) {
121
+ var value = editorProps.value,
122
+ plugins = editorProps.plugins;
123
+ var renderElement = (0, _react.useCallback)(function (props) {
124
+ return /*#__PURE__*/_react["default"].createElement(Element, (0, _extends2["default"])({}, props, {
125
+ plugins: plugins
126
+ }));
127
+ }, []);
128
+ var renderLeaf = (0, _react.useCallback)(function (props) {
129
+ return /*#__PURE__*/_react["default"].createElement(Leaf, props);
130
+ }, []);
131
+ var editor = (0, _react.useMemo)(function () {
132
+ return (0, _plugins.withPlugins)((0, _slate.createEditor)(), plugins);
133
+ }, []);
134
+
135
+ var _useState = (0, _react.useState)(false),
136
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
137
+ isFocused = _useState2[0],
138
+ setIsFocused = _useState2[1];
139
+
140
+ var editorRef = (0, _react.useRef)(null);
141
+ (0, _react.useEffect)(function () {
142
+ if (editorProps.onEditor) {
143
+ editorProps.onEditor(editor);
144
+ }
145
+ }, [editor]);
146
+ var slateValue = (0, _react.useMemo)(function () {
147
+ // Slate throws an error if the value on the initial render is invalid
148
+ // so we directly set the value on the editor in order
149
+ // to be able to trigger normalization on the initial value before rendering
150
+ editor.children = value;
151
+
152
+ _slate.Editor.normalize(editor, {
153
+ force: true
154
+ }); // We return the normalized internal value so that the rendering can take over from here
155
+
156
+
157
+ return editor.children;
158
+ }, [editor, value]);
159
+
160
+ var onKeyDown = function onKeyDown(event) {
161
+ if (event.key === 'Enter' && event.shiftKey === true) {
162
+ editor.insertText('\n');
163
+ event.preventDefault();
164
+ event.stopPropagation();
165
+ return;
166
+ }
167
+
168
+ for (var hotkey in HOTKEYS) {
169
+ if ((0, _isHotkey["default"])(hotkey, event)) {
170
+ event.preventDefault();
171
+ var mark = HOTKEYS[hotkey];
172
+ toggleMark(editor, mark);
173
+ }
174
+ }
175
+ };
176
+
177
+ var onFocus = function onFocus() {
178
+ return setIsFocused(true);
179
+ };
180
+
181
+ var onBlur = function onBlur() {
182
+ setTimeout(function () {
183
+ if (!editorRef.current || !editorRef.current.contains(document.activeElement)) {
184
+ setIsFocused(false);
185
+ }
186
+ }, 50);
187
+ };
188
+
189
+ return /*#__PURE__*/_react["default"].createElement(_slateReact.Slate, {
190
+ editor: editor,
191
+ value: slateValue
192
+ }, /*#__PURE__*/_react["default"].createElement(_RootRef["default"], {
193
+ rootRef: editorRef
194
+ }, /*#__PURE__*/_react["default"].createElement(_editorAndToolbar["default"], (0, _extends2["default"])({}, editorProps, {
195
+ editor: editor,
196
+ isFocused: isFocused,
197
+ onDone: function onDone() {
198
+ setIsFocused(false);
199
+ editorProps.onDone(editor);
200
+ }
201
+ }), /*#__PURE__*/_react["default"].createElement(_slateReact.Editable, {
202
+ renderElement: renderElement,
203
+ renderLeaf: renderLeaf,
204
+ placeholder: "Enter some rich text\u2026",
205
+ spellCheck: true,
206
+ onKeyDown: onKeyDown,
207
+ onFocus: onFocus,
208
+ onBlur: onBlur
209
+ }))));
210
+ };
211
+
212
+ var toggleBlock = function toggleBlock(editor, format) {
213
+ var isActive = isBlockActive(editor, format, TEXT_ALIGN_TYPES.includes(format) ? 'align' : 'type');
214
+ var isList = LIST_TYPES.includes(format);
215
+
216
+ _slate.Transforms.unwrapNodes(editor, {
217
+ match: function match(n) {
218
+ return !_slate.Editor.isEditor(n) && _slate.Element.isElement(n) && LIST_TYPES.includes(n.type) && !TEXT_ALIGN_TYPES.includes(format);
219
+ },
220
+ split: true
221
+ });
222
+
223
+ var newProperties;
224
+
225
+ if (TEXT_ALIGN_TYPES.includes(format)) {
226
+ newProperties = {
227
+ align: isActive ? undefined : format
228
+ };
229
+ } else {
230
+ newProperties = {
231
+ type: isActive ? 'paragraph' : isList ? 'list_item' : format
232
+ };
233
+ }
234
+
235
+ _slate.Transforms.setNodes(editor, newProperties);
236
+
237
+ if (!isActive && isList) {
238
+ var block = {
239
+ type: format,
240
+ children: []
241
+ };
242
+
243
+ _slate.Transforms.wrapNodes(editor, block);
244
+ }
245
+ };
246
+
247
+ var toggleMark = function toggleMark(editor, format) {
248
+ var isActive = isMarkActive(editor, format);
249
+
250
+ if (isActive) {
251
+ _slate.Editor.removeMark(editor, format);
252
+ } else {
253
+ _slate.Editor.addMark(editor, format, true);
254
+ }
255
+ };
256
+
257
+ var isBlockActive = function isBlockActive(editor, format) {
258
+ var blockType = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'type';
259
+ var selection = editor.selection;
260
+ if (!selection) return false;
261
+
262
+ var _Array$from = Array.from(_slate.Editor.nodes(editor, {
263
+ at: _slate.Editor.unhangRange(editor, selection),
264
+ match: function match(n) {
265
+ return !_slate.Editor.isEditor(n) && _slate.Element.isElement(n) && n[blockType] === format;
266
+ }
267
+ })),
268
+ _Array$from2 = (0, _slicedToArray2["default"])(_Array$from, 1),
269
+ match = _Array$from2[0];
270
+
271
+ return !!match;
272
+ };
273
+
274
+ var isMarkActive = function isMarkActive(editor, format) {
275
+ var marks = _slate.Editor.marks(editor);
276
+
277
+ return marks ? marks[format] === true : false;
278
+ };
279
+
280
+ var Element = function Element(props) {
281
+ var editor = (0, _slateReact.useSlateStatic)();
282
+ var focused = (0, _slateReact.useFocused)();
283
+ var attributes = props.attributes,
284
+ children = props.children,
285
+ element = props.element,
286
+ plugins = props.plugins;
287
+ var style = {
288
+ textAlign: element.align
289
+ };
290
+
291
+ var nodeProps = _objectSpread(_objectSpread(_objectSpread({}, attributes), props), {}, {
292
+ node: _objectSpread({}, element),
293
+ children: children
294
+ });
295
+
296
+ var pluginToRender = plugins.find(function (plugin) {
297
+ return typeof plugin.supports === 'function' && plugin.supports(element);
298
+ });
299
+
300
+ if (pluginToRender) {
301
+ return pluginToRender.renderNode(_objectSpread(_objectSpread({}, nodeProps), {}, {
302
+ editor: editor,
303
+ focused: focused
304
+ }));
305
+ }
306
+
307
+ switch (element.type) {
308
+ case 'block-quote':
309
+ return /*#__PURE__*/_react["default"].createElement("blockquote", (0, _extends2["default"])({
310
+ style: style
311
+ }, attributes), children);
312
+
313
+ case 'bulleted-list':
314
+ return /*#__PURE__*/_react["default"].createElement("ul", (0, _extends2["default"])({
315
+ style: style
316
+ }, attributes), children);
317
+
318
+ case 'heading-one':
319
+ return /*#__PURE__*/_react["default"].createElement("h1", (0, _extends2["default"])({
320
+ style: style
321
+ }, attributes), children);
322
+
323
+ case 'heading-two':
324
+ return /*#__PURE__*/_react["default"].createElement("h2", (0, _extends2["default"])({
325
+ style: style
326
+ }, attributes), children);
327
+
328
+ case 'list-item':
329
+ return /*#__PURE__*/_react["default"].createElement("li", (0, _extends2["default"])({
330
+ style: style
331
+ }, attributes), children);
332
+
333
+ case 'numbered-list':
334
+ return /*#__PURE__*/_react["default"].createElement("ol", (0, _extends2["default"])({
335
+ style: style
336
+ }, attributes), children);
337
+
338
+ default:
339
+ return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
340
+ style: _objectSpread(_objectSpread({}, style), {}, {
341
+ margin: 0
342
+ })
343
+ }, attributes), children);
344
+ }
345
+ };
346
+
347
+ var Leaf = function Leaf(_ref) {
348
+ var attributes = _ref.attributes,
349
+ children = _ref.children,
350
+ leaf = _ref.leaf;
351
+
352
+ if (leaf.bold) {
353
+ children = /*#__PURE__*/_react["default"].createElement("strong", null, children);
354
+ }
355
+
356
+ if (leaf.code) {
357
+ children = /*#__PURE__*/_react["default"].createElement("code", null, children);
358
+ }
359
+
360
+ if (leaf.italic) {
361
+ children = /*#__PURE__*/_react["default"].createElement("em", null, children);
362
+ }
363
+
364
+ if (leaf.underline) {
365
+ children = /*#__PURE__*/_react["default"].createElement("u", null, children);
366
+ }
367
+
368
+ if (leaf.strikethrough) {
369
+ children = /*#__PURE__*/_react["default"].createElement("del", null, children);
370
+ }
371
+
372
+ return /*#__PURE__*/_react["default"].createElement("span", attributes, children);
373
+ };
374
+
375
+ var BlockButton = function BlockButton(_ref2) {
376
+ var format = _ref2.format,
377
+ icon = _ref2.icon;
378
+ var editor = (0, _slateReact.useSlate)();
379
+ return /*#__PURE__*/_react["default"].createElement(_components.Button, {
380
+ active: isBlockActive(editor, format, TEXT_ALIGN_TYPES.includes(format) ? 'align' : 'type'),
381
+ onMouseDown: function onMouseDown(event) {
382
+ event.preventDefault();
383
+ toggleBlock(editor, format);
384
+ }
385
+ }, /*#__PURE__*/_react["default"].createElement(_components.Icon, null, icon));
386
+ };
387
+
388
+ var MarkButton = function MarkButton(_ref3) {
389
+ var format = _ref3.format,
390
+ icon = _ref3.icon;
391
+ var editor = (0, _slateReact.useSlate)();
392
+ return /*#__PURE__*/_react["default"].createElement(_components.Button, {
393
+ active: isMarkActive(editor, format),
394
+ onMouseDown: function onMouseDown(event) {
395
+ event.preventDefault();
396
+ toggleMark(editor, format);
397
+ }
398
+ }, /*#__PURE__*/_react["default"].createElement(_components.Icon, null, icon));
399
+ }; // old-editable
400
+
401
+
84
402
  var log = (0, _debug["default"])('editable-html:editor');
85
403
  var defaultToolbarOpts = {
86
404
  position: 'bottom',
@@ -96,21 +414,19 @@ var defaultResponseAreaProps = {
96
414
  };
97
415
  var defaultLanguageCharactersProps = [];
98
416
 
99
- var createToolbarOpts = function createToolbarOpts(toolbarOpts, error) {
100
- return _objectSpread(_objectSpread(_objectSpread({}, defaultToolbarOpts), toolbarOpts), {}, {
101
- error: error
102
- });
417
+ var createToolbarOpts = function createToolbarOpts(toolbarOpts) {
418
+ return _objectSpread(_objectSpread({}, defaultToolbarOpts), toolbarOpts);
103
419
  };
104
420
 
105
- var Editor = /*#__PURE__*/function (_React$Component) {
106
- (0, _inherits2["default"])(Editor, _React$Component);
421
+ var EditorComponent = /*#__PURE__*/function (_React$Component) {
422
+ (0, _inherits2["default"])(EditorComponent, _React$Component);
107
423
 
108
- var _super = _createSuper(Editor);
424
+ var _super = _createSuper(EditorComponent);
109
425
 
110
- function Editor(_props) {
426
+ function EditorComponent(_props) {
111
427
  var _this;
112
428
 
113
- (0, _classCallCheck2["default"])(this, Editor);
429
+ (0, _classCallCheck2["default"])(this, EditorComponent);
114
430
  _this = _super.call(this, _props);
115
431
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handlePlugins", function (props) {
116
432
  var normalizedResponseAreaProps = _objectSpread(_objectSpread({}, defaultResponseAreaProps), props.responseAreaProps);
@@ -122,7 +438,6 @@ var Editor = /*#__PURE__*/function (_React$Component) {
122
438
  onBlur: _this.onPluginBlur
123
439
  },
124
440
  image: {
125
- disableImageAlignmentButtons: props.disableImageAlignmentButtons,
126
441
  onDelete: props.imageSupport && props.imageSupport["delete"] && function (src, done) {
127
442
  props.imageSupport["delete"](src, function (e) {
128
443
  done(e, _this.state.value);
@@ -150,28 +465,7 @@ var Editor = /*#__PURE__*/function (_React$Component) {
150
465
  */
151
466
  disableScrollbar: !!props.disableScrollbar,
152
467
  disableUnderline: props.disableUnderline,
153
- autoWidth: props.autoWidthToolbar,
154
- onDone: function onDone() {
155
- var _this$state$value$sta, _this$state$value$sta2;
156
-
157
- var nonEmpty = props.nonEmpty;
158
- log('[onDone]');
159
-
160
- _this.setState({
161
- toolbarInFocus: false,
162
- focusedNode: null
163
- });
164
-
165
- _this.editor.blur();
166
-
167
- if (nonEmpty && ((_this$state$value$sta = _this.state.value.startText) === null || _this$state$value$sta === void 0 ? void 0 : (_this$state$value$sta2 = _this$state$value$sta.text) === null || _this$state$value$sta2 === void 0 ? void 0 : _this$state$value$sta2.length) === 0) {
168
- _this.resetValue(true).then(function () {
169
- _this.onEditingDone();
170
- });
171
- } else {
172
- _this.onEditingDone();
173
- }
174
- }
468
+ autoWidth: props.autoWidthToolbar
175
469
  },
176
470
  table: {
177
471
  onFocus: function onFocus() {
@@ -206,9 +500,6 @@ var Editor = /*#__PURE__*/function (_React$Component) {
206
500
  languageCharacters: props.languageCharactersProps,
207
501
  media: {
208
502
  focus: _this.focus,
209
- createChange: function createChange() {
210
- return _this.state.value.change();
211
- },
212
503
  onChange: _this.onChange,
213
504
  uploadSoundSupport: props.uploadSoundSupport
214
505
  }
@@ -248,15 +539,11 @@ var Editor = /*#__PURE__*/function (_React$Component) {
248
539
  _this.stashValue();
249
540
  });
250
541
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onMathClick", function (node) {
251
- _this.editor.change(function (c) {
252
- return c.collapseToStartOf(node);
253
- });
254
-
255
542
  _this.setState({
256
543
  selectedNode: node
257
544
  });
258
545
  });
259
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onEditingDone", function () {
546
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onEditingDone", function (editor) {
260
547
  log('[onEditingDone]');
261
548
 
262
549
  _this.setState({
@@ -266,7 +553,18 @@ var Editor = /*#__PURE__*/function (_React$Component) {
266
553
 
267
554
  log('[onEditingDone] value: ', _this.state.value);
268
555
 
269
- _this.props.onChange(_this.state.value, true);
556
+ _this.props.onChange(editor, true);
557
+ });
558
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onDone", function (editor) {
559
+ var nonEmpty = _this.props.nonEmpty;
560
+ log('[onDone]');
561
+
562
+ _this.setState({
563
+ toolbarInFocus: false,
564
+ focusedNode: null
565
+ });
566
+
567
+ _this.onEditingDone(editor);
270
568
  });
271
569
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleBlur", function (resolve) {
272
570
  var nonEmpty = _this.props.nonEmpty;
@@ -277,14 +575,10 @@ var Editor = /*#__PURE__*/function (_React$Component) {
277
575
  focusedNode: null
278
576
  });
279
577
 
280
- if (_this.editor) {
281
- _this.editor.blur();
282
- }
283
-
284
578
  if (doneOn === 'blur') {
285
- var _this$state$value$sta3, _this$state$value$sta4;
579
+ var _this$state$value$sta, _this$state$value$sta2;
286
580
 
287
- if (nonEmpty && ((_this$state$value$sta3 = _this.state.value.startText) === null || _this$state$value$sta3 === void 0 ? void 0 : (_this$state$value$sta4 = _this$state$value$sta3.text) === null || _this$state$value$sta4 === void 0 ? void 0 : _this$state$value$sta4.length) === 0) {
581
+ if (nonEmpty && ((_this$state$value$sta = _this.state.value.startText) === null || _this$state$value$sta === void 0 ? void 0 : (_this$state$value$sta2 = _this$state$value$sta.text) === null || _this$state$value$sta2 === void 0 ? void 0 : _this$state$value$sta2.length) === 0) {
288
582
  _this.resetValue(true).then(function () {
289
583
  _this.onEditingDone();
290
584
 
@@ -423,15 +717,19 @@ var Editor = /*#__PURE__*/function (_React$Component) {
423
717
  return Promise.resolve({});
424
718
  }
425
719
  });
426
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onChange", function (change, done) {
720
+ (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onChange", function (editor, done) {
427
721
  log('[onChange]');
428
- var value = change.value;
429
722
  var charactersLimit = _this.props.charactersLimit;
430
723
 
431
- if (value && value.document && value.document.text && value.document.text.length > charactersLimit) {
724
+ var allText = _slate.Editor.string(editor, []);
725
+
726
+ if (allText > charactersLimit) {
432
727
  return;
433
728
  }
434
729
 
730
+ var html = (0, serialization.valueToHtml)(editor);
731
+ var value = (0, serialization.htmlToValue)(html);
732
+
435
733
  _this.setState({
436
734
  value: value
437
735
  }, function () {
@@ -484,32 +782,13 @@ var Editor = /*#__PURE__*/function (_React$Component) {
484
782
  log('[validateNode] parent:', parent, p);
485
783
  return undefined;
486
784
  });
487
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeData", function (key, data) {
488
- log('[changeData]. .. ', key, data);
489
- /**
490
- * HACK ALERT: We should be calling setState here and storing the change data:
491
- *
492
- * <code>this.setState({changeData: { key, data}})</code>
493
- * However this is causing issues with the Mathquill instance. The 'input' event stops firing on the element and no
494
- * more changes get through. The issues seem to be related to the promises in onBlur/onFocus. But removing these
495
- * brings it's own problems. A major clean up is planned for this component so I've decided to temporarily settle
496
- * on this hack rather than spend more time on this.
497
- */
498
- // Uncomment this line to see the bug described above.
499
- // this.setState({changeData: {key, data}})
500
-
501
- _this.__TEMPORARY_CHANGE_DATA = {
502
- key: key,
503
- data: data
504
- };
505
- });
506
785
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "focus", function (pos, node) {
507
786
  var position = pos || 'end';
508
787
 
509
788
  _this.props.focus(position, node);
510
789
  });
511
790
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onDropPaste", /*#__PURE__*/function () {
512
- var _ref = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(event, change, dropContext) {
791
+ var _ref4 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(event, change, dropContext) {
513
792
  var editor, transfer, file, type, fragment, text, src, inline, range, ch, handler, _change$value, _document, selection, startBlock, defaultBlock, defaultMarks, frag;
514
793
 
515
794
  return _regenerator["default"].wrap(function _callee$(_context) {
@@ -635,7 +914,7 @@ var Editor = /*#__PURE__*/function (_React$Component) {
635
914
  }));
636
915
 
637
916
  return function (_x, _x2, _x3) {
638
- return _ref.apply(this, arguments);
917
+ return _ref4.apply(this, arguments);
639
918
  };
640
919
  }());
641
920
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "renderPlaceholder", function (props) {
@@ -662,7 +941,7 @@ var Editor = /*#__PURE__*/function (_React$Component) {
662
941
  });
663
942
  _this.state = {
664
943
  value: _props.value,
665
- toolbarOpts: createToolbarOpts(_props.toolbarOpts, _props.error)
944
+ toolbarOpts: createToolbarOpts(_props.toolbarOpts)
666
945
  };
667
946
 
668
947
  _this.onResize = function () {
@@ -674,7 +953,7 @@ var Editor = /*#__PURE__*/function (_React$Component) {
674
953
  return _this;
675
954
  }
676
955
 
677
- (0, _createClass2["default"])(Editor, [{
956
+ (0, _createClass2["default"])(EditorComponent, [{
678
957
  key: "componentDidMount",
679
958
  value: function componentDidMount() {
680
959
  var _this2 = this;
@@ -688,8 +967,6 @@ var Editor = /*#__PURE__*/function (_React$Component) {
688
967
  if (_this2.editor) {
689
968
  var editorDOM = document.querySelector("[data-key=\"".concat(_this2.editor.value.document.key, "\"]"));
690
969
 
691
- _this2.editor.focus();
692
-
693
970
  if (editorDOM) {
694
971
  editorDOM.focus();
695
972
  }
@@ -701,7 +978,7 @@ var Editor = /*#__PURE__*/function (_React$Component) {
701
978
  key: "componentWillReceiveProps",
702
979
  value: function componentWillReceiveProps(nextProps) {
703
980
  var toolbarOpts = this.state.toolbarOpts;
704
- var newToolbarOpts = createToolbarOpts(nextProps.toolbarOpts, nextProps.error);
981
+ var newToolbarOpts = createToolbarOpts(nextProps.toolbarOpts);
705
982
 
706
983
  if (!(0, _isEqual["default"])(newToolbarOpts, toolbarOpts)) {
707
984
  this.setState({
@@ -737,7 +1014,7 @@ var Editor = /*#__PURE__*/function (_React$Component) {
737
1014
  }, {
738
1015
  key: "UNSAFE_componentWillReceiveProps",
739
1016
  value: function UNSAFE_componentWillReceiveProps(props) {
740
- if (!props.value.document.equals(this.props.value.document)) {
1017
+ if (!(0, _isEqual["default"])(props.value, this.props.value)) {
741
1018
  this.setState({
742
1019
  focus: false,
743
1020
  value: props.value
@@ -780,25 +1057,63 @@ var Editor = /*#__PURE__*/function (_React$Component) {
780
1057
  toolbarOpts = _this$state2.toolbarOpts;
781
1058
  log('[render] value: ', value);
782
1059
  var sizeStyle = this.buildSizeStyle();
783
- var names = (0, _classnames["default"])((_classNames = {}, (0, _defineProperty2["default"])(_classNames, classes.withBg, highlightShape), (0, _defineProperty2["default"])(_classNames, classes.toolbarOnTop, toolbarOpts.alwaysVisible && toolbarOpts.position === 'top'), _classNames), className);
1060
+ var names = (0, _classnames["default"])((_classNames = {}, (0, _defineProperty2["default"])(_classNames, classes.withBg, highlightShape), (0, _defineProperty2["default"])(_classNames, classes.toolbarOnTop, toolbarOpts.alwaysVisible && toolbarOpts.position === 'top'), _classNames), className, classes.slateEditor);
784
1061
  return /*#__PURE__*/_react["default"].createElement("div", {
785
- ref: function ref(_ref2) {
786
- return _this3.wrapperRef = _ref2;
1062
+ ref: function ref(_ref5) {
1063
+ return _this3.wrapperRef = _ref5;
787
1064
  },
788
1065
  style: {
789
1066
  width: sizeStyle.width
790
1067
  },
791
1068
  className: names
792
- }, /*#__PURE__*/_react["default"].createElement(_slateReact.Editor, {
1069
+ }, /*#__PURE__*/_react["default"].createElement(SlateEditor, {
793
1070
  plugins: this.plugins,
794
- innerRef: function innerRef(r) {
1071
+ toolbarRef: function toolbarRef(r) {
795
1072
  if (r) {
796
- _this3.slateEditor = r;
1073
+ _this3.toolbarRef = r;
797
1074
  }
798
1075
  },
799
- ref: function ref(r) {
800
- return _this3.editor = r && _this3.props.editorRef(r);
1076
+ onEditor: this.props.onEditor,
1077
+ value: value,
1078
+ focus: this.focus,
1079
+ onKeyDown: onKeyDown,
1080
+ onChange: this.onChange,
1081
+ getFocusedValue: this.getFocusedValue,
1082
+ onBlur: this.onBlur,
1083
+ onDrop: function onDrop(event, editor) {
1084
+ return _this3.onDropPaste(event, editor, true);
1085
+ },
1086
+ onPaste: function onPaste(event, editor) {
1087
+ return _this3.onDropPaste(event, editor);
1088
+ },
1089
+ onFocus: this.onFocus,
1090
+ onEditingDone: this.onEditingDone,
1091
+ onDone: this.onDone,
1092
+ focusedNode: focusedNode,
1093
+ normalize: this.normalize,
1094
+ readOnly: disabled,
1095
+ spellCheck: spellCheck,
1096
+ className: (0, _classnames["default"])((0, _defineProperty2["default"])({}, classes.noPadding, toolbarOpts && toolbarOpts.noBorder), classes.slateEditor),
1097
+ style: {
1098
+ minHeight: sizeStyle.minHeight,
1099
+ height: sizeStyle.height,
1100
+ maxHeight: sizeStyle.maxHeight
1101
+ },
1102
+ pluginProps: pluginProps,
1103
+ toolbarOpts: toolbarOpts,
1104
+ placeholder: placeholder,
1105
+ renderPlaceholder: this.renderPlaceholder
1106
+ }));
1107
+ return /*#__PURE__*/_react["default"].createElement("div", {
1108
+ ref: function ref(_ref6) {
1109
+ return _this3.wrapperRef = _ref6;
1110
+ },
1111
+ style: {
1112
+ width: sizeStyle.width
801
1113
  },
1114
+ className: names
1115
+ }, /*#__PURE__*/_react["default"].createElement(_slateReact.Editor, {
1116
+ plugins: this.plugins,
802
1117
  toolbarRef: function toolbarRef(r) {
803
1118
  if (r) {
804
1119
  _this3.toolbarRef = r;
@@ -822,7 +1137,6 @@ var Editor = /*#__PURE__*/function (_React$Component) {
822
1137
  normalize: this.normalize,
823
1138
  readOnly: disabled,
824
1139
  spellCheck: spellCheck,
825
- autoCorrect: spellCheck,
826
1140
  className: (0, _classnames["default"])((0, _defineProperty2["default"])({}, classes.noPadding, toolbarOpts && toolbarOpts.noBorder), classes.slateEditor),
827
1141
  style: {
828
1142
  minHeight: sizeStyle.minHeight,
@@ -832,28 +1146,29 @@ var Editor = /*#__PURE__*/function (_React$Component) {
832
1146
  pluginProps: pluginProps,
833
1147
  toolbarOpts: toolbarOpts,
834
1148
  placeholder: placeholder,
835
- renderPlaceholder: this.renderPlaceholder,
836
- onDataChange: this.changeData
1149
+ renderPlaceholder: this.renderPlaceholder
837
1150
  }));
838
1151
  }
839
1152
  }]);
840
- return Editor;
1153
+ return EditorComponent;
841
1154
  }(_react["default"].Component); // TODO color - hardcoded gray background and keypad colors will need to change too
842
1155
 
843
1156
 
844
- exports.Editor = Editor;
845
- (0, _defineProperty2["default"])(Editor, "propTypes", {
1157
+ exports.EditorComponent = EditorComponent;
1158
+ (0, _defineProperty2["default"])(EditorComponent, "propTypes", {
846
1159
  autoFocus: _propTypes["default"].bool,
847
- editorRef: _propTypes["default"].func.isRequired,
848
1160
  onRef: _propTypes["default"].func.isRequired,
849
1161
  onChange: _propTypes["default"].func.isRequired,
1162
+ onEditor: _propTypes["default"].func,
850
1163
  onFocus: _propTypes["default"].func,
851
1164
  onBlur: _propTypes["default"].func,
852
1165
  onKeyDown: _propTypes["default"].func,
853
- focus: _propTypes["default"].func.isRequired,
854
- value: _slatePropTypes["default"].value.isRequired,
1166
+ value: _propTypes["default"].arrayOf(_propTypes["default"].shape({
1167
+ type: _propTypes["default"].string,
1168
+ children: _propTypes["default"].array,
1169
+ data: _propTypes["default"].object
1170
+ })),
855
1171
  imageSupport: _propTypes["default"].object,
856
- disableImageAlignmentButtons: _propTypes["default"].bool,
857
1172
  uploadSoundSupport: _propTypes["default"].shape({
858
1173
  add: _propTypes["default"].func,
859
1174
  "delete": _propTypes["default"].func
@@ -901,7 +1216,7 @@ exports.Editor = Editor;
901
1216
  maxImageWidth: _propTypes["default"].number,
902
1217
  maxImageHeight: _propTypes["default"].number
903
1218
  });
904
- (0, _defineProperty2["default"])(Editor, "defaultProps", {
1219
+ (0, _defineProperty2["default"])(EditorComponent, "defaultProps", {
905
1220
  disableUnderline: true,
906
1221
  onFocus: function onFocus() {},
907
1222
  onBlur: function onBlur() {},
@@ -946,7 +1261,7 @@ var styles = {
946
1261
  }
947
1262
  };
948
1263
 
949
- var _default = (0, _styles.withStyles)(styles)(Editor);
1264
+ var _default = (0, _styles.withStyles)(styles)(EditorComponent);
950
1265
 
951
1266
  exports["default"] = _default;
952
- //# sourceMappingURL=editor.js.map
1267
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["HOTKEYS","LIST_TYPES","TEXT_ALIGN_TYPES","initialValue","type","children","data","latex","wrapper","text","SlateEditor","editorProps","value","plugins","renderElement","useCallback","props","renderLeaf","editor","useMemo","withPlugins","createEditor","useState","isFocused","setIsFocused","editorRef","useRef","useEffect","onEditor","slateValue","Editor","normalize","force","onKeyDown","event","key","shiftKey","insertText","preventDefault","stopPropagation","hotkey","isHotkey","mark","toggleMark","onFocus","onBlur","setTimeout","current","contains","document","activeElement","onDone","toggleBlock","format","isActive","isBlockActive","includes","isList","Transforms","unwrapNodes","match","n","isEditor","SlateElement","isElement","split","newProperties","align","undefined","setNodes","block","wrapNodes","isMarkActive","removeMark","addMark","blockType","selection","Array","from","nodes","at","unhangRange","marks","Element","useSlateStatic","focused","useFocused","attributes","element","style","textAlign","nodeProps","node","pluginToRender","find","plugin","supports","renderNode","margin","Leaf","leaf","bold","code","italic","underline","strikethrough","BlockButton","icon","useSlate","MarkButton","log","debug","defaultToolbarOpts","position","alignment","alwaysVisible","showDone","doneOn","defaultResponseAreaProps","options","respAreaToolbar","onHandleAreaChange","defaultLanguageCharactersProps","createToolbarOpts","toolbarOpts","EditorComponent","normalizedResponseAreaProps","responseAreaProps","buildPlugins","activePlugins","math","onClick","onMathClick","onPluginFocus","onPluginBlur","image","onDelete","imageSupport","src","done","e","state","insertImageRequested","getHandler","handler","add","maxImageWidth","maxImageHeight","toolbar","disableScrollbar","disableUnderline","autoWidth","autoWidthToolbar","table","responseArea","maxResponseAreas","error","languageCharacters","languageCharactersProps","media","focus","onChange","uploadSoundSupport","relatedTarget","target","findNode","setState","focusedNode","resetValue","stashedValue","stashValue","selectedNode","nonEmpty","toolbarInFocus","onEditingDone","resolve","startText","length","then","Promise","preBlurValue","handleBlur","bind","editorDOM","querySelector","stateValue","wrapperRef","editorElement","closest","className","toolbarElement","toolbarRef","isInCurrentComponent","removeEventListener","handleDomBlur","__TEMPORARY_CHANGE_DATA","domEl","change","setNodeByKey","addEventListener","stopReset","reduce","s","p","toObject","newValue","Value","fromJSON","toJSON","charactersLimit","allText","string","html","valueToHtml","htmlToValue","v","endsWith","parseInt","isNaN","object","last","parent","getParent","Block","pos","dropContext","transfer","getEventTransfer","file","files","fragment","getBase64","inline","Inline","create","isVoid","loading","range","getEventRange","select","ch","insertInline","InsertImageHandler","insertFragment","startBlock","defaultBlock","defaultMarks","getInsertMarksAtRange","frag","Plain","deserialize","placeholder","size","display","width","maxWidth","whiteSpace","opacity","pointerEvents","userSelect","onResize","handlePlugins","onRef","window","autoFocus","nextProps","newToolbarOpts","isEqual","zeroWidthEls","querySelectorAll","forEach","el","minWidth","minHeight","height","maxHeight","valueToSize","disabled","spellCheck","highlightShape","classes","pluginProps","sizeStyle","buildSizeStyle","names","classNames","withBg","toolbarOnTop","slateEditor","ref","r","getFocusedValue","onDropPaste","noPadding","noBorder","renderPlaceholder","React","Component","PropTypes","bool","func","isRequired","arrayOf","shape","array","number","oneOfType","any","oneOf","language","characterIcon","characters","values","allValid","every","ALL_PLUGINS","Error","join","styles","backgroundColor","fontFamily","tableLayout","borderCollapse","color","background","borderTop","padding","border","marginTop","withStyles"],"sources":["../src/editor.jsx"],"sourcesContent":["import React, { useCallback, useMemo, useRef, useState, useEffect } from 'react';\nimport {\n  Editor as OldSlateEditor,\n  findNode,\n  getEventRange,\n  getEventTransfer,\n  useSlateStatic\n} from 'slate-react';\nimport RootRef from '@material-ui/core/RootRef';\n\nimport isEqual from 'lodash/isEqual';\nimport * as serialization from './new-serialization';\nimport PropTypes from 'prop-types';\nimport { Value, Block, Inline } from 'slate';\nimport { ALL_PLUGINS, DEFAULT_PLUGINS, buildPlugins, withPlugins } from './plugins';\nimport debug from 'debug';\nimport { withStyles } from '@material-ui/core/styles';\nimport classNames from 'classnames';\nimport { color } from '@pie-lib/render-ui';\nimport Plain from 'slate-plain-serializer';\n\nimport { getBase64, htmlToValue, valueToHtml } from './new-serialization';\nimport InsertImageHandler from './plugins/image/insert-image-handler';\n\nimport isHotkey from 'is-hotkey';\nimport { Editable, useFocused, withReact, useSlate, Slate } from 'slate-react';\nimport { Editor, Transforms, createEditor, Element as SlateElement } from 'slate';\nimport { withHistory } from 'slate-history';\nimport { MathPreview } from '@pie-lib/math-toolbar';\n\nimport { Button, Icon, Toolbar } from './components';\nimport EditorAndToolbar from './plugins/toolbar/editor-and-toolbar';\n\nconst HOTKEYS = {\n  'mod+b': 'bold',\n  'mod+i': 'italic',\n  'mod+u': 'underline',\n  'mod+`': 'code'\n};\n\nconst LIST_TYPES = ['numbered-list', 'bulleted-list'];\nconst TEXT_ALIGN_TYPES = ['left', 'center', 'right', 'justify'];\n\nconst initialValue = [\n  {\n    type: 'paragraph',\n    children: [\n      {\n        type: 'math',\n        data: {\n          latex: '\\\\frac{1}{2}',\n          wrapper: 'round_brackets'\n        },\n        children: [\n          {\n            text: '\\\\(\\\\frac{1}{2}\\\\)'\n          }\n        ]\n      }\n    ]\n  }\n];\n\nconst SlateEditor = editorProps => {\n  const { value, plugins } = editorProps;\n  const renderElement = useCallback(props => <Element {...props} plugins={plugins} />, []);\n  const renderLeaf = useCallback(props => <Leaf {...props} />, []);\n  const editor = useMemo(() => withPlugins(createEditor(), plugins), []);\n  const [isFocused, setIsFocused] = useState(false);\n  const editorRef = useRef(null);\n\n  useEffect(() => {\n    if (editorProps.onEditor) {\n      editorProps.onEditor(editor);\n    }\n  }, [editor]);\n\n  const slateValue = useMemo(() => {\n    // Slate throws an error if the value on the initial render is invalid\n    // so we directly set the value on the editor in order\n    // to be able to trigger normalization on the initial value before rendering\n    editor.children = value;\n    Editor.normalize(editor, { force: true });\n    // We return the normalized internal value so that the rendering can take over from here\n    return editor.children;\n  }, [editor, value]);\n\n  const onKeyDown = event => {\n    if (event.key === 'Enter' && event.shiftKey === true) {\n      editor.insertText('\\n');\n      event.preventDefault();\n      event.stopPropagation();\n      return;\n    }\n    for (const hotkey in HOTKEYS) {\n      if (isHotkey(hotkey, event)) {\n        event.preventDefault();\n        const mark = HOTKEYS[hotkey];\n        toggleMark(editor, mark);\n      }\n    }\n  };\n  const onFocus = () => setIsFocused(true);\n  const onBlur = () => {\n    setTimeout(() => {\n      if (!editorRef.current || !editorRef.current.contains(document.activeElement)) {\n        setIsFocused(false);\n      }\n    }, 50);\n  };\n\n  return (\n    <Slate editor={editor} value={slateValue}>\n      <RootRef rootRef={editorRef}>\n        <EditorAndToolbar\n          {...editorProps}\n          editor={editor}\n          isFocused={isFocused}\n          onDone={() => {\n            setIsFocused(false);\n            editorProps.onDone(editor);\n          }}\n        >\n          <Editable\n            renderElement={renderElement}\n            renderLeaf={renderLeaf}\n            placeholder=\"Enter some rich text…\"\n            spellCheck\n            onKeyDown={onKeyDown}\n            onFocus={onFocus}\n            onBlur={onBlur}\n          />\n        </EditorAndToolbar>\n      </RootRef>\n    </Slate>\n  );\n};\n\nconst toggleBlock = (editor, format) => {\n  const isActive = isBlockActive(\n    editor,\n    format,\n    TEXT_ALIGN_TYPES.includes(format) ? 'align' : 'type'\n  );\n  const isList = LIST_TYPES.includes(format);\n\n  Transforms.unwrapNodes(editor, {\n    match: n =>\n      !Editor.isEditor(n) &&\n      SlateElement.isElement(n) &&\n      LIST_TYPES.includes(n.type) &&\n      !TEXT_ALIGN_TYPES.includes(format),\n    split: true\n  });\n  let newProperties;\n  if (TEXT_ALIGN_TYPES.includes(format)) {\n    newProperties = {\n      align: isActive ? undefined : format\n    };\n  } else {\n    newProperties = {\n      type: isActive ? 'paragraph' : isList ? 'list_item' : format\n    };\n  }\n  Transforms.setNodes(editor, newProperties);\n\n  if (!isActive && isList) {\n    const block = { type: format, children: [] };\n    Transforms.wrapNodes(editor, block);\n  }\n};\n\nconst toggleMark = (editor, format) => {\n  const isActive = isMarkActive(editor, format);\n\n  if (isActive) {\n    Editor.removeMark(editor, format);\n  } else {\n    Editor.addMark(editor, format, true);\n  }\n};\n\nconst isBlockActive = (editor, format, blockType = 'type') => {\n  const { selection } = editor;\n  if (!selection) return false;\n\n  const [match] = Array.from(\n    Editor.nodes(editor, {\n      at: Editor.unhangRange(editor, selection),\n      match: n => !Editor.isEditor(n) && SlateElement.isElement(n) && n[blockType] === format\n    })\n  );\n\n  return !!match;\n};\n\nconst isMarkActive = (editor, format) => {\n  const marks = Editor.marks(editor);\n  return marks ? marks[format] === true : false;\n};\n\nconst Element = props => {\n  const editor = useSlateStatic();\n  const focused = useFocused();\n  const { attributes, children, element, plugins } = props;\n  const style = { textAlign: element.align };\n\n  const nodeProps = { ...attributes, ...props, node: { ...element }, children };\n  const pluginToRender = plugins.find(\n    plugin => typeof plugin.supports === 'function' && plugin.supports(element)\n  );\n\n  if (pluginToRender) {\n    return pluginToRender.renderNode({ ...nodeProps, editor, focused });\n  }\n\n  switch (element.type) {\n    case 'block-quote':\n      return (\n        <blockquote style={style} {...attributes}>\n          {children}\n        </blockquote>\n      );\n    case 'bulleted-list':\n      return (\n        <ul style={style} {...attributes}>\n          {children}\n        </ul>\n      );\n    case 'heading-one':\n      return (\n        <h1 style={style} {...attributes}>\n          {children}\n        </h1>\n      );\n    case 'heading-two':\n      return (\n        <h2 style={style} {...attributes}>\n          {children}\n        </h2>\n      );\n    case 'list-item':\n      return (\n        <li style={style} {...attributes}>\n          {children}\n        </li>\n      );\n    case 'numbered-list':\n      return (\n        <ol style={style} {...attributes}>\n          {children}\n        </ol>\n      );\n    default:\n      return (\n        <div\n          style={{\n            ...style,\n            margin: 0\n          }}\n          {...attributes}\n        >\n          {children}\n        </div>\n      );\n  }\n};\n\nconst Leaf = ({ attributes, children, leaf }) => {\n  if (leaf.bold) {\n    children = <strong>{children}</strong>;\n  }\n\n  if (leaf.code) {\n    children = <code>{children}</code>;\n  }\n\n  if (leaf.italic) {\n    children = <em>{children}</em>;\n  }\n\n  if (leaf.underline) {\n    children = <u>{children}</u>;\n  }\n\n  if (leaf.strikethrough) {\n    children = <del>{children}</del>;\n  }\n\n  return <span {...attributes}>{children}</span>;\n};\n\nconst BlockButton = ({ format, icon }) => {\n  const editor = useSlate();\n  return (\n    <Button\n      active={isBlockActive(editor, format, TEXT_ALIGN_TYPES.includes(format) ? 'align' : 'type')}\n      onMouseDown={event => {\n        event.preventDefault();\n        toggleBlock(editor, format);\n      }}\n    >\n      <Icon>{icon}</Icon>\n    </Button>\n  );\n};\n\nconst MarkButton = ({ format, icon }) => {\n  const editor = useSlate();\n  return (\n    <Button\n      active={isMarkActive(editor, format)}\n      onMouseDown={event => {\n        event.preventDefault();\n        toggleMark(editor, format);\n      }}\n    >\n      <Icon>{icon}</Icon>\n    </Button>\n  );\n};\n\n// old-editable\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 => {\n  return {\n    ...defaultToolbarOpts,\n    ...toolbarOpts\n  };\n};\n\nexport class EditorComponent extends React.Component {\n  static propTypes = {\n    autoFocus: PropTypes.bool,\n    onRef: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    onEditor: PropTypes.func,\n    onFocus: PropTypes.func,\n    onBlur: PropTypes.func,\n    onKeyDown: PropTypes.func,\n    value: PropTypes.arrayOf(\n      PropTypes.shape({\n        type: PropTypes.string,\n        children: PropTypes.array,\n        data: PropTypes.object\n      })\n    ),\n    imageSupport: PropTypes.object,\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    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    placeholder: PropTypes.string,\n    responseAreaProps: PropTypes.shape({\n      type: PropTypes.oneOf([\n        'explicit-constructed-response',\n        'inline-dropdown',\n        'drag-in-the-blank'\n      ]),\n      options: PropTypes.object,\n      respAreaToolbar: PropTypes.func,\n      onHandleAreaChange: PropTypes.func\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    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    }),\n    activePlugins: PropTypes.arrayOf(values => {\n      const allValid = values.every(v => ALL_PLUGINS.includes(v));\n\n      return (\n        !allValid &&\n        new Error(`Invalid values: ${values}, values must be one of [${ALL_PLUGINS.join(',')}]`)\n      );\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    toolbarOpts: defaultToolbarOpts,\n    responseAreaProps: defaultResponseAreaProps,\n    languageCharactersProps: defaultLanguageCharactersProps\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      value: props.value,\n      toolbarOpts: createToolbarOpts(props.toolbarOpts)\n    };\n\n    this.onResize = () => {\n      props.onChange(this.state.value, true);\n    };\n\n    this.handlePlugins(this.props);\n  }\n\n  handlePlugins = props => {\n    const normalizedResponseAreaProps = {\n      ...defaultResponseAreaProps,\n      ...props.responseAreaProps\n    };\n\n    this.plugins = buildPlugins(props.activePlugins, {\n      math: {\n        onClick: this.onMathClick,\n        onFocus: this.onPluginFocus,\n        onBlur: this.onPluginBlur\n      },\n      image: {\n        onDelete:\n          props.imageSupport &&\n          props.imageSupport.delete &&\n          ((src, done) => {\n            props.imageSupport.delete(src, e => {\n              done(e, this.state.value);\n            });\n          }),\n        insertImageRequested:\n          props.imageSupport &&\n          (getHandler => {\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(() => this.state.value);\n            props.imageSupport.add(handler);\n          }),\n        onFocus: this.onPluginFocus,\n        onBlur: this.onPluginBlur,\n        maxImageWidth: this.props.maxImageWidth,\n        maxImageHeight: this.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      },\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      media: {\n        focus: this.focus,\n        onChange: this.onChange,\n        uploadSoundSupport: props.uploadSoundSupport\n      }\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    if (this.editor && this.props.autoFocus) {\n      Promise.resolve().then(() => {\n        if (this.editor) {\n          const editorDOM = document.querySelector(\n            `[data-key=\"${this.editor.value.document.key}\"]`\n          );\n\n          if (editorDOM) {\n            editorDOM.focus();\n          }\n        }\n      });\n    }\n  }\n\n  componentWillReceiveProps(nextProps) {\n    const { toolbarOpts } = this.state;\n    const newToolbarOpts = createToolbarOpts(nextProps.toolbarOpts);\n\n    if (!isEqual(newToolbarOpts, toolbarOpts)) {\n      this.setState({\n        toolbarOpts: newToolbarOpts\n      });\n    }\n\n    if (!isEqual(nextProps.languageCharactersProps, this.props.languageCharactersProps)) {\n      this.handlePlugins(nextProps);\n    }\n  }\n\n  componentDidUpdate() {\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    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.setState({ selectedNode: node });\n  };\n\n  onEditingDone = editor => {\n    log('[onEditingDone]');\n    this.setState({ stashedValue: null, focusedNode: null });\n    log('[onEditingDone] value: ', this.state.value);\n    this.props.onChange(editor, true);\n  };\n\n  onDone = editor => {\n    const { nonEmpty } = this.props;\n\n    log('[onDone]');\n    this.setState({ toolbarInFocus: false, focusedNode: null });\n\n    this.onEditingDone(editor);\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 (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 target = event.relatedTarget;\n\n    const node = target ? findNode(target, this.state.value) : null;\n\n    log('[onBlur] node: ', node);\n\n    return new Promise(resolve => {\n      this.setState(\n        { preBlurValue: this.state.value, focusedNode: !node ? null : node },\n        this.handleBlur.bind(this, resolve)\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 =\n        !editorDOM || document.activeElement.closest(`[class*=\"${editorDOM.className}\"]`);\n      const toolbarElement =\n        !this.toolbarRef ||\n        document.activeElement.closest(`[class*=\"${this.toolbarRef.className}\"]`);\n      const isInCurrentComponent =\n        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 = () =>\n    new Promise(resolve => {\n      const editorDOM = document.querySelector(`[data-key=\"${this.state.value.document.key}\"]`);\n\n      log('[onFocus]', document.activeElement);\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\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      resolve();\n    });\n\n  stashValue = () => {\n    log('[stashValue]');\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 = (editor, done) => {\n    log('[onChange]');\n    const { charactersLimit } = this.props;\n    const allText = Editor.string(editor, []);\n\n    if (allText > charactersLimit) {\n      return;\n    }\n\n    const html = valueToHtml(editor);\n    const value = htmlToValue(html);\n\n    this.setState({ value }, () => {\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  UNSAFE_componentWillReceiveProps(props) {\n    if (!isEqual(props.value, this.props.value)) {\n      this.setState({\n        focus: false,\n        value: props.value\n      });\n    }\n  }\n\n  valueToSize = v => {\n    if (!v) {\n      return;\n    }\n\n    if (typeof v === 'string') {\n      if (v.endsWith('%')) {\n        return undefined;\n      } else if (v.endsWith('px') || v.endsWith('vh') || v.endsWith('vw')) {\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    return;\n  };\n\n  buildSizeStyle() {\n    const { width, minHeight, height, maxHeight } = this.props;\n\n    return {\n      width: this.valueToSize(width),\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  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 (\n      file &&\n      (file.type === 'image/jpeg' || file.type === 'image/jpg' || file.type === 'image/png')\n    ) {\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(inline, () => this.state.value, this.onChange, true);\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) {\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      placeholder,\n      pluginProps,\n      onKeyDown\n    } = this.props;\n\n    const { value, focusedNode, toolbarOpts } = 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      },\n      className,\n      classes.slateEditor\n    );\n\n    return (\n      <div\n        ref={ref => (this.wrapperRef = ref)}\n        style={{ width: sizeStyle.width }}\n        className={names}\n      >\n        <SlateEditor\n          plugins={this.plugins}\n          toolbarRef={r => {\n            if (r) {\n              this.toolbarRef = r;\n            }\n          }}\n          onEditor={this.props.onEditor}\n          value={value}\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          onDone={this.onDone}\n          focusedNode={focusedNode}\n          normalize={this.normalize}\n          readOnly={disabled}\n          spellCheck={spellCheck}\n          className={classNames(\n            {\n              [classes.noPadding]: toolbarOpts && toolbarOpts.noBorder\n            },\n            classes.slateEditor\n          )}\n          style={{\n            minHeight: sizeStyle.minHeight,\n            height: sizeStyle.height,\n            maxHeight: sizeStyle.maxHeight\n          }}\n          pluginProps={pluginProps}\n          toolbarOpts={toolbarOpts}\n          placeholder={placeholder}\n          renderPlaceholder={this.renderPlaceholder}\n        />\n      </div>\n    );\n\n    return (\n      <div\n        ref={ref => (this.wrapperRef = ref)}\n        style={{ width: sizeStyle.width }}\n        className={names}\n      >\n        <OldSlateEditor\n          plugins={this.plugins}\n          toolbarRef={r => {\n            if (r) {\n              this.toolbarRef = r;\n            }\n          }}\n          value={value}\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          className={classNames(\n            {\n              [classes.noPadding]: toolbarOpts && toolbarOpts.noBorder\n            },\n            classes.slateEditor\n          )}\n          style={{\n            minHeight: sizeStyle.minHeight,\n            height: sizeStyle.height,\n            maxHeight: sizeStyle.maxHeight\n          }}\n          pluginProps={pluginProps}\n          toolbarOpts={toolbarOpts}\n          placeholder={placeholder}\n          renderPlaceholder={this.renderPlaceholder}\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  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  toolbarOnTop: {\n    marginTop: '45px'\n  },\n  noPadding: {\n    padding: '0 !important'\n  }\n};\n\nexport default withStyles(styles)(EditorComponent);\n"],"mappings":"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"}