@ckeditor/ckeditor5-table 0.0.0-nightly-next-20260127.0 → 0.0.0-nightly-20260128.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 (356) hide show
  1. package/build/table.js +5 -0
  2. package/build/translations/af.js +1 -0
  3. package/build/translations/ar.js +1 -0
  4. package/build/translations/ast.js +1 -0
  5. package/build/translations/az.js +1 -0
  6. package/build/translations/be.js +1 -0
  7. package/build/translations/bg.js +1 -0
  8. package/build/translations/bn.js +1 -0
  9. package/build/translations/bs.js +1 -0
  10. package/build/translations/ca.js +1 -0
  11. package/build/translations/cs.js +1 -0
  12. package/build/translations/da.js +1 -0
  13. package/build/translations/de-ch.js +1 -0
  14. package/build/translations/de.js +1 -0
  15. package/build/translations/el.js +1 -0
  16. package/build/translations/en-au.js +1 -0
  17. package/build/translations/en-gb.js +1 -0
  18. package/build/translations/eo.js +1 -0
  19. package/build/translations/es-co.js +1 -0
  20. package/build/translations/es.js +1 -0
  21. package/build/translations/et.js +1 -0
  22. package/build/translations/eu.js +1 -0
  23. package/build/translations/fa.js +1 -0
  24. package/build/translations/fi.js +1 -0
  25. package/build/translations/fr.js +1 -0
  26. package/build/translations/gl.js +1 -0
  27. package/build/translations/gu.js +1 -0
  28. package/build/translations/he.js +1 -0
  29. package/build/translations/hi.js +1 -0
  30. package/build/translations/hr.js +1 -0
  31. package/build/translations/hu.js +1 -0
  32. package/build/translations/hy.js +1 -0
  33. package/build/translations/id.js +1 -0
  34. package/build/translations/it.js +1 -0
  35. package/build/translations/ja.js +1 -0
  36. package/build/translations/jv.js +1 -0
  37. package/build/translations/kk.js +1 -0
  38. package/build/translations/km.js +1 -0
  39. package/build/translations/kn.js +1 -0
  40. package/build/translations/ko.js +1 -0
  41. package/build/translations/ku.js +1 -0
  42. package/build/translations/lt.js +1 -0
  43. package/build/translations/lv.js +1 -0
  44. package/build/translations/ms.js +1 -0
  45. package/build/translations/nb.js +1 -0
  46. package/build/translations/ne.js +1 -0
  47. package/build/translations/nl.js +1 -0
  48. package/build/translations/no.js +1 -0
  49. package/build/translations/oc.js +1 -0
  50. package/build/translations/pl.js +1 -0
  51. package/build/translations/pt-br.js +1 -0
  52. package/build/translations/pt.js +1 -0
  53. package/build/translations/ro.js +1 -0
  54. package/build/translations/ru.js +1 -0
  55. package/build/translations/si.js +1 -0
  56. package/build/translations/sk.js +1 -0
  57. package/build/translations/sl.js +1 -0
  58. package/build/translations/sq.js +1 -0
  59. package/build/translations/sr-latn.js +1 -0
  60. package/build/translations/sr.js +1 -0
  61. package/build/translations/sv.js +1 -0
  62. package/build/translations/th.js +1 -0
  63. package/build/translations/ti.js +1 -0
  64. package/build/translations/tk.js +1 -0
  65. package/build/translations/tr.js +1 -0
  66. package/build/translations/tt.js +1 -0
  67. package/build/translations/ug.js +1 -0
  68. package/build/translations/uk.js +1 -0
  69. package/build/translations/ur.js +1 -0
  70. package/build/translations/uz.js +1 -0
  71. package/build/translations/vi.js +1 -0
  72. package/build/translations/zh-cn.js +1 -0
  73. package/build/translations/zh.js +1 -0
  74. package/ckeditor5-metadata.json +7 -16
  75. package/dist/index-content.css +30 -30
  76. package/dist/index-editor.css +170 -104
  77. package/dist/index.css +237 -147
  78. package/dist/index.css.map +1 -1
  79. package/dist/index.js +2433 -448
  80. package/dist/index.js.map +1 -1
  81. package/lang/contexts.json +82 -0
  82. package/lang/translations/af.po +332 -0
  83. package/lang/translations/ar.po +332 -0
  84. package/lang/translations/ast.po +332 -0
  85. package/lang/translations/az.po +332 -0
  86. package/lang/translations/be.po +332 -0
  87. package/lang/translations/bg.po +332 -0
  88. package/lang/translations/bn.po +334 -0
  89. package/lang/translations/bs.po +332 -0
  90. package/lang/translations/ca.po +332 -0
  91. package/lang/translations/cs.po +332 -0
  92. package/lang/translations/da.po +332 -0
  93. package/lang/translations/de-ch.po +332 -0
  94. package/lang/translations/de.po +332 -0
  95. package/lang/translations/el.po +332 -0
  96. package/lang/translations/en-au.po +332 -0
  97. package/lang/translations/en-gb.po +332 -0
  98. package/lang/translations/en.po +332 -0
  99. package/lang/translations/eo.po +332 -0
  100. package/lang/translations/es-co.po +332 -0
  101. package/lang/translations/es.po +332 -0
  102. package/lang/translations/et.po +332 -0
  103. package/lang/translations/eu.po +332 -0
  104. package/lang/translations/fa.po +332 -0
  105. package/lang/translations/fi.po +332 -0
  106. package/lang/translations/fr.po +332 -0
  107. package/lang/translations/gl.po +332 -0
  108. package/lang/translations/gu.po +332 -0
  109. package/lang/translations/he.po +332 -0
  110. package/lang/translations/hi.po +332 -0
  111. package/lang/translations/hr.po +332 -0
  112. package/lang/translations/hu.po +332 -0
  113. package/lang/translations/hy.po +332 -0
  114. package/lang/translations/id.po +332 -0
  115. package/lang/translations/it.po +332 -0
  116. package/lang/translations/ja.po +332 -0
  117. package/lang/translations/jv.po +332 -0
  118. package/lang/translations/kk.po +332 -0
  119. package/lang/translations/km.po +332 -0
  120. package/lang/translations/kn.po +332 -0
  121. package/lang/translations/ko.po +332 -0
  122. package/lang/translations/ku.po +332 -0
  123. package/lang/translations/lt.po +332 -0
  124. package/lang/translations/lv.po +332 -0
  125. package/lang/translations/ms.po +332 -0
  126. package/lang/translations/nb.po +332 -0
  127. package/lang/translations/ne.po +332 -0
  128. package/lang/translations/nl.po +332 -0
  129. package/lang/translations/no.po +332 -0
  130. package/lang/translations/oc.po +332 -0
  131. package/lang/translations/pl.po +332 -0
  132. package/lang/translations/pt-br.po +332 -0
  133. package/lang/translations/pt.po +332 -0
  134. package/lang/translations/ro.po +332 -0
  135. package/lang/translations/ru.po +332 -0
  136. package/lang/translations/si.po +332 -0
  137. package/lang/translations/sk.po +332 -0
  138. package/lang/translations/sl.po +332 -0
  139. package/lang/translations/sq.po +332 -0
  140. package/lang/translations/sr-latn.po +332 -0
  141. package/lang/translations/sr.po +332 -0
  142. package/lang/translations/sv.po +332 -0
  143. package/lang/translations/th.po +332 -0
  144. package/lang/translations/ti.po +332 -0
  145. package/lang/translations/tk.po +332 -0
  146. package/lang/translations/tr.po +332 -0
  147. package/lang/translations/tt.po +332 -0
  148. package/lang/translations/ug.po +332 -0
  149. package/lang/translations/uk.po +332 -0
  150. package/lang/translations/ur.po +332 -0
  151. package/lang/translations/uz.po +332 -0
  152. package/lang/translations/vi.po +332 -0
  153. package/lang/translations/zh-cn.po +332 -0
  154. package/lang/translations/zh.po +332 -0
  155. package/package.json +49 -26
  156. package/{dist → src}/augmentation.d.ts +15 -0
  157. package/src/augmentation.js +5 -0
  158. package/{dist → src}/commands/insertcolumncommand.d.ts +1 -1
  159. package/src/commands/insertcolumncommand.js +71 -0
  160. package/{dist → src}/commands/insertrowcommand.d.ts +1 -1
  161. package/src/commands/insertrowcommand.js +70 -0
  162. package/{dist → src}/commands/inserttablecommand.d.ts +1 -1
  163. package/src/commands/inserttablecommand.js +69 -0
  164. package/{dist → src}/commands/inserttablelayoutcommand.d.ts +1 -1
  165. package/src/commands/inserttablelayoutcommand.js +65 -0
  166. package/{dist → src}/commands/mergecellcommand.d.ts +3 -3
  167. package/src/commands/mergecellcommand.js +206 -0
  168. package/{dist → src}/commands/mergecellscommand.d.ts +1 -1
  169. package/src/commands/mergecellscommand.js +94 -0
  170. package/{dist → src}/commands/removecolumncommand.d.ts +1 -1
  171. package/src/commands/removecolumncommand.js +109 -0
  172. package/{dist → src}/commands/removerowcommand.d.ts +1 -1
  173. package/src/commands/removerowcommand.js +82 -0
  174. package/{dist → src}/commands/selectcolumncommand.d.ts +1 -1
  175. package/src/commands/selectcolumncommand.js +60 -0
  176. package/{dist → src}/commands/selectrowcommand.d.ts +1 -1
  177. package/src/commands/selectrowcommand.js +56 -0
  178. package/{dist → src}/commands/setheadercolumncommand.d.ts +1 -1
  179. package/src/commands/setheadercolumncommand.js +76 -0
  180. package/{dist → src}/commands/setheaderrowcommand.d.ts +1 -1
  181. package/src/commands/setheaderrowcommand.js +83 -0
  182. package/{dist → src}/commands/splitcellcommand.d.ts +1 -1
  183. package/src/commands/splitcellcommand.js +58 -0
  184. package/{dist → src}/converters/downcast.d.ts +2 -2
  185. package/src/converters/downcast.js +298 -0
  186. package/{dist → src}/converters/table-caption-post-fixer.d.ts +1 -1
  187. package/src/converters/table-caption-post-fixer.js +55 -0
  188. package/{dist → src}/converters/table-cell-paragraph-post-fixer.d.ts +1 -1
  189. package/src/converters/table-cell-paragraph-post-fixer.js +109 -0
  190. package/{dist → src}/converters/table-cell-refresh-handler.d.ts +1 -1
  191. package/src/converters/table-cell-refresh-handler.js +47 -0
  192. package/{dist → src}/converters/table-headings-refresh-handler.d.ts +1 -1
  193. package/src/converters/table-headings-refresh-handler.js +51 -0
  194. package/{dist → src}/converters/table-layout-post-fixer.d.ts +1 -1
  195. package/src/converters/table-layout-post-fixer.js +369 -0
  196. package/{dist → src}/converters/tableproperties.d.ts +2 -2
  197. package/src/converters/tableproperties.js +444 -0
  198. package/{dist → src}/converters/upcasttable.d.ts +1 -1
  199. package/src/converters/upcasttable.js +385 -0
  200. package/{dist → src}/index.d.ts +5 -2
  201. package/src/index.js +98 -0
  202. package/{dist → src}/plaintableoutput.d.ts +1 -1
  203. package/src/plaintableoutput.js +49 -0
  204. package/{dist → src}/table.d.ts +2 -2
  205. package/src/table.js +50 -0
  206. package/{dist → src}/tablecaption/tablecaptionediting.d.ts +2 -2
  207. package/src/tablecaption/tablecaptionediting.js +136 -0
  208. package/{dist → src}/tablecaption/tablecaptionui.d.ts +1 -1
  209. package/src/tablecaption/tablecaptionui.js +64 -0
  210. package/{dist → src}/tablecaption/toggletablecaptioncommand.d.ts +1 -1
  211. package/src/tablecaption/toggletablecaptioncommand.js +105 -0
  212. package/{dist → src}/tablecaption/utils.d.ts +1 -1
  213. package/src/tablecaption/utils.js +61 -0
  214. package/{dist → src}/tablecaption.d.ts +1 -1
  215. package/src/tablecaption.js +34 -0
  216. package/{dist → src}/tablecellproperties/commands/tablecellbackgroundcolorcommand.d.ts +1 -1
  217. package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.js +30 -0
  218. package/{dist → src}/tablecellproperties/commands/tablecellbordercolorcommand.d.ts +2 -2
  219. package/src/tablecellproperties/commands/tablecellbordercolorcommand.js +44 -0
  220. package/{dist → src}/tablecellproperties/commands/tablecellborderstylecommand.d.ts +2 -2
  221. package/src/tablecellproperties/commands/tablecellborderstylecommand.js +44 -0
  222. package/{dist → src}/tablecellproperties/commands/tablecellborderwidthcommand.d.ts +2 -2
  223. package/src/tablecellproperties/commands/tablecellborderwidthcommand.js +64 -0
  224. package/{dist → src}/tablecellproperties/commands/tablecellheightcommand.d.ts +1 -1
  225. package/src/tablecellproperties/commands/tablecellheightcommand.js +51 -0
  226. package/{dist → src}/tablecellproperties/commands/tablecellhorizontalalignmentcommand.d.ts +1 -1
  227. package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.js +30 -0
  228. package/{dist → src}/tablecellproperties/commands/tablecellpaddingcommand.d.ts +2 -2
  229. package/src/tablecellproperties/commands/tablecellpaddingcommand.js +64 -0
  230. package/{dist → src}/tablecellproperties/commands/tablecellpropertycommand.d.ts +2 -2
  231. package/src/tablecellproperties/commands/tablecellpropertycommand.js +138 -0
  232. package/{dist → src}/tablecellproperties/commands/tablecelltypecommand.d.ts +6 -2
  233. package/src/tablecellproperties/commands/tablecelltypecommand.js +167 -0
  234. package/{dist → src}/tablecellproperties/commands/tablecellverticalalignmentcommand.d.ts +1 -1
  235. package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.js +38 -0
  236. package/{dist → src}/tablecellproperties/tablecellpropertiesediting.d.ts +1 -1
  237. package/src/tablecellproperties/tablecellpropertiesediting.js +412 -0
  238. package/{dist → src}/tablecellproperties/tablecellpropertiesui.d.ts +2 -2
  239. package/src/tablecellproperties/tablecellpropertiesui.js +385 -0
  240. package/src/tablecellproperties/tablecellpropertiesuiexperimental.d.ts +128 -0
  241. package/src/tablecellproperties/tablecellpropertiesuiexperimental.js +408 -0
  242. package/src/tablecellproperties/ui/tablecellpropertiesview.d.ts +229 -0
  243. package/src/tablecellproperties/ui/tablecellpropertiesview.js +612 -0
  244. package/{dist/tablecellproperties/ui/tablecellpropertiesview.d.ts → src/tablecellproperties/ui/tablecellpropertiesviewexperimental.d.ts} +12 -11
  245. package/src/tablecellproperties/ui/tablecellpropertiesviewexperimental.js +744 -0
  246. package/{dist → src}/tablecellproperties.d.ts +1 -1
  247. package/src/tablecellproperties.js +40 -0
  248. package/{dist → src}/tablecellwidth/commands/tablecellwidthcommand.d.ts +1 -1
  249. package/src/tablecellwidth/commands/tablecellwidthcommand.js +51 -0
  250. package/{dist → src}/tablecellwidth/tablecellwidthediting.d.ts +1 -1
  251. package/src/tablecellwidth/tablecellwidthediting.js +53 -0
  252. package/{dist → src}/tableclipboard.d.ts +3 -3
  253. package/src/tableclipboard.js +500 -0
  254. package/src/tablecolumnresize/constants.js +33 -0
  255. package/{dist → src}/tablecolumnresize/converters.d.ts +1 -1
  256. package/src/tablecolumnresize/converters.js +62 -0
  257. package/{dist → src}/tablecolumnresize/tablecolumnresizeediting.d.ts +2 -2
  258. package/src/tablecolumnresize/tablecolumnresizeediting.js +734 -0
  259. package/{dist → src}/tablecolumnresize/tablewidthscommand.d.ts +2 -2
  260. package/src/tablecolumnresize/tablewidthscommand.js +61 -0
  261. package/{dist → src}/tablecolumnresize/utils.d.ts +2 -2
  262. package/src/tablecolumnresize/utils.js +370 -0
  263. package/{dist → src}/tablecolumnresize.d.ts +1 -1
  264. package/src/tablecolumnresize.js +36 -0
  265. package/{dist → src}/tableconfig.d.ts +6 -26
  266. package/src/tableconfig.js +5 -0
  267. package/{dist → src}/tableediting.d.ts +3 -3
  268. package/src/tableediting.js +246 -0
  269. package/{dist → src}/tablekeyboard.d.ts +3 -3
  270. package/src/tablekeyboard.js +273 -0
  271. package/{dist → src}/tablelayout/commands/tabletypecommand.d.ts +1 -1
  272. package/src/tablelayout/commands/tabletypecommand.js +68 -0
  273. package/{dist → src}/tablelayout/tablelayoutediting.d.ts +1 -1
  274. package/src/tablelayout/tablelayoutediting.js +295 -0
  275. package/{dist → src}/tablelayout/tablelayoutui.d.ts +1 -1
  276. package/src/tablelayout/tablelayoutui.js +196 -0
  277. package/{dist → src}/tablelayout.d.ts +1 -1
  278. package/src/tablelayout.js +37 -0
  279. package/{dist → src}/tablemouse/mouseeventsobserver.d.ts +1 -1
  280. package/src/tablemouse/mouseeventsobserver.js +34 -0
  281. package/{dist → src}/tablemouse.d.ts +1 -1
  282. package/src/tablemouse.js +178 -0
  283. package/{dist → src}/tableproperties/commands/tablealignmentcommand.d.ts +1 -1
  284. package/src/tableproperties/commands/tablealignmentcommand.js +30 -0
  285. package/{dist → src}/tableproperties/commands/tablebackgroundcolorcommand.d.ts +1 -1
  286. package/src/tableproperties/commands/tablebackgroundcolorcommand.js +30 -0
  287. package/{dist → src}/tableproperties/commands/tablebordercolorcommand.d.ts +2 -2
  288. package/src/tableproperties/commands/tablebordercolorcommand.js +44 -0
  289. package/{dist → src}/tableproperties/commands/tableborderstylecommand.d.ts +2 -2
  290. package/src/tableproperties/commands/tableborderstylecommand.js +44 -0
  291. package/{dist → src}/tableproperties/commands/tableborderwidthcommand.d.ts +2 -2
  292. package/src/tableproperties/commands/tableborderwidthcommand.js +64 -0
  293. package/{dist → src}/tableproperties/commands/tableheightcommand.d.ts +1 -1
  294. package/src/tableproperties/commands/tableheightcommand.js +54 -0
  295. package/{dist → src}/tableproperties/commands/tablepropertycommand.d.ts +2 -2
  296. package/src/tableproperties/commands/tablepropertycommand.js +103 -0
  297. package/{dist → src}/tableproperties/commands/tablewidthcommand.d.ts +1 -1
  298. package/src/tableproperties/commands/tablewidthcommand.js +54 -0
  299. package/{dist → src}/tableproperties/tablepropertiesediting.d.ts +1 -1
  300. package/src/tableproperties/tablepropertiesediting.js +546 -0
  301. package/{dist → src}/tableproperties/tablepropertiesui.d.ts +2 -2
  302. package/src/tableproperties/tablepropertiesui.js +374 -0
  303. package/src/tableproperties/tablepropertiesuiexperimental.d.ts +136 -0
  304. package/src/tableproperties/tablepropertiesuiexperimental.js +375 -0
  305. package/{dist → src}/tableproperties/ui/tablepropertiesview.d.ts +2 -10
  306. package/src/tableproperties/ui/tablepropertiesview.js +520 -0
  307. package/src/tableproperties/ui/tablepropertiesviewexperimental.d.ts +216 -0
  308. package/src/tableproperties/ui/tablepropertiesviewexperimental.js +544 -0
  309. package/{dist → src}/tableproperties.d.ts +1 -1
  310. package/src/tableproperties.js +40 -0
  311. package/{dist → src}/tableselection.d.ts +2 -2
  312. package/src/tableselection.js +323 -0
  313. package/{dist → src}/tabletoolbar.d.ts +2 -2
  314. package/src/tabletoolbar.js +63 -0
  315. package/{dist → src}/tableui.d.ts +1 -1
  316. package/src/tableui.js +335 -0
  317. package/{dist → src}/tableutils.d.ts +2 -2
  318. package/src/tableutils.js +1282 -0
  319. package/{dist → src}/tablewalker.d.ts +1 -1
  320. package/src/tablewalker.js +489 -0
  321. package/{dist → src}/ui/colorinputview.d.ts +2 -2
  322. package/src/ui/colorinputview.js +305 -0
  323. package/{dist → src}/ui/inserttableview.d.ts +2 -2
  324. package/src/ui/inserttableview.js +192 -0
  325. package/{dist → src}/utils/common.d.ts +2 -2
  326. package/src/utils/common.js +118 -0
  327. package/{dist → src}/utils/structure.d.ts +1 -1
  328. package/src/utils/structure.js +452 -0
  329. package/{dist → src}/utils/table-properties.d.ts +1 -1
  330. package/src/utils/table-properties.js +121 -0
  331. package/{dist → src}/utils/ui/contextualballoon.d.ts +2 -2
  332. package/src/utils/ui/contextualballoon.js +111 -0
  333. package/{dist → src}/utils/ui/table-properties.d.ts +2 -2
  334. package/src/utils/ui/table-properties.js +390 -0
  335. package/src/utils/ui/table-propertiesexperimental.d.ts +215 -0
  336. package/src/utils/ui/table-propertiesexperimental.js +391 -0
  337. package/{dist → src}/utils/ui/widget.d.ts +1 -1
  338. package/src/utils/ui/widget.js +56 -0
  339. package/theme/colorinput.css +39 -0
  340. package/theme/formrow-experimental.css +15 -0
  341. package/theme/formrow.css +13 -0
  342. package/theme/inserttable.css +10 -0
  343. package/theme/table.css +144 -0
  344. package/theme/tablecaption.css +66 -0
  345. package/theme/tablecellproperties-experimental.css +4 -0
  346. package/theme/tablecellproperties.css +28 -0
  347. package/theme/tablecolumnresize.css +62 -0
  348. package/theme/tableediting.css +10 -0
  349. package/theme/tableform-experimental.css +61 -0
  350. package/theme/tableform.css +64 -0
  351. package/theme/tablelayout.css +74 -0
  352. package/theme/tableproperties-experimental.css +78 -0
  353. package/theme/tableproperties.css +18 -0
  354. package/theme/tableselection.css +10 -0
  355. package/dist/tablecellproperties/tablecellpropertiesutils.d.ts +0 -18
  356. /package/{dist → src}/tablecolumnresize/constants.d.ts +0 -0
