@ckeditor/ckeditor5-engine 35.0.1 → 35.2.0

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.
Files changed (124) hide show
  1. package/CHANGELOG.md +4 -4
  2. package/package.json +30 -24
  3. package/src/controller/datacontroller.js +467 -561
  4. package/src/controller/editingcontroller.js +168 -204
  5. package/src/conversion/conversion.js +541 -565
  6. package/src/conversion/conversionhelpers.js +24 -28
  7. package/src/conversion/downcastdispatcher.js +457 -686
  8. package/src/conversion/downcasthelpers.js +1583 -1965
  9. package/src/conversion/mapper.js +518 -707
  10. package/src/conversion/modelconsumable.js +240 -283
  11. package/src/conversion/upcastdispatcher.js +372 -718
  12. package/src/conversion/upcasthelpers.js +707 -818
  13. package/src/conversion/viewconsumable.js +524 -581
  14. package/src/dataprocessor/basichtmlwriter.js +12 -16
  15. package/src/dataprocessor/dataprocessor.js +5 -0
  16. package/src/dataprocessor/htmldataprocessor.js +100 -116
  17. package/src/dataprocessor/htmlwriter.js +1 -18
  18. package/src/dataprocessor/xmldataprocessor.js +116 -137
  19. package/src/dev-utils/model.js +260 -352
  20. package/src/dev-utils/operationreplayer.js +106 -126
  21. package/src/dev-utils/utils.js +34 -51
  22. package/src/dev-utils/view.js +632 -753
  23. package/src/index.js +0 -11
  24. package/src/model/batch.js +111 -127
  25. package/src/model/differ.js +988 -1233
  26. package/src/model/document.js +340 -449
  27. package/src/model/documentfragment.js +327 -364
  28. package/src/model/documentselection.js +996 -1189
  29. package/src/model/element.js +306 -410
  30. package/src/model/history.js +224 -262
  31. package/src/model/item.js +5 -0
  32. package/src/model/liveposition.js +84 -145
  33. package/src/model/liverange.js +108 -185
  34. package/src/model/markercollection.js +379 -480
  35. package/src/model/model.js +883 -1034
  36. package/src/model/node.js +419 -463
  37. package/src/model/nodelist.js +176 -201
  38. package/src/model/operation/attributeoperation.js +153 -182
  39. package/src/model/operation/detachoperation.js +64 -83
  40. package/src/model/operation/insertoperation.js +135 -166
  41. package/src/model/operation/markeroperation.js +114 -140
  42. package/src/model/operation/mergeoperation.js +163 -191
  43. package/src/model/operation/moveoperation.js +157 -187
  44. package/src/model/operation/nooperation.js +28 -38
  45. package/src/model/operation/operation.js +106 -125
  46. package/src/model/operation/operationfactory.js +30 -34
  47. package/src/model/operation/renameoperation.js +109 -135
  48. package/src/model/operation/rootattributeoperation.js +155 -188
  49. package/src/model/operation/splitoperation.js +196 -232
  50. package/src/model/operation/transform.js +1833 -2204
  51. package/src/model/operation/utils.js +140 -204
  52. package/src/model/position.js +980 -1053
  53. package/src/model/range.js +910 -1028
  54. package/src/model/rootelement.js +77 -97
  55. package/src/model/schema.js +1189 -1835
  56. package/src/model/selection.js +745 -862
  57. package/src/model/text.js +90 -114
  58. package/src/model/textproxy.js +204 -240
  59. package/src/model/treewalker.js +316 -397
  60. package/src/model/typecheckable.js +16 -0
  61. package/src/model/utils/autoparagraphing.js +32 -44
  62. package/src/model/utils/deletecontent.js +334 -418
  63. package/src/model/utils/findoptimalinsertionrange.js +25 -36
  64. package/src/model/utils/getselectedcontent.js +96 -118
  65. package/src/model/utils/insertcontent.js +757 -773
  66. package/src/model/utils/insertobject.js +96 -119
  67. package/src/model/utils/modifyselection.js +120 -158
  68. package/src/model/utils/selection-post-fixer.js +153 -201
  69. package/src/model/writer.js +1305 -1474
  70. package/src/view/attributeelement.js +189 -225
  71. package/src/view/containerelement.js +75 -85
  72. package/src/view/document.js +172 -215
  73. package/src/view/documentfragment.js +200 -249
  74. package/src/view/documentselection.js +338 -367
  75. package/src/view/domconverter.js +1370 -1617
  76. package/src/view/downcastwriter.js +1747 -2076
  77. package/src/view/editableelement.js +81 -97
  78. package/src/view/element.js +739 -890
  79. package/src/view/elementdefinition.js +5 -0
  80. package/src/view/emptyelement.js +82 -92
  81. package/src/view/filler.js +35 -50
  82. package/src/view/item.js +5 -0
  83. package/src/view/matcher.js +260 -559
  84. package/src/view/node.js +274 -360
  85. package/src/view/observer/arrowkeysobserver.js +19 -28
  86. package/src/view/observer/bubblingemittermixin.js +120 -263
  87. package/src/view/observer/bubblingeventinfo.js +47 -55
  88. package/src/view/observer/clickobserver.js +7 -13
  89. package/src/view/observer/compositionobserver.js +14 -24
  90. package/src/view/observer/domeventdata.js +57 -67
  91. package/src/view/observer/domeventobserver.js +40 -64
  92. package/src/view/observer/fakeselectionobserver.js +81 -96
  93. package/src/view/observer/focusobserver.js +45 -61
  94. package/src/view/observer/inputobserver.js +7 -13
  95. package/src/view/observer/keyobserver.js +17 -27
  96. package/src/view/observer/mouseobserver.js +7 -14
  97. package/src/view/observer/mutationobserver.js +220 -315
  98. package/src/view/observer/observer.js +81 -102
  99. package/src/view/observer/selectionobserver.js +199 -246
  100. package/src/view/observer/tabobserver.js +23 -36
  101. package/src/view/placeholder.js +128 -173
  102. package/src/view/position.js +350 -401
  103. package/src/view/range.js +453 -513
  104. package/src/view/rawelement.js +85 -112
  105. package/src/view/renderer.js +874 -1018
  106. package/src/view/rooteditableelement.js +80 -90
  107. package/src/view/selection.js +608 -689
  108. package/src/view/styles/background.js +43 -44
  109. package/src/view/styles/border.js +220 -276
  110. package/src/view/styles/margin.js +8 -17
  111. package/src/view/styles/padding.js +8 -16
  112. package/src/view/styles/utils.js +127 -160
  113. package/src/view/stylesmap.js +728 -905
  114. package/src/view/text.js +102 -126
  115. package/src/view/textproxy.js +144 -170
  116. package/src/view/treewalker.js +383 -479
  117. package/src/view/typecheckable.js +19 -0
  118. package/src/view/uielement.js +166 -187
  119. package/src/view/upcastwriter.js +395 -449
  120. package/src/view/view.js +569 -664
  121. package/src/dataprocessor/dataprocessor.jsdoc +0 -64
  122. package/src/model/item.jsdoc +0 -14
  123. package/src/view/elementdefinition.jsdoc +0 -59
  124. package/src/view/item.jsdoc +0 -14
