easy-richtextarea 4.0.16 → 4.0.18
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 +75 -70
- package/lib/operation/delete.js +13 -13
- package/lib/operation/empty.js +8 -8
- package/lib/operation/insert.js +13 -13
- package/lib/richTextarea.js +37 -32
- package/lib/selection.js +8 -8
- package/package.json +1 -1
- package/src/operation/delete.js +18 -18
- package/src/operation/empty.js +6 -6
- package/src/operation/insert.js +18 -18
- package/src/richTextarea.js +38 -34
- package/src/selection.js +11 -7
package/lib/selection.js
CHANGED
|
@@ -149,6 +149,13 @@ var Selection = /*#__PURE__*/ function() {
|
|
|
149
149
|
return selection;
|
|
150
150
|
}
|
|
151
151
|
},
|
|
152
|
+
{
|
|
153
|
+
key: "fromOperation",
|
|
154
|
+
value: function fromOperation(operation) {
|
|
155
|
+
var content = operation.getContent(), position = operation.getPosition(), contentLength = content.length, startPosition = position + contentLength, endPosition = startPosition, selection = new Selection(startPosition, endPosition);
|
|
156
|
+
return selection;
|
|
157
|
+
}
|
|
158
|
+
},
|
|
152
159
|
{
|
|
153
160
|
key: "fromSelection",
|
|
154
161
|
value: function fromSelection(selection) {
|
|
@@ -164,13 +171,6 @@ var Selection = /*#__PURE__*/ function() {
|
|
|
164
171
|
return selection;
|
|
165
172
|
}
|
|
166
173
|
},
|
|
167
|
-
{
|
|
168
|
-
key: "fromStartPosition",
|
|
169
|
-
value: function fromStartPosition(startPosition) {
|
|
170
|
-
var endPosition = startPosition, selection = new Selection(startPosition, endPosition);
|
|
171
|
-
return selection;
|
|
172
|
-
}
|
|
173
|
-
},
|
|
174
174
|
{
|
|
175
175
|
key: "fromStartPositionAndEndPosition",
|
|
176
176
|
value: function fromStartPositionAndEndPosition(startPosition, endPosition) {
|
|
@@ -182,4 +182,4 @@ var Selection = /*#__PURE__*/ function() {
|
|
|
182
182
|
return Selection;
|
|
183
183
|
}();
|
|
184
184
|
|
|
185
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/selection.js","<<jsx-config-pragma.js>>"],"sourcesContent":["\"use strict\";\n\nimport transformSelection from \"./transform/selection\";\n\nexport default class Selection {\n  constructor(startPosition, endPosition) {\n    this.startPosition = startPosition;\n    this.endPosition = endPosition;\n  }\n\n  getStartPosition() {\n    return this.startPosition;\n  }\n\n  getEndPosition() {\n    return this.endPosition;\n  }\n\n  isEmpty() {\n    const empty = (this.startPosition === this.endPosition);\n\n    return empty;\n  }\n\n  isEqualTo(selection) {\n    let equalTo = false;\n\n    if (selection !== null) {\n      const selectionStartPosition = selection.getStartPosition(),\n            selectionEndPosition = selection.getEndPosition(),\n            startPositionsEqual = (this.startPosition === selectionStartPosition),\n            endPositionsEqual = (this.endPosition === selectionEndPosition);\n\n      equalTo = (startPositionsEqual && endPositionsEqual);\n    }\n\n    return equalTo;\n  }\n\n  setStartPosition(startPosition) {\n    this.startPosition = startPosition;\n  }\n\n  setEndPosition(endPosition) {\n    this.endPosition = endPosition;\n  }\n\n  startPositionShifted(startOffset) {\n    const startPosition = this.startPosition + startOffset,\n          endPosition = this.endPosition,\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  endPositionShifted(endOffset) {\n    const startPosition = this.startPosition,\n          endPosition = this.endPosition + endOffset,\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  transformed(operations) {\n    const selection = this, ///\n          transformedSelection = transformSelection(selection, operations);\n\n    return transformedSelection;\n  }\n\n  shifted(offset) {\n    const startPosition = this.startPosition + offset,\n          endPosition = this.endPosition + offset,\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  emptied() {\n    const startPosition = this.startPosition,\n          endPosition = startPosition,  ///\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  clone() {\n    const selection = new Selection(this.startPosition, this.endPosition);\n\n    return selection;\n  }\n\n  toJSON() {\n    const startPosition = this.startPosition,\n          endPosition = this.endPosition,\n          json = {\n            startPosition,\n            endPosition\n          };\n\n    return json;\n  }\n\n  static fromJSON(json) {\n    const { startPosition, endPosition } = json,\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  static fromNothing() {\n    const startPosition = 0,\n          endPosition = 0,\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  static fromSelection(selection) {\n    const startPosition = selection.getStartPosition(),\n          endPosition = selection.getEndPosition();\n\n    selection = new Selection(startPosition, endPosition);  ///\n\n    return selection;\n  }\n\n  static fromDOMElement(domElement) {\n    const { selectionStart, selectionEnd } = domElement,\n          startPosition = selectionStart, ///\n          endPosition = selectionEnd, ///\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n\n  }\n\n  static fromStartPosition(startPosition) {\n    const endPosition = startPosition,  ///\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  static fromStartPositionAndEndPosition(startPosition, endPosition) {\n    const selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n}\n","React.createElement"],"names":["Selection","startPosition","endPosition","getStartPosition","getEndPosition","isEmpty","empty","isEqualTo","selection","equalTo","selectionStartPosition","selectionEndPosition","startPositionsEqual","endPositionsEqual","setStartPosition","setEndPosition","startPositionShifted","startOffset","endPositionShifted","endOffset","transformed","operations","transformedSelection","transformSelection","shifted","offset","emptied","clone","toJSON","json","fromJSON","fromNothing","fromSelection","fromDOMElement","domElement","selectionStart","selectionEnd","fromStartPosition","fromStartPositionAndEndPosition"],"mappings":"AAAA;;;;;;;eAIqBA;;;8DAFU;;;;;;;;;;;;;;;;;;;;;;;;;AAEhB,IAAA,AAAMA,0BAAN;aAAMA,UACPC,aAAa,EAAEC,WAAW;8BADnBF;QAEjB,IAAI,CAACC,aAAa,GAAGA;QACrB,IAAI,CAACC,WAAW,GAAGA;;iBAHFF;;YAMnBG,KAAAA;mBAAAA,SAAAA,mBAAmB;gBACjB,OAAO,IAAI,CAACF,aAAa;YAC3B;;;YAEAG,KAAAA;mBAAAA,SAAAA,iBAAiB;gBACf,OAAO,IAAI,CAACF,WAAW;YACzB;;;YAEAG,KAAAA;mBAAAA,SAAAA,UAAU;gBACR,IAAMC,QAAS,IAAI,CAACL,aAAa,KAAK,IAAI,CAACC,WAAW;gBAEtD,OAAOI;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA,UAAUC,SAAS,EAAE;gBACnB,IAAIC,UAAU,KAAK;gBAEnB,IAAID,cAAc,IAAI,EAAE;oBACtB,IAAME,yBAAyBF,UAAUL,gBAAgB,IACnDQ,uBAAuBH,UAAUJ,cAAc,IAC/CQ,sBAAuB,IAAI,CAACX,aAAa,KAAKS,wBAC9CG,oBAAqB,IAAI,CAACX,WAAW,KAAKS;oBAEhDF,UAAWG,uBAAuBC;gBACpC,CAAC;gBAED,OAAOJ;YACT;;;YAEAK,KAAAA;mBAAAA,SAAAA,iBAAiBb,aAAa,EAAE;gBAC9B,IAAI,CAACA,aAAa,GAAGA;YACvB;;;YAEAc,KAAAA;mBAAAA,SAAAA,eAAeb,WAAW,EAAE;gBAC1B,IAAI,CAACA,WAAW,GAAGA;YACrB;;;YAEAc,KAAAA;mBAAAA,SAAAA,qBAAqBC,WAAW,EAAE;gBAChC,IAAMhB,gBAAgB,IAAI,CAACA,aAAa,GAAGgB,aACrCf,cAAc,IAAI,CAACA,WAAW,EAC9BM,YAAY,IA9CDR,UA8CeC,eAAeC;gBAE/C,OAAOM;YACT;;;YAEAU,KAAAA;mBAAAA,SAAAA,mBAAmBC,SAAS,EAAE;gBAC5B,IAAMlB,gBAAgB,IAAI,CAACA,aAAa,EAClCC,cAAc,IAAI,CAACA,WAAW,GAAGiB,WACjCX,YAAY,IAtDDR,UAsDeC,eAAeC;gBAE/C,OAAOM;YACT;;;YAEAY,KAAAA;mBAAAA,SAAAA,YAAYC,UAAU,EAAE;gBACtB,IAAMb,YAAY,IAAI,EAChBc,uBAAuBC,IAAAA,kBAAkB,EAACf,WAAWa;gBAE3D,OAAOC;YACT;;;YAEAE,KAAAA;mBAAAA,SAAAA,QAAQC,MAAM,EAAE;gBACd,IAAMxB,gBAAgB,IAAI,CAACA,aAAa,GAAGwB,QACrCvB,cAAc,IAAI,CAACA,WAAW,GAAGuB,QACjCjB,YAAY,IArEDR,UAqEeC,eAAeC;gBAE/C,OAAOM;YACT;;;YAEAkB,KAAAA;mBAAAA,SAAAA,UAAU;gBACR,IAAMzB,gBAAgB,IAAI,CAACA,aAAa,EAClCC,cAAcD,eACdO,YAAY,IA7EDR,UA6EeC,eAAeC;gBAE/C,OAAOM;YACT;;;YAEAmB,KAAAA;mBAAAA,SAAAA,QAAQ;gBACN,IAAMnB,YAAY,IAnFDR,UAmFe,IAAI,CAACC,aAAa,EAAE,IAAI,CAACC,WAAW;gBAEpE,OAAOM;YACT;;;YAEAoB,KAAAA;mBAAAA,SAAAA,SAAS;gBACP,IAAM3B,gBAAgB,IAAI,CAACA,aAAa,EAClCC,cAAc,IAAI,CAACA,WAAW,EAC9B2B,OAAO;oBACL5B,eAAAA;oBACAC,aAAAA;gBACF;gBAEN,OAAO2B;YACT;;;;YAEOC,KAAAA;mBAAP,SAAOA,SAASD,IAAI,EAAE;gBACpB,IAAQ5B,gBAA+B4B,KAA/B5B,eAAeC,cAAgB2B,KAAhB3B,aACjBM,YAAY,IArGDR,UAqGeC,eAAeC;gBAE/C,OAAOM;YACT;;;YAEOuB,KAAAA;mBAAP,SAAOA,cAAc;gBACnB,IAAM9B,gBAAgB,GAChBC,cAAc,GACdM,YAAY,IA7GDR,UA6GeC,eAAeC;gBAE/C,OAAOM;YACT;;;YAEOwB,KAAAA;mBAAP,SAAOA,cAAcxB,SAAS,EAAE;gBAC9B,IAAMP,gBAAgBO,UAAUL,gBAAgB,IAC1CD,cAAcM,UAAUJ,cAAc;gBAE5CI,YAAY,IAtHKR,UAsHSC,eAAeC,cAAe,GAAG;gBAE3D,OAAOM;YACT;;;YAEOyB,KAAAA;mBAAP,SAAOA,eAAeC,UAAU,EAAE;gBAChC,IAAQC,iBAAiCD,WAAjCC,gBAAgBC,eAAiBF,WAAjBE,cAClBnC,gBAAgBkC,gBAChBjC,cAAckC,cACd5B,YAAY,IA/HDR,UA+HeC,eAAeC;gBAE/C,OAAOM;YAET;;;YAEO6B,KAAAA;mBAAP,SAAOA,kBAAkBpC,aAAa,EAAE;gBACtC,IAAMC,cAAcD,eACdO,YAAY,IAvIDR,UAuIeC,eAAeC;gBAE/C,OAAOM;YACT;;;YAEO8B,KAAAA;mBAAP,SAAOA,gCAAgCrC,aAAa,EAAEC,WAAW,EAAE;gBACjE,IAAMM,YAAY,IA7IDR,UA6IeC,eAAeC;gBAE/C,OAAOM;YACT;;;WAhJmBR"}
|
|
185
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/selection.js","<<jsx-config-pragma.js>>"],"sourcesContent":["\"use strict\";\n\nimport transformSelection from \"./transform/selection\";\n\nexport default class Selection {\n  constructor(startPosition, endPosition) {\n    this.startPosition = startPosition;\n    this.endPosition = endPosition;\n  }\n\n  getStartPosition() {\n    return this.startPosition;\n  }\n\n  getEndPosition() {\n    return this.endPosition;\n  }\n\n  isEmpty() {\n    const empty = (this.startPosition === this.endPosition);\n\n    return empty;\n  }\n\n  isEqualTo(selection) {\n    let equalTo = false;\n\n    if (selection !== null) {\n      const selectionStartPosition = selection.getStartPosition(),\n            selectionEndPosition = selection.getEndPosition(),\n            startPositionsEqual = (this.startPosition === selectionStartPosition),\n            endPositionsEqual = (this.endPosition === selectionEndPosition);\n\n      equalTo = (startPositionsEqual && endPositionsEqual);\n    }\n\n    return equalTo;\n  }\n\n  setStartPosition(startPosition) {\n    this.startPosition = startPosition;\n  }\n\n  setEndPosition(endPosition) {\n    this.endPosition = endPosition;\n  }\n\n  startPositionShifted(startOffset) {\n    const startPosition = this.startPosition + startOffset,\n          endPosition = this.endPosition,\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  endPositionShifted(endOffset) {\n    const startPosition = this.startPosition,\n          endPosition = this.endPosition + endOffset,\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  transformed(operations) {\n    const selection = this, ///\n          transformedSelection = transformSelection(selection, operations);\n\n    return transformedSelection;\n  }\n\n  shifted(offset) {\n    const startPosition = this.startPosition + offset,\n          endPosition = this.endPosition + offset,\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  emptied() {\n    const startPosition = this.startPosition,\n          endPosition = startPosition,  ///\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  clone() {\n    const selection = new Selection(this.startPosition, this.endPosition);\n\n    return selection;\n  }\n\n  toJSON() {\n    const startPosition = this.startPosition,\n          endPosition = this.endPosition,\n          json = {\n            startPosition,\n            endPosition\n          };\n\n    return json;\n  }\n\n  static fromJSON(json) {\n    const { startPosition, endPosition } = json,\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  static fromNothing() {\n    const startPosition = 0,\n          endPosition = 0,\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  static fromOperation(operation) {\n    const content = operation.getContent(),\n          position = operation.getPosition(),\n          contentLength = content.length,\n          startPosition = position + contentLength,\n          endPosition = startPosition,  ///\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n\n  static fromSelection(selection) {\n    const startPosition = selection.getStartPosition(),\n          endPosition = selection.getEndPosition();\n\n    selection = new Selection(startPosition, endPosition);  ///\n\n    return selection;\n  }\n\n  static fromDOMElement(domElement) {\n    const { selectionStart, selectionEnd } = domElement,\n          startPosition = selectionStart, ///\n          endPosition = selectionEnd, ///\n          selection = new Selection(startPosition, endPosition);\n\n    return selection;\n\n  }\n\n  static fromStartPositionAndEndPosition(startPosition, endPosition) {\n    const selection = new Selection(startPosition, endPosition);\n\n    return selection;\n  }\n}\n","React.createElement"],"names":["Selection","startPosition","endPosition","getStartPosition","getEndPosition","isEmpty","empty","isEqualTo","selection","equalTo","selectionStartPosition","selectionEndPosition","startPositionsEqual","endPositionsEqual","setStartPosition","setEndPosition","startPositionShifted","startOffset","endPositionShifted","endOffset","transformed","operations","transformedSelection","transformSelection","shifted","offset","emptied","clone","toJSON","json","fromJSON","fromNothing","fromOperation","operation","content","getContent","position","getPosition","contentLength","length","fromSelection","fromDOMElement","domElement","selectionStart","selectionEnd","fromStartPositionAndEndPosition"],"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.18",
|
|
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/operation/delete.js
CHANGED
|
@@ -23,6 +23,24 @@ export default class DeleteOperation {
|
|
|
23
23
|
return this.position;
|
|
24
24
|
}
|
|
25
25
|
|
|
26
|
+
transformContent(content) {
|
|
27
|
+
let start, end;
|
|
28
|
+
|
|
29
|
+
start = 0;
|
|
30
|
+
|
|
31
|
+
end = this.position;
|
|
32
|
+
|
|
33
|
+
const leftContent = content.substring(start, end),
|
|
34
|
+
contentLength = this.content.length;
|
|
35
|
+
|
|
36
|
+
start = this.position + contentLength;
|
|
37
|
+
|
|
38
|
+
const rightContent = content.substring(start),
|
|
39
|
+
transformedContent = leftContent + rightContent;
|
|
40
|
+
|
|
41
|
+
return transformedContent;
|
|
42
|
+
}
|
|
43
|
+
|
|
26
44
|
transformOperation(operation) {
|
|
27
45
|
const type = operation.getType();
|
|
28
46
|
|
|
@@ -98,24 +116,6 @@ export default class DeleteOperation {
|
|
|
98
116
|
}
|
|
99
117
|
}
|
|
100
118
|
|
|
101
|
-
transformContent(content) {
|
|
102
|
-
let start, end;
|
|
103
|
-
|
|
104
|
-
start = 0;
|
|
105
|
-
|
|
106
|
-
end = this.position;
|
|
107
|
-
|
|
108
|
-
const leftContent = content.substring(start, end),
|
|
109
|
-
contentLength = this.content.length;
|
|
110
|
-
|
|
111
|
-
start = this.position + contentLength;
|
|
112
|
-
|
|
113
|
-
const rightContent = content.substring(start),
|
|
114
|
-
transformedContent = leftContent + rightContent;
|
|
115
|
-
|
|
116
|
-
return transformedContent;
|
|
117
|
-
}
|
|
118
|
-
|
|
119
119
|
transformSelection(selection) {
|
|
120
120
|
let transformedSelection;
|
|
121
121
|
|
package/src/operation/empty.js
CHANGED
|
@@ -11,6 +11,12 @@ export default class EmptyOperation {
|
|
|
11
11
|
return this.type;
|
|
12
12
|
}
|
|
13
13
|
|
|
14
|
+
transformContent(content) {
|
|
15
|
+
const transformedContent = content; ///
|
|
16
|
+
|
|
17
|
+
return transformedContent;
|
|
18
|
+
}
|
|
19
|
+
|
|
14
20
|
transformOperation(operation) {
|
|
15
21
|
return ((tau, rho) => {
|
|
16
22
|
|
|
@@ -19,12 +25,6 @@ export default class EmptyOperation {
|
|
|
19
25
|
})(operation, this);
|
|
20
26
|
}
|
|
21
27
|
|
|
22
|
-
transformContent(content) {
|
|
23
|
-
const transformedContent = content; ///
|
|
24
|
-
|
|
25
|
-
return transformedContent;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
28
|
transformSelection(selection) {
|
|
29
29
|
const transformedSelection = selection.clone();
|
|
30
30
|
|
package/src/operation/insert.js
CHANGED
|
@@ -24,6 +24,24 @@ export default class InsertOperation {
|
|
|
24
24
|
return this.position;
|
|
25
25
|
}
|
|
26
26
|
|
|
27
|
+
transformContent(content) {
|
|
28
|
+
let start,
|
|
29
|
+
end;
|
|
30
|
+
|
|
31
|
+
start = 0;
|
|
32
|
+
|
|
33
|
+
end = this.position;
|
|
34
|
+
|
|
35
|
+
const leftContent = content.substring(start, end);
|
|
36
|
+
|
|
37
|
+
start = this.position;
|
|
38
|
+
|
|
39
|
+
const rightContent = content.substring(start),
|
|
40
|
+
transformedContent = leftContent + this.content + rightContent;
|
|
41
|
+
|
|
42
|
+
return transformedContent;
|
|
43
|
+
}
|
|
44
|
+
|
|
27
45
|
transformOperation(operation) {
|
|
28
46
|
const type = operation.getType();
|
|
29
47
|
|
|
@@ -81,24 +99,6 @@ export default class InsertOperation {
|
|
|
81
99
|
}
|
|
82
100
|
}
|
|
83
101
|
|
|
84
|
-
transformContent(content) {
|
|
85
|
-
let start,
|
|
86
|
-
end;
|
|
87
|
-
|
|
88
|
-
start = 0;
|
|
89
|
-
|
|
90
|
-
end = this.position;
|
|
91
|
-
|
|
92
|
-
const leftContent = content.substring(start, end);
|
|
93
|
-
|
|
94
|
-
start = this.position;
|
|
95
|
-
|
|
96
|
-
const rightContent = content.substring(start),
|
|
97
|
-
transformedContent = leftContent + this.content + rightContent;
|
|
98
|
-
|
|
99
|
-
return transformedContent;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
102
|
transformSelection(selection) {
|
|
103
103
|
let transformedSelection;
|
|
104
104
|
|
package/src/richTextarea.js
CHANGED
|
@@ -241,30 +241,6 @@ export default class RichTextarea extends Element {
|
|
|
241
241
|
return active;
|
|
242
242
|
}
|
|
243
243
|
|
|
244
|
-
undo(event, element) {
|
|
245
|
-
const operation = this.undoBuffer.undo();
|
|
246
|
-
|
|
247
|
-
if (operation !== null) {
|
|
248
|
-
const undoable = false;
|
|
249
|
-
|
|
250
|
-
this.applyOperation(operation);
|
|
251
|
-
|
|
252
|
-
this.intermediateHandler(event, element, undoable);
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
|
|
256
|
-
redo(event, element) {
|
|
257
|
-
const operation = this.undoBuffer.redo();
|
|
258
|
-
|
|
259
|
-
if (operation !== null) {
|
|
260
|
-
const undoable = false;
|
|
261
|
-
|
|
262
|
-
this.applyOperation(operation);
|
|
263
|
-
|
|
264
|
-
this.intermediateHandler(event, element, undoable);
|
|
265
|
-
}
|
|
266
|
-
}
|
|
267
|
-
|
|
268
244
|
getContent() {
|
|
269
245
|
const domElement = this.getDOMElement(),
|
|
270
246
|
{ value } = domElement,
|
|
@@ -335,23 +311,32 @@ export default class RichTextarea extends Element {
|
|
|
335
311
|
}
|
|
336
312
|
}
|
|
337
313
|
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
selection = this.getSelection();
|
|
314
|
+
undo(event, element) {
|
|
315
|
+
const operation = this.undoBuffer.undo();
|
|
341
316
|
|
|
342
|
-
|
|
343
|
-
|
|
317
|
+
if (operation !== null) {
|
|
318
|
+
this.revert(event, element, operation);
|
|
319
|
+
}
|
|
320
|
+
}
|
|
344
321
|
|
|
345
|
-
|
|
322
|
+
redo(event, element) {
|
|
323
|
+
const operation = this.undoBuffer.redo();
|
|
346
324
|
|
|
347
|
-
|
|
325
|
+
if (operation !== null) {
|
|
326
|
+
this.revert(event, element, operation);
|
|
327
|
+
}
|
|
328
|
+
}
|
|
348
329
|
|
|
349
|
-
|
|
330
|
+
revert(event, element, operation) {
|
|
331
|
+
const undoable = false,
|
|
332
|
+
selection = Selection.fromOperation(operation),
|
|
350
333
|
setPreviousSelection = false;
|
|
351
334
|
|
|
352
|
-
this.
|
|
335
|
+
this.applyOperation(operation);
|
|
353
336
|
|
|
354
337
|
this.setSelection(selection, setPreviousSelection);
|
|
338
|
+
|
|
339
|
+
this.intermediateHandler(event, element, undoable);
|
|
355
340
|
}
|
|
356
341
|
|
|
357
342
|
transform(operations) {
|
|
@@ -372,7 +357,7 @@ export default class RichTextarea extends Element {
|
|
|
372
357
|
|
|
373
358
|
this.setSelection(selection, setPreviousSelection);
|
|
374
359
|
|
|
375
|
-
this.undoBuffer.transform(
|
|
360
|
+
this.undoBuffer.transform(operations);
|
|
376
361
|
|
|
377
362
|
const event = null,
|
|
378
363
|
element = this,
|
|
@@ -382,6 +367,25 @@ export default class RichTextarea extends Element {
|
|
|
382
367
|
this.intermediateHandler(event, element, undoable, eventType);
|
|
383
368
|
}
|
|
384
369
|
|
|
370
|
+
applyOperation(operation) {
|
|
371
|
+
let content = this.getContent(),
|
|
372
|
+
selection = this.getSelection();
|
|
373
|
+
|
|
374
|
+
const transformedContent = operation.transformContent(content),
|
|
375
|
+
transformedSelection = operation.transformSelection(selection);
|
|
376
|
+
|
|
377
|
+
content = transformedContent; ///
|
|
378
|
+
|
|
379
|
+
selection = transformedSelection; ///
|
|
380
|
+
|
|
381
|
+
const setPreviousContent = false,
|
|
382
|
+
setPreviousSelection = false;
|
|
383
|
+
|
|
384
|
+
this.setContent(content, setPreviousContent);
|
|
385
|
+
|
|
386
|
+
this.setSelection(selection, setPreviousSelection);
|
|
387
|
+
}
|
|
388
|
+
|
|
385
389
|
activate() {
|
|
386
390
|
this.on(KEYDOWN_EVENT_TYPE, this.keyDownHandler, this);
|
|
387
391
|
|
package/src/selection.js
CHANGED
|
@@ -116,6 +116,17 @@ export default class Selection {
|
|
|
116
116
|
return selection;
|
|
117
117
|
}
|
|
118
118
|
|
|
119
|
+
static fromOperation(operation) {
|
|
120
|
+
const content = operation.getContent(),
|
|
121
|
+
position = operation.getPosition(),
|
|
122
|
+
contentLength = content.length,
|
|
123
|
+
startPosition = position + contentLength,
|
|
124
|
+
endPosition = startPosition, ///
|
|
125
|
+
selection = new Selection(startPosition, endPosition);
|
|
126
|
+
|
|
127
|
+
return selection;
|
|
128
|
+
}
|
|
129
|
+
|
|
119
130
|
static fromSelection(selection) {
|
|
120
131
|
const startPosition = selection.getStartPosition(),
|
|
121
132
|
endPosition = selection.getEndPosition();
|
|
@@ -135,13 +146,6 @@ export default class Selection {
|
|
|
135
146
|
|
|
136
147
|
}
|
|
137
148
|
|
|
138
|
-
static fromStartPosition(startPosition) {
|
|
139
|
-
const endPosition = startPosition, ///
|
|
140
|
-
selection = new Selection(startPosition, endPosition);
|
|
141
|
-
|
|
142
|
-
return selection;
|
|
143
|
-
}
|
|
144
|
-
|
|
145
149
|
static fromStartPositionAndEndPosition(startPosition, endPosition) {
|
|
146
150
|
const selection = new Selection(startPosition, endPosition);
|
|
147
151
|
|