@ckeditor/ckeditor5-table 36.0.1 → 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.
Files changed (166) hide show
  1. package/build/table.js +1 -1
  2. package/package.json +34 -29
  3. package/src/commands/insertcolumncommand.d.ts +61 -0
  4. package/src/commands/insertcolumncommand.js +45 -60
  5. package/src/commands/insertrowcommand.d.ts +60 -0
  6. package/src/commands/insertrowcommand.js +44 -59
  7. package/src/commands/inserttablecommand.d.ts +50 -0
  8. package/src/commands/inserttablecommand.js +51 -68
  9. package/src/commands/mergecellcommand.d.ts +76 -0
  10. package/src/commands/mergecellcommand.js +169 -244
  11. package/src/commands/mergecellscommand.d.ts +33 -0
  12. package/src/commands/mergecellscommand.js +72 -101
  13. package/src/commands/removecolumncommand.d.ts +34 -0
  14. package/src/commands/removecolumncommand.js +88 -102
  15. package/src/commands/removerowcommand.d.ts +34 -0
  16. package/src/commands/removerowcommand.js +63 -80
  17. package/src/commands/selectcolumncommand.d.ts +38 -0
  18. package/src/commands/selectcolumncommand.js +41 -54
  19. package/src/commands/selectrowcommand.d.ts +38 -0
  20. package/src/commands/selectrowcommand.js +38 -48
  21. package/src/commands/setheadercolumncommand.d.ts +55 -0
  22. package/src/commands/setheadercolumncommand.js +48 -73
  23. package/src/commands/setheaderrowcommand.d.ts +58 -0
  24. package/src/commands/setheaderrowcommand.js +56 -85
  25. package/src/commands/splitcellcommand.d.ts +49 -0
  26. package/src/commands/splitcellcommand.js +35 -49
  27. package/src/converters/downcast.d.ts +63 -0
  28. package/src/converters/downcast.js +98 -130
  29. package/src/converters/table-caption-post-fixer.d.ts +20 -0
  30. package/src/converters/table-caption-post-fixer.js +36 -52
  31. package/src/converters/table-cell-paragraph-post-fixer.d.ts +32 -0
  32. package/src/converters/table-cell-paragraph-post-fixer.js +88 -119
  33. package/src/converters/table-cell-refresh-handler.d.ts +18 -0
  34. package/src/converters/table-cell-refresh-handler.js +29 -48
  35. package/src/converters/table-headings-refresh-handler.d.ts +17 -0
  36. package/src/converters/table-headings-refresh-handler.js +35 -54
  37. package/src/converters/table-layout-post-fixer.d.ts +226 -0
  38. package/src/converters/table-layout-post-fixer.js +276 -313
  39. package/src/converters/tableproperties.d.ts +54 -0
  40. package/src/converters/tableproperties.js +136 -168
  41. package/src/converters/upcasttable.d.ts +49 -0
  42. package/src/converters/upcasttable.js +196 -251
  43. package/src/index.d.ts +29 -0
  44. package/src/index.js +0 -2
  45. package/src/plaintableoutput.d.ts +30 -0
  46. package/src/plaintableoutput.js +107 -135
  47. package/src/table.d.ts +38 -0
  48. package/src/table.js +12 -88
  49. package/src/tablecaption/tablecaptionediting.d.ts +68 -0
  50. package/src/tablecaption/tablecaptionediting.js +104 -135
  51. package/src/tablecaption/tablecaptionui.d.ts +26 -0
  52. package/src/tablecaption/tablecaptionui.js +42 -58
  53. package/src/tablecaption/toggletablecaptioncommand.d.ts +73 -0
  54. package/src/tablecaption/toggletablecaptioncommand.js +77 -92
  55. package/src/tablecaption/utils.d.ts +42 -0
  56. package/src/tablecaption/utils.js +35 -61
  57. package/src/tablecaption.d.ts +27 -0
  58. package/src/tablecaption.js +12 -19
  59. package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.d.ts +37 -0
  60. package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.js +14 -20
  61. package/src/tablecellproperties/commands/tablecellbordercolorcommand.d.ts +42 -0
  62. package/src/tablecellproperties/commands/tablecellbordercolorcommand.js +27 -37
  63. package/src/tablecellproperties/commands/tablecellborderstylecommand.d.ts +42 -0
  64. package/src/tablecellproperties/commands/tablecellborderstylecommand.js +27 -37
  65. package/src/tablecellproperties/commands/tablecellborderwidthcommand.d.ts +56 -0
  66. package/src/tablecellproperties/commands/tablecellborderwidthcommand.js +42 -53
  67. package/src/tablecellproperties/commands/tablecellheightcommand.d.ts +51 -0
  68. package/src/tablecellproperties/commands/tablecellheightcommand.js +29 -36
  69. package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.d.ts +37 -0
  70. package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.js +14 -20
  71. package/src/tablecellproperties/commands/tablecellpaddingcommand.d.ts +56 -0
  72. package/src/tablecellproperties/commands/tablecellpaddingcommand.js +42 -53
  73. package/src/tablecellproperties/commands/tablecellpropertycommand.d.ts +62 -0
  74. package/src/tablecellproperties/commands/tablecellpropertycommand.js +77 -122
  75. package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.d.ts +45 -0
  76. package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.js +14 -20
  77. package/src/tablecellproperties/tablecellpropertiesediting.d.ts +47 -0
  78. package/src/tablecellproperties/tablecellpropertiesediting.js +194 -236
  79. package/src/tablecellproperties/tablecellpropertiesui.d.ts +117 -0
  80. package/src/tablecellproperties/tablecellpropertiesui.js +303 -456
  81. package/src/tablecellproperties/ui/tablecellpropertiesview.d.ts +227 -0
  82. package/src/tablecellproperties/ui/tablecellpropertiesview.js +509 -844
  83. package/src/tablecellproperties.d.ts +33 -0
  84. package/src/tablecellproperties.js +12 -98
  85. package/src/tablecellwidth/commands/tablecellwidthcommand.d.ts +51 -0
  86. package/src/tablecellwidth/commands/tablecellwidthcommand.js +29 -35
  87. package/src/tablecellwidth/tablecellwidthediting.d.ts +34 -0
  88. package/src/tablecellwidth/tablecellwidthediting.js +26 -38
  89. package/src/tableclipboard.d.ts +68 -0
  90. package/src/tableclipboard.js +429 -568
  91. package/src/tablecolumnresize/constants.d.ts +20 -0
  92. package/src/tablecolumnresize/constants.js +0 -10
  93. package/src/tablecolumnresize/converters.d.ts +18 -0
  94. package/src/tablecolumnresize/converters.js +35 -119
  95. package/src/tablecolumnresize/tablecolumnresizeediting.d.ts +142 -0
  96. package/src/tablecolumnresize/tablecolumnresizeediting.js +545 -711
  97. package/src/tablecolumnresize/tablewidthscommand.d.ts +38 -0
  98. package/src/tablecolumnresize/tablewidthscommand.js +61 -0
  99. package/src/tablecolumnresize/utils.d.ts +141 -0
  100. package/src/tablecolumnresize/utils.js +256 -233
  101. package/src/tablecolumnresize.d.ts +29 -0
  102. package/src/tablecolumnresize.js +12 -19
  103. package/src/tableconfig.d.ts +341 -0
  104. package/src/tableconfig.js +5 -0
  105. package/src/tableediting.d.ts +102 -0
  106. package/src/tableediting.js +157 -176
  107. package/src/tablekeyboard.d.ts +68 -0
  108. package/src/tablekeyboard.js +261 -344
  109. package/src/tablemouse/mouseeventsobserver.d.ts +62 -0
  110. package/src/tablemouse/mouseeventsobserver.js +12 -49
  111. package/src/tablemouse.d.ts +51 -0
  112. package/src/tablemouse.js +154 -202
  113. package/src/tableproperties/commands/tablealignmentcommand.d.ts +37 -0
  114. package/src/tableproperties/commands/tablealignmentcommand.js +14 -20
  115. package/src/tableproperties/commands/tablebackgroundcolorcommand.d.ts +37 -0
  116. package/src/tableproperties/commands/tablebackgroundcolorcommand.js +14 -20
  117. package/src/tableproperties/commands/tablebordercolorcommand.d.ts +42 -0
  118. package/src/tableproperties/commands/tablebordercolorcommand.js +27 -37
  119. package/src/tableproperties/commands/tableborderstylecommand.d.ts +42 -0
  120. package/src/tableproperties/commands/tableborderstylecommand.js +27 -37
  121. package/src/tableproperties/commands/tableborderwidthcommand.d.ts +56 -0
  122. package/src/tableproperties/commands/tableborderwidthcommand.js +42 -53
  123. package/src/tableproperties/commands/tableheightcommand.d.ts +51 -0
  124. package/src/tableproperties/commands/tableheightcommand.js +29 -33
  125. package/src/tableproperties/commands/tablepropertycommand.d.ts +61 -0
  126. package/src/tableproperties/commands/tablepropertycommand.js +68 -112
  127. package/src/tableproperties/commands/tablewidthcommand.d.ts +51 -0
  128. package/src/tableproperties/commands/tablewidthcommand.js +29 -33
  129. package/src/tableproperties/tablepropertiesediting.d.ts +45 -0
  130. package/src/tableproperties/tablepropertiesediting.js +164 -210
  131. package/src/tableproperties/tablepropertiesui.d.ts +119 -0
  132. package/src/tableproperties/tablepropertiesui.js +294 -439
  133. package/src/tableproperties/ui/tablepropertiesview.d.ts +203 -0
  134. package/src/tableproperties/ui/tablepropertiesview.js +427 -718
  135. package/src/tableproperties.d.ts +33 -0
  136. package/src/tableproperties.js +12 -95
  137. package/src/tableselection.d.ts +111 -0
  138. package/src/tableselection.js +279 -376
  139. package/src/tabletoolbar.d.ts +37 -0
  140. package/src/tabletoolbar.js +39 -92
  141. package/src/tableui.d.ts +58 -0
  142. package/src/tableui.js +281 -338
  143. package/src/tableutils.d.ts +453 -0
  144. package/src/tableutils.js +1015 -1229
  145. package/src/tablewalker.d.ts +323 -0
  146. package/src/tablewalker.js +308 -548
  147. package/src/ui/colorinputview.d.ts +143 -0
  148. package/src/ui/colorinputview.js +229 -366
  149. package/src/ui/formrowview.d.ts +61 -0
  150. package/src/ui/formrowview.js +38 -84
  151. package/src/ui/inserttableview.d.ts +77 -0
  152. package/src/ui/inserttableview.js +152 -242
  153. package/src/utils/common.d.ts +42 -0
  154. package/src/utils/common.js +33 -57
  155. package/src/utils/structure.d.ts +245 -0
  156. package/src/utils/structure.js +261 -379
  157. package/src/utils/table-properties.d.ts +67 -0
  158. package/src/utils/table-properties.js +60 -81
  159. package/src/utils/ui/contextualballoon.d.ts +34 -0
  160. package/src/utils/ui/contextualballoon.js +70 -89
  161. package/src/utils/ui/table-properties.d.ts +193 -0
  162. package/src/utils/ui/table-properties.js +259 -319
  163. package/src/utils/ui/widget.d.ts +16 -0
  164. package/src/utils/ui/widget.js +24 -46
  165. package/src/tablecolumnresize/tablecolumnwidthscommand.js +0 -55
  166. package/src/tablecolumnresize/tablewidthresizecommand.js +0 -65