@@ -2,13 +2,10 @@
2
2
  * @license Copyright (c) 2003-2022, CKSource Holding sp. z o.o. All rights reserved.
3
3
  * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
4
  */
5
-
6
5
  /**
7
6
  * @module engine/view/observer/compositionobserver
8
7
  */
9
-
10
8
  import DomEventObserver from './domeventobserver';
11
-
12
9
  /**
13
10
  * {@link module:engine/view/document~Document#event:compositionstart Compositionstart},
14
11
  * {@link module:engine/view/document~Document#event:compositionupdate compositionupdate} and
@@ -19,26 +16,21 @@ import DomEventObserver from './domeventobserver';
19
16
  * @extends module:engine/view/observer/domeventobserver~DomEventObserver
20
17
  */
21
18
  export default class CompositionObserver extends DomEventObserver {
22
- constructor( view ) {
23
- super( view );
24
-
25
- this.domEventType = [ 'compositionstart', 'compositionupdate', 'compositionend' ];
26
- const document = this.document;
27
-
28
- document.on( 'compositionstart', () => {
29
- document.isComposing = true;
30
- } );
31
-
32
- document.on( 'compositionend', () => {
33
- document.isComposing = false;
34
- } );
35
- }
36
-
37
- onDomEvent( domEvent ) {
38
- this.fire( domEvent.type, domEvent );
39
- }
19
+ constructor(view) {
20
+ super(view);
21
+ this.domEventType = ['compositionstart', 'compositionupdate', 'compositionend'];
22
+ const document = this.document;
23
+ document.on('compositionstart', () => {
24
+ document.isComposing = true;
25
+ });
26
+ document.on('compositionend', () => {
27
+ document.isComposing = false;
28
+ });
29
+ }
30
+ onDomEvent(domEvent) {
31
+ this.fire(domEvent.type, domEvent);
32
+ }
40
33
  }