@@ -2,7 +2,7 @@
2
2
  * @license Copyright (c) 2003-2026, CKSource Holding sp. z o.o. All rights reserved.
3
3
  * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
4
4
  */
5
- import { Command } from '@ckeditor/ckeditor5-core';
5
+ import { Command } from 'ckeditor5/src/core.js';
6
6
  /**
7
7
  * The merge cells command.
8
8
  *
@@ -0,0 +1,94 @@
1
+ /**
2
+ * @license Copyright (c) 2003-2026, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
4
+ */
5
+ import { Command } from 'ckeditor5/src/core.js';
6
+ import { TableUtils } from '../tableutils.js';
7
+ import { updateNumericAttribute } from '../utils/common.js';
8
+ import { removeEmptyRowsColumns } from '../utils/structure.js';
9
+ /**
10
+ * The merge cells command.
11
+ *
12
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'mergeTableCells'` editor command.
13
+ *
14
+ * For example, to merge selected table cells:
15
+ *
16
+ * ```ts
17
+ * editor.execute( 'mergeTableCells' );
18
+ * ```
19
+ */
20
+ export class MergeCellsCommand extends Command {
21
+ /**
22
+ * @inheritDoc
23
+ */
24
+ refresh() {
25
+ const tableUtils = this.editor.plugins.get(TableUtils);
26
+ const selectedTableCells = tableUtils.getSelectedTableCells(this.editor.model.document.selection);
27
+ this.isEnabled = tableUtils.isSelectionRectangular(selectedTableCells);
28
+ }
29
+ /**
30
+ * Executes the command.
31
+ *
32
+ * @fires execute
33
+ */
34
+ execute() {
35
+ const model = this.editor.model;
36
+ const tableUtils = this.editor.plugins.get(TableUtils);
37
+ model.change(writer => {
38
+ const selectedTableCells = tableUtils.getSelectedTableCells(model.document.selection);
39
+ // All cells will be merged into the first one.
40
+ const firstTableCell = selectedTableCells.shift();
41
+ // Update target cell dimensions.
42
+ const { mergeWidth, mergeHeight } = getMergeDimensions(firstTableCell, selectedTableCells, tableUtils);
43
+ updateNumericAttribute('colspan', mergeWidth, firstTableCell, writer);
44
+ updateNumericAttribute('rowspan', mergeHeight, firstTableCell, writer);
45
+ for (const tableCell of selectedTableCells) {
46
+ mergeTableCells(tableCell, firstTableCell, writer);
47
+ }
48
+ const table = firstTableCell.findAncestor('table');
49
+ // Remove rows and columns that become empty (have no anchored cells).
50
+ removeEmptyRowsColumns(table, tableUtils);
51
+ writer.setSelection(firstTableCell, 'in');
52
+ });
53
+ }
54
+ }
55
+ /**
56
+ * Merges two table cells. It will ensure that after merging cells with empty paragraphs the resulting table cell will only have one
57
+ * paragraph. If one of the merged table cells is empty, the merged table cell will have contents of the non-empty table cell.
58
+ * If both are empty, the merged table cell will have only one empty paragraph.
59
+ */
60
+ function mergeTableCells(cellBeingMerged, targetCell, writer) {
61
+ if (!isEmpty(cellBeingMerged)) {
62
+ if (isEmpty(targetCell)) {
63
+ writer.remove(writer.createRangeIn(targetCell));
64
+ }
65
+ writer.move(writer.createRangeIn(cellBeingMerged), writer.createPositionAt(targetCell, 'end'));
66
+ }
67
+ // Remove merged table cell.
68
+ writer.remove(cellBeingMerged);
69
+ }
70
+ /**
71
+ * Checks if the passed table cell contains an empty paragraph.
72
+ */
73
+ function isEmpty(tableCell) {
74
+ const firstTableChild = tableCell.getChild(0);
75
+ return tableCell.childCount == 1 && firstTableChild.is('element', 'paragraph') && firstTableChild.isEmpty;
76
+ }
77
+ function getMergeDimensions(firstTableCell, selectedTableCells, tableUtils) {
78
+ let maxWidthOffset = 0;
79
+ let maxHeightOffset = 0;
80
+ for (const tableCell of selectedTableCells) {
81
+ const { row, column } = tableUtils.getCellLocation(tableCell);
82
+ maxWidthOffset = getMaxOffset(tableCell, column, maxWidthOffset, 'colspan');
83
+ maxHeightOffset = getMaxOffset(tableCell, row, maxHeightOffset, 'rowspan');
84
+ }
85
+ // Update table cell span attribute and merge set selection on a merged contents.
86
+ const { row: firstCellRow, column: firstCellColumn } = tableUtils.getCellLocation(firstTableCell);
87
+ const mergeWidth = maxWidthOffset - firstCellColumn;
88
+ const mergeHeight = maxHeightOffset - firstCellRow;
89
+ return { mergeWidth, mergeHeight };
90
+ }
91
+ function getMaxOffset(tableCell, start, currentMaxOffset, which) {
92
+ const dimensionValue = parseInt(tableCell.getAttribute(which) || '1');
93
+ return Math.max(currentMaxOffset, start + dimensionValue);
94
+ }
@@ -5,7 +5,7 @@
5
5
  /**
6
6
  * @module table/commands/removecolumncommand
7
7
  */
