easy-richtextarea 4.0.202 → 4.0.206

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.
@@ -26,9 +26,6 @@ _export(exports, {
26
26
  },
27
27
  SCROLL_CUSTOM_EVENT_TYPE: function() {
28
28
  return SCROLL_CUSTOM_EVENT_TYPE;
29
- },
30
- default: function() {
31
- return _default;
32
29
  }
33
30
  });
34
31
  var BLUR_CUSTOM_EVENT_TYPE = "blur";
@@ -37,13 +34,5 @@ var SCROLL_CUSTOM_EVENT_TYPE = "scroll";
37
34
  var CHANGE_CUSTOM_EVENT_TYPE = "change";
38
35
  var ACTIVATE_CUSTOM_EVENT_TYPE = "activate";
39
36
  var DEACTIVATE_CUSTOM_EVENT_TYPE = "deactivate";
40
- var _default = {
41
- BLUR_CUSTOM_EVENT_TYPE: BLUR_CUSTOM_EVENT_TYPE,
42
- FOCUS_CUSTOM_EVENT_TYPE: FOCUS_CUSTOM_EVENT_TYPE,
43
- SCROLL_CUSTOM_EVENT_TYPE: SCROLL_CUSTOM_EVENT_TYPE,
44
- CHANGE_CUSTOM_EVENT_TYPE: CHANGE_CUSTOM_EVENT_TYPE,
45
- ACTIVATE_CUSTOM_EVENT_TYPE: ACTIVATE_CUSTOM_EVENT_TYPE,
46
- DEACTIVATE_CUSTOM_EVENT_TYPE: DEACTIVATE_CUSTOM_EVENT_TYPE
47
- };
48
37
 
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jdXN0b21FdmVudFR5cGVzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xuXG5leHBvcnQgY29uc3QgQkxVUl9DVVNUT01fRVZFTlRfVFlQRSA9IFwiYmx1clwiO1xuZXhwb3J0IGNvbnN0IEZPQ1VTX0NVU1RPTV9FVkVOVF9UWVBFID0gXCJmb2N1c1wiO1xuZXhwb3J0IGNvbnN0IFNDUk9MTF9DVVNUT01fRVZFTlRfVFlQRSA9IFwic2Nyb2xsXCI7XG5leHBvcnQgY29uc3QgQ0hBTkdFX0NVU1RPTV9FVkVOVF9UWVBFID0gXCJjaGFuZ2VcIjtcbmV4cG9ydCBjb25zdCBBQ1RJVkFURV9DVVNUT01fRVZFTlRfVFlQRSA9IFwiYWN0aXZhdGVcIjtcbmV4cG9ydCBjb25zdCBERUFDVElWQVRFX0NVU1RPTV9FVkVOVF9UWVBFID0gXCJkZWFjdGl2YXRlXCI7XG5cbmV4cG9ydCBkZWZhdWx0IHtcbiAgQkxVUl9DVVNUT01fRVZFTlRfVFlQRSxcbiAgRk9DVVNfQ1VTVE9NX0VWRU5UX1RZUEUsXG4gIFNDUk9MTF9DVVNUT01fRVZFTlRfVFlQRSxcbiAgQ0hBTkdFX0NVU1RPTV9FVkVOVF9UWVBFLFxuICBBQ1RJVkFURV9DVVNUT01fRVZFTlRfVFlQRSxcbiAgREVBQ1RJVkFURV9DVVNUT01fRVZFTlRfVFlQRVxufTtcbiJdLCJuYW1lcyI6WyJBQ1RJVkFURV9DVVNUT01fRVZFTlRfVFlQRSIsIkJMVVJfQ1VTVE9NX0VWRU5UX1RZUEUiLCJDSEFOR0VfQ1VTVE9NX0VWRU5UX1RZUEUiLCJERUFDVElWQVRFX0NVU1RPTV9FVkVOVF9UWVBFIiwiRk9DVVNfQ1VTVE9NX0VWRU5UX1RZUEUiLCJTQ1JPTExfQ1VTVE9NX0VWRU5UX1RZUEUiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztJQU1hQSwwQkFBMEI7ZUFBMUJBOztJQUpBQyxzQkFBc0I7ZUFBdEJBOztJQUdBQyx3QkFBd0I7ZUFBeEJBOztJQUVBQyw0QkFBNEI7ZUFBNUJBOztJQUpBQyx1QkFBdUI7ZUFBdkJBOztJQUNBQyx3QkFBd0I7ZUFBeEJBOztJQUtiLE9BT0U7ZUFQRjs7O0FBUE8sSUFBTUoseUJBQXlCO0FBQy9CLElBQU1HLDBCQUEwQjtBQUNoQyxJQUFNQywyQkFBMkI7QUFDakMsSUFBTUgsMkJBQTJCO0FBQ2pDLElBQU1GLDZCQUE2QjtBQUNuQyxJQUFNRywrQkFBK0I7SUFFNUMsV0FBZTtJQUNiRix3QkFBQUE7SUFDQUcseUJBQUFBO0lBQ0FDLDBCQUFBQTtJQUNBSCwwQkFBQUE7SUFDQUYsNEJBQUFBO0lBQ0FHLDhCQUFBQTtBQUNGIn0=
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jdXN0b21FdmVudFR5cGVzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xuXG5leHBvcnQgY29uc3QgQkxVUl9DVVNUT01fRVZFTlRfVFlQRSA9IFwiYmx1clwiO1xuZXhwb3J0IGNvbnN0IEZPQ1VTX0NVU1RPTV9FVkVOVF9UWVBFID0gXCJmb2N1c1wiO1xuZXhwb3J0IGNvbnN0IFNDUk9MTF9DVVNUT01fRVZFTlRfVFlQRSA9IFwic2Nyb2xsXCI7XG5leHBvcnQgY29uc3QgQ0hBTkdFX0NVU1RPTV9FVkVOVF9UWVBFID0gXCJjaGFuZ2VcIjtcbmV4cG9ydCBjb25zdCBBQ1RJVkFURV9DVVNUT01fRVZFTlRfVFlQRSA9IFwiYWN0aXZhdGVcIjtcbmV4cG9ydCBjb25zdCBERUFDVElWQVRFX0NVU1RPTV9FVkVOVF9UWVBFID0gXCJkZWFjdGl2YXRlXCI7XG4iXSwibmFtZXMiOlsiQUNUSVZBVEVfQ1VTVE9NX0VWRU5UX1RZUEUiLCJCTFVSX0NVU1RPTV9FVkVOVF9UWVBFIiwiQ0hBTkdFX0NVU1RPTV9FVkVOVF9UWVBFIiwiREVBQ1RJVkFURV9DVVNUT01fRVZFTlRfVFlQRSIsIkZPQ1VTX0NVU1RPTV9FVkVOVF9UWVBFIiwiU0NST0xMX0NVU1RPTV9FVkVOVF9UWVBFIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7SUFNYUEsMEJBQTBCO2VBQTFCQTs7SUFKQUMsc0JBQXNCO2VBQXRCQTs7SUFHQUMsd0JBQXdCO2VBQXhCQTs7SUFFQUMsNEJBQTRCO2VBQTVCQTs7SUFKQUMsdUJBQXVCO2VBQXZCQTs7SUFDQUMsd0JBQXdCO2VBQXhCQTs7O0FBRk4sSUFBTUoseUJBQXlCO0FBQy9CLElBQU1HLDBCQUEwQjtBQUNoQyxJQUFNQywyQkFBMkI7QUFDakMsSUFBTUgsMkJBQTJCO0FBQ2pDLElBQU1GLDZCQUE2QjtBQUNuQyxJQUFNRywrQkFBK0IifQ==
@@ -194,31 +194,16 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
194
194
  _class_call_check(this, RichTextarea);
