@ckeditor/ckeditor5-engine 36.0.1 → 37.0.0-alpha.1

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 (203) hide show
  1. package/README.md +1 -1
  2. package/package.json +25 -24
  3. package/src/controller/datacontroller.d.ts +331 -0
  4. package/src/controller/datacontroller.js +72 -116
  5. package/src/controller/editingcontroller.d.ts +98 -0
  6. package/src/controller/editingcontroller.js +22 -46
  7. package/src/conversion/conversion.d.ts +476 -0
  8. package/src/conversion/conversion.js +328 -347
  9. package/src/conversion/conversionhelpers.d.ts +26 -0
  10. package/src/conversion/conversionhelpers.js +1 -5
  11. package/src/conversion/downcastdispatcher.d.ts +547 -0
  12. package/src/conversion/downcastdispatcher.js +74 -152
  13. package/src/conversion/downcasthelpers.d.ts +1226 -0
  14. package/src/conversion/downcasthelpers.js +843 -762
  15. package/src/conversion/mapper.d.ts +503 -0
  16. package/src/conversion/mapper.js +84 -99
  17. package/src/conversion/modelconsumable.d.ts +201 -0
  18. package/src/conversion/modelconsumable.js +96 -99
  19. package/src/conversion/upcastdispatcher.d.ts +492 -0
  20. package/src/conversion/upcastdispatcher.js +73 -100
  21. package/src/conversion/upcasthelpers.d.ts +499 -0
  22. package/src/conversion/upcasthelpers.js +406 -373
  23. package/src/conversion/viewconsumable.d.ts +369 -0
  24. package/src/conversion/viewconsumable.js +139 -173
  25. package/src/dataprocessor/basichtmlwriter.d.ts +18 -0
  26. package/src/dataprocessor/basichtmlwriter.js +0 -9
  27. package/src/dataprocessor/dataprocessor.d.ts +61 -0
  28. package/src/dataprocessor/htmldataprocessor.d.ts +76 -0
  29. package/src/dataprocessor/htmldataprocessor.js +6 -28
  30. package/src/dataprocessor/htmlwriter.d.ts +16 -0
  31. package/src/dataprocessor/xmldataprocessor.d.ts +90 -0
  32. package/src/dataprocessor/xmldataprocessor.js +8 -40
  33. package/src/dev-utils/model.d.ts +124 -0
  34. package/src/dev-utils/model.js +41 -38
  35. package/src/dev-utils/operationreplayer.d.ts +51 -0
  36. package/src/dev-utils/operationreplayer.js +6 -14
  37. package/src/dev-utils/utils.d.ts +37 -0
  38. package/src/dev-utils/utils.js +5 -18
  39. package/src/dev-utils/view.d.ts +319 -0
  40. package/src/dev-utils/view.js +205 -226
  41. package/src/index.d.ts +108 -0
  42. package/src/index.js +4 -0
  43. package/src/model/batch.d.ts +106 -0
  44. package/src/model/differ.d.ts +329 -0
  45. package/src/model/document.d.ts +246 -0
  46. package/src/model/document.js +1 -1
  47. package/src/model/documentfragment.d.ts +196 -0
  48. package/src/model/documentfragment.js +2 -2
  49. package/src/model/documentselection.d.ts +420 -0
  50. package/src/model/element.d.ts +165 -0
  51. package/src/model/history.d.ts +114 -0
  52. package/src/model/item.d.ts +14 -0
  53. package/src/model/liveposition.d.ts +77 -0
  54. package/src/model/liverange.d.ts +102 -0
  55. package/src/model/markercollection.d.ts +335 -0
  56. package/src/model/model.d.ts +885 -0
  57. package/src/model/model.js +59 -81
  58. package/src/model/node.d.ts +256 -0
  59. package/src/model/nodelist.d.ts +91 -0
  60. package/src/model/operation/attributeoperation.d.ts +98 -0
  61. package/src/model/operation/detachoperation.d.ts +55 -0
  62. package/src/model/operation/insertoperation.d.ts +85 -0
  63. package/src/model/operation/markeroperation.d.ts +86 -0
  64. package/src/model/operation/mergeoperation.d.ts +95 -0
  65. package/src/model/operation/mergeoperation.js +1 -1
  66. package/src/model/operation/moveoperation.d.ts +91 -0
  67. package/src/model/operation/nooperation.d.ts +33 -0
  68. package/src/model/operation/operation.d.ts +89 -0
  69. package/src/model/operation/operationfactory.d.ts +18 -0
  70. package/src/model/operation/renameoperation.d.ts +78 -0
  71. package/src/model/operation/rootattributeoperation.d.ts +97 -0
  72. package/src/model/operation/rootattributeoperation.js +1 -1
  73. package/src/model/operation/splitoperation.d.ts +104 -0
  74. package/src/model/operation/splitoperation.js +1 -1
  75. package/src/model/operation/transform.d.ts +100 -0
  76. package/src/model/operation/utils.d.ts +71 -0
  77. package/src/model/operation/utils.js +1 -1
  78. package/src/model/position.d.ts +539 -0
  79. package/src/model/position.js +1 -1
  80. package/src/model/range.d.ts +458 -0
  81. package/src/model/range.js +1 -1
  82. package/src/model/rootelement.d.ts +40 -0
  83. package/src/model/schema.d.ts +1176 -0
  84. package/src/model/schema.js +19 -19
  85. package/src/model/selection.d.ts +472 -0
  86. package/src/model/text.d.ts +66 -0
  87. package/src/model/text.js +0 -2
  88. package/src/model/textproxy.d.ts +144 -0
  89. package/src/model/treewalker.d.ts +186 -0
  90. package/src/model/treewalker.js +19 -10
  91. package/src/model/typecheckable.d.ts +285 -0
  92. package/src/model/utils/autoparagraphing.d.ts +37 -0
  93. package/src/model/utils/deletecontent.d.ts +58 -0
  94. package/src/model/utils/findoptimalinsertionrange.d.ts +32 -0
  95. package/src/model/utils/getselectedcontent.d.ts +30 -0
  96. package/src/model/utils/insertcontent.d.ts +46 -0
  97. package/src/model/utils/insertcontent.js +2 -12
  98. package/src/model/utils/insertobject.d.ts +44 -0
  99. package/src/model/utils/insertobject.js +3 -14
  100. package/src/model/utils/modifyselection.d.ts +48 -0
  101. package/src/model/utils/selection-post-fixer.d.ts +65 -0
  102. package/src/model/writer.d.ts +823 -0
  103. package/src/model/writer.js +6 -61
  104. package/src/view/attributeelement.d.ts +108 -0
  105. package/src/view/attributeelement.js +25 -69
  106. package/src/view/containerelement.d.ts +49 -0
  107. package/src/view/containerelement.js +10 -43
  108. package/src/view/datatransfer.d.ts +75 -0
  109. package/src/view/document.d.ts +184 -0
  110. package/src/view/document.js +15 -84
  111. package/src/view/documentfragment.d.ts +149 -0
  112. package/src/view/documentfragment.js +39 -81
  113. package/src/view/documentselection.d.ts +306 -0
  114. package/src/view/documentselection.js +42 -143
  115. package/src/view/domconverter.d.ts +650 -0
  116. package/src/view/domconverter.js +157 -283
  117. package/src/view/downcastwriter.d.ts +996 -0
  118. package/src/view/downcastwriter.js +259 -426
  119. package/src/view/editableelement.d.ts +52 -0
  120. package/src/view/editableelement.js +9 -49
  121. package/src/view/element.d.ts +468 -0
  122. package/src/view/element.js +150 -222
  123. package/src/view/elementdefinition.d.ts +87 -0
  124. package/src/view/emptyelement.d.ts +41 -0
  125. package/src/view/emptyelement.js +11 -44
  126. package/src/view/filler.d.ts +111 -0
  127. package/src/view/filler.js +24 -21
  128. package/src/view/item.d.ts +14 -0
  129. package/src/view/matcher.d.ts +486 -0
  130. package/src/view/matcher.js +247 -218
  131. package/src/view/node.d.ts +163 -0
  132. package/src/view/node.js +26 -100
  133. package/src/view/observer/arrowkeysobserver.d.ts +41 -0
  134. package/src/view/observer/arrowkeysobserver.js +0 -13
  135. package/src/view/observer/bubblingemittermixin.d.ts +166 -0
  136. package/src/view/observer/bubblingemittermixin.js +36 -25
  137. package/src/view/observer/bubblingeventinfo.d.ts +47 -0
  138. package/src/view/observer/bubblingeventinfo.js +3 -29
  139. package/src/view/observer/clickobserver.d.ts +43 -0
  140. package/src/view/observer/clickobserver.js +9 -19
  141. package/src/view/observer/compositionobserver.d.ts +82 -0
  142. package/src/view/observer/compositionobserver.js +13 -42
  143. package/src/view/observer/domeventdata.d.ts +50 -0
  144. package/src/view/observer/domeventdata.js +5 -30
  145. package/src/view/observer/domeventobserver.d.ts +69 -0
  146. package/src/view/observer/domeventobserver.js +19 -21
  147. package/src/view/observer/fakeselectionobserver.d.ts +43 -0
  148. package/src/view/observer/fakeselectionobserver.js +0 -16
  149. package/src/view/observer/focusobserver.d.ts +82 -0
  150. package/src/view/observer/focusobserver.js +14 -40
  151. package/src/view/observer/inputobserver.d.ts +86 -0
  152. package/src/view/observer/inputobserver.js +18 -64
  153. package/src/view/observer/keyobserver.d.ts +66 -0
  154. package/src/view/observer/keyobserver.js +8 -42
  155. package/src/view/observer/mouseobserver.d.ts +89 -0
  156. package/src/view/observer/mouseobserver.js +8 -28
  157. package/src/view/observer/mutationobserver.d.ts +82 -0
  158. package/src/view/observer/mutationobserver.js +7 -37
  159. package/src/view/observer/observer.d.ts +84 -0
  160. package/src/view/observer/observer.js +12 -25
  161. package/src/view/observer/selectionobserver.d.ts +144 -0
  162. package/src/view/observer/selectionobserver.js +17 -107
  163. package/src/view/observer/tabobserver.d.ts +42 -0
  164. package/src/view/observer/tabobserver.js +0 -14
  165. package/src/view/placeholder.d.ts +85 -0
  166. package/src/view/placeholder.js +26 -43
  167. package/src/view/position.d.ts +189 -0
  168. package/src/view/position.js +36 -83
  169. package/src/view/range.d.ts +279 -0
  170. package/src/view/range.js +79 -122
  171. package/src/view/rawelement.d.ts +73 -0
  172. package/src/view/rawelement.js +34 -48
  173. package/src/view/renderer.d.ts +265 -0
  174. package/src/view/renderer.js +105 -193
  175. package/src/view/rooteditableelement.d.ts +41 -0
  176. package/src/view/rooteditableelement.js +12 -40
  177. package/src/view/selection.d.ts +375 -0
  178. package/src/view/selection.js +79 -153
  179. package/src/view/styles/background.d.ts +33 -0
  180. package/src/view/styles/background.js +14 -12
  181. package/src/view/styles/border.d.ts +43 -0
  182. package/src/view/styles/border.js +58 -48
  183. package/src/view/styles/margin.d.ts +29 -0
  184. package/src/view/styles/margin.js +13 -11
  185. package/src/view/styles/padding.d.ts +29 -0
  186. package/src/view/styles/padding.js +13 -11
  187. package/src/view/styles/utils.d.ts +93 -0
  188. package/src/view/styles/utils.js +22 -48
  189. package/src/view/stylesmap.d.ts +675 -0
  190. package/src/view/stylesmap.js +249 -244
  191. package/src/view/text.d.ts +74 -0
  192. package/src/view/text.js +16 -46
  193. package/src/view/textproxy.d.ts +97 -0
  194. package/src/view/textproxy.js +10 -59
  195. package/src/view/treewalker.d.ts +195 -0
  196. package/src/view/treewalker.js +43 -106
  197. package/src/view/typecheckable.d.ts +448 -0
  198. package/src/view/uielement.d.ts +96 -0
  199. package/src/view/uielement.js +29 -63
  200. package/src/view/upcastwriter.d.ts +417 -0
  201. package/src/view/upcastwriter.js +86 -157
  202. package/src/view/view.d.ts +417 -0
  203. package/src/view/view.js +47 -175
