easy-richtextarea 4.0.200 → 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.
- package/README.md +8 -1
- package/example.js +349 -72
- package/lib/customEventTypes.js +12 -2
- package/lib/example/view/button.js +39 -0
- package/lib/example/view/richTextarea.js +39 -0
- package/lib/example/view.js +217 -30
- package/lib/example.js +1 -1
- package/lib/richTextarea.js +73 -43
- package/package.json +3 -3
- package/src/customEventTypes.js +5 -1
- package/src/example/view/button.js +15 -0
- package/src/example/{richTextarea.js → view/richTextarea.js} +11 -2
- package/src/example/view.js +64 -31
- package/src/example.js +1 -1
- package/src/richTextarea.js +106 -53
- package/lib/example/richTextarea.js +0 -39
package/lib/richTextarea.js
CHANGED
|
@@ -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
|
|
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
|
|
199
|
-
|
|
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
|
|
204
|
-
|
|
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
|
|
209
|
-
|
|
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
|
|
213
|
-
|
|
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), "
|
|
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
|
|
218
|
-
|
|
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
|
|
224
|
-
var
|
|
225
|
-
|
|
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.
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
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.
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
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
|
-
|
|
376
|
-
|
|
377
|
-
|
|
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.
|
|
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,8 +10,7 @@
|
|
|
10
10
|
"url": "https://github.com/djalbat/easy-richtextarea"
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"easy": "^19.0.4"
|
|
14
|
-
"necessary": "^14.0.1"
|
|
13
|
+
"easy": "^19.0.4"
|
|
15
14
|
},
|
|
16
15
|
"devDependencies": {
|
|
17
16
|
"@swc/core": "^1.5.6",
|
|
@@ -19,6 +18,7 @@
|
|
|
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": {
|
package/src/customEventTypes.js
CHANGED
|
@@ -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
|
};
|
|
@@ -2,15 +2,24 @@
|
|
|
2
2
|
|
|
3
3
|
import withStyle from "easy-with-style";
|
|
4
4
|
|
|
5
|
-
import { RichTextarea } from "
|
|
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
|
`;
|
package/src/example/view.js
CHANGED
|
@@ -1,49 +1,82 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import
|
|
3
|
+
import { Element } from "easy";
|
|
4
|
+
import { arrayUtilities } from "necessary";
|
|
4
5
|
|
|
5
|
-
|
|
6
|
-
|
|
6
|
+
import Button from "./view/button";
|
|
7
|
+
import RichTextarea from "./view/richTextarea";
|
|
7
8
|
|
|
8
|
-
|
|
9
|
-
onCustomFocus={customFocusHandler}
|
|
10
|
-
onCustomScroll={customScrollHandler}
|
|
11
|
-
onCustomChange={customChangeHandler} />
|
|
9
|
+
const { second } = arrayUtilities;
|
|
12
10
|
|
|
13
|
-
|
|
11
|
+
let count = 0;
|
|
14
12
|
|
|
15
|
-
|
|
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
|
-
|
|
20
|
+
blurCustomHandler = (event, element) => {
|
|
21
|
+
console.log(count++, "blur")
|
|
22
|
+
}
|
|
20
23
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
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
|
-
|
|
33
|
+
console.log(count++, "scroll", scrollTop, scrollLeft)
|
|
34
|
+
}
|
|
28
35
|
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
36
|
+
changeCustomHandler = (event, element) => {
|
|
37
|
+
const richTextarea = this.getRickTextarea(),
|
|
38
|
+
contentChanged = richTextarea.hasContentChanged(),
|
|
39
|
+
selectionChanged = richTextarea.hasSelectionChanged();
|
|
32
40
|
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
}
|
|
41
|
+
console.log(count++, "change", contentChanged, selectionChanged)
|
|
42
|
+
}
|
|
36
43
|
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
44
|
+
activateCustomHandler = (event, element) => {
|
|
45
|
+
console.log(count++, "activate")
|
|
46
|
+
}
|
|
40
47
|
|
|
41
|
-
|
|
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
|
-
|
|
45
|
-
const contentChanged = richTextarea.hasContentChanged(),
|
|
46
|
-
selectionChanged = richTextarea.hasSelectionChanged();
|
|
77
|
+
static tagName = "div";
|
|
47
78
|
|
|
48
|
-
|
|
79
|
+
static defaultProperties = {
|
|
80
|
+
className: "view"
|
|
81
|
+
}
|
|
49
82
|
}
|