@atlaskit/editor-plugin-table 5.6.4 → 5.6.5
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 +6 -0
- package/dist/cjs/plugins/table/commands/selection.js +42 -1
- package/dist/cjs/plugins/table/pm-plugins/table-selection-keymap.js +4 -0
- package/dist/es2019/plugins/table/commands/selection.js +38 -1
- package/dist/es2019/plugins/table/pm-plugins/table-selection-keymap.js +6 -2
- package/dist/esm/plugins/table/commands/selection.js +42 -1
- package/dist/esm/plugins/table/pm-plugins/table-selection-keymap.js +6 -2
- package/dist/types/plugins/table/commands/selection.d.ts +2 -0
- package/dist/types-ts4.5/plugins/table/commands/selection.d.ts +2 -0
- package/package.json +4 -1
- package/src/plugins/table/commands/selection.ts +57 -2
- package/src/plugins/table/pm-plugins/table-selection-keymap.ts +19 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,11 @@
|
|
|
1
1
|
# @atlaskit/editor-plugin-table
|
|
2
2
|
|
|
3
|
+
## 5.6.5
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- [#58893](https://stash.atlassian.com/projects/CONFCLOUD/repos/confluence-frontend/pull-requests/58893) [`ed82b25d516b`](https://stash.atlassian.com/projects/CONFCLOUD/repos/confluence-frontend/commits/ed82b25d516b) - [ux] [ECA11Y-110] Selecting table columns and rows via shortcuts
|
|
8
|
+
|
|
3
9
|
## 5.6.4
|
|
4
10
|
|
|
5
11
|
### Patch Changes
|
|
@@ -3,12 +3,13 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.shiftArrowUpFromTable = exports.arrowRightFromTable = exports.arrowLeftFromTable = exports.TableSelectionDirection = void 0;
|
|
6
|
+
exports.shiftArrowUpFromTable = exports.selectRows = exports.selectColumns = exports.arrowRightFromTable = exports.arrowLeftFromTable = exports.TableSelectionDirection = void 0;
|
|
7
7
|
var _selection = require("@atlaskit/editor-common/selection");
|
|
8
8
|
var _state = require("@atlaskit/editor-prosemirror/state");
|
|
9
9
|
var _cellSelection = require("@atlaskit/editor-tables/cell-selection");
|
|
10
10
|
var _tableMap = require("@atlaskit/editor-tables/table-map");
|
|
11
11
|
var _utils = require("@atlaskit/editor-tables/utils");
|
|
12
|
+
var _misc = require("../commands/misc");
|
|
12
13
|
var _toolbar = require("../toolbar");
|
|
13
14
|
var TableSelectionDirection = exports.TableSelectionDirection = /*#__PURE__*/function (TableSelectionDirection) {
|
|
14
15
|
TableSelectionDirection["TopToBottom"] = "TopToBottom";
|
|
@@ -83,6 +84,46 @@ var arrowRightFromCellSelection = function arrowRightFromCellSelection(editorSel
|
|
|
83
84
|
};
|
|
84
85
|
};
|
|
85
86
|
};
|
|
87
|
+
var selectColumns = exports.selectColumns = function selectColumns(editorSelectionAPI) {
|
|
88
|
+
return function () {
|
|
89
|
+
return function (state, dispatch) {
|
|
90
|
+
var selection = state.selection;
|
|
91
|
+
var table = (0, _utils.findTable)(selection);
|
|
92
|
+
var rect = (0, _utils.selectedRect)(state);
|
|
93
|
+
if (table && (0, _utils.isRowSelected)(rect.top)(selection)) {
|
|
94
|
+
return selectFullTable(editorSelectionAPI)({
|
|
95
|
+
node: table.node,
|
|
96
|
+
startPos: table.start,
|
|
97
|
+
dir: TableSelectionDirection.BottomToTop
|
|
98
|
+
})(state, dispatch);
|
|
99
|
+
}
|
|
100
|
+
if (table && rect) {
|
|
101
|
+
return (0, _misc.selectColumn)(rect.left)(state, dispatch);
|
|
102
|
+
}
|
|
103
|
+
return false;
|
|
104
|
+
};
|
|
105
|
+
};
|
|
106
|
+
};
|
|
107
|
+
var selectRows = exports.selectRows = function selectRows(editorSelectionAPI) {
|
|
108
|
+
return function () {
|
|
109
|
+
return function (state, dispatch) {
|
|
110
|
+
var selection = state.selection;
|
|
111
|
+
var table = (0, _utils.findTable)(selection);
|
|
112
|
+
var rect = (0, _utils.selectedRect)(state);
|
|
113
|
+
if (table && (0, _utils.isColumnSelected)(rect.left)(selection)) {
|
|
114
|
+
return selectFullTable(editorSelectionAPI)({
|
|
115
|
+
node: table.node,
|
|
116
|
+
startPos: table.start,
|
|
117
|
+
dir: TableSelectionDirection.BottomToTop
|
|
118
|
+
})(state, dispatch);
|
|
119
|
+
}
|
|
120
|
+
if (table && rect) {
|
|
121
|
+
return (0, _misc.selectRow)(rect.top)(state, dispatch);
|
|
122
|
+
}
|
|
123
|
+
return false;
|
|
124
|
+
};
|
|
125
|
+
};
|
|
126
|
+
};
|
|
86
127
|
var arrowLeftFromGapCursor = function arrowLeftFromGapCursor(editorSelectionAPI) {
|
|
87
128
|
return function (selection) {
|
|
88
129
|
return function (state, dispatch) {
|
|
@@ -13,6 +13,10 @@ function tableSelectionKeymapPlugin(editorSelectionAPI) {
|
|
|
13
13
|
var list = {};
|
|
14
14
|
(0, _keymaps.bindKeymapWithCommand)(_keymaps.moveRight.common, (0, _selection.arrowRightFromTable)(editorSelectionAPI)(), list);
|
|
15
15
|
(0, _keymaps.bindKeymapWithCommand)(_keymaps.moveLeft.common, (0, _selection.arrowLeftFromTable)(editorSelectionAPI)(), list);
|
|
16
|
+
if ((0, _platformFeatureFlags.getBooleanFF)('platform.editor.a11y.table-selection_9uv33')) {
|
|
17
|
+
(0, _keymaps.bindKeymapArrayWithCommand)(_keymaps.selectColumn, (0, _selection.selectColumns)(editorSelectionAPI)(), list);
|
|
18
|
+
(0, _keymaps.bindKeymapArrayWithCommand)(_keymaps.selectRow, (0, _selection.selectRows)(editorSelectionAPI)(), list);
|
|
19
|
+
}
|
|
16
20
|
if ((0, _platformFeatureFlags.getBooleanFF)('platform.editor.table.shift-arrowup-fix')) {
|
|
17
21
|
(0, _keymaps.bindKeymapWithCommand)(_keymaps.shiftArrowUp.common, (0, _selection.shiftArrowUpFromTable)(editorSelectionAPI)(), list);
|
|
18
22
|
}
|
|
@@ -2,7 +2,8 @@ import { GapCursorSelection, isSelectionAtEndOfNode, isSelectionAtStartOfNode, R
|
|
|
2
2
|
import { Selection, TextSelection } from '@atlaskit/editor-prosemirror/state';
|
|
3
3
|
import { CellSelection } from '@atlaskit/editor-tables/cell-selection';
|
|
4
4
|
import { TableMap } from '@atlaskit/editor-tables/table-map';
|
|
5
|
-
import { findTable, isTableSelected } from '@atlaskit/editor-tables/utils';
|
|
5
|
+
import { findTable, isColumnSelected, isRowSelected, isTableSelected, selectedRect } from '@atlaskit/editor-tables/utils';
|
|
6
|
+
import { selectColumn, selectRow } from '../commands/misc';
|
|
6
7
|
import { getClosestSelectionRect } from '../toolbar';
|
|
7
8
|
export let TableSelectionDirection = /*#__PURE__*/function (TableSelectionDirection) {
|
|
8
9
|
TableSelectionDirection["TopToBottom"] = "TopToBottom";
|
|
@@ -66,6 +67,42 @@ const arrowRightFromCellSelection = editorSelectionAPI => selection => (state, d
|
|
|
66
67
|
}
|
|
67
68
|
return false;
|
|
68
69
|
};
|
|
70
|
+
export const selectColumns = editorSelectionAPI => () => (state, dispatch) => {
|
|
71
|
+
const {
|
|
72
|
+
selection
|
|
73
|
+
} = state;
|
|
74
|
+
const table = findTable(selection);
|
|
75
|
+
const rect = selectedRect(state);
|
|
76
|
+
if (table && isRowSelected(rect.top)(selection)) {
|
|
77
|
+
return selectFullTable(editorSelectionAPI)({
|
|
78
|
+
node: table.node,
|
|
79
|
+
startPos: table.start,
|
|
80
|
+
dir: TableSelectionDirection.BottomToTop
|
|
81
|
+
})(state, dispatch);
|
|
82
|
+
}
|
|
83
|
+
if (table && rect) {
|
|
84
|
+
return selectColumn(rect.left)(state, dispatch);
|
|
85
|
+
}
|
|
86
|
+
return false;
|
|
87
|
+
};
|
|
88
|
+
export const selectRows = editorSelectionAPI => () => (state, dispatch) => {
|
|
89
|
+
const {
|
|
90
|
+
selection
|
|
91
|
+
} = state;
|
|
92
|
+
const table = findTable(selection);
|
|
93
|
+
const rect = selectedRect(state);
|
|
94
|
+
if (table && isColumnSelected(rect.left)(selection)) {
|
|
95
|
+
return selectFullTable(editorSelectionAPI)({
|
|
96
|
+
node: table.node,
|
|
97
|
+
startPos: table.start,
|
|
98
|
+
dir: TableSelectionDirection.BottomToTop
|
|
99
|
+
})(state, dispatch);
|
|
100
|
+
}
|
|
101
|
+
if (table && rect) {
|
|
102
|
+
return selectRow(rect.top)(state, dispatch);
|
|
103
|
+
}
|
|
104
|
+
return false;
|
|
105
|
+
};
|
|
69
106
|
const arrowLeftFromGapCursor = editorSelectionAPI => selection => (state, dispatch) => {
|
|
70
107
|
const {
|
|
71
108
|
doc
|
|
@@ -1,11 +1,15 @@
|
|
|
1
|
-
import { bindKeymapWithCommand, moveLeft, moveRight, shiftArrowUp } from '@atlaskit/editor-common/keymaps';
|
|
1
|
+
import { bindKeymapArrayWithCommand, bindKeymapWithCommand, moveLeft, moveRight, selectColumn, selectRow, shiftArrowUp } from '@atlaskit/editor-common/keymaps';
|
|
2
2
|
import { keymap } from '@atlaskit/editor-prosemirror/keymap';
|
|
3
3
|
import { getBooleanFF } from '@atlaskit/platform-feature-flags';
|
|
4
|
-
import { arrowLeftFromTable, arrowRightFromTable, shiftArrowUpFromTable } from '../commands/selection';
|
|
4
|
+
import { arrowLeftFromTable, arrowRightFromTable, selectColumns, selectRows, shiftArrowUpFromTable } from '../commands/selection';
|
|
5
5
|
export function tableSelectionKeymapPlugin(editorSelectionAPI) {
|
|
6
6
|
const list = {};
|
|
7
7
|
bindKeymapWithCommand(moveRight.common, arrowRightFromTable(editorSelectionAPI)(), list);
|
|
8
8
|
bindKeymapWithCommand(moveLeft.common, arrowLeftFromTable(editorSelectionAPI)(), list);
|
|
9
|
+
if (getBooleanFF('platform.editor.a11y.table-selection_9uv33')) {
|
|
10
|
+
bindKeymapArrayWithCommand(selectColumn, selectColumns(editorSelectionAPI)(), list);
|
|
11
|
+
bindKeymapArrayWithCommand(selectRow, selectRows(editorSelectionAPI)(), list);
|
|
12
|
+
}
|
|
9
13
|
if (getBooleanFF('platform.editor.table.shift-arrowup-fix')) {
|
|
10
14
|
bindKeymapWithCommand(shiftArrowUp.common, shiftArrowUpFromTable(editorSelectionAPI)(), list);
|
|
11
15
|
}
|
|
@@ -2,7 +2,8 @@ import { GapCursorSelection, isSelectionAtEndOfNode, isSelectionAtStartOfNode, R
|
|
|
2
2
|
import { Selection, TextSelection } from '@atlaskit/editor-prosemirror/state';
|
|
3
3
|
import { CellSelection } from '@atlaskit/editor-tables/cell-selection';
|
|
4
4
|
import { TableMap } from '@atlaskit/editor-tables/table-map';
|
|
5
|
-
import { findTable, isTableSelected } from '@atlaskit/editor-tables/utils';
|
|
5
|
+
import { findTable, isColumnSelected, isRowSelected, isTableSelected, selectedRect } from '@atlaskit/editor-tables/utils';
|
|
6
|
+
import { selectColumn, selectRow } from '../commands/misc';
|
|
6
7
|
import { getClosestSelectionRect } from '../toolbar';
|
|
7
8
|
export var TableSelectionDirection = /*#__PURE__*/function (TableSelectionDirection) {
|
|
8
9
|
TableSelectionDirection["TopToBottom"] = "TopToBottom";
|
|
@@ -77,6 +78,46 @@ var arrowRightFromCellSelection = function arrowRightFromCellSelection(editorSel
|
|
|
77
78
|
};
|
|
78
79
|
};
|
|
79
80
|
};
|
|
81
|
+
export var selectColumns = function selectColumns(editorSelectionAPI) {
|
|
82
|
+
return function () {
|
|
83
|
+
return function (state, dispatch) {
|
|
84
|
+
var selection = state.selection;
|
|
85
|
+
var table = findTable(selection);
|
|
86
|
+
var rect = selectedRect(state);
|
|
87
|
+
if (table && isRowSelected(rect.top)(selection)) {
|
|
88
|
+
return selectFullTable(editorSelectionAPI)({
|
|
89
|
+
node: table.node,
|
|
90
|
+
startPos: table.start,
|
|
91
|
+
dir: TableSelectionDirection.BottomToTop
|
|
92
|
+
})(state, dispatch);
|
|
93
|
+
}
|
|
94
|
+
if (table && rect) {
|
|
95
|
+
return selectColumn(rect.left)(state, dispatch);
|
|
96
|
+
}
|
|
97
|
+
return false;
|
|
98
|
+
};
|
|
99
|
+
};
|
|
100
|
+
};
|
|
101
|
+
export var selectRows = function selectRows(editorSelectionAPI) {
|
|
102
|
+
return function () {
|
|
103
|
+
return function (state, dispatch) {
|
|
104
|
+
var selection = state.selection;
|
|
105
|
+
var table = findTable(selection);
|
|
106
|
+
var rect = selectedRect(state);
|
|
107
|
+
if (table && isColumnSelected(rect.left)(selection)) {
|
|
108
|
+
return selectFullTable(editorSelectionAPI)({
|
|
109
|
+
node: table.node,
|
|
110
|
+
startPos: table.start,
|
|
111
|
+
dir: TableSelectionDirection.BottomToTop
|
|
112
|
+
})(state, dispatch);
|
|
113
|
+
}
|
|
114
|
+
if (table && rect) {
|
|
115
|
+
return selectRow(rect.top)(state, dispatch);
|
|
116
|
+
}
|
|
117
|
+
return false;
|
|
118
|
+
};
|
|
119
|
+
};
|
|
120
|
+
};
|
|
80
121
|
var arrowLeftFromGapCursor = function arrowLeftFromGapCursor(editorSelectionAPI) {
|
|
81
122
|
return function (selection) {
|
|
82
123
|
return function (state, dispatch) {
|
|
@@ -1,11 +1,15 @@
|
|
|
1
|
-
import { bindKeymapWithCommand, moveLeft, moveRight, shiftArrowUp } from '@atlaskit/editor-common/keymaps';
|
|
1
|
+
import { bindKeymapArrayWithCommand, bindKeymapWithCommand, moveLeft, moveRight, selectColumn, selectRow, shiftArrowUp } from '@atlaskit/editor-common/keymaps';
|
|
2
2
|
import { keymap } from '@atlaskit/editor-prosemirror/keymap';
|
|
3
3
|
import { getBooleanFF } from '@atlaskit/platform-feature-flags';
|
|
4
|
-
import { arrowLeftFromTable, arrowRightFromTable, shiftArrowUpFromTable } from '../commands/selection';
|
|
4
|
+
import { arrowLeftFromTable, arrowRightFromTable, selectColumns, selectRows, shiftArrowUpFromTable } from '../commands/selection';
|
|
5
5
|
export function tableSelectionKeymapPlugin(editorSelectionAPI) {
|
|
6
6
|
var list = {};
|
|
7
7
|
bindKeymapWithCommand(moveRight.common, arrowRightFromTable(editorSelectionAPI)(), list);
|
|
8
8
|
bindKeymapWithCommand(moveLeft.common, arrowLeftFromTable(editorSelectionAPI)(), list);
|
|
9
|
+
if (getBooleanFF('platform.editor.a11y.table-selection_9uv33')) {
|
|
10
|
+
bindKeymapArrayWithCommand(selectColumn, selectColumns(editorSelectionAPI)(), list);
|
|
11
|
+
bindKeymapArrayWithCommand(selectRow, selectRows(editorSelectionAPI)(), list);
|
|
12
|
+
}
|
|
9
13
|
if (getBooleanFF('platform.editor.table.shift-arrowup-fix')) {
|
|
10
14
|
bindKeymapWithCommand(shiftArrowUp.common, shiftArrowUpFromTable(editorSelectionAPI)(), list);
|
|
11
15
|
}
|
|
@@ -6,4 +6,6 @@ export declare enum TableSelectionDirection {
|
|
|
6
6
|
}
|
|
7
7
|
export declare const arrowLeftFromTable: (editorSelectionAPI: ExtractInjectionAPI<typeof tablePlugin>['selection'] | undefined) => () => Command;
|
|
8
8
|
export declare const arrowRightFromTable: (editorSelectionAPI: ExtractInjectionAPI<typeof tablePlugin>['selection'] | undefined) => () => Command;
|
|
9
|
+
export declare const selectColumns: (editorSelectionAPI: ExtractInjectionAPI<typeof tablePlugin>['selection'] | undefined) => () => Command;
|
|
10
|
+
export declare const selectRows: (editorSelectionAPI: ExtractInjectionAPI<typeof tablePlugin>['selection'] | undefined) => () => Command;
|
|
9
11
|
export declare const shiftArrowUpFromTable: (editorSelectionAPI: ExtractInjectionAPI<typeof tablePlugin>['selection'] | undefined) => () => Command;
|
|
@@ -6,4 +6,6 @@ export declare enum TableSelectionDirection {
|
|
|
6
6
|
}
|
|
7
7
|
export declare const arrowLeftFromTable: (editorSelectionAPI: ExtractInjectionAPI<typeof tablePlugin>['selection'] | undefined) => () => Command;
|
|
8
8
|
export declare const arrowRightFromTable: (editorSelectionAPI: ExtractInjectionAPI<typeof tablePlugin>['selection'] | undefined) => () => Command;
|
|
9
|
+
export declare const selectColumns: (editorSelectionAPI: ExtractInjectionAPI<typeof tablePlugin>['selection'] | undefined) => () => Command;
|
|
10
|
+
export declare const selectRows: (editorSelectionAPI: ExtractInjectionAPI<typeof tablePlugin>['selection'] | undefined) => () => Command;
|
|
9
11
|
export declare const shiftArrowUpFromTable: (editorSelectionAPI: ExtractInjectionAPI<typeof tablePlugin>['selection'] | undefined) => () => Command;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@atlaskit/editor-plugin-table",
|
|
3
|
-
"version": "5.6.
|
|
3
|
+
"version": "5.6.5",
|
|
4
4
|
"description": "Table plugin for the @atlaskit/editor",
|
|
5
5
|
"publishConfig": {
|
|
6
6
|
"registry": "https://registry.npmjs.org/"
|
|
@@ -138,6 +138,9 @@
|
|
|
138
138
|
},
|
|
139
139
|
"platform.editor.a11y-table-resizing_uapcv": {
|
|
140
140
|
"type": "boolean"
|
|
141
|
+
},
|
|
142
|
+
"platform.editor.a11y.table-selection_9uv33": {
|
|
143
|
+
"type": "boolean"
|
|
141
144
|
}
|
|
142
145
|
}
|
|
143
146
|
}
|
|
@@ -17,8 +17,15 @@ import type {
|
|
|
17
17
|
import { Selection, TextSelection } from '@atlaskit/editor-prosemirror/state';
|
|
18
18
|
import { CellSelection } from '@atlaskit/editor-tables/cell-selection';
|
|
19
19
|
import { TableMap } from '@atlaskit/editor-tables/table-map';
|
|
20
|
-
import {
|
|
21
|
-
|
|
20
|
+
import {
|
|
21
|
+
findTable,
|
|
22
|
+
isColumnSelected,
|
|
23
|
+
isRowSelected,
|
|
24
|
+
isTableSelected,
|
|
25
|
+
selectedRect,
|
|
26
|
+
} from '@atlaskit/editor-tables/utils';
|
|
27
|
+
|
|
28
|
+
import { selectColumn, selectRow } from '../commands/misc';
|
|
22
29
|
import type tablePlugin from '../index';
|
|
23
30
|
import { getClosestSelectionRect } from '../toolbar';
|
|
24
31
|
|
|
@@ -142,6 +149,54 @@ const arrowRightFromCellSelection =
|
|
|
142
149
|
return false;
|
|
143
150
|
};
|
|
144
151
|
|
|
152
|
+
export const selectColumns =
|
|
153
|
+
(
|
|
154
|
+
editorSelectionAPI:
|
|
155
|
+
| ExtractInjectionAPI<typeof tablePlugin>['selection']
|
|
156
|
+
| undefined,
|
|
157
|
+
) =>
|
|
158
|
+
(): Command =>
|
|
159
|
+
(state, dispatch) => {
|
|
160
|
+
const { selection } = state;
|
|
161
|
+
const table = findTable(selection);
|
|
162
|
+
const rect = selectedRect(state);
|
|
163
|
+
if (table && isRowSelected(rect.top)(selection)) {
|
|
164
|
+
return selectFullTable(editorSelectionAPI)({
|
|
165
|
+
node: table.node,
|
|
166
|
+
startPos: table.start,
|
|
167
|
+
dir: TableSelectionDirection.BottomToTop,
|
|
168
|
+
})(state, dispatch);
|
|
169
|
+
}
|
|
170
|
+
if (table && rect) {
|
|
171
|
+
return selectColumn(rect.left)(state, dispatch);
|
|
172
|
+
}
|
|
173
|
+
return false;
|
|
174
|
+
};
|
|
175
|
+
|
|
176
|
+
export const selectRows =
|
|
177
|
+
(
|
|
178
|
+
editorSelectionAPI:
|
|
179
|
+
| ExtractInjectionAPI<typeof tablePlugin>['selection']
|
|
180
|
+
| undefined,
|
|
181
|
+
) =>
|
|
182
|
+
(): Command =>
|
|
183
|
+
(state, dispatch) => {
|
|
184
|
+
const { selection } = state;
|
|
185
|
+
const table = findTable(selection);
|
|
186
|
+
const rect = selectedRect(state);
|
|
187
|
+
if (table && isColumnSelected(rect.left)(selection)) {
|
|
188
|
+
return selectFullTable(editorSelectionAPI)({
|
|
189
|
+
node: table.node,
|
|
190
|
+
startPos: table.start,
|
|
191
|
+
dir: TableSelectionDirection.BottomToTop,
|
|
192
|
+
})(state, dispatch);
|
|
193
|
+
}
|
|
194
|
+
if (table && rect) {
|
|
195
|
+
return selectRow(rect.top)(state, dispatch);
|
|
196
|
+
}
|
|
197
|
+
return false;
|
|
198
|
+
};
|
|
199
|
+
|
|
145
200
|
const arrowLeftFromGapCursor =
|
|
146
201
|
(
|
|
147
202
|
editorSelectionAPI:
|
|
@@ -1,7 +1,10 @@
|
|
|
1
1
|
import {
|
|
2
|
+
bindKeymapArrayWithCommand,
|
|
2
3
|
bindKeymapWithCommand,
|
|
3
4
|
moveLeft,
|
|
4
5
|
moveRight,
|
|
6
|
+
selectColumn,
|
|
7
|
+
selectRow,
|
|
5
8
|
shiftArrowUp,
|
|
6
9
|
} from '@atlaskit/editor-common/keymaps';
|
|
7
10
|
import type { SafePlugin } from '@atlaskit/editor-common/safe-plugin';
|
|
@@ -12,6 +15,8 @@ import { getBooleanFF } from '@atlaskit/platform-feature-flags';
|
|
|
12
15
|
import {
|
|
13
16
|
arrowLeftFromTable,
|
|
14
17
|
arrowRightFromTable,
|
|
18
|
+
selectColumns,
|
|
19
|
+
selectRows,
|
|
15
20
|
shiftArrowUpFromTable,
|
|
16
21
|
} from '../commands/selection';
|
|
17
22
|
import type tablePlugin from '../index';
|
|
@@ -35,6 +40,20 @@ export function tableSelectionKeymapPlugin(
|
|
|
35
40
|
list,
|
|
36
41
|
);
|
|
37
42
|
|
|
43
|
+
if (getBooleanFF('platform.editor.a11y.table-selection_9uv33')) {
|
|
44
|
+
bindKeymapArrayWithCommand(
|
|
45
|
+
selectColumn,
|
|
46
|
+
selectColumns(editorSelectionAPI)(),
|
|
47
|
+
list,
|
|
48
|
+
);
|
|
49
|
+
|
|
50
|
+
bindKeymapArrayWithCommand(
|
|
51
|
+
selectRow,
|
|
52
|
+
selectRows(editorSelectionAPI)(),
|
|
53
|
+
list,
|
|
54
|
+
);
|
|
55
|
+
}
|
|
56
|
+
|
|
38
57
|
if (getBooleanFF('platform.editor.table.shift-arrowup-fix')) {
|
|
39
58
|
bindKeymapWithCommand(
|
|
40
59
|
shiftArrowUp.common!,
|