@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,452 +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 { TableWalker } from '../tablewalker.js';
6
- import { createEmptyTableCell, updateNumericAttribute } from './common.js';
7
- /**
8
- * Returns a cropped table according to given dimensions.
9
-
10
- * To return a cropped table that starts at first row and first column and end in third row and column:
11
- *
12
- * ```ts
13
- * const croppedTable = cropTableToDimensions( table, {
14
- * startRow: 1,
15
- * endRow: 3,
16
- * startColumn: 1,
17
- * endColumn: 3
18
- * }, writer );
19
- * ```
20
- *
21
- * Calling the code above for the table below:
22
- *
23
- * 0 1 2 3 4 0 1 2
24
- * ┌───┬───┬───┬───┬───┐
25
- * 0 │ a │ b │ c │ d │ e │
26
- * ├───┴───┤ ├───┴───┤ ┌───┬───┬───┐
27
- * 1 │ f │ │ g │ │ │ │ g │ 0
28
- * ├───┬───┴───┼───┬───┤ will return: ├───┴───┼───┤
29
- * 2 │ h │ i │ j │ k │ │ i │ j │ 1
30
- * ├───┤ ├───┤ │ │ ├───┤
31
- * 3 │ l │ │ m │ │ │ │ m │ 2
32
- * ├───┼───┬───┤ ├───┤ └───────┴───┘
33
- * 4 │ n │ o │ p │ │ q │
34
- * └───┴───┴───┴───┴───┘
35
- *
36
- * @internal
37
- */
38
- export function cropTableToDimensions(sourceTable, cropDimensions, writer) {
39
- const { startRow, startColumn, endRow, endColumn } = cropDimensions;
40
- // Initialize the cropped table element.
41
- const croppedTable = writer.createElement('table');
42
- // Copy table type attribute if present.
43
- const sourceTableType = sourceTable.getAttribute('tableType');
44
- if (sourceTableType) {
45
- writer.setAttribute('tableType', sourceTableType, croppedTable);
46
- }
47
- // Create empty table with empty rows equal to crop height.
48
- const cropHeight = endRow - startRow + 1;
49
- for (let i = 0; i < cropHeight; i++) {
50
- writer.insertElement('tableRow', croppedTable, 'end');
51
- }
52
- const tableMap = [...new TableWalker(sourceTable, { startRow, endRow, startColumn, endColumn, includeAllSlots: true })];
53
- // Iterate over source table slots (including empty - spanned - ones).
54
- for (const { row: sourceRow, column: sourceColumn, cell: tableCell, isAnchor, cellAnchorRow, cellAnchorColumn } of tableMap) {
55
- // Row index in cropped table.
56
- const rowInCroppedTable = sourceRow - startRow;
57
- const row = croppedTable.getChild(rowInCroppedTable);
58
- // For empty slots: fill the gap with empty table cell.
59
- if (!isAnchor) {
60
- // But fill the gap only if the spanning cell is anchored outside cropped area.
61
- // In the table from method jsdoc those cells are: "c" & "f".
62
- if (cellAnchorRow < startRow || cellAnchorColumn < startColumn) {
63
- createEmptyTableCell(writer, writer.createPositionAt(row, 'end'));
64
- }
65
- }
66
- // Otherwise clone the cell with all children and trim if it exceeds cropped area.
67
- else {
68
- const tableCellCopy = writer.cloneElement(tableCell);
69
- writer.append(tableCellCopy, row);
70
- // Trim table if it exceeds cropped area.
71
- // In the table from method jsdoc those cells are: "g" & "m".
72
- trimTableCellIfNeeded(tableCellCopy, sourceRow, sourceColumn, endRow, endColumn, writer);
73
- }
74
- }
75
- // Adjust heading rows & columns in cropped table if crop selection includes headings parts.
76
- addHeadingsToCroppedTable(croppedTable, sourceTable, startRow, startColumn, writer);
77
- return croppedTable;
78
- }
79
- /**
80
- * Returns slot info of cells that starts above and overlaps a given row.
81
- *
82
- * In a table below, passing `overlapRow = 3`
83
- *
84
- * ┌───┬───┬───┬───┬───┐
85
- * 0 │ a │ b │ c │ d │ e │
86
- * │ ├───┼───┼───┼───┤
87
- * 1 │ │ f │ g │ h │ i │
88
- * ├───┤ ├───┼───┤ │
89
- * 2 │ j │ │ k │ l │ │
90
- * │ │ │ ├───┼───┤
91
- * 3 │ │ │ │ m │ n │ <- overlap row to check
92
- * ├───┼───┤ │ ├───│
93
- * 4 │ o │ p │ │ │ q │
94
- * └───┴───┴───┴───┴───┘
95
- *
96
- * will return slot info for cells: "j", "f", "k".
97
- *
98
- * @internal
99
- * @param table The table to check.
100
- * @param overlapRow The index of the row to check.
101
- * @param startRow row to start analysis. Use it when it is known that the cells above that row will not overlap. Default value is 0.
102
- */
103
- export function getVerticallyOverlappingCells(table, overlapRow, startRow = 0) {
104
- const cells = [];
105
- const tableWalker = new TableWalker(table, { startRow, endRow: overlapRow - 1 });
106
- for (const slotInfo of tableWalker) {
107
- const { row, cellHeight } = slotInfo;
108
- const cellEndRow = row + cellHeight - 1;
109
- if (row < overlapRow && overlapRow <= cellEndRow) {
110
- cells.push(slotInfo);
111
- }
112
- }
113
- return cells;
114
- }
115
- /**
116
- * Splits the table cell horizontally.
117
- *
118
- * @internal
119
- * @returns Created table cell, if any were created.
120
- */
121
- export function splitHorizontally(tableCell, splitRow, writer) {
122
- const tableRow = tableCell.parent;
123
- const table = tableRow.parent;
124
- const rowIndex = tableRow.index;
125
- const rowspan = parseInt(tableCell.getAttribute('rowspan'));
126
- const newRowspan = splitRow - rowIndex;
127
- const newCellAttributes = {};
128
- const newCellRowSpan = rowspan - newRowspan;
129
- if (newCellRowSpan > 1) {
130
- newCellAttributes.rowspan = newCellRowSpan;
131
- }
132
- const colspan = parseInt(tableCell.getAttribute('colspan') || '1');
133
- if (colspan > 1) {
134
- newCellAttributes.colspan = colspan;
135
- }
136
- const startRow = rowIndex;
137
- const endRow = startRow + newRowspan;
138
- const tableMap = [...new TableWalker(table, { startRow, endRow, includeAllSlots: true })];
139
- let newCell = null;
140
- let columnIndex;
141
- for (const tableSlot of tableMap) {
142
- const { row, column, cell } = tableSlot;
143
- if (cell === tableCell && columnIndex === undefined) {
144
- columnIndex = column;
145
- }
146
- if (columnIndex !== undefined && columnIndex === column && row === endRow) {
147
- newCell = createEmptyTableCell(writer, tableSlot.getPositionBefore(), newCellAttributes);
148
- }
149
- }
150
- // Update the rowspan attribute after updating table.
151
- updateNumericAttribute('rowspan', newRowspan, tableCell, writer);
152
- return newCell;
153
- }
154
- /**
155
- * Returns slot info of cells that starts before and overlaps a given column.
156
- *
157
- * In a table below, passing `overlapColumn = 3`
158
- *
159
- * 0 1 2 3 4
160
- * ┌───────┬───────┬───┐
161
- * │ a │ b │ c │
162
- * │───┬───┴───────┼───┤
163
- * │ d │ e │ f │
164
- * ├───┼───┬───────┴───┤
165
- * │ g │ h │ i │
166
- * ├───┼───┼───┬───────┤
167
- * │ j │ k │ l │ m │
168
- * ├───┼───┴───┼───┬───┤
169
- * │ n │ o │ p │ q │
170
- * └───┴───────┴───┴───┘
171
- * ^
172
- * Overlap column to check
173
- *
174
- * will return slot info for cells: "b", "e", "i".
175
- *
176
- * @internal
177
- * @param table The table to check.
178
- * @param overlapColumn The index of the column to check.
179
- */
180
- export function getHorizontallyOverlappingCells(table, overlapColumn) {
181
- const cellsToSplit = [];
182
- const tableWalker = new TableWalker(table);
183
- for (const slotInfo of tableWalker) {
184
- const { column, cellWidth } = slotInfo;
185
- const cellEndColumn = column + cellWidth - 1;
186
- if (column < overlapColumn && overlapColumn <= cellEndColumn) {
187
- cellsToSplit.push(slotInfo);
188
- }
189
- }
190
- return cellsToSplit;
191
- }
192
- /**
193
- * Splits the table cell vertically.
194
- *
195
- * @internal
196
- * @param columnIndex The table cell column index.
197
- * @param splitColumn The index of column to split cell on.
198
- * @returns Created table cell.
199
- */
200
- export function splitVertically(tableCell, columnIndex, splitColumn, writer) {
201
- const colspan = parseInt(tableCell.getAttribute('colspan'));
202
- const newColspan = splitColumn - columnIndex;
203
- const newCellAttributes = {};
204
- const newCellColSpan = colspan - newColspan;
205
- if (newCellColSpan > 1) {
206
- newCellAttributes.colspan = newCellColSpan;
207
- }
208
- const rowspan = parseInt(tableCell.getAttribute('rowspan') || '1');
209
- if (rowspan > 1) {
210
- newCellAttributes.rowspan = rowspan;
211
- }
212
- const newCell = createEmptyTableCell(writer, writer.createPositionAfter(tableCell), newCellAttributes);
213
- // Update the colspan attribute after updating table.
214
- updateNumericAttribute('colspan', newColspan, tableCell, writer);
215
- return newCell;
216
- }
217
- /**
218
- * Adjusts table cell dimensions to not exceed limit row and column.
219
- *
220
- * If table cell width (or height) covers a column (or row) that is after a limit column (or row)
221
- * this method will trim "colspan" (or "rowspan") attribute so the table cell will fit in a defined limits.
222
- *
223
- * @internal
224
- */
225
- export function trimTableCellIfNeeded(tableCell, cellRow, cellColumn, limitRow, limitColumn, writer) {
226
- const colspan = parseInt(tableCell.getAttribute('colspan') || '1');
227
- const rowspan = parseInt(tableCell.getAttribute('rowspan') || '1');
228
- const endColumn = cellColumn + colspan - 1;
229
- if (endColumn > limitColumn) {
230
- const trimmedSpan = limitColumn - cellColumn + 1;
231
- updateNumericAttribute('colspan', trimmedSpan, tableCell, writer, 1);
232
- }
233
- const endRow = cellRow + rowspan - 1;
234
- if (endRow > limitRow) {
235
- const trimmedSpan = limitRow - cellRow + 1;
236
- updateNumericAttribute('rowspan', trimmedSpan, tableCell, writer, 1);
237
- }
238
- }
239
- /**
240
- * Sets proper heading attributes to a cropped table.
241
- */
242
- function addHeadingsToCroppedTable(croppedTable, sourceTable, startRow, startColumn, writer) {
243
- const headingRows = parseInt(sourceTable.getAttribute('headingRows') || '0');
244
- if (headingRows > 0) {
245
- const headingRowsInCrop = headingRows - startRow;
246
- updateNumericAttribute('headingRows', headingRowsInCrop, croppedTable, writer, 0);
247
- }
248
- const headingColumns = parseInt(sourceTable.getAttribute('headingColumns') || '0');
249
- if (headingColumns > 0) {
250
- const headingColumnsInCrop = headingColumns - startColumn;
251
- updateNumericAttribute('headingColumns', headingColumnsInCrop, croppedTable, writer, 0);
252
- }
253
- }
254
- /**
255
- * Removes columns that have no cells anchored.
256
- *
257
- * In table below:
258
- *
259
- * +----+----+----+----+----+----+----+
260
- * | 00 | 01 | 03 | 04 | 06 |
261
- * +----+----+----+----+ +----+
262
- * | 10 | 11 | 13 | | 16 |
263
- * +----+----+----+----+----+----+----+
264
- * | 20 | 21 | 23 | 24 | 26 |
265
- * +----+----+----+----+----+----+----+
266
- * ^--- empty ---^
267
- *
268
- * Will remove columns 2 and 5.
269
- *
270
- * **Note:** This is a low-level helper method for clearing invalid model state when doing table modifications.
271
- * To remove a column from a table use {@link module:table/tableutils~TableUtils#removeColumns `TableUtils.removeColumns()`}.
272
- *
273
- * @internal
274
- * @returns True if removed some columns.
275
- */
276
- export function removeEmptyColumns(table, tableUtils) {
277
- const width = tableUtils.getColumns(table);
278
- const columnsMap = new Array(width).fill(0);
279
- for (const { column } of new TableWalker(table)) {
280
- columnsMap[column]++;
281
- }
282
- const emptyColumns = columnsMap.reduce((result, cellsCount, column) => {
283
- return cellsCount ? result : [...result, column];
284
- }, []);
285
- if (emptyColumns.length > 0) {
286
- // Remove only last empty column because it will recurrently trigger removing empty rows.
287
- const emptyColumn = emptyColumns[emptyColumns.length - 1];
288
- // @if CK_DEBUG_TABLE // console.log( `Removing empty column: ${ emptyColumn }.` );
289
- tableUtils.removeColumns(table, { at: emptyColumn });
290
- return true;
291
- }
292
- return false;
293
- }
294
- /**
295
- * Removes rows that have no cells anchored.
296
- *
297
- * In table below:
298
- *
299
- * +----+----+----+
300
- * | 00 | 01 | 02 |
301
- * +----+----+----+
302
- * | 10 | 11 | 12 |
303
- * + + + +
304
- * | | | | <-- empty
305
- * +----+----+----+
306
- * | 30 | 31 | 32 |
307
- * +----+----+----+
308
- * | 40 | 42 |
309
- * + + +
310
- * | | | <-- empty
311
- * +----+----+----+
312
- * | 60 | 61 | 62 |
313
- * +----+----+----+
314
- *
315
- * Will remove rows 2 and 5.
316
- *
317
- * **Note:** This is a low-level helper method for clearing invalid model state when doing table modifications.
318
- * To remove a row from a table use {@link module:table/tableutils~TableUtils#removeRows `TableUtils.removeRows()`}.
319
- *
320
- * @internal
321
- * @returns True if removed some rows.
322
- */
323
- export function removeEmptyRows(table, tableUtils) {
324
- const emptyRows = [];
325
- const tableRowCount = tableUtils.getRows(table);
326
- for (let rowIndex = 0; rowIndex < tableRowCount; rowIndex++) {
327
- const tableRow = table.getChild(rowIndex);
328
- if (tableRow.isEmpty) {
329
- emptyRows.push(rowIndex);
330
- }
331
- }
332
- if (emptyRows.length > 0) {
333
- // Remove only last empty row because it will recurrently trigger removing empty columns.
334
- const emptyRow = emptyRows[emptyRows.length - 1];
335
- // @if CK_DEBUG_TABLE // console.log( `Removing empty row: ${ emptyRow }.` );
336
- tableUtils.removeRows(table, { at: emptyRow });
337
- return true;
338
- }
339
- return false;
340
- }
341
- /**
342
- * Removes rows and columns that have no cells anchored.
343
- *
344
- * In table below:
345
- *
346
- * +----+----+----+----+
347
- * | 00 | 02 |
348
- * +----+----+ +
349
- * | 10 | |
350
- * +----+----+----+----+
351
- * | 20 | 22 | 23 |
352
- * + + + +
353
- * | | | | <-- empty row
354
- * +----+----+----+----+
355
- * ^--- empty column
356
- *
357
- * Will remove row 3 and column 1.
358
- *
359
- * **Note:** This is a low-level helper method for clearing invalid model state when doing table modifications.
360
- * To remove a rows from a table use {@link module:table/tableutils~TableUtils#removeRows `TableUtils.removeRows()`} and
361
- * {@link module:table/tableutils~TableUtils#removeColumns `TableUtils.removeColumns()`} to remove a column.
362
- *
363
- * @internal
364
- */
365
- export function removeEmptyRowsColumns(table, tableUtils) {
366
- const removedColumns = removeEmptyColumns(table, tableUtils);
367
- // If there was some columns removed then cleaning empty rows was already triggered.
368
- if (!removedColumns) {
369
- removeEmptyRows(table, tableUtils);
370
- }
371
- }
372
- /**
373
- * Returns adjusted last row index if selection covers part of a row with empty slots (spanned by other cells).
374
- * The `dimensions.lastRow` is equal to last row index but selection might be bigger.
375
- *
376
- * This happens *only* on rectangular selection so we analyze a case like this:
377
- *
378
- * +---+---+---+---+
379
- * 0 | a | b | c | d |
380
- * + + +---+---+
381
- * 1 | | e | f | g |
382
- * + +---+ +---+
383
- * 2 | | h | | i | <- last row, each cell has rowspan = 2,
384
- * + + + + + so we need to return 3, not 2
385
- * 3 | | | | |
386
- * +---+---+---+---+
387
- *
388
- * @internal
389
- * @returns Adjusted last row index.
390
- */
391
- export function adjustLastRowIndex(table, dimensions) {
392
- const lastRowMap = Array.from(new TableWalker(table, {
393
- startColumn: dimensions.firstColumn,
394
- endColumn: dimensions.lastColumn,
395
- row: dimensions.lastRow
396
- }));
397
- const everyCellHasSingleRowspan = lastRowMap.every(({ cellHeight }) => cellHeight === 1);
398
- // It is a "flat" row, so the last row index is OK.
399
- if (everyCellHasSingleRowspan) {
400
- return dimensions.lastRow;
401
- }
402
- // Otherwise get any cell's rowspan and adjust the last row index.
403
- const rowspanAdjustment = lastRowMap[0].cellHeight - 1;
404
- return dimensions.lastRow + rowspanAdjustment;
405
- }
406
- /**
407
- * Returns adjusted last column index if selection covers part of a column with empty slots (spanned by other cells).
408
- * The `dimensions.lastColumn` is equal to last column index but selection might be bigger.
409
- *
410
- * This happens *only* on rectangular selection so we analyze a case like this:
411
- *
412
- * 0 1 2 3
413
- * +---+---+---+---+
414
- * | a |
415
- * +---+---+---+---+
416
- * | b | c | d |
417
- * +---+---+---+---+
418
- * | e | f |
419
- * +---+---+---+---+
420
- * | g | h |
421
- * +---+---+---+---+
422
- * ^
423
- * last column, each cell has colspan = 2, so we need to return 3, not 2
424
- *
425
- * @internal
426
- * @returns Adjusted last column index.
427
- */
428
- export function adjustLastColumnIndex(table, dimensions) {
429
- const lastColumnMap = Array.from(new TableWalker(table, {
430
- startRow: dimensions.firstRow,
431
- endRow: dimensions.lastRow,
432
- column: dimensions.lastColumn
433
- }));
434
- const everyCellHasSingleColspan = lastColumnMap.every(({ cellWidth }) => cellWidth === 1);
435
- // It is a "flat" column, so the last column index is OK.
436
- if (everyCellHasSingleColspan) {
437
- return dimensions.lastColumn;
438
- }
439
- // Otherwise get any cell's colspan and adjust the last column index.
440
- const colspanAdjustment = lastColumnMap[0].cellWidth - 1;
441
- return dimensions.lastColumn + colspanAdjustment;
442
- }
443
- /**
444
- * Get view `<table>` element from the wrapper.
445
- */
446
- export function getViewTableFromWrapper(wrapperView) {
447
- for (const wrapperChild of wrapperView.getChildren()) {
448
- if (wrapperChild.is('element', 'table')) {
449
- return wrapperChild;
450
- }
451
- }
452
- }
@@ -1,121 +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 { isObject } from 'es-toolkit/compat';
6
- /**
7
- * Returns a string if all four values of box sides are equal.
8
- *
9
- * If a string is passed, it is treated as a single value (pass-through).
10
- *
11
- * ```ts
12
- * // Returns 'foo':
13
- * getSingleValue( { top: 'foo', right: 'foo', bottom: 'foo', left: 'foo' } );
14
- * getSingleValue( 'foo' );
15
- *
16
- * // Returns undefined:
17
- * getSingleValue( { top: 'foo', right: 'foo', bottom: 'bar', left: 'foo' } );
18
- * getSingleValue( { top: 'foo', right: 'foo' } );
19
- * ```
20
- *
21
- * @internal
22
- */
23
- export function getSingleValue(objectOrString) {
24
- if (!objectOrString || !isObject(objectOrString)) {
25
- return objectOrString;
26
- }
27
- const { top, right, bottom, left } = objectOrString;
28
- if (top == right && right == bottom && bottom == left) {
29
- return top;
30
- }
31
- }
32
- /**
33
- * Adds a unit to a value if the value is a number or a string representing a number.
34
- *
35
- * **Note**: It does nothing to non-numeric values.
36
- *
37
- * ```ts
38
- * getSingleValue( 25, 'px' ); // '25px'
39
- * getSingleValue( 25, 'em' ); // '25em'
40
- * getSingleValue( '25em', 'px' ); // '25em'
41
- * getSingleValue( 'foo', 'px' ); // 'foo'
42
- * ```
43
- *
44
- * @internal
45
- * @param defaultUnit A default unit added to a numeric value.
46
- */
47
- export function addDefaultUnitToNumericValue(value, defaultUnit) {
48
- const numericValue = parseFloat(value);
49
- if (Number.isNaN(numericValue)) {
50
- return value;
51
- }
52
- if (String(numericValue) !== String(value)) {
53
- return value;
54
- }
55
- return `${numericValue}${defaultUnit}`;
56
- }
57
- /**
58
- * Returns the normalized configuration.
59
- *
60
- * @internal
61
- * @param config The configuration to normalize.
62
- * @param options Options used to determine which properties should be added.
63
- */
64
- export function getNormalizedDefaultProperties(config, options = {}) {
65
- const normalizedConfig = {
66
- borderStyle: 'none',
67
- borderWidth: '',
68
- borderColor: '',
69
- backgroundColor: '',
70
- width: '',
71
- height: '',
72
- ...config
73
- };
74
- if (options.includeAlignmentProperty && !normalizedConfig.alignment) {
75
- normalizedConfig.alignment = 'center';
76
- }
77
- if (options.includePaddingProperty && !normalizedConfig.padding) {
78
- normalizedConfig.padding = '';
79
- }
80
- if (options.includeVerticalAlignmentProperty && !normalizedConfig.verticalAlignment) {
81
- normalizedConfig.verticalAlignment = 'middle';
82
- }
83
- if (options.includeHorizontalAlignmentProperty && !normalizedConfig.horizontalAlignment) {
84
- normalizedConfig.horizontalAlignment = options.isRightToLeftContent ? 'right' : 'left';
85
- }
86
- return normalizedConfig;
87
- }
88
- /**
89
- * Returns the normalized default table properties.
90
- *
91
- * @internal
92
- * @param config The configuration to normalize.
93
- * @param options Options used to determine which properties should be added.
94
- */
95
- export function getNormalizedDefaultTableProperties(config, options) {
96
- return getNormalizedDefaultProperties({
97
- // It adds support for border none in the table element, keep it in sync with the content styles
98
- // See more: https://github.com/ckeditor/ckeditor5/issues/6841#issuecomment-1959195608
99
- borderStyle: 'double',
100
- borderColor: 'hsl(0, 0%, 70%)',
101
- borderWidth: '1px',
102
- ...config
103
- }, options);
104
- }
105
- /**
106
- * Returns the normalized default cell properties.
107
- *
108
- * @internal
109
- * @param config The configuration to normalize.
110
- * @param options Options used to determine which properties should be added.
111
- */
112
- export function getNormalizedDefaultCellProperties(config, options) {
113
- return getNormalizedDefaultProperties({
114
- // It adds support for border none in the table element, keep it in sync with the content styles
115
- // See more: https://github.com/ckeditor/ckeditor5/issues/6841#issuecomment-1959195608
116
- borderStyle: 'solid',
117
- borderColor: 'hsl(0, 0%, 75%)',
118
- borderWidth: '1px',
119
- ...config
120
- }, options);
121
- }
@@ -1,111 +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/utils/ui/contextualballoon
7
- */
8
- import { Rect } from 'ckeditor5/src/utils.js';
9
- import { BalloonPanelView } from 'ckeditor5/src/ui.js';
10
- import { getSelectionAffectedTableWidget, getTableWidgetAncestor } from './widget.js';
11
- import { getSelectionAffectedTable } from '../common.js';
12
- const BALLOON_POSITIONS = /* #__PURE__ */ (() => [
13
- BalloonPanelView.defaultPositions.northArrowSouth,
14
- BalloonPanelView.defaultPositions.northArrowSouthWest,
15
- BalloonPanelView.defaultPositions.northArrowSouthEast,
16
- BalloonPanelView.defaultPositions.southArrowNorth,
17
- BalloonPanelView.defaultPositions.southArrowNorthWest,
18
- BalloonPanelView.defaultPositions.southArrowNorthEast,
19
- BalloonPanelView.defaultPositions.viewportStickyNorth
20
- ])();
21
- /**
22
- * A helper utility that positions the
23
- * {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon contextual balloon} instance
24
- * with respect to the table in the editor content, if one is selected.
25
- *
26
- * @internal
27
- * @param editor The editor instance.
28
- * @param target Either "cell" or "table". Determines the target the balloon will be attached to.
29
- */
30
- export function repositionContextualBalloon(editor, target) {
31
- const balloon = editor.plugins.get('ContextualBalloon');
32
- const selection = editor.editing.view.document.selection;
33
- let position;
34
- if (target === 'cell') {
35
- if (getTableWidgetAncestor(selection)) {
36
- position = getBalloonCellPositionData(editor);
37
- }
38
- }
39
- else if (getSelectionAffectedTableWidget(selection)) {
40
- position = getBalloonTablePositionData(editor);
41
- }
42
- if (position) {
43
- balloon.updatePosition(position);
44
- }
45
- }
46
- /**
47
- * Returns the positioning options that control the geometry of the
48
- * {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon contextual balloon} with respect
49
- * to the selected table in the editor content.
50
- *
51
- * @param editor The editor instance.
52
- */
53
- export function getBalloonTablePositionData(editor) {
54
- const selection = editor.model.document.selection;
55
- const modelTable = getSelectionAffectedTable(selection);
56
- const viewTable = editor.editing.mapper.toViewElement(modelTable);
57
- return {
58
- target: editor.editing.view.domConverter.mapViewToDom(viewTable),
59
- positions: BALLOON_POSITIONS
60
- };
61
- }
62
- /**
63
- * Returns the positioning options that control the geometry of the
64
- * {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon contextual balloon} with respect
65
- * to the selected table cell in the editor content.
66
- *
67
- * @param editor The editor instance.
68
- * @internal
69
- */
70
- export function getBalloonCellPositionData(editor) {
71
- const mapper = editor.editing.mapper;
72
- const domConverter = editor.editing.view.domConverter;
73
- const selection = editor.model.document.selection;
74
- if (selection.rangeCount > 1) {
75
- return {
76
- target: () => createBoundingRect(selection.getRanges(), editor),
77
- positions: BALLOON_POSITIONS
78
- };
79
- }
80
- const modelTableCell = getTableCellAtPosition(selection.getFirstPosition());
81
- const viewTableCell = mapper.toViewElement(modelTableCell);
82
- return {
83
- target: domConverter.mapViewToDom(viewTableCell),
84
- positions: BALLOON_POSITIONS
85
- };
86
- }
87
- /**
88
- * Returns the first selected table cell from a multi-cell or in-cell selection.
89
- *
90
- * @param position Document position.
91
- */
92
- function getTableCellAtPosition(position) {
93
- const isTableCellSelected = position.nodeAfter && position.nodeAfter.is('element', 'tableCell');
94
- return isTableCellSelected ? position.nodeAfter : position.findAncestor('tableCell');
95
- }
96
- /**
97
- * Returns bounding rectangle for given model ranges.
98
- *
99
- * @param ranges Model ranges that the bounding rect should be returned for.
100
- * @param editor The editor instance.
101
- */
102
- function createBoundingRect(ranges, editor) {
103
- const mapper = editor.editing.mapper;
104
- const domConverter = editor.editing.view.domConverter;
105
- const rects = Array.from(ranges).map(range => {
106
- const modelTableCell = getTableCellAtPosition(range.start);
107
- const viewTableCell = mapper.toViewElement(modelTableCell);
108
- return new Rect(domConverter.mapViewToDom(viewTableCell));
109
- });
110
- return Rect.getBoundingRect(rects);
111
- }