@@ -0,0 +1,184 @@
1
+ /**
2
+ * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
+ */
5
+ /**
6
+ * @module engine/view/document
7
+ */
8
+ import DocumentSelection from './documentselection';
9
+ import { Collection } from '@ckeditor/ckeditor5-utils';
10
+ import type { StylesProcessor } from './stylesmap';
11
+ import type RootEditableElement from './rooteditableelement';
12
+ import type DowncastWriter from './downcastwriter';
13
+ declare const Document_base: import("@ckeditor/ckeditor5-utils").Mixed<{
14
+ new (): import("@ckeditor/ckeditor5-utils").Observable;
15
+ prototype: import("@ckeditor/ckeditor5-utils").Observable;
16
+ }, import("@ckeditor/ckeditor5-utils").Emitter>;
17
+ /**
18
+ * Document class creates an abstract layer over the content editable area, contains a tree of view elements and
19
+ * {@link module:engine/view/documentselection~DocumentSelection view selection} associated with this document.
20
+ */
21
+ export default class Document extends Document_base {
22
+ /**
23
+ * Selection done on this document.
24
+ */
25
+ readonly selection: DocumentSelection;
26
+ /**
27
+ * Roots of the view tree. Collection of the {@link module:engine/view/element~Element view elements}.
28
+ *
29
+ * View roots are created as a result of binding between {@link module:engine/view/document~Document#roots} and
30
+ * {@link module:engine/model/document~Document#roots} and this is handled by
31
+ * {@link module:engine/controller/editingcontroller~EditingController}, so to create view root we need to create
32
+ * model root using {@link module:engine/model/document~Document#createRoot}.
33
+ */
34
+ readonly roots: Collection<RootEditableElement>;
35
+ /**
36
+ * The styles processor instance used by this document when normalizing styles.
37
+ */
38
+ readonly stylesProcessor: StylesProcessor;
39
+ /**
40
+ * Defines whether document is in read-only mode.
41
+ *
42
+ * When document is read-ony then all roots are read-only as well and caret placed inside this root is hidden.
43
+ *
44
+ * @observable
45
+ */
46
+ isReadOnly: boolean;
47
+ /**
48
+ * True if document is focused.
49
+ *
50
+ * This property is updated by the {@link module:engine/view/observer/focusobserver~FocusObserver}.
51
+ * If the {@link module:engine/view/observer/focusobserver~FocusObserver} is disabled this property will not change.
52
+ *
53
+ * @readonly
54
+ * @observable
55
+ */
56
+ isFocused: boolean;
57
+ /**
58
+ * `true` while the user is making a selection in the document (e.g. holding the mouse button and moving the cursor).
59
+ * When they stop selecting, the property goes back to `false`.
60
+ *
61
+ * This property is updated by the {@link module:engine/view/observer/selectionobserver~SelectionObserver}.
62
+ *
63
+ * @readonly
64
+ * @observable
65
+ */
66
+ isSelecting: boolean;
67
+ /**
68
+ * True if composition is in progress inside the document.
69
+ *
70
+ * This property is updated by the {@link module:engine/view/observer/compositionobserver~CompositionObserver}.
71
+ * If the {@link module:engine/view/observer/compositionobserver~CompositionObserver} is disabled this property will not change.
72
+ *
73
+ * @readonly
74
+ * @observable
75
+ */
76
+ isComposing: boolean;
77
+ /**
78
+ * Post-fixer callbacks registered to the view document.
79
+ */
80
+ private readonly _postFixers;
81
+ /**
82
+ * Creates a Document instance.
83
+ *
84
+ * @param stylesProcessor The styles processor instance.
85
+ */
86
+ constructor(stylesProcessor: StylesProcessor);
87
+ /**
88
+ * Gets a {@link module:engine/view/document~Document#roots view root element} with the specified name. If the name is not
89
+ * specific "main" root is returned.
90
+ *
91
+ * @param name Name of the root.
92
+ * @returns The view root element with the specified name or null when there is no root of given name.
93
+ */
94
+ getRoot(name?: string): RootEditableElement | null;
95
+ /**
96
+ * Allows registering post-fixer callbacks. A post-fixers mechanism allows to update the view tree just before it is rendered
97
+ * to the DOM.
98
+ *
99
+ * Post-fixers are executed right after all changes from the outermost change block were applied but
100
+ * before the {@link module:engine/view/view~View#event:render render event} is fired. If a post-fixer callback made
101
+ * a change, it should return `true`. When this happens, all post-fixers are fired again to check if something else should
102
+ * not be fixed in the new document tree state.
103
+ *
104
+ * View post-fixers are useful when you want to apply some fixes whenever the view structure changes. Keep in mind that
105
+ * changes executed in a view post-fixer should not break model-view mapping.
106
+ *
107
+ * The types of changes which should be safe:
108
+ *
109
+ * * adding or removing attribute from elements,
110
+ * * changes inside of {@link module:engine/view/uielement~UIElement UI elements},
111
+ * * {@link module:engine/controller/editingcontroller~EditingController#reconvertItem marking some of the model elements to be
112
+ * re-converted}.
113
+ *
114
+ * Try to avoid changes which touch view structure:
115
+ *
116
+ * * you should not add or remove nor wrap or unwrap any view elements,
117
+ * * you should not change the editor data model in a view post-fixer.
118
+ *
119
+ * As a parameter, a post-fixer callback receives a {@link module:engine/view/downcastwriter~DowncastWriter downcast writer}.
120
+ *
121
+ * Typically, a post-fixer will look like this:
122
+ *
123
+ * ```ts
124
+ * editor.editing.view.document.registerPostFixer( writer => {
125
+ * if ( checkSomeCondition() ) {
126
+ * writer.doSomething();
127
+ *
128
+ * // Let other post-fixers know that something changed.
129
+ * return true;
130
+ * }
131
+ * } );
132
+ * ```
133
+ *
134
+ * Note that nothing happens right after you register a post-fixer (e.g. execute such a code in the console).
135
+ * That is because adding a post-fixer does not execute it.
136
+ * The post-fixer will be executed as soon as any change in the document needs to cause its rendering.
137
+ * If you want to re-render the editor's view after registering the post-fixer then you should do it manually by calling
138
+ * {@link module:engine/view/view~View#forceRender `view.forceRender()`}.
139
+ *
140
+ * If you need to register a callback which is executed when DOM elements are already updated,
141
+ * use {@link module:engine/view/view~View#event:render render event}.
142
+ */
143
+ registerPostFixer(postFixer: ViewDocumentPostFixer): void;
144
+ /**
145
+ * Destroys this instance. Makes sure that all observers are destroyed and listeners removed.
146
+ */
147
+ destroy(): void;
148
+ /**
149
+ * Performs post-fixer loops. Executes post-fixer callbacks as long as none of them has done any changes to the model.
150
+ *
151
+ * @internal
152
+ */
153
+ _callPostFixers(writer: DowncastWriter): void;
154
+ }
155
+ /**
156
+ * Document PostFixer.
157
+ *
158
+ * @see module:engine/view/document~Document#registerPostFixer
159
+ */
160
+ export type ViewDocumentPostFixer = (writer: DowncastWriter) => boolean;
161
+ /**
162
+ * Enum representing type of the change.
163
+ *
164
+ * Possible values:
165
+ *
166
+ * * `children` - for child list changes,
167
+ * * `attributes` - for element attributes changes,
168
+ * * `text` - for text nodes changes.
169
+ *
170
+ * @typedef {String} module:engine/view/document~ChangeType
171
+ */
172
+ export type ChangeType = 'children' | 'attributes' | 'text';
173
+ /**
174
+ * Event fired whenever document content layout changes. It is fired whenever content is
175
+ * {@link module:engine/view/view~View#event:render rendered}, but should be also fired by observers in case of
176
+ * other actions which may change layout, for instance when image loads.
177
+ *
178
+ * @eventName ~Document#layoutChanged
179
+ */
180
+ export type ViewDocumentLayoutChangedEvent = {
181
+ name: 'layoutChanged';
182
+ args: [];
183
+ };
184
+ export {};
@@ -12,101 +12,33 @@ import { Collection, ObservableMixin } from '@ckeditor/ckeditor5-utils';
12
12
  /**
13
13
  * Document class creates an abstract layer over the content editable area, contains a tree of view elements and
14
14
  * {@link module:engine/view/documentselection~DocumentSelection view selection} associated with this document.
15
- *
16
- * @mixes module:engine/view/observer/bubblingemittermixin~BubblingEmitterMixin
17
- * @mixes module:utils/observablemixin~ObservableMixin
18
15
  */