@@ -2,14 +2,8 @@
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/tablecellproperties/commands/tablecellpaddingcommand
8
- */
9
-
10
5
  import TableCellPropertyCommand from './tablecellpropertycommand';
11
6
  import { addDefaultUnitToNumericValue, getSingleValue } from '../../utils/table-properties';
12
-
13
7
  /**
14
8
  * The table cell padding command.
15
9
  *
@@ -18,58 +12,53 @@ import { addDefaultUnitToNumericValue, getSingleValue } from '../../utils/table-
18
12
  *
19
13
  * To change the padding of selected cells, execute the command:
20
14
  *
21
- * editor.execute( 'tableCellPadding', {
22
- * value: '5px'
23
- * } );
15
+ * ```ts
16
+ * editor.execute( 'tableCellPadding', {
17
+ * value: '5px'
18
+ * } );
19
+ * ```
24
20
  *
25
21
  * **Note**: This command adds the default `'px'` unit to numeric values. Executing:
26
22
  *
27
- * editor.execute( 'tableCellPadding', {
28
- * value: '5'
29
- * } );
23
+ * ```ts
24
+ * editor.execute( 'tableCellPadding', {
25
+ * value: '5'
26
+ * } );
27
+ * ```
30
28
  *
31
29
  * will set the `padding` attribute to `'5px'` in the model.
32
- *
33
- * @extends module:table/tablecellproperties/commands/tablecellpropertycommand~TableCellPropertyCommand
34
30
  */
