easy-richtextarea 4.0.46 → 4.0.48

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.
@@ -196,7 +196,7 @@ function _createSuper(Derived) {
196
196
  return _possibleConstructorReturn(this, result);
197
197
  };
198
198
  }
199
- var BLUR_EVENT_TYPE = _easy.eventTypes.BLUR_EVENT_TYPE, INPUT_EVENT_TYPE = _easy.eventTypes.INPUT_EVENT_TYPE, FOCUS_EVENT_TYPE = _easy.eventTypes.FOCUS_EVENT_TYPE, CHANGE_EVENT_TYPE = _easy.eventTypes.CHANGE_EVENT_TYPE, SCROLL_EVENT_TYPE = _easy.eventTypes.SCROLL_EVENT_TYPE, SELECTIONCHANGE_EVENT_TYPE = _easy.eventTypes.SELECTIONCHANGE_EVENT_TYPE;
199
+ var BLUR_EVENT_TYPE = _easy.eventTypes.BLUR_EVENT_TYPE, FOCUS_EVENT_TYPE = _easy.eventTypes.FOCUS_EVENT_TYPE, INPUT_EVENT_TYPE = _easy.eventTypes.INPUT_EVENT_TYPE, SCROLL_EVENT_TYPE = _easy.eventTypes.SCROLL_EVENT_TYPE, CHANGE_EVENT_TYPE = _easy.eventTypes.CHANGE_EVENT_TYPE, SELECTIONCHANGE_EVENT_TYPE = _easy.eventTypes.SELECTIONCHANGE_EVENT_TYPE;
200
200
  var RichTextarea = /*#__PURE__*/ function(Element) {
201
201
  _inherits(RichTextarea, Element);
202
202
  var _super = _createSuper(RichTextarea);
@@ -204,9 +204,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
204
204
  _classCallCheck(this, RichTextarea);
205
205
  var _this;
206
206
  _this = _super.apply(this, arguments);
207
- _defineProperty(_assertThisInitialized(_this), "inputHandler", function(event, element) {
208
- _this.intermediateHandler(event, element);
209
- });
210
207
  _defineProperty(_assertThisInitialized(_this), "blurHandler", function(event, element) {
211
208
  var eventType = BLUR_EVENT_TYPE, selectionChanged = true;
212
209
  _this.intermediateHandler(event, element, eventType, selectionChanged);
@@ -217,13 +214,13 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
217
214
  _this.intermediateHandler(event, element, eventType, selectionChanged);
218
215
  });
219
216
  });
217
+ _defineProperty(_assertThisInitialized(_this), "inputHandler", function(event, element) {
218
+ _this.intermediateHandler(event, element);
219
+ });
220
220
  _defineProperty(_assertThisInitialized(_this), "scrollHandler", function(event, element) {
221
221
  var eventType = SCROLL_EVENT_TYPE;
222
222
  _this.callHandlers(eventType, event, element);
223
223
  });
