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