8
- import { Command } from '@ckeditor/ckeditor5-core';
8
+ import { Command } from 'ckeditor5/src/core.js';
9
9
  /**
10
10
  * The remove column command.
11
11
  *
@@ -0,0 +1,109 @@
1
+ /**
2
+ * @license Copyright (c) 2003-2026, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
4
+ */
5
+ /**
6
+ * @module table/commands/removecolumncommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core.js';
9
+ import { TableWalker } from '../tablewalker.js';
10
+ /**
11
+ * The remove column command.
12
+ *
13
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableColumn'` editor command.
14
+ *
15
+ * To remove the column containing the selected cell, execute the command:
16
+ *
17
+ * ```ts
18
+ * editor.execute( 'removeTableColumn' );
19
+ * ```
20
+ */
21
+ export class RemoveColumnCommand extends Command {
22
+ /**
23
+ * @inheritDoc
24
+ */
25
+ refresh() {
26
+ const tableUtils = this.editor.plugins.get('TableUtils');
27
+ const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
28
+ const firstCell = selectedCells[0];
29
+ if (firstCell) {
30
+ const table = firstCell.findAncestor('table');
31
+ const tableColumnCount = tableUtils.getColumns(table);
32
+ const { first, last } = tableUtils.getColumnIndexes(selectedCells);
33
+ this.isEnabled = last - first < (tableColumnCount - 1);
34
+ }
35
+ else {
36
+ this.isEnabled = false;
37
+ }
38
+ }
39
+ /**
40
+ * @inheritDoc
41
+ */
42
+ execute() {
43
+ const tableUtils = this.editor.plugins.get('TableUtils');
44
+ const [firstCell, lastCell] = getBoundaryCells(this.editor.model.document.selection, tableUtils);
45
+ const table = firstCell.parent.parent;
46
+ // Cache the table before removing or updating colspans.
47
+ const tableMap = [...new TableWalker(table)];
48
+ // Store column indexes of removed columns.
49
+ const removedColumnIndexes = {
50
+ first: tableMap.find(value => value.cell === firstCell).column,
51
+ last: tableMap.find(value => value.cell === lastCell).column
52
+ };
53
+ const cellToFocus = getCellToFocus(tableMap, firstCell, lastCell, removedColumnIndexes);
54
+ this.editor.model.change(writer => {
55
+ const columnsToRemove = removedColumnIndexes.last - removedColumnIndexes.first + 1;
56
+ tableUtils.removeColumns(table, {
57
+ at: removedColumnIndexes.first,
58
+ columns: columnsToRemove
59
+ });
60
+ writer.setSelection(writer.createPositionAt(cellToFocus, 0));
61
+ });
62
+ }
63
+ }
64
+ /**
65
+ * Returns a proper table cell to focus after removing a column.
66
+ * - selection is on last table cell it will return previous cell.
67
+ */
68
+ function getCellToFocus(tableMap, firstCell, lastCell, removedColumnIndexes) {
69
+ const colspan = parseInt(lastCell.getAttribute('colspan') || '1');
70
+ // If the table cell is spanned over 2+ columns - it will be truncated so the selection should
71
+ // stay in that cell.
72
+ if (colspan > 1) {
73
+ return lastCell;
74
+ }
75
+ // Normally, look for the cell in the same row that precedes the first cell to put selection there ("column on the left").
76
+ // If the deleted column is the first column of the table, there will be no predecessor: use the cell
77
+ // from the column that follows then (also in the same row).
78
+ else if (firstCell.previousSibling || lastCell.nextSibling) {
79
+ return lastCell.nextSibling || firstCell.previousSibling;
80
+ }
81
+ // It can happen that table cells have no siblings in a row, for instance, when there are row spans
82
+ // in the table (in the previous row). Then just look for the closest cell that is in a column
83
+ // that will not be removed to put the selection there.
84
+ else {
85
+ // Look for any cell in a column that precedes the first removed column.
86
+ if (removedColumnIndexes.first) {
87
+ return tableMap.reverse().find(({ column }) => {
88
+ return column < removedColumnIndexes.first;
89
+ }).cell;
90
+ }
91
+ // If the first removed column is the first column of the table, then
92
+ // look for any cell that is in a column that follows the last removed column.
93
+ else {
94
+ return tableMap.reverse().find(({ column }) => {
95
+ return column > removedColumnIndexes.last;
96
+ }).cell;
97
+ }
98
+ }
99
+ }
100
+ /**
101
+ * Returns helper object returning the first and the last cell contained in given selection, based on DOM order.
102
+ */
103
+ function getBoundaryCells(selection, tableUtils) {
104
+ const referenceCells = tableUtils.getSelectionAffectedTableCells(selection);
105
+ const firstCell = referenceCells[0];
106
+ const lastCell = referenceCells.pop();
107
+ const returnValue = [firstCell, lastCell];
108
+ return firstCell.isBefore(lastCell) ? returnValue : returnValue.reverse();
109
+ }
@@ -5,7 +5,7 @@
5
5
  /**
6
6
  * @module table/commands/removerowcommand
7
7
  */