35
31
  export default class TableCellPaddingCommand extends TableCellPropertyCommand {
36
- /**
37
- * Creates a new `TableCellPaddingCommand` instance.
38
- *
39
- * @param {module:core/editor/editor~Editor} editor An editor in which this command will be used.
40
- * @param {String} defaultValue The default value of the attribute.
41
- */
42
- constructor( editor, defaultValue ) {
43
- super( editor, 'tableCellPadding', defaultValue );
44
- }
45
-
46
- /**
47
- * @inheritDoc
48
- */
49
- _getAttribute( tableCell ) {
50
- if ( !tableCell ) {
51
- return;
52
- }
53
-
54
- const value = getSingleValue( tableCell.getAttribute( this.attributeName ) );
55
-
56
- if ( value === this._defaultValue ) {
57
- return;
58
- }
59
-
60
- return value;
61
- }
62
-
63
- /**
64
- * @inheritDoc
65
- */
66
- _getValueToSet( value ) {
67
- value = addDefaultUnitToNumericValue( value, 'px' );
68
-
69
- if ( value === this._defaultValue ) {
70
- return;
71
- }
72
-
73
- return value;
74
- }
32
+ /**
33
+ * Creates a new `TableCellPaddingCommand` instance.
34
+ *
35
+ * @param editor An editor in which this command will be used.
36
+ * @param defaultValue The default value of the attribute.
37
+ */
38
+ constructor(editor, defaultValue) {
39
+ super(editor, 'tableCellPadding', defaultValue);
40
+ }
41
+ /**
42
+ * @inheritDoc
43
+ */
44
+ _getAttribute(tableCell) {
45
+ if (!tableCell) {
46
+ return;
47
+ }
48
+ const value = getSingleValue(tableCell.getAttribute(this.attributeName));
49
+ if (value === this._defaultValue) {
50
+ return;
51
+ }
52
+ return value;
53
+ }
54
+ /**
55
+ * @inheritDoc
56
+ */
57
+ _getValueToSet(value) {
58
+ const newValue = addDefaultUnitToNumericValue(value, 'px');
59
+ if (newValue === this._defaultValue) {
60
+ return;
61
+ }
62
+ return newValue;
63
+ }
75
64
  }