41
-
42
34
  /**
43
35
  * Fired when composition starts inside one of the editables.
44
36
  *
@@ -51,7 +43,6 @@ export default class CompositionObserver extends DomEventObserver {
51
43
  * @event module:engine/view/document~Document#event:compositionstart
52
44
  * @param {module:engine/view/observer/domeventdata~DomEventData} data Event data.
53
45
  */
54
-
55
46
  /**
56
47
  * Fired when composition is updated inside one of the editables.
57
48
  *
@@ -64,7 +55,6 @@ export default class CompositionObserver extends DomEventObserver {
64
55
  * @event module:engine/view/document~Document#event:compositionupdate
65
56
  * @param {module:engine/view/observer/domeventdata~DomEventData} data Event data.
66
57
  */
67
-
68
58
  /**
69
59
  * Fired when composition ends inside one of the editables.
70
60
  *
@@ -2,81 +2,71 @@
2
2
  * @license Copyright (c) 2003-2022, CKSource Holding sp. z o.o. All rights reserved.
3
3
  * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
4
  */
5
-
6
5
  /**
7
6
  * @module engine/view/observer/domeventdata
8
7
  */
9
-
10
8
  import { extend } from 'lodash-es';
11
-
12
9
  /**
13
10
  * Information about a DOM event in context of the {@link module:engine/view/document~Document}.
14
11
  * It wraps the native event, which usually should not be used as the wrapper contains
15
12
  * additional data (like key code for keyboard events).
16
13
  */
