easy-richtextarea 3.0.146 → 3.0.148

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.
@@ -27,7 +27,7 @@ function _taggedTemplateLiteral(strings, raw) {
27
27
  }
28
28
  function _templateObject() {
29
29
  var data = _taggedTemplateLiteral([
30
- "\n\n border: 1px solid black;\n width: 32rem;\n height: 32rem;\n padding: 0.25rem;\n font-size: 1.2rem;\n font-family: monospace;\n\n"
30
+ "\n\n border: 1px solid black;\n width: 32rem;\n height: 32rem;\n padding: 0.25rem;\n font-size: 1.2rem;\n font-family: monospace;\n \n display: none;\n \n .active {\n display: block;\n }\n\n"
31
31
  ]);
32
32
  _templateObject = function _templateObject() {
33
33
  return data;
@@ -36,4 +36,4 @@ function _templateObject() {
36
36
  }
37
37
  var _default = (0, _easyWithStyle.default)(_browser.RichTextarea)(_templateObject());
38
38
 
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9leGFtcGxlL3JpY2hUZXh0YXJlYS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHdpdGhTdHlsZSBmcm9tIFwiZWFzeS13aXRoLXN0eWxlXCI7XG5cbmltcG9ydCB7IFJpY2hUZXh0YXJlYSB9IGZyb20gXCIuLi9icm93c2VyXCI7ICAvLy9cblxuZXhwb3J0IGRlZmF1bHQgd2l0aFN0eWxlKFJpY2hUZXh0YXJlYSlgXG5cbiAgYm9yZGVyOiAxcHggc29saWQgYmxhY2s7XG4gIHdpZHRoOiAzMnJlbTtcbiAgaGVpZ2h0OiAzMnJlbTtcbiAgcGFkZGluZzogMC4yNXJlbTtcbiAgZm9udC1zaXplOiAxLjJyZW07XG4gIGZvbnQtZmFtaWx5OiBtb25vc3BhY2U7XG5cbmA7XG4iXSwibmFtZXMiOlsid2l0aFN0eWxlIiwiUmljaFRleHRhcmVhIl0sIm1hcHBpbmdzIjoiQUFBQTs7OzsrQkFNQTs7O2VBQUE7OztrRUFKc0I7dUJBRU87Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7SUFFN0IsV0FBZUEsSUFBQUEsc0JBQVMsRUFBQ0MscUJBQVkifQ==
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9leGFtcGxlL3JpY2hUZXh0YXJlYS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHdpdGhTdHlsZSBmcm9tIFwiZWFzeS13aXRoLXN0eWxlXCI7XG5cbmltcG9ydCB7IFJpY2hUZXh0YXJlYSB9IGZyb20gXCIuLi9icm93c2VyXCI7ICAvLy9cblxuZXhwb3J0IGRlZmF1bHQgd2l0aFN0eWxlKFJpY2hUZXh0YXJlYSlgXG5cbiAgYm9yZGVyOiAxcHggc29saWQgYmxhY2s7XG4gIHdpZHRoOiAzMnJlbTtcbiAgaGVpZ2h0OiAzMnJlbTtcbiAgcGFkZGluZzogMC4yNXJlbTtcbiAgZm9udC1zaXplOiAxLjJyZW07XG4gIGZvbnQtZmFtaWx5OiBtb25vc3BhY2U7XG4gIFxuICBkaXNwbGF5OiBub25lO1xuICBcbiAgLmFjdGl2ZSB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gIH1cblxuYDtcbiJdLCJuYW1lcyI6WyJ3aXRoU3R5bGUiLCJSaWNoVGV4dGFyZWEiXSwibWFwcGluZ3MiOiJBQUFBOzs7OytCQU1BOzs7ZUFBQTs7O2tFQUpzQjt1QkFFTzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQUU3QixXQUFlQSxJQUFBQSxzQkFBUyxFQUFDQyxxQkFBWSJ9
@@ -14,16 +14,19 @@ function _interopRequireDefault(obj) {
14
14
  default: obj
15
15
  };
16
16
  }
17
+ var content = "Rule (blah)\n Conclusion\n A", readOnly = true, richTextarea = /*#__PURE__*/ React.createElement(_richTextarea.default, {
18
+ onChange: changeHandler,
19
+ onScroll: scrollHandler,
20
+ onFocus: focusHandler,
21
+ onBlur: blurHandler
22
+ });
23
+ richTextarea.setContent(content);
24
+ richTextarea.setReadOnly(readOnly);
25
+ richTextarea.activate();
17
26
  var View = function(properties) {
18
27
  return /*#__PURE__*/ React.createElement("div", {
19
28
  className: "view"
20
- }, /*#__PURE__*/ React.createElement(_richTextarea.default, {
21
- onChange: changeHandler,
22
- onScroll: scrollHandler,
23
- onFocus: focusHandler,
24
- onBlur: blurHandler,
25
- active: true
26
- }));
29
+ }, richTextarea);
27
30
  };
28
31
  var _default = View;