@@ -0,0 +1,62 @@
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/commands/tablecellpropertycommand
7
+ */
8
+ import { Command, type Editor } from 'ckeditor5/src/core';
9
+ import type { Element, Batch } from 'ckeditor5/src/engine';
10
+ /**
11
+ * The table cell attribute command.
12
+ *
13
+ * The command is a base command for other table cell property commands.
14
+ */
15
+ export default class TableCellPropertyCommand extends Command {
16
+ /**
17
+ * The attribute that will be set by the command.
18
+ */
19
+ readonly attributeName: string;
20
+ /**
21
+ * The default value for the attribute.
22
+ */
23
+ protected readonly _defaultValue: string;
24
+ /**
25
+ * Creates a new `TableCellPropertyCommand` instance.
26
+ *
27
+ * @param editor An editor in which this command will be used.
28
+ * @param attributeName Table cell attribute name.
29
+ * @param defaultValue The default value of the attribute.
30
+ */
31
+ constructor(editor: Editor, attributeName: string, defaultValue: string);
32
+ /**
33
+ * @inheritDoc
34
+ */
35
+ refresh(): void;
36
+ /**
37
+ * Executes the command.
38
+ *
39
+ * @fires execute
40
+ * @param options.value If set, the command will set the attribute on selected table cells.
41
+ * If it is not set, the command will remove the attribute from the selected table cells.
42
+ * @param options.batch Pass the model batch instance to the command to aggregate changes,
43
+ * for example to allow a single undo step for multiple executions.
44
+ */
45
+ execute(options?: {
46
+ value?: string | number;
47
+ batch?: Batch;
48
+ }): void;
49
+ /**
50
+ * Returns the attribute value for a table cell.
51
+ */
52
+ protected _getAttribute(tableCell: Element | undefined): unknown;
53
+ /**
54
+ * Returns the proper model value. It can be used to add a default unit to numeric values.
55
+ */
56
+ protected _getValueToSet(value: string | number | undefined): unknown;
57
+ /**
58
+ * Returns a single value for all selected table cells. If the value is the same for all cells,
59
+ * it will be returned (`undefined` otherwise).
60
+ */
61
+ private _getSingleValue;
62
+ }
@@ -2,136 +2,91 @@
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/commands/tablecellpropertycommand
8
7
  */
