@ckeditor/ckeditor5-table 0.0.0-nightly-20260118.0 → 0.0.0-nightly-next-20260118.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (356) hide show
  1. package/ckeditor5-metadata.json +16 -7
  2. package/{src → dist}/augmentation.d.ts +0 -15
  3. package/{src → dist}/commands/insertcolumncommand.d.ts +1 -1
  4. package/{src → dist}/commands/insertrowcommand.d.ts +1 -1
  5. package/{src → dist}/commands/inserttablecommand.d.ts +1 -1
  6. package/{src → dist}/commands/inserttablelayoutcommand.d.ts +1 -1
  7. package/{src → dist}/commands/mergecellcommand.d.ts +3 -3
  8. package/{src → dist}/commands/mergecellscommand.d.ts +1 -1
  9. package/{src → dist}/commands/removecolumncommand.d.ts +1 -1
  10. package/{src → dist}/commands/removerowcommand.d.ts +1 -1
  11. package/{src → dist}/commands/selectcolumncommand.d.ts +1 -1
  12. package/{src → dist}/commands/selectrowcommand.d.ts +1 -1
  13. package/{src → dist}/commands/setheadercolumncommand.d.ts +1 -1
  14. package/{src → dist}/commands/setheaderrowcommand.d.ts +1 -1
  15. package/{src → dist}/commands/splitcellcommand.d.ts +1 -1
  16. package/{src → dist}/converters/downcast.d.ts +2 -2
  17. package/{src → dist}/converters/table-caption-post-fixer.d.ts +1 -1
  18. package/{src → dist}/converters/table-cell-paragraph-post-fixer.d.ts +1 -1
  19. package/{src → dist}/converters/table-cell-refresh-handler.d.ts +1 -1
  20. package/{src → dist}/converters/table-headings-refresh-handler.d.ts +1 -1
  21. package/{src → dist}/converters/table-layout-post-fixer.d.ts +1 -1
  22. package/{src → dist}/converters/tableproperties.d.ts +2 -2
  23. package/{src → dist}/converters/upcasttable.d.ts +1 -1
  24. package/dist/index-content.css +30 -30
  25. package/dist/index-editor.css +104 -170
  26. package/dist/index.css +147 -237
  27. package/dist/index.css.map +1 -1
  28. package/{src → dist}/index.d.ts +2 -5
  29. package/dist/index.js +423 -2408
  30. package/dist/index.js.map +1 -1
  31. package/{src → dist}/plaintableoutput.d.ts +1 -1
  32. package/{src → dist}/table.d.ts +2 -2
  33. package/{src → dist}/tablecaption/tablecaptionediting.d.ts +2 -2
  34. package/{src → dist}/tablecaption/tablecaptionui.d.ts +1 -1
  35. package/{src → dist}/tablecaption/toggletablecaptioncommand.d.ts +1 -1
  36. package/{src → dist}/tablecaption/utils.d.ts +1 -1
  37. package/{src → dist}/tablecaption.d.ts +1 -1
  38. package/{src → dist}/tablecellproperties/commands/tablecellbackgroundcolorcommand.d.ts +1 -1
  39. package/{src → dist}/tablecellproperties/commands/tablecellbordercolorcommand.d.ts +2 -2
  40. package/{src → dist}/tablecellproperties/commands/tablecellborderstylecommand.d.ts +2 -2
  41. package/{src → dist}/tablecellproperties/commands/tablecellborderwidthcommand.d.ts +2 -2
  42. package/{src → dist}/tablecellproperties/commands/tablecellheightcommand.d.ts +1 -1
  43. package/{src → dist}/tablecellproperties/commands/tablecellhorizontalalignmentcommand.d.ts +1 -1
  44. package/{src → dist}/tablecellproperties/commands/tablecellpaddingcommand.d.ts +2 -2
  45. package/{src → dist}/tablecellproperties/commands/tablecellpropertycommand.d.ts +2 -2
  46. package/{src → dist}/tablecellproperties/commands/tablecelltypecommand.d.ts +2 -6
  47. package/{src → dist}/tablecellproperties/commands/tablecellverticalalignmentcommand.d.ts +1 -1
  48. package/{src → dist}/tablecellproperties/tablecellpropertiesediting.d.ts +1 -1
  49. package/{src → dist}/tablecellproperties/tablecellpropertiesui.d.ts +2 -2
  50. package/dist/tablecellproperties/tablecellpropertiesutils.d.ts +18 -0
  51. package/{src/tablecellproperties/ui/tablecellpropertiesviewexperimental.d.ts → dist/tablecellproperties/ui/tablecellpropertiesview.d.ts} +11 -12
  52. package/{src → dist}/tablecellproperties.d.ts +1 -1
  53. package/{src → dist}/tablecellwidth/commands/tablecellwidthcommand.d.ts +1 -1
  54. package/{src → dist}/tablecellwidth/tablecellwidthediting.d.ts +1 -1
  55. package/{src → dist}/tableclipboard.d.ts +3 -3
  56. package/{src → dist}/tablecolumnresize/converters.d.ts +1 -1
  57. package/{src → dist}/tablecolumnresize/tablecolumnresizeediting.d.ts +2 -2
  58. package/{src → dist}/tablecolumnresize/tablewidthscommand.d.ts +2 -2
  59. package/{src → dist}/tablecolumnresize/utils.d.ts +2 -2
  60. package/{src → dist}/tablecolumnresize.d.ts +1 -1
  61. package/{src → dist}/tableconfig.d.ts +26 -6
  62. package/{src → dist}/tableediting.d.ts +3 -3
  63. package/{src → dist}/tablekeyboard.d.ts +3 -3
  64. package/{src → dist}/tablelayout/commands/tabletypecommand.d.ts +1 -1
  65. package/{src → dist}/tablelayout/tablelayoutediting.d.ts +1 -1
  66. package/{src → dist}/tablelayout/tablelayoutui.d.ts +1 -1
  67. package/{src → dist}/tablelayout.d.ts +1 -1
  68. package/{src → dist}/tablemouse/mouseeventsobserver.d.ts +1 -1
  69. package/{src → dist}/tablemouse.d.ts +1 -1
  70. package/{src → dist}/tableproperties/commands/tablealignmentcommand.d.ts +1 -1
  71. package/{src → dist}/tableproperties/commands/tablebackgroundcolorcommand.d.ts +1 -1
  72. package/{src → dist}/tableproperties/commands/tablebordercolorcommand.d.ts +2 -2
  73. package/{src → dist}/tableproperties/commands/tableborderstylecommand.d.ts +2 -2
  74. package/{src → dist}/tableproperties/commands/tableborderwidthcommand.d.ts +2 -2
  75. package/{src → dist}/tableproperties/commands/tableheightcommand.d.ts +1 -1
  76. package/{src → dist}/tableproperties/commands/tablepropertycommand.d.ts +2 -2
  77. package/{src → dist}/tableproperties/commands/tablewidthcommand.d.ts +1 -1
  78. package/{src → dist}/tableproperties/tablepropertiesediting.d.ts +1 -1
  79. package/{src → dist}/tableproperties/tablepropertiesui.d.ts +2 -2
  80. package/{src → dist}/tableproperties/ui/tablepropertiesview.d.ts +10 -2
  81. package/{src → dist}/tableproperties.d.ts +1 -1
  82. package/{src → dist}/tableselection.d.ts +2 -2
  83. package/{src → dist}/tabletoolbar.d.ts +2 -2
  84. package/{src → dist}/tableui.d.ts +1 -1
  85. package/{src → dist}/tableutils.d.ts +2 -2
  86. package/{src → dist}/tablewalker.d.ts +1 -1
  87. package/{src → dist}/ui/colorinputview.d.ts +2 -2
  88. package/{src → dist}/ui/inserttableview.d.ts +2 -2
  89. package/{src → dist}/utils/common.d.ts +2 -2
  90. package/{src → dist}/utils/structure.d.ts +1 -1
  91. package/{src → dist}/utils/table-properties.d.ts +1 -1
  92. package/{src → dist}/utils/ui/contextualballoon.d.ts +2 -2
  93. package/{src → dist}/utils/ui/table-properties.d.ts +2 -2
  94. package/{src → dist}/utils/ui/widget.d.ts +1 -1
  95. package/package.json +26 -49
  96. package/build/table.js +0 -5
  97. package/build/translations/af.js +0 -1
  98. package/build/translations/ar.js +0 -1
  99. package/build/translations/ast.js +0 -1
  100. package/build/translations/az.js +0 -1
  101. package/build/translations/be.js +0 -1
  102. package/build/translations/bg.js +0 -1
  103. package/build/translations/bn.js +0 -1
  104. package/build/translations/bs.js +0 -1
  105. package/build/translations/ca.js +0 -1
  106. package/build/translations/cs.js +0 -1
  107. package/build/translations/da.js +0 -1
  108. package/build/translations/de-ch.js +0 -1
  109. package/build/translations/de.js +0 -1
  110. package/build/translations/el.js +0 -1
  111. package/build/translations/en-au.js +0 -1
  112. package/build/translations/en-gb.js +0 -1
  113. package/build/translations/eo.js +0 -1
  114. package/build/translations/es-co.js +0 -1
  115. package/build/translations/es.js +0 -1
  116. package/build/translations/et.js +0 -1
  117. package/build/translations/eu.js +0 -1
  118. package/build/translations/fa.js +0 -1
  119. package/build/translations/fi.js +0 -1
  120. package/build/translations/fr.js +0 -1
  121. package/build/translations/gl.js +0 -1
  122. package/build/translations/gu.js +0 -1
  123. package/build/translations/he.js +0 -1
  124. package/build/translations/hi.js +0 -1
  125. package/build/translations/hr.js +0 -1
  126. package/build/translations/hu.js +0 -1
  127. package/build/translations/hy.js +0 -1
  128. package/build/translations/id.js +0 -1
  129. package/build/translations/it.js +0 -1
  130. package/build/translations/ja.js +0 -1
  131. package/build/translations/jv.js +0 -1
  132. package/build/translations/kk.js +0 -1
  133. package/build/translations/km.js +0 -1
  134. package/build/translations/kn.js +0 -1
  135. package/build/translations/ko.js +0 -1
  136. package/build/translations/ku.js +0 -1
  137. package/build/translations/lt.js +0 -1
  138. package/build/translations/lv.js +0 -1
  139. package/build/translations/ms.js +0 -1
  140. package/build/translations/nb.js +0 -1
  141. package/build/translations/ne.js +0 -1
  142. package/build/translations/nl.js +0 -1
  143. package/build/translations/no.js +0 -1
  144. package/build/translations/oc.js +0 -1
  145. package/build/translations/pl.js +0 -1
  146. package/build/translations/pt-br.js +0 -1
  147. package/build/translations/pt.js +0 -1
  148. package/build/translations/ro.js +0 -1
  149. package/build/translations/ru.js +0 -1
  150. package/build/translations/si.js +0 -1
  151. package/build/translations/sk.js +0 -1
  152. package/build/translations/sl.js +0 -1
  153. package/build/translations/sq.js +0 -1
  154. package/build/translations/sr-latn.js +0 -1
  155. package/build/translations/sr.js +0 -1
  156. package/build/translations/sv.js +0 -1
  157. package/build/translations/th.js +0 -1
  158. package/build/translations/ti.js +0 -1
  159. package/build/translations/tk.js +0 -1
  160. package/build/translations/tr.js +0 -1
  161. package/build/translations/tt.js +0 -1
  162. package/build/translations/ug.js +0 -1
  163. package/build/translations/uk.js +0 -1
  164. package/build/translations/ur.js +0 -1
  165. package/build/translations/uz.js +0 -1
  166. package/build/translations/vi.js +0 -1
  167. package/build/translations/zh-cn.js +0 -1
  168. package/build/translations/zh.js +0 -1
  169. package/lang/contexts.json +0 -82
  170. package/lang/translations/af.po +0 -332
  171. package/lang/translations/ar.po +0 -332
  172. package/lang/translations/ast.po +0 -332
  173. package/lang/translations/az.po +0 -332
  174. package/lang/translations/be.po +0 -332
  175. package/lang/translations/bg.po +0 -332
  176. package/lang/translations/bn.po +0 -334
  177. package/lang/translations/bs.po +0 -332
  178. package/lang/translations/ca.po +0 -332
  179. package/lang/translations/cs.po +0 -332
  180. package/lang/translations/da.po +0 -332
  181. package/lang/translations/de-ch.po +0 -332
  182. package/lang/translations/de.po +0 -332
  183. package/lang/translations/el.po +0 -332
  184. package/lang/translations/en-au.po +0 -332
  185. package/lang/translations/en-gb.po +0 -332
  186. package/lang/translations/en.po +0 -332
  187. package/lang/translations/eo.po +0 -332
  188. package/lang/translations/es-co.po +0 -332
  189. package/lang/translations/es.po +0 -332
  190. package/lang/translations/et.po +0 -332
  191. package/lang/translations/eu.po +0 -332
  192. package/lang/translations/fa.po +0 -332
  193. package/lang/translations/fi.po +0 -332
  194. package/lang/translations/fr.po +0 -332
  195. package/lang/translations/gl.po +0 -332
  196. package/lang/translations/gu.po +0 -332
  197. package/lang/translations/he.po +0 -332
  198. package/lang/translations/hi.po +0 -332
  199. package/lang/translations/hr.po +0 -332
  200. package/lang/translations/hu.po +0 -332
  201. package/lang/translations/hy.po +0 -332
  202. package/lang/translations/id.po +0 -332
  203. package/lang/translations/it.po +0 -332
  204. package/lang/translations/ja.po +0 -332
  205. package/lang/translations/jv.po +0 -332
  206. package/lang/translations/kk.po +0 -332
  207. package/lang/translations/km.po +0 -332
  208. package/lang/translations/kn.po +0 -332
  209. package/lang/translations/ko.po +0 -332
  210. package/lang/translations/ku.po +0 -332
  211. package/lang/translations/lt.po +0 -332
  212. package/lang/translations/lv.po +0 -332
  213. package/lang/translations/ms.po +0 -332
  214. package/lang/translations/nb.po +0 -332
  215. package/lang/translations/ne.po +0 -332
  216. package/lang/translations/nl.po +0 -332
  217. package/lang/translations/no.po +0 -332
  218. package/lang/translations/oc.po +0 -332
  219. package/lang/translations/pl.po +0 -332
  220. package/lang/translations/pt-br.po +0 -332
  221. package/lang/translations/pt.po +0 -332
  222. package/lang/translations/ro.po +0 -332
  223. package/lang/translations/ru.po +0 -332
  224. package/lang/translations/si.po +0 -332
  225. package/lang/translations/sk.po +0 -332
  226. package/lang/translations/sl.po +0 -332
  227. package/lang/translations/sq.po +0 -332
  228. package/lang/translations/sr-latn.po +0 -332
  229. package/lang/translations/sr.po +0 -332
  230. package/lang/translations/sv.po +0 -332
  231. package/lang/translations/th.po +0 -332
  232. package/lang/translations/ti.po +0 -332
  233. package/lang/translations/tk.po +0 -332
  234. package/lang/translations/tr.po +0 -332
  235. package/lang/translations/tt.po +0 -332
  236. package/lang/translations/ug.po +0 -332
  237. package/lang/translations/uk.po +0 -332
  238. package/lang/translations/ur.po +0 -332
  239. package/lang/translations/uz.po +0 -332
  240. package/lang/translations/vi.po +0 -332
  241. package/lang/translations/zh-cn.po +0 -332
  242. package/lang/translations/zh.po +0 -332
  243. package/src/augmentation.js +0 -5
  244. package/src/commands/insertcolumncommand.js +0 -71
  245. package/src/commands/insertrowcommand.js +0 -70
  246. package/src/commands/inserttablecommand.js +0 -69
  247. package/src/commands/inserttablelayoutcommand.js +0 -65
  248. package/src/commands/mergecellcommand.js +0 -206
  249. package/src/commands/mergecellscommand.js +0 -94
  250. package/src/commands/removecolumncommand.js +0 -109
  251. package/src/commands/removerowcommand.js +0 -82
  252. package/src/commands/selectcolumncommand.js +0 -60
  253. package/src/commands/selectrowcommand.js +0 -56
  254. package/src/commands/setheadercolumncommand.js +0 -76
  255. package/src/commands/setheaderrowcommand.js +0 -83
  256. package/src/commands/splitcellcommand.js +0 -58
  257. package/src/converters/downcast.js +0 -298
  258. package/src/converters/table-caption-post-fixer.js +0 -55
  259. package/src/converters/table-cell-paragraph-post-fixer.js +0 -109
  260. package/src/converters/table-cell-refresh-handler.js +0 -47
  261. package/src/converters/table-headings-refresh-handler.js +0 -51
  262. package/src/converters/table-layout-post-fixer.js +0 -369
  263. package/src/converters/tableproperties.js +0 -444
  264. package/src/converters/upcasttable.js +0 -385
  265. package/src/index.js +0 -98
  266. package/src/plaintableoutput.js +0 -49
  267. package/src/table.js +0 -50
  268. package/src/tablecaption/tablecaptionediting.js +0 -136
  269. package/src/tablecaption/tablecaptionui.js +0 -64
  270. package/src/tablecaption/toggletablecaptioncommand.js +0 -105
  271. package/src/tablecaption/utils.js +0 -61
  272. package/src/tablecaption.js +0 -34
  273. package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.js +0 -30
  274. package/src/tablecellproperties/commands/tablecellbordercolorcommand.js +0 -44
  275. package/src/tablecellproperties/commands/tablecellborderstylecommand.js +0 -44
  276. package/src/tablecellproperties/commands/tablecellborderwidthcommand.js +0 -64
  277. package/src/tablecellproperties/commands/tablecellheightcommand.js +0 -51
  278. package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.js +0 -30
  279. package/src/tablecellproperties/commands/tablecellpaddingcommand.js +0 -64
  280. package/src/tablecellproperties/commands/tablecellpropertycommand.js +0 -138
  281. package/src/tablecellproperties/commands/tablecelltypecommand.js +0 -167
  282. package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.js +0 -38
  283. package/src/tablecellproperties/tablecellpropertiesediting.js +0 -412
  284. package/src/tablecellproperties/tablecellpropertiesui.js +0 -385
  285. package/src/tablecellproperties/tablecellpropertiesuiexperimental.d.ts +0 -128
  286. package/src/tablecellproperties/tablecellpropertiesuiexperimental.js +0 -408
  287. package/src/tablecellproperties/ui/tablecellpropertiesview.d.ts +0 -229
  288. package/src/tablecellproperties/ui/tablecellpropertiesview.js +0 -612
  289. package/src/tablecellproperties/ui/tablecellpropertiesviewexperimental.js +0 -744
  290. package/src/tablecellproperties.js +0 -40
  291. package/src/tablecellwidth/commands/tablecellwidthcommand.js +0 -51
  292. package/src/tablecellwidth/tablecellwidthediting.js +0 -53
  293. package/src/tableclipboard.js +0 -500
  294. package/src/tablecolumnresize/constants.js +0 -33
  295. package/src/tablecolumnresize/converters.js +0 -62
  296. package/src/tablecolumnresize/tablecolumnresizeediting.js +0 -729
  297. package/src/tablecolumnresize/tablewidthscommand.js +0 -61
  298. package/src/tablecolumnresize/utils.js +0 -370
  299. package/src/tablecolumnresize.js +0 -36
  300. package/src/tableconfig.js +0 -5
  301. package/src/tableediting.js +0 -246
  302. package/src/tablekeyboard.js +0 -273
  303. package/src/tablelayout/commands/tabletypecommand.js +0 -68
  304. package/src/tablelayout/tablelayoutediting.js +0 -295
  305. package/src/tablelayout/tablelayoutui.js +0 -196
  306. package/src/tablelayout.js +0 -37
  307. package/src/tablemouse/mouseeventsobserver.js +0 -34
  308. package/src/tablemouse.js +0 -178
  309. package/src/tableproperties/commands/tablealignmentcommand.js +0 -30
  310. package/src/tableproperties/commands/tablebackgroundcolorcommand.js +0 -30
  311. package/src/tableproperties/commands/tablebordercolorcommand.js +0 -44
  312. package/src/tableproperties/commands/tableborderstylecommand.js +0 -44
  313. package/src/tableproperties/commands/tableborderwidthcommand.js +0 -64
  314. package/src/tableproperties/commands/tableheightcommand.js +0 -54
  315. package/src/tableproperties/commands/tablepropertycommand.js +0 -103
  316. package/src/tableproperties/commands/tablewidthcommand.js +0 -54
  317. package/src/tableproperties/tablepropertiesediting.js +0 -546
  318. package/src/tableproperties/tablepropertiesui.js +0 -374
  319. package/src/tableproperties/tablepropertiesuiexperimental.d.ts +0 -136
  320. package/src/tableproperties/tablepropertiesuiexperimental.js +0 -375
  321. package/src/tableproperties/ui/tablepropertiesview.js +0 -520
  322. package/src/tableproperties/ui/tablepropertiesviewexperimental.d.ts +0 -216
  323. package/src/tableproperties/ui/tablepropertiesviewexperimental.js +0 -544
  324. package/src/tableproperties.js +0 -40
  325. package/src/tableselection.js +0 -323
  326. package/src/tabletoolbar.js +0 -63
  327. package/src/tableui.js +0 -335
  328. package/src/tableutils.js +0 -1282
  329. package/src/tablewalker.js +0 -489
  330. package/src/ui/colorinputview.js +0 -305
  331. package/src/ui/inserttableview.js +0 -192
  332. package/src/utils/common.js +0 -118
  333. package/src/utils/structure.js +0 -452
  334. package/src/utils/table-properties.js +0 -121
  335. package/src/utils/ui/contextualballoon.js +0 -111
  336. package/src/utils/ui/table-properties.js +0 -390
  337. package/src/utils/ui/table-propertiesexperimental.d.ts +0 -215
  338. package/src/utils/ui/table-propertiesexperimental.js +0 -391
  339. package/src/utils/ui/widget.js +0 -56
  340. package/theme/colorinput.css +0 -39
  341. package/theme/formrow-experimental.css +0 -15
  342. package/theme/formrow.css +0 -13
  343. package/theme/inserttable.css +0 -10
  344. package/theme/table.css +0 -144
  345. package/theme/tablecaption.css +0 -66
  346. package/theme/tablecellproperties-experimental.css +0 -4
  347. package/theme/tablecellproperties.css +0 -28
  348. package/theme/tablecolumnresize.css +0 -62
  349. package/theme/tableediting.css +0 -10
  350. package/theme/tableform-experimental.css +0 -61
  351. package/theme/tableform.css +0 -64
  352. package/theme/tablelayout.css +0 -74
  353. package/theme/tableproperties-experimental.css +0 -78
  354. package/theme/tableproperties.css +0 -18
  355. package/theme/tableselection.css +0 -10
  356. /package/{src → dist}/tablecolumnresize/constants.d.ts +0 -0