29
32
  function changeHandler(event, element) {
@@ -41,4 +44,4 @@ function blurHandler(event, element) {
41
44
  console.log("blur");
42
45
  }
43
46
 
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9leGFtcGxlL3ZpZXcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCBSaWNoVGV4dGFyZWEgZnJvbSBcIi4vcmljaFRleHRhcmVhXCI7XG5cbmNvbnN0IFZpZXcgPSAocHJvcGVydGllcykgPT5cblxuICA8ZGl2IGNsYXNzTmFtZT1cInZpZXdcIj5cbiAgICA8UmljaFRleHRhcmVhIG9uQ2hhbmdlPXtjaGFuZ2VIYW5kbGVyfVxuICAgICAgICAgICAgICAgICAgb25TY3JvbGw9e3Njcm9sbEhhbmRsZXJ9XG4gICAgICAgICAgICAgICAgICBvbkZvY3VzPXtmb2N1c0hhbmRsZXJ9XG4gICAgICAgICAgICAgICAgICBvbkJsdXI9e2JsdXJIYW5kbGVyfVxuICAgICAgICAgICAgICAgICAgYWN0aXZlXG4gICAgLz5cbiAgPC9kaXY+XG5cbjtcblxuZXhwb3J0IGRlZmF1bHQgVmlldztcblxuZnVuY3Rpb24gY2hhbmdlSGFuZGxlcihldmVudCwgZWxlbWVudCkge1xuICBjb25zdCBjb250ZW50Q2hhbmdlZCA9IGVsZW1lbnQuaGFzQ29udGVudENoYW5nZWQoKSxcbiAgICAgICAgc2VsZWN0aW9uQ2hhbmdlZCA9IGVsZW1lbnQuaGFzU2VsZWN0aW9uQ2hhbmdlZCgpO1xuXG4gIGNvbnNvbGUubG9nKGNvbnRlbnRDaGFuZ2VkLCBzZWxlY3Rpb25DaGFuZ2VkKVxufVxuXG5mdW5jdGlvbiBzY3JvbGxIYW5kbGVyKGV2ZW50LCBlbGVtZW50KSB7XG4gIGNvbnN0IHNjcm9sbFRvcCA9IGVsZW1lbnQuZ2V0U2Nyb2xsVG9wKCksXG4gICAgICAgIHNjcm9sbExlZnQgPSBlbGVtZW50LmdldFNjcm9sbExlZnQoKTtcblxuICBjb25zb2xlLmxvZyhzY3JvbGxUb3AsIHNjcm9sbExlZnQpXG59XG5cbmZ1bmN0aW9uIGZvY3VzSGFuZGxlcihldmVudCwgZWxlbWVudCkge1xuICBjb25zb2xlLmxvZyhcImZvY3VzXCIpXG59XG5cbmZ1bmN0aW9uIGJsdXJIYW5kbGVyKGV2ZW50LCBlbGVtZW50KSB7XG4gIGNvbnNvbGUubG9nKFwiYmx1clwiKVxufVxuIl0sIm5hbWVzIjpbIlZpZXciLCJwcm9wZXJ0aWVzIiwiZGl2IiwiY2xhc3NOYW1lIiwiUmljaFRleHRhcmVhIiwib25DaGFuZ2UiLCJjaGFuZ2VIYW5kbGVyIiwib25TY3JvbGwiLCJzY3JvbGxIYW5kbGVyIiwib25Gb2N1cyIsImZvY3VzSGFuZGxlciIsIm9uQmx1ciIsImJsdXJIYW5kbGVyIiwiYWN0aXZlIiwiZXZlbnQiLCJlbGVtZW50IiwiY29udGVudENoYW5nZWQiLCJoYXNDb250ZW50Q2hhbmdlZCIsInNlbGVjdGlvbkNoYW5nZWQiLCJoYXNTZWxlY3Rpb25DaGFuZ2VkIiwiY29uc29sZSIsImxvZyIsInNjcm9sbFRvcCIsImdldFNjcm9sbFRvcCIsInNjcm9sbExlZnQiLCJnZXRTY3JvbGxMZWZ0Il0sIm1hcHBpbmdzIjoiQUFBQTs7OzsrQkFpQkE7OztlQUFBOzs7aUVBZnlCOzs7Ozs7QUFFekIsSUFBTUEsT0FBTyxTQUFDQzt5QkFFWixvQkFBQ0M7UUFBSUMsV0FBVTtxQkFDYixvQkFBQ0MscUJBQVk7UUFBQ0MsVUFBVUM7UUFDVkMsVUFBVUM7UUFDVkMsU0FBU0M7UUFDVEMsUUFBUUM7UUFDUkMsUUFBQUEsSUFBTTs7O0lBTXhCLFdBQWViO0FBRWYsU0FBU00sY0FBY1EsS0FBSyxFQUFFQyxPQUFPLEVBQUU7SUFDckMsSUFBTUMsaUJBQWlCRCxRQUFRRSxpQkFBaUIsSUFDMUNDLG1CQUFtQkgsUUFBUUksbUJBQW1CO0lBRXBEQyxRQUFRQyxHQUFHLENBQUNMLGdCQUFnQkU7QUFDOUI7QUFFQSxTQUFTVixjQUFjTSxLQUFLLEVBQUVDLE9BQU8sRUFBRTtJQUNyQyxJQUFNTyxZQUFZUCxRQUFRUSxZQUFZLElBQ2hDQyxhQUFhVCxRQUFRVSxhQUFhO0lBRXhDTCxRQUFRQyxHQUFHLENBQUNDLFdBQVdFO0FBQ3pCO0FBRUEsU0FBU2QsYUFBYUksS0FBSyxFQUFFQyxPQUFPLEVBQUU7SUFDcENLLFFBQVFDLEdBQUcsQ0FBQztBQUNkO0FBRUEsU0FBU1QsWUFBWUUsS0FBSyxFQUFFQyxPQUFPLEVBQUU7SUFDbkNLLFFBQVFDLEdBQUcsQ0FBQztBQUNkIn0=
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9leGFtcGxlL3ZpZXcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCBSaWNoVGV4dGFyZWEgZnJvbSBcIi4vcmljaFRleHRhcmVhXCI7XG5cbmNvbnN0IGNvbnRlbnQgPSBgUnVsZSAoYmxhaClcbiAgQ29uY2x1c2lvblxuICAgIEFgLFxuICAgICAgcmVhZE9ubHkgPSB0cnVlLFxuICAgICAgcmljaFRleHRhcmVhID1cblxuICAgICAgICA8UmljaFRleHRhcmVhIG9uQ2hhbmdlPXtjaGFuZ2VIYW5kbGVyfSBvblNjcm9sbD17c2Nyb2xsSGFuZGxlcn0gb25Gb2N1cz17Zm9jdXNIYW5kbGVyfSBvbkJsdXI9e2JsdXJIYW5kbGVyfSAvPlxuXG4gICAgICA7XG5cbnJpY2hUZXh0YXJlYS5zZXRDb250ZW50KGNvbnRlbnQpO1xucmljaFRleHRhcmVhLnNldFJlYWRPbmx5KHJlYWRPbmx5KTtcblxucmljaFRleHRhcmVhLmFjdGl2YXRlKCk7XG5cbmNvbnN0IFZpZXcgPSAocHJvcGVydGllcykgPT5cblxuICA8ZGl2IGNsYXNzTmFtZT1cInZpZXdcIj5cbiAgICB7cmljaFRleHRhcmVhfVxuICA8L2Rpdj5cblxuO1xuXG5leHBvcnQgZGVmYXVsdCBWaWV3O1xuXG5mdW5jdGlvbiBjaGFuZ2VIYW5kbGVyKGV2ZW50LCBlbGVtZW50KSB7XG4gIGNvbnN0IGNvbnRlbnRDaGFuZ2VkID0gZWxlbWVudC5oYXNDb250ZW50Q2hhbmdlZCgpLFxuICAgICAgICBzZWxlY3Rpb25DaGFuZ2VkID0gZWxlbWVudC5oYXNTZWxlY3Rpb25DaGFuZ2VkKCk7XG5cbiAgY29uc29sZS5sb2coY29udGVudENoYW5nZWQsIHNlbGVjdGlvbkNoYW5nZWQpXG59XG5cbmZ1bmN0aW9uIHNjcm9sbEhhbmRsZXIoZXZlbnQsIGVsZW1lbnQpIHtcbiAgY29uc3Qgc2Nyb2xsVG9wID0gZWxlbWVudC5nZXRTY3JvbGxUb3AoKSxcbiAgICAgICAgc2Nyb2xsTGVmdCA9IGVsZW1lbnQuZ2V0U2Nyb2xsTGVmdCgpO1xuXG4gIGNvbnNvbGUubG9nKHNjcm9sbFRvcCwgc2Nyb2xsTGVmdClcbn1cblxuZnVuY3Rpb24gZm9jdXNIYW5kbGVyKGV2ZW50LCBlbGVtZW50KSB7XG4gIGNvbnNvbGUubG9nKFwiZm9jdXNcIilcbn1cblxuZnVuY3Rpb24gYmx1ckhhbmRsZXIoZXZlbnQsIGVsZW1lbnQpIHtcbiAgY29uc29sZS5sb2coXCJibHVyXCIpXG59XG4iXSwibmFtZXMiOlsiY29udGVudCIsInJlYWRPbmx5IiwicmljaFRleHRhcmVhIiwiUmljaFRleHRhcmVhIiwib25DaGFuZ2UiLCJjaGFuZ2VIYW5kbGVyIiwib25TY3JvbGwiLCJzY3JvbGxIYW5kbGVyIiwib25Gb2N1cyIsImZvY3VzSGFuZGxlciIsIm9uQmx1ciIsImJsdXJIYW5kbGVyIiwic2V0Q29udGVudCIsInNldFJlYWRPbmx5IiwiYWN0aXZhdGUiLCJWaWV3IiwicHJvcGVydGllcyIsImRpdiIsImNsYXNzTmFtZSIsImV2ZW50IiwiZWxlbWVudCIsImNvbnRlbnRDaGFuZ2VkIiwiaGFzQ29udGVudENoYW5nZWQiLCJzZWxlY3Rpb25DaGFuZ2VkIiwiaGFzU2VsZWN0aW9uQ2hhbmdlZCIsImNvbnNvbGUiLCJsb2ciLCJzY3JvbGxUb3AiLCJnZXRTY3JvbGxUb3AiLCJzY3JvbGxMZWZ0IiwiZ2V0U2Nyb2xsTGVmdCJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7K0JBMkJBOzs7ZUFBQTs7O2lFQXpCeUI7Ozs7OztBQUV6QixJQUFNQSxVQUFXLG9DQUdYQyxXQUFXLElBQUksRUFDZkMsNkJBRUUsb0JBQUNDLHFCQUFZO0lBQUNDLFVBQVVDO0lBQWVDLFVBQVVDO0lBQWVDLFNBQVNDO0lBQWNDLFFBQVFDOztBQUl2R1QsYUFBYVUsVUFBVSxDQUFDWjtBQUN4QkUsYUFBYVcsV0FBVyxDQUFDWjtBQUV6QkMsYUFBYVksUUFBUTtBQUVyQixJQUFNQyxPQUFPLFNBQUNDO3lCQUVaLG9CQUFDQztRQUFJQyxXQUFVO09BQ1poQjs7SUFLTCxXQUFlYTtBQUVmLFNBQVNWLGNBQWNjLEtBQUssRUFBRUMsT0FBTyxFQUFFO0lBQ3JDLElBQU1DLGlCQUFpQkQsUUFBUUUsaUJBQWlCLElBQzFDQyxtQkFBbUJILFFBQVFJLG1CQUFtQjtJQUVwREMsUUFBUUMsR0FBRyxDQUFDTCxnQkFBZ0JFO0FBQzlCO0FBRUEsU0FBU2hCLGNBQWNZLEtBQUssRUFBRUMsT0FBTyxFQUFFO0lBQ3JDLElBQU1PLFlBQVlQLFFBQVFRLFlBQVksSUFDaENDLGFBQWFULFFBQVFVLGFBQWE7SUFFeENMLFFBQVFDLEdBQUcsQ0FBQ0MsV0FBV0U7QUFDekI7QUFFQSxTQUFTcEIsYUFBYVUsS0FBSyxFQUFFQyxPQUFPLEVBQUU7SUFDcENLLFFBQVFDLEdBQUcsQ0FBQztBQUNkO0FBRUEsU0FBU2YsWUFBWVEsS0FBSyxFQUFFQyxPQUFPLEVBQUU7SUFDbkNLLFFBQVFDLEdBQUcsQ0FBQztBQUNkIn0=
@@ -207,18 +207,19 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
207
207
  var _this;
208
208
  _this = _super.apply(this, arguments);
209
209
  _defineProperty(_assertThisInitialized(_this), "intermediateHandler", function(event, element, eventType, forced) {
210
+ var readOnly = _this.isReadOnly();
211
+ if (readOnly) {
212
+ var previousContent = _this.getPreviousContent(), content = previousContent; ///
213
+ _this.setContent(content);
214
+ }
210
215
  var changed = _this.hasChanged();
211
216
  if (changed || forced) {
212
217
  _this.callHandlers(eventType, event, element);
213
218
  }
214
- var content = _this.getContent(), selection = _this.getSelection(), previousContent = content, previousSelection = selection; ///
215
- _this.setPreviousContent(previousContent);
219
+ var content1 = _this.getContent(), selection = _this.getSelection(), previousContent1 = content1, previousSelection = selection; ///
220
+ _this.setPreviousContent(previousContent1);
216
221
  _this.setPreviousSelection(previousSelection);
217
222
  });
218
- _defineProperty(_assertThisInitialized(_this), "mouseUpHandler", function(event, element) {
219
- var mouseDown = false;
220
- _this.setMouseDown(mouseDown);
221
- });
222
223
  _defineProperty(_assertThisInitialized(_this), "mouseDownHandler", function(event, element) {
223
224
  var forced = false, mouseDown = true, eventType = CHANGE_EVENT_TYPE;
224
225
  _this.setMouseDown(mouseDown);
@@ -232,6 +233,10 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
232
233
  _this.intermediateHandler(event, element, eventTYpe, forced);
233
234
  }
234
235
  });
