@ckeditor/ckeditor5-table 40.0.0 → 40.2.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/CHANGELOG.md +15 -15
- package/LICENSE.md +3 -3
- package/build/table.js +1 -1
- package/build/translations/fi.js +1 -1
- package/lang/translations/fi.po +3 -3
- package/package.json +2 -2
- package/src/augmentation.d.ts +76 -76
- package/src/augmentation.js +5 -5
- package/src/commands/insertcolumncommand.d.ts +55 -55
- package/src/commands/insertcolumncommand.js +67 -67
- package/src/commands/insertrowcommand.d.ts +54 -54
- package/src/commands/insertrowcommand.js +66 -66
- package/src/commands/inserttablecommand.d.ts +44 -44
- package/src/commands/inserttablecommand.js +69 -69
- package/src/commands/mergecellcommand.d.ts +68 -68
- package/src/commands/mergecellcommand.js +198 -198
- package/src/commands/mergecellscommand.d.ts +28 -28
- package/src/commands/mergecellscommand.js +94 -94
- package/src/commands/removecolumncommand.d.ts +29 -29
- package/src/commands/removecolumncommand.js +109 -109
- package/src/commands/removerowcommand.d.ts +29 -29
- package/src/commands/removerowcommand.js +82 -82
- package/src/commands/selectcolumncommand.d.ts +33 -33
- package/src/commands/selectcolumncommand.js +60 -60
- package/src/commands/selectrowcommand.d.ts +33 -33
- package/src/commands/selectrowcommand.js +56 -56
- package/src/commands/setheadercolumncommand.d.ts +50 -50
- package/src/commands/setheadercolumncommand.js +71 -71
- package/src/commands/setheaderrowcommand.d.ts +53 -53
- package/src/commands/setheaderrowcommand.js +79 -79
- package/src/commands/splitcellcommand.d.ts +43 -43
- package/src/commands/splitcellcommand.js +54 -54
- package/src/converters/downcast.d.ts +63 -63
- package/src/converters/downcast.js +146 -146
- package/src/converters/table-caption-post-fixer.d.ts +20 -20
- package/src/converters/table-caption-post-fixer.js +53 -53
- package/src/converters/table-cell-paragraph-post-fixer.d.ts +32 -32
- package/src/converters/table-cell-paragraph-post-fixer.js +107 -107
- package/src/converters/table-cell-refresh-handler.d.ts +18 -18
- package/src/converters/table-cell-refresh-handler.js +45 -45
- package/src/converters/table-headings-refresh-handler.d.ts +17 -17
- package/src/converters/table-headings-refresh-handler.js +49 -49
- package/src/converters/table-layout-post-fixer.d.ts +226 -226
- package/src/converters/table-layout-post-fixer.js +367 -367
- package/src/converters/tableproperties.d.ts +54 -54
- package/src/converters/tableproperties.js +159 -159
- package/src/converters/upcasttable.d.ts +49 -49
- package/src/converters/upcasttable.js +243 -243
- package/src/index.d.ts +60 -60
- package/src/index.js +30 -30
- package/src/plaintableoutput.d.ts +26 -26
- package/src/plaintableoutput.js +123 -123
- package/src/table.d.ts +40 -40
- package/src/table.js +44 -44
- package/src/tablecaption/tablecaptionediting.d.ts +63 -63
- package/src/tablecaption/tablecaptionediting.js +122 -122
- package/src/tablecaption/tablecaptionui.d.ts +21 -21
- package/src/tablecaption/tablecaptionui.js +57 -57
- package/src/tablecaption/toggletablecaptioncommand.d.ts +68 -68
- package/src/tablecaption/toggletablecaptioncommand.js +105 -104
- package/src/tablecaption/utils.d.ts +38 -42
- package/src/tablecaption/utils.js +57 -67
- package/src/tablecaption.d.ts +24 -24
- package/src/tablecaption.js +28 -28
- package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.d.ts +32 -32
- package/src/tablecellproperties/commands/tablecellbackgroundcolorcommand.js +30 -30
- package/src/tablecellproperties/commands/tablecellbordercolorcommand.d.ts +37 -37
- package/src/tablecellproperties/commands/tablecellbordercolorcommand.js +44 -44
- package/src/tablecellproperties/commands/tablecellborderstylecommand.d.ts +37 -37
- package/src/tablecellproperties/commands/tablecellborderstylecommand.js +44 -44
- package/src/tablecellproperties/commands/tablecellborderwidthcommand.d.ts +51 -51
- package/src/tablecellproperties/commands/tablecellborderwidthcommand.js +64 -64
- package/src/tablecellproperties/commands/tablecellheightcommand.d.ts +46 -46
- package/src/tablecellproperties/commands/tablecellheightcommand.js +51 -51
- package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.d.ts +32 -32
- package/src/tablecellproperties/commands/tablecellhorizontalalignmentcommand.js +30 -30
- package/src/tablecellproperties/commands/tablecellpaddingcommand.d.ts +51 -51
- package/src/tablecellproperties/commands/tablecellpaddingcommand.js +64 -64
- package/src/tablecellproperties/commands/tablecellpropertycommand.d.ts +62 -62
- package/src/tablecellproperties/commands/tablecellpropertycommand.js +92 -92
- package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.d.ts +40 -40
- package/src/tablecellproperties/commands/tablecellverticalalignmentcommand.js +38 -38
- package/src/tablecellproperties/tablecellpropertiesediting.d.ts +43 -43
- package/src/tablecellproperties/tablecellpropertiesediting.js +241 -241
- package/src/tablecellproperties/tablecellpropertiesui.d.ts +112 -112
- package/src/tablecellproperties/tablecellpropertiesui.js +330 -330
- package/src/tablecellproperties/ui/tablecellpropertiesview.d.ts +228 -228
- package/src/tablecellproperties/ui/tablecellpropertiesview.js +548 -548
- package/src/tablecellproperties.d.ts +30 -30
- package/src/tablecellproperties.js +34 -34
- package/src/tablecellwidth/commands/tablecellwidthcommand.d.ts +46 -46
- package/src/tablecellwidth/commands/tablecellwidthcommand.js +51 -51
- package/src/tablecellwidth/tablecellwidthediting.d.ts +29 -29
- package/src/tablecellwidth/tablecellwidthediting.js +45 -45
- package/src/tableclipboard.d.ts +65 -65
- package/src/tableclipboard.js +450 -450
- package/src/tablecolumnresize/constants.d.ts +20 -20
- package/src/tablecolumnresize/constants.js +20 -20
- package/src/tablecolumnresize/converters.d.ts +18 -18
- package/src/tablecolumnresize/converters.js +46 -46
- package/src/tablecolumnresize/tablecolumnresizeediting.d.ts +139 -139
- package/src/tablecolumnresize/tablecolumnresizeediting.js +583 -583
- package/src/tablecolumnresize/tablewidthscommand.d.ts +38 -38
- package/src/tablecolumnresize/tablewidthscommand.js +61 -61
- package/src/tablecolumnresize/utils.d.ts +148 -148
- package/src/tablecolumnresize/utils.js +358 -358
- package/src/tablecolumnresize.d.ts +26 -26
- package/src/tablecolumnresize.js +30 -30
- package/src/tableconfig.d.ts +343 -343
- package/src/tableconfig.js +5 -5
- package/src/tableediting.d.ts +98 -98
- package/src/tableediting.js +191 -191
- package/src/tablekeyboard.d.ts +68 -68
- package/src/tablekeyboard.js +279 -279
- package/src/tablemouse/mouseeventsobserver.d.ts +62 -62
- package/src/tablemouse/mouseeventsobserver.js +35 -35
- package/src/tablemouse.d.ts +48 -48
- package/src/tablemouse.js +172 -172
- package/src/tableproperties/commands/tablealignmentcommand.d.ts +32 -32
- package/src/tableproperties/commands/tablealignmentcommand.js +30 -30
- package/src/tableproperties/commands/tablebackgroundcolorcommand.d.ts +32 -32
- package/src/tableproperties/commands/tablebackgroundcolorcommand.js +30 -30
- package/src/tableproperties/commands/tablebordercolorcommand.d.ts +37 -37
- package/src/tableproperties/commands/tablebordercolorcommand.js +44 -44
- package/src/tableproperties/commands/tableborderstylecommand.d.ts +37 -37
- package/src/tableproperties/commands/tableborderstylecommand.js +44 -44
- package/src/tableproperties/commands/tableborderwidthcommand.d.ts +51 -51
- package/src/tableproperties/commands/tableborderwidthcommand.js +64 -64
- package/src/tableproperties/commands/tableheightcommand.d.ts +46 -46
- package/src/tableproperties/commands/tableheightcommand.js +54 -54
- package/src/tableproperties/commands/tablepropertycommand.d.ts +61 -61
- package/src/tableproperties/commands/tablepropertycommand.js +81 -80
- package/src/tableproperties/commands/tablewidthcommand.d.ts +46 -46
- package/src/tableproperties/commands/tablewidthcommand.js +54 -54
- package/src/tableproperties/tablepropertiesediting.d.ts +40 -40
- package/src/tableproperties/tablepropertiesediting.js +206 -206
- package/src/tableproperties/tablepropertiesui.d.ts +114 -114
- package/src/tableproperties/tablepropertiesui.js +321 -321
- package/src/tableproperties/ui/tablepropertiesview.d.ts +207 -207
- package/src/tableproperties/ui/tablepropertiesview.js +466 -466
- package/src/tableproperties.d.ts +30 -30
- package/src/tableproperties.js +34 -34
- package/src/tableselection.d.ts +107 -107
- package/src/tableselection.js +297 -297
- package/src/tabletoolbar.d.ts +32 -32
- package/src/tabletoolbar.js +57 -57
- package/src/tableui.d.ts +53 -53
- package/src/tableui.js +309 -309
- package/src/tableutils.d.ts +448 -448
- package/src/tableutils.js +1055 -1055
- package/src/tablewalker.d.ts +362 -362
- package/src/tablewalker.js +393 -393
- package/src/ui/colorinputview.d.ts +140 -140
- package/src/ui/colorinputview.js +271 -271
- package/src/ui/formrowview.d.ts +61 -61
- package/src/ui/formrowview.js +57 -57
- package/src/ui/inserttableview.d.ts +77 -77
- package/src/ui/inserttableview.js +169 -169
- package/src/utils/common.d.ts +46 -42
- package/src/utils/common.js +68 -57
- package/src/utils/structure.d.ts +245 -245
- package/src/utils/structure.js +426 -426
- package/src/utils/table-properties.d.ts +67 -67
- package/src/utils/table-properties.js +86 -86
- package/src/utils/ui/contextualballoon.d.ts +34 -34
- package/src/utils/ui/contextualballoon.js +110 -106
- package/src/utils/ui/table-properties.d.ts +195 -195
- package/src/utils/ui/table-properties.js +362 -362
- package/src/utils/ui/widget.d.ts +20 -16
- package/src/utils/ui/widget.js +48 -38
- package/build/table.js.map +0 -1
package/src/utils/structure.d.ts
CHANGED
|
@@ -1,245 +1,245 @@
|
|
|
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/utils/structure
|
|
7
|
-
*/
|
|
8
|
-
import type { Element, Writer } from 'ckeditor5/src/engine';
|
|
9
|
-
import { type TableSlot } from '../tablewalker';
|
|
10
|
-
import type TableUtils from '../tableutils';
|
|
11
|
-
/**
|
|
12
|
-
* Returns a cropped table according to given dimensions.
|
|
13
|
-
|
|
14
|
-
* To return a cropped table that starts at first row and first column and end in third row and column:
|
|
15
|
-
*
|
|
16
|
-
* ```ts
|
|
17
|
-
* const croppedTable = cropTableToDimensions( table, {
|
|
18
|
-
* startRow: 1,
|
|
19
|
-
* endRow: 3,
|
|
20
|
-
* startColumn: 1,
|
|
21
|
-
* endColumn: 3
|
|
22
|
-
* }, writer );
|
|
23
|
-
* ```
|
|
24
|
-
*
|
|
25
|
-
* Calling the code above for the table below:
|
|
26
|
-
*
|
|
27
|
-
* 0 1 2 3 4 0 1 2
|
|
28
|
-
* ┌───┬───┬───┬───┬───┐
|
|
29
|
-
* 0 │ a │ b │ c │ d │ e │
|
|
30
|
-
* ├───┴───┤ ├───┴───┤ ┌───┬───┬───┐
|
|
31
|
-
* 1 │ f │ │ g │ │ │ │ g │ 0
|
|
32
|
-
* ├───┬───┴───┼───┬───┤ will return: ├───┴───┼───┤
|
|
33
|
-
* 2 │ h │ i │ j │ k │ │ i │ j │ 1
|
|
34
|
-
* ├───┤ ├───┤ │ │ ├───┤
|
|
35
|
-
* 3 │ l │ │ m │ │ │ │ m │ 2
|
|
36
|
-
* ├───┼───┬───┤ ├───┤ └───────┴───┘
|
|
37
|
-
* 4 │ n │ o │ p │ │ q │
|
|
38
|
-
* └───┴───┴───┴───┴───┘
|
|
39
|
-
*/
|
|
40
|
-
export declare function cropTableToDimensions(sourceTable: Element, cropDimensions: {
|
|
41
|
-
startRow: number;
|
|
42
|
-
startColumn: number;
|
|
43
|
-
endRow: number;
|
|
44
|
-
endColumn: number;
|
|
45
|
-
}, writer: Writer): Element;
|
|
46
|
-
/**
|
|
47
|
-
* Returns slot info of cells that starts above and overlaps a given row.
|
|
48
|
-
*
|
|
49
|
-
* In a table below, passing `overlapRow = 3`
|
|
50
|
-
*
|
|
51
|
-
* ┌───┬───┬───┬───┬───┐
|
|
52
|
-
* 0 │ a │ b │ c │ d │ e │
|
|
53
|
-
* │ ├───┼───┼───┼───┤
|
|
54
|
-
* 1 │ │ f │ g │ h │ i │
|
|
55
|
-
* ├───┤ ├───┼───┤ │
|
|
56
|
-
* 2 │ j │ │ k │ l │ │
|
|
57
|
-
* │ │ │ ├───┼───┤
|
|
58
|
-
* 3 │ │ │ │ m │ n │ <- overlap row to check
|
|
59
|
-
* ├───┼───┤ │ ├───│
|
|
60
|
-
* 4 │ o │ p │ │ │ q │
|
|
61
|
-
* └───┴───┴───┴───┴───┘
|
|
62
|
-
*
|
|
63
|
-
* will return slot info for cells: "j", "f", "k".
|
|
64
|
-
*
|
|
65
|
-
* @param table The table to check.
|
|
66
|
-
* @param overlapRow The index of the row to check.
|
|
67
|
-
* @param startRow row to start analysis. Use it when it is known that the cells above that row will not overlap. Default value is 0.
|
|
68
|
-
*/
|
|
69
|
-
export declare function getVerticallyOverlappingCells(table: Element, overlapRow: number, startRow?: number): Array<TableSlot>;
|
|
70
|
-
/**
|
|
71
|
-
* Splits the table cell horizontally.
|
|
72
|
-
*
|
|
73
|
-
* @returns Created table cell, if any were created.
|
|
74
|
-
*/
|
|
75
|
-
export declare function splitHorizontally(tableCell: Element, splitRow: number, writer: Writer): Element | null;
|
|
76
|
-
/**
|
|
77
|
-
* Returns slot info of cells that starts before and overlaps a given column.
|
|
78
|
-
*
|
|
79
|
-
* In a table below, passing `overlapColumn = 3`
|
|
80
|
-
*
|
|
81
|
-
* 0 1 2 3 4
|
|
82
|
-
* ┌───────┬───────┬───┐
|
|
83
|
-
* │ a │ b │ c │
|
|
84
|
-
* │───┬───┴───────┼───┤
|
|
85
|
-
* │ d │ e │ f │
|
|
86
|
-
* ├───┼───┬───────┴───┤
|
|
87
|
-
* │ g │ h │ i │
|
|
88
|
-
* ├───┼───┼───┬───────┤
|
|
89
|
-
* │ j │ k │ l │ m │
|
|
90
|
-
* ├───┼───┴───┼───┬───┤
|
|
91
|
-
* │ n │ o │ p │ q │
|
|
92
|
-
* └───┴───────┴───┴───┘
|
|
93
|
-
* ^
|
|
94
|
-
* Overlap column to check
|
|
95
|
-
*
|
|
96
|
-
* will return slot info for cells: "b", "e", "i".
|
|
97
|
-
*
|
|
98
|
-
* @param table The table to check.
|
|
99
|
-
* @param overlapColumn The index of the column to check.
|
|
100
|
-
*/
|
|
101
|
-
export declare function getHorizontallyOverlappingCells(table: Element, overlapColumn: number): Array<TableSlot>;
|
|
102
|
-
/**
|
|
103
|
-
* Splits the table cell vertically.
|
|
104
|
-
*
|
|
105
|
-
* @param columnIndex The table cell column index.
|
|
106
|
-
* @param splitColumn The index of column to split cell on.
|
|
107
|
-
* @returns Created table cell.
|
|
108
|
-
*/
|
|
109
|
-
export declare function splitVertically(tableCell: Element, columnIndex: number, splitColumn: number, writer: Writer): Element;
|
|
110
|
-
/**
|
|
111
|
-
* Adjusts table cell dimensions to not exceed limit row and column.
|
|
112
|
-
*
|
|
113
|
-
* If table cell width (or height) covers a column (or row) that is after a limit column (or row)
|
|
114
|
-
* this method will trim "colspan" (or "rowspan") attribute so the table cell will fit in a defined limits.
|
|
115
|
-
*/
|
|
116
|
-
export declare function trimTableCellIfNeeded(tableCell: Element, cellRow: number, cellColumn: number, limitRow: number, limitColumn: number, writer: Writer): void;
|
|
117
|
-
/**
|
|
118
|
-
* Removes columns that have no cells anchored.
|
|
119
|
-
*
|
|
120
|
-
* In table below:
|
|
121
|
-
*
|
|
122
|
-
* +----+----+----+----+----+----+----+
|
|
123
|
-
* | 00 | 01 | 03 | 04 | 06 |
|
|
124
|
-
* +----+----+----+----+ +----+
|
|
125
|
-
* | 10 | 11 | 13 | | 16 |
|
|
126
|
-
* +----+----+----+----+----+----+----+
|
|
127
|
-
* | 20 | 21 | 23 | 24 | 26 |
|
|
128
|
-
* +----+----+----+----+----+----+----+
|
|
129
|
-
* ^--- empty ---^
|
|
130
|
-
*
|
|
131
|
-
* Will remove columns 2 and 5.
|
|
132
|
-
*
|
|
133
|
-
* **Note:** This is a low-level helper method for clearing invalid model state when doing table modifications.
|
|
134
|
-
* To remove a column from a table use {@link module:table/tableutils~TableUtils#removeColumns `TableUtils.removeColumns()`}.
|
|
135
|
-
*
|
|
136
|
-
* @internal
|
|
137
|
-
* @returns True if removed some columns.
|
|
138
|
-
*/
|
|
139
|
-
export declare function removeEmptyColumns(table: Element, tableUtils: TableUtils): boolean;
|
|
140
|
-
/**
|
|
141
|
-
* Removes rows that have no cells anchored.
|
|
142
|
-
*
|
|
143
|
-
* In table below:
|
|
144
|
-
*
|
|
145
|
-
* +----+----+----+
|
|
146
|
-
* | 00 | 01 | 02 |
|
|
147
|
-
* +----+----+----+
|
|
148
|
-
* | 10 | 11 | 12 |
|
|
149
|
-
* + + + +
|
|
150
|
-
* | | | | <-- empty
|
|
151
|
-
* +----+----+----+
|
|
152
|
-
* | 30 | 31 | 32 |
|
|
153
|
-
* +----+----+----+
|
|
154
|
-
* | 40 | 42 |
|
|
155
|
-
* + + +
|
|
156
|
-
* | | | <-- empty
|
|
157
|
-
* +----+----+----+
|
|
158
|
-
* | 60 | 61 | 62 |
|
|
159
|
-
* +----+----+----+
|
|
160
|
-
*
|
|
161
|
-
* Will remove rows 2 and 5.
|
|
162
|
-
*
|
|
163
|
-
* **Note:** This is a low-level helper method for clearing invalid model state when doing table modifications.
|
|
164
|
-
* To remove a row from a table use {@link module:table/tableutils~TableUtils#removeRows `TableUtils.removeRows()`}.
|
|
165
|
-
*
|
|
166
|
-
* @internal
|
|
167
|
-
* @returns True if removed some rows.
|
|
168
|
-
*/
|
|
169
|
-
export declare function removeEmptyRows(table: Element, tableUtils: TableUtils): boolean;
|
|
170
|
-
/**
|
|
171
|
-
* Removes rows and columns that have no cells anchored.
|
|
172
|
-
*
|
|
173
|
-
* In table below:
|
|
174
|
-
*
|
|
175
|
-
* +----+----+----+----+
|
|
176
|
-
* | 00 | 02 |
|
|
177
|
-
* +----+----+ +
|
|
178
|
-
* | 10 | |
|
|
179
|
-
* +----+----+----+----+
|
|
180
|
-
* | 20 | 22 | 23 |
|
|
181
|
-
* + + + +
|
|
182
|
-
* | | | | <-- empty row
|
|
183
|
-
* +----+----+----+----+
|
|
184
|
-
* ^--- empty column
|
|
185
|
-
*
|
|
186
|
-
* Will remove row 3 and column 1.
|
|
187
|
-
*
|
|
188
|
-
* **Note:** This is a low-level helper method for clearing invalid model state when doing table modifications.
|
|
189
|
-
* To remove a rows from a table use {@link module:table/tableutils~TableUtils#removeRows `TableUtils.removeRows()`} and
|
|
190
|
-
* {@link module:table/tableutils~TableUtils#removeColumns `TableUtils.removeColumns()`} to remove a column.
|
|
191
|
-
*
|
|
192
|
-
* @internal
|
|
193
|
-
*/
|
|
194
|
-
export declare function removeEmptyRowsColumns(table: Element, tableUtils: TableUtils): void;
|
|
195
|
-
/**
|
|
196
|
-
* Returns adjusted last row index if selection covers part of a row with empty slots (spanned by other cells).
|
|
197
|
-
* The `dimensions.lastRow` is equal to last row index but selection might be bigger.
|
|
198
|
-
*
|
|
199
|
-
* This happens *only* on rectangular selection so we analyze a case like this:
|
|
200
|
-
*
|
|
201
|
-
* +---+---+---+---+
|
|
202
|
-
* 0 | a | b | c | d |
|
|
203
|
-
* + + +---+---+
|
|
204
|
-
* 1 | | e | f | g |
|
|
205
|
-
* + +---+ +---+
|
|
206
|
-
* 2 | | h | | i | <- last row, each cell has rowspan = 2,
|
|
207
|
-
* + + + + + so we need to return 3, not 2
|
|
208
|
-
* 3 | | | | |
|
|
209
|
-
* +---+---+---+---+
|
|
210
|
-
*
|
|
211
|
-
* @returns Adjusted last row index.
|
|
212
|
-
*/
|
|
213
|
-
export declare function adjustLastRowIndex(table: Element, dimensions: {
|
|
214
|
-
firstRow: number;
|
|
215
|
-
firstColumn: number;
|
|
216
|
-
lastRow: number;
|
|
217
|
-
lastColumn: number;
|
|
218
|
-
}): number;
|
|
219
|
-
/**
|
|
220
|
-
* Returns adjusted last column index if selection covers part of a column with empty slots (spanned by other cells).
|
|
221
|
-
* The `dimensions.lastColumn` is equal to last column index but selection might be bigger.
|
|
222
|
-
*
|
|
223
|
-
* This happens *only* on rectangular selection so we analyze a case like this:
|
|
224
|
-
*
|
|
225
|
-
* 0 1 2 3
|
|
226
|
-
* +---+---+---+---+
|
|
227
|
-
* | a |
|
|
228
|
-
* +---+---+---+---+
|
|
229
|
-
* | b | c | d |
|
|
230
|
-
* +---+---+---+---+
|
|
231
|
-
* | e | f |
|
|
232
|
-
* +---+---+---+---+
|
|
233
|
-
* | g | h |
|
|
234
|
-
* +---+---+---+---+
|
|
235
|
-
* ^
|
|
236
|
-
* last column, each cell has colspan = 2, so we need to return 3, not 2
|
|
237
|
-
*
|
|
238
|
-
* @returns Adjusted last column index.
|
|
239
|
-
*/
|
|
240
|
-
export declare function adjustLastColumnIndex(table: Element, dimensions: {
|
|
241
|
-
firstRow: number;
|
|
242
|
-
firstColumn: number;
|
|
243
|
-
lastRow: number;
|
|
244
|
-
lastColumn: number;
|
|
245
|
-
}): number;
|
|
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/utils/structure
|
|
7
|
+
*/
|
|
8
|
+
import type { Element, Writer } from 'ckeditor5/src/engine';
|
|
9
|
+
import { type TableSlot } from '../tablewalker';
|
|
10
|
+
import type TableUtils from '../tableutils';
|
|
11
|
+
/**
|
|
12
|
+
* Returns a cropped table according to given dimensions.
|
|
13
|
+
|
|
14
|
+
* To return a cropped table that starts at first row and first column and end in third row and column:
|
|
15
|
+
*
|
|
16
|
+
* ```ts
|
|
17
|
+
* const croppedTable = cropTableToDimensions( table, {
|
|
18
|
+
* startRow: 1,
|
|
19
|
+
* endRow: 3,
|
|
20
|
+
* startColumn: 1,
|
|
21
|
+
* endColumn: 3
|
|
22
|
+
* }, writer );
|
|
23
|
+
* ```
|
|
24
|
+
*
|
|
25
|
+
* Calling the code above for the table below:
|
|
26
|
+
*
|
|
27
|
+
* 0 1 2 3 4 0 1 2
|
|
28
|
+
* ┌───┬───┬───┬───┬───┐
|
|
29
|
+
* 0 │ a │ b │ c │ d │ e │
|
|
30
|
+
* ├───┴───┤ ├───┴───┤ ┌───┬───┬───┐
|
|
31
|
+
* 1 │ f │ │ g │ │ │ │ g │ 0
|
|
32
|
+
* ├───┬───┴───┼───┬───┤ will return: ├───┴───┼───┤
|
|
33
|
+
* 2 │ h │ i │ j │ k │ │ i │ j │ 1
|
|
34
|
+
* ├───┤ ├───┤ │ │ ├───┤
|
|
35
|
+
* 3 │ l │ │ m │ │ │ │ m │ 2
|
|
36
|
+
* ├───┼───┬───┤ ├───┤ └───────┴───┘
|
|
37
|
+
* 4 │ n │ o │ p │ │ q │
|
|
38
|
+
* └───┴───┴───┴───┴───┘
|
|
39
|
+
*/
|
|
40
|
+
export declare function cropTableToDimensions(sourceTable: Element, cropDimensions: {
|
|
41
|
+
startRow: number;
|
|
42
|
+
startColumn: number;
|
|
43
|
+
endRow: number;
|
|
44
|
+
endColumn: number;
|
|
45
|
+
}, writer: Writer): Element;
|
|
46
|
+
/**
|
|
47
|
+
* Returns slot info of cells that starts above and overlaps a given row.
|
|
48
|
+
*
|
|
49
|
+
* In a table below, passing `overlapRow = 3`
|
|
50
|
+
*
|
|
51
|
+
* ┌───┬───┬───┬───┬───┐
|
|
52
|
+
* 0 │ a │ b │ c │ d │ e │
|
|
53
|
+
* │ ├───┼───┼───┼───┤
|
|
54
|
+
* 1 │ │ f │ g │ h │ i │
|
|
55
|
+
* ├───┤ ├───┼───┤ │
|
|
56
|
+
* 2 │ j │ │ k │ l │ │
|
|
57
|
+
* │ │ │ ├───┼───┤
|
|
58
|
+
* 3 │ │ │ │ m │ n │ <- overlap row to check
|
|
59
|
+
* ├───┼───┤ │ ├───│
|
|
60
|
+
* 4 │ o │ p │ │ │ q │
|
|
61
|
+
* └───┴───┴───┴───┴───┘
|
|
62
|
+
*
|
|
63
|
+
* will return slot info for cells: "j", "f", "k".
|
|
64
|
+
*
|
|
65
|
+
* @param table The table to check.
|
|
66
|
+
* @param overlapRow The index of the row to check.
|
|
67
|
+
* @param startRow row to start analysis. Use it when it is known that the cells above that row will not overlap. Default value is 0.
|
|
68
|
+
*/
|
|
69
|
+
export declare function getVerticallyOverlappingCells(table: Element, overlapRow: number, startRow?: number): Array<TableSlot>;
|
|
70
|
+
/**
|
|
71
|
+
* Splits the table cell horizontally.
|
|
72
|
+
*
|
|
73
|
+
* @returns Created table cell, if any were created.
|
|
74
|
+
*/
|
|
75
|
+
export declare function splitHorizontally(tableCell: Element, splitRow: number, writer: Writer): Element | null;
|
|
76
|
+
/**
|
|
77
|
+
* Returns slot info of cells that starts before and overlaps a given column.
|
|
78
|
+
*
|
|
79
|
+
* In a table below, passing `overlapColumn = 3`
|
|
80
|
+
*
|
|
81
|
+
* 0 1 2 3 4
|
|
82
|
+
* ┌───────┬───────┬───┐
|
|
83
|
+
* │ a │ b │ c │
|
|
84
|
+
* │───┬───┴───────┼───┤
|
|
85
|
+
* │ d │ e │ f │
|
|
86
|
+
* ├───┼───┬───────┴───┤
|
|
87
|
+
* │ g │ h │ i │
|
|
88
|
+
* ├───┼───┼───┬───────┤
|
|
89
|
+
* │ j │ k │ l │ m │
|
|
90
|
+
* ├───┼───┴───┼───┬───┤
|
|
91
|
+
* │ n │ o │ p │ q │
|
|
92
|
+
* └───┴───────┴───┴───┘
|
|
93
|
+
* ^
|
|
94
|
+
* Overlap column to check
|
|
95
|
+
*
|
|
96
|
+
* will return slot info for cells: "b", "e", "i".
|
|
97
|
+
*
|
|
98
|
+
* @param table The table to check.
|
|
99
|
+
* @param overlapColumn The index of the column to check.
|
|
100
|
+
*/
|
|
101
|
+
export declare function getHorizontallyOverlappingCells(table: Element, overlapColumn: number): Array<TableSlot>;
|
|
102
|
+
/**
|
|
103
|
+
* Splits the table cell vertically.
|
|
104
|
+
*
|
|
105
|
+
* @param columnIndex The table cell column index.
|
|
106
|
+
* @param splitColumn The index of column to split cell on.
|
|
107
|
+
* @returns Created table cell.
|
|
108
|
+
*/
|
|
109
|
+
export declare function splitVertically(tableCell: Element, columnIndex: number, splitColumn: number, writer: Writer): Element;
|
|
110
|
+
/**
|
|
111
|
+
* Adjusts table cell dimensions to not exceed limit row and column.
|
|
112
|
+
*
|
|
113
|
+
* If table cell width (or height) covers a column (or row) that is after a limit column (or row)
|
|
114
|
+
* this method will trim "colspan" (or "rowspan") attribute so the table cell will fit in a defined limits.
|
|
115
|
+
*/
|
|
116
|
+
export declare function trimTableCellIfNeeded(tableCell: Element, cellRow: number, cellColumn: number, limitRow: number, limitColumn: number, writer: Writer): void;
|
|
117
|
+
/**
|
|
118
|
+
* Removes columns that have no cells anchored.
|
|
119
|
+
*
|
|
120
|
+
* In table below:
|
|
121
|
+
*
|
|
122
|
+
* +----+----+----+----+----+----+----+
|
|
123
|
+
* | 00 | 01 | 03 | 04 | 06 |
|
|
124
|
+
* +----+----+----+----+ +----+
|
|
125
|
+
* | 10 | 11 | 13 | | 16 |
|
|
126
|
+
* +----+----+----+----+----+----+----+
|
|
127
|
+
* | 20 | 21 | 23 | 24 | 26 |
|
|
128
|
+
* +----+----+----+----+----+----+----+
|
|
129
|
+
* ^--- empty ---^
|
|
130
|
+
*
|
|
131
|
+
* Will remove columns 2 and 5.
|
|
132
|
+
*
|
|
133
|
+
* **Note:** This is a low-level helper method for clearing invalid model state when doing table modifications.
|
|
134
|
+
* To remove a column from a table use {@link module:table/tableutils~TableUtils#removeColumns `TableUtils.removeColumns()`}.
|
|
135
|
+
*
|
|
136
|
+
* @internal
|
|
137
|
+
* @returns True if removed some columns.
|
|
138
|
+
*/
|
|
139
|
+
export declare function removeEmptyColumns(table: Element, tableUtils: TableUtils): boolean;
|
|
140
|
+
/**
|
|
141
|
+
* Removes rows that have no cells anchored.
|
|
142
|
+
*
|
|
143
|
+
* In table below:
|
|
144
|
+
*
|
|
145
|
+
* +----+----+----+
|
|
146
|
+
* | 00 | 01 | 02 |
|
|
147
|
+
* +----+----+----+
|
|
148
|
+
* | 10 | 11 | 12 |
|
|
149
|
+
* + + + +
|
|
150
|
+
* | | | | <-- empty
|
|
151
|
+
* +----+----+----+
|
|
152
|
+
* | 30 | 31 | 32 |
|
|
153
|
+
* +----+----+----+
|
|
154
|
+
* | 40 | 42 |
|
|
155
|
+
* + + +
|
|
156
|
+
* | | | <-- empty
|
|
157
|
+
* +----+----+----+
|
|
158
|
+
* | 60 | 61 | 62 |
|
|
159
|
+
* +----+----+----+
|
|
160
|
+
*
|
|
161
|
+
* Will remove rows 2 and 5.
|
|
162
|
+
*
|
|
163
|
+
* **Note:** This is a low-level helper method for clearing invalid model state when doing table modifications.
|
|
164
|
+
* To remove a row from a table use {@link module:table/tableutils~TableUtils#removeRows `TableUtils.removeRows()`}.
|
|
165
|
+
*
|
|
166
|
+
* @internal
|
|
167
|
+
* @returns True if removed some rows.
|
|
168
|
+
*/
|
|
169
|
+
export declare function removeEmptyRows(table: Element, tableUtils: TableUtils): boolean;
|
|
170
|
+
/**
|
|
171
|
+
* Removes rows and columns that have no cells anchored.
|
|
172
|
+
*
|
|
173
|
+
* In table below:
|
|
174
|
+
*
|
|
175
|
+
* +----+----+----+----+
|
|
176
|
+
* | 00 | 02 |
|
|
177
|
+
* +----+----+ +
|
|
178
|
+
* | 10 | |
|
|
179
|
+
* +----+----+----+----+
|
|
180
|
+
* | 20 | 22 | 23 |
|
|
181
|
+
* + + + +
|
|
182
|
+
* | | | | <-- empty row
|
|
183
|
+
* +----+----+----+----+
|
|
184
|
+
* ^--- empty column
|
|
185
|
+
*
|
|
186
|
+
* Will remove row 3 and column 1.
|
|
187
|
+
*
|
|
188
|
+
* **Note:** This is a low-level helper method for clearing invalid model state when doing table modifications.
|
|
189
|
+
* To remove a rows from a table use {@link module:table/tableutils~TableUtils#removeRows `TableUtils.removeRows()`} and
|
|
190
|
+
* {@link module:table/tableutils~TableUtils#removeColumns `TableUtils.removeColumns()`} to remove a column.
|
|
191
|
+
*
|
|
192
|
+
* @internal
|
|
193
|
+
*/
|
|
194
|
+
export declare function removeEmptyRowsColumns(table: Element, tableUtils: TableUtils): void;
|
|
195
|
+
/**
|
|
196
|
+
* Returns adjusted last row index if selection covers part of a row with empty slots (spanned by other cells).
|
|
197
|
+
* The `dimensions.lastRow` is equal to last row index but selection might be bigger.
|
|
198
|
+
*
|
|
199
|
+
* This happens *only* on rectangular selection so we analyze a case like this:
|
|
200
|
+
*
|
|
201
|
+
* +---+---+---+---+
|
|
202
|
+
* 0 | a | b | c | d |
|
|
203
|
+
* + + +---+---+
|
|
204
|
+
* 1 | | e | f | g |
|
|
205
|
+
* + +---+ +---+
|
|
206
|
+
* 2 | | h | | i | <- last row, each cell has rowspan = 2,
|
|
207
|
+
* + + + + + so we need to return 3, not 2
|
|
208
|
+
* 3 | | | | |
|
|
209
|
+
* +---+---+---+---+
|
|
210
|
+
*
|
|
211
|
+
* @returns Adjusted last row index.
|
|
212
|
+
*/
|
|
213
|
+
export declare function adjustLastRowIndex(table: Element, dimensions: {
|
|
214
|
+
firstRow: number;
|
|
215
|
+
firstColumn: number;
|
|
216
|
+
lastRow: number;
|
|
217
|
+
lastColumn: number;
|
|
218
|
+
}): number;
|
|
219
|
+
/**
|
|
220
|
+
* Returns adjusted last column index if selection covers part of a column with empty slots (spanned by other cells).
|
|
221
|
+
* The `dimensions.lastColumn` is equal to last column index but selection might be bigger.
|
|
222
|
+
*
|
|
223
|
+
* This happens *only* on rectangular selection so we analyze a case like this:
|
|
224
|
+
*
|
|
225
|
+
* 0 1 2 3
|
|
226
|
+
* +---+---+---+---+
|
|
227
|
+
* | a |
|
|
228
|
+
* +---+---+---+---+
|
|
229
|
+
* | b | c | d |
|
|
230
|
+
* +---+---+---+---+
|
|
231
|
+
* | e | f |
|
|
232
|
+
* +---+---+---+---+
|
|
233
|
+
* | g | h |
|
|
234
|
+
* +---+---+---+---+
|
|
235
|
+
* ^
|
|
236
|
+
* last column, each cell has colspan = 2, so we need to return 3, not 2
|
|
237
|
+
*
|
|
238
|
+
* @returns Adjusted last column index.
|
|
239
|
+
*/
|
|
240
|
+
export declare function adjustLastColumnIndex(table: Element, dimensions: {
|
|
241
|
+
firstRow: number;
|
|
242
|
+
firstColumn: number;
|
|
243
|
+
lastRow: number;
|
|
244
|
+
lastColumn: number;
|
|
245
|
+
}): number;
|