easy-richtextarea 4.0.214 → 4.0.216
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 +1837 -3947
- package/lib/richTextarea.js +12 -100
- package/package.json +3 -3
- package/src/richTextarea.js +10 -20
package/lib/richTextarea.js
CHANGED
|
@@ -12,14 +12,6 @@ var _easy = require("easy");
|
|
|
12
12
|
var _selection = /*#__PURE__*/ _interop_require_default(require("./selection"));
|
|
13
13
|
var _customEvent = /*#__PURE__*/ _interop_require_default(require("./mixins/customEvent"));
|
|
14
14
|
var _customEventTypes = require("./customEventTypes");
|
|
15
|
-
function _array_like_to_array(arr, len) {
|
|
16
|
-
if (len == null || len > arr.length) len = arr.length;
|
|
17
|
-
for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
|
|
18
|
-
return arr2;
|
|
19
|
-
}
|
|
20
|
-
function _array_without_holes(arr) {
|
|
21
|
-
if (Array.isArray(arr)) return _array_like_to_array(arr);
|
|
22
|
-
}
|
|
23
15
|
function _assert_this_initialized(self) {
|
|
24
16
|
if (self === void 0) {
|
|
25
17
|
throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
|
|
@@ -35,23 +27,6 @@ function _class_call_check(instance, Constructor) {
|
|
|
35
27
|
throw new TypeError("Cannot call a class as a function");
|
|
36
28
|
}
|
|
37
29
|
}
|
|
38
|
-
function _construct(Parent, args, Class) {
|
|
39
|
-
if (_is_native_reflect_construct()) {
|
|
40
|
-
_construct = Reflect.construct;
|
|
41
|
-
} else {
|
|
42
|
-
_construct = function construct(Parent, args, Class) {
|
|
43
|
-
var a = [
|
|
44
|
-
null
|
|
45
|
-
];
|
|
46
|
-
a.push.apply(a, args);
|
|
47
|
-
var Constructor = Function.bind.apply(Parent, a);
|
|
48
|
-
var instance = new Constructor();
|
|
49
|
-
if (Class) _set_prototype_of(instance, Class.prototype);
|
|
50
|
-
return instance;
|
|
51
|
-
};
|
|
52
|
-
}
|
|
53
|
-
return _construct.apply(null, arguments);
|
|
54
|
-
}
|
|
55
30
|
function _defineProperties(target, props) {
|
|
56
31
|
for(var i = 0; i < props.length; i++){
|
|
57
32
|
var descriptor = props[i];
|
|
@@ -103,15 +78,6 @@ function _interop_require_default(obj) {
|
|
|
103
78
|
default: obj
|
|
104
79
|
};
|
|
105
80
|
}
|
|
106
|
-
function _is_native_function(fn) {
|
|
107
|
-
return Function.toString.call(fn).indexOf("[native code]") !== -1;
|
|
108
|
-
}
|
|
109
|
-
function _iterable_to_array(iter) {
|
|
110
|
-
if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
|
|
111
|
-
}
|
|
112
|
-
function _non_iterable_spread() {
|
|
113
|
-
throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
114
|
-
}
|
|
115
81
|
function _possible_constructor_return(self, call) {
|
|
116
82
|
if (call && (_type_of(call) === "object" || typeof call === "function")) {
|
|
117
83
|
return call;
|
|
@@ -125,47 +91,10 @@ function _set_prototype_of(o, p) {
|
|
|
125
91
|
};
|
|
126
92
|
return _set_prototype_of(o, p);
|
|
127
93
|
}
|
|
128
|
-
function _to_consumable_array(arr) {
|
|
129
|
-
return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
|
|
130
|
-
}
|
|
131
94
|
function _type_of(obj) {
|
|
132
95
|
"@swc/helpers - typeof";
|
|
133
96
|
return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj;
|
|
134
97
|
}
|
|
135
|
-
function _unsupported_iterable_to_array(o, minLen) {
|
|
136
|
-
if (!o) return;
|
|
137
|
-
if (typeof o === "string") return _array_like_to_array(o, minLen);
|
|
138
|
-
var n = Object.prototype.toString.call(o).slice(8, -1);
|
|
139
|
-
if (n === "Object" && o.constructor) n = o.constructor.name;
|
|
140
|
-
if (n === "Map" || n === "Set") return Array.from(n);
|
|
141
|
-
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
|
|
142
|
-
}
|
|
143
|
-
function _wrap_native_super(Class) {
|
|
144
|
-
var _cache = typeof Map === "function" ? new Map() : undefined;
|
|
145
|
-
_wrap_native_super = function wrapNativeSuper(Class) {
|
|
146
|
-
if (Class === null || !_is_native_function(Class)) return Class;
|
|
147
|
-
if (typeof Class !== "function") {
|
|
148
|
-
throw new TypeError("Super expression must either be null or a function");
|
|
149
|
-
}
|
|
150
|
-
if (typeof _cache !== "undefined") {
|
|
151
|
-
if (_cache.has(Class)) return _cache.get(Class);
|
|
152
|
-
_cache.set(Class, Wrapper);
|
|
153
|
-
}
|
|
154
|
-
function Wrapper() {
|
|
155
|
-
return _construct(Class, arguments, _get_prototype_of(this).constructor);
|
|
156
|
-
}
|
|
157
|
-
Wrapper.prototype = Object.create(Class.prototype, {
|
|
158
|
-
constructor: {
|
|
159
|
-
value: Wrapper,
|
|
160
|
-
enumerable: false,
|
|
161
|
-
writable: true,
|
|
162
|
-
configurable: true
|
|
163
|
-
}
|
|
164
|
-
});
|
|
165
|
-
return _set_prototype_of(Wrapper, Class);
|
|
166
|
-
};
|
|
167
|
-
return _wrap_native_super(Class);
|
|
168
|
-
}
|
|
169
98
|
function _is_native_reflect_construct() {
|
|
170
99
|
try {
|
|
171
100
|
var result = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function() {}));
|
|
@@ -174,9 +103,8 @@ function _is_native_reflect_construct() {
|
|
|
174
103
|
return !!result;
|
|
175
104
|
})();
|
|
176
105
|
}
|
|
177
|
-
var
|
|
178
|
-
|
|
179
|
-
_inherits(RichTextarea, Element);
|
|
106
|
+
var RichTextarea = /*#__PURE__*/ function(Textarea) {
|
|
107
|
+
_inherits(RichTextarea, Textarea);
|
|
180
108
|
function RichTextarea() {
|
|
181
109
|
_class_call_check(this, RichTextarea);
|
|
182
110
|
var _this;
|
|
@@ -378,20 +306,20 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
378
306
|
var content = this.getContent(), selection = this.getSelection(), previousContent = content, previousSelection = selection; ///
|
|
379
307
|
this.setPreviousContent(previousContent);
|
|
380
308
|
this.setPreviousSelection(previousSelection);
|
|
381
|
-
this.
|
|
382
|
-
this.
|
|
383
|
-
this.
|
|
384
|
-
this.
|
|
309
|
+
this.onBlur(this.blurHandler);
|
|
310
|
+
this.onFocus(this.focusHandler);
|
|
311
|
+
this.onInput(this.inputHandler);
|
|
312
|
+
this.onScroll(this.scrollHandler);
|
|
385
313
|
_easy.document.onSelectionChange(this.selectionChangeHandler, this);
|
|
386
314
|
}
|
|
387
315
|
},
|
|
388
316
|
{
|
|
389
317
|
key: "willUnmount",
|
|
390
318
|
value: function willUnmount() {
|
|
391
|
-
this.
|
|
392
|
-
this.
|
|
393
|
-
this.
|
|
394
|
-
this.
|
|
319
|
+
this.offBlur(this.blurHandler);
|
|
320
|
+
this.offFocus(this.focusHandler);
|
|
321
|
+
this.offInput(this.inputHandler);
|
|
322
|
+
this.offScroll(this.scrollHandler);
|
|
395
323
|
_easy.document.offSelectionChange(this.selectionChangeHandler, this);
|
|
396
324
|
}
|
|
397
325
|
},
|
|
@@ -401,25 +329,9 @@ var RichTextarea = /*#__PURE__*/ function(Element) {
|
|
|
401
329
|
this.setInitialState();
|
|
402
330
|
}
|
|
403
331
|
}
|
|
404
|
-
], [
|
|
405
|
-
{
|
|
406
|
-
key: "fromClass",
|
|
407
|
-
value: function fromClass(Class, properties) {
|
|
408
|
-
for(var _len = arguments.length, remainingArguments = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++){
|
|
409
|
-
remainingArguments[_key - 2] = arguments[_key];
|
|
410
|
-
}
|
|
411
|
-
var _Element;
|
|
412
|
-
var richTextarea = (_Element = _easy.Element).fromClass.apply(_Element, [
|
|
413
|
-
Class,
|
|
414
|
-
properties
|
|
415
|
-
].concat(_to_consumable_array(remainingArguments)));
|
|
416
|
-
return richTextarea;
|
|
417
|
-
}
|
|
418
|
-
}
|
|
419
332
|
]);
|
|
420
333
|
return RichTextarea;
|
|
421
|
-
}(
|
|
422
|
-
_define_property(RichTextarea, "tagName", "textarea");
|
|
334
|
+
}(_easy.Textarea);
|
|
423
335
|
_define_property(RichTextarea, "defaultProperties", {
|
|
424
336
|
className: "rich"
|
|
425
337
|
});
|
|
@@ -428,4 +340,4 @@ function defer(func) {
|
|
|
428
340
|
setTimeout(func, 0);
|
|
429
341
|
}
|
|
430
342
|
|
|
431
|
-
//# 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 } 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  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  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  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  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\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  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  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\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","selectionChangeHandler","event","element","active","isActive","currentTarget","activeElement","domElement","getDOMElement","customEventType","CHANGE_CUSTOM_EVENT_TYPE","customHandler","scrollHandler","SCROLL_CUSTOM_EVENT_TYPE","forced","inputHandler","focusHandler","defer","addClass","FOCUS_CUSTOM_EVENT_TYPE","blurHandler","BLUR_CUSTOM_EVENT_TYPE","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","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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"}
|
|
343
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/richTextarea.js"],"sourcesContent":["\"use strict\";\r\n\r\nimport { Textarea, document } 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 } from \"./customEventTypes\";\r\n\r\nexport default class RichTextarea extends Textarea {\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  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  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  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\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  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  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\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.onBlur(this.blurHandler);\r\n\r\n    this.onFocus(this.focusHandler);\r\n\r\n    this.onInput(this.inputHandler);\r\n\r\n    this.onScroll(this.scrollHandler);\r\n\r\n    document.onSelectionChange(this.selectionChangeHandler, this);\r\n  }\r\n\r\n  willUnmount() {\r\n    this.offBlur(this.blurHandler);\r\n\r\n    this.offFocus(this.focusHandler);\r\n\r\n    this.offInput(this.inputHandler);\r\n\r\n    this.offScroll(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 defaultProperties = {\r\n    className: \"rich\"\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","selectionChangeHandler","event","element","active","isActive","currentTarget","activeElement","domElement","getDOMElement","customEventType","CHANGE_CUSTOM_EVENT_TYPE","customHandler","scrollHandler","SCROLL_CUSTOM_EVENT_TYPE","forced","inputHandler","focusHandler","defer","addClass","FOCUS_CUSTOM_EVENT_TYPE","blurHandler","BLUR_CUSTOM_EVENT_TYPE","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","getState","updateState","setInitialState","setState","didMount","onBlur","onFocus","onInput","onScroll","document","onSelectionChange","willUnmount","offBlur","offFocus","offInput","offScroll","offSelectionChange","initialise","Textarea","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.216",
|
|
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,11 +10,11 @@
|
|
|
10
10
|
"url": "https://github.com/djalbat/easy-richtextarea"
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"easy": "^
|
|
13
|
+
"easy": "^20.1.1"
|
|
14
14
|
},
|
|
15
15
|
"devDependencies": {
|
|
16
16
|
"@swc/core": "^1.5.6",
|
|
17
|
-
"easy-with-style": "^3.0.
|
|
17
|
+
"easy-with-style": "^3.0.398",
|
|
18
18
|
"esbuild": "^0.9.2",
|
|
19
19
|
"express": "^4.17.1",
|
|
20
20
|
"lively-cli": "^2.0.65",
|
package/src/richTextarea.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import {
|
|
3
|
+
import { Textarea, document } from "easy";
|
|
4
4
|
|
|
5
5
|
import Selection from "./selection"
|
|
6
6
|
import customEventMixins from "./mixins/customEvent";
|
|
@@ -10,9 +10,7 @@ import { BLUR_CUSTOM_EVENT_TYPE,
|
|
|
10
10
|
SCROLL_CUSTOM_EVENT_TYPE,
|
|
11
11
|
CHANGE_CUSTOM_EVENT_TYPE } from "./customEventTypes";
|
|
12
12
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
export default class RichTextarea extends Element {
|
|
13
|
+
export default class RichTextarea extends Textarea {
|
|
16
14
|
selectionChangeHandler = (event, element) => {
|
|
17
15
|
const active = this.isActive();
|
|
18
16
|
|
|
@@ -255,25 +253,25 @@ export default class RichTextarea extends Element {
|
|
|
255
253
|
|
|
256
254
|
this.setPreviousSelection(previousSelection);
|
|
257
255
|
|
|
258
|
-
this.
|
|
256
|
+
this.onBlur(this.blurHandler);
|
|
259
257
|
|
|
260
|
-
this.
|
|
258
|
+
this.onFocus(this.focusHandler);
|
|
261
259
|
|
|
262
|
-
this.
|
|
260
|
+
this.onInput(this.inputHandler);
|
|
263
261
|
|
|
264
|
-
this.
|
|
262
|
+
this.onScroll(this.scrollHandler);
|
|
265
263
|
|
|
266
264
|
document.onSelectionChange(this.selectionChangeHandler, this);
|
|
267
265
|
}
|
|
268
266
|
|
|
269
267
|
willUnmount() {
|
|
270
|
-
this.
|
|
268
|
+
this.offBlur(this.blurHandler);
|
|
271
269
|
|
|
272
|
-
this.
|
|
270
|
+
this.offFocus(this.focusHandler);
|
|
273
271
|
|
|
274
|
-
this.
|
|
272
|
+
this.offInput(this.inputHandler);
|
|
275
273
|
|
|
276
|
-
this.
|
|
274
|
+
this.offScroll(this.scrollHandler);
|
|
277
275
|
|
|
278
276
|
document.offSelectionChange(this.selectionChangeHandler, this);
|
|
279
277
|
}
|
|
@@ -282,17 +280,9 @@ export default class RichTextarea extends Element {
|
|
|
282
280
|
this.setInitialState();
|
|
283
281
|
}
|
|
284
282
|
|
|
285
|
-
static tagName = "textarea";
|
|
286
|
-
|
|
287
283
|
static defaultProperties = {
|
|
288
284
|
className: "rich"
|
|
289
285
|
};
|
|
290
|
-
|
|
291
|
-
static fromClass(Class, properties, ...remainingArguments) {
|
|
292
|
-
const richTextarea = Element.fromClass(Class, properties, ...remainingArguments);
|
|
293
|
-
|
|
294
|
-
return richTextarea;
|
|
295
|
-
}
|
|
296
286
|
}
|
|
297
287
|
|
|
298
288
|
Object.assign(RichTextarea.prototype, customEventMixins);
|