@ckeditor/ckeditor5-engine 44.1.0 → 44.2.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 (369) hide show
  1. package/LICENSE.md +1 -1
  2. package/dist/index-content.css +2 -2
  3. package/dist/index-editor.css +2 -2
  4. package/dist/index.css +4 -4
  5. package/dist/index.css.map +1 -1
  6. package/dist/index.js +646 -77
  7. package/dist/index.js.map +1 -1
  8. package/package.json +23 -3
  9. package/src/controller/datacontroller.d.ts +1 -1
  10. package/src/controller/datacontroller.js +1 -1
  11. package/src/controller/editingcontroller.d.ts +1 -1
  12. package/src/controller/editingcontroller.js +1 -1
  13. package/src/conversion/conversion.d.ts +1 -1
  14. package/src/conversion/conversion.js +1 -1
  15. package/src/conversion/conversionhelpers.d.ts +1 -1
  16. package/src/conversion/conversionhelpers.js +1 -1
  17. package/src/conversion/downcastdispatcher.d.ts +1 -1
  18. package/src/conversion/downcastdispatcher.js +1 -1
  19. package/src/conversion/downcasthelpers.d.ts +1 -1
  20. package/src/conversion/downcasthelpers.js +1 -1
  21. package/src/conversion/mapper.d.ts +249 -20
  22. package/src/conversion/mapper.js +524 -38
  23. package/src/conversion/modelconsumable.d.ts +1 -1
  24. package/src/conversion/modelconsumable.js +1 -1
  25. package/src/conversion/upcastdispatcher.d.ts +1 -1
  26. package/src/conversion/upcastdispatcher.js +1 -1
  27. package/src/conversion/upcasthelpers.d.ts +1 -1
  28. package/src/conversion/upcasthelpers.js +1 -1
  29. package/src/conversion/viewconsumable.d.ts +1 -1
  30. package/src/conversion/viewconsumable.js +1 -1
  31. package/src/dataprocessor/basichtmlwriter.d.ts +1 -1
  32. package/src/dataprocessor/basichtmlwriter.js +1 -1
  33. package/src/dataprocessor/dataprocessor.d.ts +1 -1
  34. package/src/dataprocessor/dataprocessor.js +1 -1
  35. package/src/dataprocessor/htmldataprocessor.d.ts +1 -1
  36. package/src/dataprocessor/htmldataprocessor.js +1 -1
  37. package/src/dataprocessor/htmlwriter.d.ts +1 -1
  38. package/src/dataprocessor/htmlwriter.js +1 -1
  39. package/src/dataprocessor/xmldataprocessor.d.ts +1 -1
  40. package/src/dataprocessor/xmldataprocessor.js +1 -1
  41. package/src/dev-utils/model.d.ts +1 -1
  42. package/src/dev-utils/model.js +1 -1
  43. package/src/dev-utils/operationreplayer.d.ts +1 -1
  44. package/src/dev-utils/operationreplayer.js +1 -1
  45. package/src/dev-utils/utils.d.ts +1 -1
  46. package/src/dev-utils/utils.js +1 -1
  47. package/src/dev-utils/view.d.ts +1 -1
  48. package/src/dev-utils/view.js +1 -1
  49. package/src/index.d.ts +4 -2
  50. package/src/index.js +2 -1
  51. package/src/model/batch.d.ts +1 -1
  52. package/src/model/batch.js +7 -3
  53. package/src/model/differ.d.ts +1 -1
  54. package/src/model/differ.js +1 -1
  55. package/src/model/document.d.ts +1 -1
  56. package/src/model/document.js +1 -1
  57. package/src/model/documentfragment.d.ts +1 -1
  58. package/src/model/documentfragment.js +1 -1
  59. package/src/model/documentselection.d.ts +1 -1
  60. package/src/model/documentselection.js +1 -1
  61. package/src/model/element.d.ts +1 -1
  62. package/src/model/element.js +1 -1
  63. package/src/model/history.d.ts +1 -1
  64. package/src/model/history.js +1 -1
  65. package/src/model/item.d.ts +1 -1
  66. package/src/model/item.js +1 -1
  67. package/src/model/liveposition.d.ts +1 -1
  68. package/src/model/liveposition.js +1 -1
  69. package/src/model/liverange.d.ts +1 -1
  70. package/src/model/liverange.js +1 -1
  71. package/src/model/markercollection.d.ts +1 -1
  72. package/src/model/markercollection.js +1 -1
  73. package/src/model/model.d.ts +1 -1
  74. package/src/model/model.js +1 -1
  75. package/src/model/node.d.ts +1 -1
  76. package/src/model/node.js +1 -1
  77. package/src/model/nodelist.d.ts +1 -1
  78. package/src/model/nodelist.js +1 -1
  79. package/src/model/operation/attributeoperation.d.ts +1 -1
  80. package/src/model/operation/attributeoperation.js +1 -1
  81. package/src/model/operation/detachoperation.d.ts +1 -1
  82. package/src/model/operation/detachoperation.js +1 -1
  83. package/src/model/operation/insertoperation.d.ts +1 -1
  84. package/src/model/operation/insertoperation.js +1 -1
  85. package/src/model/operation/markeroperation.d.ts +1 -1
  86. package/src/model/operation/markeroperation.js +1 -1
  87. package/src/model/operation/mergeoperation.d.ts +1 -1
  88. package/src/model/operation/mergeoperation.js +1 -1
  89. package/src/model/operation/moveoperation.d.ts +1 -1
  90. package/src/model/operation/moveoperation.js +1 -1
  91. package/src/model/operation/nooperation.d.ts +1 -1
  92. package/src/model/operation/nooperation.js +1 -1
  93. package/src/model/operation/operation.d.ts +4 -1
  94. package/src/model/operation/operation.js +2 -2
  95. package/src/model/operation/operationfactory.d.ts +1 -1
  96. package/src/model/operation/operationfactory.js +1 -1
  97. package/src/model/operation/renameoperation.d.ts +1 -1
  98. package/src/model/operation/renameoperation.js +1 -1
  99. package/src/model/operation/rootattributeoperation.d.ts +1 -1
  100. package/src/model/operation/rootattributeoperation.js +1 -1
  101. package/src/model/operation/rootoperation.d.ts +1 -1
  102. package/src/model/operation/rootoperation.js +1 -1
  103. package/src/model/operation/splitoperation.d.ts +1 -1
  104. package/src/model/operation/splitoperation.js +1 -1
  105. package/src/model/operation/transform.d.ts +1 -1
  106. package/src/model/operation/transform.js +1 -1
  107. package/src/model/operation/utils.d.ts +1 -1
  108. package/src/model/operation/utils.js +1 -1
  109. package/src/model/position.d.ts +1 -1
  110. package/src/model/position.js +1 -1
  111. package/src/model/range.d.ts +1 -1
  112. package/src/model/range.js +1 -1
  113. package/src/model/rootelement.d.ts +1 -1
  114. package/src/model/rootelement.js +1 -1
  115. package/src/model/schema.d.ts +1 -1
  116. package/src/model/schema.js +1 -1
  117. package/src/model/selection.d.ts +1 -1
  118. package/src/model/selection.js +9 -2
  119. package/src/model/text.d.ts +1 -1
  120. package/src/model/text.js +1 -1
  121. package/src/model/textproxy.d.ts +1 -1
  122. package/src/model/textproxy.js +1 -1
  123. package/src/model/treewalker.d.ts +17 -1
  124. package/src/model/treewalker.js +26 -1
  125. package/src/model/typecheckable.d.ts +1 -1
  126. package/src/model/typecheckable.js +1 -1
  127. package/src/model/utils/autoparagraphing.d.ts +1 -1
  128. package/src/model/utils/autoparagraphing.js +1 -1
  129. package/src/model/utils/deletecontent.d.ts +1 -1
  130. package/src/model/utils/deletecontent.js +1 -1
  131. package/src/model/utils/getselectedcontent.d.ts +1 -1
  132. package/src/model/utils/getselectedcontent.js +1 -1
  133. package/src/model/utils/insertcontent.d.ts +1 -1
  134. package/src/model/utils/insertcontent.js +1 -1
  135. package/src/model/utils/insertobject.d.ts +1 -1
  136. package/src/model/utils/insertobject.js +1 -1
  137. package/src/model/utils/modifyselection.d.ts +1 -1
  138. package/src/model/utils/modifyselection.js +1 -1
  139. package/src/model/utils/selection-post-fixer.d.ts +1 -1
  140. package/src/model/utils/selection-post-fixer.js +1 -1
  141. package/src/model/writer.d.ts +1 -1
  142. package/src/model/writer.js +1 -1
  143. package/src/view/attributeelement.d.ts +1 -1
  144. package/src/view/attributeelement.js +1 -1
  145. package/src/view/containerelement.d.ts +1 -1
  146. package/src/view/containerelement.js +1 -1
  147. package/src/view/datatransfer.d.ts +1 -1
  148. package/src/view/datatransfer.js +1 -1
  149. package/src/view/document.d.ts +1 -1
  150. package/src/view/document.js +1 -1
  151. package/src/view/documentfragment.d.ts +6 -4
  152. package/src/view/documentfragment.js +7 -7
  153. package/src/view/documentselection.d.ts +1 -1
  154. package/src/view/documentselection.js +1 -1
  155. package/src/view/domconverter.d.ts +1 -1
  156. package/src/view/domconverter.js +1 -1
  157. package/src/view/downcastwriter.d.ts +1 -1
  158. package/src/view/downcastwriter.js +1 -1
  159. package/src/view/editableelement.d.ts +1 -1
  160. package/src/view/editableelement.js +1 -1
  161. package/src/view/element.d.ts +1 -1
  162. package/src/view/element.js +3 -3
  163. package/src/view/elementdefinition.d.ts +1 -1
  164. package/src/view/elementdefinition.js +1 -1
  165. package/src/view/emptyelement.d.ts +1 -1
  166. package/src/view/emptyelement.js +1 -1
  167. package/src/view/filler.d.ts +1 -1
  168. package/src/view/filler.js +1 -1
  169. package/src/view/item.d.ts +1 -1
  170. package/src/view/item.js +1 -1
  171. package/src/view/matcher.d.ts +1 -1
  172. package/src/view/matcher.js +1 -1
  173. package/src/view/node.d.ts +13 -4
  174. package/src/view/node.js +5 -4
  175. package/src/view/observer/arrowkeysobserver.d.ts +1 -1
  176. package/src/view/observer/arrowkeysobserver.js +1 -1
  177. package/src/view/observer/bubblingemittermixin.d.ts +1 -1
  178. package/src/view/observer/bubblingemittermixin.js +1 -1
  179. package/src/view/observer/bubblingeventinfo.d.ts +1 -1
  180. package/src/view/observer/bubblingeventinfo.js +1 -1
  181. package/src/view/observer/clickobserver.d.ts +1 -1
  182. package/src/view/observer/clickobserver.js +1 -1
  183. package/src/view/observer/compositionobserver.d.ts +1 -1
  184. package/src/view/observer/compositionobserver.js +1 -1
  185. package/src/view/observer/domeventdata.d.ts +1 -1
  186. package/src/view/observer/domeventdata.js +1 -1
  187. package/src/view/observer/domeventobserver.d.ts +1 -1
  188. package/src/view/observer/domeventobserver.js +1 -1
  189. package/src/view/observer/fakeselectionobserver.d.ts +1 -1
  190. package/src/view/observer/fakeselectionobserver.js +1 -1
  191. package/src/view/observer/focusobserver.d.ts +1 -1
  192. package/src/view/observer/focusobserver.js +1 -1
  193. package/src/view/observer/inputobserver.d.ts +1 -1
  194. package/src/view/observer/inputobserver.js +1 -1
  195. package/src/view/observer/keyobserver.d.ts +1 -1
  196. package/src/view/observer/keyobserver.js +1 -1
  197. package/src/view/observer/mouseobserver.d.ts +1 -1
  198. package/src/view/observer/mouseobserver.js +1 -1
  199. package/src/view/observer/mutationobserver.d.ts +1 -1
  200. package/src/view/observer/mutationobserver.js +1 -1
  201. package/src/view/observer/observer.d.ts +1 -1
  202. package/src/view/observer/observer.js +1 -1
  203. package/src/view/observer/selectionobserver.d.ts +1 -1
  204. package/src/view/observer/selectionobserver.js +1 -1
  205. package/src/view/observer/tabobserver.d.ts +1 -1
  206. package/src/view/observer/tabobserver.js +1 -1
  207. package/src/view/observer/touchobserver.d.ts +73 -0
  208. package/src/view/observer/touchobserver.js +29 -0
  209. package/src/view/placeholder.d.ts +1 -1
  210. package/src/view/placeholder.js +23 -17
  211. package/src/view/position.d.ts +1 -1
  212. package/src/view/position.js +1 -1
  213. package/src/view/range.d.ts +1 -1
  214. package/src/view/range.js +1 -1
  215. package/src/view/rawelement.d.ts +1 -1
  216. package/src/view/rawelement.js +1 -1
  217. package/src/view/renderer.d.ts +1 -1
  218. package/src/view/renderer.js +1 -1
  219. package/src/view/rooteditableelement.d.ts +1 -1
  220. package/src/view/rooteditableelement.js +1 -1
  221. package/src/view/selection.d.ts +1 -1
  222. package/src/view/selection.js +1 -1
  223. package/src/view/styles/background.d.ts +1 -1
  224. package/src/view/styles/background.js +1 -1
  225. package/src/view/styles/border.d.ts +1 -1
  226. package/src/view/styles/border.js +1 -1
  227. package/src/view/styles/margin.d.ts +1 -1
  228. package/src/view/styles/margin.js +1 -1
  229. package/src/view/styles/padding.d.ts +1 -1
  230. package/src/view/styles/padding.js +1 -1
  231. package/src/view/styles/utils.d.ts +1 -1
  232. package/src/view/styles/utils.js +1 -1
  233. package/src/view/stylesmap.d.ts +1 -1
  234. package/src/view/stylesmap.js +1 -1
  235. package/src/view/text.d.ts +1 -1
  236. package/src/view/text.js +1 -1
  237. package/src/view/textproxy.d.ts +1 -1
  238. package/src/view/textproxy.js +1 -1
  239. package/src/view/treewalker.d.ts +17 -1
  240. package/src/view/treewalker.js +25 -1
  241. package/src/view/typecheckable.d.ts +1 -1
  242. package/src/view/typecheckable.js +1 -1
  243. package/src/view/uielement.d.ts +1 -1
  244. package/src/view/uielement.js +1 -1
  245. package/src/view/upcastwriter.d.ts +1 -1
  246. package/src/view/upcastwriter.js +1 -1
  247. package/src/view/view.d.ts +1 -1
  248. package/src/view/view.js +1 -1
  249. package/theme/placeholder.css +1 -1
  250. package/theme/renderer.css +1 -1
  251. package/dist/controller/datacontroller.d.ts +0 -339
  252. package/dist/controller/editingcontroller.d.ts +0 -102
  253. package/dist/conversion/conversion.d.ts +0 -482
  254. package/dist/conversion/conversionhelpers.d.ts +0 -30
  255. package/dist/conversion/downcastdispatcher.d.ts +0 -566
  256. package/dist/conversion/downcasthelpers.d.ts +0 -1194
  257. package/dist/conversion/mapper.d.ts +0 -507
  258. package/dist/conversion/modelconsumable.d.ts +0 -205
  259. package/dist/conversion/upcastdispatcher.d.ts +0 -496
  260. package/dist/conversion/upcasthelpers.d.ts +0 -503
  261. package/dist/conversion/viewconsumable.d.ts +0 -373
  262. package/dist/dataprocessor/basichtmlwriter.d.ts +0 -22
  263. package/dist/dataprocessor/dataprocessor.d.ts +0 -65
  264. package/dist/dataprocessor/htmldataprocessor.d.ts +0 -80
  265. package/dist/dataprocessor/htmlwriter.d.ts +0 -20
  266. package/dist/dataprocessor/xmldataprocessor.d.ts +0 -94
  267. package/dist/dev-utils/model.d.ts +0 -130
  268. package/dist/dev-utils/operationreplayer.d.ts +0 -55
  269. package/dist/dev-utils/utils.d.ts +0 -41
  270. package/dist/dev-utils/view.d.ts +0 -324
  271. package/dist/index.d.ts +0 -122
  272. package/dist/model/batch.d.ts +0 -110
  273. package/dist/model/differ.d.ts +0 -511
  274. package/dist/model/document.d.ts +0 -278
  275. package/dist/model/documentfragment.d.ts +0 -223
  276. package/dist/model/documentselection.d.ts +0 -424
  277. package/dist/model/element.d.ts +0 -191
  278. package/dist/model/history.d.ts +0 -118
  279. package/dist/model/item.d.ts +0 -18
  280. package/dist/model/liveposition.d.ts +0 -81
  281. package/dist/model/liverange.d.ts +0 -106
  282. package/dist/model/markercollection.d.ts +0 -339
  283. package/dist/model/model.d.ts +0 -923
  284. package/dist/model/node.d.ts +0 -262
  285. package/dist/model/nodelist.d.ts +0 -119
  286. package/dist/model/operation/attributeoperation.d.ts +0 -107
  287. package/dist/model/operation/detachoperation.d.ts +0 -64
  288. package/dist/model/operation/insertoperation.d.ts +0 -94
  289. package/dist/model/operation/markeroperation.d.ts +0 -95
  290. package/dist/model/operation/mergeoperation.d.ts +0 -104
  291. package/dist/model/operation/moveoperation.d.ts +0 -100
  292. package/dist/model/operation/nooperation.d.ts +0 -42
  293. package/dist/model/operation/operation.d.ts +0 -100
  294. package/dist/model/operation/operationfactory.d.ts +0 -22
  295. package/dist/model/operation/renameoperation.d.ts +0 -87
  296. package/dist/model/operation/rootattributeoperation.d.ts +0 -102
  297. package/dist/model/operation/rootoperation.d.ts +0 -80
  298. package/dist/model/operation/splitoperation.d.ts +0 -113
  299. package/dist/model/operation/transform.d.ts +0 -104
  300. package/dist/model/operation/utils.d.ts +0 -75
  301. package/dist/model/position.d.ts +0 -549
  302. package/dist/model/range.d.ts +0 -462
  303. package/dist/model/rootelement.d.ts +0 -64
  304. package/dist/model/schema.d.ts +0 -1334
  305. package/dist/model/selection.d.ts +0 -486
  306. package/dist/model/text.d.ts +0 -70
  307. package/dist/model/textproxy.d.ts +0 -148
  308. package/dist/model/treewalker.d.ts +0 -190
  309. package/dist/model/typecheckable.d.ts +0 -289
  310. package/dist/model/utils/autoparagraphing.d.ts +0 -41
  311. package/dist/model/utils/deletecontent.d.ts +0 -62
  312. package/dist/model/utils/getselectedcontent.d.ts +0 -34
  313. package/dist/model/utils/insertcontent.d.ts +0 -50
  314. package/dist/model/utils/insertobject.d.ts +0 -51
  315. package/dist/model/utils/modifyselection.d.ts +0 -52
  316. package/dist/model/utils/selection-post-fixer.d.ts +0 -78
  317. package/dist/model/writer.d.ts +0 -855
  318. package/dist/view/attributeelement.d.ts +0 -112
  319. package/dist/view/containerelement.d.ts +0 -53
  320. package/dist/view/datatransfer.d.ts +0 -83
  321. package/dist/view/document.d.ts +0 -188
  322. package/dist/view/documentfragment.d.ts +0 -157
  323. package/dist/view/documentselection.d.ts +0 -310
  324. package/dist/view/domconverter.d.ts +0 -665
  325. package/dist/view/downcastwriter.d.ts +0 -1000
  326. package/dist/view/editableelement.d.ts +0 -66
  327. package/dist/view/element.d.ts +0 -472
  328. package/dist/view/elementdefinition.d.ts +0 -91
  329. package/dist/view/emptyelement.d.ts +0 -45
  330. package/dist/view/filler.d.ts +0 -115
  331. package/dist/view/item.d.ts +0 -18
  332. package/dist/view/matcher.d.ts +0 -490
  333. package/dist/view/node.d.ts +0 -166
  334. package/dist/view/observer/arrowkeysobserver.d.ts +0 -49
  335. package/dist/view/observer/bubblingemittermixin.d.ts +0 -170
  336. package/dist/view/observer/bubblingeventinfo.d.ts +0 -51
  337. package/dist/view/observer/clickobserver.d.ts +0 -47
  338. package/dist/view/observer/compositionobserver.d.ts +0 -86
  339. package/dist/view/observer/domeventdata.d.ts +0 -54
  340. package/dist/view/observer/domeventobserver.d.ts +0 -82
  341. package/dist/view/observer/fakeselectionobserver.d.ts +0 -51
  342. package/dist/view/observer/focusobserver.d.ts +0 -98
  343. package/dist/view/observer/inputobserver.d.ts +0 -90
  344. package/dist/view/observer/keyobserver.d.ts +0 -70
  345. package/dist/view/observer/mouseobserver.d.ts +0 -93
  346. package/dist/view/observer/mutationobserver.d.ts +0 -119
  347. package/dist/view/observer/observer.d.ts +0 -93
  348. package/dist/view/observer/selectionobserver.d.ts +0 -151
  349. package/dist/view/observer/tabobserver.d.ts +0 -50
  350. package/dist/view/placeholder.d.ts +0 -100
  351. package/dist/view/position.d.ts +0 -192
  352. package/dist/view/range.d.ts +0 -283
  353. package/dist/view/rawelement.d.ts +0 -77
  354. package/dist/view/renderer.d.ts +0 -281
  355. package/dist/view/rooteditableelement.d.ts +0 -45
  356. package/dist/view/selection.d.ts +0 -379
  357. package/dist/view/styles/background.d.ts +0 -37
  358. package/dist/view/styles/border.d.ts +0 -47
  359. package/dist/view/styles/margin.d.ts +0 -33
  360. package/dist/view/styles/padding.d.ts +0 -33
  361. package/dist/view/styles/utils.d.ts +0 -97
  362. package/dist/view/stylesmap.d.ts +0 -685
  363. package/dist/view/text.d.ts +0 -78
  364. package/dist/view/textproxy.d.ts +0 -101
  365. package/dist/view/treewalker.d.ts +0 -199
  366. package/dist/view/typecheckable.d.ts +0 -452
  367. package/dist/view/uielement.d.ts +0 -100
  368. package/dist/view/upcastwriter.d.ts +0 -421
  369. package/dist/view/view.d.ts +0 -488
