@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
|
@@ -2,14 +2,11 @@
|
|
|
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/tablecellproperties/tablecellpropertiesediting
|
|
8
7
|
*/
|
|
9
|
-
|
|
10
8
|
import { Plugin } from 'ckeditor5/src/core';
|
|
11
9
|
import { addBorderRules, addPaddingRules, addBackgroundRules } from 'ckeditor5/src/engine';
|
|
12
|
-
|
|
13
10
|
import { downcastAttributeToStyle, upcastBorderStyles } from './../converters/tableproperties';
|
|
14
11
|
import TableEditing from './../tableediting';
|
|
15
12
|
import TableCellWidthEditing from '../tablecellwidth/tablecellwidthediting';
|
|
@@ -23,10 +20,9 @@ import TableCellBorderColorCommand from './commands/tablecellbordercolorcommand'
|
|
|
23
20
|
import TableCellBorderWidthCommand from './commands/tablecellborderwidthcommand';
|
|
24
21
|
import { getNormalizedDefaultProperties } from '../utils/table-properties';
|
|
25
22
|
import { enableProperty } from '../utils/common';
|
|
26
|
-
|
|
23
|
+
import '../tableconfig';
|
|
27
24
|
const VALIGN_VALUES_REG_EXP = /^(top|middle|bottom)$/;
|
|
28
25
|
const ALIGN_VALUES_REG_EXP = /^(left|center|right|justify)$/;
|
|
29
|
-
|
|
30
26
|
/**
|
|
31
27
|
* The table cell properties editing feature.
|
|
32
28
|
*
|
|
@@ -45,240 +41,202 @@ const ALIGN_VALUES_REG_EXP = /^(left|center|right|justify)$/;
|
|
|
45
41
|
* - cell padding: the `'tableCellPadding'` command
|
|
46
42
|
* - horizontal and vertical alignment: the `'tableCellHorizontalAlignment'` and `'tableCellVerticalAlignment'` commands
|
|
47
43
|
* - width and height: the `'tableCellWidth'` and `'tableCellHeight'` commands
|
|
48
|
-
*
|
|
49
|
-
* @extends module:core/plugin~Plugin
|
|
50
44
|
*/
|
|
51
45
|
export default class TableCellPropertiesEditing extends Plugin {
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
enableProperty( schema, conversion, {
|
|
114
|
-
modelAttribute: 'tableCellBackgroundColor',
|
|
115
|
-
styleName: 'background-color',
|
|
116
|
-
defaultValue: defaultTableCellProperties.backgroundColor
|
|
117
|
-
} );
|
|
118
|
-
editor.commands.add(
|
|
119
|
-
'tableCellBackgroundColor',
|
|
120
|
-
new TableCellBackgroundColorCommand( editor, defaultTableCellProperties.backgroundColor )
|
|
121
|
-
);
|
|
122
|
-
|
|
123
|
-
enableHorizontalAlignmentProperty( schema, conversion, defaultTableCellProperties.horizontalAlignment );
|
|
124
|
-
editor.commands.add(
|
|
125
|
-
'tableCellHorizontalAlignment',
|
|
126
|
-
new TableCellHorizontalAlignmentCommand( editor, defaultTableCellProperties.horizontalAlignment )
|
|
127
|
-
);
|
|
128
|
-
|
|
129
|
-
enableVerticalAlignmentProperty( schema, conversion, defaultTableCellProperties.verticalAlignment );
|
|
130
|
-
editor.commands.add(
|
|
131
|
-
'tableCellVerticalAlignment',
|
|
132
|
-
new TableCellVerticalAlignmentCommand( editor, defaultTableCellProperties.verticalAlignment )
|
|
133
|
-
);
|
|
134
|
-
}
|
|
46
|
+
/**
|
|
47
|
+
* @inheritDoc
|
|
48
|
+
*/
|
|
49
|
+
static get pluginName() {
|
|
50
|
+
return 'TableCellPropertiesEditing';
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* @inheritDoc
|
|
54
|
+
*/
|
|
55
|
+
static get requires() {
|
|
56
|
+
return [TableEditing, TableCellWidthEditing];
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* @inheritDoc
|
|
60
|
+
*/
|
|
61
|
+
init() {
|
|
62
|
+
const editor = this.editor;
|
|
63
|
+
const schema = editor.model.schema;
|
|
64
|
+
const conversion = editor.conversion;
|
|
65
|
+
editor.config.define('table.tableCellProperties.defaultProperties', {});
|
|
66
|
+
const defaultTableCellProperties = getNormalizedDefaultProperties(editor.config.get('table.tableCellProperties.defaultProperties'), {
|
|
67
|
+
includeVerticalAlignmentProperty: true,
|
|
68
|
+
includeHorizontalAlignmentProperty: true,
|
|
69
|
+
includePaddingProperty: true,
|
|
70
|
+
isRightToLeftContent: editor.locale.contentLanguageDirection === 'rtl'
|
|
71
|
+
});
|
|
72
|
+
editor.data.addStyleProcessorRules(addBorderRules);
|
|
73
|
+
enableBorderProperties(schema, conversion, {
|
|
74
|
+
color: defaultTableCellProperties.borderColor,
|
|
75
|
+
style: defaultTableCellProperties.borderStyle,
|
|
76
|
+
width: defaultTableCellProperties.borderWidth
|
|
77
|
+
});
|
|
78
|
+
editor.commands.add('tableCellBorderStyle', new TableCellBorderStyleCommand(editor, defaultTableCellProperties.borderStyle));
|
|
79
|
+
editor.commands.add('tableCellBorderColor', new TableCellBorderColorCommand(editor, defaultTableCellProperties.borderColor));
|
|
80
|
+
editor.commands.add('tableCellBorderWidth', new TableCellBorderWidthCommand(editor, defaultTableCellProperties.borderWidth));
|
|
81
|
+
enableProperty(schema, conversion, {
|
|
82
|
+
modelAttribute: 'tableCellHeight',
|
|
83
|
+
styleName: 'height',
|
|
84
|
+
defaultValue: defaultTableCellProperties.height
|
|
85
|
+
});
|
|
86
|
+
editor.commands.add('tableCellHeight', new TableCellHeightCommand(editor, defaultTableCellProperties.height));
|
|
87
|
+
editor.data.addStyleProcessorRules(addPaddingRules);
|
|
88
|
+
enableProperty(schema, conversion, {
|
|
89
|
+
modelAttribute: 'tableCellPadding',
|
|
90
|
+
styleName: 'padding',
|
|
91
|
+
reduceBoxSides: true,
|
|
92
|
+
defaultValue: defaultTableCellProperties.padding
|
|
93
|
+
});
|
|
94
|
+
editor.commands.add('tableCellPadding', new TableCellPaddingCommand(editor, defaultTableCellProperties.padding));
|
|
95
|
+
editor.data.addStyleProcessorRules(addBackgroundRules);
|
|
96
|
+
enableProperty(schema, conversion, {
|
|
97
|
+
modelAttribute: 'tableCellBackgroundColor',
|
|
98
|
+
styleName: 'background-color',
|
|
99
|
+
defaultValue: defaultTableCellProperties.backgroundColor
|
|
100
|
+
});
|
|
101
|
+
editor.commands.add('tableCellBackgroundColor', new TableCellBackgroundColorCommand(editor, defaultTableCellProperties.backgroundColor));
|
|
102
|
+
enableHorizontalAlignmentProperty(schema, conversion, defaultTableCellProperties.horizontalAlignment);
|
|
103
|
+
editor.commands.add('tableCellHorizontalAlignment', new TableCellHorizontalAlignmentCommand(editor, defaultTableCellProperties.horizontalAlignment));
|
|
104
|
+
enableVerticalAlignmentProperty(schema, conversion, defaultTableCellProperties.verticalAlignment);
|
|
105
|
+
editor.commands.add('tableCellVerticalAlignment', new TableCellVerticalAlignmentCommand(editor, defaultTableCellProperties.verticalAlignment));
|
|
106
|
+
}
|
|
135
107
|
}
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
downcastAttributeToStyle( conversion, { modelElement: 'tableCell', modelAttribute: modelAttributes.style, styleName: 'border-style' } );
|
|
159
|
-
downcastAttributeToStyle( conversion, { modelElement: 'tableCell', modelAttribute: modelAttributes.color, styleName: 'border-color' } );
|
|
160
|
-
downcastAttributeToStyle( conversion, { modelElement: 'tableCell', modelAttribute: modelAttributes.width, styleName: 'border-width' } );
|
|
108
|
+
/**
|
|
109
|
+
* Enables the `'tableCellBorderStyle'`, `'tableCellBorderColor'` and `'tableCellBorderWidth'` attributes for table cells.
|
|
110
|
+
*
|
|
111
|
+
* @param defaultBorder The default border values.
|
|
112
|
+
* @param defaultBorder.color The default `tableCellBorderColor` value.
|
|
113
|
+
* @param defaultBorder.style The default `tableCellBorderStyle` value.
|
|
114
|
+
* @param defaultBorder.width The default `tableCellBorderWidth` value.
|
|
115
|
+
*/
|
|
116
|
+
function enableBorderProperties(schema, conversion, defaultBorder) {
|
|
117
|
+
const modelAttributes = {
|
|
118
|
+
width: 'tableCellBorderWidth',
|
|
119
|
+
color: 'tableCellBorderColor',
|
|
120
|
+
style: 'tableCellBorderStyle'
|
|
121
|
+
};
|
|
122
|
+
schema.extend('tableCell', {
|
|
123
|
+
allowAttributes: Object.values(modelAttributes)
|
|
124
|
+
});
|
|
125
|
+
upcastBorderStyles(conversion, 'td', modelAttributes, defaultBorder);
|
|
126
|
+
upcastBorderStyles(conversion, 'th', modelAttributes, defaultBorder);
|
|
127
|
+
downcastAttributeToStyle(conversion, { modelElement: 'tableCell', modelAttribute: modelAttributes.style, styleName: 'border-style' });
|
|
128
|
+
downcastAttributeToStyle(conversion, { modelElement: 'tableCell', modelAttribute: modelAttributes.color, styleName: 'border-color' });
|
|
129
|
+
downcastAttributeToStyle(conversion, { modelElement: 'tableCell', modelAttribute: modelAttributes.width, styleName: 'border-width' });
|
|
161
130
|
}
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
const align = viewElement.getAttribute( 'align' );
|
|
218
|
-
|
|
219
|
-
return align === defaultValue ? null : align;
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
} );
|
|
131
|
+
/**
|
|
132
|
+
* Enables the `'tableCellHorizontalAlignment'` attribute for table cells.
|
|
133
|
+
*
|
|
134
|
+
* @param defaultValue The default horizontal alignment value.
|
|
135
|
+
*/
|
|
136
|
+
function enableHorizontalAlignmentProperty(schema, conversion, defaultValue) {
|
|
137
|
+
schema.extend('tableCell', {
|
|
138
|
+
allowAttributes: ['tableCellHorizontalAlignment']
|
|
139
|
+
});
|
|
140
|
+
conversion.for('downcast')
|
|
141
|
+
.attributeToAttribute({
|
|
142
|
+
model: {
|
|
143
|
+
name: 'tableCell',
|
|
144
|
+
key: 'tableCellHorizontalAlignment'
|
|
145
|
+
},
|
|
146
|
+
view: alignment => ({
|
|
147
|
+
key: 'style',
|
|
148
|
+
value: {
|
|
149
|
+
'text-align': alignment
|
|
150
|
+
}
|
|
151
|
+
})
|
|
152
|
+
});
|
|
153
|
+
conversion.for('upcast')
|
|
154
|
+
// Support for the `text-align:*;` CSS definition for the table cell alignment.
|
|
155
|
+
.attributeToAttribute({
|
|
156
|
+
view: {
|
|
157
|
+
name: /^(td|th)$/,
|
|
158
|
+
styles: {
|
|
159
|
+
'text-align': ALIGN_VALUES_REG_EXP
|
|
160
|
+
}
|
|
161
|
+
},
|
|
162
|
+
model: {
|
|
163
|
+
key: 'tableCellHorizontalAlignment',
|
|
164
|
+
value: (viewElement) => {
|
|
165
|
+
const align = viewElement.getStyle('text-align');
|
|
166
|
+
return align === defaultValue ? null : align;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
})
|
|
170
|
+
// Support for the `align` attribute as the backward compatibility while pasting from other sources.
|
|
171
|
+
.attributeToAttribute({
|
|
172
|
+
view: {
|
|
173
|
+
name: /^(td|th)$/,
|
|
174
|
+
attributes: {
|
|
175
|
+
align: ALIGN_VALUES_REG_EXP
|
|
176
|
+
}
|
|
177
|
+
},
|
|
178
|
+
model: {
|
|
179
|
+
key: 'tableCellHorizontalAlignment',
|
|
180
|
+
value: (viewElement) => {
|
|
181
|
+
const align = viewElement.getAttribute('align');
|
|
182
|
+
return align === defaultValue ? null : align;
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
});
|
|
223
186
|
}
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
return valign === defaultValue ? null : valign;
|
|
281
|
-
}
|
|
282
|
-
}
|
|
283
|
-
} );
|
|
187
|
+
/**
|
|
188
|
+
* Enables the `'verticalAlignment'` attribute for table cells.
|
|
189
|
+
*
|
|
190
|
+
* @param defaultValue The default vertical alignment value.
|
|
191
|
+
*/
|
|
192
|
+
function enableVerticalAlignmentProperty(schema, conversion, defaultValue) {
|
|
193
|
+
schema.extend('tableCell', {
|
|
194
|
+
allowAttributes: ['tableCellVerticalAlignment']
|
|
195
|
+
});
|
|
196
|
+
conversion.for('downcast')
|
|
197
|
+
.attributeToAttribute({
|
|
198
|
+
model: {
|
|
199
|
+
name: 'tableCell',
|
|
200
|
+
key: 'tableCellVerticalAlignment'
|
|
201
|
+
},
|
|
202
|
+
view: alignment => ({
|
|
203
|
+
key: 'style',
|
|
204
|
+
value: {
|
|
205
|
+
'vertical-align': alignment
|
|
206
|
+
}
|
|
207
|
+
})
|
|
208
|
+
});
|
|
209
|
+
conversion.for('upcast')
|
|
210
|
+
// Support for the `vertical-align:*;` CSS definition for the table cell alignment.
|
|
211
|
+
.attributeToAttribute({
|
|
212
|
+
view: {
|
|
213
|
+
name: /^(td|th)$/,
|
|
214
|
+
styles: {
|
|
215
|
+
'vertical-align': VALIGN_VALUES_REG_EXP
|
|
216
|
+
}
|
|
217
|
+
},
|
|
218
|
+
model: {
|
|
219
|
+
key: 'tableCellVerticalAlignment',
|
|
220
|
+
value: (viewElement) => {
|
|
221
|
+
const align = viewElement.getStyle('vertical-align');
|
|
222
|
+
return align === defaultValue ? null : align;
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
})
|
|
226
|
+
// Support for the `align` attribute as the backward compatibility while pasting from other sources.
|
|
227
|
+
.attributeToAttribute({
|
|
228
|
+
view: {
|
|
229
|
+
name: /^(td|th)$/,
|
|
230
|
+
attributes: {
|
|
231
|
+
valign: VALIGN_VALUES_REG_EXP
|
|
232
|
+
}
|
|
233
|
+
},
|
|
234
|
+
model: {
|
|
235
|
+
key: 'tableCellVerticalAlignment',
|
|
236
|
+
value: (viewElement) => {
|
|
237
|
+
const valign = viewElement.getAttribute('valign');
|
|
238
|
+
return valign === defaultValue ? null : valign;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
});
|
|
284
242
|
}
|
|
@@ -0,0 +1,117 @@
|
|
|
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/tablecellproperties/tablecellpropertiesui
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin, type Editor, type PluginDependencies } from 'ckeditor5/src/core';
|
|
9
|
+
import TableCellPropertiesView from './ui/tablecellpropertiesview';
|
|
10
|
+
import '../tableconfig';
|
|
11
|
+
/**
|
|
12
|
+
* The table cell properties UI plugin. It introduces the `'tableCellProperties'` button
|
|
13
|
+
* that opens a form allowing to specify the visual styling of a table cell.
|
|
14
|
+
*
|
|
15
|
+
* It uses the {@link module:ui/panel/balloon/contextualballoon~ContextualBalloon contextual balloon plugin}.
|
|
16
|
+
*/
|
|
17
|
+
export default class TableCellPropertiesUI extends Plugin {
|
|
18
|
+
/**
|
|
19
|
+
* The default table cell properties.
|
|
20
|
+
*/
|
|
21
|
+
private _defaultTableCellProperties;
|
|
22
|
+
/**
|
|
23
|
+
* The contextual balloon plugin instance.
|
|
24
|
+
*/
|
|
25
|
+
private _balloon?;
|
|
26
|
+
/**
|
|
27
|
+
* The cell properties form view displayed inside the balloon.
|
|
28
|
+
*/
|
|
29
|
+
view?: TableCellPropertiesView | null;
|
|
30
|
+
/**
|
|
31
|
+
* The batch used to undo all changes made by the form (which are live, as the user types)
|
|
32
|
+
* when "Cancel" was pressed. Each time the view is shown, a new batch is created.
|
|
33
|
+
*/
|
|
34
|
+
private _undoStepBatch?;
|
|
35
|
+
/**
|
|
36
|
+
* Flag used to indicate whether view is ready to execute update commands
|
|
37
|
+
* (it finished loading initial data).
|
|
38
|
+
*/
|
|
39
|
+
private _isReady?;
|
|
40
|
+
/**
|
|
41
|
+
* @inheritDoc
|
|
42
|
+
*/
|
|
43
|
+
static get requires(): PluginDependencies;
|
|
44
|
+
/**
|
|
45
|
+
* @inheritDoc
|
|
46
|
+
*/
|
|
47
|
+
static get pluginName(): 'TableCellPropertiesUI';
|
|
48
|
+
/**
|
|
49
|
+
* @inheritDoc
|
|
50
|
+
*/
|
|
51
|
+
constructor(editor: Editor);
|
|
52
|
+
/**
|
|
53
|
+
* @inheritDoc
|
|
54
|
+
*/
|
|
55
|
+
init(): void;
|
|
56
|
+
/**
|
|
57
|
+
* @inheritDoc
|
|
58
|
+
*/
|
|
59
|
+
destroy(): void;
|
|
60
|
+
/**
|
|
61
|
+
* Creates the {@link module:table/tablecellproperties/ui/tablecellpropertiesview~TableCellPropertiesView} instance.
|
|
62
|
+
*
|
|
63
|
+
* @returns The cell properties form view instance.
|
|
64
|
+
*/
|
|
65
|
+
private _createPropertiesView;
|
|
66
|
+
/**
|
|
67
|
+
* In this method the "editor data -> UI" binding is happening.
|
|
68
|
+
*
|
|
69
|
+
* When executed, this method obtains selected cell property values from various table commands
|
|
70
|
+
* and passes them to the {@link #view}.
|
|
71
|
+
*
|
|
72
|
+
* This way, the UI stays up–to–date with the editor data.
|
|
73
|
+
*/
|
|
74
|
+
private _fillViewFormFromCommandValues;
|
|
75
|
+
/**
|
|
76
|
+
* Shows the {@link #view} in the {@link #_balloon}.
|
|
77
|
+
*
|
|
78
|
+
* **Note**: Each time a view is shown, a new {@link #_undoStepBatch} is created. It contains
|
|
79
|
+
* all changes made to the document when the view is visible, allowing a single undo step
|
|
80
|
+
* for all of them.
|
|
81
|
+
*/
|
|
82
|
+
protected _showView(): void;
|
|
83
|
+
/**
|
|
84
|
+
* Removes the {@link #view} from the {@link #_balloon}.
|
|
85
|
+
*/
|
|
86
|
+
protected _hideView(): void;
|
|
87
|
+
/**
|
|
88
|
+
* Repositions the {@link #_balloon} or hides the {@link #view} if a table cell is no longer selected.
|
|
89
|
+
*/
|
|
90
|
+
protected _updateView(): void;
|
|
91
|
+
/**
|
|
92
|
+
* Returns `true` when the {@link #view} is visible in the {@link #_balloon}.
|
|
93
|
+
*/
|
|
94
|
+
private get _isViewVisible();
|
|
95
|
+
/**
|
|
96
|
+
* Returns `true` when the {@link #view} is in the {@link #_balloon}.
|
|
97
|
+
*/
|
|
98
|
+
private get _isViewInBalloon();
|
|
99
|
+
/**
|
|
100
|
+
* Creates a callback that when executed upon the {@link #view view's} property change
|
|
101
|
+
* executes a related editor command with the new property value.
|
|
102
|
+
*
|
|
103
|
+
* @param defaultValue The default value of the command.
|
|
104
|
+
*/
|
|
105
|
+
private _getPropertyChangeCallback;
|
|
106
|
+
/**
|
|
107
|
+
* Creates a callback that when executed upon the {@link #view view's} property change:
|
|
108
|
+
* * Executes a related editor command with the new property value if the value is valid,
|
|
109
|
+
* * Or sets the error text next to the invalid field, if the value did not pass the validation.
|
|
110
|
+
*/
|
|
111
|
+
private _getValidatedPropertyChangeCallback;
|
|
112
|
+
}
|
|
113
|
+
declare module '@ckeditor/ckeditor5-core' {
|
|
114
|
+
interface PluginsMap {
|
|
115
|
+
[TableCellPropertiesUI.pluginName]: TableCellPropertiesUI;
|
|
116
|
+
}
|
|
117
|
+
}
|