@ckeditor/ckeditor5-table 47.6.1 → 48.0.0-alpha.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 (505) hide show
  1. package/LICENSE.md +1 -1
  2. package/ckeditor5-metadata.json +35 -22
  3. package/{src → dist}/augmentation.d.ts +2 -30
  4. package/{src → dist}/commands/insertcolumncommand.d.ts +1 -1
  5. package/{src → dist}/commands/insertrowcommand.d.ts +1 -1
  6. package/{src → dist}/commands/inserttablecommand.d.ts +5 -1
  7. package/{src → dist}/commands/inserttablelayoutcommand.d.ts +1 -1
  8. package/{src → dist}/commands/mergecellcommand.d.ts +3 -3
  9. package/{src → dist}/commands/mergecellscommand.d.ts +1 -1
  10. package/{src → dist}/commands/removecolumncommand.d.ts +1 -1
  11. package/{src → dist}/commands/removerowcommand.d.ts +1 -1
  12. package/{src → dist}/commands/selectcolumncommand.d.ts +1 -1
  13. package/{src → dist}/commands/selectrowcommand.d.ts +1 -1
  14. package/dist/commands/setfooterrowcommand.d.ts +53 -0
  15. package/{src → dist}/commands/setheadercolumncommand.d.ts +1 -1
  16. package/{src → dist}/commands/setheaderrowcommand.d.ts +1 -1
  17. package/{src → dist}/commands/splitcellcommand.d.ts +1 -1
  18. package/{src → dist}/converters/downcast.d.ts +3 -3
  19. package/{src → dist}/converters/table-caption-post-fixer.d.ts +1 -1
  20. package/{src → dist}/converters/table-cell-paragraph-post-fixer.d.ts +1 -1
  21. package/{src → dist}/converters/table-cell-refresh-handler.d.ts +1 -1
  22. package/{src → dist}/converters/table-layout-post-fixer.d.ts +1 -1
  23. package/dist/converters/table-structure-post-fixer.d.ts +20 -0
  24. package/{src/converters/table-headings-refresh-handler.d.ts → dist/converters/table-structure-refresh-handler.d.ts} +3 -3
  25. package/{src → dist}/converters/tableproperties.d.ts +11 -2
  26. package/{src → dist}/converters/upcasttable.d.ts +6 -2
  27. package/dist/index-content.css +100 -110
  28. package/dist/index-editor.css +620 -289
  29. package/dist/index.css +692 -585
  30. package/dist/index.css.map +1 -1
  31. package/{src → dist}/index.d.ts +5 -7
  32. package/dist/index.js +11002 -12488
  33. package/dist/index.js.map +1 -1
  34. package/{src → dist}/plaintableoutput.d.ts +1 -1
  35. package/{src → dist}/table.d.ts +2 -2
  36. package/{src → dist}/tablecaption/tablecaptionediting.d.ts +2 -2
  37. package/{src → dist}/tablecaption/tablecaptionui.d.ts +1 -1
  38. package/{src → dist}/tablecaption/toggletablecaptioncommand.d.ts +1 -1
  39. package/{src → dist}/tablecaption/utils.d.ts +1 -1
  40. package/{src → dist}/tablecaption.d.ts +1 -1
  41. package/{src → dist}/tablecellproperties/commands/tablecellbackgroundcolorcommand.d.ts +1 -1
  42. package/{src → dist}/tablecellproperties/commands/tablecellbordercolorcommand.d.ts +2 -2
  43. package/{src → dist}/tablecellproperties/commands/tablecellborderstylecommand.d.ts +2 -2
  44. package/{src → dist}/tablecellproperties/commands/tablecellborderwidthcommand.d.ts +2 -2
  45. package/{src → dist}/tablecellproperties/commands/tablecellheightcommand.d.ts +1 -1
  46. package/{src → dist}/tablecellproperties/commands/tablecellhorizontalalignmentcommand.d.ts +1 -1
  47. package/{src → dist}/tablecellproperties/commands/tablecellpaddingcommand.d.ts +2 -2
  48. package/{src → dist}/tablecellproperties/commands/tablecellpropertycommand.d.ts +2 -2
  49. package/{src → dist}/tablecellproperties/commands/tablecelltypecommand.d.ts +2 -6
  50. package/{src → dist}/tablecellproperties/commands/tablecellverticalalignmentcommand.d.ts +1 -1
  51. package/{src → dist}/tablecellproperties/tablecellpropertiesediting.d.ts +1 -1
  52. package/{src → dist}/tablecellproperties/tablecellpropertiesui.d.ts +2 -2
  53. package/dist/tablecellproperties/tablecellpropertiesutils.d.ts +18 -0
  54. package/{src/tablecellproperties/ui/tablecellpropertiesviewexperimental.d.ts → dist/tablecellproperties/ui/tablecellpropertiesview.d.ts} +11 -13
  55. package/{src → dist}/tablecellproperties.d.ts +1 -1
  56. package/{src → dist}/tablecellwidth/commands/tablecellwidthcommand.d.ts +1 -1
  57. package/{src → dist}/tablecellwidth/tablecellwidthediting.d.ts +1 -1
  58. package/{src → dist}/tableclipboard.d.ts +3 -3
  59. package/{src → dist}/tablecolumnresize/converters.d.ts +1 -1
  60. package/{src → dist}/tablecolumnresize/tablecolumnresizeediting.d.ts +2 -2
  61. package/{src → dist}/tablecolumnresize/tablewidthscommand.d.ts +2 -2
  62. package/{src → dist}/tablecolumnresize/utils.d.ts +2 -2
  63. package/{src → dist}/tablecolumnresize.d.ts +1 -1
  64. package/{src → dist}/tableconfig.d.ts +57 -8
  65. package/{src → dist}/tableediting.d.ts +3 -3
  66. package/{src → dist}/tablekeyboard.d.ts +3 -3
  67. package/{src → dist}/tablelayout/commands/tabletypecommand.d.ts +1 -1
  68. package/{src → dist}/tablelayout/tablelayoutediting.d.ts +1 -1
  69. package/{src → dist}/tablelayout/tablelayoutui.d.ts +1 -1
  70. package/{src → dist}/tablelayout.d.ts +1 -1
  71. package/{src → dist}/tablemouse/mouseeventsobserver.d.ts +1 -1
  72. package/{src → dist}/tablemouse.d.ts +1 -1
  73. package/{src → dist}/tableproperties/commands/tablealignmentcommand.d.ts +1 -1
  74. package/{src → dist}/tableproperties/commands/tablebackgroundcolorcommand.d.ts +1 -1
  75. package/{src → dist}/tableproperties/commands/tablebordercolorcommand.d.ts +2 -2
  76. package/{src → dist}/tableproperties/commands/tableborderstylecommand.d.ts +2 -2
  77. package/{src → dist}/tableproperties/commands/tableborderwidthcommand.d.ts +2 -2
  78. package/{src → dist}/tableproperties/commands/tableheightcommand.d.ts +1 -1
  79. package/{src → dist}/tableproperties/commands/tablepropertycommand.d.ts +2 -2
  80. package/{src → dist}/tableproperties/commands/tablewidthcommand.d.ts +1 -1
  81. package/{src → dist}/tableproperties/tablepropertiesediting.d.ts +1 -1
  82. package/{src → dist}/tableproperties/tablepropertiesui.d.ts +2 -2
  83. package/{src → dist}/tableproperties/ui/tablepropertiesview.d.ts +10 -3
  84. package/{src → dist}/tableproperties.d.ts +1 -1
  85. package/{src → dist}/tableselection.d.ts +2 -2
  86. package/{src → dist}/tabletoolbar.d.ts +2 -2
  87. package/{src → dist}/tableui.d.ts +1 -1
  88. package/{src → dist}/tableutils.d.ts +69 -17
  89. package/{src → dist}/tablewalker.d.ts +1 -1
  90. package/dist/translations/af.js +1 -1
  91. package/dist/translations/af.umd.js +1 -1
  92. package/dist/translations/ar.js +1 -1
  93. package/dist/translations/ar.umd.js +1 -1
  94. package/dist/translations/ast.js +1 -1
  95. package/dist/translations/ast.umd.js +1 -1
  96. package/dist/translations/az.js +1 -1
  97. package/dist/translations/az.umd.js +1 -1
  98. package/dist/translations/be.js +1 -1
  99. package/dist/translations/be.umd.js +1 -1
  100. package/dist/translations/bg.js +1 -1
  101. package/dist/translations/bg.umd.js +1 -1
  102. package/dist/translations/bn.js +1 -1
  103. package/dist/translations/bn.umd.js +1 -1
  104. package/dist/translations/bs.js +1 -1
  105. package/dist/translations/bs.umd.js +1 -1
  106. package/dist/translations/ca.js +1 -1
  107. package/dist/translations/ca.umd.js +1 -1
  108. package/dist/translations/cs.js +1 -1
  109. package/dist/translations/cs.umd.js +1 -1
  110. package/dist/translations/da.js +1 -1
  111. package/dist/translations/da.umd.js +1 -1
  112. package/dist/translations/de-ch.js +1 -1
  113. package/dist/translations/de-ch.umd.js +1 -1
  114. package/dist/translations/de.js +1 -1
  115. package/dist/translations/de.umd.js +1 -1
  116. package/dist/translations/el.js +1 -1
  117. package/dist/translations/el.umd.js +1 -1
  118. package/dist/translations/en-au.js +1 -1
  119. package/dist/translations/en-au.umd.js +1 -1
  120. package/dist/translations/en-gb.js +1 -1
  121. package/dist/translations/en-gb.umd.js +1 -1
  122. package/dist/translations/en.js +1 -1
  123. package/dist/translations/en.umd.js +1 -1
  124. package/dist/translations/eo.js +1 -1
  125. package/dist/translations/eo.umd.js +1 -1
  126. package/dist/translations/es-co.js +1 -1
  127. package/dist/translations/es-co.umd.js +1 -1
  128. package/dist/translations/es.js +1 -1
  129. package/dist/translations/es.umd.js +1 -1
  130. package/dist/translations/et.js +1 -1
  131. package/dist/translations/et.umd.js +1 -1
  132. package/dist/translations/eu.js +1 -1
  133. package/dist/translations/eu.umd.js +1 -1
  134. package/dist/translations/fa.js +1 -1
  135. package/dist/translations/fa.umd.js +1 -1
  136. package/dist/translations/fi.js +1 -1
  137. package/dist/translations/fi.umd.js +1 -1
  138. package/dist/translations/fr.js +1 -1
  139. package/dist/translations/fr.umd.js +1 -1
  140. package/dist/translations/gl.js +1 -1
  141. package/dist/translations/gl.umd.js +1 -1
  142. package/dist/translations/gu.js +1 -1
  143. package/dist/translations/gu.umd.js +1 -1
  144. package/dist/translations/he.js +1 -1
  145. package/dist/translations/he.umd.js +1 -1
  146. package/dist/translations/hi.js +1 -1
  147. package/dist/translations/hi.umd.js +1 -1
  148. package/dist/translations/hr.js +1 -1
  149. package/dist/translations/hr.umd.js +1 -1
  150. package/dist/translations/hu.js +1 -1
  151. package/dist/translations/hu.umd.js +1 -1
  152. package/dist/translations/hy.js +1 -1
  153. package/dist/translations/hy.umd.js +1 -1
  154. package/dist/translations/id.js +1 -1
  155. package/dist/translations/id.umd.js +1 -1
  156. package/dist/translations/it.js +1 -1
  157. package/dist/translations/it.umd.js +1 -1
  158. package/dist/translations/ja.js +1 -1
  159. package/dist/translations/ja.umd.js +1 -1
  160. package/dist/translations/jv.js +1 -1
  161. package/dist/translations/jv.umd.js +1 -1
  162. package/dist/translations/kk.js +1 -1
  163. package/dist/translations/kk.umd.js +1 -1
  164. package/dist/translations/km.js +1 -1
  165. package/dist/translations/km.umd.js +1 -1
  166. package/dist/translations/kn.js +1 -1
  167. package/dist/translations/kn.umd.js +1 -1
  168. package/dist/translations/ko.js +1 -1
  169. package/dist/translations/ko.umd.js +1 -1
  170. package/dist/translations/ku.js +1 -1
  171. package/dist/translations/ku.umd.js +1 -1
  172. package/dist/translations/lt.js +1 -1
  173. package/dist/translations/lt.umd.js +1 -1
  174. package/dist/translations/lv.js +1 -1
  175. package/dist/translations/lv.umd.js +1 -1
  176. package/dist/translations/ms.js +1 -1
  177. package/dist/translations/ms.umd.js +1 -1
  178. package/dist/translations/nb.js +1 -1
  179. package/dist/translations/nb.umd.js +1 -1
  180. package/dist/translations/ne.js +1 -1
  181. package/dist/translations/ne.umd.js +1 -1
  182. package/dist/translations/nl.js +1 -1
  183. package/dist/translations/nl.umd.js +1 -1
  184. package/dist/translations/no.js +1 -1
  185. package/dist/translations/no.umd.js +1 -1
  186. package/dist/translations/oc.js +1 -1
  187. package/dist/translations/oc.umd.js +1 -1
  188. package/dist/translations/pl.js +1 -1
  189. package/dist/translations/pl.umd.js +1 -1
  190. package/dist/translations/pt-br.js +1 -1
  191. package/dist/translations/pt-br.umd.js +1 -1
  192. package/dist/translations/pt.js +1 -1
  193. package/dist/translations/pt.umd.js +1 -1
  194. package/dist/translations/ro.js +1 -1
  195. package/dist/translations/ro.umd.js +1 -1
  196. package/dist/translations/ru.js +1 -1
  197. package/dist/translations/ru.umd.js +1 -1
  198. package/dist/translations/si.js +1 -1
  199. package/dist/translations/si.umd.js +1 -1
  200. package/dist/translations/sk.js +1 -1
  201. package/dist/translations/sk.umd.js +1 -1
  202. package/dist/translations/sl.js +1 -1
  203. package/dist/translations/sl.umd.js +1 -1
  204. package/dist/translations/sq.js +1 -1
  205. package/dist/translations/sq.umd.js +1 -1
  206. package/dist/translations/sr-latn.js +1 -1
  207. package/dist/translations/sr-latn.umd.js +1 -1
  208. package/dist/translations/sr.js +1 -1
  209. package/dist/translations/sr.umd.js +1 -1
  210. package/dist/translations/sv.js +1 -1
  211. package/dist/translations/sv.umd.js +1 -1
  212. package/dist/translations/th.js +1 -1
  213. package/dist/translations/th.umd.js +1 -1
  214. package/dist/translations/ti.js +1 -1
  215. package/dist/translations/ti.umd.js +1 -1
  216. package/dist/translations/tk.js +1 -1
  217. package/dist/translations/tk.umd.js +1 -1
  218. package/dist/translations/tr.js +1 -1
  219. package/dist/translations/tr.umd.js +1 -1
  220. package/dist/translations/tt.js +1 -1
  221. package/dist/translations/tt.umd.js +1 -1
  222. package/dist/translations/ug.js +1 -1
  223. package/dist/translations/ug.umd.js +1 -1
  224. package/dist/translations/uk.js +1 -1
  225. package/dist/translations/uk.umd.js +1 -1
  226. package/dist/translations/ur.js +1 -1
  227. package/dist/translations/ur.umd.js +1 -1
  228. package/dist/translations/uz.js +1 -1
  229. package/dist/translations/uz.umd.js +1 -1
  230. package/dist/translations/vi.js +1 -1
  231. package/dist/translations/vi.umd.js +1 -1
  232. package/dist/translations/zh-cn.js +1 -1
  233. package/dist/translations/zh-cn.umd.js +1 -1
  234. package/dist/translations/zh.js +1 -1
  235. package/dist/translations/zh.umd.js +1 -1
  236. package/{src → dist}/ui/colorinputview.d.ts +2 -2
  237. package/{src → dist}/ui/inserttableview.d.ts +2 -2
  238. package/{src → dist}/utils/common.d.ts +2 -2
  239. package/{src → dist}/utils/structure.d.ts +1 -1
  240. package/{src → dist}/utils/table-properties.d.ts +1 -1
  241. package/{src → dist}/utils/ui/contextualballoon.d.ts +2 -2
  242. package/{src → dist}/utils/ui/table-properties.d.ts +2 -2
  243. package/{src → dist}/utils/ui/widget.d.ts +1 -1
  244. package/package.json +27 -50
  245. package/build/table.js +0 -5
  246. package/build/translations/af.js +0 -1
  247. package/build/translations/ar.js +0 -1
  248. package/build/translations/ast.js +0 -1
  249. package/build/translations/az.js +0 -1
  250. package/build/translations/be.js +0 -1
  251. package/build/translations/bg.js +0 -1
  252. package/build/translations/bn.js +0 -1
  253. package/build/translations/bs.js +0 -1
  254. package/build/translations/ca.js +0 -1
  255. package/build/translations/cs.js +0 -1
  256. package/build/translations/da.js +0 -1
  257. package/build/translations/de-ch.js +0 -1
  258. package/build/translations/de.js +0 -1
  259. package/build/translations/el.js +0 -1
  260. package/build/translations/en-au.js +0 -1
  261. package/build/translations/en-gb.js +0 -1
  262. package/build/translations/eo.js +0 -1
  263. package/build/translations/es-co.js +0 -1
  264. package/build/translations/es.js +0 -1
  265. package/build/translations/et.js +0 -1
  266. package/build/translations/eu.js +0 -1
  267. package/build/translations/fa.js +0 -1
  268. package/build/translations/fi.js +0 -1
  269. package/build/translations/fr.js +0 -1
  270. package/build/translations/gl.js +0 -1
  271. package/build/translations/gu.js +0 -1
  272. package/build/translations/he.js +0 -1
  273. package/build/translations/hi.js +0 -1
  274. package/build/translations/hr.js +0 -1
  275. package/build/translations/hu.js +0 -1
  276. package/build/translations/hy.js +0 -1
  277. package/build/translations/id.js +0 -1
  278. package/build/translations/it.js +0 -1
  279. package/build/translations/ja.js +0 -1
  280. package/build/translations/jv.js +0 -1
  281. package/build/translations/kk.js +0 -1
  282. package/build/translations/km.js +0 -1
  283. package/build/translations/kn.js +0 -1
  284. package/build/translations/ko.js +0 -1
  285. package/build/translations/ku.js +0 -1
  286. package/build/translations/lt.js +0 -1
  287. package/build/translations/lv.js +0 -1
  288. package/build/translations/ms.js +0 -1
  289. package/build/translations/nb.js +0 -1
  290. package/build/translations/ne.js +0 -1
  291. package/build/translations/nl.js +0 -1
  292. package/build/translations/no.js +0 -1
  293. package/build/translations/oc.js +0 -1
  294. package/build/translations/pl.js +0 -1
  295. package/build/translations/pt-br.js +0 -1
  296. package/build/translations/pt.js +0 -1
  297. package/build/translations/ro.js +0 -1
  298. package/build/translations/ru.js +0 -1
  299. package/build/translations/si.js +0 -1
  300. package/build/translations/sk.js +0 -1
  301. package/build/translations/sl.js +0 -1
  302. package/build/translations/sq.js +0 -1
  303. package/build/translations/sr-latn.js +0 -1
  304. package/build/translations/sr.js +0 -1
  305. package/build/translations/sv.js +0 -1
  306. package/build/translations/th.js +0 -1
  307. package/build/translations/ti.js +0 -1
  308. package/build/translations/tk.js +0 -1
  309. package/build/translations/tr.js +0 -1
  310. package/build/translations/tt.js +0 -1
  311. package/build/translations/ug.js +0 -1
  312. package/build/translations/uk.js +0 -1
  313. package/build/translations/ur.js +0 -1
  314. package/build/translations/uz.js +0 -1
  315. package/build/translations/vi.js +0 -1
  316. package/build/translations/zh-cn.js +0 -1
  317. package/build/translations/zh.js +0 -1
  318. package/lang/contexts.json +0 -82
  319. package/lang/translations/af.po +0 -332
  320. package/lang/translations/ar.po +0 -332
  321. package/lang/translations/ast.po +0 -332
  322. package/lang/translations/az.po +0 -332
  323. package/lang/translations/be.po +0 -332
  324. package/lang/translations/bg.po +0 -332
  325. package/lang/translations/bn.po +0 -334
  326. package/lang/translations/bs.po +0 -332
  327. package/lang/translations/ca.po +0 -332
  328. package/lang/translations/cs.po +0 -332
  329. package/lang/translations/da.po +0 -332
  330. package/lang/translations/de-ch.po +0 -332
  331. package/lang/translations/de.po +0 -332
  332. package/lang/translations/el.po +0 -332
  333. package/lang/translations/en-au.po +0 -332
  334. package/lang/translations/en-gb.po +0 -332
  335. package/lang/translations/en.po +0 -332
  336. package/lang/translations/eo.po +0 -332
  337. package/lang/translations/es-co.po +0 -332
  338. package/lang/translations/es.po +0 -332
  339. package/lang/translations/et.po +0 -332
  340. package/lang/translations/eu.po +0 -332
  341. package/lang/translations/fa.po +0 -332
  342. package/lang/translations/fi.po +0 -332
  343. package/lang/translations/fr.po +0 -332
  344. package/lang/translations/gl.po +0 -332
  345. package/lang/translations/gu.po +0 -332
  346. package/lang/translations/he.po +0 -332
  347. package/lang/translations/hi.po +0 -332
  348. package/lang/translations/hr.po +0 -332
  349. package/lang/translations/hu.po +0 -332
  350. package/lang/translations/hy.po +0 -332
  351. package/lang/translations/id.po +0 -332
  352. package/lang/translations/it.po +0 -332
  353. package/lang/translations/ja.po +0 -332
  354. package/lang/translations/jv.po +0 -332
  355. package/lang/translations/kk.po +0 -332
  356. package/lang/translations/km.po +0 -332
  357. package/lang/translations/kn.po +0 -332
  358. package/lang/translations/ko.po +0 -332
  359. package/lang/translations/ku.po +0 -332
  360. package/lang/translations/lt.po +0 -332
  361. package/lang/translations/lv.po +0 -332
  362. package/lang/translations/ms.po +0 -332
  363. package/lang/translations/nb.po +0 -332
  364. package/lang/translations/ne.po +0 -332
  365. package/lang/translations/nl.po +0 -332
  366. package/lang/translations/no.po +0 -332
  367. package/lang/translations/oc.po +0 -332
  368. package/lang/translations/pl.po +0 -332
  369. package/lang/translations/pt-br.po +0 -332
  370. package/lang/translations/pt.po +0 -332
  371. package/lang/translations/ro.po +0 -332
  372. package/lang/translations/ru.po +0 -332
  373. package/lang/translations/si.po +0 -332
  374. package/lang/translations/sk.po +0 -332
  375. package/lang/translations/sl.po +0 -332
  376. package/lang/translations/sq.po +0 -332
  377. package/lang/translations/sr-latn.po +0 -332
  378. package/lang/translations/sr.po +0 -332
  379. package/lang/translations/sv.po +0 -332
  380. package/lang/translations/th.po +0 -332
  381. package/lang/translations/ti.po +0 -332
  382. package/lang/translations/tk.po +0 -332
  383. package/lang/translations/tr.po +0 -332
  384. package/lang/translations/tt.po +0 -332
  385. package/lang/translations/ug.po +0 -332
  386. package/lang/translations/uk.po +0 -332
  387. package/lang/translations/ur.po +0 -332
  388. package/lang/translations/uz.po +0 -332
  389. package/lang/translations/vi.po +0 -332
  390. package/lang/translations/zh-cn.po +0 -332
  391. package/lang/translations/zh.po +0 -332
  392. package/src/augmentation.js +0 -5
  393. package/src/commands/insertcolumncommand.js +0 -71
  394. package/src/commands/insertrowcommand.js +0 -70
  395. package/src/commands/inserttablecommand.js +0 -69
  396. package/src/commands/inserttablelayoutcommand.js +0 -65
  397. package/src/commands/mergecellcommand.js +0 -206
  398. package/src/commands/mergecellscommand.js +0 -94
  399. package/src/commands/removecolumncommand.js +0 -109
  400. package/src/commands/removerowcommand.js +0 -82
  401. package/src/commands/selectcolumncommand.js +0 -60
  402. package/src/commands/selectrowcommand.js +0 -56
  403. package/src/commands/setheadercolumncommand.js +0 -76
  404. package/src/commands/setheaderrowcommand.js +0 -83
  405. package/src/commands/splitcellcommand.js +0 -58
  406. package/src/converters/downcast.js +0 -322
  407. package/src/converters/table-caption-post-fixer.js +0 -55
  408. package/src/converters/table-cell-paragraph-post-fixer.js +0 -109
  409. package/src/converters/table-cell-refresh-handler.js +0 -47
  410. package/src/converters/table-headings-refresh-handler.js +0 -51
  411. package/src/converters/table-layout-post-fixer.js +0 -369
  412. package/src/converters/tableproperties.js +0 -451
  413. package/src/converters/upcasttable.js +0 -385
  414. package/src/index.js +0 -98
  415. package/src/plaintableoutput.js +0 -49
  416. package/src/table.js +0 -50
  417. package/src/tablecaption/tablecaptionediting.js +0 -178
  418. package/src/tablecaption/tablecaptionui.js +0 -64
  419. package/src/tablecaption/toggletablecaptioncommand.js +0 -105
  420. package/src/tablecaption/utils.js +0 -61
  421. package/src/tablecaption.js +0 -34
  422. package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.js +0 -30
  423. package/src/tablecellproperties/commands/tablecellbordercolorcommand.js +0 -44
  424. package/src/tablecellproperties/commands/tablecellborderstylecommand.js +0 -44
  425. package/src/tablecellproperties/commands/tablecellborderwidthcommand.js +0 -64
  426. package/src/tablecellproperties/commands/tablecellheightcommand.js +0 -51
  427. package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.js +0 -30
  428. package/src/tablecellproperties/commands/tablecellpaddingcommand.js +0 -64
  429. package/src/tablecellproperties/commands/tablecellpropertycommand.js +0 -138
  430. package/src/tablecellproperties/commands/tablecelltypecommand.js +0 -167
  431. package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.js +0 -38
  432. package/src/tablecellproperties/tablecellpropertiesediting.js +0 -412
  433. package/src/tablecellproperties/tablecellpropertiesui.js +0 -385
  434. package/src/tablecellproperties/tablecellpropertiesuiexperimental.d.ts +0 -128
  435. package/src/tablecellproperties/tablecellpropertiesuiexperimental.js +0 -408
  436. package/src/tablecellproperties/ui/tablecellpropertiesview.d.ts +0 -229
  437. package/src/tablecellproperties/ui/tablecellpropertiesview.js +0 -612
  438. package/src/tablecellproperties/ui/tablecellpropertiesviewexperimental.js +0 -744
  439. package/src/tablecellproperties.js +0 -40
  440. package/src/tablecellwidth/commands/tablecellwidthcommand.js +0 -51
  441. package/src/tablecellwidth/tablecellwidthediting.js +0 -53
  442. package/src/tableclipboard.js +0 -500
  443. package/src/tablecolumnresize/constants.js +0 -33
  444. package/src/tablecolumnresize/converters.js +0 -62
  445. package/src/tablecolumnresize/tablecolumnresizeediting.js +0 -734
  446. package/src/tablecolumnresize/tablewidthscommand.js +0 -61
  447. package/src/tablecolumnresize/utils.js +0 -370
  448. package/src/tablecolumnresize.js +0 -36
  449. package/src/tableconfig.js +0 -5
  450. package/src/tableediting.js +0 -246
  451. package/src/tablekeyboard.js +0 -273
  452. package/src/tablelayout/commands/tabletypecommand.js +0 -68
  453. package/src/tablelayout/tablelayoutediting.js +0 -295
  454. package/src/tablelayout/tablelayoutui.js +0 -196
  455. package/src/tablelayout.js +0 -36
  456. package/src/tablemouse/mouseeventsobserver.js +0 -34
  457. package/src/tablemouse.js +0 -178
  458. package/src/tableproperties/commands/tablealignmentcommand.js +0 -30
  459. package/src/tableproperties/commands/tablebackgroundcolorcommand.js +0 -30
  460. package/src/tableproperties/commands/tablebordercolorcommand.js +0 -44
  461. package/src/tableproperties/commands/tableborderstylecommand.js +0 -44
  462. package/src/tableproperties/commands/tableborderwidthcommand.js +0 -64
  463. package/src/tableproperties/commands/tableheightcommand.js +0 -54
  464. package/src/tableproperties/commands/tablepropertycommand.js +0 -103
  465. package/src/tableproperties/commands/tablewidthcommand.js +0 -54
  466. package/src/tableproperties/tablepropertiesediting.js +0 -546
  467. package/src/tableproperties/tablepropertiesui.js +0 -374
  468. package/src/tableproperties/tablepropertiesuiexperimental.d.ts +0 -136
  469. package/src/tableproperties/tablepropertiesuiexperimental.js +0 -375
  470. package/src/tableproperties/ui/tablepropertiesview.js +0 -520
  471. package/src/tableproperties/ui/tablepropertiesviewexperimental.d.ts +0 -216
  472. package/src/tableproperties/ui/tablepropertiesviewexperimental.js +0 -544
  473. package/src/tableproperties.js +0 -40
  474. package/src/tableselection.js +0 -323
  475. package/src/tabletoolbar.js +0 -63
  476. package/src/tableui.js +0 -335
  477. package/src/tableutils.js +0 -1282
  478. package/src/tablewalker.js +0 -489
  479. package/src/ui/colorinputview.js +0 -305
  480. package/src/ui/inserttableview.js +0 -192
  481. package/src/utils/common.js +0 -118
  482. package/src/utils/structure.js +0 -452
  483. package/src/utils/table-properties.js +0 -121
  484. package/src/utils/ui/contextualballoon.js +0 -111
  485. package/src/utils/ui/table-properties.js +0 -390
  486. package/src/utils/ui/table-propertiesexperimental.d.ts +0 -215
  487. package/src/utils/ui/table-propertiesexperimental.js +0 -391
  488. package/src/utils/ui/widget.js +0 -56
  489. package/theme/colorinput.css +0 -39
  490. package/theme/formrow-experimental.css +0 -15
  491. package/theme/formrow.css +0 -13
  492. package/theme/inserttable.css +0 -10
  493. package/theme/table.css +0 -144
  494. package/theme/tablecaption.css +0 -66
  495. package/theme/tablecellproperties-experimental.css +0 -4
  496. package/theme/tablecellproperties.css +0 -28
  497. package/theme/tablecolumnresize.css +0 -62
  498. package/theme/tableediting.css +0 -10
  499. package/theme/tableform-experimental.css +0 -61
  500. package/theme/tableform.css +0 -64
  501. package/theme/tablelayout.css +0 -74
  502. package/theme/tableproperties-experimental.css +0 -78
  503. package/theme/tableproperties.css +0 -18
  504. package/theme/tableselection.css +0 -10
  505. /package/{src → dist}/tablecolumnresize/constants.d.ts +0 -0
@@ -1,206 +0,0 @@
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
- }
@@ -1,94 +0,0 @@
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
- }
@@ -1,109 +0,0 @@
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
- }
@@ -1,82 +0,0 @@
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
- }
@@ -1,60 +0,0 @@
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
- }
@@ -1,56 +0,0 @@
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
- }