224
- _defineProperty(_assertThisInitialized(_this), "contextmenuHandler", function(event, element) {
225
- event.preventDefault();
226
- });
227
224
  _defineProperty(_assertThisInitialized(_this), "selectChangeHandler", function(event, element) {
228
225
  var currentTarget = event.currentTarget, activeElement = currentTarget.activeElement, domElement = _this.getDOMElement();
229
226
  if (activeElement === domElement) {
@@ -254,10 +251,11 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
254
251
  var eventListeners = this.findEventListeners(eventType);
255
252
  eventListeners.forEach(function(eventListener) {
256
253
  var element = eventListener.element;
257
- var handler = eventListener.handler, handlerElement = element; ///
258
- element = _this; ///
259
- if (handler !== _this.inputHandler && handler !== _this.blurHandler && handler !== _this.focusHandler && handler !== _this.scrollHandler && handler !== _this.contextmenuHandler && handler !== _this.selectChangeHandler) {
254
+ var handler = eventListener.handler;
255
+ if (handler !== _this.blurHandler && handler !== _this.focusHandler && handler !== _this.inputHandler && handler !== _this.scrollHandler && handler !== _this.selectChangeHandler) {
260
256
  var _handler;
257
+ var handlerElement = element; ///
258
+ element = _this; ///
261
259
  (_handler = handler).call.apply(_handler, [
262
260
  handlerElement
263
261
  ].concat(_toConsumableArray(remainingArguments), [
@@ -295,13 +293,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
295
293
  return selection;
296
294
  }
297
295
  },
298
- {
299
- key: "getSelectedContent",
300
- value: function getSelectedContent() {
301
- var content = this.getContent(), selection = this.getSelection(), endPosition = selection.getEndPosition(), startPosition = selection.getStartPosition(), start = startPosition, end = endPosition, selectedContent = content.slice(start, end);
302
- return selectedContent;
303
- }
304
- },
305
296
  {
306
297
  key: "hasContentChanged",
307
298
  value: function hasContentChanged() {
@@ -354,9 +345,9 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
354
345
  {
355
346
  key: "activate",
356
347
  value: function activate() {
357
- this.on(INPUT_EVENT_TYPE, this.inputHandler);
358
348
  this.on(BLUR_EVENT_TYPE, this.blurHandler);
359
349
  this.on(FOCUS_EVENT_TYPE, this.focusHandler);
350
+ this.on(INPUT_EVENT_TYPE, this.inputHandler);
360
351
  this.on(SCROLL_EVENT_TYPE, this.scrollHandler);
361
352
  _easy.document.on(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);
362
353
  this.addClass("active");
@@ -365,9 +356,9 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
365
356
  {
366
357
  key: "deactivate",
367
358
  value: function deactivate() {
368
- this.off(INPUT_EVENT_TYPE, this.inputHandler);
369
359
  this.off(BLUR_EVENT_TYPE, this.blurHandler);
370
360
  this.off(FOCUS_EVENT_TYPE, this.focusHandler);
361
+ this.off(INPUT_EVENT_TYPE, this.inputHandler);
371
362
  this.off(SCROLL_EVENT_TYPE, this.scrollHandler);
372
363
  _easy.document.off(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);
373
364
  this.removeClass("active");
@@ -406,8 +397,10 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
406
397
  {
407
398
  key: "didMount",
408
399
  value: function didMount() {
400
+ var content = this.getContent(), selection = this.getSelection(), previousContent = content, previousSelection = selection; ///
401
+ this.setPreviousContent(previousContent);
402
+ this.setPreviousSelection(previousSelection);
409
403
  var _this_properties = this.properties, onBlur = _this_properties.onBlur, onFocus = _this_properties.onFocus, onScroll = _this_properties.onScroll, onChange = _this_properties.onChange, blurHandler = onBlur, focusHandler = onFocus, scrollHandler = onScroll, changeHandler = onChange; ///
410
- this.updateInitialState();
411
404
  blurHandler && this.onBlur(blurHandler, this);
412
405
  focusHandler && this.onFocus(focusHandler, this);
413
406
  scrollHandler && this.onScroll(scrollHandler, this);
@@ -428,14 +421,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
428
421
  }
429
422
  }
430
423
  },
431
- {
432
- key: "updateInitialState",
433
- value: function updateInitialState() {
434
- var content = this.getContent(), selection = this.getSelection(), previousContent = content, previousSelection = selection; ///
435
- this.setPreviousContent(previousContent);
436
- this.setPreviousSelection(previousSelection);
437
- }
438
- },
439
424
  {
440
425
  key: "setInitialState",
441
426
  value: function setInitialState() {
@@ -485,4 +470,4 @@ function defer(func) {
485
470
  setTimeout(func, 0);
486
471
  }
487
472
 
488
- //# 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 eventMixins from \"./mixins/event\";\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        SELECTIONCHANGE_EVENT_TYPE } = eventTypes;\r\n\r\nexport default class RichTextarea extends Element {\r\n  inputHandler = (event, element) => {\r\n    this.intermediateHandler(event, element);\r\n  }\r\n\r\n  blurHandler = (event, element) => {\r\n    const eventType = BLUR_EVENT_TYPE,\r\n          selectionChanged = true;\r\n\r\n    this.intermediateHandler(event, element, eventType, selectionChanged);\r\n  }\r\n\r\n  focusHandler = (event, element) => {\r\n    defer(() => {\r\n      const eventType = FOCUS_EVENT_TYPE,\r\n            selectionChanged = true;\r\n\r\n      this.intermediateHandler(event, element, eventType, selectionChanged);\r\n    });\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  contextmenuHandler = (event, element) => {\r\n    event.preventDefault();\r\n  }\r\n\r\n  selectChangeHandler = (event, element) => {\r\n    const { currentTarget } = event,\r\n          { activeElement } = currentTarget,\r\n          domElement = this.getDOMElement();\r\n\r\n    if (activeElement === domElement) {\r\n      element = this; ///\r\n\r\n      this.intermediateHandler(event, element);\r\n    }\r\n  }\r\n\r\n  intermediateHandler = (event, element, eventType = CHANGE_EVENT_TYPE, selectionChanged = this.hasSelectionChanged()) => {\r\n    const content = this.getContent(),\r\n          selection = this.getSelection(),\r\n          contentChanged = this.hasContentChanged();\r\n\r\n    if (contentChanged || selectionChanged) {\r\n      this.callHandlers(eventType, 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  callHandlers(eventType, ...remainingArguments) {\r\n    const eventListeners = this.findEventListeners(eventType);\r\n\r\n    eventListeners.forEach((eventListener) => {\r\n      let { element } = eventListener;\r\n\r\n      const { handler } = eventListener,\r\n            handlerElement = element; ///\r\n\r\n      element = this; ///\r\n\r\n      if ( (handler !== this.inputHandler)\r\n        && (handler !== this.blurHandler)\r\n        && (handler !== this.focusHandler)\r\n        && (handler !== this.scrollHandler)\r\n        && (handler !== this.contextmenuHandler)\r\n        && (handler !== this.selectChangeHandler) ) {\r\n\r\n        handler.call(handlerElement, ...remainingArguments, element);\r\n      }\r\n    });\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  getSelectedContent() {\r\n    const content = this.getContent(),\r\n          selection = this.getSelection(),\r\n          endPosition = selection.getEndPosition(),\r\n          startPosition = selection.getStartPosition(),\r\n          start = startPosition,  ///\r\n          end = endPosition,  ///\r\n          selectedContent = content.slice(start, end);\r\n\r\n    return selectedContent;\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    this.on(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.on(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.on(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.on(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.on(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);\r\n\r\n    this.addClass(\"active\");\r\n  }\r\n\r\n  deactivate() {\r\n    this.off(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.off(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.off(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.off(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.off(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);\r\n\r\n    this.removeClass(\"active\");\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  didMount() {\r\n    const { onBlur, onFocus, onScroll, onChange } = this.properties,\r\n          blurHandler = onBlur, ///\r\n          focusHandler = onFocus, ///\r\n          scrollHandler = onScroll, ///\r\n          changeHandler = onChange; ///\r\n\r\n    this.updateInitialState();\r\n\r\n    blurHandler && this.onBlur(blurHandler, this);\r\n\r\n    focusHandler && this.onFocus(focusHandler, this);\r\n\r\n    scrollHandler && this.onScroll(scrollHandler, this);\r\n\r\n    changeHandler && this.onChange(changeHandler, this);\r\n  }\r\n\r\n  willUnmount() {\r\n    const { onBlur, onFocus, onScroll, onChange } = this.properties,\r\n            blurHandler = onBlur, ///\r\n            focusHandler = onFocus, ///\r\n            scrollHandler = onScroll, ///\r\n            changeHandler = onChange; ///\r\n\r\n    blurHandler && this.offBlur(blurHandler, this);\r\n\r\n    focusHandler && this.offFocus(focusHandler, this);\r\n\r\n    scrollHandler && this.offScroll(scrollHandler, this);\r\n\r\n    changeHandler && this.offChange(changeHandler, 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  updateInitialState() {\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\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  initialise() {\r\n    this.setInitialState();\r\n  }\r\n\r\n  static tagName = \"textarea\";\r\n\r\n  static ignoredProperties = [\r\n    \"onBlur\",\r\n    \"onFocus\",\r\n    \"onScroll\",\r\n    \"onChange\"\r\n  ];\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, eventMixins);\r\n\r\nfunction defer(func) {\r\n  setTimeout(func, 0);\r\n}\r\n"],"names":["RichTextarea","BLUR_EVENT_TYPE","eventTypes","INPUT_EVENT_TYPE","FOCUS_EVENT_TYPE","CHANGE_EVENT_TYPE","SCROLL_EVENT_TYPE","SELECTIONCHANGE_EVENT_TYPE","inputHandler","event","element","intermediateHandler","blurHandler","eventType","selectionChanged","focusHandler","defer","scrollHandler","callHandlers","contextmenuHandler","preventDefault","selectChangeHandler","currentTarget","activeElement","domElement","getDOMElement","hasSelectionChanged","content","getContent","selection","getSelection","contentChanged","hasContentChanged","previousContent","previousSelection","setPreviousContent","setPreviousSelection","remainingArguments","eventListeners","findEventListeners","forEach","eventListener","handler","handlerElement","call","isReadOnly","readOnly","isActive","active","hasClass","value","Selection","fromDOMElement","getSelectedContent","endPosition","getEndPosition","startPosition","getStartPosition","start","end","selectedContent","slice","getPreviousContent","contentPreviousContent","getPreviousSelection","selectionPreviousSelection","isEqualTo","setReadOnly","Object","assign","setContent","setSelection","selectionStartPosition","selectionEndPosition","selectionStart","selectionEnd","setSelectionRange","activate","on","document","addClass","deactivate","off","removeClass","getState","updateState","didMount","properties","onBlur","onFocus","onScroll","onChange","changeHandler","updateInitialState","willUnmount","offBlur","offFocus","offScroll","offChange","setInitialState","setState","initialise","fromClass","Class","Element","richTextarea","tagName","ignoredProperties","defaultProperties","className","prototype","eventMixins","func","setTimeout"],"mappings":"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"}
473
+ //# 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 eventMixins from \"./mixins/event\";\r\n\r\nconst { BLUR_EVENT_TYPE,\r\n        FOCUS_EVENT_TYPE,\r\n        INPUT_EVENT_TYPE,\r\n        SCROLL_EVENT_TYPE,\r\n        CHANGE_EVENT_TYPE,\r\n        SELECTIONCHANGE_EVENT_TYPE } = eventTypes;\r\n\r\nexport default class RichTextarea extends Element {\r\n  blurHandler = (event, element) => {\r\n    const eventType = BLUR_EVENT_TYPE,\r\n          selectionChanged = true;\r\n\r\n    this.intermediateHandler(event, element, eventType, selectionChanged);\r\n  }\r\n\r\n  focusHandler = (event, element) => {\r\n    defer(() => {\r\n      const eventType = FOCUS_EVENT_TYPE,\r\n            selectionChanged = true;\r\n\r\n      this.intermediateHandler(event, element, eventType, selectionChanged);\r\n    });\r\n  }\r\n\r\n  inputHandler = (event, element) => {\r\n    this.intermediateHandler(event, element);\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  selectChangeHandler = (event, element) => {\r\n    const { currentTarget } = event,\r\n          { activeElement } = currentTarget,\r\n          domElement = this.getDOMElement();\r\n\r\n    if (activeElement === domElement) {\r\n      element = this; ///\r\n\r\n      this.intermediateHandler(event, element);\r\n    }\r\n  }\r\n\r\n  intermediateHandler = (event, element, eventType = CHANGE_EVENT_TYPE, selectionChanged = this.hasSelectionChanged()) => {\r\n    const content = this.getContent(),\r\n          selection = this.getSelection(),\r\n          contentChanged = this.hasContentChanged();\r\n\r\n    if (contentChanged || selectionChanged) {\r\n      this.callHandlers(eventType, 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  callHandlers(eventType, ...remainingArguments) {\r\n    const eventListeners = this.findEventListeners(eventType);\r\n\r\n    eventListeners.forEach((eventListener) => {\r\n      let { element } = eventListener;\r\n\r\n      const { handler } = eventListener;\r\n\r\n      if ( (handler !== this.blurHandler)\r\n        && (handler !== this.focusHandler)\r\n        && (handler !== this.inputHandler)\r\n        && (handler !== this.scrollHandler)\r\n        && (handler !== this.selectChangeHandler) ) {\r\n\r\n        const handlerElement = element; ///\r\n\r\n        element = this; ///\r\n\r\n        handler.call(handlerElement, ...remainingArguments, element);\r\n      }\r\n    });\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    this.on(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.on(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.on(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.on(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.on(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);\r\n\r\n    this.addClass(\"active\");\r\n  }\r\n\r\n  deactivate() {\r\n    this.off(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.off(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.off(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.off(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.off(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);\r\n\r\n    this.removeClass(\"active\");\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  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    const { onBlur, onFocus, onScroll, onChange } = this.properties,\r\n          blurHandler = onBlur, ///\r\n          focusHandler = onFocus, ///\r\n          scrollHandler = onScroll, ///\r\n          changeHandler = onChange; ///\r\n\r\n    blurHandler && this.onBlur(blurHandler, this);\r\n\r\n    focusHandler && this.onFocus(focusHandler, this);\r\n\r\n    scrollHandler && this.onScroll(scrollHandler, this);\r\n\r\n    changeHandler && this.onChange(changeHandler, this);\r\n  }\r\n\r\n  willUnmount() {\r\n    const { onBlur, onFocus, onScroll, onChange } = this.properties,\r\n            blurHandler = onBlur, ///\r\n            focusHandler = onFocus, ///\r\n            scrollHandler = onScroll, ///\r\n            changeHandler = onChange; ///\r\n\r\n    blurHandler && this.offBlur(blurHandler, this);\r\n\r\n    focusHandler && this.offFocus(focusHandler, this);\r\n\r\n    scrollHandler && this.offScroll(scrollHandler, this);\r\n\r\n    changeHandler && this.offChange(changeHandler, 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  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  initialise() {\r\n    this.setInitialState();\r\n  }\r\n\r\n  static tagName = \"textarea\";\r\n\r\n  static ignoredProperties = [\r\n    \"onBlur\",\r\n    \"onFocus\",\r\n    \"onScroll\",\r\n    \"onChange\"\r\n  ];\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, eventMixins);\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","CHANGE_EVENT_TYPE","SELECTIONCHANGE_EVENT_TYPE","blurHandler","event","element","eventType","selectionChanged","intermediateHandler","focusHandler","defer","inputHandler","scrollHandler","callHandlers","selectChangeHandler","currentTarget","activeElement","domElement","getDOMElement","hasSelectionChanged","content","getContent","selection","getSelection","contentChanged","hasContentChanged","previousContent","previousSelection","setPreviousContent","setPreviousSelection","remainingArguments","eventListeners","findEventListeners","forEach","eventListener","handler","handlerElement","call","isReadOnly","readOnly","isActive","active","hasClass","value","Selection","fromDOMElement","getPreviousContent","contentPreviousContent","getPreviousSelection","selectionPreviousSelection","isEqualTo","setReadOnly","Object","assign","setContent","setSelection","selectionStartPosition","getStartPosition","selectionEndPosition","getEndPosition","selectionStart","selectionEnd","setSelectionRange","activate","on","document","addClass","deactivate","off","removeClass","getState","updateState","didMount","properties","onBlur","onFocus","onScroll","onChange","changeHandler","willUnmount","offBlur","offFocus","offScroll","offChange","setInitialState","setState","initialise","fromClass","Class","Element","richTextarea","tagName","ignoredProperties","defaultProperties","className","prototype","eventMixins","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.46",
4
+ "version": "4.0.48",
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,17 +6,13 @@ import Selection from "./selection"
6
6
  import eventMixins from "./mixins/event";
7
7
 
8
8
  const { BLUR_EVENT_TYPE,
9
- INPUT_EVENT_TYPE,
10
9
  FOCUS_EVENT_TYPE,
11
- CHANGE_EVENT_TYPE,
10
+ INPUT_EVENT_TYPE,
12
11
  SCROLL_EVENT_TYPE,
12
+ CHANGE_EVENT_TYPE,
13
13
  SELECTIONCHANGE_EVENT_TYPE } = eventTypes;
14
14
 
15
15
  export default class RichTextarea extends Element {
16
- inputHandler = (event, element) => {
17
- this.intermediateHandler(event, element);
18
- }
19
-
20
16
  blurHandler = (event, element) => {
21
17
  const eventType = BLUR_EVENT_TYPE,
22
18
  selectionChanged = true;
@@ -33,16 +29,16 @@ export default class RichTextarea extends Element {
33
29
  });
34
30
  }
35
31
 
32
+ inputHandler = (event, element) => {
33
+ this.intermediateHandler(event, element);
34
+ }
35
+
36
36
  scrollHandler = (event, element) => {
37
37
  const eventType = SCROLL_EVENT_TYPE;
38
38
 
39
39
  this.callHandlers(eventType, event, element);
40
40
  }
41
41
 
42
- contextmenuHandler = (event, element) => {
43
- event.preventDefault();
44
- }
45
-
46
42
  selectChangeHandler = (event, element) => {
47
43
  const { currentTarget } = event,
48
44
  { activeElement } = currentTarget,
@@ -78,18 +74,18 @@ export default class RichTextarea extends Element {
78
74
  eventListeners.forEach((eventListener) => {
79
75
  let { element } = eventListener;
80
76
 
81
- const { handler } = eventListener,
82
- handlerElement = element; ///
83
-
84
- element = this; ///
77
+ const { handler } = eventListener;
85
78
 
86
- if ( (handler !== this.inputHandler)
87
- && (handler !== this.blurHandler)
79
+ if ( (handler !== this.blurHandler)
88
80
  && (handler !== this.focusHandler)
81
+ && (handler !== this.inputHandler)
89
82
  && (handler !== this.scrollHandler)
90
- && (handler !== this.contextmenuHandler)
91
83
  && (handler !== this.selectChangeHandler) ) {
92
84
 
85
+ const handlerElement = element; ///
86
+
87
+ element = this; ///
88
+
93
89
  handler.call(handlerElement, ...remainingArguments, element);
94
90
  }
95
91
  });
@@ -123,18 +119,6 @@ export default class RichTextarea extends Element {
123
119
  return selection;
124
120
  }
125
121
 
126
- getSelectedContent() {
127
- const content = this.getContent(),
128
- selection = this.getSelection(),
129
- endPosition = selection.getEndPosition(),
130
- startPosition = selection.getStartPosition(),
131
- start = startPosition, ///
132
- end = endPosition, ///
133
- selectedContent = content.slice(start, end);
134
-
135
- return selectedContent;
136
- }
137
-
138
122
  hasContentChanged() {
139
123
  const content = this.getContent(),
140
124
  previousContent = this.getPreviousContent(),
@@ -193,12 +177,12 @@ export default class RichTextarea extends Element {
193
177
  }
194
178
 
195
179
  activate() {
196
- this.on(INPUT_EVENT_TYPE, this.inputHandler);
197
-
198
180
  this.on(BLUR_EVENT_TYPE, this.blurHandler);
199
181
 
200
182
  this.on(FOCUS_EVENT_TYPE, this.focusHandler);
201
183
 
184
+ this.on(INPUT_EVENT_TYPE, this.inputHandler);
185
+
202
186
  this.on(SCROLL_EVENT_TYPE, this.scrollHandler);
203
187
 
204
188
  document.on(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);
@@ -207,12 +191,12 @@ export default class RichTextarea extends Element {
207
191
  }
208
192
 
209
193
  deactivate() {
210
- this.off(INPUT_EVENT_TYPE, this.inputHandler);
211
-
212
194
  this.off(BLUR_EVENT_TYPE, this.blurHandler);
213
195
 
214
196
  this.off(FOCUS_EVENT_TYPE, this.focusHandler);
215
197
 
198
+ this.off(INPUT_EVENT_TYPE, this.inputHandler);
199
+
216
200
  this.off(SCROLL_EVENT_TYPE, this.scrollHandler);
217
201
 
218
202
  document.off(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);
@@ -245,14 +229,21 @@ export default class RichTextarea extends Element {
245
229
  }
246
230
 
247
231
  didMount() {
232
+ const content = this.getContent(),
233
+ selection = this.getSelection(),
234
+ previousContent = content, ///
235
+ previousSelection = selection; ///
236
+
237
+ this.setPreviousContent(previousContent);
238
+
239
+ this.setPreviousSelection(previousSelection);
240
+
248
241
  const { onBlur, onFocus, onScroll, onChange } = this.properties,
249
242
  blurHandler = onBlur, ///
250
243
  focusHandler = onFocus, ///
251
244
  scrollHandler = onScroll, ///
252
245
  changeHandler = onChange; ///
253
246
 
254
- this.updateInitialState();
255
-
256
247
  blurHandler && this.onBlur(blurHandler, this);
257
248
 
258
249
  focusHandler && this.onFocus(focusHandler, this);
@@ -284,17 +275,6 @@ export default class RichTextarea extends Element {
284
275
  }
285
276
  }
286
277
 
287
- updateInitialState() {
288
- const content = this.getContent(),
289
- selection = this.getSelection(),
290
- previousContent = content, ///
291
- previousSelection = selection; ///
292
-
293
- this.setPreviousContent(previousContent);
294
-
295
- this.setPreviousSelection(previousSelection);
296
- }
297
-
298
278
  setInitialState() {
299
279
  const previousContent = null,
300
280
  previousSelection = null;