@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,76 +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/setheadercolumncommand
7
- */
8
- import { Command } from 'ckeditor5/src/core.js';
9
- import { isHeadingColumnCell } from '../utils/common.js';
10
- import { getHorizontallyOverlappingCells, splitVertically } from '../utils/structure.js';
11
- /**
12
- * The header column command.
13
- *
14
- * The command is registered by {@link module:table/tableediting~TableEditing} as the `'setTableColumnHeader'` editor command.
15
- *
16
- * You can make the column containing the selected cell a [header](https://www.w3.org/TR/html50/tabular-data.html#the-th-element)
17
- * by executing:
18
- *
19
- * ```ts
20
- * editor.execute( 'setTableColumnHeader' );
21
- * ```
22
- *
23
- * **Note:** All preceding columns will also become headers. If the current column is already a header, executing this command
24
- * will make it a regular column back again (including the following columns).
25
- */
26
- export class SetHeaderColumnCommand extends Command {
27
- /**
28
- * @inheritDoc
29
- */
30
- refresh() {
31
- const tableUtils = this.editor.plugins.get('TableUtils');
32
- const model = this.editor.model;
33
- const selectedCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
34
- if (selectedCells.length === 0) {
35
- this.isEnabled = false;
36
- this.value = false;
37
- return;
38
- }
39
- const table = selectedCells[0].findAncestor('table');
40
- this.isEnabled = model.schema.checkAttribute(table, 'headingColumns');
41
- this.value = selectedCells.every(cell => isHeadingColumnCell(tableUtils, cell));
42
- }
43
- /**
44
- * Executes the command.
45
- *
46
- * When the selection is in a non-header column, the command will set the `headingColumns` table attribute to cover that column.
47
- *
48
- * When the selection is already in a header column, it will set `headingColumns` so the heading section will end before that column.
49
- *
50
- * @fires execute
51
- * @param options.forceValue If set, the command will set (`true`) or unset (`false`) the header columns according to
52
- * the `forceValue` parameter instead of the current model state.
53
- */
54
- execute(options = {}) {
55
- if (options.forceValue === this.value) {
56
- return;
57
- }
58
- const tableUtils = this.editor.plugins.get('TableUtils');
59
- const model = this.editor.model;
60
- const selectedCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
61
- const table = selectedCells[0].findAncestor('table');
62
- const { first, last } = tableUtils.getColumnIndexes(selectedCells);
63
- const headingColumnsToSet = this.value ? first : last + 1;
64
- model.change(writer => {
65
- if (headingColumnsToSet) {
66
- // Changing heading columns requires to check if any of a heading cell is overlapping horizontally the table head.
67
- // Any table cell that has a colspan attribute > 1 will not exceed the table head so we need to fix it in columns before.
68
- const overlappingCells = getHorizontallyOverlappingCells(table, headingColumnsToSet);
69
- for (const { cell, column } of overlappingCells) {
70
- splitVertically(cell, column, headingColumnsToSet, writer);
71
- }
72
- }
73
- tableUtils.setHeadingColumnsCount(writer, table, headingColumnsToSet);
74
- });
75
- }
76
- }
@@ -1,83 +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/setheaderrowcommand
7
- */
8
- import { Command } from 'ckeditor5/src/core.js';
9
- import { getVerticallyOverlappingCells, splitHorizontally } from '../utils/structure.js';
10
- /**
11
- * The header row command.
12
- *
13
- * The command is registered by {@link module:table/tableediting~TableEditing} as the `'setTableColumnHeader'` editor command.
14
- *
15
- * You can make the row containing the selected cell a [header](https://www.w3.org/TR/html50/tabular-data.html#the-th-element) by executing:
16
- *
17
- * ```ts
18
- * editor.execute( 'setTableRowHeader' );
19
- * ```
20
- *
21
- * **Note:** All preceding rows will also become headers. If the current row is already a header, executing this command
22
- * will make it a regular row back again (including the following rows).
23
- */
24
- export class SetHeaderRowCommand extends Command {
25
- /**
26
- * @inheritDoc
27
- */
28
- refresh() {
29
- const tableUtils = this.editor.plugins.get('TableUtils');
30
- const model = this.editor.model;
31
- const selectedCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
32
- if (selectedCells.length === 0) {
33
- this.isEnabled = false;
34
- this.value = false;
35
- return;
36
- }
37
- const table = selectedCells[0].findAncestor('table');
38
- this.isEnabled = model.schema.checkAttribute(table, 'headingRows');
39
- this.value = selectedCells.every(cell => this._isInHeading(cell, cell.parent.parent));
40
- }
41
- /**
42
- * Executes the command.
43
- *
44
- * When the selection is in a non-header row, the command will set the `headingRows` table attribute to cover that row.
45
- *
46
- * When the selection is already in a header row, it will set `headingRows` so the heading section will end before that row.
47
- *
48
- * @fires execute
49
- * @param options.forceValue If set, the command will set (`true`) or unset (`false`) the header rows according to
50
- * the `forceValue` parameter instead of the current model state.
51
- */
52
- execute(options = {}) {
53
- if (options.forceValue === this.value) {
54
- return;
55
- }
56
- const tableUtils = this.editor.plugins.get('TableUtils');
57
- const model = this.editor.model;
58
- const selectedCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
59
- const table = selectedCells[0].findAncestor('table');
60
- const { first, last } = tableUtils.getRowIndexes(selectedCells);
61
- const headingRowsToSet = this.value ? first : last + 1;
62
- const currentHeadingRows = table.getAttribute('headingRows') || 0;
63
- model.change(writer => {
64
- if (headingRowsToSet) {
65
- // Changing heading rows requires to check if any of a heading cell is overlapping vertically the table head.
66
- // Any table cell that has a rowspan attribute > 1 will not exceed the table head so we need to fix it in rows below.
67
- const startRow = headingRowsToSet > currentHeadingRows ? currentHeadingRows : 0;
68
- const overlappingCells = getVerticallyOverlappingCells(table, headingRowsToSet, startRow);
69
- for (const { cell } of overlappingCells) {
70
- splitHorizontally(cell, headingRowsToSet, writer);
71
- }
72
- }
73
- tableUtils.setHeadingRowsCount(writer, table, headingRowsToSet);
74
- });
75
- }
76
- /**
77
- * Checks if a table cell is in the heading section.
78
- */
79
- _isInHeading(tableCell, table) {
80
- const headingRows = parseInt(table.getAttribute('headingRows') || '0');
81
- return !!headingRows && tableCell.parent.index < headingRows;
82
- }
83
- }
@@ -1,58 +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/splitcellcommand
7
- */
8
- import { Command } from 'ckeditor5/src/core.js';
9
- /**
10
- * The split cell command.
11
- *
12
- * The command is registered by {@link module:table/tableediting~TableEditing} as the `'splitTableCellVertically'`
13
- * and `'splitTableCellHorizontally'` editor commands.
14
- *
15
- * You can split any cell vertically or horizontally by executing this command. For example, to split the selected table cell vertically:
16
- *
17
- * ```ts
18
- * editor.execute( 'splitTableCellVertically' );
19
- * ```
20
- */
21
- export class SplitCellCommand extends Command {
22
- /**
23
- * The direction that indicates which cell will be split.
24
- */
25
- direction;
26
- /**
27
- * Creates a new `SplitCellCommand` instance.
28
- *
29
- * @param editor The editor on which this command will be used.
30
- * @param options.direction Indicates whether the command should split cells `'horizontally'` or `'vertically'`.
31
- */
32
- constructor(editor, options = {}) {
33
- super(editor);
34
- this.direction = options.direction || 'horizontally';
35
- }
36
- /**
37
- * @inheritDoc
38
- */
39
- refresh() {
40
- const tableUtils = this.editor.plugins.get('TableUtils');
41
- const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
42
- this.isEnabled = selectedCells.length === 1;
43
- }
44
- /**
45
- * @inheritDoc
46
- */
47
- execute() {
48
- const tableUtils = this.editor.plugins.get('TableUtils');
49
- const tableCell = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection)[0];
50
- const isHorizontal = this.direction === 'horizontally';
51
- if (isHorizontal) {
52
- tableUtils.splitCellHorizontally(tableCell, 2);
53
- }
54
- else {
55
- tableUtils.splitCellVertically(tableCell, 2);
56
- }
57
- }
58
- }
@@ -1,322 +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 { toWidget, toWidgetEditable } from 'ckeditor5/src/widget.js';
6
- import { downcastTableAlignmentConfig } from './tableproperties.js';
7
- import { getNormalizedDefaultTableProperties } from '../utils/table-properties.js';
8
- import { TableWalker } from '../tablewalker.js';
9
- /**
10
- * Model table element to view table element conversion helper.
11
- *
12
- * @internal
13
- */
14
- export function downcastTable(tableUtils, options) {
15
- return (table, { writer }) => {
16
- const headingRows = table.getAttribute('headingRows') || 0;
17
- const tableElement = writer.createContainerElement('table', null, []);
18
- const figureElement = writer.createContainerElement('figure', { class: 'table' }, tableElement);
19
- // Table head slot.
20
- if (headingRows > 0) {
21
- writer.insert(writer.createPositionAt(tableElement, 'end'), writer.createContainerElement('thead', null, writer.createSlot(element => element.is('element', 'tableRow') && element.index < headingRows)));
22
- }
23
- // Table body slot.
24
- if (headingRows < tableUtils.getRows(table)) {
25
- writer.insert(writer.createPositionAt(tableElement, 'end'), writer.createContainerElement('tbody', null, writer.createSlot(element => element.is('element', 'tableRow') && element.index >= headingRows)));
26
- }
27
- // Dynamic slots.
28
- for (const { positionOffset, filter } of options.additionalSlots) {
29
- writer.insert(writer.createPositionAt(tableElement, positionOffset), writer.createSlot(filter));
30
- }
31
- // Create a slot with items that don't fit into the table.
32
- writer.insert(writer.createPositionAt(tableElement, 'after'), writer.createSlot(element => {
33
- if (element.is('element', 'tableRow')) {
34
- return false;
35
- }
36
- return !options.additionalSlots.some(({ filter }) => filter(element));
37
- }));
38
- return options.asWidget ? toTableWidget(figureElement, writer) : figureElement;
39
- };
40
- }
41
- /**
42
- * Model table row element to view `<tr>` element conversion helper.
43
- *
44
- * @internal
45
- * @returns Element creator.
46
- */
47
- export function downcastRow() {
48
- return (tableRow, { writer }) => {
49
- return tableRow.isEmpty ?
50
- writer.createEmptyElement('tr') :
51
- writer.createContainerElement('tr');
52
- };
53
- }
54
- /**
55
- * Model table cell element to view `<td>` or `<th>` element conversion helper.
56
- *
57
- * This conversion helper will create proper `<th>` elements for table cells that are in the heading section (heading row or column)
58
- * and `<td>` otherwise.
59
- *
60
- * @internal
61
- * @param options.asWidget If set to `true`, the downcast conversion will produce a widget.
62
- * @param options.cellTypeEnabled If returns `true`, the downcast conversion will use the `tableCellType` attribute to determine cell type.
63
- * @returns Element creator.
64
- */
65
- export function downcastCell(options) {
66
- return (tableCell, { writer }) => {
67
- // If the table cell type feature is enabled, then we can simply check the cell type attribute.
68
- if (options.cellTypeEnabled?.()) {
69
- const cellElementName = (tableCell.getAttribute('tableCellType') === 'header' ?
70
- 'th' :
71
- 'td');
72
- return createCellElement(writer, cellElementName);
73
- }
74
- // If the table cell type feature is not enabled, we should iterate through the table structure
75
- // to determine whether the cell is in the heading section.
76
- const tableRow = tableCell.parent;
77
- const table = tableRow.parent;
78
- const rowIndex = table.getChildIndex(tableRow);
79
- const tableWalker = new TableWalker(table, { row: rowIndex });
80
- const headingRows = table.getAttribute('headingRows') || 0;
81
- const headingColumns = table.getAttribute('headingColumns') || 0;
82
- let result = null;
83
- // We need to iterate over a table in order to get proper row & column values from a walker.
84
- for (const tableSlot of tableWalker) {
85
- if (tableSlot.cell == tableCell) {
86
- const isHeading = tableSlot.row < headingRows || tableSlot.column < headingColumns;
87
- result = createCellElement(writer, isHeading ? 'th' : 'td');
88
- break;
89
- }
90
- }
91
- return result;
92
- };
93
- function createCellElement(writer, name) {
94
- return (options.asWidget ?
95
- toWidgetEditable(writer.createEditableElement(name), writer, { withAriaRole: false }) :
96
- writer.createContainerElement(name));
97
- }
98
- }
99
- /**
100
- * Overrides paragraph inside table cell conversion.
101
- *
102
- * This converter:
103
- * * should be used to override default paragraph conversion.
104
- * * It will only convert `<paragraph>` placed directly inside `<tableCell>`.
105
- * * For a single paragraph without attributes it returns `<span>` to simulate data table.
106
- * * For all other cases it returns `<p>` element.
107
- *
108
- * @internal
109
- * @param options.asWidget If set to `true`, the downcast conversion will produce a widget.
110
- * @returns Element creator.
111
- */
112
- export function convertParagraphInTableCell(options = {}) {
113
- return (modelElement, { writer }) => {
114
- if (!modelElement.parent.is('element', 'tableCell')) {
115
- return null;
116
- }
117
- if (!isSingleParagraphWithoutAttributes(modelElement)) {
118
- return null;
119
- }
120
- if (options.asWidget) {
121
- return writer.createContainerElement('span', { class: 'ck-table-bogus-paragraph' });
122
- }
123
- else {
124
- // Using `<p>` in case there are some markers on it and transparentRendering will render it anyway.
125
- const viewElement = writer.createContainerElement('p');
126
- writer.setCustomProperty('dataPipeline:transparentRendering', true, viewElement);
127
- return viewElement;
128
- }
129
- };
130
- }
131
- /**
132
- * Checks if given model `<paragraph>` is an only child of a parent (`<tableCell>`) and if it has any attribute set.
133
- *
134
- * The paragraph should be converted in the editing view to:
135
- *
136
- * * If returned `true` - to a `<span class="ck-table-bogus-paragraph">`
137
- * * If returned `false` - to a `<p>`
138
- *
139
- * @internal
140
- */
141
- export function isSingleParagraphWithoutAttributes(modelElement) {
142
- const tableCell = modelElement.parent;
143
- const isSingleParagraph = tableCell.childCount == 1;
144
- return isSingleParagraph && !hasAnyAttribute(modelElement);
145
- }
146
- /**
147
- * Converts a given {@link module:engine/view/element~ViewElement} to a table widget:
148
- * * Adds a {@link module:engine/view/element~ViewElement#_setCustomProperty custom property}
149
- * allowing to recognize the table widget element.
150
- * * Calls the {@link module:widget/utils~toWidget} function with the proper element's label creator.
151
- *
152
- * @param writer An instance of the view writer.
153
- * @param label The element's label. It will be concatenated with the table `alt` attribute if one is present.
154
- */
155
- function toTableWidget(viewElement, writer) {
156
- writer.setCustomProperty('table', true, viewElement);
157
- return toWidget(viewElement, writer, { hasSelectionHandle: true });
158
- }
159
- /**
160
- * Checks if an element has any attributes set.
161
- */
162
- function hasAnyAttribute(element) {
163
- for (const attributeKey of element.getAttributeKeys()) {
164
- // Ignore selection attributes stored on block elements.
165
- if (attributeKey.startsWith('selection:') || attributeKey == 'htmlEmptyBlock') {
166
- continue;
167
- }
168
- return true;
169
- }
170
- return false;
171
- }
172
- /**
173
- * Downcasts a plain table (also used in the clipboard pipeline).
174
- */
175
- export function convertPlainTable(editor) {
176
- return (table, conversionApi) => {
177
- const hasPlainTableOutput = editor.plugins.has('PlainTableOutput');
178
- const isClipboardPipeline = conversionApi.options.isClipboardPipeline;
179
- const useExtendedAlignment = editor.config.get('experimentalFlags.useExtendedTableBlockAlignment');
180
- const stripFigureTagWithLayoutTable = shouldStripFigureTagWithLayoutTable(editor, table);
181
- if (hasPlainTableOutput ||
182
- stripFigureTagWithLayoutTable ||
183
- (useExtendedAlignment && isClipboardPipeline)) {
184
- return downcastPlainTable(table, conversionApi, editor);
185
- }
186
- return null;
187
- };
188
- }
189
- /**
190
- * Downcasts a plain table caption (also used in the clipboard pipeline).
191
- */
192
- export function convertPlainTableCaption(editor) {
193
- return (modelElement, { writer, options }) => {
194
- const hasPlainTableOutput = editor.plugins.has('PlainTableOutput');
195
- const isClipboardPipeline = options.isClipboardPipeline;
196
- const useExtendedAlignment = editor.config.get('experimentalFlags.useExtendedTableBlockAlignment');
197
- const stripFigureTagWithLayoutTable = shouldStripFigureTagWithLayoutTable(editor, modelElement);
198
- if (!(hasPlainTableOutput ||
199
- stripFigureTagWithLayoutTable ||
200
- (useExtendedAlignment && isClipboardPipeline))) {
201
- return null;
202
- }
203
- if (modelElement.parent.name === 'table') {
204
- return writer.createContainerElement('caption');
205
- }
206
- return null;
207
- };
208
- }
209
- /**
210
- * Downcasts a plain table.
211
- *
212
- * @param table Table model element.
213
- * @param conversionApi The conversion API object.
214
- * @param editor The editor instance.
215
- * @returns Created element.
216
- */
217
- export function downcastPlainTable(table, conversionApi, editor) {
218
- const writer = conversionApi.writer;
219
- const headingRows = table.getAttribute('headingRows') || 0;
220
- // Table head rows slot.
221
- const headRowsSlot = writer.createSlot((element) => element.is('element', 'tableRow') && element.index < headingRows);
222
- // Table body rows slot.
223
- const bodyRowsSlot = writer.createSlot((element) => element.is('element', 'tableRow') && element.index >= headingRows);
224
- // Table children slot.
225
- const childrenSlot = writer.createSlot((element) => !element.is('element', 'tableRow'));
226
- // Table <thead> element with all the heading rows.
227
- const theadElement = writer.createContainerElement('thead', null, headRowsSlot);
228
- // Table <tbody> element with all the body rows.
229
- const tbodyElement = writer.createContainerElement('tbody', null, bodyRowsSlot);
230
- // Table contents element containing <thead> and <tbody> when necessary.
231
- const tableContentElements = [];
232
- if (headingRows) {
233
- tableContentElements.push(theadElement);
234
- }
235
- if (headingRows < table.childCount) {
236
- tableContentElements.push(tbodyElement);
237
- }
238
- const tableAttributes = { class: 'table' };
239
- if (editor.plugins.has('TablePropertiesEditing') && conversionApi.options.isClipboardPipeline) {
240
- const defaultTableProperties = getNormalizedDefaultTableProperties(editor.config.get('table.tableProperties.defaultProperties'), {
241
- includeAlignmentProperty: true
242
- });
243
- const tableAlignment = table.getAttribute('tableAlignment');
244
- let localDefaultValue = defaultTableProperties.alignment;
245
- if (table.getAttribute('tableType') === 'layout') {
246
- localDefaultValue = '';
247
- }
248
- const tableAlignmentValue = tableAlignment || localDefaultValue;
249
- if (tableAlignmentValue) {
250
- tableAttributes.class += ' ' + downcastTableAlignmentConfig[tableAlignmentValue].className;
251
- tableAttributes.style = downcastTableAlignmentConfig[tableAlignmentValue].style;
252
- if (downcastTableAlignmentConfig[tableAlignmentValue].align !== undefined) {
253
- tableAttributes.align = downcastTableAlignmentConfig[tableAlignmentValue].align;
254
- }
255
- }
256
- }
257
- // Create table structure.
258
- //
259
- // <table>
260
- // {children-slot-like-caption}
261
- // <thead>
262
- // {table-head-rows-slot}
263
- // </thead>
264
- // <tbody>
265
- // {table-body-rows-slot}
266
- // </tbody>
267
- // </table>
268
- return writer.createContainerElement('table', tableAttributes, [childrenSlot, ...tableContentElements]);
269
- }
270
- /**
271
- * Registers border and background attributes converters for plain tables or when the clipboard pipeline is used.
272
- */
273
- export function downcastTableBorderAndBackgroundAttributes(editor) {
274
- const modelAttributes = {
275
- 'border-width': 'tableBorderWidth',
276
- 'border-color': 'tableBorderColor',
277
- 'border-style': 'tableBorderStyle',
278
- 'background-color': 'tableBackgroundColor'
279
- };
280
- for (const [styleName, modelAttribute] of Object.entries(modelAttributes)) {
281
- editor.conversion.for('dataDowncast').add(dispatcher => {
282
- return dispatcher.on(`attribute:${modelAttribute}:table`, (evt, data, conversionApi) => {
283
- const { item, attributeNewValue } = data;
284
- const { mapper, writer } = conversionApi;
285
- const hasPlainTableOutput = editor.plugins.has('PlainTableOutput');
286
- const isClipboardPipeline = conversionApi.options.isClipboardPipeline;
287
- const useExtendedAlignment = editor.config.get('experimentalFlags.useExtendedTableBlockAlignment');
288
- const stripFigureTagWithLayoutTable = shouldStripFigureTagWithLayoutTable(editor, item);
289
- if (!(hasPlainTableOutput ||
290
- stripFigureTagWithLayoutTable ||
291
- (useExtendedAlignment && isClipboardPipeline))) {
292
- return;
293
- }
294
- if (!conversionApi.consumable.consume(item, evt.name)) {
295
- return;
296
- }
297
- const table = mapper.toViewElement(item);
298
- if (attributeNewValue) {
299
- writer.setStyle(styleName, attributeNewValue, table);
300
- }
301
- else {
302
- writer.removeStyle(styleName, table);
303
- }
304
- }, { priority: 'high' });
305
- });
306
- }
307
- }
308
- /**
309
- * Returns `true` if the figure tag should be stripped when using layout tables and when `tableType` is `layout`
310
- * or `stripFigureFromContentTable` option is set to `true`, `false` otherwise.
311
- *
312
- * @param editor The editor instance.
313
- * @param modelElement The model element to check.
314
- * @returns `true` if the figure tag should be stripped, `false` otherwise.
315
- */
316
- function shouldStripFigureTagWithLayoutTable(editor, modelElement) {
317
- const hasTableLayout = editor.plugins.has('TableLayoutEditing');
318
- const stripFigureFromContentTable = editor.config.get('table.tableLayout.stripFigureFromContentTable') ?? true;
319
- const tableModelElement = modelElement.findAncestor('table', { includeSelf: true });
320
- const tableType = tableModelElement?.getAttribute('tableType');
321
- return hasTableLayout && (stripFigureFromContentTable || tableType === 'layout');
322
- }
@@ -1,55 +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
- * Injects a table caption post-fixer into the model.
7
- *
8
- * The role of the table caption post-fixer is to ensure that the table with caption have the correct structure
9
- * after a {@link module:engine/model/model~Model#change `change()`} block was executed.
10
- *
11
- * The correct structure means that:
12
- *
13
- * * If there are many caption model element, they are merged into one model.
14
- * * A final, merged caption model is placed at the end of the table.
15
- *
16
- * @internal
17
- */
18
- export function injectTableCaptionPostFixer(model) {
19
- model.document.registerPostFixer(writer => tableCaptionPostFixer(writer, model));
20
- }
21
- /**
22
- * The table caption post-fixer.
23
- */
24
- function tableCaptionPostFixer(writer, model) {
25
- const changes = model.document.differ.getChanges();
26
- let wasFixed = false;
27
- for (const entry of changes) {
28
- if (entry.type != 'insert') {
29
- continue;
30
- }
31
- const positionParent = entry.position.parent;
32
- if (positionParent.is('element', 'table') || entry.name == 'table') {
33
- const table = (entry.name == 'table' ? entry.position.nodeAfter : positionParent);
34
- const captionsToMerge = Array.from(table.getChildren())
35
- .filter((child) => child.is('element', 'caption'));
36
- const firstCaption = captionsToMerge.shift();
37
- if (!firstCaption) {
38
- continue;
39
- }
40
- // Move all the contents of the captions to the first one.
41
- for (const caption of captionsToMerge) {
42
- writer.move(writer.createRangeIn(caption), firstCaption, 'end');
43
- writer.remove(caption);
44
- }
45
- // Make sure the final caption is at the end of the table.
46
- if (firstCaption.nextSibling) {
47
- writer.move(writer.createRangeOn(firstCaption), table, 'end');
48
- wasFixed = true;
49
- }
50
- // Do we merged captions and/or moved the single caption to the end of the table?
51
- wasFixed = !!captionsToMerge.length || wasFixed;
52
- }
53
- }
54
- return wasFixed;
55
- }