9
-
10
8
  import { Command } from 'ckeditor5/src/core';
11
-
12
9
  /**
13
10
  * The table cell attribute command.
14
11
  *
15
12
  * The command is a base command for other table cell property commands.
16
- *
17
- * @extends module:core/command~Command
18
13
  */
19
14
  export default class TableCellPropertyCommand extends Command {
20
- /**
21
- * Creates a new `TableCellPropertyCommand` instance.
22
- *
23
- * @param {module:core/editor/editor~Editor} editor An editor in which this command will be used.
24
- * @param {String} attributeName Table cell attribute name.
25
- * @param {String} defaultValue The default value of the attribute.
26
- */
27
- constructor( editor, attributeName, defaultValue ) {
28
- super( editor );
29
-
30
- /**
31
- * The attribute that will be set by the command.
32
- *
33
- * @readonly
34
- * @member {String}
35
- */
36
- this.attributeName = attributeName;
37
-
38
- /**
39
- * The default value for the attribute.
40
- *
41
- * @readonly
42
- * @protected
43
- * @member {String}
44
- */
45
- this._defaultValue = defaultValue;
46
- }
47
-
48
- /**
49
- * @inheritDoc
50
- */
51
- refresh() {
52
- const editor = this.editor;
53
- const tableUtils = this.editor.plugins.get( 'TableUtils' );
54
- const selectedTableCells = tableUtils.getSelectionAffectedTableCells( editor.model.document.selection );
55
-
56
- this.isEnabled = !!selectedTableCells.length;
57
- this.value = this._getSingleValue( selectedTableCells );
58
- }
59
-
60
- /**
61
- * Executes the command.
62
- *
63
- * @fires execute
64
- * @param {Object} [options]
65
- * @param {*} [options.value] If set, the command will set the attribute on selected table cells.
66
- * If it is not set, the command will remove the attribute from the selected table cells.
67
- * @param {module:engine/model/batch~Batch} [options.batch] Pass the model batch instance to the command to aggregate changes,
68
- * for example to allow a single undo step for multiple executions.
69
- */
70
- execute( options = {} ) {
71
- const { value, batch } = options;
72
- const model = this.editor.model;
73
- const tableUtils = this.editor.plugins.get( 'TableUtils' );
74
- const tableCells = tableUtils.getSelectionAffectedTableCells( model.document.selection );
75
- const valueToSet = this._getValueToSet( value );
76
-
77
- model.enqueueChange( batch, writer => {
78
- if ( valueToSet ) {
79
- tableCells.forEach( tableCell => writer.setAttribute( this.attributeName, valueToSet, tableCell ) );
80
- } else {
81
- tableCells.forEach( tableCell => writer.removeAttribute( this.attributeName, tableCell ) );
82
- }
83
- } );
84
- }
85
-
86
- /**
87
- * Returns the attribute value for a table cell.
88
- *
89
- * @param {module:engine/model/element~Element} tableCell
90
- * @returns {String|undefined}
91
- * @private
92
- */
93
- _getAttribute( tableCell ) {
94
- if ( !tableCell ) {
95
- return;
96
- }
97
-
98
- const value = tableCell.getAttribute( this.attributeName );
99
-
100
- if ( value === this._defaultValue ) {
101
- return;
102
- }
103
-
104
- return value;
105
- }
106
-
107
- /**
108
- * Returns the proper model value. It can be used to add a default unit to numeric values.
109
- *
110
- * @private
111
- * @param {*} value
112
- * @returns {*}
113
- */
114
- _getValueToSet( value ) {
115
- if ( value === this._defaultValue ) {
116
- return;
117
- }
118
-
119
- return value;
120
- }
121
-
122
- /**
123
- * Returns a single value for all selected table cells. If the value is the same for all cells,
124
- * it will be returned (`undefined` otherwise).
125
- *
126
- * @param {Array.<module:engine/model/element~Element>} tableCell
127
- * @returns {*}
128
- * @private
129
- */
130
- _getSingleValue( tableCell ) {
131
- const firstCellValue = this._getAttribute( tableCell[ 0 ] );
132
-
133
- const everyCellHasAttribute = tableCell.every( tableCell => this._getAttribute( tableCell ) === firstCellValue );
134
-
135
- return everyCellHasAttribute ? firstCellValue : undefined;
136
- }
15
+ /**
16
+ * Creates a new `TableCellPropertyCommand` instance.
17
+ *
18
+ * @param editor An editor in which this command will be used.
19
+ * @param attributeName Table cell attribute name.
20
+ * @param defaultValue The default value of the attribute.
21
+ */
22
+ constructor(editor, attributeName, defaultValue) {
23
+ super(editor);
24
+ this.attributeName = attributeName;
25
+ this._defaultValue = defaultValue;
26
+ }
27
+ /**
28
+ * @inheritDoc
29
+ */
30
+ refresh() {
31
+ const editor = this.editor;
32
+ const tableUtils = this.editor.plugins.get('TableUtils');
33
+ const selectedTableCells = tableUtils.getSelectionAffectedTableCells(editor.model.document.selection);
34
+ this.isEnabled = !!selectedTableCells.length;
35
+ this.value = this._getSingleValue(selectedTableCells);
36
+ }
37
+ /**
38
+ * Executes the command.
39
+ *
40
+ * @fires execute
41
+ * @param options.value If set, the command will set the attribute on selected table cells.
42
+ * If it is not set, the command will remove the attribute from the selected table cells.
43
+ * @param options.batch Pass the model batch instance to the command to aggregate changes,
44
+ * for example to allow a single undo step for multiple executions.
45
+ */
46
+ execute(options = {}) {
47
+ const { value, batch } = options;
48
+ const model = this.editor.model;
49
+ const tableUtils = this.editor.plugins.get('TableUtils');
50
+ const tableCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
51
+ const valueToSet = this._getValueToSet(value);
52
+ model.enqueueChange(batch, writer => {
53
+ if (valueToSet) {
54
+ tableCells.forEach(tableCell => writer.setAttribute(this.attributeName, valueToSet, tableCell));
55
+ }
56
+ else {
57
+ tableCells.forEach(tableCell => writer.removeAttribute(this.attributeName, tableCell));
58
+ }
59
+ });
60
+ }
61
+ /**
62
+ * Returns the attribute value for a table cell.
63
+ */
64
+ _getAttribute(tableCell) {
65
+ if (!tableCell) {
66
+ return;
67
+ }
68
+ const value = tableCell.getAttribute(this.attributeName);
69
+ if (value === this._defaultValue) {
70
+ return;
71
+ }
72
+ return value;
73
+ }
74
+ /**
75
+ * Returns the proper model value. It can be used to add a default unit to numeric values.
76
+ */
77
+ _getValueToSet(value) {
78
+ if (value === this._defaultValue) {
79
+ return;
80
+ }
81
+ return value;
82
+ }
83
+ /**
84
+ * Returns a single value for all selected table cells. If the value is the same for all cells,
85
+ * it will be returned (`undefined` otherwise).
86
+ */
87
+ _getSingleValue(tableCells) {
88
+ const firstCellValue = this._getAttribute(tableCells[0]);
89
+ const everyCellHasAttribute = tableCells.every(tableCells => this._getAttribute(tableCells) === firstCellValue);
90
+ return everyCellHasAttribute ? firstCellValue : undefined;
91
+ }
137
92
  }
