@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,305 +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/ui/colorinputview
7
- */
8
- import { View, InputTextView, createDropdown, FocusCycler, ViewCollection, ColorSelectorView } from 'ckeditor5/src/ui.js';
9
- import { FocusTracker, KeystrokeHandler } from 'ckeditor5/src/utils.js';
10
- import '../../theme/colorinput.css';
11
- /**
12
- * The color input view class. It allows the user to type in a color (hex, rgb, etc.)
13
- * or choose it from the configurable color palette with a preview.
14
- *
15
- * @internal
16
- */
17
- export class ColorInputView extends View {
18
- /**
19
- * A cached reference to the options passed to the constructor.
20
- */
21
- options;
22
- /**
23
- * Tracks information about the DOM focus in the view.
24
- */
25
- focusTracker;
26
- /**
27
- * Helps cycling over focusable children in the input view.
28
- */
29
- focusCycler;
30
- /**
31
- * A collection of views that can be focused in the view.
32
- */
33
- _focusables;
34
- /**
35
- * An instance of the dropdown allowing to select a color from a grid.
36
- */
37
- dropdownView;
38
- /**
39
- * An instance of the input allowing the user to type a color value.
40
- */
41
- inputView;
42
- /**
43
- * An instance of the {@link module:utils/keystrokehandler~KeystrokeHandler}.
44
- */
45
- keystrokes;
46
- /**
47
- * The flag that indicates whether the user is still typing.
48
- * If set to true, it means that the text input field ({@link #inputView}) still has the focus.
49
- * So, we should interrupt the user by replacing the input's value.
50
- */
51
- _stillTyping;
52
- /**
53
- * Creates an instance of the color input view.
54
- *
55
- * @param locale The locale instance.
56
- * @param options The input options.
57
- * @param options.colorDefinitions The colors to be displayed in the palette inside the input's dropdown.
58
- * @param options.columns The number of columns in which the colors will be displayed.
59
- * @param options.defaultColorValue If specified, the color input view will replace the "Remove color" button with
60
- * the "Restore default" button. Instead of clearing the input field, the default color value will be set.
61
- */
62
- constructor(locale, options) {
63
- super(locale);
64
- this.set('value', '');
65
- this.set('isReadOnly', false);
66
- this.set('isFocused', false);
67
- this.set('isEmpty', true);
68
- this.options = options;
69
- this.focusTracker = new FocusTracker();
70
- this._focusables = new ViewCollection();
71
- this.dropdownView = this._createDropdownView();
72
- this.inputView = this._createInputTextView();
73
- this.keystrokes = new KeystrokeHandler();
74
- this._stillTyping = false;
75
- this.focusCycler = new FocusCycler({
76
- focusables: this._focusables,
77
- focusTracker: this.focusTracker,
78
- keystrokeHandler: this.keystrokes,
79
- actions: {
80
- // Navigate items backwards using the <kbd>Shift</kbd> + <kbd>Tab</kbd> keystroke.
81
- focusPrevious: 'shift + tab',
82
- // Navigate items forwards using the <kbd>Tab</kbd> key.
83
- focusNext: 'tab'
84
- }
85
- });
86
- this.setTemplate({
87
- tag: 'div',
88
- attributes: {
89
- class: [
90
- 'ck',
91
- 'ck-input-color'
92
- ]
93
- },
94
- children: [
95
- this.dropdownView,
96
- this.inputView
97
- ]
98
- });
99
- this.on('change:value', (evt, name, inputValue) => this._setInputValue(inputValue));
100
- }
101
- /**
102
- * @inheritDoc
103
- */
104
- render() {
105
- super.render();
106
- [this.inputView, this.dropdownView.buttonView].forEach(view => {
107
- this.focusTracker.add(view.element);
108
- this._focusables.add(view);
109
- });
110
- this.keystrokes.listenTo(this.element);
111
- }
112
- /**
113
- * Focuses the view.
114
- */
115
- focus(direction) {
116
- if (direction === -1) {
117
- this.focusCycler.focusLast();
118
- }
119
- else {
120
- this.focusCycler.focusFirst();
121
- }
122
- }
123
- /**
124
- * @inheritDoc
125
- */
126
- destroy() {
127
- super.destroy();
128
- this.focusTracker.destroy();
129
- this.keystrokes.destroy();
130
- }
131
- /**
132
- * Creates and configures the {@link #dropdownView}.
133
- */
134
- _createDropdownView() {
135
- const locale = this.locale;
136
- const t = locale.t;
137
- const bind = this.bindTemplate;
138
- const colorSelector = this._createColorSelector(locale);
139
- const dropdown = createDropdown(locale);
140
- const colorPreview = new View();
141
- colorPreview.setTemplate({
142
- tag: 'span',
143
- attributes: {
144
- class: [
145
- 'ck',
146
- 'ck-input-color__button__preview'
147
- ],
148
- style: {
149
- backgroundColor: bind.to('value')
150
- }
151
- },
152
- children: [{
153
- tag: 'span',
154
- attributes: {
155
- class: [
156
- 'ck',
157
- 'ck-input-color__button__preview__no-color-indicator',
158
- bind.if('value', 'ck-hidden', value => value != '')
159
- ]
160
- }
161
- }]
162
- });
163
- dropdown.buttonView.extendTemplate({
164
- attributes: {
165
- class: 'ck-input-color__button'
166
- }
167
- });
168
- dropdown.buttonView.children.add(colorPreview);
169
- dropdown.buttonView.label = t('Color picker');
170
- dropdown.buttonView.tooltip = true;
171
- dropdown.panelPosition = locale.uiLanguageDirection === 'rtl' ? 'se' : 'sw';
172
- dropdown.panelView.children.add(colorSelector);
173
- dropdown.bind('isEnabled').to(this, 'isReadOnly', value => !value);
174
- dropdown.on('change:isOpen', (evt, name, isVisible) => {
175
- if (isVisible) {
176
- colorSelector.updateSelectedColors();
177
- colorSelector.showColorGridsFragment();
178
- }
179
- });
180
- return dropdown;
181
- }
182
- /**
183
- * Creates and configures an instance of {@link module:ui/inputtext/inputtextview~InputTextView}.
184
- *
185
- * @returns A configured instance to be set as {@link #inputView}.
186
- */
187
- _createInputTextView() {
188
- const locale = this.locale;
189
- const inputView = new InputTextView(locale);
190
- inputView.extendTemplate({
191
- on: {
192
- blur: inputView.bindTemplate.to('blur')
193
- }
194
- });
195
- inputView.value = this.value;
196
- inputView.bind('isReadOnly', 'hasError').to(this);
197
- this.bind('isFocused', 'isEmpty').to(inputView);
198
- inputView.on('input', () => {
199
- const inputValue = inputView.element.value;
200
- // Check if the value matches one of our defined colors' label.
201
- const mappedColor = this.options.colorDefinitions.find(def => inputValue === def.label);
202
- this._stillTyping = true;
203
- this.value = mappedColor && mappedColor.color || inputValue;
204
- });
205
- inputView.on('blur', () => {
206
- this._stillTyping = false;
207
- this._setInputValue(inputView.element.value);
208
- });
209
- inputView.delegate('input').to(this);
210
- return inputView;
211
- }
212
- /**
213
- * Creates and configures the panel with "color grid" and "color picker" inside the {@link #dropdownView}.
214
- */
215
- _createColorSelector(locale) {
216
- const t = locale.t;
217
- const defaultColor = this.options.defaultColorValue || '';
218
- const removeColorButtonLabel = defaultColor ? t('Restore default') : t('Remove color');
219
- const colorSelector = new ColorSelectorView(locale, {
220
- colors: this.options.colorDefinitions,
221
- columns: this.options.columns,
222
- removeButtonLabel: removeColorButtonLabel,
223
- colorPickerLabel: t('Color picker'),
224
- colorPickerViewConfig: this.options.colorPickerConfig === false ? false : {
225
- ...this.options.colorPickerConfig,
226
- hideInput: true
227
- }
228
- });
229
- colorSelector.appendUI();
230
- colorSelector.on('execute', (evt, data) => {
231
- if (data.source === 'colorPickerSaveButton') {
232
- this.dropdownView.isOpen = false;
233
- return;
234
- }
235
- this.value = data.value || defaultColor;
236
- // Trigger the listener that actually applies the set value.
237
- this.fire('input');
238
- if (data.source !== 'colorPicker') {
239
- this.dropdownView.isOpen = false;
240
- }
241
- });
242
- /**
243
- * Color is saved before changes in color picker. In case "cancel button" is pressed
244
- * this color will be applied.
245
- */
246
- let backupColor = this.value;
247
- colorSelector.on('colorPicker:cancel', () => {
248
- /**
249
- * Revert color to previous value before changes in color picker.
250
- */
251
- this.value = backupColor;
252
- this.fire('input');
253
- this.dropdownView.isOpen = false;
254
- });
255
- colorSelector.colorGridsFragmentView.colorPickerButtonView.on('execute', () => {
256
- /**
257
- * Save color value before changes in color picker.
258
- */
259
- backupColor = this.value;
260
- });
261
- colorSelector.bind('selectedColor').to(this, 'value');
262
- return colorSelector;
263
- }
264
- /**
265
- * Sets {@link #inputView}'s value property to the color value or color label,
266
- * if there is one and the user is not typing.
267
- *
268
- * Handles cases like:
269
- *
270
- * * Someone picks the color in the grid.
271
- * * The color is set from the plugin level.
272
- *
273
- * @param inputValue Color value to be set.
274
- */
275
- _setInputValue(inputValue) {
276
- if (!this._stillTyping) {
277
- const normalizedInputValue = normalizeColor(inputValue);
278
- // Check if the value matches one of our defined colors.
279
- const mappedColor = this.options.colorDefinitions.find(def => normalizedInputValue === normalizeColor(def.color));
280
- if (mappedColor) {
281
- this.inputView.value = mappedColor.label;
282
- }
283
- else {
284
- this.inputView.value = inputValue || '';
285
- }
286
- }
287
- }
288
- }
289
- /**
290
- * Normalizes color value, by stripping extensive whitespace.
291
- * For example., transforms:
292
- * * ` rgb( 25 50 0 )` to `rgb(25 50 0)`,
293
- * * "\t rgb( 25 , 50,0 ) " to `rgb(25 50 0)`.
294
- *
295
- * @param colorString The value to be normalized.
296
- */
297
- function normalizeColor(colorString) {
298
- return colorString
299
- // Remove any whitespace right after `(` or `,`.
300
- .replace(/([(,])\s+/g, '$1')
301
- // Remove any whitespace at the beginning or right before the end, `)`, `,`, or another whitespace.
302
- .replace(/^\s+|\s+(?=[),\s]|$)/g, '')
303
- // Then, replace `,` or whitespace with a single space.
304
- .replace(/,|\s/g, ' ');
305
- }
@@ -1,192 +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/ui/inserttableview
7
- */
8
- import { View, ButtonView, addKeyboardHandlingForGrid } from 'ckeditor5/src/ui.js';
9
- import { KeystrokeHandler, FocusTracker } from 'ckeditor5/src/utils.js';
10
- import './../../theme/inserttable.css';
11
- /**
12
- * The table size view.
13
- *
14
- * It renders a 10x10 grid to choose the inserted table size.
15
- *
16
- * @internal
17
- */
18
- export class InsertTableView extends View {
19
- /**
20
- * A collection of table size box items.
21
- */
22
- items;
23
- /**
24
- * Listen to `keydown` events fired in this view's main element.
25
- */
26
- keystrokes;
27
- /**
28
- * Tracks information about the DOM focus in the grid.
29
- */
30
- focusTracker;
31
- /**
32
- * @inheritDoc
33
- */
34
- constructor(locale) {
35
- super(locale);
36
- const bind = this.bindTemplate;
37
- this.items = this._createGridCollection();
38
- this.keystrokes = new KeystrokeHandler();
39
- this.focusTracker = new FocusTracker();
40
- this.set('rows', 0);
41
- this.set('columns', 0);
42
- this.bind('label').to(this, 'columns', this, 'rows', (columns, rows) => `${rows} × ${columns}`);
43
- this.setTemplate({
44
- tag: 'div',
45
- attributes: {
46
- class: ['ck']
47
- },
48
- children: [
49
- {
50
- tag: 'div',
51
- attributes: {
52
- class: ['ck-insert-table-dropdown__grid']
53
- },
54
- on: {
55
- 'mouseover@.ck-insert-table-dropdown-grid-box': bind.to('boxover')
56
- },
57
- children: this.items
58
- },
59
- {
60
- tag: 'div',
61
- attributes: {
62
- class: [
63
- 'ck',
64
- 'ck-insert-table-dropdown__label'
65
- ],
66
- 'aria-hidden': true
67
- },
68
- children: [
69
- {
70
- text: bind.to('label')
71
- }
72
- ]
73
- }
74
- ],
75
- on: {
76
- mousedown: bind.to(evt => {
77
- evt.preventDefault();
78
- }),
79
- click: bind.to(() => {
80
- this.fire('execute');
81
- })
82
- }
83
- });
84
- // #rows and #columns are set via changes to #focusTracker on mouse over.
85
- this.on('boxover', (evt, domEvt) => {
86
- const { row, column } = domEvt.target.dataset;
87
- this.items.get((parseInt(row, 10) - 1) * 10 + (parseInt(column, 10) - 1)).focus();
88
- });
89
- // This allows the #rows and #columns to be updated when:
90
- // * the user navigates the grid using the keyboard,
91
- // * the user moves the mouse over grid items.
92
- this.focusTracker.on('change:focusedElement', (evt, name, focusedElement) => {
93
- if (!focusedElement) {
94
- return;
95
- }
96
- const { row, column } = focusedElement.dataset;
97
- // As row & column indexes are zero-based transform it to number of selected rows & columns.
98
- this.set({
99
- rows: parseInt(row),
100
- columns: parseInt(column)
101
- });
102
- });
103
- this.on('change:columns', () => this._highlightGridBoxes());
104
- this.on('change:rows', () => this._highlightGridBoxes());
105
- }
106
- render() {
107
- super.render();
108
- addKeyboardHandlingForGrid({
109
- keystrokeHandler: this.keystrokes,
110
- focusTracker: this.focusTracker,
111
- gridItems: this.items,
112
- numberOfColumns: 10,
113
- uiLanguageDirection: this.locale && this.locale.uiLanguageDirection
114
- });
115
- for (const item of this.items) {
116
- this.focusTracker.add(item.element);
117
- }
118
- this.keystrokes.listenTo(this.element);
119
- }
120
- /**
121
- * Resets the rows and columns selection.
122
- */
123
- reset() {
124
- this.set({
125
- rows: 1,
126
- columns: 1
127
- });
128
- }
129
- /**
130
- * @inheritDoc
131
- */
132
- focus() {
133
- this.items.get(0).focus();
134
- }
135
- /**
136
- * @inheritDoc
137
- */
138
- focusLast() {
139
- this.items.get(0).focus();
140
- }
141
- /**
142
- * Highlights grid boxes depending on rows and columns selected.
143
- */
144
- _highlightGridBoxes() {
145
- const rows = this.rows;
146
- const columns = this.columns;
147
- this.items.map((boxView, index) => {
148
- // Translate box index to the row & column index.
149
- const itemRow = Math.floor(index / 10);
150
- const itemColumn = index % 10;
151
- // Grid box is highlighted when its row & column index belongs to selected number of rows & columns.
152
- const isOn = itemRow < rows && itemColumn < columns;
153
- boxView.set('isOn', isOn);
154
- });
155
- }
156
- /**
157
- * Creates a new Button for the grid.
158
- *
159
- * @param locale The locale instance.
160
- * @param row Row number.
161
- * @param column Column number.
162
- * @param label The grid button label.
163
- */
164
- _createGridButton(locale, row, column, label) {
165
- const button = new ButtonView(locale);
166
- button.set({
167
- label,
168
- class: 'ck-insert-table-dropdown-grid-box'
169
- });
170
- button.extendTemplate({
171
- attributes: {
172
- 'data-row': row,
173
- 'data-column': column
174
- }
175
- });
176
- return button;
177
- }
178
- /**
179
- * @returns A view collection containing boxes to be placed in a table grid.
180
- */
181
- _createGridCollection() {
182
- const boxes = [];
183
- // Add grid boxes to table selection view.
184
- for (let index = 0; index < 100; index++) {
185
- const row = Math.floor(index / 10);
186
- const column = index % 10;
187
- const label = `${row + 1} × ${column + 1}`;
188
- boxes.push(this._createGridButton(this.locale, row + 1, column + 1, label));
189
- }
190
- return this.createCollection(boxes);
191
- }
192
- }
@@ -1,118 +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 { downcastAttributeToStyle, upcastStyleToAttribute } from '../converters/tableproperties.js';
6
- import { TableWalker } from '../tablewalker.js';
7
- /**
8
- * A common method to update the numeric value. If a value is the default one, it will be unset.
9
- *
10
- * @internal
11
- * @param key An attribute key.
12
- * @param value The new attribute value.
13
- * @param item A model item on which the attribute will be set.
14
- * @param defaultValue The default attribute value. If a value is lower or equal, it will be unset.
15
- */
16
- export function updateNumericAttribute(key, value, item, writer, defaultValue = 1) {
17
- if (value !== undefined && value !== null && defaultValue !== undefined && defaultValue !== null && value > defaultValue) {
18
- writer.setAttribute(key, value, item);
19
- }
20
- else {
21
- writer.removeAttribute(key, item);
22
- }
23
- }
24
- /**
25
- * A common method to create an empty table cell. It creates a proper model structure as a table cell must have at least one block inside.
26
- *
27
- * @internal
28
- * @param writer The model writer.
29
- * @param insertPosition The position at which the table cell should be inserted.
30
- * @param attributes The element attributes.
31
- * @returns Created table cell.
32
- */
33
- export function createEmptyTableCell(writer, insertPosition, attributes = {}) {
34
- const tableCell = writer.createElement('tableCell', attributes);
35
- writer.insertElement('paragraph', tableCell);
36
- writer.insert(tableCell, insertPosition);
37
- return tableCell;
38
- }
39
- /**
40
- * Checks if a table cell belongs to the heading column section.
41
- *
42
- * @internal
43
- */
44
- export function isHeadingColumnCell(tableUtils, tableCell) {
45
- const table = tableCell.parent.parent;
46
- const headingColumns = parseInt(table.getAttribute('headingColumns') || '0');
47
- const { column } = tableUtils.getCellLocation(tableCell);
48
- return !!headingColumns && column < headingColumns;
49
- }
50
- /**
51
- * Enables conversion for an attribute for simple view-model mappings.
52
- *
53
- * @internal
54
- * @param options.defaultValue The default value for the specified `modelAttribute`.
55
- */
56
- export function enableProperty(schema, conversion, options) {
57
- const { modelAttribute } = options;
58
- schema.extend('tableCell', {
59
- allowAttributes: [modelAttribute]
60
- });
61
- schema.setAttributeProperties(modelAttribute, { isFormatting: true });
62
- upcastStyleToAttribute(conversion, { viewElement: /^(td|th)$/, ...options });
63
- downcastAttributeToStyle(conversion, { modelElement: 'tableCell', ...options });
64
- }
65
- /**
66
- * Depending on the position of the selection we either return the table under cursor or look for the table higher in the hierarchy.
67
- *
68
- * @internal
69
- */
70
- export function getSelectionAffectedTable(selection) {
71
- const selectedElement = selection.getSelectedElement();
72
- // Is the command triggered from the `tableToolbar`?
73
- if (selectedElement && selectedElement.is('element', 'table')) {
74
- return selectedElement;
75
- }
76
- return selection.getFirstPosition().findAncestor('table');
77
- }
78
- /**
79
- * Groups table cells by their parent table.
80
- *
81
- * @internal
82
- */
83
- export function groupCellsByTable(tableCells) {
84
- const tableMap = new Map();
85
- for (const tableCell of tableCells) {
86
- const table = tableCell.findAncestor('table');
87
- if (!tableMap.has(table)) {
88
- tableMap.set(table, []);
89
- }
90
- tableMap.get(table).push(tableCell);
91
- }
92
- return tableMap;
93
- }
94
- /**
95
- * Checks if all cells in a given row or column are header cells.
96
- *
97
- * @internal
98
- */
99
- export function isEntireCellsLineHeader({ table, row, column }) {
100
- const tableWalker = new TableWalker(table, { row, column });
101
- for (const { cell } of tableWalker) {
102
- const cellType = cell.getAttribute('tableCellType');
103
- if (cellType !== 'header') {
104
- return false;
105
- }
106
- }
107
- return true;
108
- }
109
- /**
110
- * Checks whether the `tableCellType` attribute is enabled in the editor schema and the experimental flag is set.
111
- *
112
- * @internal
113
- */
114
- export function isTableCellTypeEnabled(editor) {
115
- const { model, config } = editor;
116
- return (model.schema.checkAttribute('tableCell', 'tableCellType') &&
117
- config.get('experimentalFlags.tableCellTypeSupport') === true);
118
- }