-
-
Notifications
You must be signed in to change notification settings - Fork 3.7k
/
selectrowcommand.js
57 lines (48 loc) · 1.54 KB
/
selectrowcommand.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/**
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved.
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
*/
/**
* @module table/commands/selectrowcommand
*/
import Command from '@ckeditor/ckeditor5-core/src/command';
import { findAncestor } from './utils';
import { getRowIndexes, getSelectionAffectedTableCells } from '../utils';
/**
* The select row command.
*
* The command is registered by {@link module:table/tableediting~TableEditing} as the `'selectTableRow'` editor command.
*
* To select the rows containing the selected cells, execute the command:
*
* editor.execute( 'selectTableRow' );
*
* @extends module:core/command~Command
*/
export default class SelectRowCommand extends Command {
/**
* @inheritDoc
*/
refresh() {
const selectedCells = getSelectionAffectedTableCells( this.editor.model.document.selection );
this.isEnabled = selectedCells.length > 0;
}
/**
* @inheritDoc
*/
execute() {
const model = this.editor.model;
const referenceCells = getSelectionAffectedTableCells( model.document.selection );
const rowIndexes = getRowIndexes( referenceCells );
const table = findAncestor( 'table', referenceCells[ 0 ] );
const rangesToSelect = [];
for ( let rowIndex = rowIndexes.first; rowIndex <= rowIndexes.last; rowIndex++ ) {
for ( const cell of table.getChild( rowIndex ).getChildren() ) {
rangesToSelect.push( model.createRangeOn( cell ) );
}
}
model.change( writer => {
writer.setSelection( rangesToSelect );
} );
}
}