8
- import { Command } from '@ckeditor/ckeditor5-core';
8
+ import { Command } from 'ckeditor5/src/core.js';
9
9
  /**
10
10
  * The remove row command.
11
11
  *
@@ -0,0 +1,82 @@
1
+ /**
2
+ * @license Copyright (c) 2003-2026, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
4
+ */
5
+ /**
6
+ * @module table/commands/removerowcommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core.js';
9
+ /**
10
+ * The remove row command.
11
+ *
12
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableRow'` editor command.
13
+ *
14
+ * To remove the row containing the selected cell, execute the command:
15
+ *
16
+ * ```ts
17
+ * editor.execute( 'removeTableRow' );
18
+ * ```
19
+ */
20
+ export class RemoveRowCommand extends Command {
21
+ /**
22
+ * @inheritDoc
23
+ */
24
+ refresh() {
25
+ const tableUtils = this.editor.plugins.get('TableUtils');
26
+ const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
27
+ const firstCell = selectedCells[0];
28
+ if (firstCell) {
29
+ const table = firstCell.findAncestor('table');
30
+ const tableRowCount = tableUtils.getRows(table);
31
+ const lastRowIndex = tableRowCount - 1;
32
+ const selectedRowIndexes = tableUtils.getRowIndexes(selectedCells);
33
+ const areAllRowsSelected = selectedRowIndexes.first === 0 && selectedRowIndexes.last === lastRowIndex;
34
+ // Disallow selecting whole table -> delete whole table should be used instead.
35
+ this.isEnabled = !areAllRowsSelected;
36
+ }
37
+ else {
38
+ this.isEnabled = false;
39
+ }
40
+ }
41
+ /**
42
+ * @inheritDoc
43
+ */
44
+ execute() {
45
+ const model = this.editor.model;
46
+ const tableUtils = this.editor.plugins.get('TableUtils');
47
+ const referenceCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
48
+ const removedRowIndexes = tableUtils.getRowIndexes(referenceCells);
49
+ const firstCell = referenceCells[0];
50
+ const table = firstCell.findAncestor('table');
51
+ const columnIndexToFocus = tableUtils.getCellLocation(firstCell).column;
52
+ model.change(writer => {
53
+ const rowsToRemove = removedRowIndexes.last - removedRowIndexes.first + 1;
54
+ tableUtils.removeRows(table, {
55
+ at: removedRowIndexes.first,
56
+ rows: rowsToRemove
57
+ });
58
+ const cellToFocus = getCellToFocus(table, removedRowIndexes.first, columnIndexToFocus, tableUtils.getRows(table));
59
+ writer.setSelection(writer.createPositionAt(cellToFocus, 0));
60
+ });
61
+ }
62
+ }
63
+ /**
64
+ * Returns a cell that should be focused before removing the row, belonging to the same column as the currently focused cell.
65
+ * - If the row was not the last one, the cell to focus will be in the row that followed it (before removal).
66
+ * - If the row was the last one, the cell to focus will be in the row that preceded it (before removal).
67
+ */
68
+ function getCellToFocus(table, removedRowIndex, columnToFocus, tableRowCount) {
69
+ // Don't go beyond last row's index.
70
+ const row = table.getChild(Math.min(removedRowIndex, tableRowCount - 1));
71
+ // Default to first table cell.
72
+ let cellToFocus = row.getChild(0);
73
+ let column = 0;
74
+ for (const tableCell of row.getChildren()) {
75
+ if (column > columnToFocus) {
76
+ return cellToFocus;
77
+ }
78
+ cellToFocus = tableCell;
79
+ column += parseInt(tableCell.getAttribute('colspan') || '1');
80
+ }
81
+ return cellToFocus;
82
+ }
@@ -5,7 +5,7 @@
5
5
  /**
6
6
  * @module table/commands/selectcolumncommand
7
7
  */
