handsontable 0.0.0-next-e5dbebc-20240319 → 0.0.0-next-923e108-20240319
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.
Potentially problematic release.
This version of handsontable might be problematic. Click here for more details.
- package/3rdparty/walkontable/src/cell/range.d.ts +1 -2
- package/3rdparty/walkontable/src/cell/range.js +5 -22
- package/3rdparty/walkontable/src/cell/range.mjs +5 -22
- package/base.js +2 -2
- package/base.mjs +2 -2
- package/core/viewportScroll/index.js +1 -4
- package/core/viewportScroll/index.mjs +1 -4
- package/core.d.ts +3 -4
- package/core.js +21 -76
- package/core.mjs +21 -76
- package/dist/handsontable.css +2 -2
- package/dist/handsontable.full.css +2 -2
- package/dist/handsontable.full.js +1357 -2619
- package/dist/handsontable.full.min.css +2 -2
- package/dist/handsontable.full.min.js +71 -71
- package/dist/handsontable.js +1361 -2623
- package/dist/handsontable.min.css +2 -2
- package/dist/handsontable.min.js +19 -19
- package/editorManager.js +8 -12
- package/editorManager.mjs +8 -12
- package/focusManager.js +1 -7
- package/focusManager.mjs +1 -7
- package/helpers/mixed.js +1 -1
- package/helpers/mixed.mjs +1 -1
- package/package.json +1 -1
- package/pluginHooks.d.ts +0 -4
- package/pluginHooks.js +1 -69
- package/pluginHooks.mjs +1 -69
- package/plugins/collapsibleColumns/collapsibleColumns.js +3 -9
- package/plugins/collapsibleColumns/collapsibleColumns.mjs +3 -9
- package/plugins/columnSorting/columnSorting.js +2 -8
- package/plugins/columnSorting/columnSorting.mjs +2 -8
- package/plugins/contextMenu/menu/defaultShortcutsList.js +10 -26
- package/plugins/contextMenu/menu/defaultShortcutsList.mjs +10 -26
- package/plugins/mergeCells/calculations/selection.js +70 -1
- package/plugins/mergeCells/calculations/selection.mjs +70 -1
- package/plugins/mergeCells/cellsCollection.js +0 -116
- package/plugins/mergeCells/cellsCollection.mjs +0 -116
- package/plugins/mergeCells/contextMenuItem/toggleMerge.js +1 -11
- package/plugins/mergeCells/contextMenuItem/toggleMerge.mjs +1 -11
- package/plugins/mergeCells/mergeCells.js +196 -337
- package/plugins/mergeCells/mergeCells.mjs +196 -337
- package/plugins/multiColumnSorting/multiColumnSorting.js +2 -8
- package/plugins/multiColumnSorting/multiColumnSorting.mjs +2 -8
- package/plugins/nestedHeaders/nestedHeaders.js +0 -1
- package/plugins/nestedHeaders/nestedHeaders.mjs +0 -1
- package/plugins/nestedRows/nestedRows.js +3 -9
- package/plugins/nestedRows/nestedRows.mjs +3 -9
- package/renderers/checkboxRenderer/checkboxRenderer.js +5 -8
- package/renderers/checkboxRenderer/checkboxRenderer.mjs +5 -8
- package/selection/highlight/visualSelection.js +0 -2
- package/selection/highlight/visualSelection.mjs +0 -2
- package/selection/selection.js +40 -209
- package/selection/selection.mjs +39 -208
- package/selection/transformation.js +32 -83
- package/selection/transformation.mjs +32 -83
- package/shortcutContexts/commands/editor/closeAndSave.js +2 -2
- package/shortcutContexts/commands/editor/closeAndSave.mjs +2 -2
- package/shortcutContexts/commands/editor/open.js +3 -18
- package/shortcutContexts/commands/editor/open.mjs +3 -18
- package/shortcutContexts/commands/extendCellsSelection/down.js +1 -1
- package/shortcutContexts/commands/extendCellsSelection/down.mjs +1 -1
- package/shortcutContexts/commands/extendCellsSelection/left.js +1 -1
- package/shortcutContexts/commands/extendCellsSelection/left.mjs +1 -1
- package/shortcutContexts/commands/extendCellsSelection/right.js +1 -1
- package/shortcutContexts/commands/extendCellsSelection/right.mjs +1 -1
- package/shortcutContexts/commands/extendCellsSelection/toColumns.js +1 -1
- package/shortcutContexts/commands/extendCellsSelection/toColumns.mjs +1 -1
- package/shortcutContexts/commands/extendCellsSelection/toMostBottom.js +1 -3
- package/shortcutContexts/commands/extendCellsSelection/toMostBottom.mjs +1 -3
- package/shortcutContexts/commands/extendCellsSelection/toMostInlineEnd.js +3 -9
- package/shortcutContexts/commands/extendCellsSelection/toMostInlineEnd.mjs +3 -9
- package/shortcutContexts/commands/extendCellsSelection/toMostInlineStart.js +3 -10
- package/shortcutContexts/commands/extendCellsSelection/toMostInlineStart.mjs +3 -10
- package/shortcutContexts/commands/extendCellsSelection/toMostLeft.js +1 -3
- package/shortcutContexts/commands/extendCellsSelection/toMostLeft.mjs +1 -3
- package/shortcutContexts/commands/extendCellsSelection/toMostRight.js +1 -3
- package/shortcutContexts/commands/extendCellsSelection/toMostRight.mjs +1 -3
- package/shortcutContexts/commands/extendCellsSelection/toMostTop.js +1 -3
- package/shortcutContexts/commands/extendCellsSelection/toMostTop.mjs +1 -3
- package/shortcutContexts/commands/extendCellsSelection/toRows.js +1 -1
- package/shortcutContexts/commands/extendCellsSelection/toRows.mjs +1 -1
- package/shortcutContexts/commands/extendCellsSelection/up.js +1 -1
- package/shortcutContexts/commands/extendCellsSelection/up.mjs +1 -1
- package/shortcutContexts/commands/moveCellSelection/inlineEnd.js +1 -6
- package/shortcutContexts/commands/moveCellSelection/inlineEnd.mjs +1 -6
- package/shortcutContexts/commands/moveCellSelection/inlineStart.js +1 -6
- package/shortcutContexts/commands/moveCellSelection/inlineStart.mjs +1 -6
- package/shortcutContexts/grid.js +2 -2
- package/shortcutContexts/grid.mjs +2 -2
- package/shortcuts/context.js +1 -2
- package/shortcuts/context.mjs +1 -2
- package/utils/dataStructures/linkedList.js +1 -6
- package/utils/dataStructures/linkedList.mjs +1 -6
- package/core/viewportScroll/scrollStrategies/focusScroll.js +0 -15
- package/core/viewportScroll/scrollStrategies/focusScroll.mjs +0 -11
- package/plugins/mergeCells/focusOrder.js +0 -303
- package/plugins/mergeCells/focusOrder.mjs +0 -298
@@ -36,6 +36,74 @@ class SelectionCalculations {
|
|
36
36
|
this.hot = plugin.hot;
|
37
37
|
}
|
38
38
|
|
39
|
+
/**
|
40
|
+
* "Snap" the delta value according to defined merged cells. (In other words, compensate the rowspan -
|
41
|
+
* e.g. Going up with `delta.row = -1` over a merged cell with `rowspan = 3`, `delta.row` should change to `-3`.).
|
42
|
+
*
|
43
|
+
* @param {object} delta The delta object containing `row` and `col` properties.
|
44
|
+
* @param {CellRange} selectionRange The selection range.
|
45
|
+
* @param {object} mergedCell A merged cell object.
|
46
|
+
*/
|
47
|
+
snapDelta(delta, selectionRange, mergedCell) {
|
48
|
+
const cellCoords = selectionRange.to;
|
49
|
+
const newRow = cellCoords.row + delta.row;
|
50
|
+
const newColumn = cellCoords.col + delta.col;
|
51
|
+
if (delta.row) {
|
52
|
+
this.jumpOverMergedCell(delta, mergedCell, newRow);
|
53
|
+
} else if (delta.col) {
|
54
|
+
this.jumpOverMergedCell(delta, mergedCell, newColumn);
|
55
|
+
}
|
56
|
+
}
|
57
|
+
|
58
|
+
/**
|
59
|
+
* "Jump" over the merged cell (compensate for the indexes within the merged cell to get past it).
|
60
|
+
*
|
61
|
+
* @private
|
62
|
+
* @param {object} delta The delta object.
|
63
|
+
* @param {MergedCellCoords} mergedCell The merge cell object.
|
64
|
+
* @param {number} newIndex New row/column index, created with the delta.
|
65
|
+
*/
|
66
|
+
jumpOverMergedCell(delta, mergedCell, newIndex) {
|
67
|
+
let flatDelta = delta.row || delta.col;
|
68
|
+
let includesIndex = null;
|
69
|
+
let firstIndex = null;
|
70
|
+
let lastIndex = null;
|
71
|
+
if (delta.row) {
|
72
|
+
includesIndex = mergedCell.includesVertically(newIndex);
|
73
|
+
firstIndex = mergedCell.row;
|
74
|
+
lastIndex = mergedCell.getLastRow();
|
75
|
+
} else if (delta.col) {
|
76
|
+
includesIndex = mergedCell.includesHorizontally(newIndex);
|
77
|
+
firstIndex = mergedCell.col;
|
78
|
+
lastIndex = mergedCell.getLastColumn();
|
79
|
+
}
|
80
|
+
if (flatDelta === 0) {
|
81
|
+
return;
|
82
|
+
} else if (flatDelta > 0) {
|
83
|
+
if (includesIndex && newIndex !== firstIndex) {
|
84
|
+
flatDelta += lastIndex - newIndex + 1;
|
85
|
+
}
|
86
|
+
} else if (includesIndex && newIndex !== lastIndex) {
|
87
|
+
flatDelta -= newIndex - firstIndex + 1;
|
88
|
+
}
|
89
|
+
if (delta.row) {
|
90
|
+
delta.row = flatDelta;
|
91
|
+
} else if (delta.col) {
|
92
|
+
delta.col = flatDelta;
|
93
|
+
}
|
94
|
+
}
|
95
|
+
|
96
|
+
/**
|
97
|
+
* Get a selection range with `to` property incremented by the provided delta.
|
98
|
+
*
|
99
|
+
* @param {CellRange} oldSelectionRange The base selection range.
|
100
|
+
* @param {object} delta The delta object with `row` and `col` properties.
|
101
|
+
* @returns {CellRange} A new `CellRange` object.
|
102
|
+
*/
|
103
|
+
getUpdatedSelectionRange(oldSelectionRange, delta) {
|
104
|
+
return this.hot._createCellRange(oldSelectionRange.highlight, oldSelectionRange.from, this.hot._createCellCoords(oldSelectionRange.to.row + delta.row, oldSelectionRange.to.col + delta.col));
|
105
|
+
}
|
106
|
+
|
39
107
|
/**
|
40
108
|
* Generate an additional class name for the entirely-selected merged cells.
|
41
109
|
*
|
@@ -68,7 +136,8 @@ class SelectionCalculations {
|
|
68
136
|
const fullMergeAreaWithinSelection = startRow <= mergedCell.row && startColumn <= mergedCell.col && endRow >= mergeRowEnd && endColumn >= mergeColumnEnd;
|
69
137
|
if (fullMergeAreaWithinSelection) {
|
70
138
|
return `${this.fullySelectedMergedCellClassName}-${layerLevel}`;
|
71
|
-
} else if (this.isMergeCellFullySelected(mergedCell, this.plugin.hot.getSelectedRange())) {
|
139
|
+
} else if (this.plugin.selectionCalculations.isMergeCellFullySelected(mergedCell, this.plugin.hot.getSelectedRange())) {
|
140
|
+
// eslint-disable-line max-len
|
72
141
|
return `${this.fullySelectedMergedCellClassName}-multiple`;
|
73
142
|
}
|
74
143
|
}
|
@@ -33,6 +33,74 @@ class SelectionCalculations {
|
|
33
33
|
this.hot = plugin.hot;
|
34
34
|
}
|
35
35
|
|
36
|
+
/**
|
37
|
+
* "Snap" the delta value according to defined merged cells. (In other words, compensate the rowspan -
|
38
|
+
* e.g. Going up with `delta.row = -1` over a merged cell with `rowspan = 3`, `delta.row` should change to `-3`.).
|
39
|
+
*
|
40
|
+
* @param {object} delta The delta object containing `row` and `col` properties.
|
41
|
+
* @param {CellRange} selectionRange The selection range.
|
42
|
+
* @param {object} mergedCell A merged cell object.
|
43
|
+
*/
|
44
|
+
snapDelta(delta, selectionRange, mergedCell) {
|
45
|
+
const cellCoords = selectionRange.to;
|
46
|
+
const newRow = cellCoords.row + delta.row;
|
47
|
+
const newColumn = cellCoords.col + delta.col;
|
48
|
+
if (delta.row) {
|
49
|
+
this.jumpOverMergedCell(delta, mergedCell, newRow);
|
50
|
+
} else if (delta.col) {
|
51
|
+
this.jumpOverMergedCell(delta, mergedCell, newColumn);
|
52
|
+
}
|
53
|
+
}
|
54
|
+
|
55
|
+
/**
|
56
|
+
* "Jump" over the merged cell (compensate for the indexes within the merged cell to get past it).
|
57
|
+
*
|
58
|
+
* @private
|
59
|
+
* @param {object} delta The delta object.
|
60
|
+
* @param {MergedCellCoords} mergedCell The merge cell object.
|
61
|
+
* @param {number} newIndex New row/column index, created with the delta.
|
62
|
+
*/
|
63
|
+
jumpOverMergedCell(delta, mergedCell, newIndex) {
|
64
|
+
let flatDelta = delta.row || delta.col;
|
65
|
+
let includesIndex = null;
|
66
|
+
let firstIndex = null;
|
67
|
+
let lastIndex = null;
|
68
|
+
if (delta.row) {
|
69
|
+
includesIndex = mergedCell.includesVertically(newIndex);
|
70
|
+
firstIndex = mergedCell.row;
|
71
|
+
lastIndex = mergedCell.getLastRow();
|
72
|
+
} else if (delta.col) {
|
73
|
+
includesIndex = mergedCell.includesHorizontally(newIndex);
|
74
|
+
firstIndex = mergedCell.col;
|
75
|
+
lastIndex = mergedCell.getLastColumn();
|
76
|
+
}
|
77
|
+
if (flatDelta === 0) {
|
78
|
+
return;
|
79
|
+
} else if (flatDelta > 0) {
|
80
|
+
if (includesIndex && newIndex !== firstIndex) {
|
81
|
+
flatDelta += lastIndex - newIndex + 1;
|
82
|
+
}
|
83
|
+
} else if (includesIndex && newIndex !== lastIndex) {
|
84
|
+
flatDelta -= newIndex - firstIndex + 1;
|
85
|
+
}
|
86
|
+
if (delta.row) {
|
87
|
+
delta.row = flatDelta;
|
88
|
+
} else if (delta.col) {
|
89
|
+
delta.col = flatDelta;
|
90
|
+
}
|
91
|
+
}
|
92
|
+
|
93
|
+
/**
|
94
|
+
* Get a selection range with `to` property incremented by the provided delta.
|
95
|
+
*
|
96
|
+
* @param {CellRange} oldSelectionRange The base selection range.
|
97
|
+
* @param {object} delta The delta object with `row` and `col` properties.
|
98
|
+
* @returns {CellRange} A new `CellRange` object.
|
99
|
+
*/
|
100
|
+
getUpdatedSelectionRange(oldSelectionRange, delta) {
|
101
|
+
return this.hot._createCellRange(oldSelectionRange.highlight, oldSelectionRange.from, this.hot._createCellCoords(oldSelectionRange.to.row + delta.row, oldSelectionRange.to.col + delta.col));
|
102
|
+
}
|
103
|
+
|
36
104
|
/**
|
37
105
|
* Generate an additional class name for the entirely-selected merged cells.
|
38
106
|
*
|
@@ -65,7 +133,8 @@ class SelectionCalculations {
|
|
65
133
|
const fullMergeAreaWithinSelection = startRow <= mergedCell.row && startColumn <= mergedCell.col && endRow >= mergeRowEnd && endColumn >= mergeColumnEnd;
|
66
134
|
if (fullMergeAreaWithinSelection) {
|
67
135
|
return `${this.fullySelectedMergedCellClassName}-${layerLevel}`;
|
68
|
-
} else if (this.isMergeCellFullySelected(mergedCell, this.plugin.hot.getSelectedRange())) {
|
136
|
+
} else if (this.plugin.selectionCalculations.isMergeCellFullySelected(mergedCell, this.plugin.hot.getSelectedRange())) {
|
137
|
+
// eslint-disable-line max-len
|
69
138
|
return `${this.fullySelectedMergedCellClassName}-multiple`;
|
70
139
|
}
|
71
140
|
}
|
@@ -3,7 +3,6 @@
|
|
3
3
|
exports.__esModule = true;
|
4
4
|
require("core-js/modules/es.error.cause.js");
|
5
5
|
require("core-js/modules/es.array.push.js");
|
6
|
-
require("core-js/modules/es.array.unscopables.flat-map.js");
|
7
6
|
var _cellCoords = _interopRequireDefault(require("./cellCoords"));
|
8
7
|
var _number = require("../../helpers/number");
|
9
8
|
var _console = require("../../helpers/console");
|
@@ -11,30 +10,17 @@ var _array = require("../../helpers/array");
|
|
11
10
|
var _utils = require("./utils");
|
12
11
|
var _templateLiteralTag = require("../../helpers/templateLiteralTag");
|
13
12
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
14
|
-
function _classPrivateMethodInitSpec(obj, privateSet) { _checkPrivateRedeclaration(obj, privateSet); privateSet.add(obj); }
|
15
|
-
function _checkPrivateRedeclaration(obj, privateCollection) { if (privateCollection.has(obj)) { throw new TypeError("Cannot initialize the same private elements twice on an object"); } }
|
16
13
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
17
14
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
|
18
15
|
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
19
|
-
function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); }
|
20
16
|
/**
|
21
17
|
* Defines a container object for the merged cells.
|
22
18
|
*
|
23
19
|
* @private
|
24
20
|
* @class MergedCellsCollection
|
25
21
|
*/
|
26
|
-
var _MergedCellsCollection_brand = /*#__PURE__*/new WeakSet();
|
27
22
|
class MergedCellsCollection {
|
28
23
|
constructor(mergeCellsPlugin) {
|
29
|
-
/**
|
30
|
-
* Gets the list of the indexes that do not intersect with other merged cells within the provided range.
|
31
|
-
*
|
32
|
-
* @param {CellRange} range The range to search within.
|
33
|
-
* @param {'row' | 'col'} axis The axis to search within.
|
34
|
-
* @param {number} scanDirection The direction to scan the range. `1` for forward, `-1` for backward.
|
35
|
-
* @returns {number[]}
|
36
|
-
*/
|
37
|
-
_classPrivateMethodInitSpec(this, _MergedCellsCollection_brand);
|
38
24
|
/**
|
39
25
|
* Reference to the Merge Cells plugin.
|
40
26
|
*
|
@@ -273,81 +259,6 @@ class MergedCellsCollection {
|
|
273
259
|
return this.hot._createCellCoords(firstRenderableRow, firstRenderableColumn);
|
274
260
|
}
|
275
261
|
|
276
|
-
/**
|
277
|
-
* Gets the start-most visual column index that do not intersect with other merged cells within the provided range.
|
278
|
-
*
|
279
|
-
* @param {CellRange} range The range to search within.
|
280
|
-
* @param {number} visualColumnIndex The visual column index to start the search from.
|
281
|
-
* @returns {number}
|
282
|
-
*/
|
283
|
-
getStartMostColumnIndex(range, visualColumnIndex) {
|
284
|
-
const indexes = _assertClassBrand(_MergedCellsCollection_brand, this, _getNonIntersectingIndexes).call(this, range, 'col', -1);
|
285
|
-
let startMostIndex = visualColumnIndex;
|
286
|
-
for (let i = 0; i < indexes.length; i++) {
|
287
|
-
if (indexes[i] <= visualColumnIndex) {
|
288
|
-
startMostIndex = indexes[i];
|
289
|
-
break;
|
290
|
-
}
|
291
|
-
}
|
292
|
-
return startMostIndex;
|
293
|
-
}
|
294
|
-
|
295
|
-
/**
|
296
|
-
* Gets the end-most visual column index that do not intersect with other merged cells within the provided range.
|
297
|
-
*
|
298
|
-
* @param {CellRange} range The range to search within.
|
299
|
-
* @param {number} visualColumnIndex The visual column index to start the search from.
|
300
|
-
* @returns {number}
|
301
|
-
*/
|
302
|
-
getEndMostColumnIndex(range, visualColumnIndex) {
|
303
|
-
const indexes = _assertClassBrand(_MergedCellsCollection_brand, this, _getNonIntersectingIndexes).call(this, range, 'col', 1);
|
304
|
-
let endMostIndex = visualColumnIndex;
|
305
|
-
for (let i = 0; i < indexes.length; i++) {
|
306
|
-
if (indexes[i] >= visualColumnIndex) {
|
307
|
-
endMostIndex = indexes[i];
|
308
|
-
break;
|
309
|
-
}
|
310
|
-
}
|
311
|
-
return endMostIndex;
|
312
|
-
}
|
313
|
-
|
314
|
-
/**
|
315
|
-
* Gets the top-most visual row index that do not intersect with other merged cells within the provided range.
|
316
|
-
*
|
317
|
-
* @param {CellRange} range The range to search within.
|
318
|
-
* @param {number} visualRowIndex The visual row index to start the search from.
|
319
|
-
* @returns {number}
|
320
|
-
*/
|
321
|
-
getTopMostRowIndex(range, visualRowIndex) {
|
322
|
-
const indexes = _assertClassBrand(_MergedCellsCollection_brand, this, _getNonIntersectingIndexes).call(this, range, 'row', -1);
|
323
|
-
let topMostIndex = visualRowIndex;
|
324
|
-
for (let i = 0; i < indexes.length; i++) {
|
325
|
-
if (indexes[i] <= visualRowIndex) {
|
326
|
-
topMostIndex = indexes[i];
|
327
|
-
break;
|
328
|
-
}
|
329
|
-
}
|
330
|
-
return topMostIndex;
|
331
|
-
}
|
332
|
-
|
333
|
-
/**
|
334
|
-
* Gets the bottom-most visual row index that do not intersect with other merged cells within the provided range.
|
335
|
-
*
|
336
|
-
* @param {CellRange} range The range to search within.
|
337
|
-
* @param {number} visualRowIndex The visual row index to start the search from.
|
338
|
-
* @returns {number}
|
339
|
-
*/
|
340
|
-
getBottomMostRowIndex(range, visualRowIndex) {
|
341
|
-
const indexes = _assertClassBrand(_MergedCellsCollection_brand, this, _getNonIntersectingIndexes).call(this, range, 'row', 1);
|
342
|
-
let bottomMostIndex = visualRowIndex;
|
343
|
-
for (let i = 0; i < indexes.length; i++) {
|
344
|
-
if (indexes[i] >= visualRowIndex) {
|
345
|
-
bottomMostIndex = indexes[i];
|
346
|
-
break;
|
347
|
-
}
|
348
|
-
}
|
349
|
-
return bottomMostIndex;
|
350
|
-
}
|
351
262
|
/**
|
352
263
|
* Shift the merged cell in the direction and by an offset defined in the arguments.
|
353
264
|
*
|
@@ -383,31 +294,4 @@ class MergedCellsCollection {
|
|
383
294
|
});
|
384
295
|
}
|
385
296
|
}
|
386
|
-
function _getNonIntersectingIndexes(range, axis) {
|
387
|
-
let scanDirection = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;
|
388
|
-
const indexes = new Map();
|
389
|
-
const from = scanDirection === 1 ? range.getTopStartCorner() : range.getBottomEndCorner();
|
390
|
-
const to = scanDirection === 1 ? range.getBottomEndCorner() : range.getTopStartCorner();
|
391
|
-
for (let row = from.row; scanDirection === 1 ? row <= to.row : row >= to.row; row += scanDirection) {
|
392
|
-
for (let column = from.col; scanDirection === 1 ? column <= to.col : column >= to.col; column += scanDirection) {
|
393
|
-
const index = axis === 'row' ? row : column;
|
394
|
-
const mergedCell = this.get(row, column);
|
395
|
-
let lastIndex = index;
|
396
|
-
if (mergedCell) {
|
397
|
-
lastIndex = scanDirection === 1 ? mergedCell[axis] + mergedCell[`${axis}span`] - 1 : mergedCell[axis];
|
398
|
-
}
|
399
|
-
if (!indexes.has(index)) {
|
400
|
-
indexes.set(index, new Set());
|
401
|
-
}
|
402
|
-
indexes.get(index).add(lastIndex);
|
403
|
-
}
|
404
|
-
}
|
405
|
-
return Array.from(new Set(Array.from(indexes.entries()).filter(_ref => {
|
406
|
-
let [, set] = _ref;
|
407
|
-
return set.size === 1;
|
408
|
-
}).flatMap(_ref2 => {
|
409
|
-
let [, set] = _ref2;
|
410
|
-
return Array.from(set);
|
411
|
-
})));
|
412
|
-
}
|
413
297
|
var _default = exports.default = MergedCellsCollection;
|
@@ -1,12 +1,8 @@
|
|
1
1
|
import "core-js/modules/es.error.cause.js";
|
2
2
|
import "core-js/modules/es.array.push.js";
|
3
|
-
import "core-js/modules/es.array.unscopables.flat-map.js";
|
4
|
-
function _classPrivateMethodInitSpec(obj, privateSet) { _checkPrivateRedeclaration(obj, privateSet); privateSet.add(obj); }
|
5
|
-
function _checkPrivateRedeclaration(obj, privateCollection) { if (privateCollection.has(obj)) { throw new TypeError("Cannot initialize the same private elements twice on an object"); } }
|
6
3
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
7
4
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
|
8
5
|
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
9
|
-
function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); }
|
10
6
|
import MergedCellCoords from "./cellCoords.mjs";
|
11
7
|
import { rangeEach, rangeEachReverse } from "../../helpers/number.mjs";
|
12
8
|
import { warn } from "../../helpers/console.mjs";
|
@@ -19,18 +15,8 @@ import { toSingleLine } from "../../helpers/templateLiteralTag.mjs";
|
|
19
15
|
* @private
|
20
16
|
* @class MergedCellsCollection
|
21
17
|
*/
|
22
|
-
var _MergedCellsCollection_brand = /*#__PURE__*/new WeakSet();
|
23
18
|
class MergedCellsCollection {
|
24
19
|
constructor(mergeCellsPlugin) {
|
25
|
-
/**
|
26
|
-
* Gets the list of the indexes that do not intersect with other merged cells within the provided range.
|
27
|
-
*
|
28
|
-
* @param {CellRange} range The range to search within.
|
29
|
-
* @param {'row' | 'col'} axis The axis to search within.
|
30
|
-
* @param {number} scanDirection The direction to scan the range. `1` for forward, `-1` for backward.
|
31
|
-
* @returns {number[]}
|
32
|
-
*/
|
33
|
-
_classPrivateMethodInitSpec(this, _MergedCellsCollection_brand);
|
34
20
|
/**
|
35
21
|
* Reference to the Merge Cells plugin.
|
36
22
|
*
|
@@ -269,81 +255,6 @@ class MergedCellsCollection {
|
|
269
255
|
return this.hot._createCellCoords(firstRenderableRow, firstRenderableColumn);
|
270
256
|
}
|
271
257
|
|
272
|
-
/**
|
273
|
-
* Gets the start-most visual column index that do not intersect with other merged cells within the provided range.
|
274
|
-
*
|
275
|
-
* @param {CellRange} range The range to search within.
|
276
|
-
* @param {number} visualColumnIndex The visual column index to start the search from.
|
277
|
-
* @returns {number}
|
278
|
-
*/
|
279
|
-
getStartMostColumnIndex(range, visualColumnIndex) {
|
280
|
-
const indexes = _assertClassBrand(_MergedCellsCollection_brand, this, _getNonIntersectingIndexes).call(this, range, 'col', -1);
|
281
|
-
let startMostIndex = visualColumnIndex;
|
282
|
-
for (let i = 0; i < indexes.length; i++) {
|
283
|
-
if (indexes[i] <= visualColumnIndex) {
|
284
|
-
startMostIndex = indexes[i];
|
285
|
-
break;
|
286
|
-
}
|
287
|
-
}
|
288
|
-
return startMostIndex;
|
289
|
-
}
|
290
|
-
|
291
|
-
/**
|
292
|
-
* Gets the end-most visual column index that do not intersect with other merged cells within the provided range.
|
293
|
-
*
|
294
|
-
* @param {CellRange} range The range to search within.
|
295
|
-
* @param {number} visualColumnIndex The visual column index to start the search from.
|
296
|
-
* @returns {number}
|
297
|
-
*/
|
298
|
-
getEndMostColumnIndex(range, visualColumnIndex) {
|
299
|
-
const indexes = _assertClassBrand(_MergedCellsCollection_brand, this, _getNonIntersectingIndexes).call(this, range, 'col', 1);
|
300
|
-
let endMostIndex = visualColumnIndex;
|
301
|
-
for (let i = 0; i < indexes.length; i++) {
|
302
|
-
if (indexes[i] >= visualColumnIndex) {
|
303
|
-
endMostIndex = indexes[i];
|
304
|
-
break;
|
305
|
-
}
|
306
|
-
}
|
307
|
-
return endMostIndex;
|
308
|
-
}
|
309
|
-
|
310
|
-
/**
|
311
|
-
* Gets the top-most visual row index that do not intersect with other merged cells within the provided range.
|
312
|
-
*
|
313
|
-
* @param {CellRange} range The range to search within.
|
314
|
-
* @param {number} visualRowIndex The visual row index to start the search from.
|
315
|
-
* @returns {number}
|
316
|
-
*/
|
317
|
-
getTopMostRowIndex(range, visualRowIndex) {
|
318
|
-
const indexes = _assertClassBrand(_MergedCellsCollection_brand, this, _getNonIntersectingIndexes).call(this, range, 'row', -1);
|
319
|
-
let topMostIndex = visualRowIndex;
|
320
|
-
for (let i = 0; i < indexes.length; i++) {
|
321
|
-
if (indexes[i] <= visualRowIndex) {
|
322
|
-
topMostIndex = indexes[i];
|
323
|
-
break;
|
324
|
-
}
|
325
|
-
}
|
326
|
-
return topMostIndex;
|
327
|
-
}
|
328
|
-
|
329
|
-
/**
|
330
|
-
* Gets the bottom-most visual row index that do not intersect with other merged cells within the provided range.
|
331
|
-
*
|
332
|
-
* @param {CellRange} range The range to search within.
|
333
|
-
* @param {number} visualRowIndex The visual row index to start the search from.
|
334
|
-
* @returns {number}
|
335
|
-
*/
|
336
|
-
getBottomMostRowIndex(range, visualRowIndex) {
|
337
|
-
const indexes = _assertClassBrand(_MergedCellsCollection_brand, this, _getNonIntersectingIndexes).call(this, range, 'row', 1);
|
338
|
-
let bottomMostIndex = visualRowIndex;
|
339
|
-
for (let i = 0; i < indexes.length; i++) {
|
340
|
-
if (indexes[i] >= visualRowIndex) {
|
341
|
-
bottomMostIndex = indexes[i];
|
342
|
-
break;
|
343
|
-
}
|
344
|
-
}
|
345
|
-
return bottomMostIndex;
|
346
|
-
}
|
347
258
|
/**
|
348
259
|
* Shift the merged cell in the direction and by an offset defined in the arguments.
|
349
260
|
*
|
@@ -379,31 +290,4 @@ class MergedCellsCollection {
|
|
379
290
|
});
|
380
291
|
}
|
381
292
|
}
|
382
|
-
function _getNonIntersectingIndexes(range, axis) {
|
383
|
-
let scanDirection = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;
|
384
|
-
const indexes = new Map();
|
385
|
-
const from = scanDirection === 1 ? range.getTopStartCorner() : range.getBottomEndCorner();
|
386
|
-
const to = scanDirection === 1 ? range.getBottomEndCorner() : range.getTopStartCorner();
|
387
|
-
for (let row = from.row; scanDirection === 1 ? row <= to.row : row >= to.row; row += scanDirection) {
|
388
|
-
for (let column = from.col; scanDirection === 1 ? column <= to.col : column >= to.col; column += scanDirection) {
|
389
|
-
const index = axis === 'row' ? row : column;
|
390
|
-
const mergedCell = this.get(row, column);
|
391
|
-
let lastIndex = index;
|
392
|
-
if (mergedCell) {
|
393
|
-
lastIndex = scanDirection === 1 ? mergedCell[axis] + mergedCell[`${axis}span`] - 1 : mergedCell[axis];
|
394
|
-
}
|
395
|
-
if (!indexes.has(index)) {
|
396
|
-
indexes.set(index, new Set());
|
397
|
-
}
|
398
|
-
indexes.get(index).add(lastIndex);
|
399
|
-
}
|
400
|
-
}
|
401
|
-
return Array.from(new Set(Array.from(indexes.entries()).filter(_ref => {
|
402
|
-
let [, set] = _ref;
|
403
|
-
return set.size === 1;
|
404
|
-
}).flatMap(_ref2 => {
|
405
|
-
let [, set] = _ref2;
|
406
|
-
return Array.from(set);
|
407
|
-
})));
|
408
|
-
}
|
409
293
|
export default MergedCellsCollection;
|
@@ -25,17 +25,7 @@ function toggleMergeItem(plugin) {
|
|
25
25
|
return this.getTranslatedPhrase(C.CONTEXTMENU_ITEMS_MERGE_CELLS);
|
26
26
|
},
|
27
27
|
callback() {
|
28
|
-
|
29
|
-
if (!currentRange) {
|
30
|
-
return;
|
31
|
-
}
|
32
|
-
currentRange.setDirection(this.isRtl() ? 'NE-SW' : 'NW-SE');
|
33
|
-
const {
|
34
|
-
from,
|
35
|
-
to
|
36
|
-
} = currentRange;
|
37
|
-
plugin.toggleMerge(currentRange);
|
38
|
-
this.selectCell(from.row, from.col, to.row, to.col, false);
|
28
|
+
plugin.toggleMergeOnSelection();
|
39
29
|
},
|
40
30
|
disabled() {
|
41
31
|
const sel = this.getSelectedLast();
|
@@ -18,17 +18,7 @@ export default function toggleMergeItem(plugin) {
|
|
18
18
|
return this.getTranslatedPhrase(C.CONTEXTMENU_ITEMS_MERGE_CELLS);
|
19
19
|
},
|
20
20
|
callback() {
|
21
|
-
|
22
|
-
if (!currentRange) {
|
23
|
-
return;
|
24
|
-
}
|
25
|
-
currentRange.setDirection(this.isRtl() ? 'NE-SW' : 'NW-SE');
|
26
|
-
const {
|
27
|
-
from,
|
28
|
-
to
|
29
|
-
} = currentRange;
|
30
|
-
plugin.toggleMerge(currentRange);
|
31
|
-
this.selectCell(from.row, from.col, to.row, to.col, false);
|
21
|
+
plugin.toggleMergeOnSelection();
|
32
22
|
},
|
33
23
|
disabled() {
|
34
24
|
const sel = this.getSelectedLast();
|