@@ -1,374 +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/tableproperties/tablepropertiesui
7
- */
8
- import { Plugin } from 'ckeditor5/src/core.js';
9
- import { IconTableProperties } from 'ckeditor5/src/icons.js';
10
- import { ButtonView, ContextualBalloon, clickOutsideHandler, getLocalizedColorOptions, normalizeColorOptions } from 'ckeditor5/src/ui.js';
11
- import { debounce } from 'es-toolkit/compat';
12
- import { TablePropertiesView } from './ui/tablepropertiesview.js';
13
- import { colorFieldValidator, getLocalizedColorErrorText, getLocalizedLengthErrorText, lengthFieldValidator, lineWidthFieldValidator, defaultColors } from '../utils/ui/table-properties.js';
14
- import { getSelectionAffectedTableWidget } from '../utils/ui/widget.js';
15
- import { getBalloonTablePositionData, repositionContextualBalloon } from '../utils/ui/contextualballoon.js';
16
- import { getNormalizedDefaultProperties, getNormalizedDefaultTableProperties } from '../utils/table-properties.js';
17
- const ERROR_TEXT_TIMEOUT = 500;
18
- // Map of view properties and related commands.
19
- const propertyToCommandMap = {
20
- borderStyle: 'tableBorderStyle',
21
- borderColor: 'tableBorderColor',
22
- borderWidth: 'tableBorderWidth',
23
- backgroundColor: 'tableBackgroundColor',
24
- width: 'tableWidth',
25
- height: 'tableHeight',
26
- alignment: 'tableAlignment'
27
- };
28
- /**
29
- * The table properties UI plugin. It introduces the `'tableProperties'` button
30
- * that opens a form allowing to specify visual styling of an entire table.
31
- *
32
- * It uses the {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon contextual balloon plugin}.
33
- */
34
- export class TablePropertiesUI extends Plugin {
35
- /**
36
- * The default table properties.
37
- */
38
- _defaultContentTableProperties;
39
- /**
40
- * The default layout table properties.
41
- */
42
- _defaultLayoutTableProperties;
43
- /**
44
- * The contextual balloon plugin instance.
45
- */
46
- _balloon;
47
- /**
48
- * The properties form view displayed inside the balloon.
49
- */
50
- view = null;
51
- /**
52
- * The properties form view displayed inside the balloon (content table).
53
- */
54
- _viewWithContentTableDefaults = null;
55
- /**
56
- * The properties form view displayed inside the balloon (layout table).
57
- */
58
- _viewWithLayoutTableDefaults = null;
59
- /**
60
- * The batch used to undo all changes made by the form (which are live, as the user types)
61
- * when "Cancel" was pressed. Each time the view is shown, a new batch is created.
62
- */
63
- _undoStepBatch;
64
- /**
65
- * Flag used to indicate whether view is ready to execute update commands
66
- * (it finished loading initial data).
67
- */
68
- _isReady;
69
- /**
70
- * @inheritDoc
71
- */
72
- static get requires() {
73
- return [ContextualBalloon];
74
- }
75
- /**
76
- * @inheritDoc
77
- */
78
- static get pluginName() {
79
- return 'TablePropertiesUI';
80
- }
81
- /**
82
- * @inheritDoc
83
- */
84
- static get isOfficialPlugin() {
85
- return true;
86
- }
87
- /**
88
- * @inheritDoc
89
- */
90
- constructor(editor) {
91
- super(editor);
92
- editor.config.define('table.tableProperties', {
93
- borderColors: defaultColors,
94
- backgroundColors: defaultColors
95
- });
96
- }
97
- /**
98
- * @inheritDoc
99
- */
100
- init() {
101
- const editor = this.editor;
102
- this._defaultContentTableProperties = getNormalizedDefaultTableProperties(editor.config.get('table.tableProperties.defaultProperties'), {
103
- includeAlignmentProperty: true
104
- });
105
- this._defaultLayoutTableProperties = getNormalizedDefaultProperties();
106
- this._balloon = editor.plugins.get(ContextualBalloon);
107
- editor.ui.componentFactory.add('tableProperties', () => this._createTablePropertiesButton());
108
- }
109
- /**
110
- * Creates the table properties button.
111
- *
112
- * @internal
113
- */
114
- _createTablePropertiesButton() {
115
- const editor = this.editor;
116
- const t = editor.t;
117
- const view = new ButtonView(editor.locale);
118
- view.set({
119
- label: t('Table properties'),
120
- icon: IconTableProperties,
121
- tooltip: true
122
- });
123
- this.listenTo(view, 'execute', () => this._showView());
124
- const commands = Object.values(propertyToCommandMap)
125
- .map(commandName => editor.commands.get(commandName));
126
- view.bind('isEnabled').toMany(commands, 'isEnabled', (...areEnabled) => (areEnabled.some(isCommandEnabled => isCommandEnabled)));
127
- return view;
128
- }
129
- /**
130
- * @inheritDoc
131
- */
132
- destroy() {
133
- super.destroy();
134
- // Destroy created UI components as they are not automatically destroyed.
135
- // See https://github.com/ckeditor/ckeditor5/issues/1341.
136
- if (this.view) {
137
- this.view.destroy();
138
- }
139
- }
140
- /**
141
- * Creates the {@link module:table/tableproperties/ui/tablepropertiesview~TablePropertiesView} instance.
142
- *
143
- * @returns The table properties form view instance.
144
- */
145
- _createPropertiesView(defaultTableProperties) {
146
- const editor = this.editor;
147
- const config = editor.config.get('table.tableProperties');
148
- const borderColorsConfig = normalizeColorOptions(config.borderColors);
149
- const localizedBorderColors = getLocalizedColorOptions(editor.locale, borderColorsConfig);
150
- const backgroundColorsConfig = normalizeColorOptions(config.backgroundColors);
151
- const localizedBackgroundColors = getLocalizedColorOptions(editor.locale, backgroundColorsConfig);
152
- const hasColorPicker = config.colorPicker !== false;
153
- const view = new TablePropertiesView(editor.locale, {
154
- borderColors: localizedBorderColors,
155
- backgroundColors: localizedBackgroundColors,
156
- defaultTableProperties,
157
- colorPickerConfig: hasColorPicker ? (config.colorPicker || {}) : false
158
- });
159
- const t = editor.t;
160
- // Render the view so its #element is available for the clickOutsideHandler.
161
- view.render();
162
- this.listenTo(view, 'submit', () => {
163
- this._hideView();
164
- });
165
- this.listenTo(view, 'cancel', () => {
166
- // https://github.com/ckeditor/ckeditor5/issues/6180
167
- if (this._undoStepBatch.operations.length) {
168
- editor.execute('undo', this._undoStepBatch);
169
- }
170
- this._hideView();
171
- });
172
- // Close the balloon on Esc key press.
173
- view.keystrokes.set('Esc', (data, cancel) => {
174
- this._hideView();
175
- cancel();
176
- });
177
- // Close on click outside of balloon panel element.
178
- clickOutsideHandler({
179
- emitter: view,
180
- activator: () => this._isViewInBalloon,
181
- contextElements: [this._balloon.view.element],
182
- callback: () => this._hideView()
183
- });
184
- const colorErrorText = getLocalizedColorErrorText(t);
185
- const lengthErrorText = getLocalizedLengthErrorText(t);
186
- // Create the "UI -> editor data" binding.
187
- // These listeners update the editor data (via table commands) when any observable
188
- // property of the view has changed. They also validate the value and display errors in the UI
189
- // when necessary. This makes the view live, which means the changes are
190
- // visible in the editing as soon as the user types or changes fields' values.
191
- view.on('change:borderStyle', this._getPropertyChangeCallback('tableBorderStyle'));
192
- view.on('change:borderColor', this._getValidatedPropertyChangeCallback({
193
- viewField: view.borderColorInput,
194
- commandName: 'tableBorderColor',
195
- errorText: colorErrorText,
196
- validator: colorFieldValidator
197
- }));
198
- view.on('change:borderWidth', this._getValidatedPropertyChangeCallback({
199
- viewField: view.borderWidthInput,
200
- commandName: 'tableBorderWidth',
201
- errorText: lengthErrorText,
202
- validator: lineWidthFieldValidator
203
- }));
204
- view.on('change:backgroundColor', this._getValidatedPropertyChangeCallback({
205
- viewField: view.backgroundInput,
206
- commandName: 'tableBackgroundColor',
207
- errorText: colorErrorText,
208
- validator: colorFieldValidator
209
- }));
210
- view.on('change:width', this._getValidatedPropertyChangeCallback({
211
- viewField: view.widthInput,
212
- commandName: 'tableWidth',
213
- errorText: lengthErrorText,
214
- validator: lengthFieldValidator
215
- }));
216
- view.on('change:height', this._getValidatedPropertyChangeCallback({
217
- viewField: view.heightInput,
218
- commandName: 'tableHeight',
219
- errorText: lengthErrorText,
220
- validator: lengthFieldValidator
221
- }));
222
- view.on('change:alignment', this._getPropertyChangeCallback('tableAlignment'));
223
- return view;
224
- }
225
- /**
226
- * In this method the "editor data -> UI" binding is happening.
227
- *
228
- * When executed, this method obtains selected table property values from various table commands
229
- * and passes them to the {@link #view}.
230
- *
231
- * This way, the UI stays up–to–date with the editor data.
232
- */
233
- _fillViewFormFromCommandValues() {
234
- const commands = this.editor.commands;
235
- const borderStyleCommand = commands.get('tableBorderStyle');
236
- Object.entries(propertyToCommandMap)
237
- .map(([property, commandName]) => {
238
- const propertyKey = property;
239
- const defaultValue = this.view === this._viewWithContentTableDefaults ?
240
- this._defaultContentTableProperties[propertyKey] || '' :
241
- this._defaultLayoutTableProperties[propertyKey] || '';
242
- return [propertyKey, (commands.get(commandName).value || defaultValue)];
243
- })
244
- .forEach(([property, value]) => {
245
- // Do not set the `border-color` and `border-width` fields if `border-style:none`.
246
- if ((property === 'borderColor' || property === 'borderWidth') && borderStyleCommand.value === 'none') {
247
- return;
248
- }
249
- this.view.set(property, value);
250
- });
251
- this._isReady = true;
252
- }
253
- /**
254
- * Shows the {@link #view} in the {@link #_balloon}.
255
- *
256
- * **Note**: Each time a view is shown, the new {@link #_undoStepBatch} is created that contains
257
- * all changes made to the document when the view is visible, allowing a single undo step
258
- * for all of them.
259
- */
260
- _showView() {
261
- const editor = this.editor;
262
- const viewTable = getSelectionAffectedTableWidget(editor.editing.view.document.selection);
263
- const modelTable = viewTable && editor.editing.mapper.toModelElement(viewTable);
264
- const useDefaults = !modelTable || modelTable.getAttribute('tableType') !== 'layout';
265
- if (useDefaults && !this._viewWithContentTableDefaults) {
266
- this._viewWithContentTableDefaults = this._createPropertiesView(this._defaultContentTableProperties);
267
- }
268
- else if (!useDefaults && !this._viewWithLayoutTableDefaults) {
269
- this._viewWithLayoutTableDefaults = this._createPropertiesView(this._defaultLayoutTableProperties);
270
- }
271
- this.view = useDefaults ? this._viewWithContentTableDefaults : this._viewWithLayoutTableDefaults;
272
- this.listenTo(editor.ui, 'update', () => {
273
- this._updateView();
274
- });
275
- // Update the view with the model values.
276
- this._fillViewFormFromCommandValues();
277
- this._balloon.add({
278
- view: this.view,
279
- position: getBalloonTablePositionData(editor)
280
- });
281
- // Create a new batch. Clicking "Cancel" will undo this batch.
282
- this._undoStepBatch = editor.model.createBatch();
283
- // Basic a11y.
284
- this.view.focus();
285
- }
286
- /**
287
- * Removes the {@link #view} from the {@link #_balloon}.
288
- */
289
- _hideView() {
290
- const editor = this.editor;
291
- this.stopListening(editor.ui, 'update');
292
- this._isReady = false;
293
- // Blur any input element before removing it from DOM to prevent issues in some browsers.
294
- // See https://github.com/ckeditor/ckeditor5/issues/1501.
295
- this.view.saveButtonView.focus();
296
- this._balloon.remove(this.view);
297
- // Make sure the focus is not lost in the process by putting it directly
298
- // into the editing view.
299
- this.editor.editing.view.focus();
300
- }
301
- /**
302
- * Repositions the {@link #_balloon} or hides the {@link #view} if a table is no longer selected.
303
- */
304
- _updateView() {
305
- const editor = this.editor;
306
- const viewDocument = editor.editing.view.document;
307
- if (!getSelectionAffectedTableWidget(viewDocument.selection)) {
308
- this._hideView();
309
- }
310
- else if (this._isViewVisible) {
311
- repositionContextualBalloon(editor, 'table');
312
- }
313
- }
314
- /**
315
- * Returns `true` when the {@link #view} is the visible in the {@link #_balloon}.
316
- */
317
- get _isViewVisible() {
318
- return !!this.view && this._balloon.visibleView === this.view;
319
- }
320
- /**
321
- * Returns `true` when the {@link #view} is in the {@link #_balloon}.
322
- */
323
- get _isViewInBalloon() {
324
- return !!this.view && this._balloon.hasView(this.view);
325
- }
326
- /**
327
- * Creates a callback that when executed upon {@link #view view's} property change
328
- * executes a related editor command with the new property value.
329
- *
330
- * If new value will be set to the default value, the command will not be executed.
331
- *
332
- * @param commandName The command that will be executed.
333
- */
334
- _getPropertyChangeCallback(commandName) {
335
- return (evt, propertyName, newValue) => {
336
- // Do not execute the command on initial call (opening the table properties view).
337
- if (!this._isReady) {
338
- return;
339
- }
340
- this.editor.execute(commandName, {
341
- value: newValue,
342
- batch: this._undoStepBatch
343
- });
344
- };
345
- }
346
- /**
347
- * Creates a callback that when executed upon {@link #view view's} property change:
348
- * * executes a related editor command with the new property value if the value is valid,
349
- * * or sets the error text next to the invalid field, if the value did not pass the validation.
350
- */
351
- _getValidatedPropertyChangeCallback(options) {
352
- const { commandName, viewField, validator, errorText } = options;
353
- const setErrorTextDebounced = debounce(() => {
354
- viewField.errorText = errorText;
355
- }, ERROR_TEXT_TIMEOUT);
356
- return (evt, propertyName, newValue) => {
357
- setErrorTextDebounced.cancel();
358
- // Do not execute the command on initial call (opening the table properties view).
359
- if (!this._isReady) {
360
- return;
361
- }
362
- if (validator(newValue)) {
363
- this.editor.execute(commandName, {
364
- value: newValue,
365
- batch: this._undoStepBatch
366
- });
367
- viewField.errorText = null;
368
- }
369
- else {
370
- setErrorTextDebounced();
371
- }
372
- };
373
- }
374
- }
@@ -1,136 +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/tableproperties/tablepropertiesuiexperimental
7
- */
8
- import { Plugin, type Editor } from 'ckeditor5/src/core.js';
9
- import { ButtonView, ContextualBalloon } from 'ckeditor5/src/ui.js';
10
- import { TablePropertiesViewExperimental } from './ui/tablepropertiesviewexperimental.js';
11
- /**
12
- * The table properties UI plugin. It introduces the `'tableProperties'` button
13
- * that opens a form allowing to specify visual styling of an entire table.
14
- *
15
- * It uses the {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon contextual balloon plugin}.
16
- */
17
- export declare class TablePropertiesUIExperimental extends Plugin {
18
- /**
19
- * The default table properties.
20
- */
21
- private _defaultContentTableProperties;
22
- /**
23
- * The default layout table properties.
24
- */
25
- private _defaultLayoutTableProperties;
26
- /**
27
- * The contextual balloon plugin instance.
28
- */
29
- private _balloon;
30
- /**
31
- * The properties form view displayed inside the balloon.
32
- */
33
- view: TablePropertiesViewExperimental | null;
34
- /**
35
- * The properties form view displayed inside the balloon (content table).
36
- */
37
- private _viewWithContentTableDefaults;
38
- /**
39
- * The properties form view displayed inside the balloon (layout table).
40
- */
41
- private _viewWithLayoutTableDefaults;
42
- /**
43
- * The batch used to undo all changes made by the form (which are live, as the user types)
44
- * when "Cancel" was pressed. Each time the view is shown, a new batch is created.
45
- */
46
- private _undoStepBatch?;
47
- /**
48
- * Flag used to indicate whether view is ready to execute update commands
49
- * (it finished loading initial data).
50
- */
51
- private _isReady?;
52
- /**
53
- * @inheritDoc
54
- */
55
- static get requires(): readonly [typeof ContextualBalloon];
56
- /**
57
- * @inheritDoc
58
- */
59
- static get pluginName(): "TablePropertiesUIExperimental";
60
- /**
61
- * @inheritDoc
62
- */
63
- static get isOfficialPlugin(): true;
64
- /**
65
- * @inheritDoc
66
- */
67
- constructor(editor: Editor);
68
- /**
69
- * @inheritDoc
70
- */
71
- init(): void;
72
- /**
73
- * Creates the table properties button.
74
- *
75
- * @internal
76
- */
77
- _createTablePropertiesButton(): ButtonView;
78
- /**
79
- * @inheritDoc
80
- */
81
- destroy(): void;
82
- /**
83
- * Creates the {@link module:table/tableproperties/ui/tablepropertiesview~TablePropertiesView} instance.
84
- *
85
- * @returns The table properties form view instance.
86
- */
87
- private _createPropertiesView;
88
- /**
89
- * In this method the "editor data -> UI" binding is happening.
90
- *
91
- * When executed, this method obtains selected table property values from various table commands
92
- * and passes them to the {@link #view}.
93
- *
94
- * This way, the UI stays up–to–date with the editor data.
95
- */
96
- private _fillViewFormFromCommandValues;
97
- /**
98
- * Shows the {@link #view} in the {@link #_balloon}.
99
- *
100
- * **Note**: Each time a view is shown, the new {@link #_undoStepBatch} is created that contains
101
- * all changes made to the document when the view is visible, allowing a single undo step
102
- * for all of them.
103
- */
104
- protected _showView(): void;
105
- /**
106
- * Removes the {@link #view} from the {@link #_balloon}.
107
- */
108
- protected _hideView(): void;
109
- /**
110
- * Repositions the {@link #_balloon} or hides the {@link #view} if a table is no longer selected.
111
- */
112
- protected _updateView(): void;
113
- /**
114
- * Returns `true` when the {@link #view} is the visible in the {@link #_balloon}.
115
- */
116
- private get _isViewVisible();
117
- /**
118
- * Returns `true` when the {@link #view} is in the {@link #_balloon}.
119
- */
120
- private get _isViewInBalloon();
121
- /**
122
- * Creates a callback that when executed upon {@link #view view's} property change
123
- * executes a related editor command with the new property value.
124
- *
125
- * If new value will be set to the default value, the command will not be executed.
126
- *
127
- * @param commandName The command that will be executed.
128
- */
129
- private _getPropertyChangeCallback;
130
- /**
131
- * Creates a callback that when executed upon {@link #view view's} property change:
132
- * * executes a related editor command with the new property value if the value is valid,
133
- * * or sets the error text next to the invalid field, if the value did not pass the validation.
134
- */
135
- private _getValidatedPropertyChangeCallback;
136
- }