8
- import { Command, type Editor } from '@ckeditor/ckeditor5-core';
8
+ import { Command, type Editor } from 'ckeditor5/src/core.js';
9
9
  /**
10
10
  * The select column command.
11
11
  *
@@ -0,0 +1,60 @@
1
+ /**
2
+ * @license Copyright (c) 2003-2026, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
4
+ */
5
+ /**
6
+ * @module table/commands/selectcolumncommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core.js';
9
+ import { TableWalker } from '../tablewalker.js';
10
+ /**
11
+ * The select column command.
12
+ *
13
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableColumn'` editor command.
14
+ *
15
+ * To select the columns containing the selected cells, execute the command:
16
+ *
17
+ * ```ts
18
+ * editor.execute( 'selectTableColumn' );
19
+ * ```
20
+ */
21
+ export class SelectColumnCommand extends Command {
22
+ /**
23
+ * @inheritDoc
24
+ */
25
+ constructor(editor) {
26
+ super(editor);
27
+ // It does not affect data so should be enabled in read-only mode.
28
+ this.affectsData = false;
29
+ }
30
+ /**
31
+ * @inheritDoc
32
+ */
33
+ refresh() {
34
+ const tableUtils = this.editor.plugins.get('TableUtils');
35
+ const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
36
+ this.isEnabled = selectedCells.length > 0;
37
+ }
38
+ /**
39
+ * @inheritDoc
40
+ */
41
+ execute() {
42
+ const tableUtils = this.editor.plugins.get('TableUtils');
43
+ const model = this.editor.model;
44
+ const referenceCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
45
+ const firstCell = referenceCells[0];
46
+ const lastCell = referenceCells.pop();
47
+ const table = firstCell.findAncestor('table');
48
+ const startLocation = tableUtils.getCellLocation(firstCell);
49
+ const endLocation = tableUtils.getCellLocation(lastCell);
50
+ const startColumn = Math.min(startLocation.column, endLocation.column);
51
+ const endColumn = Math.max(startLocation.column, endLocation.column);
52
+ const rangesToSelect = [];
53
+ for (const cellInfo of new TableWalker(table, { startColumn, endColumn })) {
54
+ rangesToSelect.push(model.createRangeOn(cellInfo.cell));
55
+ }
56
+ model.change(writer => {
57
+ writer.setSelection(rangesToSelect);
58
+ });
59
+ }
60
+ }
@@ -5,7 +5,7 @@
5
5
  /**
6
6
  * @module table/commands/selectrowcommand
7
7
  */
