@ckeditor/ckeditor5-table 36.0.0 → 37.0.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/table.js +1 -1
- package/package.json +34 -29
- package/src/commands/insertcolumncommand.d.ts +61 -0
- package/src/commands/insertcolumncommand.js +45 -60
- package/src/commands/insertrowcommand.d.ts +60 -0
- package/src/commands/insertrowcommand.js +44 -59
- package/src/commands/inserttablecommand.d.ts +50 -0
- package/src/commands/inserttablecommand.js +51 -68
- package/src/commands/mergecellcommand.d.ts +76 -0
- package/src/commands/mergecellcommand.js +169 -244
- package/src/commands/mergecellscommand.d.ts +33 -0
- package/src/commands/mergecellscommand.js +72 -101
- package/src/commands/removecolumncommand.d.ts +34 -0
- package/src/commands/removecolumncommand.js +88 -102
- package/src/commands/removerowcommand.d.ts +34 -0
- package/src/commands/removerowcommand.js +63 -80
- package/src/commands/selectcolumncommand.d.ts +38 -0
- package/src/commands/selectcolumncommand.js +41 -54
- package/src/commands/selectrowcommand.d.ts +38 -0
- package/src/commands/selectrowcommand.js +38 -48
- package/src/commands/setheadercolumncommand.d.ts +55 -0
- package/src/commands/setheadercolumncommand.js +48 -73
- package/src/commands/setheaderrowcommand.d.ts +58 -0
- package/src/commands/setheaderrowcommand.js +56 -85
- package/src/commands/splitcellcommand.d.ts +49 -0
- package/src/commands/splitcellcommand.js +35 -49
- package/src/converters/downcast.d.ts +63 -0
- package/src/converters/downcast.js +98 -130
- package/src/converters/table-caption-post-fixer.d.ts +20 -0
- package/src/converters/table-caption-post-fixer.js +36 -52
- package/src/converters/table-cell-paragraph-post-fixer.d.ts +32 -0
- package/src/converters/table-cell-paragraph-post-fixer.js +88 -119
- package/src/converters/table-cell-refresh-handler.d.ts +18 -0
- package/src/converters/table-cell-refresh-handler.js +29 -48
- package/src/converters/table-headings-refresh-handler.d.ts +17 -0
- package/src/converters/table-headings-refresh-handler.js +35 -54
- package/src/converters/table-layout-post-fixer.d.ts +226 -0
- package/src/converters/table-layout-post-fixer.js +276 -313
- package/src/converters/tableproperties.d.ts +54 -0
- package/src/converters/tableproperties.js +136 -168
- package/src/converters/upcasttable.d.ts +49 -0
- package/src/converters/upcasttable.js +196 -251
- package/src/index.d.ts +29 -0
- package/src/index.js +0 -2
- package/src/plaintableoutput.d.ts +30 -0
- package/src/plaintableoutput.js +107 -135
- package/src/table.d.ts +38 -0
- package/src/table.js +12 -88
- package/src/tablecaption/tablecaptionediting.d.ts +68 -0
- package/src/tablecaption/tablecaptionediting.js +104 -135
- package/src/tablecaption/tablecaptionui.d.ts +26 -0
- package/src/tablecaption/tablecaptionui.js +42 -58
- package/src/tablecaption/toggletablecaptioncommand.d.ts +73 -0
- package/src/tablecaption/toggletablecaptioncommand.js +77 -92
- package/src/tablecaption/utils.d.ts +42 -0
- package/src/tablecaption/utils.js +35 -61
- package/src/tablecaption.d.ts +27 -0
- package/src/tablecaption.js +12 -19
- package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.d.ts +37 -0
- package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.js +14 -20
- package/src/tablecellproperties/commands/tablecellbordercolorcommand.d.ts +42 -0
- package/src/tablecellproperties/commands/tablecellbordercolorcommand.js +27 -37
- package/src/tablecellproperties/commands/tablecellborderstylecommand.d.ts +42 -0
- package/src/tablecellproperties/commands/tablecellborderstylecommand.js +27 -37
- package/src/tablecellproperties/commands/tablecellborderwidthcommand.d.ts +56 -0
- package/src/tablecellproperties/commands/tablecellborderwidthcommand.js +42 -53
- package/src/tablecellproperties/commands/tablecellheightcommand.d.ts +51 -0
- package/src/tablecellproperties/commands/tablecellheightcommand.js +29 -36
- package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.d.ts +37 -0
- package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.js +14 -20
- package/src/tablecellproperties/commands/tablecellpaddingcommand.d.ts +56 -0
- package/src/tablecellproperties/commands/tablecellpaddingcommand.js +42 -53
- package/src/tablecellproperties/commands/tablecellpropertycommand.d.ts +62 -0
- package/src/tablecellproperties/commands/tablecellpropertycommand.js +77 -122
- package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.d.ts +45 -0
- package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.js +14 -20
- package/src/tablecellproperties/tablecellpropertiesediting.d.ts +47 -0
- package/src/tablecellproperties/tablecellpropertiesediting.js +194 -236
- package/src/tablecellproperties/tablecellpropertiesui.d.ts +117 -0
- package/src/tablecellproperties/tablecellpropertiesui.js +303 -456
- package/src/tablecellproperties/ui/tablecellpropertiesview.d.ts +227 -0
- package/src/tablecellproperties/ui/tablecellpropertiesview.js +509 -844
- package/src/tablecellproperties.d.ts +33 -0
- package/src/tablecellproperties.js +12 -98
- package/src/tablecellwidth/commands/tablecellwidthcommand.d.ts +51 -0
- package/src/tablecellwidth/commands/tablecellwidthcommand.js +29 -35
- package/src/tablecellwidth/tablecellwidthediting.d.ts +34 -0
- package/src/tablecellwidth/tablecellwidthediting.js +26 -38
- package/src/tableclipboard.d.ts +68 -0
- package/src/tableclipboard.js +429 -568
- package/src/tablecolumnresize/constants.d.ts +20 -0
- package/src/tablecolumnresize/constants.js +0 -10
- package/src/tablecolumnresize/converters.d.ts +18 -0
- package/src/tablecolumnresize/converters.js +35 -119
- package/src/tablecolumnresize/tablecolumnresizeediting.d.ts +142 -0
- package/src/tablecolumnresize/tablecolumnresizeediting.js +545 -711
- package/src/tablecolumnresize/tablewidthscommand.d.ts +38 -0
- package/src/tablecolumnresize/tablewidthscommand.js +61 -0
- package/src/tablecolumnresize/utils.d.ts +141 -0
- package/src/tablecolumnresize/utils.js +256 -233
- package/src/tablecolumnresize.d.ts +29 -0
- package/src/tablecolumnresize.js +12 -19
- package/src/tableconfig.d.ts +341 -0
- package/src/tableconfig.js +5 -0
- package/src/tableediting.d.ts +102 -0
- package/src/tableediting.js +157 -176
- package/src/tablekeyboard.d.ts +68 -0
- package/src/tablekeyboard.js +261 -344
- package/src/tablemouse/mouseeventsobserver.d.ts +62 -0
- package/src/tablemouse/mouseeventsobserver.js +12 -49
- package/src/tablemouse.d.ts +51 -0
- package/src/tablemouse.js +154 -202
- package/src/tableproperties/commands/tablealignmentcommand.d.ts +37 -0
- package/src/tableproperties/commands/tablealignmentcommand.js +14 -20
- package/src/tableproperties/commands/tablebackgroundcolorcommand.d.ts +37 -0
- package/src/tableproperties/commands/tablebackgroundcolorcommand.js +14 -20
- package/src/tableproperties/commands/tablebordercolorcommand.d.ts +42 -0
- package/src/tableproperties/commands/tablebordercolorcommand.js +27 -37
- package/src/tableproperties/commands/tableborderstylecommand.d.ts +42 -0
- package/src/tableproperties/commands/tableborderstylecommand.js +27 -37
- package/src/tableproperties/commands/tableborderwidthcommand.d.ts +56 -0
- package/src/tableproperties/commands/tableborderwidthcommand.js +42 -53
- package/src/tableproperties/commands/tableheightcommand.d.ts +51 -0
- package/src/tableproperties/commands/tableheightcommand.js +29 -33
- package/src/tableproperties/commands/tablepropertycommand.d.ts +61 -0
- package/src/tableproperties/commands/tablepropertycommand.js +68 -112
- package/src/tableproperties/commands/tablewidthcommand.d.ts +51 -0
- package/src/tableproperties/commands/tablewidthcommand.js +29 -33
- package/src/tableproperties/tablepropertiesediting.d.ts +45 -0
- package/src/tableproperties/tablepropertiesediting.js +164 -210
- package/src/tableproperties/tablepropertiesui.d.ts +119 -0
- package/src/tableproperties/tablepropertiesui.js +294 -439
- package/src/tableproperties/ui/tablepropertiesview.d.ts +203 -0
- package/src/tableproperties/ui/tablepropertiesview.js +427 -718
- package/src/tableproperties.d.ts +33 -0
- package/src/tableproperties.js +12 -95
- package/src/tableselection.d.ts +111 -0
- package/src/tableselection.js +279 -376
- package/src/tabletoolbar.d.ts +37 -0
- package/src/tabletoolbar.js +39 -92
- package/src/tableui.d.ts +58 -0
- package/src/tableui.js +281 -338
- package/src/tableutils.d.ts +453 -0
- package/src/tableutils.js +1015 -1229
- package/src/tablewalker.d.ts +323 -0
- package/src/tablewalker.js +308 -548
- package/src/ui/colorinputview.d.ts +143 -0
- package/src/ui/colorinputview.js +229 -366
- package/src/ui/formrowview.d.ts +61 -0
- package/src/ui/formrowview.js +38 -84
- package/src/ui/inserttableview.d.ts +77 -0
- package/src/ui/inserttableview.js +152 -242
- package/src/utils/common.d.ts +42 -0
- package/src/utils/common.js +33 -57
- package/src/utils/structure.d.ts +245 -0
- package/src/utils/structure.js +261 -379
- package/src/utils/table-properties.d.ts +67 -0
- package/src/utils/table-properties.js +60 -81
- package/src/utils/ui/contextualballoon.d.ts +34 -0
- package/src/utils/ui/contextualballoon.js +70 -89
- package/src/utils/ui/table-properties.d.ts +193 -0
- package/src/utils/ui/table-properties.js +259 -319
- package/src/utils/ui/widget.d.ts +16 -0
- package/src/utils/ui/widget.js +24 -46
- package/src/tablecolumnresize/tablecolumnwidthscommand.js +0 -55
- package/src/tablecolumnresize/tablewidthresizecommand.js +0 -65
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
|
|
3
|
+
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* @module table/tabletoolbar
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin, type PluginDependencies } from 'ckeditor5/src/core';
|
|
9
|
+
import './tableconfig';
|
|
10
|
+
/**
|
|
11
|
+
* The table toolbar class. It creates toolbars for the table feature and its content (for now only for the table cell content).
|
|
12
|
+
*
|
|
13
|
+
* The table toolbar shows up when a table widget is selected. Its components (e.g. buttons) are created based on the
|
|
14
|
+
* {@link module:table/tableconfig~TableConfig#tableToolbar `table.tableToolbar` configuration option}.
|
|
15
|
+
*
|
|
16
|
+
* Table content toolbar shows up when the selection is inside the content of a table. It creates its component based on the
|
|
17
|
+
* {@link module:table/tableconfig~TableConfig#contentToolbar `table.contentToolbar` configuration option}.
|
|
18
|
+
*/
|
|
19
|
+
export default class TableToolbar extends Plugin {
|
|
20
|
+
/**
|
|
21
|
+
* @inheritDoc
|
|
22
|
+
*/
|
|
23
|
+
static get requires(): PluginDependencies;
|
|
24
|
+
/**
|
|
25
|
+
* @inheritDoc
|
|
26
|
+
*/
|
|
27
|
+
static get pluginName(): 'TableToolbar';
|
|
28
|
+
/**
|
|
29
|
+
* @inheritDoc
|
|
30
|
+
*/
|
|
31
|
+
afterInit(): void;
|
|
32
|
+
}
|
|
33
|
+
declare module '@ckeditor/ckeditor5-core' {
|
|
34
|
+
interface PluginsMap {
|
|
35
|
+
[TableToolbar.pluginName]: TableToolbar;
|
|
36
|
+
}
|
|
37
|
+
}
|
package/src/tabletoolbar.js
CHANGED
|
@@ -2,110 +2,57 @@
|
|
|
2
2
|
* @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
|
|
3
3
|
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
|
|
4
4
|
*/
|
|
5
|
-
|
|
6
5
|
/**
|
|
7
6
|
* @module table/tabletoolbar
|
|
8
7
|
*/
|
|
9
|
-
|
|
10
8
|
import { Plugin } from 'ckeditor5/src/core';
|
|
11
9
|
import { WidgetToolbarRepository } from 'ckeditor5/src/widget';
|
|
12
10
|
import { getSelectedTableWidget, getTableWidgetAncestor } from './utils/ui/widget';
|
|
13
|
-
|
|
11
|
+
import './tableconfig';
|
|
14
12
|
/**
|
|
15
13
|
* The table toolbar class. It creates toolbars for the table feature and its content (for now only for the table cell content).
|
|
16
14
|
*
|
|
17
15
|
* The table toolbar shows up when a table widget is selected. Its components (e.g. buttons) are created based on the
|
|
18
|
-
* {@link module:table/
|
|
16
|
+
* {@link module:table/tableconfig~TableConfig#tableToolbar `table.tableToolbar` configuration option}.
|
|
19
17
|
*
|
|
20
18
|
* Table content toolbar shows up when the selection is inside the content of a table. It creates its component based on the
|
|
21
|
-
* {@link module:table/
|
|
22
|
-
*
|
|
23
|
-
* @extends module:core/plugin~Plugin
|
|
19
|
+
* {@link module:table/tableconfig~TableConfig#contentToolbar `table.contentToolbar` configuration option}.
|
|
24
20
|
*/
|
|
25
21
|
export default class TableToolbar extends Plugin {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
ariaLabel: t( 'Table toolbar' ),
|
|
63
|
-
items: tableToolbarItems,
|
|
64
|
-
getRelatedElement: getSelectedTableWidget
|
|
65
|
-
} );
|
|
66
|
-
}
|
|
67
|
-
}
|
|
22
|
+
/**
|
|
23
|
+
* @inheritDoc
|
|
24
|
+
*/
|
|
25
|
+
static get requires() {
|
|
26
|
+
return [WidgetToolbarRepository];
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* @inheritDoc
|
|
30
|
+
*/
|
|
31
|
+
static get pluginName() {
|
|
32
|
+
return 'TableToolbar';
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* @inheritDoc
|
|
36
|
+
*/
|
|
37
|
+
afterInit() {
|
|
38
|
+
const editor = this.editor;
|
|
39
|
+
const t = editor.t;
|
|
40
|
+
const widgetToolbarRepository = editor.plugins.get(WidgetToolbarRepository);
|
|
41
|
+
const tableContentToolbarItems = editor.config.get('table.contentToolbar');
|
|
42
|
+
const tableToolbarItems = editor.config.get('table.tableToolbar');
|
|
43
|
+
if (tableContentToolbarItems) {
|
|
44
|
+
widgetToolbarRepository.register('tableContent', {
|
|
45
|
+
ariaLabel: t('Table toolbar'),
|
|
46
|
+
items: tableContentToolbarItems,
|
|
47
|
+
getRelatedElement: getTableWidgetAncestor
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
if (tableToolbarItems) {
|
|
51
|
+
widgetToolbarRepository.register('table', {
|
|
52
|
+
ariaLabel: t('Table toolbar'),
|
|
53
|
+
items: tableToolbarItems,
|
|
54
|
+
getRelatedElement: getSelectedTableWidget
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}
|
|
68
58
|
}
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* Items to be placed in the table content toolbar.
|
|
72
|
-
* The {@link module:table/tabletoolbar~TableToolbar} plugin is required to make this toolbar work.
|
|
73
|
-
*
|
|
74
|
-
* Assuming that you use the {@link module:table/tableui~TableUI} feature, the following toolbar items will be available
|
|
75
|
-
* in {@link module:ui/componentfactory~ComponentFactory}:
|
|
76
|
-
*
|
|
77
|
-
* * `'tableRow'`,
|
|
78
|
-
* * `'tableColumn'`,
|
|
79
|
-
* * `'mergeTableCells'`.
|
|
80
|
-
*
|
|
81
|
-
* You can thus configure the toolbar like this:
|
|
82
|
-
*
|
|
83
|
-
* const tableConfig = {
|
|
84
|
-
* contentToolbar: [ 'tableRow', 'tableColumn', 'mergeTableCells' ]
|
|
85
|
-
* };
|
|
86
|
-
*
|
|
87
|
-
* Of course, the same buttons can also be used in the
|
|
88
|
-
* {@link module:core/editor/editorconfig~EditorConfig#toolbar main editor toolbar}.
|
|
89
|
-
*
|
|
90
|
-
* Read more about configuring the toolbar in {@link module:core/editor/editorconfig~EditorConfig#toolbar}.
|
|
91
|
-
*
|
|
92
|
-
* @member {Array.<String>} module:table/table~TableConfig#contentToolbar
|
|
93
|
-
*/
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* Items to be placed in the table toolbar.
|
|
97
|
-
* The {@link module:table/tabletoolbar~TableToolbar} plugin is required to make this toolbar work.
|
|
98
|
-
*
|
|
99
|
-
* You can thus configure the toolbar like this:
|
|
100
|
-
*
|
|
101
|
-
* const tableConfig = {
|
|
102
|
-
* tableToolbar: [ 'blockQuote' ]
|
|
103
|
-
* };
|
|
104
|
-
*
|
|
105
|
-
* Of course, the same buttons can also be used in the
|
|
106
|
-
* {@link module:core/editor/editorconfig~EditorConfig#toolbar main editor toolbar}.
|
|
107
|
-
*
|
|
108
|
-
* Read more about configuring the toolbar in {@link module:core/editor/editorconfig~EditorConfig#toolbar}.
|
|
109
|
-
*
|
|
110
|
-
* @member {Array.<String>} module:table/table~TableConfig#tableToolbar
|
|
111
|
-
*/
|
package/src/tableui.d.ts
ADDED
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license Copyright (c) 2003-2023, CKSource Holding sp. z o.o. All rights reserved.
|
|
3
|
+
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* @module table/tableui
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin } from 'ckeditor5/src/core';
|
|
9
|
+
/**
|
|
10
|
+
* The table UI plugin. It introduces:
|
|
11
|
+
*
|
|
12
|
+
* * The `'insertTable'` dropdown,
|
|
13
|
+
* * The `'tableColumn'` dropdown,
|
|
14
|
+
* * The `'tableRow'` dropdown,
|
|
15
|
+
* * The `'mergeTableCells'` split button.
|
|
16
|
+
*
|
|
17
|
+
* The `'tableColumn'`, `'tableRow'` and `'mergeTableCells'` dropdowns work best with {@link module:table/tabletoolbar~TableToolbar}.
|
|
18
|
+
*/
|
|
19
|
+
export default class TableUI extends Plugin {
|
|
20
|
+
/**
|
|
21
|
+
* @inheritDoc
|
|
22
|
+
*/
|
|
23
|
+
static get pluginName(): 'TableUI';
|
|
24
|
+
/**
|
|
25
|
+
* @inheritDoc
|
|
26
|
+
*/
|
|
27
|
+
init(): void;
|
|
28
|
+
/**
|
|
29
|
+
* Creates a dropdown view from a set of options.
|
|
30
|
+
*
|
|
31
|
+
* @param label The dropdown button label.
|
|
32
|
+
* @param icon An icon for the dropdown button.
|
|
33
|
+
* @param options The list of options for the dropdown.
|
|
34
|
+
*/
|
|
35
|
+
private _prepareDropdown;
|
|
36
|
+
/**
|
|
37
|
+
* Creates a dropdown view with a {@link module:ui/dropdown/button/splitbuttonview~SplitButtonView} for
|
|
38
|
+
* merge (and split)–related commands.
|
|
39
|
+
*
|
|
40
|
+
* @param label The dropdown button label.
|
|
41
|
+
* @param icon An icon for the dropdown button.
|
|
42
|
+
* @param options The list of options for the dropdown.
|
|
43
|
+
*/
|
|
44
|
+
private _prepareMergeSplitButtonDropdown;
|
|
45
|
+
/**
|
|
46
|
+
* Injects a {@link module:ui/list/listview~ListView} into the passed dropdown with buttons
|
|
47
|
+
* which execute editor commands as configured in passed options.
|
|
48
|
+
*
|
|
49
|
+
* @param options The list of options for the dropdown.
|
|
50
|
+
* @returns Commands the list options are interacting with.
|
|
51
|
+
*/
|
|
52
|
+
private _fillDropdownWithListOptions;
|
|
53
|
+
}
|
|
54
|
+
declare module '@ckeditor/ckeditor5-core' {
|
|
55
|
+
interface PluginsMap {
|
|
56
|
+
[TableUI.pluginName]: TableUI;
|
|
57
|
+
}
|
|
58
|
+
}
|