@@ -0,0 +1,45 @@
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/commands/tablecellverticalalignmentcommand
7
+ */
8
+ import type { Editor } from 'ckeditor5/src/core';
9
+ import TableCellPropertyCommand from './tablecellpropertycommand';
10
+ /**
11
+ * The table cell vertical alignment command.
12
+ *
13
+ * The command is registered by the {@link module:table/tablecellproperties/tablecellpropertiesediting~TableCellPropertiesEditing} as
14
+ * the `'tableCellVerticalAlignment'` editor command.
15
+ *
16
+ * To change the vertical text alignment of selected cells, execute the command:
17
+ *
18
+ * ```ts
19
+ * editor.execute( 'tableCellVerticalAlignment', {
20
+ * value: 'top'
21
+ * } );
22
+ * ```
23
+ *
24
+ * The following values, corresponding to the
25
+ * [`vertical-align` CSS attribute](https://developer.mozilla.org/en-US/docs/Web/CSS/vertical-align), are allowed:
26
+ *
27
+ * * `'top'`
28
+ * * `'bottom'`
29
+ *
30
+ * The `'middle'` value is the default one so there is no need to set it.
31
+ */
32
+ export default class TableCellVerticalAlignmentCommand extends TableCellPropertyCommand {
33
+ /**
34
+ * Creates a new `TableCellVerticalAlignmentCommand` instance.
35
+ *
36
+ * @param editor An editor in which this command will be used.
37
+ * @param defaultValue The default value for the "alignment" attribute.
38
+ */
39
+ constructor(editor: Editor, defaultValue: string);
40
+ }
41
+ declare module '@ckeditor/ckeditor5-core' {
42
+ interface CommandsMap {
43
+ tableCellVerticalAlignment: TableCellVerticalAlignmentCommand;
44
+ }
45
+ }
@@ -2,13 +2,7 @@
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/tablecellproperties/commands/tablecellverticalalignmentcommand
8
- */
9
-
10
5
  import TableCellPropertyCommand from './tablecellpropertycommand';