17
14
  export default class DomEventData {
18
- /**
19
- * @param {module:engine/view/view~View} view The instance of the view controller.
20
- * @param {Event} domEvent The DOM event.
21
- * @param {Object} [additionalData] Additional properties that the instance should contain.
22
- */
23
- constructor( view, domEvent, additionalData ) {
24
- /**
25
- * Instance of the view controller.
26
- *
27
- * @readonly
28
- * @member {module:engine/view/view~View} module:engine/view/observer/observer~Observer.DomEvent#view
29
- */
30
- this.view = view;
31
-
32
- /**
33
- * The instance of the document.
34
- *
35
- * @readonly
36
- * @member {module:engine/view/document~Document} module:engine/view/observer/observer~Observer.DomEvent#document
37
- */
38
- this.document = view.document;
39
-
40
- /**
41
- * The DOM event.
42
- *
43
- * @readonly
44
- * @member {Event} module:engine/view/observer/observer~Observer.DomEvent#domEvent
45
- */
46
- this.domEvent = domEvent;
47
-
48
- /**
49
- * The DOM target.
50
- *
51
- * @readonly
52
- * @member {HTMLElement} module:engine/view/observer/observer~Observer.DomEvent#target
53
- */
54
- this.domTarget = domEvent.target;
55
-
56
- extend( this, additionalData );
57
- }
58
-
59
- /**
60
- * The tree view element representing the target.
61
- *
62
- * @readonly
63
- * @type module:engine/view/element~Element
64
- */
65
- get target() {
66
- return this.view.domConverter.mapDomToView( this.domTarget );
67
- }
68
-
69
- /**
70
- * Prevents the native's event default action.
71
- */
72
- preventDefault() {
73
- this.domEvent.preventDefault();
74
- }
75
-
76
- /**
77
- * Stops native event propagation.
78
- */
79
- stopPropagation() {
80
- this.domEvent.stopPropagation();
81
- }
15
+ /**
16
+ * @param {module:engine/view/view~View} view The instance of the view controller.
17
+ * @param {Event} domEvent The DOM event.
18
+ * @param {Object} [additionalData] Additional properties that the instance should contain.
19
+ */
20
+ constructor(view, domEvent, additionalData) {
21
+ /**
22
+ * Instance of the view controller.
23
+ *
24
+ * @readonly
25
+ * @member {module:engine/view/view~View} module:engine/view/observer/observer~Observer.DomEvent#view
26
+ */
27
+ this.view = view;
28
+ /**
29
+ * The instance of the document.
30
+ *
31
+ * @readonly
32
+ * @member {module:engine/view/document~Document} module:engine/view/observer/observer~Observer.DomEvent#document
33
+ */
34
+ this.document = view.document;
35
+ /**
36
+ * The DOM event.
37
+ *
38
+ * @readonly
39
+ * @member {Event} module:engine/view/observer/observer~Observer.DomEvent#domEvent
40
+ */
41
+ this.domEvent = domEvent;
42
+ /**
43
+ * The DOM target.
44
+ *
45
+ * @readonly
46
+ * @member {HTMLElement} module:engine/view/observer/observer~Observer.DomEvent#target
47
+ */
48
+ this.domTarget = domEvent.target;
49
+ extend(this, additionalData);
50
+ }
51
+ /**
52
+ * The tree view element representing the target.
53
+ *
54
+ * @readonly
55
+ * @type module:engine/view/element~Element
56
+ */
57
+ get target() {
58
+ return this.view.domConverter.mapDomToView(this.domTarget);
59
+ }
60
+ /**
61
+ * Prevents the native's event default action.
62
+ */
63
+ preventDefault() {
64
+ this.domEvent.preventDefault();
65
+ }
66
+ /**
67
+ * Stops native event propagation.
68
+ */
69
+ stopPropagation() {
70
+ this.domEvent.stopPropagation();
71
+ }
82
72
  }
@@ -2,14 +2,11 @@
2
2
  * @license Copyright (c) 2003-2022, CKSource Holding sp. z o.o. All rights reserved.
3
3
  * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
4
  */
5
-
6
5
  /**
7
6
  * @module engine/view/observer/domeventobserver
8
7
  */
9
-
10
8
  import Observer from './observer';
11
9
  import DomEventData from './domeventdata';
12
-
13
10
  /**
14
11
  * Base class for DOM event observers. This class handles
15
12
  * {@link module:engine/view/observer/observer~Observer#observe adding} listeners to DOM elements,
@@ -35,65 +32,44 @@ import DomEventData from './domeventdata';
35
32
  * @extends module:engine/view/observer/observer~Observer
36
33
  */