8
- import { Command, type Editor } from '@ckeditor/ckeditor5-core';
8
+ import { Command, type Editor } from 'ckeditor5/src/core.js';
9
9
  /**
10
10
  * The select row command.
11
11
  *
@@ -0,0 +1,56 @@
1
+ /**
2
+ * @license Copyright (c) 2003-2026, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
4
+ */
5
+ /**
6
+ * @module table/commands/selectrowcommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core.js';
9
+ /**
10
+ * The select row command.
11
+ *
12
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableRow'` editor command.
13
+ *
14
+ * To select the rows containing the selected cells, execute the command:
15
+ *
16
+ * ```ts
17
+ * editor.execute( 'selectTableRow' );
18
+ * ```
19
+ */
20
+ export class SelectRowCommand extends Command {
21
+ /**
22
+ * @inheritDoc
23
+ */
24
+ constructor(editor) {
25
+ super(editor);
26
+ // It does not affect data so should be enabled in read-only mode.
27
+ this.affectsData = false;
28
+ }
29
+ /**
30
+ * @inheritDoc
31
+ */
32
+ refresh() {
33
+ const tableUtils = this.editor.plugins.get('TableUtils');
34
+ const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
35
+ this.isEnabled = selectedCells.length > 0;
36
+ }
37
+ /**
38
+ * @inheritDoc
39
+ */
40
+ execute() {
41
+ const model = this.editor.model;
42
+ const tableUtils = this.editor.plugins.get('TableUtils');
43
+ const referenceCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
44
+ const rowIndexes = tableUtils.getRowIndexes(referenceCells);
45
+ const table = referenceCells[0].findAncestor('table');
46
+ const rangesToSelect = [];
47
+ for (let rowIndex = rowIndexes.first; rowIndex <= rowIndexes.last; rowIndex++) {
48
+ for (const cell of table.getChild(rowIndex).getChildren()) {
49
+ rangesToSelect.push(model.createRangeOn(cell));
50
+ }
51
+ }
52
+ model.change(writer => {
53
+ writer.setSelection(rangesToSelect);
54
+ });
55
+ }
56
+ }
@@ -5,7 +5,7 @@
5
5
  /**
6
6
  * @module table/commands/setheadercolumncommand
7
7
  */
