@ckeditor/ckeditor5-table 39.0.2 → 40.0.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/build/table.js.map +1 -0
- package/build/translations/hy.js +1 -0
- package/lang/translations/hy.po +262 -0
- 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 +104 -104
- package/src/tablecaption/utils.d.ts +42 -42
- package/src/tablecaption/utils.js +67 -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 -539
- 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 +80 -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 -457
- 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 -265
- 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 +42 -42
- package/src/utils/common.js +57 -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 +106 -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 +16 -16
- package/src/utils/ui/widget.js +38 -38
|
@@ -1,82 +1,82 @@
|
|
|
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/commands/removerowcommand
|
|
7
|
-
*/
|
|
8
|
-
import { Command } from 'ckeditor5/src/core';
|
|
9
|
-
/**
|
|
10
|
-
* The remove row command.
|
|
11
|
-
*
|
|
12
|
-
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableRow'` editor command.
|
|
13
|
-
*
|
|
14
|
-
* To remove the row containing the selected cell, execute the command:
|
|
15
|
-
*
|
|
16
|
-
* ```ts
|
|
17
|
-
* editor.execute( 'removeTableRow' );
|
|
18
|
-
* ```
|
|
19
|
-
*/
|
|
20
|
-
export default class RemoveRowCommand extends Command {
|
|
21
|
-
/**
|
|
22
|
-
* @inheritDoc
|
|
23
|
-
*/
|
|
24
|
-
refresh() {
|
|
25
|
-
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
26
|
-
const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
|
|
27
|
-
const firstCell = selectedCells[0];
|
|
28
|
-
if (firstCell) {
|
|
29
|
-
const table = firstCell.findAncestor('table');
|
|
30
|
-
const tableRowCount = tableUtils.getRows(table);
|
|
31
|
-
const lastRowIndex = tableRowCount - 1;
|
|
32
|
-
const selectedRowIndexes = tableUtils.getRowIndexes(selectedCells);
|
|
33
|
-
const areAllRowsSelected = selectedRowIndexes.first === 0 && selectedRowIndexes.last === lastRowIndex;
|
|
34
|
-
// Disallow selecting whole table -> delete whole table should be used instead.
|
|
35
|
-
this.isEnabled = !areAllRowsSelected;
|
|
36
|
-
}
|
|
37
|
-
else {
|
|
38
|
-
this.isEnabled = false;
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* @inheritDoc
|
|
43
|
-
*/
|
|
44
|
-
execute() {
|
|
45
|
-
const model = this.editor.model;
|
|
46
|
-
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
47
|
-
const referenceCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
|
|
48
|
-
const removedRowIndexes = tableUtils.getRowIndexes(referenceCells);
|
|
49
|
-
const firstCell = referenceCells[0];
|
|
50
|
-
const table = firstCell.findAncestor('table');
|
|
51
|
-
const columnIndexToFocus = tableUtils.getCellLocation(firstCell).column;
|
|
52
|
-
model.change(writer => {
|
|
53
|
-
const rowsToRemove = removedRowIndexes.last - removedRowIndexes.first + 1;
|
|
54
|
-
tableUtils.removeRows(table, {
|
|
55
|
-
at: removedRowIndexes.first,
|
|
56
|
-
rows: rowsToRemove
|
|
57
|
-
});
|
|
58
|
-
const cellToFocus = getCellToFocus(table, removedRowIndexes.first, columnIndexToFocus, tableUtils.getRows(table));
|
|
59
|
-
writer.setSelection(writer.createPositionAt(cellToFocus, 0));
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
/**
|
|
64
|
-
* Returns a cell that should be focused before removing the row, belonging to the same column as the currently focused cell.
|
|
65
|
-
* - If the row was not the last one, the cell to focus will be in the row that followed it (before removal).
|
|
66
|
-
* - If the row was the last one, the cell to focus will be in the row that preceded it (before removal).
|
|
67
|
-
*/
|
|
68
|
-
function getCellToFocus(table, removedRowIndex, columnToFocus, tableRowCount) {
|
|
69
|
-
// Don't go beyond last row's index.
|
|
70
|
-
const row = table.getChild(Math.min(removedRowIndex, tableRowCount - 1));
|
|
71
|
-
// Default to first table cell.
|
|
72
|
-
let cellToFocus = row.getChild(0);
|
|
73
|
-
let column = 0;
|
|
74
|
-
for (const tableCell of row.getChildren()) {
|
|
75
|
-
if (column > columnToFocus) {
|
|
76
|
-
return cellToFocus;
|
|
77
|
-
}
|
|
78
|
-
cellToFocus = tableCell;
|
|
79
|
-
column += parseInt(tableCell.getAttribute('colspan') || '1');
|
|
80
|
-
}
|
|
81
|
-
return cellToFocus;
|
|
82
|
-
}
|
|
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/commands/removerowcommand
|
|
7
|
+
*/
|
|
8
|
+
import { Command } from 'ckeditor5/src/core';
|
|
9
|
+
/**
|
|
10
|
+
* The remove row command.
|
|
11
|
+
*
|
|
12
|
+
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'removeTableRow'` editor command.
|
|
13
|
+
*
|
|
14
|
+
* To remove the row containing the selected cell, execute the command:
|
|
15
|
+
*
|
|
16
|
+
* ```ts
|
|
17
|
+
* editor.execute( 'removeTableRow' );
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
export default class RemoveRowCommand extends Command {
|
|
21
|
+
/**
|
|
22
|
+
* @inheritDoc
|
|
23
|
+
*/
|
|
24
|
+
refresh() {
|
|
25
|
+
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
26
|
+
const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
|
|
27
|
+
const firstCell = selectedCells[0];
|
|
28
|
+
if (firstCell) {
|
|
29
|
+
const table = firstCell.findAncestor('table');
|
|
30
|
+
const tableRowCount = tableUtils.getRows(table);
|
|
31
|
+
const lastRowIndex = tableRowCount - 1;
|
|
32
|
+
const selectedRowIndexes = tableUtils.getRowIndexes(selectedCells);
|
|
33
|
+
const areAllRowsSelected = selectedRowIndexes.first === 0 && selectedRowIndexes.last === lastRowIndex;
|
|
34
|
+
// Disallow selecting whole table -> delete whole table should be used instead.
|
|
35
|
+
this.isEnabled = !areAllRowsSelected;
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
this.isEnabled = false;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* @inheritDoc
|
|
43
|
+
*/
|
|
44
|
+
execute() {
|
|
45
|
+
const model = this.editor.model;
|
|
46
|
+
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
47
|
+
const referenceCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
|
|
48
|
+
const removedRowIndexes = tableUtils.getRowIndexes(referenceCells);
|
|
49
|
+
const firstCell = referenceCells[0];
|
|
50
|
+
const table = firstCell.findAncestor('table');
|
|
51
|
+
const columnIndexToFocus = tableUtils.getCellLocation(firstCell).column;
|
|
52
|
+
model.change(writer => {
|
|
53
|
+
const rowsToRemove = removedRowIndexes.last - removedRowIndexes.first + 1;
|
|
54
|
+
tableUtils.removeRows(table, {
|
|
55
|
+
at: removedRowIndexes.first,
|
|
56
|
+
rows: rowsToRemove
|
|
57
|
+
});
|
|
58
|
+
const cellToFocus = getCellToFocus(table, removedRowIndexes.first, columnIndexToFocus, tableUtils.getRows(table));
|
|
59
|
+
writer.setSelection(writer.createPositionAt(cellToFocus, 0));
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Returns a cell that should be focused before removing the row, belonging to the same column as the currently focused cell.
|
|
65
|
+
* - If the row was not the last one, the cell to focus will be in the row that followed it (before removal).
|
|
66
|
+
* - If the row was the last one, the cell to focus will be in the row that preceded it (before removal).
|
|
67
|
+
*/
|
|
68
|
+
function getCellToFocus(table, removedRowIndex, columnToFocus, tableRowCount) {
|
|
69
|
+
// Don't go beyond last row's index.
|
|
70
|
+
const row = table.getChild(Math.min(removedRowIndex, tableRowCount - 1));
|
|
71
|
+
// Default to first table cell.
|
|
72
|
+
let cellToFocus = row.getChild(0);
|
|
73
|
+
let column = 0;
|
|
74
|
+
for (const tableCell of row.getChildren()) {
|
|
75
|
+
if (column > columnToFocus) {
|
|
76
|
+
return cellToFocus;
|
|
77
|
+
}
|
|
78
|
+
cellToFocus = tableCell;
|
|
79
|
+
column += parseInt(tableCell.getAttribute('colspan') || '1');
|
|
80
|
+
}
|
|
81
|
+
return cellToFocus;
|
|
82
|
+
}
|
|
@@ -1,33 +1,33 @@
|
|
|
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/commands/selectcolumncommand
|
|
7
|
-
*/
|
|
8
|
-
import { Command, type Editor } from 'ckeditor5/src/core';
|
|
9
|
-
/**
|
|
10
|
-
* The select column command.
|
|
11
|
-
*
|
|
12
|
-
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableColumn'` editor command.
|
|
13
|
-
*
|
|
14
|
-
* To select the columns containing the selected cells, execute the command:
|
|
15
|
-
*
|
|
16
|
-
* ```ts
|
|
17
|
-
* editor.execute( 'selectTableColumn' );
|
|
18
|
-
* ```
|
|
19
|
-
*/
|
|
20
|
-
export default class SelectColumnCommand extends Command {
|
|
21
|
-
/**
|
|
22
|
-
* @inheritDoc
|
|
23
|
-
*/
|
|
24
|
-
constructor(editor: Editor);
|
|
25
|
-
/**
|
|
26
|
-
* @inheritDoc
|
|
27
|
-
*/
|
|
28
|
-
refresh(): void;
|
|
29
|
-
/**
|
|
30
|
-
* @inheritDoc
|
|
31
|
-
*/
|
|
32
|
-
execute(): void;
|
|
33
|
-
}
|
|
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/commands/selectcolumncommand
|
|
7
|
+
*/
|
|
8
|
+
import { Command, type Editor } from 'ckeditor5/src/core';
|
|
9
|
+
/**
|
|
10
|
+
* The select column command.
|
|
11
|
+
*
|
|
12
|
+
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableColumn'` editor command.
|
|
13
|
+
*
|
|
14
|
+
* To select the columns containing the selected cells, execute the command:
|
|
15
|
+
*
|
|
16
|
+
* ```ts
|
|
17
|
+
* editor.execute( 'selectTableColumn' );
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
export default class SelectColumnCommand extends Command {
|
|
21
|
+
/**
|
|
22
|
+
* @inheritDoc
|
|
23
|
+
*/
|
|
24
|
+
constructor(editor: Editor);
|
|
25
|
+
/**
|
|
26
|
+
* @inheritDoc
|
|
27
|
+
*/
|
|
28
|
+
refresh(): void;
|
|
29
|
+
/**
|
|
30
|
+
* @inheritDoc
|
|
31
|
+
*/
|
|
32
|
+
execute(): void;
|
|
33
|
+
}
|
|
@@ -1,60 +1,60 @@
|
|
|
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/commands/selectcolumncommand
|
|
7
|
-
*/
|
|
8
|
-
import { Command } from 'ckeditor5/src/core';
|
|
9
|
-
import TableWalker from '../tablewalker';
|
|
10
|
-
/**
|
|
11
|
-
* The select column command.
|
|
12
|
-
*
|
|
13
|
-
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableColumn'` editor command.
|
|
14
|
-
*
|
|
15
|
-
* To select the columns containing the selected cells, execute the command:
|
|
16
|
-
*
|
|
17
|
-
* ```ts
|
|
18
|
-
* editor.execute( 'selectTableColumn' );
|
|
19
|
-
* ```
|
|
20
|
-
*/
|
|
21
|
-
export default class SelectColumnCommand extends Command {
|
|
22
|
-
/**
|
|
23
|
-
* @inheritDoc
|
|
24
|
-
*/
|
|
25
|
-
constructor(editor) {
|
|
26
|
-
super(editor);
|
|
27
|
-
// It does not affect data so should be enabled in read-only mode.
|
|
28
|
-
this.affectsData = false;
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* @inheritDoc
|
|
32
|
-
*/
|
|
33
|
-
refresh() {
|
|
34
|
-
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
35
|
-
const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
|
|
36
|
-
this.isEnabled = selectedCells.length > 0;
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
* @inheritDoc
|
|
40
|
-
*/
|
|
41
|
-
execute() {
|
|
42
|
-
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
43
|
-
const model = this.editor.model;
|
|
44
|
-
const referenceCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
|
|
45
|
-
const firstCell = referenceCells[0];
|
|
46
|
-
const lastCell = referenceCells.pop();
|
|
47
|
-
const table = firstCell.findAncestor('table');
|
|
48
|
-
const startLocation = tableUtils.getCellLocation(firstCell);
|
|
49
|
-
const endLocation = tableUtils.getCellLocation(lastCell);
|
|
50
|
-
const startColumn = Math.min(startLocation.column, endLocation.column);
|
|
51
|
-
const endColumn = Math.max(startLocation.column, endLocation.column);
|
|
52
|
-
const rangesToSelect = [];
|
|
53
|
-
for (const cellInfo of new TableWalker(table, { startColumn, endColumn })) {
|
|
54
|
-
rangesToSelect.push(model.createRangeOn(cellInfo.cell));
|
|
55
|
-
}
|
|
56
|
-
model.change(writer => {
|
|
57
|
-
writer.setSelection(rangesToSelect);
|
|
58
|
-
});
|
|
59
|
-
}
|
|
60
|
-
}
|
|
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/commands/selectcolumncommand
|
|
7
|
+
*/
|
|
8
|
+
import { Command } from 'ckeditor5/src/core';
|
|
9
|
+
import TableWalker from '../tablewalker';
|
|
10
|
+
/**
|
|
11
|
+
* The select column command.
|
|
12
|
+
*
|
|
13
|
+
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableColumn'` editor command.
|
|
14
|
+
*
|
|
15
|
+
* To select the columns containing the selected cells, execute the command:
|
|
16
|
+
*
|
|
17
|
+
* ```ts
|
|
18
|
+
* editor.execute( 'selectTableColumn' );
|
|
19
|
+
* ```
|
|
20
|
+
*/
|
|
21
|
+
export default class SelectColumnCommand extends Command {
|
|
22
|
+
/**
|
|
23
|
+
* @inheritDoc
|
|
24
|
+
*/
|
|
25
|
+
constructor(editor) {
|
|
26
|
+
super(editor);
|
|
27
|
+
// It does not affect data so should be enabled in read-only mode.
|
|
28
|
+
this.affectsData = false;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* @inheritDoc
|
|
32
|
+
*/
|
|
33
|
+
refresh() {
|
|
34
|
+
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
35
|
+
const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
|
|
36
|
+
this.isEnabled = selectedCells.length > 0;
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* @inheritDoc
|
|
40
|
+
*/
|
|
41
|
+
execute() {
|
|
42
|
+
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
43
|
+
const model = this.editor.model;
|
|
44
|
+
const referenceCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
|
|
45
|
+
const firstCell = referenceCells[0];
|
|
46
|
+
const lastCell = referenceCells.pop();
|
|
47
|
+
const table = firstCell.findAncestor('table');
|
|
48
|
+
const startLocation = tableUtils.getCellLocation(firstCell);
|
|
49
|
+
const endLocation = tableUtils.getCellLocation(lastCell);
|
|
50
|
+
const startColumn = Math.min(startLocation.column, endLocation.column);
|
|
51
|
+
const endColumn = Math.max(startLocation.column, endLocation.column);
|
|
52
|
+
const rangesToSelect = [];
|
|
53
|
+
for (const cellInfo of new TableWalker(table, { startColumn, endColumn })) {
|
|
54
|
+
rangesToSelect.push(model.createRangeOn(cellInfo.cell));
|
|
55
|
+
}
|
|
56
|
+
model.change(writer => {
|
|
57
|
+
writer.setSelection(rangesToSelect);
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
@@ -1,33 +1,33 @@
|
|
|
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/commands/selectrowcommand
|
|
7
|
-
*/
|
|
8
|
-
import { Command, type Editor } from 'ckeditor5/src/core';
|
|
9
|
-
/**
|
|
10
|
-
* The select row command.
|
|
11
|
-
*
|
|
12
|
-
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableRow'` editor command.
|
|
13
|
-
*
|
|
14
|
-
* To select the rows containing the selected cells, execute the command:
|
|
15
|
-
*
|
|
16
|
-
* ```ts
|
|
17
|
-
* editor.execute( 'selectTableRow' );
|
|
18
|
-
* ```
|
|
19
|
-
*/
|
|
20
|
-
export default class SelectRowCommand extends Command {
|
|
21
|
-
/**
|
|
22
|
-
* @inheritDoc
|
|
23
|
-
*/
|
|
24
|
-
constructor(editor: Editor);
|
|
25
|
-
/**
|
|
26
|
-
* @inheritDoc
|
|
27
|
-
*/
|
|
28
|
-
refresh(): void;
|
|
29
|
-
/**
|
|
30
|
-
* @inheritDoc
|
|
31
|
-
*/
|
|
32
|
-
execute(): void;
|
|
33
|
-
}
|
|
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/commands/selectrowcommand
|
|
7
|
+
*/
|
|
8
|
+
import { Command, type Editor } from 'ckeditor5/src/core';
|
|
9
|
+
/**
|
|
10
|
+
* The select row command.
|
|
11
|
+
*
|
|
12
|
+
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableRow'` editor command.
|
|
13
|
+
*
|
|
14
|
+
* To select the rows containing the selected cells, execute the command:
|
|
15
|
+
*
|
|
16
|
+
* ```ts
|
|
17
|
+
* editor.execute( 'selectTableRow' );
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
export default class SelectRowCommand extends Command {
|
|
21
|
+
/**
|
|
22
|
+
* @inheritDoc
|
|
23
|
+
*/
|
|
24
|
+
constructor(editor: Editor);
|
|
25
|
+
/**
|
|
26
|
+
* @inheritDoc
|
|
27
|
+
*/
|
|
28
|
+
refresh(): void;
|
|
29
|
+
/**
|
|
30
|
+
* @inheritDoc
|
|
31
|
+
*/
|
|
32
|
+
execute(): void;
|
|
33
|
+
}
|
|
@@ -1,56 +1,56 @@
|
|
|
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/commands/selectrowcommand
|
|
7
|
-
*/
|
|
8
|
-
import { Command } from 'ckeditor5/src/core';
|
|
9
|
-
/**
|
|
10
|
-
* The select row command.
|
|
11
|
-
*
|
|
12
|
-
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableRow'` editor command.
|
|
13
|
-
*
|
|
14
|
-
* To select the rows containing the selected cells, execute the command:
|
|
15
|
-
*
|
|
16
|
-
* ```ts
|
|
17
|
-
* editor.execute( 'selectTableRow' );
|
|
18
|
-
* ```
|
|
19
|
-
*/
|
|
20
|
-
export default class SelectRowCommand extends Command {
|
|
21
|
-
/**
|
|
22
|
-
* @inheritDoc
|
|
23
|
-
*/
|
|
24
|
-
constructor(editor) {
|
|
25
|
-
super(editor);
|
|
26
|
-
// It does not affect data so should be enabled in read-only mode.
|
|
27
|
-
this.affectsData = false;
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* @inheritDoc
|
|
31
|
-
*/
|
|
32
|
-
refresh() {
|
|
33
|
-
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
34
|
-
const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
|
|
35
|
-
this.isEnabled = selectedCells.length > 0;
|
|
36
|
-
}
|
|
37
|
-
/**
|
|
38
|
-
* @inheritDoc
|
|
39
|
-
*/
|
|
40
|
-
execute() {
|
|
41
|
-
const model = this.editor.model;
|
|
42
|
-
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
43
|
-
const referenceCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
|
|
44
|
-
const rowIndexes = tableUtils.getRowIndexes(referenceCells);
|
|
45
|
-
const table = referenceCells[0].findAncestor('table');
|
|
46
|
-
const rangesToSelect = [];
|
|
47
|
-
for (let rowIndex = rowIndexes.first; rowIndex <= rowIndexes.last; rowIndex++) {
|
|
48
|
-
for (const cell of table.getChild(rowIndex).getChildren()) {
|
|
49
|
-
rangesToSelect.push(model.createRangeOn(cell));
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
model.change(writer => {
|
|
53
|
-
writer.setSelection(rangesToSelect);
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
}
|
|
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/commands/selectrowcommand
|
|
7
|
+
*/
|
|
8
|
+
import { Command } from 'ckeditor5/src/core';
|
|
9
|
+
/**
|
|
10
|
+
* The select row command.
|
|
11
|
+
*
|
|
12
|
+
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableRow'` editor command.
|
|
13
|
+
*
|
|
14
|
+
* To select the rows containing the selected cells, execute the command:
|
|
15
|
+
*
|
|
16
|
+
* ```ts
|
|
17
|
+
* editor.execute( 'selectTableRow' );
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
export default class SelectRowCommand extends Command {
|
|
21
|
+
/**
|
|
22
|
+
* @inheritDoc
|
|
23
|
+
*/
|
|
24
|
+
constructor(editor) {
|
|
25
|
+
super(editor);
|
|
26
|
+
// It does not affect data so should be enabled in read-only mode.
|
|
27
|
+
this.affectsData = false;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* @inheritDoc
|
|
31
|
+
*/
|
|
32
|
+
refresh() {
|
|
33
|
+
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
34
|
+
const selectedCells = tableUtils.getSelectionAffectedTableCells(this.editor.model.document.selection);
|
|
35
|
+
this.isEnabled = selectedCells.length > 0;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* @inheritDoc
|
|
39
|
+
*/
|
|
40
|
+
execute() {
|
|
41
|
+
const model = this.editor.model;
|
|
42
|
+
const tableUtils = this.editor.plugins.get('TableUtils');
|
|
43
|
+
const referenceCells = tableUtils.getSelectionAffectedTableCells(model.document.selection);
|
|
44
|
+
const rowIndexes = tableUtils.getRowIndexes(referenceCells);
|
|
45
|
+
const table = referenceCells[0].findAncestor('table');
|
|
46
|
+
const rangesToSelect = [];
|
|
47
|
+
for (let rowIndex = rowIndexes.first; rowIndex <= rowIndexes.last; rowIndex++) {
|
|
48
|
+
for (const cell of table.getChild(rowIndex).getChildren()) {
|
|
49
|
+
rangesToSelect.push(model.createRangeOn(cell));
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
model.change(writer => {
|
|
53
|
+
writer.setSelection(rangesToSelect);
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
@@ -1,50 +1,50 @@
|
|
|
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/commands/setheadercolumncommand
|
|
7
|
-
*/
|
|
8
|
-
import { Command } from 'ckeditor5/src/core';
|
|
9
|
-
/**
|
|
10
|
-
* The header column command.
|
|
11
|
-
*
|
|
12
|
-
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'setTableColumnHeader'` editor command.
|
|
13
|
-
*
|
|
14
|
-
* You can make the column containing the selected cell a [header](https://www.w3.org/TR/html50/tabular-data.html#the-th-element)
|
|
15
|
-
* by executing:
|
|
16
|
-
*
|
|
17
|
-
* ```ts
|
|
18
|
-
* editor.execute( 'setTableColumnHeader' );
|
|
19
|
-
* ```
|
|
20
|
-
*
|
|
21
|
-
* **Note:** All preceding columns will also become headers. If the current column is already a header, executing this command
|
|
22
|
-
* will make it a regular column back again (including the following columns).
|
|
23
|
-
*/
|
|
24
|
-
export default class SetHeaderColumnCommand extends Command {
|
|
25
|
-
/**
|
|
26
|
-
* Flag indicating whether the command is active. The command is active when the
|
|
27
|
-
* {@link module:engine/model/selection~Selection} is in a header column.
|
|
28
|
-
*
|
|
29
|
-
* @observable
|
|
30
|
-
*/
|
|
31
|
-
value: boolean;
|
|
32
|
-
/**
|
|
33
|
-
* @inheritDoc
|
|
34
|
-
*/
|
|
35
|
-
refresh(): void;
|
|
36
|
-
/**
|
|
37
|
-
* Executes the command.
|
|
38
|
-
*
|
|
39
|
-
* When the selection is in a non-header column, the command will set the `headingColumns` table attribute to cover that column.
|
|
40
|
-
*
|
|
41
|
-
* When the selection is already in a header column, it will set `headingColumns` so the heading section will end before that column.
|
|
42
|
-
*
|
|
43
|
-
* @fires execute
|
|
44
|
-
* @param options.forceValue If set, the command will set (`true`) or unset (`false`) the header columns according to
|
|
45
|
-
* the `forceValue` parameter instead of the current model state.
|
|
46
|
-
*/
|
|
47
|
-
execute(options?: {
|
|
48
|
-
forceValue?: boolean;
|
|
49
|
-
}): void;
|
|
50
|
-
}
|
|
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/commands/setheadercolumncommand
|
|
7
|
+
*/
|
|
8
|
+
import { Command } from 'ckeditor5/src/core';
|
|
9
|
+
/**
|
|
10
|
+
* The header column command.
|
|
11
|
+
*
|
|
12
|
+
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'setTableColumnHeader'` editor command.
|
|
13
|
+
*
|
|
14
|
+
* You can make the column containing the selected cell a [header](https://www.w3.org/TR/html50/tabular-data.html#the-th-element)
|
|
15
|
+
* by executing:
|
|
16
|
+
*
|
|
17
|
+
* ```ts
|
|
18
|
+
* editor.execute( 'setTableColumnHeader' );
|
|
19
|
+
* ```
|
|
20
|
+
*
|
|
21
|
+
* **Note:** All preceding columns will also become headers. If the current column is already a header, executing this command
|
|
22
|
+
* will make it a regular column back again (including the following columns).
|
|
23
|
+
*/
|
|
24
|
+
export default class SetHeaderColumnCommand extends Command {
|
|
25
|
+
/**
|
|
26
|
+
* Flag indicating whether the command is active. The command is active when the
|
|
27
|
+
* {@link module:engine/model/selection~Selection} is in a header column.
|
|
28
|
+
*
|
|
29
|
+
* @observable
|
|
30
|
+
*/
|
|
31
|
+
value: boolean;
|
|
32
|
+
/**
|
|
33
|
+
* @inheritDoc
|
|
34
|
+
*/
|
|
35
|
+
refresh(): void;
|
|
36
|
+
/**
|
|
37
|
+
* Executes the command.
|
|
38
|
+
*
|
|
39
|
+
* When the selection is in a non-header column, the command will set the `headingColumns` table attribute to cover that column.
|
|
40
|
+
*
|
|
41
|
+
* When the selection is already in a header column, it will set `headingColumns` so the heading section will end before that column.
|
|
42
|
+
*
|
|
43
|
+
* @fires execute
|
|
44
|
+
* @param options.forceValue If set, the command will set (`true`) or unset (`false`) the header columns according to
|
|
45
|
+
* the `forceValue` parameter instead of the current model state.
|
|
46
|
+
*/
|
|
47
|
+
execute(options?: {
|
|
48
|
+
forceValue?: boolean;
|
|
49
|
+
}): void;
|
|
50
|
+
}
|