11
-
12
6
  /**
13
7
  * The table cell vertical alignment command.
14
8
  *
@@ -17,9 +11,11 @@ import TableCellPropertyCommand from './tablecellpropertycommand';
17
11
  *
18
12
  * To change the vertical text alignment of selected cells, execute the command:
19
13
  *
20
- * editor.execute( 'tableCellVerticalAlignment', {
21
- * value: 'top'
22
- * } );
14
+ * ```ts
15
+ * editor.execute( 'tableCellVerticalAlignment', {
16
+ * value: 'top'
17
+ * } );
18
+ * ```
23
19
  *
24
20
  * The following values, corresponding to the
25
21
  * [`vertical-align` CSS attribute](https://developer.mozilla.org/en-US/docs/Web/CSS/vertical-align), are allowed:
@@ -28,17 +24,15 @@ import TableCellPropertyCommand from './tablecellpropertycommand';
28
24
  * * `'bottom'`
29
25
  *
30
26
  * The `'middle'` value is the default one so there is no need to set it.
31
- *
32
- * @extends module:table/tablecellproperties/commands/tablecellpropertycommand~TableCellPropertyCommand
33
27
  */
34
28
  export default class TableCellVerticalAlignmentCommand extends TableCellPropertyCommand {
35
- /**
36
- * Creates a new `TableCellVerticalAlignmentCommand` instance.
37
- *
38
- * @param {module:core/editor/editor~Editor} editor An editor in which this command will be used.
39
- * @param {String} defaultValue The default value for the "alignment" attribute.
40
- */
41
- constructor( editor, defaultValue ) {
42
- super( editor, 'tableCellVerticalAlignment', defaultValue );
43
- }
29
+ /**
30
+ * Creates a new `TableCellVerticalAlignmentCommand` instance.
31
+ *
32
+ * @param editor An editor in which this command will be used.
33
+ * @param defaultValue The default value for the "alignment" attribute.
34
+ */
35
+ constructor(editor, defaultValue) {
36
+ super(editor, 'tableCellVerticalAlignment', defaultValue);
37
+ }
44
38
  }
