@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
package/package.json CHANGED
@@ -1,45 +1,68 @@
1
1
  {
2
2
  "name": "@ckeditor/ckeditor5-table",
3
- "version": "0.0.0-nightly-next-20260127.0",
3
+ "version": "0.0.0-nightly-20260128.0",
4
4
  "description": "Table feature for CKEditor 5.",
5
- "license": "SEE LICENSE IN LICENSE.md",
6
- "author": "CKSource (http://cksource.com/)",
7
- "homepage": "https://ckeditor.com/ckeditor-5",
8
- "bugs": "https://github.com/ckeditor/ckeditor5/issues",
9
- "repository": {
10
- "type": "git",
11
- "url": "https://github.com/ckeditor/ckeditor5.git",
12
- "directory": "packages/ckeditor5-table"
13
- },
14
5
  "keywords": [
15
6
  "ckeditor",
16
7
  "ckeditor5",
17
8
  "ckeditor 5",
18
9
  "ckeditor5-feature",
19
- "ckeditor5-plugin"
10
+ "ckeditor5-plugin",
11
+ "ckeditor5-dll"
20
12
  ],
21
13
  "type": "module",
22
- "main": "./dist/index.js",
23
- "exports": {
24
- ".": "./dist/index.js",
25
- "./dist/*": "./dist/*",
26
- "./package.json": "./package.json"
27
- },
14
+ "main": "src/index.js",
28
15
  "dependencies": {
29
- "@ckeditor/ckeditor5-clipboard": "0.0.0-nightly-next-20260127.0",
30
- "@ckeditor/ckeditor5-core": "0.0.0-nightly-next-20260127.0",
31
- "@ckeditor/ckeditor5-engine": "0.0.0-nightly-next-20260127.0",
32
- "@ckeditor/ckeditor5-icons": "0.0.0-nightly-next-20260127.0",
33
- "@ckeditor/ckeditor5-typing": "0.0.0-nightly-next-20260127.0",
34
- "@ckeditor/ckeditor5-ui": "0.0.0-nightly-next-20260127.0",
35
- "@ckeditor/ckeditor5-utils": "0.0.0-nightly-next-20260127.0",
36
- "@ckeditor/ckeditor5-widget": "0.0.0-nightly-next-20260127.0",
16
+ "ckeditor5": "0.0.0-nightly-20260128.0",
17
+ "@ckeditor/ckeditor5-clipboard": "0.0.0-nightly-20260128.0",
18
+ "@ckeditor/ckeditor5-core": "0.0.0-nightly-20260128.0",
19
+ "@ckeditor/ckeditor5-engine": "0.0.0-nightly-20260128.0",
20
+ "@ckeditor/ckeditor5-icons": "0.0.0-nightly-20260128.0",
21
+ "@ckeditor/ckeditor5-ui": "0.0.0-nightly-20260128.0",
22
+ "@ckeditor/ckeditor5-utils": "0.0.0-nightly-20260128.0",
23
+ "@ckeditor/ckeditor5-widget": "0.0.0-nightly-20260128.0",
37
24
  "es-toolkit": "1.39.5"
38
25
  },
26
+ "author": "CKSource (http://cksource.com/)",
27
+ "license": "SEE LICENSE IN LICENSE.md",
28
+ "homepage": "https://ckeditor.com/ckeditor-5",
29
+ "bugs": "https://github.com/ckeditor/ckeditor5/issues",
30
+ "repository": {
31
+ "type": "git",
32
+ "url": "https://github.com/ckeditor/ckeditor5.git",
33
+ "directory": "packages/ckeditor5-table"
34
+ },
39
35
  "files": [
40
36
  "dist",
37
+ "lang",
38
+ "src/**/*.js",
39
+ "src/**/*.d.ts",
40
+ "theme",
41
+ "build",
41
42
  "ckeditor5-metadata.json",
42
43
  "CHANGELOG.md"
43
44
  ],
44
- "types": "./dist/index.d.ts"
45
+ "types": "src/index.d.ts",
46
+ "exports": {
47
+ ".": {
48
+ "types": "./src/index.d.ts",
49
+ "import": "./src/index.js",
50
+ "default": "./src/index.js"
51
+ },
52
+ "./dist/*": {
53
+ "types": "./src/index.d.ts",
54
+ "import": "./dist/*",
55
+ "default": "./dist/*"
56
+ },
57
+ "./src/*": {
58
+ "types": "./src/*.d.ts",
59
+ "import": "./src/*",
60
+ "default": "./src/*"
61
+ },
62
+ "./build/*": "./build/*",
63
+ "./lang/*": "./lang/*",
64
+ "./theme/*": "./theme/*",
65
+ "./ckeditor5-metadata.json": "./ckeditor5-metadata.json",
66
+ "./package.json": "./package.json"
67
+ }
45
68
  }
