@ckeditor/ckeditor5-table 0.0.0-nightly-next-20260127.0 → 0.0.0-nightly-20260128.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.
- package/build/table.js +5 -0
- package/build/translations/af.js +1 -0
- package/build/translations/ar.js +1 -0
- package/build/translations/ast.js +1 -0
- package/build/translations/az.js +1 -0
- package/build/translations/be.js +1 -0
- package/build/translations/bg.js +1 -0
- package/build/translations/bn.js +1 -0
- package/build/translations/bs.js +1 -0
- package/build/translations/ca.js +1 -0
- package/build/translations/cs.js +1 -0
- package/build/translations/da.js +1 -0
- package/build/translations/de-ch.js +1 -0
- package/build/translations/de.js +1 -0
- package/build/translations/el.js +1 -0
- package/build/translations/en-au.js +1 -0
- package/build/translations/en-gb.js +1 -0
- package/build/translations/eo.js +1 -0
- package/build/translations/es-co.js +1 -0
- package/build/translations/es.js +1 -0
- package/build/translations/et.js +1 -0
- package/build/translations/eu.js +1 -0
- package/build/translations/fa.js +1 -0
- package/build/translations/fi.js +1 -0
- package/build/translations/fr.js +1 -0
- package/build/translations/gl.js +1 -0
- package/build/translations/gu.js +1 -0
- package/build/translations/he.js +1 -0
- package/build/translations/hi.js +1 -0
- package/build/translations/hr.js +1 -0
- package/build/translations/hu.js +1 -0
- package/build/translations/hy.js +1 -0
- package/build/translations/id.js +1 -0
- package/build/translations/it.js +1 -0
- package/build/translations/ja.js +1 -0
- package/build/translations/jv.js +1 -0
- package/build/translations/kk.js +1 -0
- package/build/translations/km.js +1 -0
- package/build/translations/kn.js +1 -0
- package/build/translations/ko.js +1 -0
- package/build/translations/ku.js +1 -0
- package/build/translations/lt.js +1 -0
- package/build/translations/lv.js +1 -0
- package/build/translations/ms.js +1 -0
- package/build/translations/nb.js +1 -0
- package/build/translations/ne.js +1 -0
- package/build/translations/nl.js +1 -0
- package/build/translations/no.js +1 -0
- package/build/translations/oc.js +1 -0
- package/build/translations/pl.js +1 -0
- package/build/translations/pt-br.js +1 -0
- package/build/translations/pt.js +1 -0
- package/build/translations/ro.js +1 -0
- package/build/translations/ru.js +1 -0
- package/build/translations/si.js +1 -0
- package/build/translations/sk.js +1 -0
- package/build/translations/sl.js +1 -0
- package/build/translations/sq.js +1 -0
- package/build/translations/sr-latn.js +1 -0
- package/build/translations/sr.js +1 -0
- package/build/translations/sv.js +1 -0
- package/build/translations/th.js +1 -0
- package/build/translations/ti.js +1 -0
- package/build/translations/tk.js +1 -0
- package/build/translations/tr.js +1 -0
- package/build/translations/tt.js +1 -0
- package/build/translations/ug.js +1 -0
- package/build/translations/uk.js +1 -0
- package/build/translations/ur.js +1 -0
- package/build/translations/uz.js +1 -0
- package/build/translations/vi.js +1 -0
- package/build/translations/zh-cn.js +1 -0
- package/build/translations/zh.js +1 -0
- package/ckeditor5-metadata.json +7 -16
- package/dist/index-content.css +30 -30
- package/dist/index-editor.css +170 -104
- package/dist/index.css +237 -147
- package/dist/index.css.map +1 -1
- package/dist/index.js +2433 -448
- package/dist/index.js.map +1 -1
- package/lang/contexts.json +82 -0
- package/lang/translations/af.po +332 -0
- package/lang/translations/ar.po +332 -0
- package/lang/translations/ast.po +332 -0
- package/lang/translations/az.po +332 -0
- package/lang/translations/be.po +332 -0
- package/lang/translations/bg.po +332 -0
- package/lang/translations/bn.po +334 -0
- package/lang/translations/bs.po +332 -0
- package/lang/translations/ca.po +332 -0
- package/lang/translations/cs.po +332 -0
- package/lang/translations/da.po +332 -0
- package/lang/translations/de-ch.po +332 -0
- package/lang/translations/de.po +332 -0
- package/lang/translations/el.po +332 -0
- package/lang/translations/en-au.po +332 -0
- package/lang/translations/en-gb.po +332 -0
- package/lang/translations/en.po +332 -0
- package/lang/translations/eo.po +332 -0
- package/lang/translations/es-co.po +332 -0
- package/lang/translations/es.po +332 -0
- package/lang/translations/et.po +332 -0
- package/lang/translations/eu.po +332 -0
- package/lang/translations/fa.po +332 -0
- package/lang/translations/fi.po +332 -0
- package/lang/translations/fr.po +332 -0
- package/lang/translations/gl.po +332 -0
- package/lang/translations/gu.po +332 -0
- package/lang/translations/he.po +332 -0
- package/lang/translations/hi.po +332 -0
- package/lang/translations/hr.po +332 -0
- package/lang/translations/hu.po +332 -0
- package/lang/translations/hy.po +332 -0
- package/lang/translations/id.po +332 -0
- package/lang/translations/it.po +332 -0
- package/lang/translations/ja.po +332 -0
- package/lang/translations/jv.po +332 -0
- package/lang/translations/kk.po +332 -0
- package/lang/translations/km.po +332 -0
- package/lang/translations/kn.po +332 -0
- package/lang/translations/ko.po +332 -0
- package/lang/translations/ku.po +332 -0
- package/lang/translations/lt.po +332 -0
- package/lang/translations/lv.po +332 -0
- package/lang/translations/ms.po +332 -0
- package/lang/translations/nb.po +332 -0
- package/lang/translations/ne.po +332 -0
- package/lang/translations/nl.po +332 -0
- package/lang/translations/no.po +332 -0
- package/lang/translations/oc.po +332 -0
- package/lang/translations/pl.po +332 -0
- package/lang/translations/pt-br.po +332 -0
- package/lang/translations/pt.po +332 -0
- package/lang/translations/ro.po +332 -0
- package/lang/translations/ru.po +332 -0
- package/lang/translations/si.po +332 -0
- package/lang/translations/sk.po +332 -0
- package/lang/translations/sl.po +332 -0
- package/lang/translations/sq.po +332 -0
- package/lang/translations/sr-latn.po +332 -0
- package/lang/translations/sr.po +332 -0
- package/lang/translations/sv.po +332 -0
- package/lang/translations/th.po +332 -0
- package/lang/translations/ti.po +332 -0
- package/lang/translations/tk.po +332 -0
- package/lang/translations/tr.po +332 -0
- package/lang/translations/tt.po +332 -0
- package/lang/translations/ug.po +332 -0
- package/lang/translations/uk.po +332 -0
- package/lang/translations/ur.po +332 -0
- package/lang/translations/uz.po +332 -0
- package/lang/translations/vi.po +332 -0
- package/lang/translations/zh-cn.po +332 -0
- package/lang/translations/zh.po +332 -0
- package/package.json +49 -26
- package/{dist → src}/augmentation.d.ts +15 -0
- package/src/augmentation.js +5 -0
- package/{dist → src}/commands/insertcolumncommand.d.ts +1 -1
- package/src/commands/insertcolumncommand.js +71 -0
- package/{dist → src}/commands/insertrowcommand.d.ts +1 -1
- package/src/commands/insertrowcommand.js +70 -0
- package/{dist → src}/commands/inserttablecommand.d.ts +1 -1
- package/src/commands/inserttablecommand.js +69 -0
- package/{dist → src}/commands/inserttablelayoutcommand.d.ts +1 -1
- package/src/commands/inserttablelayoutcommand.js +65 -0
- package/{dist → src}/commands/mergecellcommand.d.ts +3 -3
- package/src/commands/mergecellcommand.js +206 -0
- package/{dist → src}/commands/mergecellscommand.d.ts +1 -1
- package/src/commands/mergecellscommand.js +94 -0
- package/{dist → src}/commands/removecolumncommand.d.ts +1 -1
- package/src/commands/removecolumncommand.js +109 -0
- package/{dist → src}/commands/removerowcommand.d.ts +1 -1
- package/src/commands/removerowcommand.js +82 -0
- package/{dist → src}/commands/selectcolumncommand.d.ts +1 -1
- package/src/commands/selectcolumncommand.js +60 -0
- package/{dist → src}/commands/selectrowcommand.d.ts +1 -1
- package/src/commands/selectrowcommand.js +56 -0
- package/{dist → src}/commands/setheadercolumncommand.d.ts +1 -1
- package/src/commands/setheadercolumncommand.js +76 -0
- package/{dist → src}/commands/setheaderrowcommand.d.ts +1 -1
- package/src/commands/setheaderrowcommand.js +83 -0
- package/{dist → src}/commands/splitcellcommand.d.ts +1 -1
- package/src/commands/splitcellcommand.js +58 -0
- package/{dist → src}/converters/downcast.d.ts +2 -2
- package/src/converters/downcast.js +298 -0
- package/{dist → src}/converters/table-caption-post-fixer.d.ts +1 -1
- package/src/converters/table-caption-post-fixer.js +55 -0
- package/{dist → src}/converters/table-cell-paragraph-post-fixer.d.ts +1 -1
- package/src/converters/table-cell-paragraph-post-fixer.js +109 -0
- package/{dist → src}/converters/table-cell-refresh-handler.d.ts +1 -1
- package/src/converters/table-cell-refresh-handler.js +47 -0
- package/{dist → src}/converters/table-headings-refresh-handler.d.ts +1 -1
- package/src/converters/table-headings-refresh-handler.js +51 -0
- package/{dist → src}/converters/table-layout-post-fixer.d.ts +1 -1
- package/src/converters/table-layout-post-fixer.js +369 -0
- package/{dist → src}/converters/tableproperties.d.ts +2 -2
- package/src/converters/tableproperties.js +444 -0
- package/{dist → src}/converters/upcasttable.d.ts +1 -1
- package/src/converters/upcasttable.js +385 -0
- package/{dist → src}/index.d.ts +5 -2
- package/src/index.js +98 -0
- package/{dist → src}/plaintableoutput.d.ts +1 -1
- package/src/plaintableoutput.js +49 -0
- package/{dist → src}/table.d.ts +2 -2
- package/src/table.js +50 -0
- package/{dist → src}/tablecaption/tablecaptionediting.d.ts +2 -2
- package/src/tablecaption/tablecaptionediting.js +136 -0
- package/{dist → src}/tablecaption/tablecaptionui.d.ts +1 -1
- package/src/tablecaption/tablecaptionui.js +64 -0
- package/{dist → src}/tablecaption/toggletablecaptioncommand.d.ts +1 -1
- package/src/tablecaption/toggletablecaptioncommand.js +105 -0
- package/{dist → src}/tablecaption/utils.d.ts +1 -1
- package/src/tablecaption/utils.js +61 -0
- package/{dist → src}/tablecaption.d.ts +1 -1
- package/src/tablecaption.js +34 -0
- package/{dist → src}/tablecellproperties/commands/tablecellbackgroundcolorcommand.d.ts +1 -1
- package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.js +30 -0
- package/{dist → src}/tablecellproperties/commands/tablecellbordercolorcommand.d.ts +2 -2
- package/src/tablecellproperties/commands/tablecellbordercolorcommand.js +44 -0
- package/{dist → src}/tablecellproperties/commands/tablecellborderstylecommand.d.ts +2 -2
- package/src/tablecellproperties/commands/tablecellborderstylecommand.js +44 -0
- package/{dist → src}/tablecellproperties/commands/tablecellborderwidthcommand.d.ts +2 -2
- package/src/tablecellproperties/commands/tablecellborderwidthcommand.js +64 -0
- package/{dist → src}/tablecellproperties/commands/tablecellheightcommand.d.ts +1 -1
- package/src/tablecellproperties/commands/tablecellheightcommand.js +51 -0
- package/{dist → src}/tablecellproperties/commands/tablecellhorizontalalignmentcommand.d.ts +1 -1
- package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.js +30 -0
- package/{dist → src}/tablecellproperties/commands/tablecellpaddingcommand.d.ts +2 -2
- package/src/tablecellproperties/commands/tablecellpaddingcommand.js +64 -0
- package/{dist → src}/tablecellproperties/commands/tablecellpropertycommand.d.ts +2 -2
- package/src/tablecellproperties/commands/tablecellpropertycommand.js +138 -0
- package/{dist → src}/tablecellproperties/commands/tablecelltypecommand.d.ts +6 -2
- package/src/tablecellproperties/commands/tablecelltypecommand.js +167 -0
- package/{dist → src}/tablecellproperties/commands/tablecellverticalalignmentcommand.d.ts +1 -1
- package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.js +38 -0
- package/{dist → src}/tablecellproperties/tablecellpropertiesediting.d.ts +1 -1
- package/src/tablecellproperties/tablecellpropertiesediting.js +412 -0
- package/{dist → src}/tablecellproperties/tablecellpropertiesui.d.ts +2 -2
- package/src/tablecellproperties/tablecellpropertiesui.js +385 -0
- package/src/tablecellproperties/tablecellpropertiesuiexperimental.d.ts +128 -0
- package/src/tablecellproperties/tablecellpropertiesuiexperimental.js +408 -0
- package/src/tablecellproperties/ui/tablecellpropertiesview.d.ts +229 -0
- package/src/tablecellproperties/ui/tablecellpropertiesview.js +612 -0
- package/{dist/tablecellproperties/ui/tablecellpropertiesview.d.ts → src/tablecellproperties/ui/tablecellpropertiesviewexperimental.d.ts} +12 -11
- package/src/tablecellproperties/ui/tablecellpropertiesviewexperimental.js +744 -0
- package/{dist → src}/tablecellproperties.d.ts +1 -1
- package/src/tablecellproperties.js +40 -0
- package/{dist → src}/tablecellwidth/commands/tablecellwidthcommand.d.ts +1 -1
- package/src/tablecellwidth/commands/tablecellwidthcommand.js +51 -0
- package/{dist → src}/tablecellwidth/tablecellwidthediting.d.ts +1 -1
- package/src/tablecellwidth/tablecellwidthediting.js +53 -0
- package/{dist → src}/tableclipboard.d.ts +3 -3
- package/src/tableclipboard.js +500 -0
- package/src/tablecolumnresize/constants.js +33 -0
- package/{dist → src}/tablecolumnresize/converters.d.ts +1 -1
- package/src/tablecolumnresize/converters.js +62 -0
- package/{dist → src}/tablecolumnresize/tablecolumnresizeediting.d.ts +2 -2
- package/src/tablecolumnresize/tablecolumnresizeediting.js +734 -0
- package/{dist → src}/tablecolumnresize/tablewidthscommand.d.ts +2 -2
- package/src/tablecolumnresize/tablewidthscommand.js +61 -0
- package/{dist → src}/tablecolumnresize/utils.d.ts +2 -2
- package/src/tablecolumnresize/utils.js +370 -0
- package/{dist → src}/tablecolumnresize.d.ts +1 -1
- package/src/tablecolumnresize.js +36 -0
- package/{dist → src}/tableconfig.d.ts +6 -26
- package/src/tableconfig.js +5 -0
- package/{dist → src}/tableediting.d.ts +3 -3
- package/src/tableediting.js +246 -0
- package/{dist → src}/tablekeyboard.d.ts +3 -3
- package/src/tablekeyboard.js +273 -0
- package/{dist → src}/tablelayout/commands/tabletypecommand.d.ts +1 -1
- package/src/tablelayout/commands/tabletypecommand.js +68 -0
- package/{dist → src}/tablelayout/tablelayoutediting.d.ts +1 -1
- package/src/tablelayout/tablelayoutediting.js +295 -0
- package/{dist → src}/tablelayout/tablelayoutui.d.ts +1 -1
- package/src/tablelayout/tablelayoutui.js +196 -0
- package/{dist → src}/tablelayout.d.ts +1 -1
- package/src/tablelayout.js +37 -0
- package/{dist → src}/tablemouse/mouseeventsobserver.d.ts +1 -1
- package/src/tablemouse/mouseeventsobserver.js +34 -0
- package/{dist → src}/tablemouse.d.ts +1 -1
- package/src/tablemouse.js +178 -0
- package/{dist → src}/tableproperties/commands/tablealignmentcommand.d.ts +1 -1
- package/src/tableproperties/commands/tablealignmentcommand.js +30 -0
- package/{dist → src}/tableproperties/commands/tablebackgroundcolorcommand.d.ts +1 -1
- package/src/tableproperties/commands/tablebackgroundcolorcommand.js +30 -0
- package/{dist → src}/tableproperties/commands/tablebordercolorcommand.d.ts +2 -2
- package/src/tableproperties/commands/tablebordercolorcommand.js +44 -0
- package/{dist → src}/tableproperties/commands/tableborderstylecommand.d.ts +2 -2
- package/src/tableproperties/commands/tableborderstylecommand.js +44 -0
- package/{dist → src}/tableproperties/commands/tableborderwidthcommand.d.ts +2 -2
- package/src/tableproperties/commands/tableborderwidthcommand.js +64 -0
- package/{dist → src}/tableproperties/commands/tableheightcommand.d.ts +1 -1
- package/src/tableproperties/commands/tableheightcommand.js +54 -0
- package/{dist → src}/tableproperties/commands/tablepropertycommand.d.ts +2 -2
- package/src/tableproperties/commands/tablepropertycommand.js +103 -0
- package/{dist → src}/tableproperties/commands/tablewidthcommand.d.ts +1 -1
- package/src/tableproperties/commands/tablewidthcommand.js +54 -0
- package/{dist → src}/tableproperties/tablepropertiesediting.d.ts +1 -1
- package/src/tableproperties/tablepropertiesediting.js +546 -0
- package/{dist → src}/tableproperties/tablepropertiesui.d.ts +2 -2
- package/src/tableproperties/tablepropertiesui.js +374 -0
- package/src/tableproperties/tablepropertiesuiexperimental.d.ts +136 -0
- package/src/tableproperties/tablepropertiesuiexperimental.js +375 -0
- package/{dist → src}/tableproperties/ui/tablepropertiesview.d.ts +2 -10
- package/src/tableproperties/ui/tablepropertiesview.js +520 -0
- package/src/tableproperties/ui/tablepropertiesviewexperimental.d.ts +216 -0
- package/src/tableproperties/ui/tablepropertiesviewexperimental.js +544 -0
- package/{dist → src}/tableproperties.d.ts +1 -1
- package/src/tableproperties.js +40 -0
- package/{dist → src}/tableselection.d.ts +2 -2
- package/src/tableselection.js +323 -0
- package/{dist → src}/tabletoolbar.d.ts +2 -2
- package/src/tabletoolbar.js +63 -0
- package/{dist → src}/tableui.d.ts +1 -1
- package/src/tableui.js +335 -0
- package/{dist → src}/tableutils.d.ts +2 -2
- package/src/tableutils.js +1282 -0
- package/{dist → src}/tablewalker.d.ts +1 -1
- package/src/tablewalker.js +489 -0
- package/{dist → src}/ui/colorinputview.d.ts +2 -2
- package/src/ui/colorinputview.js +305 -0
- package/{dist → src}/ui/inserttableview.d.ts +2 -2
- package/src/ui/inserttableview.js +192 -0
- package/{dist → src}/utils/common.d.ts +2 -2
- package/src/utils/common.js +118 -0
- package/{dist → src}/utils/structure.d.ts +1 -1
- package/src/utils/structure.js +452 -0
- package/{dist → src}/utils/table-properties.d.ts +1 -1
- package/src/utils/table-properties.js +121 -0
- package/{dist → src}/utils/ui/contextualballoon.d.ts +2 -2
- package/src/utils/ui/contextualballoon.js +111 -0
- package/{dist → src}/utils/ui/table-properties.d.ts +2 -2
- package/src/utils/ui/table-properties.js +390 -0
- package/src/utils/ui/table-propertiesexperimental.d.ts +215 -0
- package/src/utils/ui/table-propertiesexperimental.js +391 -0
- package/{dist → src}/utils/ui/widget.d.ts +1 -1
- package/src/utils/ui/widget.js +56 -0
- package/theme/colorinput.css +39 -0
- package/theme/formrow-experimental.css +15 -0
- package/theme/formrow.css +13 -0
- package/theme/inserttable.css +10 -0
- package/theme/table.css +144 -0
- package/theme/tablecaption.css +66 -0
- package/theme/tablecellproperties-experimental.css +4 -0
- package/theme/tablecellproperties.css +28 -0
- package/theme/tablecolumnresize.css +62 -0
- package/theme/tableediting.css +10 -0
- package/theme/tableform-experimental.css +61 -0
- package/theme/tableform.css +64 -0
- package/theme/tablelayout.css +74 -0
- package/theme/tableproperties-experimental.css +78 -0
- package/theme/tableproperties.css +18 -0
- package/theme/tableselection.css +10 -0
- package/dist/tablecellproperties/tablecellpropertiesutils.d.ts +0 -18
- /package/{dist → src}/tablecolumnresize/constants.d.ts +0 -0
|
@@ -0,0 +1,305 @@
|
|
|
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
|
+
}
|
|
@@ -5,8 +5,8 @@
|
|
|
5
5
|
/**
|
|
6
6
|
* @module table/ui/inserttableview
|
|
7
7
|
*/
|
|
8
|
-
import { View, ButtonView, type ViewCollection } from '
|
|
9
|
-
import { KeystrokeHandler, FocusTracker, type Locale } from '
|
|
8
|
+
import { View, ButtonView, type ViewCollection } from 'ckeditor5/src/ui.js';
|
|
9
|
+
import { KeystrokeHandler, FocusTracker, type Locale } from 'ckeditor5/src/utils.js';
|
|
10
10
|
import './../../theme/inserttable.css';
|
|
11
11
|
/**
|
|
12
12
|
* The table size view.
|
|
@@ -0,0 +1,192 @@
|
|
|
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
|
+
}
|
|
@@ -5,8 +5,8 @@
|
|
|
5
5
|
/**
|
|
6
6
|
* @module table/utils/common
|
|
7
7
|
*/
|
|
8
|
-
import type { Editor } from '
|
|
9
|
-
import type { Conversion, ModelElement, ModelItem, ModelPosition, ModelSchema, ModelWriter, ModelDocumentSelection } from '
|
|
8
|
+
import type { Editor } from 'ckeditor5/src/core.js';
|
|
9
|
+
import type { Conversion, ModelElement, ModelItem, ModelPosition, ModelSchema, ModelWriter, ModelDocumentSelection } from 'ckeditor5/src/engine.js';
|
|
10
10
|
import { type TableUtils } from '../tableutils.js';
|
|
11
11
|
/**
|
|
12
12
|
* A common method to update the numeric value. If a value is the default one, it will be unset.
|
|
@@ -0,0 +1,118 @@
|
|
|
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
|
+
}
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
/**
|
|
6
6
|
* @module table/utils/structure
|
|
7
7
|
*/
|
|
8
|
-
import type { ModelElement, ModelWriter, ViewElement } from '
|
|
8
|
+
import type { ModelElement, ModelWriter, ViewElement } from 'ckeditor5/src/engine.js';
|
|
9
9
|
import { type TableSlot } from '../tablewalker.js';
|
|
10
10
|
import { type TableUtils } from '../tableutils.js';
|
|
11
11
|
/**
|