@@ -1,80 +0,0 @@
1
- /**
2
- * @license Copyright (c) 2003-2024, 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
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
7
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
8
- */
9
- /**
10
- * @module engine/model/operation/rootoperation
11
- */
12
- import Operation from './operation.js';
13
- import type Document from '../document.js';
14
- import type { Selectable } from '../selection.js';
15
- /**
16
- * Operation that creates (or attaches) or detaches a root element.
17
- */
18
- export default class RootOperation extends Operation {
19
- /**
20
- * Root name to create or detach.
21
- */
22
- readonly rootName: string;
23
- /**
24
- * Root element name.
25
- */
26
- readonly elementName: string;
27
- /**
28
- * Specifies whether the operation adds (`true`) or detaches the root (`false`).
29
- */
30
- readonly isAdd: boolean;
31
- /**
32
- * Document which owns the root.
33
- */
34
- private readonly _document;
35
- /**
36
- * Creates an operation that creates or removes a root element.
37
- *
38
- * @param rootName Root name to create or detach.
39
- * @param elementName Root element name.
40
- * @param isAdd Specifies whether the operation adds (`true`) or detaches the root (`false`).
41
- * @param document Document which owns the root.
42
- * @param baseVersion Document {@link module:engine/model/document~Document#version} on which operation can be applied.
43
- */
44
- constructor(rootName: string, elementName: string, isAdd: boolean, document: Document, baseVersion: number);
45
- /**
46
- * @inheritDoc
47
- */
48
- get type(): 'addRoot' | 'detachRoot';
49
- /**
50
- * @inheritDoc
51
- */
52
- get affectedSelectable(): Selectable;
53
- /**
54
- * @inheritDoc
55
- */
56
- clone(): RootOperation;
57
- /**
58
- * @inheritDoc
59
- */
60
- getReversed(): RootOperation;
61
- /**
62
- * @inheritDoc
63
- */
64
- _execute(): void;
65
- /**
66
- * @inheritDoc
67
- */
68
- toJSON(): unknown;
69
- /**
70
- * @inheritDoc
71
- */
72
- static get className(): string;
73
- /**
74
- * Creates `RootOperation` object from deserialized object, i.e. from parsed JSON string.
75
- *
76
- * @param json Deserialized JSON object.
77
- * @param document Document on which this operation will be applied.
78
- */
79
- static fromJSON(json: any, document: Document): RootOperation;
80
- }
@@ -1,113 +0,0 @@
1
- /**
2
- * @license Copyright (c) 2003-2024, 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
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
7
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
8
- */
9
- /**
10
- * @module engine/model/operation/splitoperation
11
- */
12
- import Operation from './operation.js';
13
- import Position from '../position.js';
14
- import Range from '../range.js';
15
- import type Document from '../document.js';
16
- import type { Selectable } from '../selection.js';
17
- /**
18
- * Operation to split {@link module:engine/model/element~Element an element} at given
19
- * {@link module:engine/model/operation/splitoperation~SplitOperation#splitPosition split position} into two elements,
20
- * both containing a part of the element's original content.
21
- */
22
- export default class SplitOperation extends Operation {
23
- /**
24
- * Position at which an element should be split.
25
- */
26
- splitPosition: Position;
27
- /**
28
- * Total offset size of elements that are in the split element after `position`.
29
- */
30
- howMany: number;
31
- /**
32
- * Position at which the clone of split element (or element from graveyard) will be inserted.
33
- */
34
- insertionPosition: Position;
35
- /**
36
- * Position in the graveyard root before the element which should be used as a parent of the nodes after `position`.
37
- * If it is not set, a copy of the the `position` parent will be used.
38
- *
39
- * The default behavior is to clone the split element. Element from graveyard is used during undo.
40
- */
41
- graveyardPosition: Position | null;
42
- /**
43
- * Creates a split operation.
44
- *
45
- * @param splitPosition Position at which an element should be split.
46
- * @param howMany Total offset size of elements that are in the split element after `position`.
47
- * @param insertionPosition Position at which the clone of split element (or element from graveyard) will be inserted.
48
- * @param graveyardPosition Position in the graveyard root before the element which
49
- * should be used as a parent of the nodes after `position`. If it is not set, a copy of the the `position` parent will be used.
50
- * @param baseVersion Document {@link module:engine/model/document~Document#version} on which operation
51
- * can be applied or `null` if the operation operates on detached (non-document) tree.
52
- */
53
- constructor(splitPosition: Position, howMany: number, insertionPosition: Position, graveyardPosition: Position | null, baseVersion: number | null);
54
- /**
55
- * @inheritDoc
56
- */
57
- get type(): 'split';
58
- /**
59
- * Position inside the new clone of a split element.
60
- *
61
- * This is a position where nodes that are after the split position will be moved to.
62
- */
63
- get moveTargetPosition(): Position;
64
- /**
65
- * Artificial range that contains all the nodes from the split element that will be moved to the new element.
66
- * The range starts at {@link #splitPosition} and ends in the same parent, at `POSITIVE_INFINITY` offset.
67
- */
68
- get movedRange(): Range;
69
- /**
70
- * @inheritDoc
71
- */
72
- get affectedSelectable(): Selectable;
73
- /**
74
- * Creates and returns an operation that has the same parameters as this operation.
75
- *
76
- * @returns Clone of this operation.
77
- */
78
- clone(): SplitOperation;
79
- /**
80
- * See {@link module:engine/model/operation/operation~Operation#getReversed `Operation#getReversed()`}.
81
- */
82
- getReversed(): Operation;
83
- /**
84
- * @inheritDoc
85
- * @internal
86
- */
87
- _validate(): void;
88
- /**
89
- * @inheritDoc
90
- * @internal
91
- */
92
- _execute(): void;
93
- /**
94
- * @inheritDoc
95
- */
96
- toJSON(): unknown;
97
- /**
98
- * @inheritDoc
99
- */
100
- static get className(): string;
101
- /**
102
- * Helper function that returns a default insertion position basing on given `splitPosition`. The default insertion
103
- * position is after the split element.
104
- */
105
- static getInsertionPosition(splitPosition: Position): Position;
106
- /**
107
- * Creates `SplitOperation` object from deserialized object, i.e. from parsed JSON string.
108
- *
109
- * @param json Deserialized JSON object.
110
- * @param document Document on which this operation will be applied.
111
- */
112
- static fromJSON(json: any, document: Document): SplitOperation;
113
- }
@@ -1,104 +0,0 @@
1
- /**
2
- * @license Copyright (c) 2003-2024, 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
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
7
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
8
- */
9
- import type Operation from './operation.js';
10
- import type Document from '../document.js';
11
- /**
12
- * Transforms operation `a` by operation `b`.
13
- *
14
- * @param a Operation to be transformed.
15
- * @param b Operation to transform by.
16
- * @param context Transformation context for this transformation.
17
- * @returns Transformation result.
18
- */
19
- export declare function transform(a: Operation, b: Operation, context?: TransformationContext): Array<Operation>;
20
- /**
21
- * Performs a transformation of two sets of operations - `operationsA` and `operationsB`. The transformation is two-way -
22
- * both transformed `operationsA` and transformed `operationsB` are returned.
23
- *
24
- * Note, that the first operation in each set should base on the same document state (
25
- * {@link module:engine/model/document~Document#version document version}).
26
- *
27
- * It is assumed that `operationsA` are "more important" during conflict resolution between two operations.
28
- *
29
- * New copies of both passed arrays and operations inside them are returned. Passed arguments are not altered.
30
- *
31
- * Base versions of the transformed operations sets are updated accordingly. For example, assume that base versions are `4`
32
- * and there are `3` operations in `operationsA` and `5` operations in `operationsB`. Then:
33
- *
34
- * * transformed `operationsA` will start from base version `9` (`4` base version + `5` operations B),
35
- * * transformed `operationsB` will start from base version `7` (`4` base version + `3` operations A).
36
- *
37
- * If no operation was broken into two during transformation, then both sets will end up with an operation that bases on version `11`:
38
- *
39
- * * transformed `operationsA` start from `9` and there are `3` of them, so the last will have `baseVersion` equal to `11`,
40
- * * transformed `operationsB` start from `7` and there are `5` of them, so the last will have `baseVersion` equal to `11`.
41
- *
42
- * @param operationsA
43
- * @param operationsB
44
- * @param options Additional transformation options.
45
- * @param options.document Document which the operations change.
46
- * @param options.useRelations Whether during transformation relations should be used (used during undo for better conflict resolution).
47
- * @param options.padWithNoOps Whether additional {@link module:engine/model/operation/nooperation~NoOperation}s
48
- * should be added to the transformation results to force the same last base version for both transformed sets (in case
49
- * if some operations got broken into multiple operations during transformation).
50
- * @param options.forceWeakRemove If set to `false`, remove operation will be always stronger than move operation,
51
- * so the removed nodes won't end up back in the document root. When set to `true`, context data will be used.
52
- * @returns Transformation result.
53
- */
54
- export declare function transformSets(operationsA: Array<Operation>, operationsB: Array<Operation>, options: {
55
- document: Document;
56
- useRelations?: boolean;
57
- padWithNoOps?: boolean;
58
- forceWeakRemove?: boolean;
59
- }): TransformSetsResult;
60
- /**
61
- * The result of {@link module:engine/model/operation/transform~transformSets}.
62
- */
63
- export interface TransformSetsResult {
64
- /**
65
- * Transformed `operationsA`.
66
- */
67
- operationsA: Array<Operation>;
68
- /**
69
- * Transformed `operationsB`.
70
- */
71
- operationsB: Array<Operation>;
72
- /**
73
- * A map that links transformed operations to original operations. The keys are the transformed
74
- * operations and the values are the original operations from the input (`operationsA` and `operationsB`).
75
- */
76
- originalOperations: Map<Operation, Operation>;
77
- }
78
- /**
79
- * Holds additional contextual information about a transformed pair of operations (`a` and `b`). Those information
80
- * can be used for better conflict resolving.
81
- */
82
- export type TransformationContext = {
83
- /**
84
- * Whether `a` is strong operation in this transformation, or weak.
85
- */
86
- aIsStrong?: boolean;
87
- /**
88
- * Whether `a` operation was undone.
89
- */
90
- aWasUndone?: boolean;
91
- /**
92
- * Whether `b` operation was undone.
93
- */
94
- bWasUndone?: boolean;
95
- /**
96
- * The relation between `a` operation and an operation undone by `b` operation.
97
- */
98
- abRelation?: any;
99
- /**
100
- * The relation between `b` operation and an operation undone by `a` operation.
101
- */
102
- baRelation?: any;
103
- forceWeakRemove?: boolean;
104
- };
@@ -1,75 +0,0 @@
1
- /**
2
- * @license Copyright (c) 2003-2024, 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
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
7
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
8
- */
9
- /**
10
- * @module engine/model/operation/utils
11
- */
12
- import Node from '../node.js';
13
- import Range from '../range.js';
14
- import type DocumentFragment from '../documentfragment.js';
15
- import type Item from '../item.js';
16
- import type NodeList from '../nodelist.js';
17
- import type Position from '../position.js';
18
- /**
19
- * Inserts given nodes at given position.
20
- *
21
- * @internal
22
- * @param position Position at which nodes should be inserted.
23
- * @param normalizedNodes Nodes to insert.
24
- * @returns Range spanning over inserted elements.
25
- */
26
- export declare function _insert(position: Position, nodes: NodeSet): Range;
27
- /**
28
- * Removed nodes in given range. Only {@link module:engine/model/range~Range#isFlat flat} ranges are accepted.
29
- *
30
- * @internal
31
- * @param range Range containing nodes to remove.
32
- */
33
- export declare function _remove(this: any, range: Range): Array<Node>;
34
- /**
35
- * Moves nodes in given range to given target position. Only {@link module:engine/model/range~Range#isFlat flat} ranges are accepted.
36
- *
37
- * @internal
38
- * @param sourceRange Range containing nodes to move.
39
- * @param targetPosition Position to which nodes should be moved.
40
- * @returns Range containing moved nodes.
41
- */
42
- export declare function _move(this: any, sourceRange: Range, targetPosition: Position): Range;
43
- /**
44
- * Sets given attribute on nodes in given range. The attributes are only set on top-level nodes of the range, not on its children.
45
- *
46
- * @internal
47
- * @param range Range containing nodes that should have the attribute set. Must be a flat range.
48
- * @param key Key of attribute to set.
49
- * @param value Attribute value.
50
- */
51
- export declare function _setAttribute(range: Range, key: string, value: unknown): void;
52
- /**
53
- * Normalizes given object or an array of objects to an array of {@link module:engine/model/node~Node nodes}. See
54
- * {@link ~NodeSet NodeSet} for details on how normalization is performed.
55
- *
56
- * @internal
57
- * @param nodes Objects to normalize.
58
- * @returns Normalized nodes.
59
- */
60
- export declare function _normalizeNodes(nodes: NodeSet): Array<Node>;
61
- /**
62
- * Value that can be normalized to an array of {@link module:engine/model/node~Node nodes}.
63
- *
64
- * Non-arrays are normalized as follows:
65
- * * {@link module:engine/model/node~Node Node} is left as is,
66
- * * {@link module:engine/model/textproxy~TextProxy TextProxy} and `string` are normalized to {@link module:engine/model/text~Text Text},
67
- * * {@link module:engine/model/nodelist~NodeList NodeList} is normalized to an array containing all nodes that are in that node list,
68
- * * {@link module:engine/model/documentfragment~DocumentFragment DocumentFragment} is normalized to an array containing all of it's
69
- * * children.
70
- *
71
- * Arrays are processed item by item like non-array values and flattened to one array. Normalization always results in
72
- * a flat array of {@link module:engine/model/node~Node nodes}. Consecutive text nodes (or items normalized to text nodes) will be
73
- * merged if they have same attributes.
74
- */
75
- export type NodeSet = Item | string | NodeList | DocumentFragment | Iterable<Item | string | NodeList | DocumentFragment>;