8
- import { Command } from '@ckeditor/ckeditor5-core';
8
+ import { Command } from 'ckeditor5/src/core.js';
9
9
  /**
10
10
  * The header column command.
11
11
  *
@@ -0,0 +1,76 @@
1
+ /**
2
+ * @license Copyright (c) 2003-2026, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
4
+ */
5
+ /**
6
+ * @module table/commands/setheadercolumncommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core.js';
9
+ import { isHeadingColumnCell } from '../utils/common.js';
10
+ import { getHorizontallyOverlappingCells, splitVertically } from '../utils/structure.js';
11
+ /**
12
+ * The header column command.
13
+ *
14
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'setTableColumnHeader'` editor command.
15
+ *
16
+ * You can make the column containing the selected cell a [header](https://www.w3.org/TR/html50/tabular-data.html#the-th-element)
17
+ * by executing:
18
+ *
19
+ * ```ts
20
+ * editor.execute( 'setTableColumnHeader' );
21
+ * ```
22
+ *
23
+ * **Note:** All preceding columns will also become headers. If the current column is already a header, executing this command
24
+ * will make it a regular column back again (including the following columns).
25
+ */
26
+ export class SetHeaderColumnCommand extends Command {
27
+ /**
28
+ * @inheritDoc
29
+ */
30
+ refresh() {
31
+ const tableUtils = this.editor.plugins.get('TableUtils');
32
+ const model = this.editor.model;
33
+ const selectedCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
34
+ if (selectedCells.length === 0) {
35
+ this.isEnabled = false;
36
+ this.value = false;
37
+ return;
38
+ }
39
+ const table = selectedCells[0].findAncestor('table');
40
+ this.isEnabled = model.schema.checkAttribute(table, 'headingColumns');
41
+ this.value = selectedCells.every(cell => isHeadingColumnCell(tableUtils, cell));
42
+ }
43
+ /**
44
+ * Executes the command.
45
+ *
46
+ * When the selection is in a non-header column, the command will set the `headingColumns` table attribute to cover that column.
47
+ *
48
+ * When the selection is already in a header column, it will set `headingColumns` so the heading section will end before that column.
49
+ *
50
+ * @fires execute
51
+ * @param options.forceValue If set, the command will set (`true`) or unset (`false`) the header columns according to
52
+ * the `forceValue` parameter instead of the current model state.
53
+ */
54
+ execute(options = {}) {
55
+ if (options.forceValue === this.value) {
56
+ return;
57
+ }
58
+ const tableUtils = this.editor.plugins.get('TableUtils');
59
+ const model = this.editor.model;
60
+ const selectedCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
61
+ const table = selectedCells[0].findAncestor('table');
62
+ const { first, last } = tableUtils.getColumnIndexes(selectedCells);
63
+ const headingColumnsToSet = this.value ? first : last + 1;
64
+ model.change(writer => {
65
+ if (headingColumnsToSet) {
66
+ // Changing heading columns requires to check if any of a heading cell is overlapping horizontally the table head.
67
+ // Any table cell that has a colspan attribute > 1 will not exceed the table head so we need to fix it in columns before.
68
+ const overlappingCells = getHorizontallyOverlappingCells(table, headingColumnsToSet);
69
+ for (const { cell, column } of overlappingCells) {
70
+ splitVertically(cell, column, headingColumnsToSet, writer);
71
+ }
72
+ }
73
+ tableUtils.setHeadingColumnsCount(writer, table, headingColumnsToSet);
74
+ });
75
+ }
76
+ }
@@ -5,7 +5,7 @@
5
5
  /**
6
6
  * @module table/commands/setheaderrowcommand
7
7
  */