19
16
  export default class Document extends BubblingEmitterMixin(ObservableMixin()) {
20
17
  /**
21
18
  * Creates a Document instance.
22
19
  *
23
- * @param {module:engine/view/stylesmap~StylesProcessor} stylesProcessor The styles processor instance.
20
+ * @param stylesProcessor The styles processor instance.
24
21
  */
25
22
  constructor(stylesProcessor) {
26
23
  super();
27
24
  /**
28
- * Selection done on this document.
29
- *
30
- * @readonly
31
- * @member {module:engine/view/documentselection~DocumentSelection} module:engine/view/document~Document#selection
25
+ * Post-fixer callbacks registered to the view document.
32
26
  */
27
+ this._postFixers = new Set();
33
28
  this.selection = new DocumentSelection();
34
- /**
35
- * Roots of the view tree. Collection of the {@link module:engine/view/element~Element view elements}.
36
- *
37
- * View roots are created as a result of binding between {@link module:engine/view/document~Document#roots} and
38
- * {@link module:engine/model/document~Document#roots} and this is handled by
39
- * {@link module:engine/controller/editingcontroller~EditingController}, so to create view root we need to create
40
- * model root using {@link module:engine/model/document~Document#createRoot}.
41
- *
42
- * @readonly
43
- * @member {module:utils/collection~Collection} module:engine/view/document~Document#roots
44
- */
45
29
  this.roots = new Collection({ idProperty: 'rootName' });
46
- /**
47
- * The styles processor instance used by this document when normalizing styles.
48
- *
49
- * @readonly
50
- * @member {module:engine/view/stylesmap~StylesProcessor}
51
- */
52
30
  this.stylesProcessor = stylesProcessor;
53
- /**
54
- * Defines whether document is in read-only mode.
55
- *
56
- * When document is read-ony then all roots are read-only as well and caret placed inside this root is hidden.
57
- *
58
- * @observable
59
- * @member {Boolean} #isReadOnly
60
- */
61
31
  this.set('isReadOnly', false);
62
- /**
63
- * True if document is focused.
64
- *
65
- * This property is updated by the {@link module:engine/view/observer/focusobserver~FocusObserver}.
66
- * If the {@link module:engine/view/observer/focusobserver~FocusObserver} is disabled this property will not change.
67
- *
68
- * @readonly
69
- * @observable
70
- * @member {Boolean} module:engine/view/document~Document#isFocused
71
- */
72
32
  this.set('isFocused', false);
73
- /**
74
- * `true` while the user is making a selection in the document (e.g. holding the mouse button and moving the cursor).
75
- * When they stop selecting, the property goes back to `false`.
76
- *
77
- * This property is updated by the {@link module:engine/view/observer/selectionobserver~SelectionObserver}.
78
- *
79
- * @readonly
80
- * @observable
81
- * @member {Boolean} module:engine/view/document~Document#isSelecting
82
- */
83
33
  this.set('isSelecting', false);
84
- /**
85
- * True if composition is in progress inside the document.
86
- *
87
- * This property is updated by the {@link module:engine/view/observer/compositionobserver~CompositionObserver}.
88
- * If the {@link module:engine/view/observer/compositionobserver~CompositionObserver} is disabled this property will not change.
89
- *
90
- * @readonly
91
- * @observable
92
- * @member {Boolean} module:engine/view/document~Document#isComposing
93
- */
94
34
  this.set('isComposing', false);
95
- /**
96
- * Post-fixer callbacks registered to the view document.
97
- *
98
- * @private
99
- * @member {Set}
100
- */
101
- this._postFixers = new Set();
102
35
  }
103
36
  /**
104
37
  * Gets a {@link module:engine/view/document~Document#roots view root element} with the specified name. If the name is not
105
38
  * specific "main" root is returned.
106
39
  *
107
- * @param {String} [name='main'] Name of the root.
108
- * @returns {module:engine/view/rooteditableelement~RootEditableElement|null} The view root element with the specified name
109
- * or null when there is no root of given name.
40
+ * @param name Name of the root.
41
+ * @returns The view root element with the specified name or null when there is no root of given name.
110
42
  */
111
43
  getRoot(name = 'main') {
112
44
  return this.roots.get(name);
@@ -139,14 +71,16 @@ export default class Document extends BubblingEmitterMixin(ObservableMixin()) {
139
71
  *
140
72
  * Typically, a post-fixer will look like this:
141
73
  *
142
- * editor.editing.view.document.registerPostFixer( writer => {
143
- * if ( checkSomeCondition() ) {
144
- * writer.doSomething();
74
+ * ```ts
75
+ * editor.editing.view.document.registerPostFixer( writer => {
76
+ * if ( checkSomeCondition() ) {
77
+ * writer.doSomething();
145
78
  *
146
- * // Let other post-fixers know that something changed.
147
- * return true;
148
- * }
149
- * } );
79
+ * // Let other post-fixers know that something changed.
80
+ * return true;
81
+ * }
82
+ * } );
83
+ * ```
150
84
  *
151
85
  * Note that nothing happens right after you register a post-fixer (e.g. execute such a code in the console).
152
86
  * That is because adding a post-fixer does not execute it.
@@ -156,8 +90,6 @@ export default class Document extends BubblingEmitterMixin(ObservableMixin()) {
156
90
  *
157
91
  * If you need to register a callback which is executed when DOM elements are already updated,
158
92
  * use {@link module:engine/view/view~View#event:render render event}.
159
- *
160
- * @param {Function} postFixer
161
93
  */
162
94
  registerPostFixer(postFixer) {
163
95
  this._postFixers.add(postFixer);
@@ -172,8 +104,7 @@ export default class Document extends BubblingEmitterMixin(ObservableMixin()) {
172
104
  /**
173
105
  * Performs post-fixer loops. Executes post-fixer callbacks as long as none of them has done any changes to the model.
174
106
  *
175
- * @protected
176
- * @param {module:engine/view/downcastwriter~DowncastWriter} writer
107
+ * @internal
177
108
  */
178
109
  _callPostFixers(writer) {
179
110
  let wasFixed = false;
@@ -0,0 +1,149 @@
1
+ /**
2
+ * @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
+ */
5
+ /**
6
+ * @module engine/view/documentfragment
7
+ */
8
+ import TypeCheckable from './typecheckable';
9
+ import type { default as Document, ChangeType } from './document';
10
+ import type Item from './item';
11
+ import type Node from './node';
12
+ declare const DocumentFragment_base: import("@ckeditor/ckeditor5-utils").Mixed<typeof TypeCheckable, import("@ckeditor/ckeditor5-utils").Emitter>;
13
+ /**
14
+ * Document fragment.
15
+ *
16
+ * To create a new document fragment instance use the
17
+ * {@link module:engine/view/upcastwriter~UpcastWriter#createDocumentFragment `UpcastWriter#createDocumentFragment()`}
18
+ * method.
19
+ */
20
+ export default class DocumentFragment extends DocumentFragment_base implements Iterable<Node> {
21
+ /**
22
+ * The document to which this document fragment belongs.
23
+ */
24
+ readonly document: Document;
25
+ /**
26
+ * Array of child nodes.
27
+ */
28
+ private readonly _children;
29
+ /**
30
+ * Map of custom properties.
31
+ * Custom properties can be added to document fragment instance.
32
+ */
33
+ private readonly _customProperties;
34
+ /**
35
+ * Creates new DocumentFragment instance.
36
+ *
37
+ * @internal
38
+ * @param document The document to which this document fragment belongs.
39
+ * @param children A list of nodes to be inserted into the created document fragment.
40
+ */
41
+ constructor(document: Document, children?: Node | Iterable<Node>);
42
+ /**
43
+ * Iterable interface.
44
+ *
45
+ * Iterates over nodes added to this document fragment.
46
+ */
47
+ [Symbol.iterator](): Iterator<Node>;
48
+ /**
49
+ * Number of child nodes in this document fragment.
50
+ */
51
+ get childCount(): number;
52
+ /**
53
+ * Is `true` if there are no nodes inside this document fragment, `false` otherwise.
54
+ */
55
+ get isEmpty(): boolean;
56
+ /**
57
+ * Artificial root of `DocumentFragment`. Returns itself. Added for compatibility reasons.
58
+ */
59
+ get root(): this;
60
+ /**
61
+ * Artificial parent of `DocumentFragment`. Returns `null`. Added for compatibility reasons.
62
+ */
63
+ get parent(): null;
64
+ /**
65
+ * Artificial element name. Returns `undefined`. Added for compatibility reasons.
66
+ */
67
+ get name(): undefined;
68
+ /**
69
+ * Returns the custom property value for the given key.
70
+ */
71
+ getCustomProperty(key: string | symbol): unknown;
72
+ /**
73
+ * Returns an iterator which iterates over this document fragment's custom properties.
74
+ * Iterator provides `[ key, value ]` pairs for each stored property.
75
+ */
76
+ getCustomProperties(): Iterable<[string | symbol, unknown]>;
77
+ /**
78
+ * {@link module:engine/view/documentfragment~DocumentFragment#_insertChild Insert} a child node or a list of child nodes at the end
79
+ * and sets the parent of these nodes to this fragment.
80
+ *
81
+ * @internal
82
+ * @param items Items to be inserted.
83
+ * @returns Number of appended nodes.
84
+ */
85
+ _appendChild(items: Item | string | Iterable<Item | string>): number;
86
+ /**
87
+ * Gets child at the given index.
88
+ *
89
+ * @param index Index of child.
90
+ * @returns Child node.
91
+ */
92
+ getChild(index: number): Node;
93
+ /**
94
+ * Gets index of the given child node. Returns `-1` if child node is not found.
95
+ *
96
+ * @param node Child node.
97
+ * @returns Index of the child node.
98
+ */
99
+ getChildIndex(node: Node): number;
100
+ /**
101
+ * Gets child nodes iterator.
102
+ *
103
+ * @returns Child nodes iterator.
104
+ */
105
+ getChildren(): IterableIterator<Node>;
106
+ /**
107
+ * Inserts a child node or a list of child nodes on the given index and sets the parent of these nodes to
108
+ * this fragment.
109
+ *
110
+ * @internal
111
+ * @param index Position where nodes should be inserted.
112
+ * @param items Items to be inserted.
113
+ * @returns Number of inserted nodes.
114
+ */
115
+ _insertChild(index: number, items: Item | string | Iterable<Item | string>): number;
116
+ /**
117
+ * Removes number of child nodes starting at the given index and set the parent of these nodes to `null`.
118
+ *
119
+ * @internal
120
+ * @param index Number of the first node to remove.
121
+ * @param howMany Number of nodes to remove.
122
+ * @returns The array of removed nodes.
123
+ */
124
+ _removeChildren(index: number, howMany?: number): Array<Node>;
125
+ /**
126
+ * Fires `change` event with given type of the change.
127
+ *
128
+ * @internal
129
+ * @param type Type of the change.
130
+ * @param node Changed node.
131
+ */
132
+ _fireChange(type: ChangeType, node: Node | DocumentFragment): void;
133
+ /**
134
+ * Sets a custom property. They can be used to add special data to elements.
135
+ *
136
+ * @see module:engine/view/downcastwriter~DowncastWriter#setCustomProperty
137
+ * @internal
138
+ */
139
+ _setCustomProperty(key: string | symbol, value: unknown): void;
140
+ /**
141
+ * Removes the custom property stored under the given key.
142
+ *
143
+ * @see module:engine/view/downcastwriter~DowncastWriter#removeCustomProperty
144
+ * @internal
145
+ * @returns Returns true if property was removed.
146
+ */
147
+ _removeCustomProperty(key: string | symbol): boolean;
148
+ }
149
+ export {};