@@ -0,0 +1,47 @@
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/tablecellpropertiesediting
7
+ */
8
+ import { Plugin, type PluginDependencies } from 'ckeditor5/src/core';
9
+ import '../tableconfig';
10
+ /**
11
+ * The table cell properties editing feature.
12
+ *
13
+ * Introduces table cell model attributes and their conversion:
14
+ *
15
+ * - border: `tableCellBorderStyle`, `tableCellBorderColor` and `tableCellBorderWidth`
16
+ * - background color: `tableCellBackgroundColor`
17
+ * - cell padding: `tableCellPadding`
18
+ * - horizontal and vertical alignment: `tableCellHorizontalAlignment`, `tableCellVerticalAlignment`
19
+ * - cell width and height: `tableCellWidth`, `tableCellHeight`
20
+ *
21
+ * It also registers commands used to manipulate the above attributes:
22
+ *
23
+ * - border: the `'tableCellBorderStyle'`, `'tableCellBorderColor'` and `'tableCellBorderWidth'` commands
24
+ * - background color: the `'tableCellBackgroundColor'` command
25
+ * - cell padding: the `'tableCellPadding'` command
26
+ * - horizontal and vertical alignment: the `'tableCellHorizontalAlignment'` and `'tableCellVerticalAlignment'` commands
27
+ * - width and height: the `'tableCellWidth'` and `'tableCellHeight'` commands
28
+ */
29
+ export default class TableCellPropertiesEditing extends Plugin {
30
+ /**
31
+ * @inheritDoc
32
+ */
33
+ static get pluginName(): 'TableCellPropertiesEditing';
34
+ /**
35
+ * @inheritDoc
36
+ */
37
+ static get requires(): PluginDependencies;
38
+ /**
39
+ * @inheritDoc
40
+ */
41
+ init(): void;
42
+ }
43
+ declare module '@ckeditor/ckeditor5-core' {
44
+ interface PluginsMap {
45
+ [TableCellPropertiesEditing.pluginName]: TableCellPropertiesEditing;
46
+ }
47
+ }