37
34
  export default class DomEventObserver extends Observer {
38
- /**
39
- * Type of the DOM event the observer should listen to. Array of types can be defined
40
- * if the observer should listen to multiple DOM events.
41
- *
42
- * @readonly
43
- * @member {String|Array.<String>} #domEventType
44
- */
45
-
46
- /**
47
- * Callback which should be called when the DOM event occurred. Note that the callback will not be called if
48
- * observer {@link #isEnabled is not enabled}.
49
- *
50
- * @see #domEventType
51
- * @abstract
52
- * @method #onDomEvent
53
- */
54
-
55
- /**
56
- * @inheritDoc
57
- */
58
- constructor( view ) {
59
- super( view );
60
-
61
- /**
62
- * If set to `true` DOM events will be listened on the capturing phase.
63
- * Default value is `false`.
64
- *
65
- * @member {Boolean}
66
- */
67
- this.useCapture = false;
68
- }
69
-
70
- /**
71
- * @inheritDoc
72
- */
73
- observe( domElement ) {
74
- const types = typeof this.domEventType == 'string' ? [ this.domEventType ] : this.domEventType;
75
-
76
- types.forEach( type => {
77
- this.listenTo( domElement, type, ( eventInfo, domEvent ) => {
78
- if ( this.isEnabled && !this.checkShouldIgnoreEventFromTarget( domEvent.target ) ) {
79
- this.onDomEvent( domEvent );
80
- }
81
- }, { useCapture: this.useCapture } );
82
- } );
83
- }
84
-
85
- /**
86
- * Calls `Document#fire()` if observer {@link #isEnabled is enabled}.
87
- *
88
- * @see module:utils/emittermixin~EmitterMixin#fire
89
- * @param {String} eventType The event type (name).
90
- * @param {Event} domEvent The DOM event.
91
- * @param {Object} [additionalData] The additional data which should extend the
92
- * {@link module:engine/view/observer/domeventdata~DomEventData event data} object.
93
- */
94
- fire( eventType, domEvent, additionalData ) {
95
- if ( this.isEnabled ) {
96
- this.document.fire( eventType, new DomEventData( this.view, domEvent, additionalData ) );
97
- }
98
- }
35
+ /**
36
+ * @inheritDoc
37
+ */
38
+ constructor(view) {
39
+ super(view);
40
+ /**
41
+ * If set to `true` DOM events will be listened on the capturing phase.
42
+ * Default value is `false`.
43
+ *
44
+ * @member {Boolean}
45
+ */
46
+ this.useCapture = false;
47
+ }
48
+ /**
49
+ * @inheritDoc
50
+ */
51
+ observe(domElement) {
52
+ const types = typeof this.domEventType == 'string' ? [this.domEventType] : this.domEventType;
53
+ types.forEach(type => {
54
+ this.listenTo(domElement, type, (eventInfo, domEvent) => {
55
+ if (this.isEnabled && !this.checkShouldIgnoreEventFromTarget(domEvent.target)) {
56
+ this.onDomEvent(domEvent);
57
+ }
58
+ }, { useCapture: this.useCapture });
59
+ });
60
+ }
61
+ /**
62
+ * Calls `Document#fire()` if observer {@link #isEnabled is enabled}.
63
+ *
64
+ * @see module:utils/emittermixin~EmitterMixin#fire
65
+ * @param {String} eventType The event type (name).
66
+ * @param {Event} domEvent The DOM event.
67
+ * @param {Object} [additionalData] The additional data which should extend the
68
+ * {@link module:engine/view/observer/domeventdata~DomEventData event data} object.
69
+ */
70
+ fire(eventType, domEvent, additionalData) {
71
+ if (this.isEnabled) {
72
+ this.document.fire(eventType, new DomEventData(this.view, domEvent, additionalData));
73
+ }
74
+ }
99
75
  }
@@ -2,16 +2,13 @@
2
2
  * @license Copyright (c) 2003-2022, CKSource Holding sp. z o.o. All rights reserved.
3
3
  * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
4
  */
5
-
6
5
  /**
7
6
  * @module engine/view/observer/fakeselectionobserver
8
7
  */
9
-
10
8
  import Observer from './observer';
11
9
  import ViewSelection from '../selection';
12
10
  import { keyCodes } from '@ckeditor/ckeditor5-utils/src/keyboard';