236
+ _defineProperty(_assertThisInitialized(_this), "mouseUpHandler", function(event, element) {
237
+ var mouseDown = false;
238
+ _this.setMouseDown(mouseDown);
239
+ });
235
240
  _defineProperty(_assertThisInitialized(_this), "keyDownHandler", function(event, element) {
236
241
  var forced = false, eventType = CHANGE_EVENT_TYPE;
237
242
  defer(function() {
@@ -266,13 +271,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
266
271
  return active;
267
272
  }
268
273
  },
269
- {
270
- key: "isReadOnly",
271
- value: function isReadOnly() {
272
- var domElement = this.getDOMElement(), readOnly = domElement.readOnly;
273
- return readOnly;
274
- }
275
- },
276
274
  {
277
275
  key: "getContent",
278
276
  value: function getContent() {
@@ -287,15 +285,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
287
285
  return selection;
288
286
  }
289
287
  },
290
- {
291
- key: "setReadOnly",
292
- value: function setReadOnly(readOnly) {
293
- var domElement = this.getDOMElement();
294
- Object.assign(domElement, {
295
- readOnly: readOnly
296
- });
297
- }
298
- },
299
288
  {
300
289
  key: "setContent",
301
290
  value: function setContent(content) {
@@ -317,13 +306,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
317
306
  this.setPreviousSelection(previousSelection);
318
307
  }
319
308
  },
320
- {
321
- key: "isMouseDown",
322
- value: function isMouseDown() {
323
- var state = this.getState(), mouseDown = state.mouseDown;
324
- return mouseDown;
325
- }
326
- },
327
309
  {
328
310
  key: "hasChanged",
329
311
  value: function hasChanged() {
@@ -454,20 +436,42 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
454
436
  });
455
437
  }
456
438
  },
439
+ {
440
+ key: "isReadOnly",
441
+ value: function isReadOnly() {
442
+ var readOnly = this.getState().readOnly;
443
+ return readOnly;
444
+ }
445
+ },
446
+ {
447
+ key: "isMouseDown",
448
+ value: function isMouseDown() {
449
+ var mouseDown = this.getState().mouseDown;
450
+ return mouseDown;
451
+ }
452
+ },
457
453
  {
458
454
  key: "getPreviousContent",
459
455
  value: function getPreviousContent() {
460
- var state = this.getState(), previousContent = state.previousContent;
456
+ var previousContent = this.getState().previousContent;
461
457
  return previousContent;
462
458
  }
463
459
  },
464
460
  {
465
461
  key: "getPreviousSelection",
466
462
  value: function getPreviousSelection() {
467
- var state = this.getState(), previousSelection = state.previousSelection;
463
+ var previousSelection = this.getState().previousSelection;
468
464
  return previousSelection;
469
465
  }
470
466
  },