195
195
  var _this;
196
196
  _this = _super.apply(this, arguments);
197
- _define_property(_assert_this_initialized(_this), "blurHandler", function(event, element) {
197
+ _define_property(_assert_this_initialized(_this), "selectionChangeHandler", function(event, element) {
198
198
  var active = _this.isActive();
199
199
  if (!active) {
200
200
  return;
201
201
  }
202
- var customEventType = _customEventTypes.BLUR_CUSTOM_EVENT_TYPE, forced = true;
203
- _this.customHandler(customEventType, event, element, forced);
204
- });
205
- _define_property(_assert_this_initialized(_this), "focusHandler", function(event, element) {
206
- defer(function() {
207
- var active = _this.isActive();
208
- if (!active) {
209
- _this.addClass("active");
210
- var customEventType = _customEventTypes.ACTIVATE_CUSTOM_EVENT_TYPE, _$event = null, _$element = _assert_this_initialized(_this), forced = true;
211
- _this.customHandler(customEventType, _$event, _$element, forced);
212
- }
213
- var customEventType1 = _customEventTypes.FOCUS_CUSTOM_EVENT_TYPE, forced1 = true;
214
- _this.customHandler(customEventType1, event, element, forced1);
215
- });
216
- });
217
- _define_property(_assert_this_initialized(_this), "inputHandler", function(event, element) {
218
- var active = _this.isActive();
219
- if (!active) {
202
+ var currentTarget = event.currentTarget, activeElement = currentTarget.activeElement, domElement = _this.getDOMElement();
203
+ if (activeElement !== domElement) {
220
204
  return;
221
205
  }
206
+ element = _assert_this_initialized(_this); ///
222
207
  var customEventType = _customEventTypes.CHANGE_CUSTOM_EVENT_TYPE;
223
208
  _this.customHandler(customEventType, event, element);
224
209
  });
@@ -230,19 +215,34 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
230
215
  var customEventType = _customEventTypes.SCROLL_CUSTOM_EVENT_TYPE, forced = true;
231
216
  _this.customHandler(customEventType, event, element, forced);
232
217
  });
233
- _define_property(_assert_this_initialized(_this), "selectionChangeHandler", function(event, element) {
218
+ _define_property(_assert_this_initialized(_this), "inputHandler", function(event, element) {
234
219
  var active = _this.isActive();
235
220
  if (!active) {
236
221
  return;
237
222
  }
238
- var currentTarget = event.currentTarget, activeElement = currentTarget.activeElement, domElement = _this.getDOMElement();
239
- if (activeElement !== domElement) {
240
- return;
241
- }
242
- element = _assert_this_initialized(_this); ///
243
223
  var customEventType = _customEventTypes.CHANGE_CUSTOM_EVENT_TYPE;
244
224
  _this.customHandler(customEventType, event, element);
245
225
  });
226
+ _define_property(_assert_this_initialized(_this), "focusHandler", function(event, element) {
227
+ defer(function() {
228
+ var active = _this.isActive();
229
+ if (!active) {
230
+ _this.addClass("active");
231
+ var customEventType = _customEventTypes.ACTIVATE_CUSTOM_EVENT_TYPE, _$event = null, _$element = _assert_this_initialized(_this), forced = true;
232
+ _this.customHandler(customEventType, _$event, _$element, forced);
233
+ }
234
+ var customEventType1 = _customEventTypes.FOCUS_CUSTOM_EVENT_TYPE, forced1 = true;
235
+ _this.customHandler(customEventType1, event, element, forced1);
236
+ });
237
+ });
238
+ _define_property(_assert_this_initialized(_this), "blurHandler", function(event, element) {
239
+ var active = _this.isActive();
240
+ if (!active) {
241
+ return;
242
+ }
243
+ var customEventType = _customEventTypes.BLUR_CUSTOM_EVENT_TYPE, forced = true;
244
+ _this.customHandler(customEventType, event, element, forced);
245
+ });
246
246
  _define_property(_assert_this_initialized(_this), "customHandler", function(customEventType, event, element) {
247
247
  var forced = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : false;
248
248
  var content = _this.getContent(), selection = _this.getSelection(), contentChanged = _this.hasContentChanged(), selectionChanged = _this.hasSelectionChanged();
@@ -451,4 +451,4 @@ function defer(func) {
451
451
  setTimeout(func, 0);
452
452
  }
453
453
 
454
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/richTextarea.js"],"sourcesContent":["\"use strict\";\r\n\r\nimport { Element, document, eventTypes } from \"easy\";\r\n\r\nimport Selection from \"./selection\"\r\nimport customEventMixins from \"./mixins/customEvent\";\r\n\r\nimport { BLUR_CUSTOM_EVENT_TYPE,\r\n         FOCUS_CUSTOM_EVENT_TYPE,\r\n         SCROLL_CUSTOM_EVENT_TYPE,\r\n         CHANGE_CUSTOM_EVENT_TYPE,\r\n         ACTIVATE_CUSTOM_EVENT_TYPE,\r\n         DEACTIVATE_CUSTOM_EVENT_TYPE } from \"./customEventTypes\";\r\n\r\nconst { BLUR_EVENT_TYPE, FOCUS_EVENT_TYPE, INPUT_EVENT_TYPE, SCROLL_EVENT_TYPE } = eventTypes;\r\n\r\nexport default class RichTextarea extends Element {\r\n  blurHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const customEventType = BLUR_CUSTOM_EVENT_TYPE,\r\n          forced = true;\r\n\r\n    this.customHandler(customEventType, event, element, forced);\r\n  }\r\n\r\n  focusHandler = (event, element) => {\r\n    defer(() => {\r\n      const active = this.isActive();\r\n\r\n      if (!active) {\r\n        this.addClass(\"active\");\r\n\r\n        const customEventType = ACTIVATE_CUSTOM_EVENT_TYPE,\r\n              event = null,\r\n              element = this,\r\n              forced = true;\r\n\r\n        this.customHandler(customEventType, event, element, forced);\r\n      }\r\n\r\n      const customEventType = FOCUS_CUSTOM_EVENT_TYPE,\r\n            forced = true;\r\n\r\n      this.customHandler(customEventType, event, element, forced);\r\n    });\r\n  }\r\n\r\n  inputHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const customEventType = CHANGE_CUSTOM_EVENT_TYPE;\r\n\r\n    this.customHandler(customEventType, event, element);\r\n  }\r\n\r\n  scrollHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const customEventType = SCROLL_CUSTOM_EVENT_TYPE,\r\n          forced = true;\r\n\r\n    this.customHandler(customEventType, event, element, forced);\r\n  }\r\n\r\n  selectionChangeHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const { currentTarget } = event,\r\n          { activeElement } = currentTarget,\r\n          domElement = this.getDOMElement();\r\n\r\n    if (activeElement !== domElement) {\r\n      return;\r\n    }\r\n\r\n    element = this; ///\r\n\r\n    const customEventType = CHANGE_CUSTOM_EVENT_TYPE;\r\n\r\n    this.customHandler(customEventType, event, element);\r\n  }\r\n\r\n  customHandler = (customEventType, event, element, forced = false) => {\r\n    const content = this.getContent(),\r\n          selection = this.getSelection(),\r\n          contentChanged = this.hasContentChanged(),\r\n          selectionChanged = this.hasSelectionChanged();\r\n\r\n    if (forced || contentChanged || selectionChanged) {\r\n      this.callCustomHandlers(customEventType, event, element);\r\n    }\r\n\r\n    const previousContent = content,  ///\r\n          previousSelection = selection;  ///\r\n\r\n    this.setPreviousContent(previousContent);\r\n\r\n    this.setPreviousSelection(previousSelection);\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  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  hasContentChanged() {\r\n    const content = this.getContent(),\r\n          previousContent = this.getPreviousContent(),\r\n          contentPreviousContent = (content === previousContent),\r\n          contentChanged = !contentPreviousContent;\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          selectionPreviousSelection = selection.isEqualTo(previousSelection),\r\n          selectionChanged = !selectionPreviousSelection; ///\r\n\r\n    return selectionChanged;\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, setPreviousContent = true) {\r\n    const value = content,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      value\r\n    });\r\n\r\n    if (setPreviousContent) {\r\n      const previousContent = content;  ///\r\n\r\n      this.setPreviousContent(previousContent);\r\n    }\r\n  }\r\n\r\n  setSelection(selection, setPreviousSelection = true) {\r\n    const selectionStartPosition = selection.getStartPosition(),\r\n          selectionEndPosition = selection.getEndPosition(),\r\n          selectionStart = selectionStartPosition,  ///\r\n          selectionEnd = selectionEndPosition,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    domElement.setSelectionRange(selectionStart, selectionEnd);\r\n\r\n    if (setPreviousSelection) {\r\n      const previousSelection = selection;  ///\r\n\r\n      this.setPreviousSelection(previousSelection);\r\n    }\r\n  }\r\n\r\n  activate() {\r\n    const active = this.isActive();\r\n\r\n    if (active) {\r\n      return;\r\n    }\r\n\r\n    this.focus();\r\n  }\r\n\r\n  deactivate() {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    this.removeClass(\"active\");\r\n\r\n    const customEventType = DEACTIVATE_CUSTOM_EVENT_TYPE,\r\n          event = null,\r\n          element = this,\r\n          forced = true;\r\n\r\n    this.customHandler(customEventType, event, element, forced);\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  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 previousContent = null,\r\n          previousSelection = null;\r\n\r\n    this.setState({\r\n      previousContent,\r\n      previousSelection\r\n    });\r\n  }\r\n\r\n  didMount() {\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\r\n    this.setPreviousSelection(previousSelection);\r\n\r\n    this.onEvent(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.onEvent(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.onEvent(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.onEvent(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.onSelectionChange(this.selectionChangeHandler, this);\r\n  }\r\n\r\n  willUnmount() {\r\n    this.offEvent(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.offEvent(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.offEvent(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.offEvent(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.offSelectionChange(this.selectionChangeHandler, 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 defaultProperties = {\r\n    className: \"rich\"\r\n  };\r\n\r\n  static fromClass(Class, properties, ...remainingArguments) {\r\n    const richTextarea = Element.fromClass(Class, properties, ...remainingArguments);\r\n\r\n    return richTextarea;\r\n  }\r\n}\r\n\r\nObject.assign(RichTextarea.prototype, customEventMixins);\r\n\r\nfunction defer(func) {\r\n  setTimeout(func, 0);\r\n}\r\n"],"names":["RichTextarea","BLUR_EVENT_TYPE","eventTypes","FOCUS_EVENT_TYPE","INPUT_EVENT_TYPE","SCROLL_EVENT_TYPE","blurHandler","event","element","active","isActive","customEventType","BLUR_CUSTOM_EVENT_TYPE","forced","customHandler","focusHandler","defer","addClass","ACTIVATE_CUSTOM_EVENT_TYPE","FOCUS_CUSTOM_EVENT_TYPE","inputHandler","CHANGE_CUSTOM_EVENT_TYPE","scrollHandler","SCROLL_CUSTOM_EVENT_TYPE","selectionChangeHandler","currentTarget","activeElement","domElement","getDOMElement","content","getContent","selection","getSelection","contentChanged","hasContentChanged","selectionChanged","hasSelectionChanged","callCustomHandlers","previousContent","previousSelection","setPreviousContent","setPreviousSelection","isReadOnly","readOnly","hasClass","value","Selection","fromDOMElement","getPreviousContent","contentPreviousContent","getPreviousSelection","selectionPreviousSelection","isEqualTo","setReadOnly","Object","assign","setContent","setSelection","selectionStartPosition","getStartPosition","selectionEndPosition","getEndPosition","selectionStart","selectionEnd","setSelectionRange","activate","focus","deactivate","removeClass","DEACTIVATE_CUSTOM_EVENT_TYPE","getState","updateState","setInitialState","setState","didMount","onEvent","document","onSelectionChange","willUnmount","offEvent","offSelectionChange","initialise","fromClass","Class","properties","remainingArguments","Element","richTextarea","tagName","defaultProperties","className","prototype","customEventMixins","func","setTimeout"],"mappings":"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"}
454
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/richTextarea.js"],"sourcesContent":["\"use strict\";\r\n\r\nimport { Element, document, eventTypes } from \"easy\";\r\n\r\nimport Selection from \"./selection\"\r\nimport customEventMixins from \"./mixins/customEvent\";\r\n\r\nimport { BLUR_CUSTOM_EVENT_TYPE,\r\n         FOCUS_CUSTOM_EVENT_TYPE,\r\n         SCROLL_CUSTOM_EVENT_TYPE,\r\n         CHANGE_CUSTOM_EVENT_TYPE,\r\n         ACTIVATE_CUSTOM_EVENT_TYPE,\r\n         DEACTIVATE_CUSTOM_EVENT_TYPE } from \"./customEventTypes\";\r\n\r\nconst { BLUR_EVENT_TYPE, FOCUS_EVENT_TYPE, INPUT_EVENT_TYPE, SCROLL_EVENT_TYPE } = eventTypes;\r\n\r\nexport default class RichTextarea extends Element {\r\n  selectionChangeHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const { currentTarget } = event,\r\n          { activeElement } = currentTarget,\r\n          domElement = this.getDOMElement();\r\n\r\n    if (activeElement !== domElement) {\r\n      return;\r\n    }\r\n\r\n    element = this; ///\r\n\r\n    const customEventType = CHANGE_CUSTOM_EVENT_TYPE;\r\n\r\n    this.customHandler(customEventType, event, element);\r\n  }\r\n\r\n  scrollHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const customEventType = SCROLL_CUSTOM_EVENT_TYPE,\r\n          forced = true;\r\n\r\n    this.customHandler(customEventType, event, element, forced);\r\n  }\r\n\r\n  inputHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const customEventType = CHANGE_CUSTOM_EVENT_TYPE;\r\n\r\n    this.customHandler(customEventType, event, element);\r\n  }\r\n\r\n  focusHandler = (event, element) => {\r\n    defer(() => {\r\n      const active = this.isActive();\r\n\r\n      if (!active) {\r\n        this.addClass(\"active\");\r\n\r\n        const customEventType = ACTIVATE_CUSTOM_EVENT_TYPE,\r\n              event = null,\r\n              element = this,\r\n              forced = true;\r\n\r\n        this.customHandler(customEventType, event, element, forced);\r\n      }\r\n\r\n      const customEventType = FOCUS_CUSTOM_EVENT_TYPE,\r\n            forced = true;\r\n\r\n      this.customHandler(customEventType, event, element, forced);\r\n    });\r\n  }\r\n\r\n  blurHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const customEventType = BLUR_CUSTOM_EVENT_TYPE,\r\n          forced = true;\r\n\r\n    this.customHandler(customEventType, event, element, forced);\r\n  }\r\n\r\n  customHandler = (customEventType, event, element, forced = false) => {\r\n    const content = this.getContent(),\r\n          selection = this.getSelection(),\r\n          contentChanged = this.hasContentChanged(),\r\n          selectionChanged = this.hasSelectionChanged();\r\n\r\n    if (forced || contentChanged || selectionChanged) {\r\n      this.callCustomHandlers(customEventType, event, element);\r\n    }\r\n\r\n    const previousContent = content,  ///\r\n          previousSelection = selection;  ///\r\n\r\n    this.setPreviousContent(previousContent);\r\n\r\n    this.setPreviousSelection(previousSelection);\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  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  hasContentChanged() {\r\n    const content = this.getContent(),\r\n          previousContent = this.getPreviousContent(),\r\n          contentPreviousContent = (content === previousContent),\r\n          contentChanged = !contentPreviousContent;\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          selectionPreviousSelection = selection.isEqualTo(previousSelection),\r\n          selectionChanged = !selectionPreviousSelection; ///\r\n\r\n    return selectionChanged;\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, setPreviousContent = true) {\r\n    const value = content,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      value\r\n    });\r\n\r\n    if (setPreviousContent) {\r\n      const previousContent = content;  ///\r\n\r\n      this.setPreviousContent(previousContent);\r\n    }\r\n  }\r\n\r\n  setSelection(selection, setPreviousSelection = true) {\r\n    const selectionStartPosition = selection.getStartPosition(),\r\n          selectionEndPosition = selection.getEndPosition(),\r\n          selectionStart = selectionStartPosition,  ///\r\n          selectionEnd = selectionEndPosition,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    domElement.setSelectionRange(selectionStart, selectionEnd);\r\n\r\n    if (setPreviousSelection) {\r\n      const previousSelection = selection;  ///\r\n\r\n      this.setPreviousSelection(previousSelection);\r\n    }\r\n  }\r\n\r\n  activate() {\r\n    const active = this.isActive();\r\n\r\n    if (active) {\r\n      return;\r\n    }\r\n\r\n    this.focus();\r\n  }\r\n\r\n  deactivate() {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    this.removeClass(\"active\");\r\n\r\n    const customEventType = DEACTIVATE_CUSTOM_EVENT_TYPE,\r\n          event = null,\r\n          element = this,\r\n          forced = true;\r\n\r\n    this.customHandler(customEventType, event, element, forced);\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  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 previousContent = null,\r\n          previousSelection = null;\r\n\r\n    this.setState({\r\n      previousContent,\r\n      previousSelection\r\n    });\r\n  }\r\n\r\n  didMount() {\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\r\n    this.setPreviousSelection(previousSelection);\r\n\r\n    this.onEvent(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.onEvent(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.onEvent(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.onEvent(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.onSelectionChange(this.selectionChangeHandler, this);\r\n  }\r\n\r\n  willUnmount() {\r\n    this.offEvent(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.offEvent(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.offEvent(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.offEvent(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.offSelectionChange(this.selectionChangeHandler, 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 defaultProperties = {\r\n    className: \"rich\"\r\n  };\r\n\r\n  static fromClass(Class, properties, ...remainingArguments) {\r\n    const richTextarea = Element.fromClass(Class, properties, ...remainingArguments);\r\n\r\n    return richTextarea;\r\n  }\r\n}\r\n\r\nObject.assign(RichTextarea.prototype, customEventMixins);\r\n\r\nfunction defer(func) {\r\n  setTimeout(func, 0);\r\n}\r\n"],"names":["RichTextarea","BLUR_EVENT_TYPE","eventTypes","FOCUS_EVENT_TYPE","INPUT_EVENT_TYPE","SCROLL_EVENT_TYPE","selectionChangeHandler","event","element","active","isActive","currentTarget","activeElement","domElement","getDOMElement","customEventType","CHANGE_CUSTOM_EVENT_TYPE","customHandler","scrollHandler","SCROLL_CUSTOM_EVENT_TYPE","forced","inputHandler","focusHandler","defer","addClass","ACTIVATE_CUSTOM_EVENT_TYPE","FOCUS_CUSTOM_EVENT_TYPE","blurHandler","BLUR_CUSTOM_EVENT_TYPE","content","getContent","selection","getSelection","contentChanged","hasContentChanged","selectionChanged","hasSelectionChanged","callCustomHandlers","previousContent","previousSelection","setPreviousContent","setPreviousSelection","isReadOnly","readOnly","hasClass","value","Selection","fromDOMElement","getPreviousContent","contentPreviousContent","getPreviousSelection","selectionPreviousSelection","isEqualTo","setReadOnly","Object","assign","setContent","setSelection","selectionStartPosition","getStartPosition","selectionEndPosition","getEndPosition","selectionStart","selectionEnd","setSelectionRange","activate","focus","deactivate","removeClass","DEACTIVATE_CUSTOM_EVENT_TYPE","getState","updateState","setInitialState","setState","didMount","onEvent","document","onSelectionChange","willUnmount","offEvent","offSelectionChange","initialise","fromClass","Class","properties","remainingArguments","Element","richTextarea","tagName","defaultProperties","className","prototype","customEventMixins","func","setTimeout"],"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": "4.0.202",
4
+ "version": "4.0.206",
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.",
@@ -6,12 +6,3 @@ export const SCROLL_CUSTOM_EVENT_TYPE = "scroll";
6
6
  export const CHANGE_CUSTOM_EVENT_TYPE = "change";
7
7
  export const ACTIVATE_CUSTOM_EVENT_TYPE = "activate";
8
8
  export const DEACTIVATE_CUSTOM_EVENT_TYPE = "deactivate";
9
-
10
- export default {
11
- BLUR_CUSTOM_EVENT_TYPE,
12
- FOCUS_CUSTOM_EVENT_TYPE,
13
- SCROLL_CUSTOM_EVENT_TYPE,
14
- CHANGE_CUSTOM_EVENT_TYPE,
15
- ACTIVATE_CUSTOM_EVENT_TYPE,
16
- DEACTIVATE_CUSTOM_EVENT_TYPE
17
- };
@@ -15,19 +15,53 @@ import { BLUR_CUSTOM_EVENT_TYPE,
15
15
  const { BLUR_EVENT_TYPE, FOCUS_EVENT_TYPE, INPUT_EVENT_TYPE, SCROLL_EVENT_TYPE } = eventTypes;
16
16
 
17
17
  export default class RichTextarea extends Element {
18
- blurHandler = (event, element) => {
18
+ selectionChangeHandler = (event, element) => {
19
19
  const active = this.isActive();
20
20
 
21
21
  if (!active) {
22
22
  return;
23
23
  }
24
24
 
25
- const customEventType = BLUR_CUSTOM_EVENT_TYPE,
25
+ const { currentTarget } = event,
26
+ { activeElement } = currentTarget,
27
+ domElement = this.getDOMElement();
28
+
29
+ if (activeElement !== domElement) {
30
+ return;
31
+ }
32
+
33
+ element = this; ///
34
+
35
+ const customEventType = CHANGE_CUSTOM_EVENT_TYPE;
36
+
37
+ this.customHandler(customEventType, event, element);
38
+ }
39
+
40
+ scrollHandler = (event, element) => {
41
+ const active = this.isActive();
42
+
43
+ if (!active) {
44
+ return;
45
+ }
46
+
47
+ const customEventType = SCROLL_CUSTOM_EVENT_TYPE,
26
48
  forced = true;
27
49
 
28
50
  this.customHandler(customEventType, event, element, forced);
29
51
  }
30
52
 
53
+ inputHandler = (event, element) => {
54
+ const active = this.isActive();
55
+
56
+ if (!active) {
57
+ return;
58
+ }
59
+
60
+ const customEventType = CHANGE_CUSTOM_EVENT_TYPE;
61
+
62
+ this.customHandler(customEventType, event, element);
63
+ }
64
+
31
65
  focusHandler = (event, element) => {
32
66
  defer(() => {
33
67
  const active = this.isActive();
@@ -50,53 +84,19 @@ export default class RichTextarea extends Element {
50
84
  });
51
85
  }
52
86
 
53
- inputHandler = (event, element) => {
54
- const active = this.isActive();
55
-
56
- if (!active) {
57
- return;
58
- }
59
-
60
- const customEventType = CHANGE_CUSTOM_EVENT_TYPE;
61
-
62
- this.customHandler(customEventType, event, element);
63
- }
64
-
65
- scrollHandler = (event, element) => {
87
+ blurHandler = (event, element) => {
66
88
  const active = this.isActive();
67
89
 
68
90
  if (!active) {
69
91
  return;
70
92
  }
71
93
 
72
- const customEventType = SCROLL_CUSTOM_EVENT_TYPE,
94
+ const customEventType = BLUR_CUSTOM_EVENT_TYPE,
73
95
  forced = true;
74
96
 
75
97
  this.customHandler(customEventType, event, element, forced);
76
98
  }
77
99
 
78
- selectionChangeHandler = (event, element) => {
79
- const active = this.isActive();
80
-
81
- if (!active) {
82
- return;
83
- }
84
-
85
- const { currentTarget } = event,
86
- { activeElement } = currentTarget,
87
- domElement = this.getDOMElement();
88
-
89
- if (activeElement !== domElement) {
90
- return;
91
- }
92
-
93
- element = this; ///
94
-
95
- const customEventType = CHANGE_CUSTOM_EVENT_TYPE;
96
-
97
- this.customHandler(customEventType, event, element);
98
- }
99
-
100
100
  customHandler = (customEventType, event, element, forced = false) => {
101
101
  const content = this.getContent(),
102
102
  selection = this.getSelection(),