@@ -15,6 +15,21 @@ declare module '@ckeditor/ckeditor5-engine' {
15
15
  * This will be enabled by default in the future CKEditor 5 releases.
16
16
  */
17
17
  upcastTableBorderZeroAttributes?: boolean;
18
+ /**
19
+ * When enabled, the the {@link module:table/tableproperties/tablepropertiesediting~TablePropertiesEditing table properties feature}
20
+ * will support extended alignment options for tables, i.e. `blockLeft` and `blockRight`, using CSS `margin` property.
21
+ *
22
+ * This will be enabled by default in the future CKEditor 5 releases.
23
+ */
24
+ useExtendedTableBlockAlignment?: boolean;
25
+ /**
26
+ * When enabled, the
27
+ * {@link module:table/tablecellproperties/tablecellpropertiesediting~TableCellPropertiesEditing table cell properties feature}
28
+ * will introduce a special selector for table cell types (i.e. header and data cells) in the cell properties dropdown.
29
+ *
30
+ * This will be enabled by default in the future CKEditor 5 releases.
31
+ */
32
+ tableCellTypeSupport?: boolean;
18
33
  }
19
34
  }
20
35
  declare module '@ckeditor/ckeditor5-core' {
@@ -0,0 +1,5 @@
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
+ export {};
@@ -5,7 +5,7 @@
5
5
  /**
6
6
  * @module table/commands/insertcolumncommand
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 insert column command.
11
11
  *
@@ -0,0 +1,71 @@
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/insertcolumncommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core.js';
9
+ /**
10
+ * The insert column command.
11
+ *
12
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'insertTableColumnLeft'` and
13
+ * `'insertTableColumnRight'` editor commands.
14
+ *
15
+ * To insert a column to the left of the selected cell, execute the following command:
16
+ *
17
+ * ```ts
18
+ * editor.execute( 'insertTableColumnLeft' );
19
+ * ```
20
+ *
21
+ * To insert a column to the right of the selected cell, execute the following command:
22
+ *
23
+ * ```ts
24
+ * editor.execute( 'insertTableColumnRight' );
25
+ * ```
26
+ */
27
+ export class InsertColumnCommand extends Command {
28
+ /**
29
+ * The order of insertion relative to the column in which the caret is located.
30
+ */
31
+ order;
32
+ /**
33
+ * Creates a new `InsertColumnCommand` instance.
34
+ *
35
+ * @param editor An editor on which this command will be used.
36
+ * @param options.order The order of insertion relative to the column in which the caret is located.
37
+ * Possible values: `"left"` and `"right"`. Default value is "right".
38
+ */
39
+ constructor(editor, options = {}) {
40
+ super(editor);
41
+ this.order = options.order || 'right';
42
+ }
43
+ /**
44
+ * @inheritDoc
45
+ */
46
+ refresh() {
47
+ const selection = this.editor.model.document.selection;
48
+ const tableUtils = this.editor.plugins.get('TableUtils');
49
+ const isAnyCellSelected = !!tableUtils.getSelectionAffectedTableCells(selection).length;
50
+ this.isEnabled = isAnyCellSelected;
51
+ }
52
+ /**
53
+ * Executes the command.
54
+ *
55
+ * Depending on the command's {@link #order} value, it inserts a column to the `'left'` or `'right'` of the column
56
+ * in which the selection is set.
57
+ *
58
+ * @fires execute
59
+ */
60
+ execute() {
61
+ const editor = this.editor;
62
+ const selection = editor.model.document.selection;
63
+ const tableUtils = editor.plugins.get('TableUtils');
64
+ const insertBefore = this.order === 'left';
65
+ const affectedTableCells = tableUtils.getSelectionAffectedTableCells(selection);
66
+ const columnIndexes = tableUtils.getColumnIndexes(affectedTableCells);
67
+ const column = insertBefore ? columnIndexes.first : columnIndexes.last;
68
+ const table = affectedTableCells[0].findAncestor('table');
69
+ tableUtils.insertColumns(table, { columns: 1, at: insertBefore ? column : column + 1 });
70
+ }
71
+ }
@@ -5,7 +5,7 @@
5
5
  /**
6
6
  * @module table/commands/insertrowcommand
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 insert row command.
11
11
  *
@@ -0,0 +1,70 @@
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/insertrowcommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core.js';
9
+ /**
10
+ * The insert row command.
11
+ *
12
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'insertTableRowBelow'` and
13
+ * `'insertTableRowAbove'` editor commands.
14
+ *
15
+ * To insert a row below the selected cell, execute the following command:
16
+ *
17
+ * ```ts
18
+ * editor.execute( 'insertTableRowBelow' );
19
+ * ```
20
+ *
21
+ * To insert a row above the selected cell, execute the following command:
22
+ *
23
+ * ```ts
24
+ * editor.execute( 'insertTableRowAbove' );
25
+ * ```
26
+ */
27
+ export class InsertRowCommand extends Command {
28
+ /**
29
+ * The order of insertion relative to the row in which the caret is located.
30
+ */
31
+ order;
32
+ /**
33
+ * Creates a new `InsertRowCommand` instance.
34
+ *
35
+ * @param editor The editor on which this command will be used.
36
+ * @param options.order The order of insertion relative to the row in which the caret is located.
37
+ * Possible values: `"above"` and `"below"`. Default value is "below"
38
+ */
39
+ constructor(editor, options = {}) {
40
+ super(editor);
41
+ this.order = options.order || 'below';
42
+ }
43
+ /**
44
+ * @inheritDoc
45
+ */
46
+ refresh() {
47
+ const selection = this.editor.model.document.selection;
48
+ const tableUtils = this.editor.plugins.get('TableUtils');
49
+ const isAnyCellSelected = !!tableUtils.getSelectionAffectedTableCells(selection).length;
50
+ this.isEnabled = isAnyCellSelected;
51
+ }
52
+ /**
53
+ * Executes the command.
54
+ *
55
+ * Depending on the command's {@link #order} value, it inserts a row `'below'` or `'above'` the row in which selection is set.
56
+ *
57
+ * @fires execute
58
+ */
59
+ execute() {
60
+ const editor = this.editor;
61
+ const selection = editor.model.document.selection;
62
+ const tableUtils = editor.plugins.get('TableUtils');
63
+ const insertAbove = this.order === 'above';
64
+ const affectedTableCells = tableUtils.getSelectionAffectedTableCells(selection);
65
+ const rowIndexes = tableUtils.getRowIndexes(affectedTableCells);
66
+ const row = insertAbove ? rowIndexes.first : rowIndexes.last;
67
+ const table = affectedTableCells[0].findAncestor('table');
68
+ tableUtils.insertRows(table, { at: insertAbove ? row : row + 1, copyStructureFromAbove: !insertAbove });
69
+ }
70
+ }
@@ -5,7 +5,7 @@
5
5
  /**
6
6
  * @module table/commands/inserttablecommand
7
7
  */
8
- import { Command } from '@ckeditor/ckeditor5-core';
8
+ import { Command } from 'ckeditor5/src/core.js';
9
9
  /**
10
10
  * The insert table command.
11
11
  *
@@ -0,0 +1,69 @@
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/inserttablecommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core.js';
9
+ /**
10
+ * The insert table command.
11
+ *
12
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'insertTable'` editor command.
13
+ *
14
+ * To insert a table at the current selection, execute the command and specify the dimensions:
15
+ *
16
+ * ```ts
17
+ * editor.execute( 'insertTable', { rows: 20, columns: 5 } );
18
+ * ```
19
+ */
20
+ export class InsertTableCommand extends Command {
21
+ /**
22
+ * @inheritDoc
23
+ */
24
+ refresh() {
25
+ const model = this.editor.model;
26
+ const selection = model.document.selection;
27
+ const schema = model.schema;
28
+ this.isEnabled = isAllowedInParent(selection, schema);
29
+ }
30
+ /**
31
+ * Executes the command.
32
+ *
33
+ * Inserts a table with the given number of rows and columns into the editor.
34
+ *
35
+ * @param options.rows The number of rows to create in the inserted table. Default value is 2.
36
+ * @param options.columns The number of columns to create in the inserted table. Default value is 2.
37
+ * @param options.headingRows The number of heading rows. If not provided it will default to
38
+ * {@link module:table/tableconfig~TableConfig#defaultHeadings `config.table.defaultHeadings.rows`} table config.
39
+ * @param options.headingColumns The number of heading columns. If not provided it will default to
40
+ * {@link module:table/tableconfig~TableConfig#defaultHeadings `config.table.defaultHeadings.columns`} table config.
41
+ * @fires execute
42
+ */
43
+ execute(options = {}) {
44
+ const editor = this.editor;
45
+ const model = editor.model;
46
+ const tableUtils = editor.plugins.get('TableUtils');
47
+ const defaultRows = editor.config.get('table.defaultHeadings.rows');
48
+ const defaultColumns = editor.config.get('table.defaultHeadings.columns');
49
+ if (options.headingRows === undefined && defaultRows) {
50
+ options.headingRows = defaultRows;
51
+ }
52
+ if (options.headingColumns === undefined && defaultColumns) {
53
+ options.headingColumns = defaultColumns;
54
+ }
55
+ model.change(writer => {
56
+ const table = tableUtils.createTable(writer, options);
57
+ model.insertObject(table, null, null, { findOptimalPosition: 'auto' });
58
+ writer.setSelection(writer.createPositionAt(table.getNodeByPath([0, 0, 0]), 0));
59
+ });
60
+ }
61
+ }
62
+ /**
63
+ * Checks if the table is allowed in the parent.
64
+ */
65
+ function isAllowedInParent(selection, schema) {
66
+ const positionParent = selection.getFirstPosition().parent;
67
+ const validParent = positionParent === positionParent.root ? positionParent : positionParent.parent;
68
+ return schema.checkChild(validParent, 'table');
69
+ }
@@ -5,7 +5,7 @@
5
5
  /**
6
6
  * @module table/commands/inserttablelayoutcommand
7
7
  */
8
- import { Command } from '@ckeditor/ckeditor5-core';
8
+ import { Command } from 'ckeditor5/src/core.js';
9
9
  /**
10
10
  * The insert table layout command.
11
11
  *
@@ -0,0 +1,65 @@
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/inserttablelayoutcommand
7
+ */
8
+ import { Command } from 'ckeditor5/src/core.js';
9
+ /**
10
+ * The insert table layout command.
11
+ *
12
+ * The command is registered by {@link module:table/tablelayout/tablelayoutediting~TableLayoutEditing}
13
+ * as the `'insertTableLayout'` editor command.
14
+ *
15
+ * To insert a layout table at the current selection, execute the command and specify the dimensions:
16
+ *
17
+ * ```ts
18
+ * editor.execute( 'insertTableLayout', { rows: 20, columns: 5 } );
19
+ * ```
20
+ */
21
+ export class InsertTableLayoutCommand extends Command {
22
+ /**
23
+ * @inheritDoc
24
+ */
25
+ refresh() {
26
+ const model = this.editor.model;
27
+ const selection = model.document.selection;
28
+ const schema = model.schema;
29
+ this.isEnabled = isAllowedInParent(selection, schema);
30
+ }
31
+ /**
32
+ * Executes the command.
33
+ *
34
+ * Inserts a layout table with the given number of rows and columns into the editor.
35
+ *
36
+ * @param options.rows The number of rows to create in the inserted table. Default value is 2.
37
+ * @param options.columns The number of columns to create in the inserted table. Default value is 2.
38
+ * @fires execute
39
+ */
40
+ execute(options = {}) {
41
+ const editor = this.editor;
42
+ const model = editor.model;
43
+ const tableUtils = editor.plugins.get('TableUtils');
44
+ model.change(writer => {
45
+ const normalizedOptions = { rows: options.rows || 2, columns: options.columns || 2 };
46
+ const table = tableUtils.createTable(writer, normalizedOptions);
47
+ writer.setAttribute('tableType', 'layout', table);
48
+ model.insertObject(table, null, null, { findOptimalPosition: 'auto' });
49
+ const singleColumnWidth = `${100 / normalizedOptions.columns}%`;
50
+ const columnWidths = Array(normalizedOptions.columns).fill(singleColumnWidth);
51
+ const tableWidthsCommand = editor.commands.get('resizeColumnWidths');
52
+ // Make the table full-width with equal columns width.
53
+ tableWidthsCommand.execute({ tableWidth: '100%', columnWidths, table });
54
+ writer.setSelection(writer.createPositionAt(table.getNodeByPath([0, 0, 0]), 0));
55
+ });
56
+ }
57
+ }
58
+ /**
59
+ * Checks if the table is allowed in the parent.
60
+ */
61
+ function isAllowedInParent(selection, schema) {
62
+ const positionParent = selection.getFirstPosition().parent;
63
+ const validParent = positionParent === positionParent.root ? positionParent : positionParent.parent;
64
+ return schema.checkChild(validParent, 'table');
65
+ }
@@ -5,9 +5,9 @@
5
5
  /**
6
6
  * @module table/commands/mergecellcommand
7
7
  */
8
- import type { ModelNode } from '@ckeditor/ckeditor5-engine';
9
- import { Command, type Editor } from '@ckeditor/ckeditor5-core';
10
- import type { ArrowKeyCodeDirection } from '@ckeditor/ckeditor5-utils';
8
+ import type { ModelNode } from 'ckeditor5/src/engine.js';
9
+ import { Command, type Editor } from 'ckeditor5/src/core.js';
10
+ import type { ArrowKeyCodeDirection } from 'ckeditor5/src/utils.js';
11
11
  /**
12
12
  * The merge cell command.
13
13
  *
@@ -0,0 +1,206 @@
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 { TableWalker } from '../tablewalker.js';
7
+ import { isHeadingColumnCell } from '../utils/common.js';
8
+ import { removeEmptyRowsColumns } from '../utils/structure.js';
9
+ /**
10
+ * The merge cell command.
11
+ *
12
+ * The command is registered by {@link module:table/tableediting~TableEditing} as the `'mergeTableCellRight'`, `'mergeTableCellLeft'`,
13
+ * `'mergeTableCellUp'` and `'mergeTableCellDown'` editor commands.
14
+ *
15
+ * To merge a table cell at the current selection with another cell, execute the command corresponding with the preferred direction.
16
+ *
17
+ * For example, to merge with a cell to the right:
18
+ *
19
+ * ```ts
20
+ * editor.execute( 'mergeTableCellRight' );
21
+ * ```
22
+ *
23
+ * **Note**: If a table cell has a different [`rowspan`](https://www.w3.org/TR/html50/tabular-data.html#attr-tdth-rowspan)
24
+ * (for `'mergeTableCellRight'` and `'mergeTableCellLeft'`) or [`colspan`](https://www.w3.org/TR/html50/tabular-data.html#attr-tdth-colspan)
25
+ * (for `'mergeTableCellUp'` and `'mergeTableCellDown'`), the command will be disabled.
26
+ */
27
+ export class MergeCellCommand extends Command {
28
+ /**
29
+ * The direction that indicates which cell will be merged with the currently selected one.
30
+ */
31
+ direction;
32
+ /**
33
+ * Whether the merge is horizontal (left/right) or vertical (up/down).
34
+ */
35
+ isHorizontal;
36
+ /**
37
+ * Creates a new `MergeCellCommand` instance.
38
+ *
39
+ * @param editor The editor on which this command will be used.
40
+ * @param options.direction Indicates which cell to merge with the currently selected one.
41
+ * Possible values are: `'left'`, `'right'`, `'up'` and `'down'`.
42
+ */
43
+ constructor(editor, options) {
44
+ super(editor);
45
+ this.direction = options.direction;
46
+ this.isHorizontal = this.direction == 'right' || this.direction == 'left';
47
+ }
48
+ /**
49
+ * @inheritDoc
50
+ */
51
+ refresh() {
52
+ const cellToMerge = this._getMergeableCell();
53
+ this.value = cellToMerge;
54
+ this.isEnabled = !!cellToMerge;
55
+ }
56
+ /**
57
+ * Executes the command.
58
+ *
59
+ * Depending on the command's {@link #direction} value, it will merge the cell that is to the `'left'`, `'right'`, `'up'` or `'down'`.
60
+ *
61
+ * @fires execute
62
+ */
63
+ execute() {
64
+ const model = this.editor.model;
65
+ const doc = model.document;
66
+ const tableUtils = this.editor.plugins.get('TableUtils');
67
+ const tableCell = tableUtils.getTableCellsContainingSelection(doc.selection)[0];
68
+ const cellToMerge = this.value;
69
+ const direction = this.direction;
70
+ model.change(writer => {
71
+ const isMergeNext = direction == 'right' || direction == 'down';
72
+ // The merge mechanism is always the same so sort cells to be merged.
73
+ const cellToExpand = (isMergeNext ? tableCell : cellToMerge);
74
+ const cellToRemove = (isMergeNext ? cellToMerge : tableCell);
75
+ // Cache the parent of cell to remove for later check.
76
+ const removedTableCellRow = cellToRemove.parent;
77
+ mergeTableCells(cellToRemove, cellToExpand, writer);
78
+ const spanAttribute = this.isHorizontal ? 'colspan' : 'rowspan';
79
+ const cellSpan = parseInt(tableCell.getAttribute(spanAttribute) || '1');
80
+ const cellToMergeSpan = parseInt(cellToMerge.getAttribute(spanAttribute) || '1');
81
+ // Update table cell span attribute and merge set selection on merged contents.
82
+ writer.setAttribute(spanAttribute, cellSpan + cellToMergeSpan, cellToExpand);
83
+ writer.setSelection(writer.createRangeIn(cellToExpand));
84
+ const tableUtils = this.editor.plugins.get('TableUtils');
85
+ const table = removedTableCellRow.findAncestor('table');
86
+ // Remove empty rows and columns after merging.
87
+ removeEmptyRowsColumns(table, tableUtils);
88
+ });
89
+ }
90
+ /**
91
+ * Returns a cell that can be merged with the current cell depending on the command's direction.
92
+ */
93
+ _getMergeableCell() {
94
+ const model = this.editor.model;
95
+ const doc = model.document;
96
+ const tableUtils = this.editor.plugins.get('TableUtils');
97
+ const tableCell = tableUtils.getTableCellsContainingSelection(doc.selection)[0];
98
+ if (!tableCell) {
99
+ return;
100
+ }
101
+ // First get the cell on proper direction.
102
+ const cellToMerge = this.isHorizontal ?
103
+ getHorizontalCell(tableCell, this.direction, tableUtils) :
104
+ getVerticalCell(tableCell, this.direction, tableUtils);
105
+ if (!cellToMerge) {
106
+ return;
107
+ }
108
+ // If found check if the span perpendicular to merge direction is equal on both cells.
109
+ const spanAttribute = this.isHorizontal ? 'rowspan' : 'colspan';
110
+ const span = parseInt(tableCell.getAttribute(spanAttribute) || '1');
111
+ const cellToMergeSpan = parseInt(cellToMerge.getAttribute(spanAttribute) || '1');
112
+ if (cellToMergeSpan === span) {
113
+ return cellToMerge;
114
+ }
115
+ }
116
+ }
117
+ /**
118
+ * Returns the cell that can be merged horizontally.
119
+ */
120
+ function getHorizontalCell(tableCell, direction, tableUtils) {
121
+ const tableRow = tableCell.parent;
122
+ const table = tableRow.parent;
123
+ const horizontalCell = direction == 'right' ? tableCell.nextSibling : tableCell.previousSibling;
124
+ const hasHeadingColumns = (table.getAttribute('headingColumns') || 0) > 0;
125
+ if (!horizontalCell) {
126
+ return;
127
+ }
128
+ // Sort cells:
129
+ const cellOnLeft = (direction == 'right' ? tableCell : horizontalCell);
130
+ const cellOnRight = (direction == 'right' ? horizontalCell : tableCell);
131
+ // Get their column indexes:
132
+ const { column: leftCellColumn } = tableUtils.getCellLocation(cellOnLeft);
133
+ const { column: rightCellColumn } = tableUtils.getCellLocation(cellOnRight);
134
+ const leftCellSpan = parseInt(cellOnLeft.getAttribute('colspan') || '1');
135
+ const isCellOnLeftInHeadingColumn = isHeadingColumnCell(tableUtils, cellOnLeft);
136
+ const isCellOnRightInHeadingColumn = isHeadingColumnCell(tableUtils, cellOnRight);
137
+ // We cannot merge heading columns cells with regular cells.
138
+ if (hasHeadingColumns && isCellOnLeftInHeadingColumn != isCellOnRightInHeadingColumn) {
139
+ return;
140
+ }
141
+ // The cell on the right must have index that is distant to the cell on the left by the left cell's width (colspan).
142
+ const cellsAreTouching = leftCellColumn + leftCellSpan === rightCellColumn;
143
+ // If the right cell's column index is different it means that there are rowspanned cells between them.
144
+ return cellsAreTouching ? horizontalCell : undefined;
145
+ }
146
+ /**
147
+ * Returns the cell that can be merged vertically.
148
+ */
149
+ function getVerticalCell(tableCell, direction, tableUtils) {
150
+ const tableRow = tableCell.parent;
151
+ const table = tableRow.parent;
152
+ const rowIndex = table.getChildIndex(tableRow);
153
+ // Don't search for mergeable cell if direction points out of the table.
154
+ if ((direction == 'down' && rowIndex === tableUtils.getRows(table) - 1) || (direction == 'up' && rowIndex === 0)) {
155
+ return null;
156
+ }
157
+ const rowspan = parseInt(tableCell.getAttribute('rowspan') || '1');
158
+ const headingRows = table.getAttribute('headingRows') || 0;
159
+ const isMergeWithBodyCell = direction == 'down' && (rowIndex + rowspan) === headingRows;
160
+ const isMergeWithHeadCell = direction == 'up' && rowIndex === headingRows;
161
+ // Don't search for mergeable cell if direction points out of the current table section.
162
+ if (headingRows && (isMergeWithBodyCell || isMergeWithHeadCell)) {
163
+ return null;
164
+ }
165
+ const currentCellRowSpan = parseInt(tableCell.getAttribute('rowspan') || '1');
166
+ const rowOfCellToMerge = direction == 'down' ? rowIndex + currentCellRowSpan : rowIndex;
167
+ const tableMap = [...new TableWalker(table, { endRow: rowOfCellToMerge })];
168
+ const currentCellData = tableMap.find(value => value.cell === tableCell);
169
+ const mergeColumn = currentCellData.column;
170
+ const cellToMergeData = tableMap.find(({ row, cellHeight, column }) => {
171
+ if (column !== mergeColumn) {
172
+ return false;
173
+ }
174
+ if (direction == 'down') {
175
+ // If merging a cell below the mergeRow is already calculated.
176
+ return row === rowOfCellToMerge;
177
+ }
178
+ else {
179
+ // If merging a cell above calculate if it spans to mergeRow.
180
+ return rowOfCellToMerge === row + cellHeight;
181
+ }
182
+ });
183
+ return cellToMergeData && cellToMergeData.cell ? cellToMergeData.cell : null;
184
+ }
185
+ /**
186
+ * Merges two table cells. It will ensure that after merging cells with an empty paragraph, the resulting table cell will only have one
187
+ * paragraph. If one of the merged table cells is empty, the merged table cell will have the contents of the non-empty table cell.
188
+ * If both are empty, the merged table cell will have only one empty paragraph.
189
+ */
190
+ function mergeTableCells(cellToRemove, cellToExpand, writer) {
191
+ if (!isEmpty(cellToRemove)) {
192
+ if (isEmpty(cellToExpand)) {
193
+ writer.remove(writer.createRangeIn(cellToExpand));
194
+ }
195
+ writer.move(writer.createRangeIn(cellToRemove), writer.createPositionAt(cellToExpand, 'end'));
196
+ }
197
+ // Remove merged table cell.
198
+ writer.remove(cellToRemove);
199
+ }
200
+ /**
201
+ * Checks if the passed table cell contains an empty paragraph.
202
+ */
203
+ function isEmpty(tableCell) {
204
+ const firstTableChild = tableCell.getChild(0);
205
+ return tableCell.childCount == 1 && firstTableChild.is('element', 'paragraph') && firstTableChild.isEmpty;
206
+ }