8
- import { Command } from '@ckeditor/ckeditor5-core';
8
+ import { Command } from 'ckeditor5/src/core.js';
9
9
  /**
10
10
  * The header row command.
11
11
  *
@@ -0,0 +1,83 @@
1
+ /**
2
+ * @license Copyright (c) 2003-2026, CKSource Holding sp. z o.o. All rights reserved.
3
+ * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
4
+ */
5
+ /**
6
+ * @module table/commands/setheaderrowcommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core.js';
9
+ import { getVerticallyOverlappingCells, splitHorizontally } from '../utils/structure.js';
10
+ /**
11
+ * The header row command.
12
+ *
13
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'setTableColumnHeader'` editor command.
14
+ *
15
+ * You can make the row containing the selected cell a [header](https://www.w3.org/TR/html50/tabular-data.html#the-th-element) by executing:
16
+ *
17
+ * ```ts
18
+ * editor.execute( 'setTableRowHeader' );
19
+ * ```
20
+ *
21
+ * **Note:** All preceding rows will also become headers. If the current row is already a header, executing this command
22
+ * will make it a regular row back again (including the following rows).
23
+ */
24
+ export class SetHeaderRowCommand extends Command {
25
+ /**
26
+ * @inheritDoc
27
+ */
28
+ refresh() {
29
+ const tableUtils = this.editor.plugins.get('TableUtils');
30
+ const model = this.editor.model;
31
+ const selectedCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
32
+ if (selectedCells.length === 0) {
33
+ this.isEnabled = false;
34
+ this.value = false;
35
+ return;
36
+ }
37
+ const table = selectedCells[0].findAncestor('table');
38
+ this.isEnabled = model.schema.checkAttribute(table, 'headingRows');
39
+ this.value = selectedCells.every(cell => this._isInHeading(cell, cell.parent.parent));
40
+ }
41
+ /**
42
+ * Executes the command.
43
+ *
44
+ * When the selection is in a non-header row, the command will set the `headingRows` table attribute to cover that row.
45
+ *
46
+ * When the selection is already in a header row, it will set `headingRows` so the heading section will end before that row.
47
+ *
48
+ * @fires execute
49
+ * @param options.forceValue If set, the command will set (`true`) or unset (`false`) the header rows according to
50
+ * the `forceValue` parameter instead of the current model state.
51
+ */
52
+ execute(options = {}) {
53
+ if (options.forceValue === this.value) {
54
+ return;
55
+ }
56
+ const tableUtils = this.editor.plugins.get('TableUtils');
57
+ const model = this.editor.model;
58
+ const selectedCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
59
+ const table = selectedCells[0].findAncestor('table');
60
+ const { first, last } = tableUtils.getRowIndexes(selectedCells);
61
+ const headingRowsToSet = this.value ? first : last + 1;
62
+ const currentHeadingRows = table.getAttribute('headingRows') || 0;
63
+ model.change(writer => {
64
+ if (headingRowsToSet) {
65
+ // Changing heading rows requires to check if any of a heading cell is overlapping vertically the table head.
66
+ // Any table cell that has a rowspan attribute > 1 will not exceed the table head so we need to fix it in rows below.
67
+ const startRow = headingRowsToSet > currentHeadingRows ? currentHeadingRows : 0;
68
+ const overlappingCells = getVerticallyOverlappingCells(table, headingRowsToSet, startRow);
69
+ for (const { cell } of overlappingCells) {
70
+ splitHorizontally(cell, headingRowsToSet, writer);
71
+ }
72
+ }
73
+ tableUtils.setHeadingRowsCount(writer, table, headingRowsToSet);
74
+ });
75
+ }
76
+ /**
77
+ * Checks if a table cell is in the heading section.
78
+ */
79
+ _isInHeading(tableCell, table) {
80
+ const headingRows = parseInt(table.getAttribute('headingRows') || '0');
81
+ return !!headingRows && tableCell.parent.index < headingRows;
82
+ }
83
+ }
@@ -5,7 +5,7 @@
5
5
  /**
6
6
  * @module table/commands/splitcellcommand
7
7
  */
8
- import { Command, type Editor } from '@ckeditor/ckeditor5-core';
8
+ import { Command, type Editor } from 'ckeditor5/src/core.js';
9
9
  /**
10
10
  * The split cell command.
11
11
  *