easy-richtextarea 4.0.47 → 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.
- package/example.js +5 -43
- package/lib/richTextarea.js +6 -44
- package/package.json +1 -1
- package/src/richTextarea.js +9 -75
package/lib/richTextarea.js
CHANGED
|
@@ -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, 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,
|
|
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);
|
|
@@ -221,21 +221,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
221
221
|
var eventType = SCROLL_EVENT_TYPE;
|
|
222
222
|
_this.callHandlers(eventType, event, element);
|
|
223
223
|
});
|
|
224
|
-
_defineProperty(_assertThisInitialized(_this), "cutHandler", function(event, element) {
|
|
225
|
-
///
|
|
226
|
-
});
|
|
227
|
-
_defineProperty(_assertThisInitialized(_this), "copyHandler", function(event, element) {
|
|
228
|
-
///
|
|
229
|
-
});
|
|
230
|
-
_defineProperty(_assertThisInitialized(_this), "pasteHandler", function(event, element) {
|
|
231
|
-
///
|
|
232
|
-
});
|
|
233
|
-
_defineProperty(_assertThisInitialized(_this), "keyDownHandler", function(event, element) {
|
|
234
|
-
///
|
|
235
|
-
});
|
|
236
|
-
_defineProperty(_assertThisInitialized(_this), "mouseDownHandler", function(event, element) {
|
|
237
|
-
///
|
|
238
|
-
});
|
|
239
224
|
_defineProperty(_assertThisInitialized(_this), "selectChangeHandler", function(event, element) {
|
|
240
225
|
var currentTarget = event.currentTarget, activeElement = currentTarget.activeElement, domElement = _this.getDOMElement();
|
|
241
226
|
if (activeElement === domElement) {
|
|
@@ -267,7 +252,7 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
267
252
|
eventListeners.forEach(function(eventListener) {
|
|
268
253
|
var element = eventListener.element;
|
|
269
254
|
var handler = eventListener.handler;
|
|
270
|
-
if (handler !== _this.blurHandler && handler !== _this.focusHandler && handler !== _this.inputHandler && handler !== _this.scrollHandler && handler !== _this.
|
|
255
|
+
if (handler !== _this.blurHandler && handler !== _this.focusHandler && handler !== _this.inputHandler && handler !== _this.scrollHandler && handler !== _this.selectChangeHandler) {
|
|
271
256
|
var _handler;
|
|
272
257
|
var handlerElement = element; ///
|
|
273
258
|
element = _this; ///
|
|
@@ -308,13 +293,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
308
293
|
return selection;
|
|
309
294
|
}
|
|
310
295
|
},
|
|
311
|
-
{
|
|
312
|
-
key: "getSelectedContent",
|
|
313
|
-
value: function getSelectedContent() {
|
|
314
|
-
var content = this.getContent(), selection = this.getSelection(), endPosition = selection.getEndPosition(), startPosition = selection.getStartPosition(), start = startPosition, end = endPosition, selectedContent = content.slice(start, end);
|
|
315
|
-
return selectedContent;
|
|
316
|
-
}
|
|
317
|
-
},
|
|
318
296
|
{
|
|
319
297
|
key: "hasContentChanged",
|
|
320
298
|
value: function hasContentChanged() {
|
|
@@ -371,11 +349,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
371
349
|
this.on(FOCUS_EVENT_TYPE, this.focusHandler);
|
|
372
350
|
this.on(INPUT_EVENT_TYPE, this.inputHandler);
|
|
373
351
|
this.on(SCROLL_EVENT_TYPE, this.scrollHandler);
|
|
374
|
-
this.on(CUT_EVENT_TYPE, this.cutHandler);
|
|
375
|
-
this.on(COPY_EVENT_TYPE, this.copyHandler);
|
|
376
|
-
this.on(PASTE_EVENT_TYPE, this.pasteHandler);
|
|
377
|
-
this.on(KEYDOWN_EVENT_TYPE, this.keyDownHandler);
|
|
378
|
-
this.on(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler);
|
|
379
352
|
_easy.document.on(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);
|
|
380
353
|
this.addClass("active");
|
|
381
354
|
}
|
|
@@ -387,11 +360,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
387
360
|
this.off(FOCUS_EVENT_TYPE, this.focusHandler);
|
|
388
361
|
this.off(INPUT_EVENT_TYPE, this.inputHandler);
|
|
389
362
|
this.off(SCROLL_EVENT_TYPE, this.scrollHandler);
|
|
390
|
-
this.off(CUT_EVENT_TYPE, this.cutHandler);
|
|
391
|
-
this.off(COPY_EVENT_TYPE, this.copyHandler);
|
|
392
|
-
this.off(PASTE_EVENT_TYPE, this.pasteHandler);
|
|
393
|
-
this.off(KEYDOWN_EVENT_TYPE, this.keyDownHandler);
|
|
394
|
-
this.off(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler);
|
|
395
363
|
_easy.document.off(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);
|
|
396
364
|
this.removeClass("active");
|
|
397
365
|
}
|
|
@@ -429,8 +397,10 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
429
397
|
{
|
|
430
398
|
key: "didMount",
|
|
431
399
|
value: function didMount() {
|
|
400
|
+
var content = this.getContent(), selection = this.getSelection(), previousContent = content, previousSelection = selection; ///
|
|
401
|
+
this.setPreviousContent(previousContent);
|
|
402
|
+
this.setPreviousSelection(previousSelection);
|
|
432
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; ///
|
|
433
|
-
this.updateInitialState();
|
|
434
404
|
blurHandler && this.onBlur(blurHandler, this);
|
|
435
405
|
focusHandler && this.onFocus(focusHandler, this);
|
|
436
406
|
scrollHandler && this.onScroll(scrollHandler, this);
|
|
@@ -451,14 +421,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
451
421
|
}
|
|
452
422
|
}
|
|
453
423
|
},
|
|
454
|
-
{
|
|
455
|
-
key: "updateInitialState",
|
|
456
|
-
value: function updateInitialState() {
|
|
457
|
-
var content = this.getContent(), selection = this.getSelection(), previousContent = content, previousSelection = selection; ///
|
|
458
|
-
this.setPreviousContent(previousContent);
|
|
459
|
-
this.setPreviousSelection(previousSelection);
|
|
460
|
-
}
|
|
461
|
-
},
|
|
462
424
|
{
|
|
463
425
|
key: "setInitialState",
|
|
464
426
|
value: function setInitialState() {
|
|
@@ -508,4 +470,4 @@ function defer(func) {
|
|
|
508
470
|
setTimeout(func, 0);
|
|
509
471
|
}
|
|
510
472
|
|
|
511
|
-
//# 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        CUT_EVENT_TYPE,\r\n        COPY_EVENT_TYPE,\r\n        PASTE_EVENT_TYPE,\r\n        KEYDOWN_EVENT_TYPE,\r\n        MOUSEDOWN_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  cutHandler = (event, element) => {\r\n    ///\r\n  }\r\n\r\n  copyHandler = (event, element) => {\r\n    ///\r\n  }\r\n\r\n  pasteHandler = (event, element) => {\r\n    ///\r\n  }\r\n\r\n  keyDownHandler = (event, element) => {\r\n    ///\r\n  }\r\n\r\n  mouseDownHandler = (event, element) => {\r\n    ///\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.cutHandler)\r\n        && (handler !== this.copyHandler)\r\n        && (handler !== this.pasteHandler)\r\n        && (handler !== this.keyDownHandler)\r\n        && (handler !== this.mouseDownHandler)\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  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(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    this.on(CUT_EVENT_TYPE, this.cutHandler);\r\n\r\n    this.on(COPY_EVENT_TYPE, this.copyHandler);\r\n\r\n    this.on(PASTE_EVENT_TYPE, this.pasteHandler);\r\n\r\n    this.on(KEYDOWN_EVENT_TYPE, this.keyDownHandler);\r\n\r\n    this.on(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler);\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    this.off(CUT_EVENT_TYPE, this.cutHandler);\r\n\r\n    this.off(COPY_EVENT_TYPE, this.copyHandler);\r\n\r\n    this.off(PASTE_EVENT_TYPE, this.pasteHandler);\r\n\r\n    this.off(KEYDOWN_EVENT_TYPE, this.keyDownHandler);\r\n\r\n    this.off(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler);\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","FOCUS_EVENT_TYPE","INPUT_EVENT_TYPE","SCROLL_EVENT_TYPE","CHANGE_EVENT_TYPE","CUT_EVENT_TYPE","COPY_EVENT_TYPE","PASTE_EVENT_TYPE","KEYDOWN_EVENT_TYPE","MOUSEDOWN_EVENT_TYPE","SELECTIONCHANGE_EVENT_TYPE","blurHandler","event","element","eventType","selectionChanged","intermediateHandler","focusHandler","defer","inputHandler","scrollHandler","callHandlers","cutHandler","copyHandler","pasteHandler","keyDownHandler","mouseDownHandler","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.
|
|
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.",
|
package/src/richTextarea.js
CHANGED
|
@@ -10,11 +10,6 @@ const { BLUR_EVENT_TYPE,
|
|
|
10
10
|
INPUT_EVENT_TYPE,
|
|
11
11
|
SCROLL_EVENT_TYPE,
|
|
12
12
|
CHANGE_EVENT_TYPE,
|
|
13
|
-
CUT_EVENT_TYPE,
|
|
14
|
-
COPY_EVENT_TYPE,
|
|
15
|
-
PASTE_EVENT_TYPE,
|
|
16
|
-
KEYDOWN_EVENT_TYPE,
|
|
17
|
-
MOUSEDOWN_EVENT_TYPE,
|
|
18
13
|
SELECTIONCHANGE_EVENT_TYPE } = eventTypes;
|
|
19
14
|
|
|
20
15
|
export default class RichTextarea extends Element {
|
|
@@ -44,26 +39,6 @@ export default class RichTextarea extends Element {
|
|
|
44
39
|
this.callHandlers(eventType, event, element);
|
|
45
40
|
}
|
|
46
41
|
|
|
47
|
-
cutHandler = (event, element) => {
|
|
48
|
-
///
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
copyHandler = (event, element) => {
|
|
52
|
-
///
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
pasteHandler = (event, element) => {
|
|
56
|
-
///
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
keyDownHandler = (event, element) => {
|
|
60
|
-
///
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
mouseDownHandler = (event, element) => {
|
|
64
|
-
///
|
|
65
|
-
}
|
|
66
|
-
|
|
67
42
|
selectChangeHandler = (event, element) => {
|
|
68
43
|
const { currentTarget } = event,
|
|
69
44
|
{ activeElement } = currentTarget,
|
|
@@ -105,11 +80,6 @@ export default class RichTextarea extends Element {
|
|
|
105
80
|
&& (handler !== this.focusHandler)
|
|
106
81
|
&& (handler !== this.inputHandler)
|
|
107
82
|
&& (handler !== this.scrollHandler)
|
|
108
|
-
&& (handler !== this.cutHandler)
|
|
109
|
-
&& (handler !== this.copyHandler)
|
|
110
|
-
&& (handler !== this.pasteHandler)
|
|
111
|
-
&& (handler !== this.keyDownHandler)
|
|
112
|
-
&& (handler !== this.mouseDownHandler)
|
|
113
83
|
&& (handler !== this.selectChangeHandler) ) {
|
|
114
84
|
|
|
115
85
|
const handlerElement = element; ///
|
|
@@ -149,18 +119,6 @@ export default class RichTextarea extends Element {
|
|
|
149
119
|
return selection;
|
|
150
120
|
}
|
|
151
121
|
|
|
152
|
-
getSelectedContent() {
|
|
153
|
-
const content = this.getContent(),
|
|
154
|
-
selection = this.getSelection(),
|
|
155
|
-
endPosition = selection.getEndPosition(),
|
|
156
|
-
startPosition = selection.getStartPosition(),
|
|
157
|
-
start = startPosition, ///
|
|
158
|
-
end = endPosition, ///
|
|
159
|
-
selectedContent = content.slice(start, end);
|
|
160
|
-
|
|
161
|
-
return selectedContent;
|
|
162
|
-
}
|
|
163
|
-
|
|
164
122
|
hasContentChanged() {
|
|
165
123
|
const content = this.getContent(),
|
|
166
124
|
previousContent = this.getPreviousContent(),
|
|
@@ -227,16 +185,6 @@ export default class RichTextarea extends Element {
|
|
|
227
185
|
|
|
228
186
|
this.on(SCROLL_EVENT_TYPE, this.scrollHandler);
|
|
229
187
|
|
|
230
|
-
this.on(CUT_EVENT_TYPE, this.cutHandler);
|
|
231
|
-
|
|
232
|
-
this.on(COPY_EVENT_TYPE, this.copyHandler);
|
|
233
|
-
|
|
234
|
-
this.on(PASTE_EVENT_TYPE, this.pasteHandler);
|
|
235
|
-
|
|
236
|
-
this.on(KEYDOWN_EVENT_TYPE, this.keyDownHandler);
|
|
237
|
-
|
|
238
|
-
this.on(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler);
|
|
239
|
-
|
|
240
188
|
document.on(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);
|
|
241
189
|
|
|
242
190
|
this.addClass("active");
|
|
@@ -251,16 +199,6 @@ export default class RichTextarea extends Element {
|
|
|
251
199
|
|
|
252
200
|
this.off(SCROLL_EVENT_TYPE, this.scrollHandler);
|
|
253
201
|
|
|
254
|
-
this.off(CUT_EVENT_TYPE, this.cutHandler);
|
|
255
|
-
|
|
256
|
-
this.off(COPY_EVENT_TYPE, this.copyHandler);
|
|
257
|
-
|
|
258
|
-
this.off(PASTE_EVENT_TYPE, this.pasteHandler);
|
|
259
|
-
|
|
260
|
-
this.off(KEYDOWN_EVENT_TYPE, this.keyDownHandler);
|
|
261
|
-
|
|
262
|
-
this.off(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler);
|
|
263
|
-
|
|
264
202
|
document.off(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);
|
|
265
203
|
|
|
266
204
|
this.removeClass("active");
|
|
@@ -291,14 +229,21 @@ export default class RichTextarea extends Element {
|
|
|
291
229
|
}
|
|
292
230
|
|
|
293
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
|
+
|
|
294
241
|
const { onBlur, onFocus, onScroll, onChange } = this.properties,
|
|
295
242
|
blurHandler = onBlur, ///
|
|
296
243
|
focusHandler = onFocus, ///
|
|
297
244
|
scrollHandler = onScroll, ///
|
|
298
245
|
changeHandler = onChange; ///
|
|
299
246
|
|
|
300
|
-
this.updateInitialState();
|
|
301
|
-
|
|
302
247
|
blurHandler && this.onBlur(blurHandler, this);
|
|
303
248
|
|
|
304
249
|
focusHandler && this.onFocus(focusHandler, this);
|
|
@@ -330,17 +275,6 @@ export default class RichTextarea extends Element {
|
|
|
330
275
|
}
|
|
331
276
|
}
|
|
332
277
|
|
|
333
|
-
updateInitialState() {
|
|
334
|
-
const content = this.getContent(),
|
|
335
|
-
selection = this.getSelection(),
|
|
336
|
-
previousContent = content, ///
|
|
337
|
-
previousSelection = selection; ///
|
|
338
|
-
|
|
339
|
-
this.setPreviousContent(previousContent);
|
|
340
|
-
|
|
341
|
-
this.setPreviousSelection(previousSelection);
|
|
342
|
-
}
|
|
343
|
-
|
|
344
278
|
setInitialState() {
|
|
345
279
|
const previousContent = null,
|
|
346
280
|
previousSelection = null;
|