467
+ {
468
+ key: "setReadOnly",
469
+ value: function setReadOnly(readOnly) {
470
+ this.updateState({
471
+ readOnly: readOnly
472
+ });
473
+ }
474
+ },
471
475
  {
472
476
  key: "setMouseDown",
473
477
  value: function setMouseDown(mouseDown) {
@@ -495,8 +499,9 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
495
499
  {
496
500
  key: "setInitialState",
497
501
  value: function setInitialState() {
498
- var mouseDown = false, previousContent = null, previousSelection = null;
502
+ var readOnly = false, mouseDown = false, previousContent = null, previousSelection = null;
499
503
  this.setState({
504
+ readOnly: readOnly,
500
505
  mouseDown: mouseDown,
501
506
  previousContent: previousContent,
502
507
  previousSelection: previousSelection
@@ -506,14 +511,14 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
506
511
  {
507
512
  key: "didMount",
508
513
  value: function didMount() {
509
- var _this_properties = this.properties, active = _this_properties.active, onChange = _this_properties.onChange, onScroll = _this_properties.onScroll, onFocus = _this_properties.onFocus, onBlur = _this_properties.onBlur, changeHandler = onChange, scrollHandler = onScroll, focusHandler = onFocus, blurHandler = onBlur; ///
514
+ var _this_properties = this.properties, onChange = _this_properties.onChange, onScroll = _this_properties.onScroll, onFocus = _this_properties.onFocus, onBlur = _this_properties.onBlur, changeHandler = onChange, scrollHandler = onScroll, focusHandler = onFocus, blurHandler = onBlur; ///
510
515
  changeHandler && this.onChange(changeHandler, this);
511
516
  scrollHandler && this.onScroll(scrollHandler, this);
512
517
  focusHandler && this.onFocus(focusHandler, this);
513
518
  blurHandler && this.onBlur(blurHandler, this);
514
- if (active) {
515
- this.activate();
516
- }
519
+ var content = this.getContent(), selection = this.getSelection(), previousContent = content, previousSelection = selection; ///
520
+ this.setPreviousSelection(previousSelection);
521
+ this.setPreviousContent(previousContent);
517
522
  }
518
523
  },
519
524
  {
@@ -524,6 +529,10 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
524
529
  scrollHandler && this.offScroll(scrollHandler, this);
525
530
  focusHandler && this.offFocus(focusHandler, this);
526
531
  blurHandler && this.offBlur(blurHandler, this);
532
+ var active = this.isActive();
533
+ if (active) {
534
+ this.deactivate();
535
+ }
527
536
  }
528
537
  },
529
538
  {
@@ -540,11 +549,10 @@ _defineProperty(RichTextarea, "ignoredProperties", [
540
549
  "onChange",
541
550
  "onScroll",
542
551
  "onFocus",
543
- "onBlur",
544
- "active"
552
+ "onBlur"
545
553
  ]);
546
554
  _defineProperty(RichTextarea, "defaultProperties", {
547
555
  className: "rich"
548
556
  });
549
557
 
550
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/richTextarea.js","<<jsx-config-pragma.js>>"],"sourcesContent":["\"use strict\";\r\n\r\nimport { window, Element, eventTypes } from \"easy\";\r\n\r\nimport Selection from \"./selection\"\r\n\r\nconst { BLUR_EVENT_TYPE,\r\n         INPUT_EVENT_TYPE,\r\n         FOCUS_EVENT_TYPE,\r\n         CHANGE_EVENT_TYPE,\r\n         SCROLL_EVENT_TYPE,\r\n         KEYDOWN_EVENT_TYPE,\r\n         MOUSEUP_EVENT_TYPE,\r\n         MOUSEDOWN_EVENT_TYPE,\r\n         MOUSEMOVE_EVENT_TYPE,\r\n         CONTEXTMENU_EVENT_TYPE } = eventTypes;\r\n\r\nconst defer = (func) => setTimeout(func, 1); ///\r\n\r\nexport default class RichTextarea extends Element {\r\n  intermediateHandler = (event, element, eventType, forced) => {\r\n    const changed = this.hasChanged();\r\n\r\n    if (changed || forced) {\r\n      this.callHandlers(eventType, event, element);\r\n    }\r\n\r\n    const content = this.getContent(),\r\n          selection = this.getSelection(),\r\n          previousContent = content,  ///\r\n          previousSelection = selection;  ///\r\n\r\n    this.setPreviousContent(previousContent);\r\n    this.setPreviousSelection(previousSelection);\r\n  }\r\n\r\n  mouseUpHandler = (event, element) => {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n  };\r\n\r\n  mouseDownHandler = (event, element) => {\r\n    const forced = false,\r\n        mouseDown = true,\r\n        eventType = CHANGE_EVENT_TYPE;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  mouseMoveHandler = (event, element) => {\r\n    const forced = false,\r\n        mouseDown = this.isMouseDown(),\r\n        eventTYpe = CHANGE_EVENT_TYPE;\r\n\r\n    if (mouseDown) {\r\n      this.intermediateHandler(event, element, eventTYpe, forced);\r\n    }\r\n  }\r\n\r\n  keyDownHandler = (event, element) => {\r\n    const forced = false,\r\n        eventType = CHANGE_EVENT_TYPE;\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  inputHandler = (event, element) => {\r\n    const forced = false,\r\n        eventType = CHANGE_EVENT_TYPE;\r\n\r\n    this.intermediateHandler(event, element, eventType, forced);\r\n  }\r\n\r\n  scrollHandler = (event, element) => {\r\n    const eventType = SCROLL_EVENT_TYPE;\r\n\r\n    this.callHandlers(eventType, event, element);\r\n  }\r\n\r\n  focusHandler = (event, element) => {\r\n    const forced = true,\r\n        eventType = FOCUS_EVENT_TYPE;\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  blurHandler = (event, element) => {\r\n    const forced = true,\r\n        eventType = BLUR_EVENT_TYPE;\r\n\r\n    this.intermediateHandler(event, element, eventType, forced);\r\n  }\r\n\r\n  isActive() {\r\n    const active = this.hasClass(\"active\");\r\n\r\n    return active;\r\n  }\r\n\r\n  isReadOnly() {\r\n    const domElement = this.getDOMElement(),\r\n          { readOnly } = domElement;\r\n    \r\n    return readOnly; \r\n  }\r\n\r\n  getContent() {\r\n    const domElement = this.getDOMElement(),\r\n          { value } = domElement,\r\n          content = value;  ///\r\n\r\n    return content;\r\n  }\r\n\r\n  getSelection() {\r\n    const domElement = this.getDOMElement(),\r\n          selection = Selection.fromDOMElement(domElement);\r\n\r\n    return selection;\r\n  }\r\n\r\n  setReadOnly(readOnly) {\r\n    const domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      readOnly\r\n    });\r\n  }\r\n\r\n  setContent(content) {\r\n    const value = content,  ///\r\n          previousContent = content,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      value\r\n    });\r\n\r\n    this.setPreviousContent(previousContent);\r\n  }\r\n\r\n  setSelection(selection) {\r\n    const selectionStartPosition = selection.getStartPosition(),\r\n          selectionEndPosition = selection.getEndPosition(),\r\n          selectionStart = selectionStartPosition,  ///\r\n          selectionEnd = selectionEndPosition,  ///\r\n          previousSelection = selection,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      selectionStart,\r\n      selectionEnd\r\n    });\r\n\r\n    this.setPreviousSelection(previousSelection);\r\n  }\r\n\r\n  isMouseDown() {\r\n    const state = this.getState(),\r\n          { mouseDown } = state;\r\n\r\n    return mouseDown;\r\n  }\r\n\r\n  hasChanged() {\r\n    const contentChanged = this.hasContentChanged(),\r\n          selectionChanged = this.hasSelectionChanged(),\r\n          changed = (contentChanged || selectionChanged);\r\n\r\n    return changed;\r\n  }\r\n\r\n  hasContentChanged() {\r\n    const content = this.getContent(),\r\n          previousContent = this.getPreviousContent(),\r\n          contentDifferentToPreviousContent = (content !== previousContent),\r\n          contentChanged = contentDifferentToPreviousContent; ///\r\n\r\n    return contentChanged;\r\n  }\r\n\r\n  hasSelectionChanged() {\r\n    const selection = this.getSelection(),\r\n          previousSelection = this.getPreviousSelection(),\r\n          selectionDifferentToPreviousSelection = selection.isDifferentTo(previousSelection),\r\n          selectionChanged = selectionDifferentToPreviousSelection; ///\r\n\r\n    return selectionChanged;\r\n  }\r\n\r\n  activate() {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    window.on(`${BLUR_EVENT_TYPE} ${MOUSEUP_EVENT_TYPE} ${CONTEXTMENU_EVENT_TYPE}`, this.mouseUpHandler, this); ///\r\n\r\n    this.on(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler, this);\r\n\r\n    this.on(MOUSEMOVE_EVENT_TYPE, this.mouseMoveHandler, this);\r\n\r\n    this.on(KEYDOWN_EVENT_TYPE, this.keyDownHandler, this);\r\n\r\n    this.on(INPUT_EVENT_TYPE, this.inputHandler, this);\r\n\r\n    this.on(SCROLL_EVENT_TYPE, this.scrollHandler, this);\r\n\r\n    this.on(FOCUS_EVENT_TYPE, this.focusHandler, this);\r\n\r\n    this.on(BLUR_EVENT_TYPE, this.blurHandler, this);\r\n\r\n    this.addClass(\"active\");\r\n  }\r\n\r\n  deactivate() {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    window.off(`${BLUR_EVENT_TYPE} ${MOUSEUP_EVENT_TYPE} ${CONTEXTMENU_EVENT_TYPE}`, this.mouseUpHandler, this); ///\r\n\r\n    this.off(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler, this);\r\n\r\n    this.off(MOUSEMOVE_EVENT_TYPE, this.mouseMoveHandler, this);\r\n\r\n    this.off(KEYDOWN_EVENT_TYPE, this.keyDownHandler, this);\r\n\r\n    this.off(INPUT_EVENT_TYPE, this.inputHandler, this);\r\n\r\n    this.off(SCROLL_EVENT_TYPE, this.scrollHandler, this);\r\n\r\n    this.off(FOCUS_EVENT_TYPE, this.focusHandler, this);\r\n\r\n    this.off(BLUR_EVENT_TYPE, this.blurHandler, this);\r\n\r\n    this.removeClass(\"active\");\r\n  }\r\n\r\n  onBlur(blurHandler, element) {\r\n    const eventType = BLUR_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offBlur(blurHandler, element) {\r\n    const eventType = BLUR_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onFocus(blurHandler, element) {\r\n    const eventType = FOCUS_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offFocus(blurHandler, element) {\r\n    const eventType = FOCUS_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onScroll(scrollHandler, element) {\r\n    const eventType = SCROLL_EVENT_TYPE,\r\n          handler = scrollHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offScroll(scrollHandler, element) {\r\n    const eventType = SCROLL_EVENT_TYPE,\r\n          handler = scrollHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onChange(changeHandler, element) {\r\n    const eventType = CHANGE_EVENT_TYPE,\r\n          handler = changeHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offChange(changeHandler, element) {\r\n    const eventType = CHANGE_EVENT_TYPE,\r\n          handler = changeHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  callHandlers(eventType, ...remainingArguments) {\r\n    const eventListeners = this.findEventListeners(eventType);\r\n\r\n    eventListeners.forEach((eventListener) => {\r\n      const { handler, element: handlerElement } = eventListener,\r\n            element = this; ///\r\n\r\n      if ((handler !== this.blurHandler) && (handler !== this.focusHandler) && (handler !== this.scrollHandler)) {\r\n        handler.call(handlerElement, ...remainingArguments, element);\r\n      }\r\n    });\r\n  }\r\n\r\n  getPreviousContent() {\r\n    const state = this.getState(),\r\n          { previousContent } = state;\r\n\r\n    return previousContent;\r\n  }\r\n\r\n  getPreviousSelection() {\r\n    const state = this.getState(),\r\n          { previousSelection } = state;\r\n\r\n    return previousSelection;\r\n  }\r\n\r\n  setMouseDown(mouseDown) {\r\n    this.updateState({\r\n      mouseDown\r\n    });\r\n  }\r\n\r\n  setPreviousContent(previousContent) {\r\n    this.updateState({\r\n      previousContent\r\n    });\r\n  }\r\n\r\n  setPreviousSelection(previousSelection) {\r\n    this.updateState({\r\n      previousSelection\r\n    });\r\n  }\r\n\r\n  setInitialState() {\r\n    const mouseDown = false,\r\n          previousContent = null,\r\n          previousSelection = null;\r\n\r\n    this.setState({\r\n      mouseDown,\r\n      previousContent,\r\n      previousSelection\r\n    });\r\n  }\r\n\r\n  didMount() {\r\n    const { active, onChange, onScroll, onFocus, onBlur } = this.properties,\r\n            changeHandler = onChange, ///\r\n            scrollHandler = onScroll, ///\r\n            focusHandler = onFocus, ///\r\n            blurHandler = onBlur; ///\r\n\r\n    changeHandler && this.onChange(changeHandler, this);\r\n    scrollHandler && this.onScroll(scrollHandler, this);\r\n    focusHandler && this.onFocus(focusHandler, this);\r\n    blurHandler && this.onBlur(blurHandler, this);\r\n\r\n    if (active) {\r\n      this.activate();\r\n    }\r\n  }\r\n\r\n  willUnmount() {\r\n    const { onChange, onScroll, onFocus, onBlur } = this.properties,\r\n          changeHandler = onChange, ///\r\n          scrollHandler = onScroll, ///\r\n          focusHandler = onFocus, ///\r\n          blurHandler = onBlur; ///\r\n\r\n    changeHandler && this.offChange(changeHandler, this);\r\n    scrollHandler && this.offScroll(scrollHandler, this);\r\n    focusHandler && this.offFocus(focusHandler, this);\r\n    blurHandler && this.offBlur(blurHandler, this);\r\n  }\r\n\r\n  initialise() {\r\n    this.setInitialState();\r\n  }\r\n\r\n  static tagName = \"textarea\";\r\n\r\n  static ignoredProperties = [\r\n    \"onChange\",\r\n    \"onScroll\",\r\n    \"onFocus\",\r\n    \"onBlur\",\r\n    \"active\"\r\n  ];\r\n\r\n  static defaultProperties = {\r\n    className: \"rich\"\r\n  };\r\n}\r\n","React.createElement"],"names":["RichTextarea","BLUR_EVENT_TYPE","eventTypes","INPUT_EVENT_TYPE","FOCUS_EVENT_TYPE","CHANGE_EVENT_TYPE","SCROLL_EVENT_TYPE","KEYDOWN_EVENT_TYPE","MOUSEUP_EVENT_TYPE","MOUSEDOWN_EVENT_TYPE","MOUSEMOVE_EVENT_TYPE","CONTEXTMENU_EVENT_TYPE","defer","func","setTimeout","intermediateHandler","event","element","eventType","forced","changed","hasChanged","callHandlers","content","getContent","selection","getSelection","previousContent","previousSelection","setPreviousContent","setPreviousSelection","mouseUpHandler","mouseDown","setMouseDown","mouseDownHandler","mouseMoveHandler","isMouseDown","eventTYpe","keyDownHandler","inputHandler","scrollHandler","focusHandler","blurHandler","isActive","active","hasClass","isReadOnly","domElement","getDOMElement","readOnly","value","Selection","fromDOMElement","setReadOnly","Object","assign","setContent","setSelection","selectionStartPosition","getStartPosition","selectionEndPosition","getEndPosition","selectionStart","selectionEnd","state","getState","contentChanged","hasContentChanged","selectionChanged","hasSelectionChanged","getPreviousContent","contentDifferentToPreviousContent","getPreviousSelection","selectionDifferentToPreviousSelection","isDifferentTo","activate","window","on","addClass","deactivate","off","removeClass","onBlur","handler","addEventListener","offBlur","removeEventListener","onFocus","offFocus","onScroll","offScroll","onChange","changeHandler","offChange","remainingArguments","eventListeners","findEventListeners","forEach","eventListener","handlerElement","call","updateState","setInitialState","setState","didMount","properties","willUnmount","initialise","Element","tagName","ignoredProperties","defaultProperties","className"],"mappings":"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"}
558
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/richTextarea.js","<<jsx-config-pragma.js>>"],"sourcesContent":["\"use strict\";\r\n\r\nimport { window, Element, eventTypes } from \"easy\";\r\n\r\nimport Selection from \"./selection\"\r\n\r\nconst { BLUR_EVENT_TYPE,\r\n         INPUT_EVENT_TYPE,\r\n         FOCUS_EVENT_TYPE,\r\n         CHANGE_EVENT_TYPE,\r\n         SCROLL_EVENT_TYPE,\r\n         KEYDOWN_EVENT_TYPE,\r\n         MOUSEUP_EVENT_TYPE,\r\n         MOUSEDOWN_EVENT_TYPE,\r\n         MOUSEMOVE_EVENT_TYPE,\r\n         CONTEXTMENU_EVENT_TYPE } = eventTypes;\r\n\r\nconst defer = (func) => setTimeout(func, 1); ///\r\n\r\nexport default class RichTextarea extends Element {\r\n  intermediateHandler = (event, element, eventType, forced) => {\r\n    const readOnly = this.isReadOnly();\r\n\r\n    if (readOnly) {\r\n      const previousContent = this.getPreviousContent(),\r\n            content = previousContent;  ///\r\n\r\n      this.setContent(content);\r\n    }\r\n\r\n    const changed = this.hasChanged();\r\n\r\n    if (changed || forced) {\r\n      this.callHandlers(eventType, event, element);\r\n    }\r\n\r\n    const content = this.getContent(),\r\n          selection = this.getSelection(),\r\n          previousContent = content,  ///\r\n          previousSelection = selection;  ///\r\n\r\n    this.setPreviousContent(previousContent);\r\n    this.setPreviousSelection(previousSelection);\r\n  }\r\n\r\n  mouseDownHandler = (event, element) => {\r\n    const forced = false,\r\n          mouseDown = true,\r\n          eventType = CHANGE_EVENT_TYPE;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  mouseMoveHandler = (event, element) => {\r\n    const forced = false,\r\n          mouseDown = this.isMouseDown(),\r\n          eventTYpe = CHANGE_EVENT_TYPE;\r\n\r\n    if (mouseDown) {\r\n      this.intermediateHandler(event, element, eventTYpe, forced);\r\n    }\r\n  }\r\n\r\n  mouseUpHandler = (event, element) => {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n  };\r\n\r\n  keyDownHandler = (event, element) => {\r\n    const forced = false,\r\n          eventType = CHANGE_EVENT_TYPE;\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  inputHandler = (event, element) => {\r\n    const forced = false,\r\n          eventType = CHANGE_EVENT_TYPE;\r\n\r\n    this.intermediateHandler(event, element, eventType, forced);\r\n  }\r\n\r\n  scrollHandler = (event, element) => {\r\n    const eventType = SCROLL_EVENT_TYPE;\r\n\r\n    this.callHandlers(eventType, event, element);\r\n  }\r\n\r\n  focusHandler = (event, element) => {\r\n    const forced = true,\r\n          eventType = FOCUS_EVENT_TYPE;\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  blurHandler = (event, element) => {\r\n    const forced = true,\r\n          eventType = BLUR_EVENT_TYPE;\r\n\r\n    this.intermediateHandler(event, element, eventType, forced);\r\n  }\r\n\r\n  isActive() {\r\n    const active = this.hasClass(\"active\");\r\n\r\n    return active;\r\n  }\r\n\r\n  getContent() {\r\n    const domElement = this.getDOMElement(),\r\n          { value } = domElement,\r\n          content = value;  ///\r\n\r\n    return content;\r\n  }\r\n\r\n  getSelection() {\r\n    const domElement = this.getDOMElement(),\r\n          selection = Selection.fromDOMElement(domElement);\r\n\r\n    return selection;\r\n  }\r\n\r\n  setContent(content) {\r\n    const value = content,  ///\r\n          previousContent = content,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      value\r\n    });\r\n\r\n    this.setPreviousContent(previousContent);\r\n  }\r\n\r\n  setSelection(selection) {\r\n    const selectionStartPosition = selection.getStartPosition(),\r\n          selectionEndPosition = selection.getEndPosition(),\r\n          selectionStart = selectionStartPosition,  ///\r\n          selectionEnd = selectionEndPosition,  ///\r\n          previousSelection = selection,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      selectionStart,\r\n      selectionEnd\r\n    });\r\n\r\n    this.setPreviousSelection(previousSelection);\r\n  }\r\n\r\n  hasChanged() {\r\n    const contentChanged = this.hasContentChanged(),\r\n          selectionChanged = this.hasSelectionChanged(),\r\n          changed = (contentChanged || selectionChanged);\r\n\r\n    return changed;\r\n  }\r\n\r\n  hasContentChanged() {\r\n    const content = this.getContent(),\r\n          previousContent = this.getPreviousContent(),\r\n          contentDifferentToPreviousContent = (content !== previousContent),\r\n          contentChanged = contentDifferentToPreviousContent; ///\r\n\r\n    return contentChanged;\r\n  }\r\n\r\n  hasSelectionChanged() {\r\n    const selection = this.getSelection(),\r\n          previousSelection = this.getPreviousSelection(),\r\n          selectionDifferentToPreviousSelection = selection.isDifferentTo(previousSelection),\r\n          selectionChanged = selectionDifferentToPreviousSelection; ///\r\n\r\n    return selectionChanged;\r\n  }\r\n\r\n  activate() {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    window.on(`${BLUR_EVENT_TYPE} ${MOUSEUP_EVENT_TYPE} ${CONTEXTMENU_EVENT_TYPE}`, this.mouseUpHandler, this); ///\r\n\r\n    this.on(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler, this);\r\n\r\n    this.on(MOUSEMOVE_EVENT_TYPE, this.mouseMoveHandler, this);\r\n\r\n    this.on(KEYDOWN_EVENT_TYPE, this.keyDownHandler, this);\r\n\r\n    this.on(INPUT_EVENT_TYPE, this.inputHandler, this);\r\n\r\n    this.on(SCROLL_EVENT_TYPE, this.scrollHandler, this);\r\n\r\n    this.on(FOCUS_EVENT_TYPE, this.focusHandler, this);\r\n\r\n    this.on(BLUR_EVENT_TYPE, this.blurHandler, this);\r\n\r\n    this.addClass(\"active\");\r\n  }\r\n\r\n  deactivate() {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    window.off(`${BLUR_EVENT_TYPE} ${MOUSEUP_EVENT_TYPE} ${CONTEXTMENU_EVENT_TYPE}`, this.mouseUpHandler, this); ///\r\n\r\n    this.off(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler, this);\r\n\r\n    this.off(MOUSEMOVE_EVENT_TYPE, this.mouseMoveHandler, this);\r\n\r\n    this.off(KEYDOWN_EVENT_TYPE, this.keyDownHandler, this);\r\n\r\n    this.off(INPUT_EVENT_TYPE, this.inputHandler, this);\r\n\r\n    this.off(SCROLL_EVENT_TYPE, this.scrollHandler, this);\r\n\r\n    this.off(FOCUS_EVENT_TYPE, this.focusHandler, this);\r\n\r\n    this.off(BLUR_EVENT_TYPE, this.blurHandler, this);\r\n\r\n    this.removeClass(\"active\");\r\n  }\r\n\r\n  onBlur(blurHandler, element) {\r\n    const eventType = BLUR_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offBlur(blurHandler, element) {\r\n    const eventType = BLUR_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onFocus(blurHandler, element) {\r\n    const eventType = FOCUS_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offFocus(blurHandler, element) {\r\n    const eventType = FOCUS_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onScroll(scrollHandler, element) {\r\n    const eventType = SCROLL_EVENT_TYPE,\r\n          handler = scrollHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offScroll(scrollHandler, element) {\r\n    const eventType = SCROLL_EVENT_TYPE,\r\n          handler = scrollHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onChange(changeHandler, element) {\r\n    const eventType = CHANGE_EVENT_TYPE,\r\n          handler = changeHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offChange(changeHandler, element) {\r\n    const eventType = CHANGE_EVENT_TYPE,\r\n          handler = changeHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  callHandlers(eventType, ...remainingArguments) {\r\n    const eventListeners = this.findEventListeners(eventType);\r\n\r\n    eventListeners.forEach((eventListener) => {\r\n      const { handler, element: handlerElement } = eventListener,\r\n            element = this; ///\r\n\r\n      if ((handler !== this.blurHandler) && (handler !== this.focusHandler) && (handler !== this.scrollHandler)) {\r\n        handler.call(handlerElement, ...remainingArguments, element);\r\n      }\r\n    });\r\n  }\r\n\r\n  isReadOnly() {\r\n    const { readOnly } = this.getState();\r\n\r\n    return readOnly;\r\n  }\r\n\r\n  isMouseDown() {\r\n    const { mouseDown } = this.getState();\r\n\r\n    return mouseDown;\r\n  }\r\n\r\n  getPreviousContent() {\r\n    const { previousContent } = this.getState();\r\n\r\n    return previousContent;\r\n  }\r\n\r\n  getPreviousSelection() {\r\n    const { previousSelection } = this.getState();\r\n\r\n    return previousSelection;\r\n  }\r\n\r\n  setReadOnly(readOnly) {\r\n    this.updateState({\r\n      readOnly\r\n    });\r\n  }\r\n\r\n  setMouseDown(mouseDown) {\r\n    this.updateState({\r\n      mouseDown\r\n    });\r\n  }\r\n\r\n  setPreviousContent(previousContent) {\r\n    this.updateState({\r\n      previousContent\r\n    });\r\n  }\r\n\r\n  setPreviousSelection(previousSelection) {\r\n    this.updateState({\r\n      previousSelection\r\n    });\r\n  }\r\n\r\n  setInitialState() {\r\n    const readOnly = false,\r\n          mouseDown = false,\r\n          previousContent = null,\r\n          previousSelection = null;\r\n\r\n    this.setState({\r\n      readOnly,\r\n      mouseDown,\r\n      previousContent,\r\n      previousSelection\r\n    });\r\n  }\r\n\r\n  didMount() {\r\n    const { onChange, onScroll, onFocus, onBlur } = this.properties,\r\n            changeHandler = onChange, ///\r\n            scrollHandler = onScroll, ///\r\n            focusHandler = onFocus, ///\r\n            blurHandler = onBlur; ///\r\n\r\n    changeHandler && this.onChange(changeHandler, this);\r\n    scrollHandler && this.onScroll(scrollHandler, this);\r\n    focusHandler && this.onFocus(focusHandler, this);\r\n    blurHandler && this.onBlur(blurHandler, this);\r\n\r\n    const content = this.getContent(),\r\n          selection = this.getSelection(),\r\n          previousContent = content,  ///\r\n          previousSelection = selection;  ///\r\n\r\n    this.setPreviousSelection(previousSelection);\r\n\r\n    this.setPreviousContent(previousContent);\r\n  }\r\n\r\n  willUnmount() {\r\n    const { onChange, onScroll, onFocus, onBlur } = this.properties,\r\n          changeHandler = onChange, ///\r\n          scrollHandler = onScroll, ///\r\n          focusHandler = onFocus, ///\r\n          blurHandler = onBlur; ///\r\n\r\n    changeHandler && this.offChange(changeHandler, this);\r\n    scrollHandler && this.offScroll(scrollHandler, this);\r\n    focusHandler && this.offFocus(focusHandler, this);\r\n    blurHandler && this.offBlur(blurHandler, this);\r\n\r\n    const active = this.isActive();\r\n\r\n    if (active) {\r\n      this.deactivate();\r\n    }\r\n  }\r\n\r\n  initialise() {\r\n    this.setInitialState();\r\n  }\r\n\r\n  static tagName = \"textarea\";\r\n\r\n  static ignoredProperties = [\r\n    \"onChange\",\r\n    \"onScroll\",\r\n    \"onFocus\",\r\n    \"onBlur\"\r\n  ];\r\n\r\n  static defaultProperties = {\r\n    className: \"rich\"\r\n  };\r\n}\r\n","React.createElement"],"names":["RichTextarea","BLUR_EVENT_TYPE","eventTypes","INPUT_EVENT_TYPE","FOCUS_EVENT_TYPE","CHANGE_EVENT_TYPE","SCROLL_EVENT_TYPE","KEYDOWN_EVENT_TYPE","MOUSEUP_EVENT_TYPE","MOUSEDOWN_EVENT_TYPE","MOUSEMOVE_EVENT_TYPE","CONTEXTMENU_EVENT_TYPE","defer","func","setTimeout","intermediateHandler","event","element","eventType","forced","readOnly","isReadOnly","previousContent","getPreviousContent","content","setContent","changed","hasChanged","callHandlers","getContent","selection","getSelection","previousSelection","setPreviousContent","setPreviousSelection","mouseDownHandler","mouseDown","setMouseDown","mouseMoveHandler","isMouseDown","eventTYpe","mouseUpHandler","keyDownHandler","inputHandler","scrollHandler","focusHandler","blurHandler","isActive","active","hasClass","domElement","getDOMElement","value","Selection","fromDOMElement","Object","assign","setSelection","selectionStartPosition","getStartPosition","selectionEndPosition","getEndPosition","selectionStart","selectionEnd","contentChanged","hasContentChanged","selectionChanged","hasSelectionChanged","contentDifferentToPreviousContent","getPreviousSelection","selectionDifferentToPreviousSelection","isDifferentTo","activate","window","on","addClass","deactivate","off","removeClass","onBlur","handler","addEventListener","offBlur","removeEventListener","onFocus","offFocus","onScroll","offScroll","onChange","changeHandler","offChange","remainingArguments","eventListeners","findEventListeners","forEach","eventListener","handlerElement","call","getState","setReadOnly","updateState","setInitialState","setState","didMount","properties","willUnmount","initialise","Element","tagName","ignoredProperties","defaultProperties","className"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "easy-richtextarea",
3
3
  "author": "James Smith",
4
- "version": "3.0.146",
4
+ "version": "3.0.148",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/easy-richtextarea",
7
7
  "description": "A textarea element that handles and hands off events well.",
@@ -12,5 +12,11 @@ export default withStyle(RichTextarea)`
12
12
  padding: 0.25rem;
13
13
  font-size: 1.2rem;
14
14
  font-family: monospace;
15
+
16
+ display: none;
17
+
18
+ .active {
19
+ display: block;
20
+ }
15
21
 
16
22
  `;
@@ -2,15 +2,25 @@
2
2
 
3
3
  import RichTextarea from "./richTextarea";
4
4
 
5
+ const content = `Rule (blah)
6
+ Conclusion
7
+ A`,
8
+ readOnly = true,
9
+ richTextarea =
10
+
11
+ <RichTextarea onChange={changeHandler} onScroll={scrollHandler} onFocus={focusHandler} onBlur={blurHandler} />
12
+
13
+ ;
14
+
15
+ richTextarea.setContent(content);
16
+ richTextarea.setReadOnly(readOnly);
17
+
18
+ richTextarea.activate();
19
+
5
20
  const View = (properties) =>
6
21
 
7
22
  <div className="view">
8
- <RichTextarea onChange={changeHandler}
9
- onScroll={scrollHandler}
10
- onFocus={focusHandler}
11
- onBlur={blurHandler}
12
- active
13
- />
23
+ {richTextarea}
14
24
  </div>
15
25
 
16
26
  ;
@@ -19,6 +19,15 @@ const defer = (func) => setTimeout(func, 1); ///
19
19
 
20
20
  export default class RichTextarea extends Element {
21
21
  intermediateHandler = (event, element, eventType, forced) => {
22
+ const readOnly = this.isReadOnly();
23
+
24
+ if (readOnly) {
25
+ const previousContent = this.getPreviousContent(),
26
+ content = previousContent; ///
27
+
28
+ this.setContent(content);
29
+ }
30
+
22
31
  const changed = this.hasChanged();
23
32
 
24
33
  if (changed || forced) {
@@ -34,16 +43,10 @@ export default class RichTextarea extends Element {
34
43
  this.setPreviousSelection(previousSelection);
35
44
  }
36
45
 
37
- mouseUpHandler = (event, element) => {
38
- const mouseDown = false;
39
-
40
- this.setMouseDown(mouseDown);
41
- };
42
-
43
46
  mouseDownHandler = (event, element) => {
44
47
  const forced = false,
45
- mouseDown = true,
46
- eventType = CHANGE_EVENT_TYPE;
48
+ mouseDown = true,
49
+ eventType = CHANGE_EVENT_TYPE;
47
50
 
48
51
  this.setMouseDown(mouseDown);
49
52
 
@@ -52,24 +55,30 @@ export default class RichTextarea extends Element {
52
55
 
53
56
  mouseMoveHandler = (event, element) => {
54
57
  const forced = false,
55
- mouseDown = this.isMouseDown(),
56
- eventTYpe = CHANGE_EVENT_TYPE;
58
+ mouseDown = this.isMouseDown(),
59
+ eventTYpe = CHANGE_EVENT_TYPE;
57
60
 
58
61
  if (mouseDown) {
59
62
  this.intermediateHandler(event, element, eventTYpe, forced);
60
63
  }
61
64
  }
62
65
 
66
+ mouseUpHandler = (event, element) => {
67
+ const mouseDown = false;
68
+
69
+ this.setMouseDown(mouseDown);
70
+ };
71
+
63
72
  keyDownHandler = (event, element) => {
64
73
  const forced = false,
65
- eventType = CHANGE_EVENT_TYPE;
74
+ eventType = CHANGE_EVENT_TYPE;
66
75
 
67
76
  defer(() => this.intermediateHandler(event, element, eventType, forced));
68
77
  }
69
78
 
70
79
  inputHandler = (event, element) => {
71
80
  const forced = false,
72
- eventType = CHANGE_EVENT_TYPE;
81
+ eventType = CHANGE_EVENT_TYPE;
73
82
 
74
83
  this.intermediateHandler(event, element, eventType, forced);
75
84
  }
@@ -82,14 +91,14 @@ export default class RichTextarea extends Element {
82
91
 
83
92
  focusHandler = (event, element) => {
84
93
  const forced = true,
85
- eventType = FOCUS_EVENT_TYPE;
94
+ eventType = FOCUS_EVENT_TYPE;
86
95
 
87
96
  defer(() => this.intermediateHandler(event, element, eventType, forced));
88
97
  }
89
98
 
90
99
  blurHandler = (event, element) => {
91
100
  const forced = true,
92
- eventType = BLUR_EVENT_TYPE;
101
+ eventType = BLUR_EVENT_TYPE;
93
102
 
94
103
  this.intermediateHandler(event, element, eventType, forced);
95
104
  }
@@ -100,13 +109,6 @@ export default class RichTextarea extends Element {
100
109
  return active;
101
110
  }
102
111
 
103
- isReadOnly() {
104
- const domElement = this.getDOMElement(),
105
- { readOnly } = domElement;
106
-
107
- return readOnly;
108
- }
109
-
110
112
  getContent() {
111
113
  const domElement = this.getDOMElement(),
112
114
  { value } = domElement,
@@ -122,14 +124,6 @@ export default class RichTextarea extends Element {
122
124
  return selection;
123
125
  }
124
126
 
125
- setReadOnly(readOnly) {
126
- const domElement = this.getDOMElement();
127
-
128
- Object.assign(domElement, {
129
- readOnly
130
- });
131
- }
132
-
133
127
  setContent(content) {
134
128
  const value = content, ///
135
129
  previousContent = content, ///
@@ -158,13 +152,6 @@ export default class RichTextarea extends Element {
158
152
  this.setPreviousSelection(previousSelection);
159
153
  }
160
154
 
161
- isMouseDown() {
162
- const state = this.getState(),
163
- { mouseDown } = state;
164
-
165
- return mouseDown;
166
- }
167
-
168
155
  hasChanged() {
169
156
  const contentChanged = this.hasContentChanged(),
170
157
  selectionChanged = this.hasSelectionChanged(),
@@ -308,20 +295,36 @@ export default class RichTextarea extends Element {
308
295
  });
309
296
  }
310
297
 
298
+ isReadOnly() {
299
+ const { readOnly } = this.getState();
300
+
301
+ return readOnly;
302
+ }
303
+
304
+ isMouseDown() {
305
+ const { mouseDown } = this.getState();
306
+
307
+ return mouseDown;
308
+ }
309
+
311
310
  getPreviousContent() {
312
- const state = this.getState(),
313
- { previousContent } = state;
311
+ const { previousContent } = this.getState();
314
312
 
315
313
  return previousContent;
316
314
  }
317
315
 
318
316
  getPreviousSelection() {
319
- const state = this.getState(),
320
- { previousSelection } = state;
317
+ const { previousSelection } = this.getState();
321
318
 
322
319
  return previousSelection;
323
320
  }
324
321
 
322
+ setReadOnly(readOnly) {
323
+ this.updateState({
324
+ readOnly
325
+ });
326
+ }
327
+
325
328
  setMouseDown(mouseDown) {
326
329
  this.updateState({
327
330
  mouseDown
@@ -341,11 +344,13 @@ export default class RichTextarea extends Element {
341
344
  }
342
345
 
343
346
  setInitialState() {
344
- const mouseDown = false,
347
+ const readOnly = false,
348
+ mouseDown = false,
345
349
  previousContent = null,
346
350
  previousSelection = null;
347
351
 
348
352
  this.setState({
353
+ readOnly,
349
354
  mouseDown,
350
355
  previousContent,
351
356
  previousSelection
@@ -353,7 +358,7 @@ export default class RichTextarea extends Element {
353
358
  }
354
359
 
355
360
  didMount() {
356
- const { active, onChange, onScroll, onFocus, onBlur } = this.properties,
361
+ const { onChange, onScroll, onFocus, onBlur } = this.properties,
357
362
  changeHandler = onChange, ///
358
363
  scrollHandler = onScroll, ///
359
364
  focusHandler = onFocus, ///
@@ -364,9 +369,14 @@ export default class RichTextarea extends Element {
364
369
  focusHandler && this.onFocus(focusHandler, this);
365
370
  blurHandler && this.onBlur(blurHandler, this);
366
371
 
367
- if (active) {
368
- this.activate();
369
- }
372
+ const content = this.getContent(),
373
+ selection = this.getSelection(),
374
+ previousContent = content, ///
375
+ previousSelection = selection; ///
376
+
377
+ this.setPreviousSelection(previousSelection);
378
+
379
+ this.setPreviousContent(previousContent);
370
380
  }
371
381
 
372
382
  willUnmount() {
@@ -380,6 +390,12 @@ export default class RichTextarea extends Element {
380
390
  scrollHandler && this.offScroll(scrollHandler, this);
381
391
  focusHandler && this.offFocus(focusHandler, this);
382
392
  blurHandler && this.offBlur(blurHandler, this);
393
+
394
+ const active = this.isActive();
395
+
396
+ if (active) {
397
+ this.deactivate();
398
+ }
383
399
  }
384
400
 
385
401
  initialise() {
@@ -392,8 +408,7 @@ export default class RichTextarea extends Element {
392
408
  "onChange",
393
409
  "onScroll",
394
410
  "onFocus",
395
- "onBlur",
396
- "active"
411
+ "onBlur"
397
412
  ];
398
413
 
399
414
  static defaultProperties = {