easy-richtextarea 3.0.146 → 3.0.148
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 +60 -47
- package/lib/example/richTextarea.js +2 -2
- package/lib/example/view.js +11 -8
- package/lib/richTextarea.js +47 -39
- package/package.json +1 -1
- package/src/example/richTextarea.js +6 -0
- package/src/example/view.js +16 -6
- package/src/richTextarea.js +62 -47
|
@@ -27,7 +27,7 @@ function _taggedTemplateLiteral(strings, raw) {
|
|
|
27
27
|
}
|
|
28
28
|
function _templateObject() {
|
|
29
29
|
var data = _taggedTemplateLiteral([
|
|
30
|
-
"\n\n border: 1px solid black;\n width: 32rem;\n height: 32rem;\n padding: 0.25rem;\n font-size: 1.2rem;\n font-family: monospace;\n\n"
|
|
30
|
+
"\n\n border: 1px solid black;\n width: 32rem;\n height: 32rem;\n padding: 0.25rem;\n font-size: 1.2rem;\n font-family: monospace;\n \n display: none;\n \n .active {\n display: block;\n }\n\n"
|
|
31
31
|
]);
|
|
32
32
|
_templateObject = function _templateObject() {
|
|
33
33
|
return data;
|
|
@@ -36,4 +36,4 @@ function _templateObject() {
|
|
|
36
36
|
}
|
|
37
37
|
var _default = (0, _easyWithStyle.default)(_browser.RichTextarea)(_templateObject());
|
|
38
38
|
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9leGFtcGxlL3JpY2hUZXh0YXJlYS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHdpdGhTdHlsZSBmcm9tIFwiZWFzeS13aXRoLXN0eWxlXCI7XG5cbmltcG9ydCB7IFJpY2hUZXh0YXJlYSB9IGZyb20gXCIuLi9icm93c2VyXCI7ICAvLy9cblxuZXhwb3J0IGRlZmF1bHQgd2l0aFN0eWxlKFJpY2hUZXh0YXJlYSlgXG5cbiAgYm9yZGVyOiAxcHggc29saWQgYmxhY2s7XG4gIHdpZHRoOiAzMnJlbTtcbiAgaGVpZ2h0OiAzMnJlbTtcbiAgcGFkZGluZzogMC4yNXJlbTtcbiAgZm9udC1zaXplOiAxLjJyZW07XG4gIGZvbnQtZmFtaWx5OiBtb25vc3BhY2U7XG4gIFxuICBkaXNwbGF5OiBub25lO1xuICBcbiAgLmFjdGl2ZSB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gIH1cblxuYDtcbiJdLCJuYW1lcyI6WyJ3aXRoU3R5bGUiLCJSaWNoVGV4dGFyZWEiXSwibWFwcGluZ3MiOiJBQUFBOzs7OytCQU1BOzs7ZUFBQTs7O2tFQUpzQjt1QkFFTzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQUU3QixXQUFlQSxJQUFBQSxzQkFBUyxFQUFDQyxxQkFBWSJ9
|
package/lib/example/view.js
CHANGED
|
@@ -14,16 +14,19 @@ function _interopRequireDefault(obj) {
|
|
|
14
14
|
default: obj
|
|
15
15
|
};
|
|
16
16
|
}
|
|
17
|
+
var content = "Rule (blah)\n Conclusion\n A", readOnly = true, richTextarea = /*#__PURE__*/ React.createElement(_richTextarea.default, {
|
|
18
|
+
onChange: changeHandler,
|
|
19
|
+
onScroll: scrollHandler,
|
|
20
|
+
onFocus: focusHandler,
|
|
21
|
+
onBlur: blurHandler
|
|
22
|
+
});
|
|
23
|
+
richTextarea.setContent(content);
|
|
24
|
+
richTextarea.setReadOnly(readOnly);
|
|
25
|
+
richTextarea.activate();
|
|
17
26
|
var View = function(properties) {
|
|
18
27
|
return /*#__PURE__*/ React.createElement("div", {
|
|
19
28
|
className: "view"
|
|
20
|
-
},
|
|
21
|
-
onChange: changeHandler,
|
|
22
|
-
onScroll: scrollHandler,
|
|
23
|
-
onFocus: focusHandler,
|
|
24
|
-
onBlur: blurHandler,
|
|
25
|
-
active: true
|
|
26
|
-
}));
|
|
29
|
+
}, richTextarea);
|
|
27
30
|
};
|
|
28
31
|
var _default = View;
|
|
29
32
|
function changeHandler(event, element) {
|
|
@@ -41,4 +44,4 @@ function blurHandler(event, element) {
|
|
|
41
44
|
console.log("blur");
|
|
42
45
|
}
|
|
43
46
|
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9leGFtcGxlL3ZpZXcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCBSaWNoVGV4dGFyZWEgZnJvbSBcIi4vcmljaFRleHRhcmVhXCI7XG5cbmNvbnN0IGNvbnRlbnQgPSBgUnVsZSAoYmxhaClcbiAgQ29uY2x1c2lvblxuICAgIEFgLFxuICAgICAgcmVhZE9ubHkgPSB0cnVlLFxuICAgICAgcmljaFRleHRhcmVhID1cblxuICAgICAgICA8UmljaFRleHRhcmVhIG9uQ2hhbmdlPXtjaGFuZ2VIYW5kbGVyfSBvblNjcm9sbD17c2Nyb2xsSGFuZGxlcn0gb25Gb2N1cz17Zm9jdXNIYW5kbGVyfSBvbkJsdXI9e2JsdXJIYW5kbGVyfSAvPlxuXG4gICAgICA7XG5cbnJpY2hUZXh0YXJlYS5zZXRDb250ZW50KGNvbnRlbnQpO1xucmljaFRleHRhcmVhLnNldFJlYWRPbmx5KHJlYWRPbmx5KTtcblxucmljaFRleHRhcmVhLmFjdGl2YXRlKCk7XG5cbmNvbnN0IFZpZXcgPSAocHJvcGVydGllcykgPT5cblxuICA8ZGl2IGNsYXNzTmFtZT1cInZpZXdcIj5cbiAgICB7cmljaFRleHRhcmVhfVxuICA8L2Rpdj5cblxuO1xuXG5leHBvcnQgZGVmYXVsdCBWaWV3O1xuXG5mdW5jdGlvbiBjaGFuZ2VIYW5kbGVyKGV2ZW50LCBlbGVtZW50KSB7XG4gIGNvbnN0IGNvbnRlbnRDaGFuZ2VkID0gZWxlbWVudC5oYXNDb250ZW50Q2hhbmdlZCgpLFxuICAgICAgICBzZWxlY3Rpb25DaGFuZ2VkID0gZWxlbWVudC5oYXNTZWxlY3Rpb25DaGFuZ2VkKCk7XG5cbiAgY29uc29sZS5sb2coY29udGVudENoYW5nZWQsIHNlbGVjdGlvbkNoYW5nZWQpXG59XG5cbmZ1bmN0aW9uIHNjcm9sbEhhbmRsZXIoZXZlbnQsIGVsZW1lbnQpIHtcbiAgY29uc3Qgc2Nyb2xsVG9wID0gZWxlbWVudC5nZXRTY3JvbGxUb3AoKSxcbiAgICAgICAgc2Nyb2xsTGVmdCA9IGVsZW1lbnQuZ2V0U2Nyb2xsTGVmdCgpO1xuXG4gIGNvbnNvbGUubG9nKHNjcm9sbFRvcCwgc2Nyb2xsTGVmdClcbn1cblxuZnVuY3Rpb24gZm9jdXNIYW5kbGVyKGV2ZW50LCBlbGVtZW50KSB7XG4gIGNvbnNvbGUubG9nKFwiZm9jdXNcIilcbn1cblxuZnVuY3Rpb24gYmx1ckhhbmRsZXIoZXZlbnQsIGVsZW1lbnQpIHtcbiAgY29uc29sZS5sb2coXCJibHVyXCIpXG59XG4iXSwibmFtZXMiOlsiY29udGVudCIsInJlYWRPbmx5IiwicmljaFRleHRhcmVhIiwiUmljaFRleHRhcmVhIiwib25DaGFuZ2UiLCJjaGFuZ2VIYW5kbGVyIiwib25TY3JvbGwiLCJzY3JvbGxIYW5kbGVyIiwib25Gb2N1cyIsImZvY3VzSGFuZGxlciIsIm9uQmx1ciIsImJsdXJIYW5kbGVyIiwic2V0Q29udGVudCIsInNldFJlYWRPbmx5IiwiYWN0aXZhdGUiLCJWaWV3IiwicHJvcGVydGllcyIsImRpdiIsImNsYXNzTmFtZSIsImV2ZW50IiwiZWxlbWVudCIsImNvbnRlbnRDaGFuZ2VkIiwiaGFzQ29udGVudENoYW5nZWQiLCJzZWxlY3Rpb25DaGFuZ2VkIiwiaGFzU2VsZWN0aW9uQ2hhbmdlZCIsImNvbnNvbGUiLCJsb2ciLCJzY3JvbGxUb3AiLCJnZXRTY3JvbGxUb3AiLCJzY3JvbGxMZWZ0IiwiZ2V0U2Nyb2xsTGVmdCJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7K0JBMkJBOzs7ZUFBQTs7O2lFQXpCeUI7Ozs7OztBQUV6QixJQUFNQSxVQUFXLG9DQUdYQyxXQUFXLElBQUksRUFDZkMsNkJBRUUsb0JBQUNDLHFCQUFZO0lBQUNDLFVBQVVDO0lBQWVDLFVBQVVDO0lBQWVDLFNBQVNDO0lBQWNDLFFBQVFDOztBQUl2R1QsYUFBYVUsVUFBVSxDQUFDWjtBQUN4QkUsYUFBYVcsV0FBVyxDQUFDWjtBQUV6QkMsYUFBYVksUUFBUTtBQUVyQixJQUFNQyxPQUFPLFNBQUNDO3lCQUVaLG9CQUFDQztRQUFJQyxXQUFVO09BQ1poQjs7SUFLTCxXQUFlYTtBQUVmLFNBQVNWLGNBQWNjLEtBQUssRUFBRUMsT0FBTyxFQUFFO0lBQ3JDLElBQU1DLGlCQUFpQkQsUUFBUUUsaUJBQWlCLElBQzFDQyxtQkFBbUJILFFBQVFJLG1CQUFtQjtJQUVwREMsUUFBUUMsR0FBRyxDQUFDTCxnQkFBZ0JFO0FBQzlCO0FBRUEsU0FBU2hCLGNBQWNZLEtBQUssRUFBRUMsT0FBTyxFQUFFO0lBQ3JDLElBQU1PLFlBQVlQLFFBQVFRLFlBQVksSUFDaENDLGFBQWFULFFBQVFVLGFBQWE7SUFFeENMLFFBQVFDLEdBQUcsQ0FBQ0MsV0FBV0U7QUFDekI7QUFFQSxTQUFTcEIsYUFBYVUsS0FBSyxFQUFFQyxPQUFPLEVBQUU7SUFDcENLLFFBQVFDLEdBQUcsQ0FBQztBQUNkO0FBRUEsU0FBU2YsWUFBWVEsS0FBSyxFQUFFQyxPQUFPLEVBQUU7SUFDbkNLLFFBQVFDLEdBQUcsQ0FBQztBQUNkIn0=
|
package/lib/richTextarea.js
CHANGED
|
@@ -207,18 +207,19 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
207
207
|
var _this;
|
|
208
208
|
_this = _super.apply(this, arguments);
|
|
209
209
|
_defineProperty(_assertThisInitialized(_this), "intermediateHandler", function(event, element, eventType, forced) {
|
|
210
|
+
var readOnly = _this.isReadOnly();
|
|
211
|
+
if (readOnly) {
|
|
212
|
+
var previousContent = _this.getPreviousContent(), content = previousContent; ///
|
|
213
|
+
_this.setContent(content);
|
|
214
|
+
}
|
|
210
215
|
var changed = _this.hasChanged();
|
|
211
216
|
if (changed || forced) {
|
|
212
217
|
_this.callHandlers(eventType, event, element);
|
|
213
218
|
}
|
|
214
|
-
var
|
|
215
|
-
_this.setPreviousContent(
|
|
219
|
+
var content1 = _this.getContent(), selection = _this.getSelection(), previousContent1 = content1, previousSelection = selection; ///
|
|
220
|
+
_this.setPreviousContent(previousContent1);
|
|
216
221
|
_this.setPreviousSelection(previousSelection);
|
|
217
222
|
});
|
|
218
|
-
_defineProperty(_assertThisInitialized(_this), "mouseUpHandler", function(event, element) {
|
|
219
|
-
var mouseDown = false;
|
|
220
|
-
_this.setMouseDown(mouseDown);
|
|
221
|
-
});
|
|
222
223
|
_defineProperty(_assertThisInitialized(_this), "mouseDownHandler", function(event, element) {
|
|
223
224
|
var forced = false, mouseDown = true, eventType = CHANGE_EVENT_TYPE;
|
|
224
225
|
_this.setMouseDown(mouseDown);
|
|
@@ -232,6 +233,10 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
232
233
|
_this.intermediateHandler(event, element, eventTYpe, forced);
|
|
233
234
|
}
|
|
234
235
|
});
|
|
236
|
+
_defineProperty(_assertThisInitialized(_this), "mouseUpHandler", function(event, element) {
|
|
237
|
+
var mouseDown = false;
|
|
238
|
+
_this.setMouseDown(mouseDown);
|
|
239
|
+
});
|
|
235
240
|
_defineProperty(_assertThisInitialized(_this), "keyDownHandler", function(event, element) {
|
|
236
241
|
var forced = false, eventType = CHANGE_EVENT_TYPE;
|
|
237
242
|
defer(function() {
|
|
@@ -266,13 +271,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
266
271
|
return active;
|
|
267
272
|
}
|
|
268
273
|
},
|
|
269
|
-
{
|
|
270
|
-
key: "isReadOnly",
|
|
271
|
-
value: function isReadOnly() {
|
|
272
|
-
var domElement = this.getDOMElement(), readOnly = domElement.readOnly;
|
|
273
|
-
return readOnly;
|
|
274
|
-
}
|
|
275
|
-
},
|
|
276
274
|
{
|
|
277
275
|
key: "getContent",
|
|
278
276
|
value: function getContent() {
|
|
@@ -287,15 +285,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
287
285
|
return selection;
|
|
288
286
|
}
|
|
289
287
|
},
|
|
290
|
-
{
|
|
291
|
-
key: "setReadOnly",
|
|
292
|
-
value: function setReadOnly(readOnly) {
|
|
293
|
-
var domElement = this.getDOMElement();
|
|
294
|
-
Object.assign(domElement, {
|
|
295
|
-
readOnly: readOnly
|
|
296
|
-
});
|
|
297
|
-
}
|
|
298
|
-
},
|
|
299
288
|
{
|
|
300
289
|
key: "setContent",
|
|
301
290
|
value: function setContent(content) {
|
|
@@ -317,13 +306,6 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
317
306
|
this.setPreviousSelection(previousSelection);
|
|
318
307
|
}
|
|
319
308
|
},
|
|
320
|
-
{
|
|
321
|
-
key: "isMouseDown",
|
|
322
|
-
value: function isMouseDown() {
|
|
323
|
-
var state = this.getState(), mouseDown = state.mouseDown;
|
|
324
|
-
return mouseDown;
|
|
325
|
-
}
|
|
326
|
-
},
|
|
327
309
|
{
|
|
328
310
|
key: "hasChanged",
|
|
329
311
|
value: function hasChanged() {
|
|
@@ -454,20 +436,42 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
454
436
|
});
|
|
455
437
|
}
|
|
456
438
|
},
|
|
439
|
+
{
|
|
440
|
+
key: "isReadOnly",
|
|
441
|
+
value: function isReadOnly() {
|
|
442
|
+
var readOnly = this.getState().readOnly;
|
|
443
|
+
return readOnly;
|
|
444
|
+
}
|
|
445
|
+
},
|
|
446
|
+
{
|
|
447
|
+
key: "isMouseDown",
|
|
448
|
+
value: function isMouseDown() {
|
|
449
|
+
var mouseDown = this.getState().mouseDown;
|
|
450
|
+
return mouseDown;
|
|
451
|
+
}
|
|
452
|
+
},
|
|
457
453
|
{
|
|
458
454
|
key: "getPreviousContent",
|
|
459
455
|
value: function getPreviousContent() {
|
|
460
|
-
var
|
|
456
|
+
var previousContent = this.getState().previousContent;
|
|
461
457
|
return previousContent;
|
|
462
458
|
}
|
|
463
459
|
},
|
|
464
460
|
{
|
|
465
461
|
key: "getPreviousSelection",
|
|
466
462
|
value: function getPreviousSelection() {
|
|
467
|
-
var
|
|
463
|
+
var previousSelection = this.getState().previousSelection;
|
|
468
464
|
return previousSelection;
|
|
469
465
|
}
|
|
470
466
|
},
|
|
467
|
+
{
|
|
468
|
+
key: "setReadOnly",
|
|
469
|
+
value: function setReadOnly(readOnly) {
|
|
470
|
+
this.updateState({
|
|
471
|
+
readOnly: readOnly
|
|
472
|
+
});
|
|
473
|
+
}
|
|
474
|
+
},
|
|
471
475
|
{
|
|
472
476
|
key: "setMouseDown",
|
|
473
477
|
value: function setMouseDown(mouseDown) {
|
|
@@ -495,8 +499,9 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
495
499
|
{
|
|
496
500
|
key: "setInitialState",
|
|
497
501
|
value: function setInitialState() {
|
|
498
|
-
var mouseDown = false, previousContent = null, previousSelection = null;
|
|
502
|
+
var readOnly = false, mouseDown = false, previousContent = null, previousSelection = null;
|
|
499
503
|
this.setState({
|
|
504
|
+
readOnly: readOnly,
|
|
500
505
|
mouseDown: mouseDown,
|
|
501
506
|
previousContent: previousContent,
|
|
502
507
|
previousSelection: previousSelection
|
|
@@ -506,14 +511,14 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
506
511
|
{
|
|
507
512
|
key: "didMount",
|
|
508
513
|
value: function didMount() {
|
|
509
|
-
var _this_properties = this.properties,
|
|
514
|
+
var _this_properties = this.properties, onChange = _this_properties.onChange, onScroll = _this_properties.onScroll, onFocus = _this_properties.onFocus, onBlur = _this_properties.onBlur, changeHandler = onChange, scrollHandler = onScroll, focusHandler = onFocus, blurHandler = onBlur; ///
|
|
510
515
|
changeHandler && this.onChange(changeHandler, this);
|
|
511
516
|
scrollHandler && this.onScroll(scrollHandler, this);
|
|
512
517
|
focusHandler && this.onFocus(focusHandler, this);
|
|
513
518
|
blurHandler && this.onBlur(blurHandler, this);
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
519
|
+
var content = this.getContent(), selection = this.getSelection(), previousContent = content, previousSelection = selection; ///
|
|
520
|
+
this.setPreviousSelection(previousSelection);
|
|
521
|
+
this.setPreviousContent(previousContent);
|
|
517
522
|
}
|
|
518
523
|
},
|
|
519
524
|
{
|
|
@@ -524,6 +529,10 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
524
529
|
scrollHandler && this.offScroll(scrollHandler, this);
|
|
525
530
|
focusHandler && this.offFocus(focusHandler, this);
|
|
526
531
|
blurHandler && this.offBlur(blurHandler, this);
|
|
532
|
+
var active = this.isActive();
|
|
533
|
+
if (active) {
|
|
534
|
+
this.deactivate();
|
|
535
|
+
}
|
|
527
536
|
}
|
|
528
537
|
},
|
|
529
538
|
{
|
|
@@ -540,11 +549,10 @@ _defineProperty(RichTextarea, "ignoredProperties", [
|
|
|
540
549
|
"onChange",
|
|
541
550
|
"onScroll",
|
|
542
551
|
"onFocus",
|
|
543
|
-
"onBlur"
|
|
544
|
-
"active"
|
|
552
|
+
"onBlur"
|
|
545
553
|
]);
|
|
546
554
|
_defineProperty(RichTextarea, "defaultProperties", {
|
|
547
555
|
className: "rich"
|
|
548
556
|
});
|
|
549
557
|
|
|
550
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/richTextarea.js","<<jsx-config-pragma.js>>"],"sourcesContent":["\"use strict\";\r\n\r\nimport { window, Element, eventTypes } from \"easy\";\r\n\r\nimport Selection from \"./selection\"\r\n\r\nconst { BLUR_EVENT_TYPE,\r\n         INPUT_EVENT_TYPE,\r\n         FOCUS_EVENT_TYPE,\r\n         CHANGE_EVENT_TYPE,\r\n         SCROLL_EVENT_TYPE,\r\n         KEYDOWN_EVENT_TYPE,\r\n         MOUSEUP_EVENT_TYPE,\r\n         MOUSEDOWN_EVENT_TYPE,\r\n         MOUSEMOVE_EVENT_TYPE,\r\n         CONTEXTMENU_EVENT_TYPE } = eventTypes;\r\n\r\nconst defer = (func) => setTimeout(func, 1); ///\r\n\r\nexport default class RichTextarea extends Element {\r\n  intermediateHandler = (event, element, eventType, forced) => {\r\n    const changed = this.hasChanged();\r\n\r\n    if (changed || forced) {\r\n      this.callHandlers(eventType, event, element);\r\n    }\r\n\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    this.setPreviousSelection(previousSelection);\r\n  }\r\n\r\n  mouseUpHandler = (event, element) => {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n  };\r\n\r\n  mouseDownHandler = (event, element) => {\r\n    const forced = false,\r\n        mouseDown = true,\r\n        eventType = CHANGE_EVENT_TYPE;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  mouseMoveHandler = (event, element) => {\r\n    const forced = false,\r\n        mouseDown = this.isMouseDown(),\r\n        eventTYpe = CHANGE_EVENT_TYPE;\r\n\r\n    if (mouseDown) {\r\n      this.intermediateHandler(event, element, eventTYpe, forced);\r\n    }\r\n  }\r\n\r\n  keyDownHandler = (event, element) => {\r\n    const forced = false,\r\n        eventType = CHANGE_EVENT_TYPE;\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  inputHandler = (event, element) => {\r\n    const forced = false,\r\n        eventType = CHANGE_EVENT_TYPE;\r\n\r\n    this.intermediateHandler(event, element, eventType, forced);\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  focusHandler = (event, element) => {\r\n    const forced = true,\r\n        eventType = FOCUS_EVENT_TYPE;\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  blurHandler = (event, element) => {\r\n    const forced = true,\r\n        eventType = BLUR_EVENT_TYPE;\r\n\r\n    this.intermediateHandler(event, element, eventType, forced);\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  isReadOnly() {\r\n    const domElement = this.getDOMElement(),\r\n          { readOnly } = domElement;\r\n    \r\n    return readOnly; \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  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) {\r\n    const value = content,  ///\r\n          previousContent = content,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      value\r\n    });\r\n\r\n    this.setPreviousContent(previousContent);\r\n  }\r\n\r\n  setSelection(selection) {\r\n    const selectionStartPosition = selection.getStartPosition(),\r\n          selectionEndPosition = selection.getEndPosition(),\r\n          selectionStart = selectionStartPosition,  ///\r\n          selectionEnd = selectionEndPosition,  ///\r\n          previousSelection = selection,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      selectionStart,\r\n      selectionEnd\r\n    });\r\n\r\n    this.setPreviousSelection(previousSelection);\r\n  }\r\n\r\n  isMouseDown() {\r\n    const state = this.getState(),\r\n          { mouseDown } = state;\r\n\r\n    return mouseDown;\r\n  }\r\n\r\n  hasChanged() {\r\n    const contentChanged = this.hasContentChanged(),\r\n          selectionChanged = this.hasSelectionChanged(),\r\n          changed = (contentChanged || selectionChanged);\r\n\r\n    return changed;\r\n  }\r\n\r\n  hasContentChanged() {\r\n    const content = this.getContent(),\r\n          previousContent = this.getPreviousContent(),\r\n          contentDifferentToPreviousContent = (content !== previousContent),\r\n          contentChanged = contentDifferentToPreviousContent; ///\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          selectionDifferentToPreviousSelection = selection.isDifferentTo(previousSelection),\r\n          selectionChanged = selectionDifferentToPreviousSelection; ///\r\n\r\n    return selectionChanged;\r\n  }\r\n\r\n  activate() {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    window.on(`${BLUR_EVENT_TYPE} ${MOUSEUP_EVENT_TYPE} ${CONTEXTMENU_EVENT_TYPE}`, this.mouseUpHandler, this); ///\r\n\r\n    this.on(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler, this);\r\n\r\n    this.on(MOUSEMOVE_EVENT_TYPE, this.mouseMoveHandler, this);\r\n\r\n    this.on(KEYDOWN_EVENT_TYPE, this.keyDownHandler, this);\r\n\r\n    this.on(INPUT_EVENT_TYPE, this.inputHandler, this);\r\n\r\n    this.on(SCROLL_EVENT_TYPE, this.scrollHandler, this);\r\n\r\n    this.on(FOCUS_EVENT_TYPE, this.focusHandler, this);\r\n\r\n    this.on(BLUR_EVENT_TYPE, this.blurHandler, this);\r\n\r\n    this.addClass(\"active\");\r\n  }\r\n\r\n  deactivate() {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    window.off(`${BLUR_EVENT_TYPE} ${MOUSEUP_EVENT_TYPE} ${CONTEXTMENU_EVENT_TYPE}`, this.mouseUpHandler, this); ///\r\n\r\n    this.off(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler, this);\r\n\r\n    this.off(MOUSEMOVE_EVENT_TYPE, this.mouseMoveHandler, this);\r\n\r\n    this.off(KEYDOWN_EVENT_TYPE, this.keyDownHandler, this);\r\n\r\n    this.off(INPUT_EVENT_TYPE, this.inputHandler, this);\r\n\r\n    this.off(SCROLL_EVENT_TYPE, this.scrollHandler, this);\r\n\r\n    this.off(FOCUS_EVENT_TYPE, this.focusHandler, this);\r\n\r\n    this.off(BLUR_EVENT_TYPE, this.blurHandler, this);\r\n\r\n    this.removeClass(\"active\");\r\n  }\r\n\r\n  onBlur(blurHandler, element) {\r\n    const eventType = BLUR_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offBlur(blurHandler, element) {\r\n    const eventType = BLUR_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onFocus(blurHandler, element) {\r\n    const eventType = FOCUS_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offFocus(blurHandler, element) {\r\n    const eventType = FOCUS_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onScroll(scrollHandler, element) {\r\n    const eventType = SCROLL_EVENT_TYPE,\r\n          handler = scrollHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offScroll(scrollHandler, element) {\r\n    const eventType = SCROLL_EVENT_TYPE,\r\n          handler = scrollHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onChange(changeHandler, element) {\r\n    const eventType = CHANGE_EVENT_TYPE,\r\n          handler = changeHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offChange(changeHandler, element) {\r\n    const eventType = CHANGE_EVENT_TYPE,\r\n          handler = changeHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\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      const { handler, element: handlerElement } = eventListener,\r\n            element = this; ///\r\n\r\n      if ((handler !== this.blurHandler) && (handler !== this.focusHandler) && (handler !== this.scrollHandler)) {\r\n        handler.call(handlerElement, ...remainingArguments, element);\r\n      }\r\n    });\r\n  }\r\n\r\n  getPreviousContent() {\r\n    const state = this.getState(),\r\n          { previousContent } = state;\r\n\r\n    return previousContent;\r\n  }\r\n\r\n  getPreviousSelection() {\r\n    const state = this.getState(),\r\n          { previousSelection } = state;\r\n\r\n    return previousSelection;\r\n  }\r\n\r\n  setMouseDown(mouseDown) {\r\n    this.updateState({\r\n      mouseDown\r\n    });\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 mouseDown = false,\r\n          previousContent = null,\r\n          previousSelection = null;\r\n\r\n    this.setState({\r\n      mouseDown,\r\n      previousContent,\r\n      previousSelection\r\n    });\r\n  }\r\n\r\n  didMount() {\r\n    const { active, onChange, onScroll, onFocus, onBlur } = this.properties,\r\n            changeHandler = onChange, ///\r\n            scrollHandler = onScroll, ///\r\n            focusHandler = onFocus, ///\r\n            blurHandler = onBlur; ///\r\n\r\n    changeHandler && this.onChange(changeHandler, this);\r\n    scrollHandler && this.onScroll(scrollHandler, this);\r\n    focusHandler && this.onFocus(focusHandler, this);\r\n    blurHandler && this.onBlur(blurHandler, this);\r\n\r\n    if (active) {\r\n      this.activate();\r\n    }\r\n  }\r\n\r\n  willUnmount() {\r\n    const { onChange, onScroll, onFocus, onBlur } = this.properties,\r\n          changeHandler = onChange, ///\r\n          scrollHandler = onScroll, ///\r\n          focusHandler = onFocus, ///\r\n          blurHandler = onBlur; ///\r\n\r\n    changeHandler && this.offChange(changeHandler, this);\r\n    scrollHandler && this.offScroll(scrollHandler, this);\r\n    focusHandler && this.offFocus(focusHandler, this);\r\n    blurHandler && this.offBlur(blurHandler, 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 ignoredProperties = [\r\n    \"onChange\",\r\n    \"onScroll\",\r\n    \"onFocus\",\r\n    \"onBlur\",\r\n    \"active\"\r\n  ];\r\n\r\n  static defaultProperties = {\r\n    className: \"rich\"\r\n  };\r\n}\r\n","React.createElement"],"names":["RichTextarea","BLUR_EVENT_TYPE","eventTypes","INPUT_EVENT_TYPE","FOCUS_EVENT_TYPE","CHANGE_EVENT_TYPE","SCROLL_EVENT_TYPE","KEYDOWN_EVENT_TYPE","MOUSEUP_EVENT_TYPE","MOUSEDOWN_EVENT_TYPE","MOUSEMOVE_EVENT_TYPE","CONTEXTMENU_EVENT_TYPE","defer","func","setTimeout","intermediateHandler","event","element","eventType","forced","changed","hasChanged","callHandlers","content","getContent","selection","getSelection","previousContent","previousSelection","setPreviousContent","setPreviousSelection","mouseUpHandler","mouseDown","setMouseDown","mouseDownHandler","mouseMoveHandler","isMouseDown","eventTYpe","keyDownHandler","inputHandler","scrollHandler","focusHandler","blurHandler","isActive","active","hasClass","isReadOnly","domElement","getDOMElement","readOnly","value","Selection","fromDOMElement","setReadOnly","Object","assign","setContent","setSelection","selectionStartPosition","getStartPosition","selectionEndPosition","getEndPosition","selectionStart","selectionEnd","state","getState","contentChanged","hasContentChanged","selectionChanged","hasSelectionChanged","getPreviousContent","contentDifferentToPreviousContent","getPreviousSelection","selectionDifferentToPreviousSelection","isDifferentTo","activate","window","on","addClass","deactivate","off","removeClass","onBlur","handler","addEventListener","offBlur","removeEventListener","onFocus","offFocus","onScroll","offScroll","onChange","changeHandler","offChange","remainingArguments","eventListeners","findEventListeners","forEach","eventListener","handlerElement","call","updateState","setInitialState","setState","didMount","properties","willUnmount","initialise","Element","tagName","ignoredProperties","defaultProperties","className"],"mappings":"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"}
|
|
558
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/richTextarea.js","<<jsx-config-pragma.js>>"],"sourcesContent":["\"use strict\";\r\n\r\nimport { window, Element, eventTypes } from \"easy\";\r\n\r\nimport Selection from \"./selection\"\r\n\r\nconst { BLUR_EVENT_TYPE,\r\n         INPUT_EVENT_TYPE,\r\n         FOCUS_EVENT_TYPE,\r\n         CHANGE_EVENT_TYPE,\r\n         SCROLL_EVENT_TYPE,\r\n         KEYDOWN_EVENT_TYPE,\r\n         MOUSEUP_EVENT_TYPE,\r\n         MOUSEDOWN_EVENT_TYPE,\r\n         MOUSEMOVE_EVENT_TYPE,\r\n         CONTEXTMENU_EVENT_TYPE } = eventTypes;\r\n\r\nconst defer = (func) => setTimeout(func, 1); ///\r\n\r\nexport default class RichTextarea extends Element {\r\n  intermediateHandler = (event, element, eventType, forced) => {\r\n    const readOnly = this.isReadOnly();\r\n\r\n    if (readOnly) {\r\n      const previousContent = this.getPreviousContent(),\r\n            content = previousContent;  ///\r\n\r\n      this.setContent(content);\r\n    }\r\n\r\n    const changed = this.hasChanged();\r\n\r\n    if (changed || forced) {\r\n      this.callHandlers(eventType, event, element);\r\n    }\r\n\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    this.setPreviousSelection(previousSelection);\r\n  }\r\n\r\n  mouseDownHandler = (event, element) => {\r\n    const forced = false,\r\n          mouseDown = true,\r\n          eventType = CHANGE_EVENT_TYPE;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  mouseMoveHandler = (event, element) => {\r\n    const forced = false,\r\n          mouseDown = this.isMouseDown(),\r\n          eventTYpe = CHANGE_EVENT_TYPE;\r\n\r\n    if (mouseDown) {\r\n      this.intermediateHandler(event, element, eventTYpe, forced);\r\n    }\r\n  }\r\n\r\n  mouseUpHandler = (event, element) => {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n  };\r\n\r\n  keyDownHandler = (event, element) => {\r\n    const forced = false,\r\n          eventType = CHANGE_EVENT_TYPE;\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  inputHandler = (event, element) => {\r\n    const forced = false,\r\n          eventType = CHANGE_EVENT_TYPE;\r\n\r\n    this.intermediateHandler(event, element, eventType, forced);\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  focusHandler = (event, element) => {\r\n    const forced = true,\r\n          eventType = FOCUS_EVENT_TYPE;\r\n\r\n    defer(() => this.intermediateHandler(event, element, eventType, forced));\r\n  }\r\n\r\n  blurHandler = (event, element) => {\r\n    const forced = true,\r\n          eventType = BLUR_EVENT_TYPE;\r\n\r\n    this.intermediateHandler(event, element, eventType, forced);\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  setContent(content) {\r\n    const value = content,  ///\r\n          previousContent = content,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      value\r\n    });\r\n\r\n    this.setPreviousContent(previousContent);\r\n  }\r\n\r\n  setSelection(selection) {\r\n    const selectionStartPosition = selection.getStartPosition(),\r\n          selectionEndPosition = selection.getEndPosition(),\r\n          selectionStart = selectionStartPosition,  ///\r\n          selectionEnd = selectionEndPosition,  ///\r\n          previousSelection = selection,  ///\r\n          domElement = this.getDOMElement();\r\n\r\n    Object.assign(domElement, {\r\n      selectionStart,\r\n      selectionEnd\r\n    });\r\n\r\n    this.setPreviousSelection(previousSelection);\r\n  }\r\n\r\n  hasChanged() {\r\n    const contentChanged = this.hasContentChanged(),\r\n          selectionChanged = this.hasSelectionChanged(),\r\n          changed = (contentChanged || selectionChanged);\r\n\r\n    return changed;\r\n  }\r\n\r\n  hasContentChanged() {\r\n    const content = this.getContent(),\r\n          previousContent = this.getPreviousContent(),\r\n          contentDifferentToPreviousContent = (content !== previousContent),\r\n          contentChanged = contentDifferentToPreviousContent; ///\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          selectionDifferentToPreviousSelection = selection.isDifferentTo(previousSelection),\r\n          selectionChanged = selectionDifferentToPreviousSelection; ///\r\n\r\n    return selectionChanged;\r\n  }\r\n\r\n  activate() {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    window.on(`${BLUR_EVENT_TYPE} ${MOUSEUP_EVENT_TYPE} ${CONTEXTMENU_EVENT_TYPE}`, this.mouseUpHandler, this); ///\r\n\r\n    this.on(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler, this);\r\n\r\n    this.on(MOUSEMOVE_EVENT_TYPE, this.mouseMoveHandler, this);\r\n\r\n    this.on(KEYDOWN_EVENT_TYPE, this.keyDownHandler, this);\r\n\r\n    this.on(INPUT_EVENT_TYPE, this.inputHandler, this);\r\n\r\n    this.on(SCROLL_EVENT_TYPE, this.scrollHandler, this);\r\n\r\n    this.on(FOCUS_EVENT_TYPE, this.focusHandler, this);\r\n\r\n    this.on(BLUR_EVENT_TYPE, this.blurHandler, this);\r\n\r\n    this.addClass(\"active\");\r\n  }\r\n\r\n  deactivate() {\r\n    const mouseDown = false;\r\n\r\n    this.setMouseDown(mouseDown);\r\n\r\n    window.off(`${BLUR_EVENT_TYPE} ${MOUSEUP_EVENT_TYPE} ${CONTEXTMENU_EVENT_TYPE}`, this.mouseUpHandler, this); ///\r\n\r\n    this.off(MOUSEDOWN_EVENT_TYPE, this.mouseDownHandler, this);\r\n\r\n    this.off(MOUSEMOVE_EVENT_TYPE, this.mouseMoveHandler, this);\r\n\r\n    this.off(KEYDOWN_EVENT_TYPE, this.keyDownHandler, this);\r\n\r\n    this.off(INPUT_EVENT_TYPE, this.inputHandler, this);\r\n\r\n    this.off(SCROLL_EVENT_TYPE, this.scrollHandler, this);\r\n\r\n    this.off(FOCUS_EVENT_TYPE, this.focusHandler, this);\r\n\r\n    this.off(BLUR_EVENT_TYPE, this.blurHandler, this);\r\n\r\n    this.removeClass(\"active\");\r\n  }\r\n\r\n  onBlur(blurHandler, element) {\r\n    const eventType = BLUR_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offBlur(blurHandler, element) {\r\n    const eventType = BLUR_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onFocus(blurHandler, element) {\r\n    const eventType = FOCUS_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offFocus(blurHandler, element) {\r\n    const eventType = FOCUS_EVENT_TYPE,\r\n          handler = blurHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onScroll(scrollHandler, element) {\r\n    const eventType = SCROLL_EVENT_TYPE,\r\n          handler = scrollHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offScroll(scrollHandler, element) {\r\n    const eventType = SCROLL_EVENT_TYPE,\r\n          handler = scrollHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\r\n  }\r\n\r\n  onChange(changeHandler, element) {\r\n    const eventType = CHANGE_EVENT_TYPE,\r\n          handler = changeHandler;  ///\r\n\r\n    this.addEventListener(eventType, handler, element);\r\n  }\r\n\r\n  offChange(changeHandler, element) {\r\n    const eventType = CHANGE_EVENT_TYPE,\r\n          handler = changeHandler;  ///\r\n\r\n    this.removeEventListener(eventType, handler, element);\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      const { handler, element: handlerElement } = eventListener,\r\n            element = this; ///\r\n\r\n      if ((handler !== this.blurHandler) && (handler !== this.focusHandler) && (handler !== this.scrollHandler)) {\r\n        handler.call(handlerElement, ...remainingArguments, element);\r\n      }\r\n    });\r\n  }\r\n\r\n  isReadOnly() {\r\n    const { readOnly } = this.getState();\r\n\r\n    return readOnly;\r\n  }\r\n\r\n  isMouseDown() {\r\n    const { mouseDown } = this.getState();\r\n\r\n    return mouseDown;\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  setReadOnly(readOnly) {\r\n    this.updateState({\r\n      readOnly\r\n    });\r\n  }\r\n\r\n  setMouseDown(mouseDown) {\r\n    this.updateState({\r\n      mouseDown\r\n    });\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 readOnly = false,\r\n          mouseDown = false,\r\n          previousContent = null,\r\n          previousSelection = null;\r\n\r\n    this.setState({\r\n      readOnly,\r\n      mouseDown,\r\n      previousContent,\r\n      previousSelection\r\n    });\r\n  }\r\n\r\n  didMount() {\r\n    const { onChange, onScroll, onFocus, onBlur } = this.properties,\r\n            changeHandler = onChange, ///\r\n            scrollHandler = onScroll, ///\r\n            focusHandler = onFocus, ///\r\n            blurHandler = onBlur; ///\r\n\r\n    changeHandler && this.onChange(changeHandler, this);\r\n    scrollHandler && this.onScroll(scrollHandler, this);\r\n    focusHandler && this.onFocus(focusHandler, this);\r\n    blurHandler && this.onBlur(blurHandler, this);\r\n\r\n    const content = this.getContent(),\r\n          selection = this.getSelection(),\r\n          previousContent = content,  ///\r\n          previousSelection = selection;  ///\r\n\r\n    this.setPreviousSelection(previousSelection);\r\n\r\n    this.setPreviousContent(previousContent);\r\n  }\r\n\r\n  willUnmount() {\r\n    const { onChange, onScroll, onFocus, onBlur } = this.properties,\r\n          changeHandler = onChange, ///\r\n          scrollHandler = onScroll, ///\r\n          focusHandler = onFocus, ///\r\n          blurHandler = onBlur; ///\r\n\r\n    changeHandler && this.offChange(changeHandler, this);\r\n    scrollHandler && this.offScroll(scrollHandler, this);\r\n    focusHandler && this.offFocus(focusHandler, this);\r\n    blurHandler && this.offBlur(blurHandler, 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  initialise() {\r\n    this.setInitialState();\r\n  }\r\n\r\n  static tagName = \"textarea\";\r\n\r\n  static ignoredProperties = [\r\n    \"onChange\",\r\n    \"onScroll\",\r\n    \"onFocus\",\r\n    \"onBlur\"\r\n  ];\r\n\r\n  static defaultProperties = {\r\n    className: \"rich\"\r\n  };\r\n}\r\n","React.createElement"],"names":["RichTextarea","BLUR_EVENT_TYPE","eventTypes","INPUT_EVENT_TYPE","FOCUS_EVENT_TYPE","CHANGE_EVENT_TYPE","SCROLL_EVENT_TYPE","KEYDOWN_EVENT_TYPE","MOUSEUP_EVENT_TYPE","MOUSEDOWN_EVENT_TYPE","MOUSEMOVE_EVENT_TYPE","CONTEXTMENU_EVENT_TYPE","defer","func","setTimeout","intermediateHandler","event","element","eventType","forced","readOnly","isReadOnly","previousContent","getPreviousContent","content","setContent","changed","hasChanged","callHandlers","getContent","selection","getSelection","previousSelection","setPreviousContent","setPreviousSelection","mouseDownHandler","mouseDown","setMouseDown","mouseMoveHandler","isMouseDown","eventTYpe","mouseUpHandler","keyDownHandler","inputHandler","scrollHandler","focusHandler","blurHandler","isActive","active","hasClass","domElement","getDOMElement","value","Selection","fromDOMElement","Object","assign","setSelection","selectionStartPosition","getStartPosition","selectionEndPosition","getEndPosition","selectionStart","selectionEnd","contentChanged","hasContentChanged","selectionChanged","hasSelectionChanged","contentDifferentToPreviousContent","getPreviousSelection","selectionDifferentToPreviousSelection","isDifferentTo","activate","window","on","addClass","deactivate","off","removeClass","onBlur","handler","addEventListener","offBlur","removeEventListener","onFocus","offFocus","onScroll","offScroll","onChange","changeHandler","offChange","remainingArguments","eventListeners","findEventListeners","forEach","eventListener","handlerElement","call","getState","setReadOnly","updateState","setInitialState","setState","didMount","properties","willUnmount","initialise","Element","tagName","ignoredProperties","defaultProperties","className"],"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": "3.0.
|
|
4
|
+
"version": "3.0.148",
|
|
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/example/view.js
CHANGED
|
@@ -2,15 +2,25 @@
|
|
|
2
2
|
|
|
3
3
|
import RichTextarea from "./richTextarea";
|
|
4
4
|
|
|
5
|
+
const content = `Rule (blah)
|
|
6
|
+
Conclusion
|
|
7
|
+
A`,
|
|
8
|
+
readOnly = true,
|
|
9
|
+
richTextarea =
|
|
10
|
+
|
|
11
|
+
<RichTextarea onChange={changeHandler} onScroll={scrollHandler} onFocus={focusHandler} onBlur={blurHandler} />
|
|
12
|
+
|
|
13
|
+
;
|
|
14
|
+
|
|
15
|
+
richTextarea.setContent(content);
|
|
16
|
+
richTextarea.setReadOnly(readOnly);
|
|
17
|
+
|
|
18
|
+
richTextarea.activate();
|
|
19
|
+
|
|
5
20
|
const View = (properties) =>
|
|
6
21
|
|
|
7
22
|
<div className="view">
|
|
8
|
-
|
|
9
|
-
onScroll={scrollHandler}
|
|
10
|
-
onFocus={focusHandler}
|
|
11
|
-
onBlur={blurHandler}
|
|
12
|
-
active
|
|
13
|
-
/>
|
|
23
|
+
{richTextarea}
|
|
14
24
|
</div>
|
|
15
25
|
|
|
16
26
|
;
|
package/src/richTextarea.js
CHANGED
|
@@ -19,6 +19,15 @@ const defer = (func) => setTimeout(func, 1); ///
|
|
|
19
19
|
|
|
20
20
|
export default class RichTextarea extends Element {
|
|
21
21
|
intermediateHandler = (event, element, eventType, forced) => {
|
|
22
|
+
const readOnly = this.isReadOnly();
|
|
23
|
+
|
|
24
|
+
if (readOnly) {
|
|
25
|
+
const previousContent = this.getPreviousContent(),
|
|
26
|
+
content = previousContent; ///
|
|
27
|
+
|
|
28
|
+
this.setContent(content);
|
|
29
|
+
}
|
|
30
|
+
|
|
22
31
|
const changed = this.hasChanged();
|
|
23
32
|
|
|
24
33
|
if (changed || forced) {
|
|
@@ -34,16 +43,10 @@ export default class RichTextarea extends Element {
|
|
|
34
43
|
this.setPreviousSelection(previousSelection);
|
|
35
44
|
}
|
|
36
45
|
|
|
37
|
-
mouseUpHandler = (event, element) => {
|
|
38
|
-
const mouseDown = false;
|
|
39
|
-
|
|
40
|
-
this.setMouseDown(mouseDown);
|
|
41
|
-
};
|
|
42
|
-
|
|
43
46
|
mouseDownHandler = (event, element) => {
|
|
44
47
|
const forced = false,
|
|
45
|
-
|
|
46
|
-
|
|
48
|
+
mouseDown = true,
|
|
49
|
+
eventType = CHANGE_EVENT_TYPE;
|
|
47
50
|
|
|
48
51
|
this.setMouseDown(mouseDown);
|
|
49
52
|
|
|
@@ -52,24 +55,30 @@ export default class RichTextarea extends Element {
|
|
|
52
55
|
|
|
53
56
|
mouseMoveHandler = (event, element) => {
|
|
54
57
|
const forced = false,
|
|
55
|
-
|
|
56
|
-
|
|
58
|
+
mouseDown = this.isMouseDown(),
|
|
59
|
+
eventTYpe = CHANGE_EVENT_TYPE;
|
|
57
60
|
|
|
58
61
|
if (mouseDown) {
|
|
59
62
|
this.intermediateHandler(event, element, eventTYpe, forced);
|
|
60
63
|
}
|
|
61
64
|
}
|
|
62
65
|
|
|
66
|
+
mouseUpHandler = (event, element) => {
|
|
67
|
+
const mouseDown = false;
|
|
68
|
+
|
|
69
|
+
this.setMouseDown(mouseDown);
|
|
70
|
+
};
|
|
71
|
+
|
|
63
72
|
keyDownHandler = (event, element) => {
|
|
64
73
|
const forced = false,
|
|
65
|
-
|
|
74
|
+
eventType = CHANGE_EVENT_TYPE;
|
|
66
75
|
|
|
67
76
|
defer(() => this.intermediateHandler(event, element, eventType, forced));
|
|
68
77
|
}
|
|
69
78
|
|
|
70
79
|
inputHandler = (event, element) => {
|
|
71
80
|
const forced = false,
|
|
72
|
-
|
|
81
|
+
eventType = CHANGE_EVENT_TYPE;
|
|
73
82
|
|
|
74
83
|
this.intermediateHandler(event, element, eventType, forced);
|
|
75
84
|
}
|
|
@@ -82,14 +91,14 @@ export default class RichTextarea extends Element {
|
|
|
82
91
|
|
|
83
92
|
focusHandler = (event, element) => {
|
|
84
93
|
const forced = true,
|
|
85
|
-
|
|
94
|
+
eventType = FOCUS_EVENT_TYPE;
|
|
86
95
|
|
|
87
96
|
defer(() => this.intermediateHandler(event, element, eventType, forced));
|
|
88
97
|
}
|
|
89
98
|
|
|
90
99
|
blurHandler = (event, element) => {
|
|
91
100
|
const forced = true,
|
|
92
|
-
|
|
101
|
+
eventType = BLUR_EVENT_TYPE;
|
|
93
102
|
|
|
94
103
|
this.intermediateHandler(event, element, eventType, forced);
|
|
95
104
|
}
|
|
@@ -100,13 +109,6 @@ export default class RichTextarea extends Element {
|
|
|
100
109
|
return active;
|
|
101
110
|
}
|
|
102
111
|
|
|
103
|
-
isReadOnly() {
|
|
104
|
-
const domElement = this.getDOMElement(),
|
|
105
|
-
{ readOnly } = domElement;
|
|
106
|
-
|
|
107
|
-
return readOnly;
|
|
108
|
-
}
|
|
109
|
-
|
|
110
112
|
getContent() {
|
|
111
113
|
const domElement = this.getDOMElement(),
|
|
112
114
|
{ value } = domElement,
|
|
@@ -122,14 +124,6 @@ export default class RichTextarea extends Element {
|
|
|
122
124
|
return selection;
|
|
123
125
|
}
|
|
124
126
|
|
|
125
|
-
setReadOnly(readOnly) {
|
|
126
|
-
const domElement = this.getDOMElement();
|
|
127
|
-
|
|
128
|
-
Object.assign(domElement, {
|
|
129
|
-
readOnly
|
|
130
|
-
});
|
|
131
|
-
}
|
|
132
|
-
|
|
133
127
|
setContent(content) {
|
|
134
128
|
const value = content, ///
|
|
135
129
|
previousContent = content, ///
|
|
@@ -158,13 +152,6 @@ export default class RichTextarea extends Element {
|
|
|
158
152
|
this.setPreviousSelection(previousSelection);
|
|
159
153
|
}
|
|
160
154
|
|
|
161
|
-
isMouseDown() {
|
|
162
|
-
const state = this.getState(),
|
|
163
|
-
{ mouseDown } = state;
|
|
164
|
-
|
|
165
|
-
return mouseDown;
|
|
166
|
-
}
|
|
167
|
-
|
|
168
155
|
hasChanged() {
|
|
169
156
|
const contentChanged = this.hasContentChanged(),
|
|
170
157
|
selectionChanged = this.hasSelectionChanged(),
|
|
@@ -308,20 +295,36 @@ export default class RichTextarea extends Element {
|
|
|
308
295
|
});
|
|
309
296
|
}
|
|
310
297
|
|
|
298
|
+
isReadOnly() {
|
|
299
|
+
const { readOnly } = this.getState();
|
|
300
|
+
|
|
301
|
+
return readOnly;
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
isMouseDown() {
|
|
305
|
+
const { mouseDown } = this.getState();
|
|
306
|
+
|
|
307
|
+
return mouseDown;
|
|
308
|
+
}
|
|
309
|
+
|
|
311
310
|
getPreviousContent() {
|
|
312
|
-
const
|
|
313
|
-
{ previousContent } = state;
|
|
311
|
+
const { previousContent } = this.getState();
|
|
314
312
|
|
|
315
313
|
return previousContent;
|
|
316
314
|
}
|
|
317
315
|
|
|
318
316
|
getPreviousSelection() {
|
|
319
|
-
const
|
|
320
|
-
{ previousSelection } = state;
|
|
317
|
+
const { previousSelection } = this.getState();
|
|
321
318
|
|
|
322
319
|
return previousSelection;
|
|
323
320
|
}
|
|
324
321
|
|
|
322
|
+
setReadOnly(readOnly) {
|
|
323
|
+
this.updateState({
|
|
324
|
+
readOnly
|
|
325
|
+
});
|
|
326
|
+
}
|
|
327
|
+
|
|
325
328
|
setMouseDown(mouseDown) {
|
|
326
329
|
this.updateState({
|
|
327
330
|
mouseDown
|
|
@@ -341,11 +344,13 @@ export default class RichTextarea extends Element {
|
|
|
341
344
|
}
|
|
342
345
|
|
|
343
346
|
setInitialState() {
|
|
344
|
-
const
|
|
347
|
+
const readOnly = false,
|
|
348
|
+
mouseDown = false,
|
|
345
349
|
previousContent = null,
|
|
346
350
|
previousSelection = null;
|
|
347
351
|
|
|
348
352
|
this.setState({
|
|
353
|
+
readOnly,
|
|
349
354
|
mouseDown,
|
|
350
355
|
previousContent,
|
|
351
356
|
previousSelection
|
|
@@ -353,7 +358,7 @@ export default class RichTextarea extends Element {
|
|
|
353
358
|
}
|
|
354
359
|
|
|
355
360
|
didMount() {
|
|
356
|
-
const {
|
|
361
|
+
const { onChange, onScroll, onFocus, onBlur } = this.properties,
|
|
357
362
|
changeHandler = onChange, ///
|
|
358
363
|
scrollHandler = onScroll, ///
|
|
359
364
|
focusHandler = onFocus, ///
|
|
@@ -364,9 +369,14 @@ export default class RichTextarea extends Element {
|
|
|
364
369
|
focusHandler && this.onFocus(focusHandler, this);
|
|
365
370
|
blurHandler && this.onBlur(blurHandler, this);
|
|
366
371
|
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
372
|
+
const content = this.getContent(),
|
|
373
|
+
selection = this.getSelection(),
|
|
374
|
+
previousContent = content, ///
|
|
375
|
+
previousSelection = selection; ///
|
|
376
|
+
|
|
377
|
+
this.setPreviousSelection(previousSelection);
|
|
378
|
+
|
|
379
|
+
this.setPreviousContent(previousContent);
|
|
370
380
|
}
|
|
371
381
|
|
|
372
382
|
willUnmount() {
|
|
@@ -380,6 +390,12 @@ export default class RichTextarea extends Element {
|
|
|
380
390
|
scrollHandler && this.offScroll(scrollHandler, this);
|
|
381
391
|
focusHandler && this.offFocus(focusHandler, this);
|
|
382
392
|
blurHandler && this.offBlur(blurHandler, this);
|
|
393
|
+
|
|
394
|
+
const active = this.isActive();
|
|
395
|
+
|
|
396
|
+
if (active) {
|
|
397
|
+
this.deactivate();
|
|
398
|
+
}
|
|
383
399
|
}
|
|
384
400
|
|
|
385
401
|
initialise() {
|
|
@@ -392,8 +408,7 @@ export default class RichTextarea extends Element {
|
|
|
392
408
|
"onChange",
|
|
393
409
|
"onScroll",
|
|
394
410
|
"onFocus",
|
|
395
|
-
"onBlur"
|
|
396
|
-
"active"
|
|
411
|
+
"onBlur"
|
|
397
412
|
];
|
|
398
413
|
|
|
399
414
|
static defaultProperties = {
|