easy-richtextarea 4.0.199 → 4.0.201

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.
@@ -186,7 +186,7 @@ function _create_super(Derived) {
186
186
  return _possible_constructor_return(this, result);
187
187
  };
188
188
  }
189
- 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, SELECTIONCHANGE_EVENT_TYPE = _easy.eventTypes.SELECTIONCHANGE_EVENT_TYPE;
189
+ 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;
190
190
  var RichTextarea = /*#__PURE__*/ function(Element) {
191
191
  _inherits(RichTextarea, Element);
192
192
  var _super = _create_super(RichTextarea);
@@ -195,34 +195,58 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
195
195
  var _this;
196
196
  _this = _super.apply(this, arguments);
197
197
  _define_property(_assert_this_initialized(_this), "blurHandler", function(event, element) {
198
- var customEventType = _customEventTypes.BLUR_CUSTOM_EVENT_TYPE, selectionChanged = true;
199
- _this.customHandler(customEventType, event, element, selectionChanged);
198
+ var active = _this.isActive();
199
+ if (!active) {
200
+ return;
201
+ }
202
+ var customEventType = _customEventTypes.BLUR_CUSTOM_EVENT_TYPE, forced = true;
203
+ _this.customHandler(customEventType, event, element, forced);
200
204
  });
201
205
  _define_property(_assert_this_initialized(_this), "focusHandler", function(event, element) {
202
206
  defer(function() {
203
- var customEventType = _customEventTypes.FOCUS_CUSTOM_EVENT_TYPE, selectionChanged = true;
204
- _this.customHandler(customEventType, event, element, selectionChanged);
207
+ var active = _this.isActive();
208
+ if (!active) {
209
+ _this.addClass("active");
210
+ var customEventType = _customEventTypes.ACTIVATE_CUSTOM_EVENT_TYPE, _$event = null, _$element = _assert_this_initialized(_this), forced = true;
211
+ _this.customHandler(customEventType, _$event, _$element, forced);
212
+ }
213
+ var customEventType1 = _customEventTypes.FOCUS_CUSTOM_EVENT_TYPE, forced1 = true;
214
+ _this.customHandler(customEventType1, event, element, forced1);
205
215
  });
206
216
  });
207
217
  _define_property(_assert_this_initialized(_this), "inputHandler", function(event, element) {
208
- var customEventType = _customEventTypes.CHANGE_CUSTOM_EVENT_TYPE, selectionChanged = _this.hasSelectionChanged();
209
- _this.customHandler(customEventType, event, element, selectionChanged);
218
+ var active = _this.isActive();
219
+ if (!active) {
220
+ return;
221
+ }
222
+ var customEventType = _customEventTypes.CHANGE_CUSTOM_EVENT_TYPE;
223
+ _this.customHandler(customEventType, event, element);
210
224
  });
211
225
  _define_property(_assert_this_initialized(_this), "scrollHandler", function(event, element) {
212
- var customEventType = _customEventTypes.SCROLL_CUSTOM_EVENT_TYPE;
213
- _this.callCustomHandlers(customEventType, event, element);
226
+ var active = _this.isActive();
227
+ if (!active) {
228
+ return;
229
+ }
230
+ var customEventType = _customEventTypes.SCROLL_CUSTOM_EVENT_TYPE, forced = true;
231
+ _this.customHandler(customEventType, event, element, forced);
214
232
  });
215
- _define_property(_assert_this_initialized(_this), "selectChangeHandler", function(event, element) {
233
+ _define_property(_assert_this_initialized(_this), "selectionChangeHandler", function(event, element) {
234
+ var active = _this.isActive();
235
+ if (!active) {
236
+ return;
237
+ }
216
238
  var currentTarget = event.currentTarget, activeElement = currentTarget.activeElement, domElement = _this.getDOMElement();
217
- if (activeElement === domElement) {
218
- element = _assert_this_initialized(_this); ///
219
- var customEventType = _customEventTypes.CHANGE_CUSTOM_EVENT_TYPE, selectionChanged = _this.hasSelectionChanged();
220
- _this.customHandler(customEventType, event, element, selectionChanged);
239
+ if (activeElement !== domElement) {
240
+ return;
221
241
  }
242
+ element = _assert_this_initialized(_this); ///
243
+ var customEventType = _customEventTypes.CHANGE_CUSTOM_EVENT_TYPE;
244
+ _this.customHandler(customEventType, event, element);
222
245
  });
223
- _define_property(_assert_this_initialized(_this), "customHandler", function(customEventType, event, element, selectionChanged) {
224
- var content = _this.getContent(), selection = _this.getSelection(), contentChanged = _this.hasContentChanged();
225
- if (contentChanged || selectionChanged) {
246
+ _define_property(_assert_this_initialized(_this), "customHandler", function(customEventType, event, element) {
247
+ var forced = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : false;
248
+ var content = _this.getContent(), selection = _this.getSelection(), contentChanged = _this.hasContentChanged(), selectionChanged = _this.hasSelectionChanged();
249
+ if (forced || contentChanged || selectionChanged) {
226
250
  _this.callCustomHandlers(customEventType, event, element);
227
251
  }
228
252
  var previousContent = content, previousSelection = selection; ///
@@ -312,23 +336,23 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
312
336
  {
313
337
  key: "activate",
314
338
  value: function activate() {
315
- this.onEvent(BLUR_EVENT_TYPE, this.blurHandler);
316
- this.onEvent(FOCUS_EVENT_TYPE, this.focusHandler);
317
- this.onEvent(INPUT_EVENT_TYPE, this.inputHandler);
318
- this.onEvent(SCROLL_EVENT_TYPE, this.scrollHandler);
319
- _easy.document.onEvent(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);
320
- this.addClass("active");
339
+ var active = this.isActive();
340
+ if (active) {
341
+ return;
342
+ }
343
+ this.focus();
321
344
  }
322
345
  },
323
346
  {
324
347
  key: "deactivate",
325
348
  value: function deactivate() {
326
- this.offEvent(BLUR_EVENT_TYPE, this.blurHandler);
327
- this.offEvent(FOCUS_EVENT_TYPE, this.focusHandler);
328
- this.offEvent(INPUT_EVENT_TYPE, this.inputHandler);
329
- this.offEvent(SCROLL_EVENT_TYPE, this.scrollHandler);
330
- _easy.document.offEvent(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);
349
+ var active = this.isActive();
350
+ if (!active) {
351
+ return;
352
+ }
331
353
  this.removeClass("active");
354
+ var customEventType = _customEventTypes.DEACTIVATE_CUSTOM_EVENT_TYPE, event = null, element = this, forced = true;
355
+ this.customHandler(customEventType, event, element, forced);
332
356
  }
333
357
  },
334
358
  {
@@ -361,31 +385,37 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
361
385
  });
362
386
  }
363
387
  },
388
+ {
389
+ key: "setInitialState",
390
+ value: function setInitialState() {
391
+ var previousContent = null, previousSelection = null;
392
+ this.setState({
393
+ previousContent: previousContent,
394
+ previousSelection: previousSelection
395
+ });
396
+ }
397
+ },
364
398
  {
365
399
  key: "didMount",
366
400
  value: function didMount() {
367
401
  var content = this.getContent(), selection = this.getSelection(), previousContent = content, previousSelection = selection; ///
368
402
  this.setPreviousContent(previousContent);
369
403
  this.setPreviousSelection(previousSelection);
404
+ this.onEvent(BLUR_EVENT_TYPE, this.blurHandler);
405
+ this.onEvent(FOCUS_EVENT_TYPE, this.focusHandler);
406
+ this.onEvent(INPUT_EVENT_TYPE, this.inputHandler);
407
+ this.onEvent(SCROLL_EVENT_TYPE, this.scrollHandler);
408
+ _easy.document.onSelectionChange(this.selectionChangeHandler, this);
370
409
  }
371
410
  },
372
411
  {
373
412
  key: "willUnmount",
374
413
  value: function willUnmount() {
375
- var active = this.isActive();
376
- if (active) {
377
- this.deactivate();
378
- }
379
- }
380
- },
381
- {
382
- key: "setInitialState",
383
- value: function setInitialState() {
384
- var previousContent = null, previousSelection = null;
385
- this.setState({
386
- previousContent: previousContent,
387
- previousSelection: previousSelection
388
- });
414
+ this.offEvent(BLUR_EVENT_TYPE, this.blurHandler);
415
+ this.offEvent(FOCUS_EVENT_TYPE, this.focusHandler);
416
+ this.offEvent(INPUT_EVENT_TYPE, this.inputHandler);
417
+ this.offEvent(SCROLL_EVENT_TYPE, this.scrollHandler);
418
+ _easy.document.offSelectionChange(this.selectionChangeHandler, this);
389
419
  }
390
420
  },
391
421
  {
@@ -421,4 +451,4 @@ function defer(func) {
421
451
  setTimeout(func, 0);
422
452
  }
423
453
 
424
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/richTextarea.js"],"sourcesContent":["\"use strict\";\r\n\r\nimport { Element, document, eventTypes } from \"easy\";\r\n\r\nimport Selection from \"./selection\"\r\nimport customEventMixins from \"./mixins/customEvent\";\r\n\r\nimport { BLUR_CUSTOM_EVENT_TYPE, FOCUS_CUSTOM_EVENT_TYPE, SCROLL_CUSTOM_EVENT_TYPE, CHANGE_CUSTOM_EVENT_TYPE } from \"./customEventTypes\";\r\n\r\nconst { BLUR_EVENT_TYPE,\r\n        FOCUS_EVENT_TYPE,\r\n        INPUT_EVENT_TYPE,\r\n        SCROLL_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 customEventType = BLUR_CUSTOM_EVENT_TYPE,\r\n          selectionChanged = true;\r\n\r\n    this.customHandler(customEventType, event, element, selectionChanged);\r\n  }\r\n\r\n  focusHandler = (event, element) => {\r\n    defer(() => {\r\n      const customEventType = FOCUS_CUSTOM_EVENT_TYPE,\r\n            selectionChanged = true;\r\n\r\n      this.customHandler(customEventType, event, element, selectionChanged);\r\n    });\r\n  }\r\n\r\n  inputHandler = (event, element) => {\r\n    const customEventType = CHANGE_CUSTOM_EVENT_TYPE,\r\n          selectionChanged = this.hasSelectionChanged();\r\n\r\n    this.customHandler(customEventType, event, element, selectionChanged);\r\n  }\r\n\r\n  scrollHandler = (event, element) => {\r\n    const customEventType = SCROLL_CUSTOM_EVENT_TYPE;\r\n\r\n    this.callCustomHandlers(customEventType, 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      const customEventType = CHANGE_CUSTOM_EVENT_TYPE,\r\n            selectionChanged = this.hasSelectionChanged();\r\n\r\n      this.customHandler(customEventType, event, element, selectionChanged);\r\n    }\r\n  }\r\n\r\n  customHandler = (customEventType, event, element, selectionChanged) => {\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.callCustomHandlers(customEventType, event, element);\r\n    }\r\n\r\n    const previousContent = content,  ///\r\n          previousSelection = selection;  ///\r\n\r\n    this.setPreviousContent(previousContent);\r\n\r\n    this.setPreviousSelection(previousSelection);\r\n  }\r\n\r\n  isReadOnly() {\r\n    const domElement = this.getDOMElement(),\r\n          { readOnly } = domElement;\r\n\r\n    return readOnly;\r\n  }\r\n\r\n  isActive() {\r\n    const active = this.hasClass(\"active\");\r\n\r\n    return active;\r\n  }\r\n\r\n  getContent() {\r\n    const domElement = this.getDOMElement(),\r\n          { value } = domElement,\r\n          content = value;  ///\r\n\r\n    return content;\r\n  }\r\n\r\n  getSelection() {\r\n    const domElement = this.getDOMElement(),\r\n          selection = Selection.fromDOMElement(domElement);\r\n\r\n    return selection;\r\n  }\r\n\r\n  hasContentChanged() {\r\n    const content = this.getContent(),\r\n          previousContent = this.getPreviousContent(),\r\n          contentPreviousContent = (content === previousContent),\r\n          contentChanged = !contentPreviousContent;\r\n\r\n    return contentChanged;\r\n  }\r\n\r\n  hasSelectionChanged() {\r\n    const selection = this.getSelection(),\r\n          previousSelection = this.getPreviousSelection(),\r\n          selectionPreviousSelection = selection.isEqualTo(previousSelection),\r\n          selectionChanged = !selectionPreviousSelection; ///\r\n\r\n    return selectionChanged;\r\n  }\r\n\r\n  setReadOnly(readOnly) {\r\n    const domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      readOnly\r\n    });\r\n  }\r\n\r\n  setContent(content, setPreviousContent = true) {\r\n    const value = content,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      value\r\n    });\r\n\r\n    if (setPreviousContent) {\r\n      const previousContent = content;  ///\r\n\r\n      this.setPreviousContent(previousContent);\r\n    }\r\n  }\r\n\r\n  setSelection(selection, setPreviousSelection = true) {\r\n    const selectionStartPosition = selection.getStartPosition(),\r\n          selectionEndPosition = selection.getEndPosition(),\r\n          selectionStart = selectionStartPosition,  ///\r\n          selectionEnd = selectionEndPosition,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    domElement.setSelectionRange(selectionStart, selectionEnd);\r\n\r\n    if (setPreviousSelection) {\r\n      const previousSelection = selection;  ///\r\n\r\n      this.setPreviousSelection(previousSelection);\r\n    }\r\n  }\r\n\r\n  activate() {\r\n    this.onEvent(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.onEvent(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.onEvent(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.onEvent(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.onEvent(SELECTIONCHANGE_EVENT_TYPE, this.selectChangeHandler);\r\n\r\n    this.addClass(\"active\");\r\n  }\r\n\r\n  deactivate() {\r\n    this.offEvent(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.offEvent(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.offEvent(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.offEvent(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.offEvent(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\r\n  willUnmount() {\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 defaultProperties = {\r\n    className: \"rich\"\r\n  };\r\n\r\n  static fromClass(Class, properties, ...remainingArguments) {\r\n    const richTextarea = Element.fromClass(Class, properties, ...remainingArguments);\r\n\r\n    return richTextarea;\r\n  }\r\n}\r\n\r\nObject.assign(RichTextarea.prototype, customEventMixins);\r\n\r\nfunction defer(func) {\r\n  setTimeout(func, 0);\r\n}\r\n"],"names":["RichTextarea","BLUR_EVENT_TYPE","eventTypes","FOCUS_EVENT_TYPE","INPUT_EVENT_TYPE","SCROLL_EVENT_TYPE","SELECTIONCHANGE_EVENT_TYPE","blurHandler","event","element","customEventType","BLUR_CUSTOM_EVENT_TYPE","selectionChanged","customHandler","focusHandler","defer","FOCUS_CUSTOM_EVENT_TYPE","inputHandler","CHANGE_CUSTOM_EVENT_TYPE","hasSelectionChanged","scrollHandler","SCROLL_CUSTOM_EVENT_TYPE","callCustomHandlers","selectChangeHandler","currentTarget","activeElement","domElement","getDOMElement","content","getContent","selection","getSelection","contentChanged","hasContentChanged","previousContent","previousSelection","setPreviousContent","setPreviousSelection","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","onEvent","document","addClass","deactivate","offEvent","removeClass","getState","updateState","didMount","willUnmount","setInitialState","setState","initialise","fromClass","Class","properties","remainingArguments","Element","richTextarea","tagName","defaultProperties","className","prototype","customEventMixins","func","setTimeout"],"mappings":"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"}
454
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/richTextarea.js"],"sourcesContent":["\"use strict\";\r\n\r\nimport { Element, document, eventTypes } from \"easy\";\r\n\r\nimport Selection from \"./selection\"\r\nimport customEventMixins from \"./mixins/customEvent\";\r\n\r\nimport { BLUR_CUSTOM_EVENT_TYPE,\r\n         FOCUS_CUSTOM_EVENT_TYPE,\r\n         SCROLL_CUSTOM_EVENT_TYPE,\r\n         CHANGE_CUSTOM_EVENT_TYPE,\r\n         ACTIVATE_CUSTOM_EVENT_TYPE,\r\n         DEACTIVATE_CUSTOM_EVENT_TYPE } from \"./customEventTypes\";\r\n\r\nconst { BLUR_EVENT_TYPE, FOCUS_EVENT_TYPE, INPUT_EVENT_TYPE, SCROLL_EVENT_TYPE } = eventTypes;\r\n\r\nexport default class RichTextarea extends Element {\r\n  blurHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const customEventType = BLUR_CUSTOM_EVENT_TYPE,\r\n          forced = true;\r\n\r\n    this.customHandler(customEventType, event, element, forced);\r\n  }\r\n\r\n  focusHandler = (event, element) => {\r\n    defer(() => {\r\n      const active = this.isActive();\r\n\r\n      if (!active) {\r\n        this.addClass(\"active\");\r\n\r\n        const customEventType = ACTIVATE_CUSTOM_EVENT_TYPE,\r\n              event = null,\r\n              element = this,\r\n              forced = true;\r\n\r\n        this.customHandler(customEventType, event, element, forced);\r\n      }\r\n\r\n      const customEventType = FOCUS_CUSTOM_EVENT_TYPE,\r\n            forced = true;\r\n\r\n      this.customHandler(customEventType, event, element, forced);\r\n    });\r\n  }\r\n\r\n  inputHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const customEventType = CHANGE_CUSTOM_EVENT_TYPE;\r\n\r\n    this.customHandler(customEventType, event, element);\r\n  }\r\n\r\n  scrollHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const customEventType = SCROLL_CUSTOM_EVENT_TYPE,\r\n          forced = true;\r\n\r\n    this.customHandler(customEventType, event, element, forced);\r\n  }\r\n\r\n  selectionChangeHandler = (event, element) => {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    const { currentTarget } = event,\r\n          { activeElement } = currentTarget,\r\n          domElement = this.getDOMElement();\r\n\r\n    if (activeElement !== domElement) {\r\n      return;\r\n    }\r\n\r\n    element = this; ///\r\n\r\n    const customEventType = CHANGE_CUSTOM_EVENT_TYPE;\r\n\r\n    this.customHandler(customEventType, event, element);\r\n  }\r\n\r\n  customHandler = (customEventType, event, element, forced = false) => {\r\n    const content = this.getContent(),\r\n          selection = this.getSelection(),\r\n          contentChanged = this.hasContentChanged(),\r\n          selectionChanged = this.hasSelectionChanged();\r\n\r\n    if (forced || contentChanged || selectionChanged) {\r\n      this.callCustomHandlers(customEventType, event, element);\r\n    }\r\n\r\n    const previousContent = content,  ///\r\n          previousSelection = selection;  ///\r\n\r\n    this.setPreviousContent(previousContent);\r\n\r\n    this.setPreviousSelection(previousSelection);\r\n  }\r\n\r\n  isReadOnly() {\r\n    const domElement = this.getDOMElement(),\r\n          { readOnly } = domElement;\r\n\r\n    return readOnly;\r\n  }\r\n\r\n  isActive() {\r\n    const active = this.hasClass(\"active\");\r\n\r\n    return active;\r\n  }\r\n\r\n  getContent() {\r\n    const domElement = this.getDOMElement(),\r\n          { value } = domElement,\r\n          content = value;  ///\r\n\r\n    return content;\r\n  }\r\n\r\n  getSelection() {\r\n    const domElement = this.getDOMElement(),\r\n          selection = Selection.fromDOMElement(domElement);\r\n\r\n    return selection;\r\n  }\r\n\r\n  hasContentChanged() {\r\n    const content = this.getContent(),\r\n          previousContent = this.getPreviousContent(),\r\n          contentPreviousContent = (content === previousContent),\r\n          contentChanged = !contentPreviousContent;\r\n\r\n    return contentChanged;\r\n  }\r\n\r\n  hasSelectionChanged() {\r\n    const selection = this.getSelection(),\r\n          previousSelection = this.getPreviousSelection(),\r\n          selectionPreviousSelection = selection.isEqualTo(previousSelection),\r\n          selectionChanged = !selectionPreviousSelection; ///\r\n\r\n    return selectionChanged;\r\n  }\r\n\r\n  setReadOnly(readOnly) {\r\n    const domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      readOnly\r\n    });\r\n  }\r\n\r\n  setContent(content, setPreviousContent = true) {\r\n    const value = content,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      value\r\n    });\r\n\r\n    if (setPreviousContent) {\r\n      const previousContent = content;  ///\r\n\r\n      this.setPreviousContent(previousContent);\r\n    }\r\n  }\r\n\r\n  setSelection(selection, setPreviousSelection = true) {\r\n    const selectionStartPosition = selection.getStartPosition(),\r\n          selectionEndPosition = selection.getEndPosition(),\r\n          selectionStart = selectionStartPosition,  ///\r\n          selectionEnd = selectionEndPosition,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    domElement.setSelectionRange(selectionStart, selectionEnd);\r\n\r\n    if (setPreviousSelection) {\r\n      const previousSelection = selection;  ///\r\n\r\n      this.setPreviousSelection(previousSelection);\r\n    }\r\n  }\r\n\r\n  activate() {\r\n    const active = this.isActive();\r\n\r\n    if (active) {\r\n      return;\r\n    }\r\n\r\n    this.focus();\r\n  }\r\n\r\n  deactivate() {\r\n    const active = this.isActive();\r\n\r\n    if (!active) {\r\n      return;\r\n    }\r\n\r\n    this.removeClass(\"active\");\r\n\r\n    const customEventType = DEACTIVATE_CUSTOM_EVENT_TYPE,\r\n          event = null,\r\n          element = this,\r\n          forced = true;\r\n\r\n    this.customHandler(customEventType, event, element, forced);\r\n  }\r\n\r\n  getPreviousContent() {\r\n    const { previousContent } = this.getState();\r\n\r\n    return previousContent;\r\n  }\r\n\r\n  getPreviousSelection() {\r\n    const { previousSelection } = this.getState();\r\n\r\n    return previousSelection;\r\n  }\r\n\r\n  setPreviousContent(previousContent) {\r\n    this.updateState({\r\n      previousContent\r\n    });\r\n  }\r\n\r\n  setPreviousSelection(previousSelection) {\r\n    this.updateState({\r\n      previousSelection\r\n    });\r\n  }\r\n\r\n  setInitialState() {\r\n    const previousContent = null,\r\n          previousSelection = null;\r\n\r\n    this.setState({\r\n      previousContent,\r\n      previousSelection\r\n    });\r\n  }\r\n\r\n  didMount() {\r\n    const content = this.getContent(),\r\n          selection = this.getSelection(),\r\n          previousContent = content,  ///\r\n          previousSelection = selection;  ///\r\n\r\n    this.setPreviousContent(previousContent);\r\n\r\n    this.setPreviousSelection(previousSelection);\r\n\r\n    this.onEvent(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.onEvent(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.onEvent(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.onEvent(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.onSelectionChange(this.selectionChangeHandler, this);\r\n  }\r\n\r\n  willUnmount() {\r\n    this.offEvent(BLUR_EVENT_TYPE, this.blurHandler);\r\n\r\n    this.offEvent(FOCUS_EVENT_TYPE, this.focusHandler);\r\n\r\n    this.offEvent(INPUT_EVENT_TYPE, this.inputHandler);\r\n\r\n    this.offEvent(SCROLL_EVENT_TYPE, this.scrollHandler);\r\n\r\n    document.offSelectionChange(this.selectionChangeHandler, this);\r\n  }\r\n\r\n  initialise() {\r\n    this.setInitialState();\r\n  }\r\n\r\n  static tagName = \"textarea\";\r\n\r\n  static defaultProperties = {\r\n    className: \"rich\"\r\n  };\r\n\r\n  static fromClass(Class, properties, ...remainingArguments) {\r\n    const richTextarea = Element.fromClass(Class, properties, ...remainingArguments);\r\n\r\n    return richTextarea;\r\n  }\r\n}\r\n\r\nObject.assign(RichTextarea.prototype, customEventMixins);\r\n\r\nfunction defer(func) {\r\n  setTimeout(func, 0);\r\n}\r\n"],"names":["RichTextarea","BLUR_EVENT_TYPE","eventTypes","FOCUS_EVENT_TYPE","INPUT_EVENT_TYPE","SCROLL_EVENT_TYPE","blurHandler","event","element","active","isActive","customEventType","BLUR_CUSTOM_EVENT_TYPE","forced","customHandler","focusHandler","defer","addClass","ACTIVATE_CUSTOM_EVENT_TYPE","FOCUS_CUSTOM_EVENT_TYPE","inputHandler","CHANGE_CUSTOM_EVENT_TYPE","scrollHandler","SCROLL_CUSTOM_EVENT_TYPE","selectionChangeHandler","currentTarget","activeElement","domElement","getDOMElement","content","getContent","selection","getSelection","contentChanged","hasContentChanged","selectionChanged","hasSelectionChanged","callCustomHandlers","previousContent","previousSelection","setPreviousContent","setPreviousSelection","isReadOnly","readOnly","hasClass","value","Selection","fromDOMElement","getPreviousContent","contentPreviousContent","getPreviousSelection","selectionPreviousSelection","isEqualTo","setReadOnly","Object","assign","setContent","setSelection","selectionStartPosition","getStartPosition","selectionEndPosition","getEndPosition","selectionStart","selectionEnd","setSelectionRange","activate","focus","deactivate","removeClass","DEACTIVATE_CUSTOM_EVENT_TYPE","getState","updateState","setInitialState","setState","didMount","onEvent","document","onSelectionChange","willUnmount","offEvent","offSelectionChange","initialise","fromClass","Class","properties","remainingArguments","Element","richTextarea","tagName","defaultProperties","className","prototype","customEventMixins","func","setTimeout"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "easy-richtextarea",
3
3
  "author": "James Smith",
4
- "version": "4.0.199",
4
+ "version": "4.0.201",
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.",
@@ -10,15 +10,15 @@
10
10
  "url": "https://github.com/djalbat/easy-richtextarea"
11
11
  },
12
12
  "dependencies": {
13
- "easy": "^19.0.1",
14
- "necessary": "^14.0.1"
13
+ "easy": "^19.0.4"
15
14
  },
16
15
  "devDependencies": {
17
16
  "@swc/core": "^1.5.6",
18
- "easy-with-style": "^3.0.391",
17
+ "easy-with-style": "^3.0.392",
19
18
  "esbuild": "^0.9.2",
20
19
  "express": "^4.17.1",
21
20
  "lively-cli": "^2.0.65",
21
+ "necessary": "^14.0.1",
22
22
  "watchful-cli": "^1.7.56"
23
23
  },
24
24
  "scripts": {
@@ -4,10 +4,14 @@ export const BLUR_CUSTOM_EVENT_TYPE = "blur";
4
4
  export const FOCUS_CUSTOM_EVENT_TYPE = "focus";
5
5
  export const SCROLL_CUSTOM_EVENT_TYPE = "scroll";
6
6
  export const CHANGE_CUSTOM_EVENT_TYPE = "change";
7
+ export const ACTIVATE_CUSTOM_EVENT_TYPE = "activate";
8
+ export const DEACTIVATE_CUSTOM_EVENT_TYPE = "deactivate";
7
9
 
8
10
  export default {
9
11
  BLUR_CUSTOM_EVENT_TYPE,
10
12
  FOCUS_CUSTOM_EVENT_TYPE,
11
13
  SCROLL_CUSTOM_EVENT_TYPE,
12
- CHANGE_CUSTOM_EVENT_TYPE
14
+ CHANGE_CUSTOM_EVENT_TYPE,
15
+ ACTIVATE_CUSTOM_EVENT_TYPE,
16
+ DEACTIVATE_CUSTOM_EVENT_TYPE
13
17
  };
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+
3
+ import withStyle from "easy-with-style"; ///
4
+
5
+ import { Button } from "easy";
6
+
7
+ export default withStyle(Button)`
8
+
9
+ cursor: pointer;
10
+ border: 1px solid black;
11
+ margin: 1rem;
12
+ display: block;
13
+ padding: 0.25rem;
14
+
15
+ `;
@@ -2,15 +2,24 @@
2
2
 
3
3
  import withStyle from "easy-with-style";
4
4
 
5
- import { RichTextarea } from "../index"; ///
5
+ import { RichTextarea } from "../../index"; ///
6
6
 
7
7
  export default withStyle(RichTextarea)`
8
8
 
9
+ color: white;
9
10
  width: 48rem;
10
- border: solid 1px black;
11
11
  resize: none;
12
12
  height: 32rem;
13
+ margin: 1rem;
14
+ display: block;
13
15
  padding: 0.25rem;
14
16
  font-family: monospace;
17
+ background-color: black;
18
+
19
+ opacity: 0.5;
20
+
21
+ .active {
22
+ opacity: 1;
23
+ }
15
24
 
16
25
  `;
@@ -1,49 +1,82 @@
1
1
  "use strict";
2
2
 
3
- import RichTextarea from "./richTextarea";
3
+ import { Element } from "easy";
4
+ import { arrayUtilities } from "necessary";
4
5
 
5
- const content = "",
6
- richTextarea =
6
+ import Button from "./view/button";
7
+ import RichTextarea from "./view/richTextarea";
7
8
 
8
- <RichTextarea onCustomBlur={customBlurHandler}
9
- onCustomFocus={customFocusHandler}
10
- onCustomScroll={customScrollHandler}
11
- onCustomChange={customChangeHandler} />
9
+ const { second } = arrayUtilities;
12
10
 
13
- ;
11
+ let count = 0;
14
12
 
15
- richTextarea.setContent(content);
13
+ export default class View extends Element {
14
+ buttonClickHandler = (event, element) => {
15
+ const richTextarea = this.getRickTextarea();
16
16
 
17
- richTextarea.activate();
17
+ richTextarea.activate();
18
+ }
18
19
 
19
- const View = (properties) =>
20
+ blurCustomHandler = (event, element) => {
21
+ console.log(count++, "blur")
22
+ }
20
23
 
21
- <div className="view">
22
- {richTextarea}
23
- </div>
24
+ focusCustomHandler = (event, element) => {
25
+ console.log(count++, "focus")
26
+ }
24
27
 
25
- ;
28
+ scrollCustomHandler = (event, element) => {
29
+ const richTextarea = this.getRickTextarea(),
30
+ scrollTop = richTextarea.getScrollTop(),
31
+ scrollLeft = richTextarea.getScrollLeft();
26
32
 
27
- export default View;
33
+ console.log(count++, "scroll", scrollTop, scrollLeft)
34
+ }
28
35
 
29
- function customBlurHandler(event, element) {
30
- console.log("blur")
31
- }
36
+ changeCustomHandler = (event, element) => {
37
+ const richTextarea = this.getRickTextarea(),
38
+ contentChanged = richTextarea.hasContentChanged(),
39
+ selectionChanged = richTextarea.hasSelectionChanged();
32
40
 
33
- function customFocusHandler(event, element) {
34
- console.log("focus")
35
- }
41
+ console.log(count++, "change", contentChanged, selectionChanged)
42
+ }
36
43
 
37
- function customScrollHandler(event, element) {
38
- const scrollTop = richTextarea.getScrollTop(),
39
- scrollLeft = richTextarea.getScrollLeft();
44
+ activateCustomHandler = (event, element) => {
45
+ console.log(count++, "activate")
46
+ }
40
47
 
41
- console.log(scrollTop, scrollLeft)
42
- }
48
+ deactivateCustomHandler = (event, element) => {
49
+ console.log(count++, "deactivate")
50
+ }
51
+
52
+ getRickTextarea() {
53
+ const childElements = this.getChildElements(),
54
+ secondChildElement = second(childElements),
55
+ richTextarea = secondChildElement; ///
56
+
57
+ return richTextarea;
58
+ }
59
+
60
+ childElements() {
61
+ return ([
62
+
63
+ <Button onClick={this.buttonClickHandler}>
64
+ Activate
65
+ </Button>,
66
+ <RichTextarea onCustomBlur={this.blurCustomHandler}
67
+ onCustomFocus={this.focusCustomHandler}
68
+ onCustomScroll={this.scrollCustomHandler}
69
+ onCustomChange={this.changeCustomHandler}
70
+ onCustomActivate={this.activateCustomHandler}
71
+ onCustomDeactivate={this.deactivateCustomHandler}
72
+ />
73
+
74
+ ]);
75
+ }
43
76
 
44
- function customChangeHandler(event, element) {
45
- const contentChanged = richTextarea.hasContentChanged(),
46
- selectionChanged = richTextarea.hasSelectionChanged();
77
+ static tagName = "div";
47
78
 
48
- console.log(contentChanged, selectionChanged)
79
+ static defaultProperties = {
80
+ className: "view"
81
+ }
49
82
  }
package/src/example.js CHANGED
@@ -16,6 +16,6 @@ renderStyles();
16
16
 
17
17
  body.mount(
18
18
 
19
- <View />
19
+ <View/>
20
20
 
21
21
  );