13
11
  import { debounce } from 'lodash-es';
14
-
15
12
  /**
16
13
  * Fake selection observer class. If view selection is fake it is placed in dummy DOM container. This observer listens
17
14
  * on {@link module:engine/view/document~Document#event:keydown keydown} events and handles moving fake view selection to the correct place
@@ -22,97 +19,85 @@ import { debounce } from 'lodash-es';
22
19
  * @extends module:engine/view/observer/observer~Observer
23
20
  */
24
21
  export default class FakeSelectionObserver extends Observer {
25
- /**
26
- * Creates new FakeSelectionObserver instance.
27
- *
28
- * @param {module:engine/view/view~View} view
29
- */
30
- constructor( view ) {
31
- super( view );
32
-
33
- /**
34
- * Fires debounced event `selectionChangeDone`. It uses `lodash#debounce` method to delay function call.
35
- *
36
- * @private
37
- * @param {Object} data Selection change data.
38
- * @method #_fireSelectionChangeDoneDebounced
39
- */
40
- this._fireSelectionChangeDoneDebounced = debounce( data => this.document.fire( 'selectionChangeDone', data ), 200 );
41
- }
42
-
43
- /**
44
- * @inheritDoc
45
- */
46
- observe() {
47
- const document = this.document;
48
-
49
- document.on( 'arrowKey', ( eventInfo, data ) => {
50
- const selection = document.selection;
51
-
52
- if ( selection.isFake && this.isEnabled ) {
53
- // Prevents default key down handling - no selection change will occur.
54
- data.preventDefault();
55
- }
56
- }, { context: '$capture' } );
57
-
58
- document.on( 'arrowKey', ( eventInfo, data ) => {
59
- const selection = document.selection;
60
-
61
- if ( selection.isFake && this.isEnabled ) {
62
- this._handleSelectionMove( data.keyCode );
63
- }
64
- }, { priority: 'lowest' } );
65
- }
66
-
67
- /**
68
- * @inheritDoc
69
- */
70
- destroy() {
71
- super.destroy();
72
-
73
- this._fireSelectionChangeDoneDebounced.cancel();
74
- }
75
-
76
- /**
77
- * Handles collapsing view selection according to given key code. If left or up key is provided - new selection will be
78
- * collapsed to left. If right or down key is pressed - new selection will be collapsed to right.
79
- *
80
- * This method fires {@link module:engine/view/document~Document#event:selectionChange} and
81
- * {@link module:engine/view/document~Document#event:selectionChangeDone} events imitating behaviour of
82
- * {@link module:engine/view/observer/selectionobserver~SelectionObserver}.
83
- *
84
- * @private
85
- * @param {Number} keyCode
86
- * @fires module:engine/view/document~Document#event:selectionChange
87
- * @fires module:engine/view/document~Document#event:selectionChangeDone
88
- */
89
- _handleSelectionMove( keyCode ) {
90
- const selection = this.document.selection;
91
- const newSelection = new ViewSelection( selection.getRanges(), { backward: selection.isBackward, fake: false } );
92
-
93
- // Left or up arrow pressed - move selection to start.
94
- if ( keyCode == keyCodes.arrowleft || keyCode == keyCodes.arrowup ) {
95
- newSelection.setTo( newSelection.getFirstPosition() );
96
- }
97
-
98
- // Right or down arrow pressed - move selection to end.
99
- if ( keyCode == keyCodes.arrowright || keyCode == keyCodes.arrowdown ) {
100
- newSelection.setTo( newSelection.getLastPosition() );
101
- }
102
-
103
- const data = {
104
- oldSelection: selection,
105
- newSelection,
106
- domSelection: null
107
- };
108
-
109
- // Fire dummy selection change event.
110
- this.document.fire( 'selectionChange', data );
111
-
112
- // Call` #_fireSelectionChangeDoneDebounced` every time when `selectionChange` event is fired.
113
- // This function is debounced what means that `selectionChangeDone` event will be fired only when
114
- // defined int the function time will elapse since the last time the function was called.
115
- // So `selectionChangeDone` will be fired when selection will stop changing.
116
- this._fireSelectionChangeDoneDebounced( data );
117
- }
22
+ /**
23
+ * Creates new FakeSelectionObserver instance.
24
+ *
25
+ * @param {module:engine/view/view~View} view
26
+ */
27
+ constructor(view) {
28
+ super(view);
29
+ /**
30
+ * Fires debounced event `selectionChangeDone`. It uses `lodash#debounce` method to delay function call.
31
+ *
32
+ * @private
33
+ * @param {Object} data Selection change data.
34
+ * @method #_fireSelectionChangeDoneDebounced
35
+ */
36
+ this._fireSelectionChangeDoneDebounced = debounce(data => {
37
+ this.document.fire('selectionChangeDone', data);
38
+ }, 200);
39
+ }
40
+ /**
41
+ * @inheritDoc
42
+ */
43
+ observe() {
44
+ const document = this.document;
45
+ document.on('arrowKey', (eventInfo, data) => {
46
+ const selection = document.selection;
47
+ if (selection.isFake && this.isEnabled) {
48
+ // Prevents default key down handling - no selection change will occur.
49
+ data.preventDefault();
50
+ }
51
+ }, { context: '$capture' });
52
+ document.on('arrowKey', (eventInfo, data) => {
53
+ const selection = document.selection;
54
+ if (selection.isFake && this.isEnabled) {
55
+ this._handleSelectionMove(data.keyCode);
56
+ }
57
+ }, { priority: 'lowest' });
58
+ }
59
+ /**
60
+ * @inheritDoc
61
+ */
62
+ destroy() {
63
+ super.destroy();
64
+ this._fireSelectionChangeDoneDebounced.cancel();
65
+ }
66
+ /**
67
+ * Handles collapsing view selection according to given key code. If left or up key is provided - new selection will be
68
+ * collapsed to left. If right or down key is pressed - new selection will be collapsed to right.
69
+ *
70
+ * This method fires {@link module:engine/view/document~Document#event:selectionChange} and
71
+ * {@link module:engine/view/document~Document#event:selectionChangeDone} events imitating behaviour of
72
+ * {@link module:engine/view/observer/selectionobserver~SelectionObserver}.
73
+ *
74
+ * @private
75
+ * @param {Number} keyCode
76
+ * @fires module:engine/view/document~Document#event:selectionChange
77
+ * @fires module:engine/view/document~Document#event:selectionChangeDone
78
+ */
79
+ _handleSelectionMove(keyCode) {
80
+ const selection = this.document.selection;
81
+ const newSelection = new ViewSelection(selection.getRanges(), { backward: selection.isBackward, fake: false });
82
+ // Left or up arrow pressed - move selection to start.
83
+ if (keyCode == keyCodes.arrowleft || keyCode == keyCodes.arrowup) {
84
+ newSelection.setTo(newSelection.getFirstPosition());
85
+ }
86
+ // Right or down arrow pressed - move selection to end.
87
+ if (keyCode == keyCodes.arrowright || keyCode == keyCodes.arrowdown) {
88
+ newSelection.setTo(newSelection.getLastPosition());
89
+ }
90
+ const data = {
91
+ oldSelection: selection,
92
+ newSelection,
93
+ domSelection: null
94
+ };
95
+ // Fire dummy selection change event.
96
+ this.document.fire('selectionChange', data);
97
+ // Call` #_fireSelectionChangeDoneDebounced` every time when `selectionChange` event is fired.
98
+ // This function is debounced what means that `selectionChangeDone` event will be fired only when
99
+ // defined int the function time will elapse since the last time the function was called.
100
+ // So `selectionChangeDone` will be fired when selection will stop changing.
101
+ this._fireSelectionChangeDoneDebounced(data);
102
+ }
118
103
  }