@ckeditor/ckeditor5-table 36.0.1 → 37.0.0-alpha.1
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/README.md +1 -1
- package/build/table.js +1 -1
- package/ckeditor5-metadata.json +6 -6
- package/package.json +34 -29
- package/src/augmentation.d.ts +76 -0
- package/src/augmentation.js +5 -0
- package/src/commands/insertcolumncommand.d.ts +55 -0
- package/src/commands/insertcolumncommand.js +45 -60
- package/src/commands/insertrowcommand.d.ts +54 -0
- package/src/commands/insertrowcommand.js +44 -59
- package/src/commands/inserttablecommand.d.ts +44 -0
- package/src/commands/inserttablecommand.js +50 -68
- package/src/commands/mergecellcommand.d.ts +68 -0
- package/src/commands/mergecellcommand.js +169 -244
- package/src/commands/mergecellscommand.d.ts +28 -0
- package/src/commands/mergecellscommand.js +72 -101
- package/src/commands/removecolumncommand.d.ts +29 -0
- package/src/commands/removecolumncommand.js +88 -102
- package/src/commands/removerowcommand.d.ts +29 -0
- package/src/commands/removerowcommand.js +63 -80
- package/src/commands/selectcolumncommand.d.ts +33 -0
- package/src/commands/selectcolumncommand.js +41 -54
- package/src/commands/selectrowcommand.d.ts +33 -0
- package/src/commands/selectrowcommand.js +38 -48
- package/src/commands/setheadercolumncommand.d.ts +50 -0
- package/src/commands/setheadercolumncommand.js +48 -73
- package/src/commands/setheaderrowcommand.d.ts +53 -0
- package/src/commands/setheaderrowcommand.js +56 -85
- package/src/commands/splitcellcommand.d.ts +43 -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 +199 -251
- package/src/index.d.ts +60 -0
- package/src/index.js +1 -2
- package/src/plaintableoutput.d.ts +25 -0
- package/src/plaintableoutput.js +107 -135
- package/src/table.d.ts +33 -0
- package/src/table.js +12 -88
- package/src/tablecaption/tablecaptionediting.d.ts +63 -0
- package/src/tablecaption/tablecaptionediting.js +104 -135
- package/src/tablecaption/tablecaptionui.d.ts +21 -0
- package/src/tablecaption/tablecaptionui.js +42 -58
- package/src/tablecaption/toggletablecaptioncommand.d.ts +68 -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 +22 -0
- package/src/tablecaption.js +12 -19
- package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.d.ts +32 -0
- package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.js +14 -20
- package/src/tablecellproperties/commands/tablecellbordercolorcommand.d.ts +37 -0
- package/src/tablecellproperties/commands/tablecellbordercolorcommand.js +27 -37
- package/src/tablecellproperties/commands/tablecellborderstylecommand.d.ts +37 -0
- package/src/tablecellproperties/commands/tablecellborderstylecommand.js +27 -37
- package/src/tablecellproperties/commands/tablecellborderwidthcommand.d.ts +51 -0
- package/src/tablecellproperties/commands/tablecellborderwidthcommand.js +42 -53
- package/src/tablecellproperties/commands/tablecellheightcommand.d.ts +46 -0
- package/src/tablecellproperties/commands/tablecellheightcommand.js +29 -36
- package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.d.ts +32 -0
- package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.js +14 -20
- package/src/tablecellproperties/commands/tablecellpaddingcommand.d.ts +51 -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 +40 -0
- package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.js +14 -20
- package/src/tablecellproperties/tablecellpropertiesediting.d.ts +41 -0
- package/src/tablecellproperties/tablecellpropertiesediting.js +193 -236
- package/src/tablecellproperties/tablecellpropertiesui.d.ts +111 -0
- package/src/tablecellproperties/tablecellpropertiesui.js +302 -456
- package/src/tablecellproperties/ui/tablecellpropertiesview.d.ts +227 -0
- package/src/tablecellproperties/ui/tablecellpropertiesview.js +509 -844
- package/src/tablecellproperties.d.ts +28 -0
- package/src/tablecellproperties.js +12 -98
- package/src/tablecellwidth/commands/tablecellwidthcommand.d.ts +46 -0
- package/src/tablecellwidth/commands/tablecellwidthcommand.js +29 -35
- package/src/tablecellwidth/tablecellwidthediting.d.ts +28 -0
- package/src/tablecellwidth/tablecellwidthediting.js +25 -38
- package/src/tableclipboard.d.ts +63 -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 +137 -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 +24 -0
- package/src/tablecolumnresize.js +12 -19
- package/src/tableconfig.d.ts +331 -0
- package/src/tableconfig.js +5 -0
- package/src/tableediting.d.ts +97 -0
- package/src/tableediting.js +157 -176
- package/src/tablekeyboard.d.ts +63 -0
- package/src/tablekeyboard.js +261 -344
- package/src/tablemouse/mouseeventsobserver.d.ts +62 -0
- package/src/tablemouse/mouseeventsobserver.js +13 -50
- package/src/tablemouse.d.ts +46 -0
- package/src/tablemouse.js +154 -202
- package/src/tableproperties/commands/tablealignmentcommand.d.ts +32 -0
- package/src/tableproperties/commands/tablealignmentcommand.js +14 -20
- package/src/tableproperties/commands/tablebackgroundcolorcommand.d.ts +32 -0
- package/src/tableproperties/commands/tablebackgroundcolorcommand.js +14 -20
- package/src/tableproperties/commands/tablebordercolorcommand.d.ts +37 -0
- package/src/tableproperties/commands/tablebordercolorcommand.js +27 -37
- package/src/tableproperties/commands/tableborderstylecommand.d.ts +37 -0
- package/src/tableproperties/commands/tableborderstylecommand.js +27 -37
- package/src/tableproperties/commands/tableborderwidthcommand.d.ts +51 -0
- package/src/tableproperties/commands/tableborderwidthcommand.js +42 -53
- package/src/tableproperties/commands/tableheightcommand.d.ts +46 -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 +46 -0
- package/src/tableproperties/commands/tablewidthcommand.js +29 -33
- package/src/tableproperties/tablepropertiesediting.d.ts +39 -0
- package/src/tableproperties/tablepropertiesediting.js +163 -210
- package/src/tableproperties/tablepropertiesui.d.ts +113 -0
- package/src/tableproperties/tablepropertiesui.js +293 -439
- package/src/tableproperties/ui/tablepropertiesview.d.ts +203 -0
- package/src/tableproperties/ui/tablepropertiesview.js +427 -718
- package/src/tableproperties.d.ts +28 -0
- package/src/tableproperties.js +12 -95
- package/src/tableselection.d.ts +106 -0
- package/src/tableselection.js +279 -376
- package/src/tabletoolbar.d.ts +31 -0
- package/src/tabletoolbar.js +38 -92
- package/src/tableui.d.ts +53 -0
- package/src/tableui.js +281 -338
- package/src/tableutils.d.ts +448 -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,61 @@
|
|
|
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/tableproperties/commands/tablepropertycommand
|
|
7
|
+
*/
|
|
8
|
+
import type { Batch, Element } from 'ckeditor5/src/engine';
|
|
9
|
+
import { Command, type Editor } from 'ckeditor5/src/core';
|
|
10
|
+
export interface TablePropertyCommandExecuteOptions {
|
|
11
|
+
batch?: Batch;
|
|
12
|
+
columnWidths?: string;
|
|
13
|
+
table?: Element;
|
|
14
|
+
tableWidth?: string;
|
|
15
|
+
value?: string;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* The table cell attribute command.
|
|
19
|
+
*
|
|
20
|
+
* This command is a base command for other table property commands.
|
|
21
|
+
*/
|
|
22
|
+
export default class TablePropertyCommand extends Command {
|
|
23
|
+
/**
|
|
24
|
+
* The attribute that will be set by the command.
|
|
25
|
+
*/
|
|
26
|
+
readonly attributeName: string;
|
|
27
|
+
/**
|
|
28
|
+
* The default value for the attribute.
|
|
29
|
+
*/
|
|
30
|
+
protected readonly _defaultValue: string | undefined;
|
|
31
|
+
/**
|
|
32
|
+
* Creates a new `TablePropertyCommand` instance.
|
|
33
|
+
*
|
|
34
|
+
* @param editor An editor in which this command will be used.
|
|
35
|
+
* @param attributeName Table cell attribute name.
|
|
36
|
+
* @param defaultValue The default value of the attribute.
|
|
37
|
+
*/
|
|
38
|
+
constructor(editor: Editor, attributeName: string, defaultValue?: string);
|
|
39
|
+
/**
|
|
40
|
+
* @inheritDoc
|
|
41
|
+
*/
|
|
42
|
+
refresh(): void;
|
|
43
|
+
/**
|
|
44
|
+
* Executes the command.
|
|
45
|
+
*
|
|
46
|
+
* @fires execute
|
|
47
|
+
* @param options.value If set, the command will set the attribute on the selected table.
|
|
48
|
+
* If not set, the command will remove the attribute from the selected table.
|
|
49
|
+
* @param options.batch Pass the model batch instance to the command to aggregate changes,
|
|
50
|
+
* for example, to allow a single undo step for multiple executions.
|
|
51
|
+
*/
|
|
52
|
+
execute(options?: TablePropertyCommandExecuteOptions): void;
|
|
53
|
+
/**
|
|
54
|
+
* Returns the attribute value for a table.
|
|
55
|
+
*/
|
|
56
|
+
protected _getValue(table: Element): unknown;
|
|
57
|
+
/**
|
|
58
|
+
* Returns the proper model value. It can be used to add a default unit to numeric values.
|
|
59
|
+
*/
|
|
60
|
+
protected _getValueToSet(value: string | number | undefined): unknown;
|
|
61
|
+
}
|
|
@@ -2,123 +2,79 @@
|
|
|
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
|
-
/**
|
|
7
|
-
* @module table/tableproperties/commands/tablepropertycommand
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
5
|
import { Command } from 'ckeditor5/src/core';
|
|
11
|
-
|
|
12
6
|
/**
|
|
13
7
|
* The table cell attribute command.
|
|
14
8
|
*
|
|
15
9
|
* This command is a base command for other table property commands.
|
|
16
|
-
*
|
|
17
|
-
* @extends module:core/command~Command
|
|
18
10
|
*/
|
|
19
11
|
export default class TablePropertyCommand extends Command {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
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
|
-
|
|
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
|
-
* Returns the attribute value for a table.
|
|
91
|
-
*
|
|
92
|
-
* @param {module:engine/model/element~Element} table
|
|
93
|
-
* @returns {String|undefined}
|
|
94
|
-
* @private
|
|
95
|
-
*/
|
|
96
|
-
_getValue( table ) {
|
|
97
|
-
if ( !table ) {
|
|
98
|
-
return;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
const value = table.getAttribute( this.attributeName );
|
|
102
|
-
|
|
103
|
-
if ( value === this._defaultValue ) {
|
|
104
|
-
return;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
return value;
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
/**
|
|
111
|
-
* Returns the proper model value. It can be used to add a default unit to numeric values.
|
|
112
|
-
*
|
|
113
|
-
* @private
|
|
114
|
-
* @param {*} value
|
|
115
|
-
* @returns {*}
|
|
116
|
-
*/
|
|
117
|
-
_getValueToSet( value ) {
|
|
118
|
-
if ( value === this._defaultValue ) {
|
|
119
|
-
return;
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
return value;
|
|
123
|
-
}
|
|
12
|
+
/**
|
|
13
|
+
* Creates a new `TablePropertyCommand` instance.
|
|
14
|
+
*
|
|
15
|
+
* @param editor An editor in which this command will be used.
|
|
16
|
+
* @param attributeName Table cell attribute name.
|
|
17
|
+
* @param defaultValue The default value of the attribute.
|
|
18
|
+
*/
|
|
19
|
+
constructor(editor, attributeName, defaultValue) {
|
|
20
|
+
super(editor);
|
|
21
|
+
this.attributeName = attributeName;
|
|
22
|
+
this._defaultValue = defaultValue;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* @inheritDoc
|
|
26
|
+
*/
|
|
27
|
+
refresh() {
|
|
28
|
+
const editor = this.editor;
|
|
29
|
+
const selection = editor.model.document.selection;
|
|
30
|
+
const table = selection.getFirstPosition().findAncestor('table');
|
|
31
|
+
this.isEnabled = !!table;
|
|
32
|
+
this.value = this._getValue(table);
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Executes the command.
|
|
36
|
+
*
|
|
37
|
+
* @fires execute
|
|
38
|
+
* @param options.value If set, the command will set the attribute on the selected table.
|
|
39
|
+
* If not set, the command will remove the attribute from the selected table.
|
|
40
|
+
* @param options.batch Pass the model batch instance to the command to aggregate changes,
|
|
41
|
+
* for example, to allow a single undo step for multiple executions.
|
|
42
|
+
*/
|
|
43
|
+
execute(options = {}) {
|
|
44
|
+
const model = this.editor.model;
|
|
45
|
+
const selection = model.document.selection;
|
|
46
|
+
const { value, batch } = options;
|
|
47
|
+
const table = selection.getFirstPosition().findAncestor('table');
|
|
48
|
+
const valueToSet = this._getValueToSet(value);
|
|
49
|
+
model.enqueueChange(batch, writer => {
|
|
50
|
+
if (valueToSet) {
|
|
51
|
+
writer.setAttribute(this.attributeName, valueToSet, table);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
writer.removeAttribute(this.attributeName, table);
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Returns the attribute value for a table.
|
|
60
|
+
*/
|
|
61
|
+
_getValue(table) {
|
|
62
|
+
if (!table) {
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
const value = table.getAttribute(this.attributeName);
|
|
66
|
+
if (value === this._defaultValue) {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
return value;
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Returns the proper model value. It can be used to add a default unit to numeric values.
|
|
73
|
+
*/
|
|
74
|
+
_getValueToSet(value) {
|
|
75
|
+
if (value === this._defaultValue) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
return value;
|
|
79
|
+
}
|
|
124
80
|
}
|
|
@@ -0,0 +1,46 @@
|
|
|
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/tableproperties/commands/tablewidthcommand
|
|
7
|
+
*/
|
|
8
|
+
import TablePropertyCommand from './tablepropertycommand';
|
|
9
|
+
import type { Editor } from 'ckeditor5/src/core';
|
|
10
|
+
/**
|
|
11
|
+
* The table width command.
|
|
12
|
+
*
|
|
13
|
+
* The command is registered by the {@link module:table/tableproperties/tablepropertiesediting~TablePropertiesEditing} as
|
|
14
|
+
* the `'tableWidth'` editor command.
|
|
15
|
+
*
|
|
16
|
+
* To change the width of the selected table, execute the command:
|
|
17
|
+
*
|
|
18
|
+
* ```ts
|
|
19
|
+
* editor.execute( 'tableWidth', {
|
|
20
|
+
* value: '400px'
|
|
21
|
+
* } );
|
|
22
|
+
* ```
|
|
23
|
+
*
|
|
24
|
+
* **Note**: This command adds the default `'px'` unit to numeric values. Executing:
|
|
25
|
+
*
|
|
26
|
+
* ```ts
|
|
27
|
+
* editor.execute( 'tableWidth', {
|
|
28
|
+
* value: '50'
|
|
29
|
+
* } );
|
|
30
|
+
* ```
|
|
31
|
+
*
|
|
32
|
+
* will set the `width` attribute to `'50px'` in the model.
|
|
33
|
+
*/
|
|
34
|
+
export default class TableWidthCommand extends TablePropertyCommand {
|
|
35
|
+
/**
|
|
36
|
+
* Creates a new `TableWidthCommand` instance.
|
|
37
|
+
*
|
|
38
|
+
* @param editor An editor in which this command will be used.
|
|
39
|
+
* @param defaultValue The default value of the attribute.
|
|
40
|
+
*/
|
|
41
|
+
constructor(editor: Editor, defaultValue: string);
|
|
42
|
+
/**
|
|
43
|
+
* @inheritDoc
|
|
44
|
+
*/
|
|
45
|
+
_getValueToSet(value: string | number | undefined): unknown;
|
|
46
|
+
}
|
|
@@ -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/tableproperties/commands/tablewidthcommand
|
|
8
7
|
*/
|
|
9
|
-
|
|
10
8
|
import TablePropertyCommand from './tablepropertycommand';
|
|
11
9
|
import { addDefaultUnitToNumericValue } from '../../utils/table-properties';
|
|
12
|
-
|
|
13
10
|
/**
|
|
14
11
|
* The table width command.
|
|
15
12
|
*
|
|
@@ -18,41 +15,40 @@ import { addDefaultUnitToNumericValue } from '../../utils/table-properties';
|
|
|
18
15
|
*
|
|
19
16
|
* To change the width of the selected table, execute the command:
|
|
20
17
|
*
|
|
21
|
-
*
|
|
22
|
-
*
|
|
23
|
-
*
|
|
18
|
+
* ```ts
|
|
19
|
+
* editor.execute( 'tableWidth', {
|
|
20
|
+
* value: '400px'
|
|
21
|
+
* } );
|
|
22
|
+
* ```
|
|
24
23
|
*
|
|
25
24
|
* **Note**: This command adds the default `'px'` unit to numeric values. Executing:
|
|
26
25
|
*
|
|
27
|
-
*
|
|
28
|
-
*
|
|
29
|
-
*
|
|
26
|
+
* ```ts
|
|
27
|
+
* editor.execute( 'tableWidth', {
|
|
28
|
+
* value: '50'
|
|
29
|
+
* } );
|
|
30
|
+
* ```
|
|
30
31
|
*
|
|
31
32
|
* will set the `width` attribute to `'50px'` in the model.
|
|
32
|
-
*
|
|
33
|
-
* @extends module:table/tableproperties/commands/tablepropertycommand~TablePropertyCommand
|
|
34
33
|
*/
|
|
35
34
|
export default class TableWidthCommand extends TablePropertyCommand {
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
return value;
|
|
57
|
-
}
|
|
35
|
+
/**
|
|
36
|
+
* Creates a new `TableWidthCommand` instance.
|
|
37
|
+
*
|
|
38
|
+
* @param editor An editor in which this command will be used.
|
|
39
|
+
* @param defaultValue The default value of the attribute.
|
|
40
|
+
*/
|
|
41
|
+
constructor(editor, defaultValue) {
|
|
42
|
+
super(editor, 'tableWidth', defaultValue);
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* @inheritDoc
|
|
46
|
+
*/
|
|
47
|
+
_getValueToSet(value) {
|
|
48
|
+
value = addDefaultUnitToNumericValue(value, 'px');
|
|
49
|
+
if (value === this._defaultValue) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
return value;
|
|
53
|
+
}
|
|
58
54
|
}
|
|
@@ -0,0 +1,39 @@
|
|
|
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/tableproperties/tablepropertiesediting
|
|
7
|
+
*/
|
|
8
|
+
import { Plugin, type PluginDependencies } from 'ckeditor5/src/core';
|
|
9
|
+
/**
|
|
10
|
+
* The table properties editing feature.
|
|
11
|
+
*
|
|
12
|
+
* Introduces table's model attributes and their conversion:
|
|
13
|
+
*
|
|
14
|
+
* - border: `tableBorderStyle`, `tableBorderColor` and `tableBorderWidth`
|
|
15
|
+
* - background color: `tableBackgroundColor`
|
|
16
|
+
* - horizontal alignment: `tableAlignment`
|
|
17
|
+
* - width & height: `tableWidth` & `tableHeight`
|
|
18
|
+
*
|
|
19
|
+
* It also registers commands used to manipulate the above attributes:
|
|
20
|
+
*
|
|
21
|
+
* - border: `'tableBorderStyle'`, `'tableBorderColor'` and `'tableBorderWidth'` commands
|
|
22
|
+
* - background color: `'tableBackgroundColor'`
|
|
23
|
+
* - horizontal alignment: `'tableAlignment'`
|
|
24
|
+
* - width & height: `'tableWidth'` & `'tableHeight'`
|
|
25
|
+
*/
|
|
26
|
+
export default class TablePropertiesEditing extends Plugin {
|
|
27
|
+
/**
|
|
28
|
+
* @inheritDoc
|
|
29
|
+
*/
|
|
30
|
+
static get pluginName(): 'TablePropertiesEditing';
|
|
31
|
+
/**
|
|
32
|
+
* @inheritDoc
|
|
33
|
+
*/
|
|
34
|
+
static get requires(): PluginDependencies;
|
|
35
|
+
/**
|
|
36
|
+
* @inheritDoc
|
|
37
|
+
*/
|
|
38
|
+
init(): void;
|
|
39
|
+
}
|