easy-richtextarea 4.0.42 → 4.0.44
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/example.js +27 -805
- package/lib/richTextarea.js +7 -22
- package/package.json +2 -2
- package/src/richTextarea.js +6 -21
package/lib/richTextarea.js
CHANGED
|
@@ -200,20 +200,18 @@ var BLUR_EVENT_TYPE = _easy.eventTypes.BLUR_EVENT_TYPE, INPUT_EVENT_TYPE = _easy
|
|
|
200
200
|
var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
201
201
|
_inherits(RichTextarea, Element);
|
|
202
202
|
var _super = _createSuper(RichTextarea);
|
|
203
|
-
function RichTextarea(
|
|
203
|
+
function RichTextarea() {
|
|
204
204
|
_classCallCheck(this, RichTextarea);
|
|
205
205
|
var _this;
|
|
206
|
-
_this = _super.
|
|
206
|
+
_this = _super.apply(this, arguments);
|
|
207
207
|
_defineProperty(_assertThisInitialized(_this), "inputHandler", function(event, element) {
|
|
208
208
|
_this.intermediateHandler(event, element);
|
|
209
209
|
});
|
|
210
210
|
_defineProperty(_assertThisInitialized(_this), "blurHandler", function(event, element) {
|
|
211
|
-
_this.focused = false;
|
|
212
211
|
var eventType = BLUR_EVENT_TYPE, selectionChanged = true;
|
|
213
212
|
_this.intermediateHandler(event, element, eventType, selectionChanged);
|
|
214
213
|
});
|
|
215
214
|
_defineProperty(_assertThisInitialized(_this), "focusHandler", function(event, element) {
|
|
216
|
-
_this.focused = true;
|
|
217
215
|
defer(function() {
|
|
218
216
|
var eventType = FOCUS_EVENT_TYPE, selectionChanged = true;
|
|
219
217
|
_this.intermediateHandler(event, element, eventType, selectionChanged);
|
|
@@ -227,7 +225,8 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
227
225
|
event.preventDefault();
|
|
228
226
|
});
|
|
229
227
|
_defineProperty(_assertThisInitialized(_this), "selectChangeHandler", function(event, element) {
|
|
230
|
-
|
|
228
|
+
var currentTarget = event.currentTarget, activeElement = currentTarget.activeElement, domElement = _this.getDOMElement();
|
|
229
|
+
if (activeElement === domElement) {
|
|
231
230
|
element = _assertThisInitialized(_this); ///
|
|
232
231
|
_this.intermediateHandler(event, element);
|
|
233
232
|
}
|
|
@@ -242,22 +241,9 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
242
241
|
_this.setPreviousContent(previousContent);
|
|
243
242
|
_this.setPreviousSelection(previousSelection);
|
|
244
243
|
});
|
|
245
|
-
_this.focused = focused;
|
|
246
244
|
return _this;
|
|
247
245
|
}
|
|
248
246
|
_createClass(RichTextarea, [
|
|
249
|
-
{
|
|
250
|
-
key: "isFocused",
|
|
251
|
-
value: function isFocused() {
|
|
252
|
-
return this.focused;
|
|
253
|
-
}
|
|
254
|
-
},
|
|
255
|
-
{
|
|
256
|
-
key: "setFocused",
|
|
257
|
-
value: function setFocused(focused) {
|
|
258
|
-
this.focused = focused;
|
|
259
|
-
}
|
|
260
|
-
},
|
|
261
247
|
{
|
|
262
248
|
key: "callHandlers",
|
|
263
249
|
value: function callHandlers(eventType) {
|
|
@@ -458,10 +444,9 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
458
444
|
remainingArguments[_key - 2] = arguments[_key];
|
|
459
445
|
}
|
|
460
446
|
var _Element;
|
|
461
|
-
var
|
|
447
|
+
var richTextarea = (_Element = _easy.Element).fromClass.apply(_Element, [
|
|
462
448
|
Class,
|
|
463
|
-
properties
|
|
464
|
-
focused
|
|
449
|
+
properties
|
|
465
450
|
].concat(_toConsumableArray(remainingArguments)));
|
|
466
451
|
return richTextarea;
|
|
467
452
|
}
|
|
@@ -484,4 +469,4 @@ function defer(func) {
|
|
|
484
469
|
setTimeout(func, 0);
|
|
485
470
|
}
|
|
486
471
|
|
|
487
|
-
//# 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  constructor(selector, focused) {\r\n    super(selector);\r\n\r\n    this.focused = focused;\r\n  }\r\n\r\n  isFocused() {\r\n    return this.focused;\r\n  }\r\n\r\n  setFocused(focused) {\r\n    this.focused = focused;\r\n  }\r\n\r\n  inputHandler = (event, element) => {\r\n    this.intermediateHandler(event, element);\r\n  }\r\n\r\n  blurHandler = (event, element) => {\r\n    this.focused = false;\r\n\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    this.focused = true;\r\n\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    if (this.focused) {\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  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  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 focused = false,\r\n          richTextarea = Element.fromClass(Class, properties, focused, ...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","selector","focused","inputHandler","event","element","intermediateHandler","blurHandler","eventType","selectionChanged","focusHandler","defer","scrollHandler","callHandlers","contextmenuHandler","preventDefault","selectChangeHandler","hasSelectionChanged","content","getContent","selection","getSelection","contentChanged","hasContentChanged","previousContent","previousSelection","setPreviousContent","setPreviousSelection","isFocused","setFocused","remainingArguments","eventListeners","findEventListeners","forEach","eventListener","handler","handlerElement","call","isActive","active","hasClass","domElement","getDOMElement","value","Selection","fromDOMElement","getSelectedContent","endPosition","getEndPosition","startPosition","getStartPosition","start","end","selectedContent","slice","getPreviousContent","contentPreviousContent","getPreviousSelection","selectionPreviousSelection","isEqualTo","setContent","Object","assign","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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"}
|
|
472
|
+
//# 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  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  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","isActive","active","hasClass","value","Selection","fromDOMElement","getSelectedContent","endPosition","getEndPosition","startPosition","getStartPosition","start","end","selectedContent","slice","getPreviousContent","contentPreviousContent","getPreviousSelection","selectionPreviousSelection","isEqualTo","setContent","Object","assign","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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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "easy-richtextarea",
|
|
3
3
|
"author": "James Smith",
|
|
4
|
-
"version": "4.0.
|
|
4
|
+
"version": "4.0.44",
|
|
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.",
|
|
@@ -15,7 +15,7 @@
|
|
|
15
15
|
},
|
|
16
16
|
"devDependencies": {
|
|
17
17
|
"@swc/core": "^1.2.160",
|
|
18
|
-
"easy-with-style": "^3.0.
|
|
18
|
+
"easy-with-style": "^3.0.195",
|
|
19
19
|
"esbuild": "^0.9.2",
|
|
20
20
|
"express": "^4.17.1",
|
|
21
21
|
"lively-cli": "^2.0.34",
|
package/src/richTextarea.js
CHANGED
|
@@ -13,27 +13,11 @@ const { BLUR_EVENT_TYPE,
|
|
|
13
13
|
SELECTIONCHANGE_EVENT_TYPE } = eventTypes;
|
|
14
14
|
|
|
15
15
|
export default class RichTextarea extends Element {
|
|
16
|
-
constructor(selector, focused) {
|
|
17
|
-
super(selector);
|
|
18
|
-
|
|
19
|
-
this.focused = focused;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
isFocused() {
|
|
23
|
-
return this.focused;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
setFocused(focused) {
|
|
27
|
-
this.focused = focused;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
16
|
inputHandler = (event, element) => {
|
|
31
17
|
this.intermediateHandler(event, element);
|
|
32
18
|
}
|
|
33
19
|
|
|
34
20
|
blurHandler = (event, element) => {
|
|
35
|
-
this.focused = false;
|
|
36
|
-
|
|
37
21
|
const eventType = BLUR_EVENT_TYPE,
|
|
38
22
|
selectionChanged = true;
|
|
39
23
|
|
|
@@ -41,8 +25,6 @@ export default class RichTextarea extends Element {
|
|
|
41
25
|
}
|
|
42
26
|
|
|
43
27
|
focusHandler = (event, element) => {
|
|
44
|
-
this.focused = true;
|
|
45
|
-
|
|
46
28
|
defer(() => {
|
|
47
29
|
const eventType = FOCUS_EVENT_TYPE,
|
|
48
30
|
selectionChanged = true;
|
|
@@ -62,7 +44,11 @@ export default class RichTextarea extends Element {
|
|
|
62
44
|
}
|
|
63
45
|
|
|
64
46
|
selectChangeHandler = (event, element) => {
|
|
65
|
-
|
|
47
|
+
const { currentTarget } = event,
|
|
48
|
+
{ activeElement } = currentTarget,
|
|
49
|
+
domElement = this.getDOMElement();
|
|
50
|
+
|
|
51
|
+
if (activeElement === domElement) {
|
|
66
52
|
element = this; ///
|
|
67
53
|
|
|
68
54
|
this.intermediateHandler(event, element);
|
|
@@ -322,8 +308,7 @@ export default class RichTextarea extends Element {
|
|
|
322
308
|
};
|
|
323
309
|
|
|
324
310
|
static fromClass(Class, properties, ...remainingArguments) {
|
|
325
|
-
const
|
|
326
|
-
richTextarea = Element.fromClass(Class, properties, focused, ...remainingArguments);
|
|
311
|
+
const richTextarea = Element.fromClass(Class, properties, ...remainingArguments);
|
|
327
312
|
|
|
328
313
|
return richTextarea;
|
|
329
314
|
}
|