@deephaven/grid 0.28.1-beta.0 → 0.29.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/dist/ColumnHeaderGroup.d.ts +1 -1
- package/dist/ColumnHeaderGroup.d.ts.map +1 -1
- package/dist/ColumnHeaderGroup.js.map +1 -1
- package/dist/EditableGridModel.d.ts +2 -2
- package/dist/EditableGridModel.d.ts.map +1 -1
- package/dist/EditableGridModel.js.map +1 -1
- package/dist/Grid.d.ts +26 -26
- package/dist/Grid.d.ts.map +1 -1
- package/dist/Grid.js +7 -6
- package/dist/Grid.js.map +1 -1
- package/dist/GridMetricCalculator.d.ts +6 -6
- package/dist/GridMetricCalculator.d.ts.map +1 -1
- package/dist/GridMetricCalculator.js.map +1 -1
- package/dist/GridMetrics.d.ts +8 -8
- package/dist/GridMetrics.d.ts.map +1 -1
- package/dist/GridMetrics.js.map +1 -1
- package/dist/GridRange.d.ts +11 -11
- package/dist/GridRange.d.ts.map +1 -1
- package/dist/GridRange.js +0 -3
- package/dist/GridRange.js.map +1 -1
- package/dist/GridRenderer.d.ts +6 -6
- package/dist/GridRenderer.d.ts.map +1 -1
- package/dist/GridRenderer.js.map +1 -1
- package/dist/GridUtils.d.ts +17 -17
- package/dist/GridUtils.d.ts.map +1 -1
- package/dist/GridUtils.js +11 -10
- package/dist/GridUtils.js.map +1 -1
- package/dist/mouse-handlers/GridColumnMoveMouseHandler.d.ts +1 -1
- package/dist/mouse-handlers/GridColumnMoveMouseHandler.d.ts.map +1 -1
- package/dist/mouse-handlers/GridColumnMoveMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridSeparatorMouseHandler.js +0 -12
- package/dist/mouse-handlers/GridSeparatorMouseHandler.js.map +1 -1
- package/package.json +4 -4
package/dist/GridUtils.d.ts
CHANGED
|
@@ -91,7 +91,7 @@ export declare class GridUtils {
|
|
|
91
91
|
* @param itemSizes The size of each item
|
|
92
92
|
* @returns The item index, or null if no item matches
|
|
93
93
|
*/
|
|
94
|
-
static getItemAtOffset(offset: Coordinate, itemCount: number, floatingStart: number, floatingEnd: number, items: VisibleIndex[], itemCoordinates: CoordinateMap, itemSizes: SizeMap, ignoreFloating?: boolean): VisibleIndex | null;
|
|
94
|
+
static getItemAtOffset(offset: Coordinate, itemCount: number, floatingStart: number, floatingEnd: number, items: readonly VisibleIndex[], itemCoordinates: CoordinateMap, itemSizes: SizeMap, ignoreFloating?: boolean): VisibleIndex | null;
|
|
95
95
|
/**
|
|
96
96
|
* Get the index of the column at the specified x coordinate
|
|
97
97
|
* @param x Coordinate to get the item of
|
|
@@ -114,7 +114,7 @@ export declare class GridUtils {
|
|
|
114
114
|
* @param userSizes The user set sizes
|
|
115
115
|
* @returns Index of the next visible item, or null if no more are visible
|
|
116
116
|
*/
|
|
117
|
-
static getNextShownItem(startIndex: VisibleIndex, modelIndexes: VisibleToModelMap, visibleItems: VisibleIndex[], userSizes: ModelSizeMap): VisibleIndex | null;
|
|
117
|
+
static getNextShownItem(startIndex: VisibleIndex, modelIndexes: VisibleToModelMap, visibleItems: readonly VisibleIndex[], userSizes: ModelSizeMap): VisibleIndex | null;
|
|
118
118
|
/**
|
|
119
119
|
* Iterate backward through the visible columns until a shown column is hit
|
|
120
120
|
* @param columnIndex The column index to start iterating backward from
|
|
@@ -174,7 +174,7 @@ export declare class GridUtils {
|
|
|
174
174
|
* @param visibleItems Visible items
|
|
175
175
|
* @returns Array of items that are hidden
|
|
176
176
|
*/
|
|
177
|
-
static getHiddenItems(itemIndex: VisibleIndex, visibleSizes: SizeMap, visibleItems: VisibleIndex[]): VisibleIndex[];
|
|
177
|
+
static getHiddenItems(itemIndex: VisibleIndex, visibleSizes: SizeMap, visibleItems: readonly VisibleIndex[]): VisibleIndex[];
|
|
178
178
|
/**
|
|
179
179
|
* Get all the columns that are hidden under the same Index
|
|
180
180
|
* @param columnIndex Index of the item to start at
|
|
@@ -212,7 +212,7 @@ export declare class GridUtils {
|
|
|
212
212
|
* @param oldMovedItems The old reordered items
|
|
213
213
|
* @returns The new reordered items
|
|
214
214
|
*/
|
|
215
|
-
static moveItem(from: VisibleIndex, to: VisibleIndex, oldMovedItems: MoveOperation[]): MoveOperation[];
|
|
215
|
+
static moveItem(from: VisibleIndex, to: VisibleIndex, oldMovedItems: readonly MoveOperation[]): MoveOperation[];
|
|
216
216
|
/**
|
|
217
217
|
* Move a visible range in the grid
|
|
218
218
|
*
|
|
@@ -231,7 +231,7 @@ export declare class GridUtils {
|
|
|
231
231
|
* Both will result in [0, 2] -> 1
|
|
232
232
|
* @returns The new reordered items
|
|
233
233
|
*/
|
|
234
|
-
static moveRange(from: BoundedAxisRange, toParam: VisibleIndex, oldMovedItems: MoveOperation[], isPreMoveTo?: boolean): MoveOperation[];
|
|
234
|
+
static moveRange(from: BoundedAxisRange, toParam: VisibleIndex, oldMovedItems: readonly MoveOperation[], isPreMoveTo?: boolean): MoveOperation[];
|
|
235
235
|
static moveItemOrRange(from: VisibleIndex | BoundedAxisRange, to: VisibleIndex, oldMovedItems: MoveOperation[], isPreMoveTo?: boolean): MoveOperation[];
|
|
236
236
|
/**
|
|
237
237
|
* Applies the items moves to the AxisRange
|
|
@@ -241,7 +241,7 @@ export declare class GridUtils {
|
|
|
241
241
|
* @param reverse If the moved items should be applied in reverse (this reverses the effects of the moves)
|
|
242
242
|
* @returns A list of AxisRanges in the translated space. Possibly multiple non-continuous ranges
|
|
243
243
|
*/
|
|
244
|
-
static applyItemMoves<T extends number | GridRangeIndex>(start: T, end: T, movedItems: MoveOperation[], reverse?: boolean): Range<T>[];
|
|
244
|
+
static applyItemMoves<T extends number | GridRangeIndex>(start: T, end: T, movedItems: readonly MoveOperation[], reverse?: boolean): Range<T>[];
|
|
245
245
|
/**
|
|
246
246
|
* Applies the items moves to the givengrid range
|
|
247
247
|
* @param range The grid range to translate
|
|
@@ -250,14 +250,14 @@ export declare class GridUtils {
|
|
|
250
250
|
* @param reverse If the moved items should be reversed (i.e. visible to model range)
|
|
251
251
|
* @returns A list of grid ranges in the translated space. Possibly multiple non-continuous ranges
|
|
252
252
|
*/
|
|
253
|
-
static translateRange(range: GridRange, movedColumns: MoveOperation[], movedRows: MoveOperation[], reverse: boolean): GridRange[];
|
|
253
|
+
static translateRange(range: GridRange, movedColumns: readonly MoveOperation[], movedRows: readonly MoveOperation[], reverse: boolean): GridRange[];
|
|
254
254
|
/**
|
|
255
255
|
* Retrieve the model index given the currently moved items
|
|
256
256
|
* @param visibleIndex The visible index of the item to get the model index for
|
|
257
257
|
* @param movedItems The moved items
|
|
258
258
|
* @returns The model index of the item
|
|
259
259
|
*/
|
|
260
|
-
static getModelIndex(visibleIndex: VisibleIndex, movedItems: MoveOperation[]): ModelIndex;
|
|
260
|
+
static getModelIndex(visibleIndex: VisibleIndex, movedItems: readonly MoveOperation[]): ModelIndex;
|
|
261
261
|
/**
|
|
262
262
|
* Retrieve the model indexes given the currently moved items
|
|
263
263
|
* @param visibleIndexes The visible indexes of the item to get the model indexes for
|
|
@@ -274,7 +274,7 @@ export declare class GridUtils {
|
|
|
274
274
|
* @param movedItems Moved item pairs in this dimension
|
|
275
275
|
* @returns Array of start/end pairs of the indexes after transformations applied.
|
|
276
276
|
*/
|
|
277
|
-
static getModelRangeIndexes(start: GridRangeIndex, end: GridRangeIndex, movedItems: MoveOperation[]): AxisRange[];
|
|
277
|
+
static getModelRangeIndexes(start: GridRangeIndex, end: GridRangeIndex, movedItems: readonly MoveOperation[]): AxisRange[];
|
|
278
278
|
/**
|
|
279
279
|
* Translate the provided UI range into model range, using the `movedColumns` and `movedRows` to apply the necessary transforms.
|
|
280
280
|
* `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items
|
|
@@ -284,7 +284,7 @@ export declare class GridUtils {
|
|
|
284
284
|
* @param movedRows The moved row pairs
|
|
285
285
|
* @returns The model ranges after translation.
|
|
286
286
|
*/
|
|
287
|
-
static getModelRange(uiRange: GridRange, movedColumns?: MoveOperation[], movedRows?: MoveOperation[]): GridRange[];
|
|
287
|
+
static getModelRange(uiRange: GridRange, movedColumns?: readonly MoveOperation[], movedRows?: readonly MoveOperation[]): GridRange[];
|
|
288
288
|
/**
|
|
289
289
|
* Translate the provided UI range into model ranges, using the `movedColumns` and `movedRows` to apply the necessary transforms.
|
|
290
290
|
* `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items
|
|
@@ -294,7 +294,7 @@ export declare class GridUtils {
|
|
|
294
294
|
* @param movedRows The moved row pairs
|
|
295
295
|
* @returns The model ranges after translation.
|
|
296
296
|
*/
|
|
297
|
-
static getModelRanges(uiRanges: GridRange[], movedColumns?: MoveOperation[], movedRows?: MoveOperation[]): GridRange[];
|
|
297
|
+
static getModelRanges(uiRanges: readonly GridRange[], movedColumns?: readonly MoveOperation[], movedRows?: readonly MoveOperation[]): GridRange[];
|
|
298
298
|
/**
|
|
299
299
|
* Translate the provided UI start/end indexes to the visible start/end indexes by applying the `movedItems` transformations.
|
|
300
300
|
* Since moved items can split apart a range, multiple pairs of indexes are returned
|
|
@@ -304,7 +304,7 @@ export declare class GridUtils {
|
|
|
304
304
|
* @param movedItems Moved item pairs in this dimension
|
|
305
305
|
* @returns Array of start/end pairs of the indexes after transformations applied.
|
|
306
306
|
*/
|
|
307
|
-
static getVisibleRangeIndexes(start: GridRangeIndex, end: GridRangeIndex, movedItems: MoveOperation[]): AxisRange[];
|
|
307
|
+
static getVisibleRangeIndexes(start: GridRangeIndex, end: GridRangeIndex, movedItems: readonly MoveOperation[]): AxisRange[];
|
|
308
308
|
/**
|
|
309
309
|
* Translate the provided UI range into visible range, using the `movedColumns` and `movedRows` to apply the necessary transforms.
|
|
310
310
|
* `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items
|
|
@@ -314,7 +314,7 @@ export declare class GridUtils {
|
|
|
314
314
|
* @param movedRows The moved row pairs
|
|
315
315
|
* @returns The model ranges after translation.
|
|
316
316
|
*/
|
|
317
|
-
static getVisibleRange(modelRange: GridRange, movedColumns?: MoveOperation[], movedRows?: MoveOperation[]): GridRange[];
|
|
317
|
+
static getVisibleRange(modelRange: GridRange, movedColumns?: readonly MoveOperation[], movedRows?: readonly MoveOperation[]): GridRange[];
|
|
318
318
|
/**
|
|
319
319
|
* Translate the provided model ranges into visible ranges, using the `movedColumns` and `movedRows` to apply the necessary transforms.
|
|
320
320
|
* `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items
|
|
@@ -324,21 +324,21 @@ export declare class GridUtils {
|
|
|
324
324
|
* @param movedRows The moved row pairs
|
|
325
325
|
* @returns The model ranges after translation.
|
|
326
326
|
*/
|
|
327
|
-
static getVisibleRanges(modelRanges: GridRange[], movedColumns?: MoveOperation[], movedRows?: MoveOperation[]): GridRange[];
|
|
327
|
+
static getVisibleRanges(modelRanges: readonly GridRange[], movedColumns?: readonly MoveOperation[], movedRows?: readonly MoveOperation[]): GridRange[];
|
|
328
328
|
/**
|
|
329
329
|
* Retrieve the visible index given the currently moved items
|
|
330
330
|
* @param modelIndex The model index to get the visible index for
|
|
331
331
|
* @param movedItems Moved items
|
|
332
332
|
* @returns The visible index of the item
|
|
333
333
|
*/
|
|
334
|
-
static getVisibleIndex(modelIndex: ModelIndex, movedItems: MoveOperation[]): VisibleIndex;
|
|
334
|
+
static getVisibleIndex(modelIndex: ModelIndex, movedItems: readonly MoveOperation[]): VisibleIndex;
|
|
335
335
|
/**
|
|
336
336
|
* Retrieve the visible indexes given the currently moved items
|
|
337
337
|
* @param modelIndexes The model indexes to get the visible indexes for
|
|
338
338
|
* @param movedItems Moved items
|
|
339
339
|
* @returns The visible indexes of the item
|
|
340
340
|
*/
|
|
341
|
-
static getVisibleIndexes(modelIndexes: ModelIndex[], movedItems: MoveOperation[]): VisibleIndex[];
|
|
341
|
+
static getVisibleIndexes(modelIndexes: readonly ModelIndex[], movedItems: readonly MoveOperation[]): VisibleIndex[];
|
|
342
342
|
/**
|
|
343
343
|
* Check if the current platform is Mac
|
|
344
344
|
* @returns True if this platform is a Mac, false otherwise
|
|
@@ -368,7 +368,7 @@ export declare class GridUtils {
|
|
|
368
368
|
* @param userColumnWidths The user set column widths
|
|
369
369
|
* @returns True if the user has hidden all of the columns
|
|
370
370
|
*/
|
|
371
|
-
static checkAllColumnsHidden(columns: ModelIndex[], userColumnWidths: ModelSizeMap): boolean;
|
|
371
|
+
static checkAllColumnsHidden(columns: readonly ModelIndex[], userColumnWidths: ModelSizeMap): boolean;
|
|
372
372
|
/**
|
|
373
373
|
* Get the bounds the mouse needs to be dragged outside of from an initial selection before scrolling occurs.
|
|
374
374
|
* Taking into account any floating rows that may be covering the viewport.
|
package/dist/GridUtils.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GridUtils.d.ts","sourceRoot":"","sources":["../src/GridUtils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"GridUtils.d.ts","sourceRoot":"","sources":["../src/GridUtils.ts"],"names":[],"mappings":"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"}
|
package/dist/GridUtils.js
CHANGED
|
@@ -4,6 +4,7 @@ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key i
|
|
|
4
4
|
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
|
5
5
|
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
6
6
|
import clamp from 'lodash.clamp';
|
|
7
|
+
import { EMPTY_ARRAY } from '@deephaven/utils';
|
|
7
8
|
import GridRange from "./GridRange.js";
|
|
8
9
|
import { isBoundedAxisRange } from "./GridAxisRange.js";
|
|
9
10
|
export class GridUtils {
|
|
@@ -559,7 +560,7 @@ export class GridUtils {
|
|
|
559
560
|
*/
|
|
560
561
|
static moveItem(from, to, oldMovedItems) {
|
|
561
562
|
if (from === to) {
|
|
562
|
-
return oldMovedItems;
|
|
563
|
+
return [...oldMovedItems];
|
|
563
564
|
}
|
|
564
565
|
var movedItems = [...oldMovedItems];
|
|
565
566
|
var lastMovedItem = movedItems[movedItems.length - 1];
|
|
@@ -612,7 +613,7 @@ export class GridUtils {
|
|
|
612
613
|
to -= from[1] - from[0];
|
|
613
614
|
}
|
|
614
615
|
if (from[0] === to) {
|
|
615
|
-
return oldMovedItems;
|
|
616
|
+
return [...oldMovedItems];
|
|
616
617
|
}
|
|
617
618
|
var movedItems = [...oldMovedItems];
|
|
618
619
|
var lastMovedItem = movedItems[movedItems.length - 1];
|
|
@@ -796,8 +797,8 @@ export class GridUtils {
|
|
|
796
797
|
* @returns The model ranges after translation.
|
|
797
798
|
*/
|
|
798
799
|
static getModelRange(uiRange) {
|
|
799
|
-
var movedColumns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] :
|
|
800
|
-
var movedRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] :
|
|
800
|
+
var movedColumns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : EMPTY_ARRAY;
|
|
801
|
+
var movedRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : EMPTY_ARRAY;
|
|
801
802
|
return GridUtils.translateRange(uiRange, movedColumns, movedRows, true);
|
|
802
803
|
}
|
|
803
804
|
|
|
@@ -811,8 +812,8 @@ export class GridUtils {
|
|
|
811
812
|
* @returns The model ranges after translation.
|
|
812
813
|
*/
|
|
813
814
|
static getModelRanges(uiRanges) {
|
|
814
|
-
var movedColumns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] :
|
|
815
|
-
var movedRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] :
|
|
815
|
+
var movedColumns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : EMPTY_ARRAY;
|
|
816
|
+
var movedRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : EMPTY_ARRAY;
|
|
816
817
|
var modelRanges = [];
|
|
817
818
|
for (var i = 0; i < uiRanges.length; i += 1) {
|
|
818
819
|
modelRanges.push(...GridUtils.getModelRange(uiRanges[i], movedColumns, movedRows));
|
|
@@ -843,8 +844,8 @@ export class GridUtils {
|
|
|
843
844
|
* @returns The model ranges after translation.
|
|
844
845
|
*/
|
|
845
846
|
static getVisibleRange(modelRange) {
|
|
846
|
-
var movedColumns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] :
|
|
847
|
-
var movedRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] :
|
|
847
|
+
var movedColumns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : EMPTY_ARRAY;
|
|
848
|
+
var movedRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : EMPTY_ARRAY;
|
|
848
849
|
return this.translateRange(modelRange, movedColumns, movedRows, false);
|
|
849
850
|
}
|
|
850
851
|
|
|
@@ -858,8 +859,8 @@ export class GridUtils {
|
|
|
858
859
|
* @returns The model ranges after translation.
|
|
859
860
|
*/
|
|
860
861
|
static getVisibleRanges(modelRanges) {
|
|
861
|
-
var movedColumns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] :
|
|
862
|
-
var movedRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] :
|
|
862
|
+
var movedColumns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : EMPTY_ARRAY;
|
|
863
|
+
var movedRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : EMPTY_ARRAY;
|
|
863
864
|
var visibleRanges = [];
|
|
864
865
|
for (var i = 0; i < modelRanges.length; i += 1) {
|
|
865
866
|
visibleRanges.push(...GridUtils.getVisibleRange(modelRanges[i], movedColumns, movedRows));
|
package/dist/GridUtils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GridUtils.js","names":["clamp","GridRange","isBoundedAxisRange","GridUtils","getGridPointFromXY","x","y","metrics","column","getColumnAtX","row","getRowAtY","columnHeaderDepth","getColumnHeaderDepthAtY","getCellInfoFromXY","allColumnWidths","allRowHeights","allColumnXs","allRowYs","modelColumns","modelRows","modelRow","get","modelColumn","left","top","columnWidth","rowHeight","columnHeaderHeight","columnHeaderMaxDepth","Math","ceil","undefined","iterateFloatingStart","start","total","callback","i","result","iterateFloatingEnd","end","iterateFloating","iterateAllItems","visibleStart","visibleEnd","floatingStartCount","floatingEndCount","totalCount","visibleStartIndex","max","visibleEndIndex","min","isInItem","itemIndex","itemCoordinates","itemSizes","coordinate","itemX","itemSize","getItemAtOffset","offset","itemCount","floatingStart","floatingEnd","items","ignoreFloating","floatingItem","item","length","columnCount","floatingLeftColumnCount","floatingRightColumnCount","visibleColumns","gridX","floatingTopRowCount","floatingBottomRowCount","rowCount","visibleRows","gridY","getNextShownItem","startIndex","modelIndexes","visibleItems","userSizes","visibleItemIndex","findIndex","value","modelIndex","getNextShownColumn","userColumnWidths","getNextShownRow","userRowHeights","getColumnSeparatorIndex","theme","rowHeaderWidth","floatingColumns","floatingLeftWidth","allowColumnResize","headerSeparatorHandleSize","halfSeparatorSize","isPreviousColumnHidden","columnX","isColumnHidden","midX","minX","maxX","isItemHidden","visibleSizes","columnIndex","isFloatingRow","isFloatingColumn","getHiddenItems","hiddenItems","push","getHiddenColumns","getRowSeparatorIndex","allowRowResize","isPreviousRowHidden","rowY","isRowHidden","midY","minY","maxY","rowIndex","getHiddenRows","moveItem","from","to","oldMovedItems","movedItems","lastMovedItem","pop","moveRange","toParam","isPreMoveTo","newLastMovedItem","moveItemOrRange","Array","isArray","applyItemMoves","reverse","fromItemOrRange","toItem","fromItem","fromStart","fromEnd","toStart","moveDistance","nextResult","currentStart","j","Number","NEGATIVE_INFINITY","currentEnd","POSITIVE_INFINITY","movedRange","currentResult","map","s","e","filter","range","flat","isFinite","translateRange","movedColumns","movedRows","columnRanges","startColumn","endColumn","rowRanges","startRow","endRow","ranges","c","r","getModelIndex","visibleIndex","getModelIndexes","visibleIndexes","getModelRangeIndexes","getModelRange","uiRange","getModelRanges","uiRanges","modelRanges","getVisibleRangeIndexes","getVisibleRange","modelRange","getVisibleRanges","visibleRanges","getVisibleIndex","getVisibleIndexes","isMacPlatform","platform","window","navigator","startsWith","getModifierKey","isModifierKeyDown","event","modifierKey","checkColumnHidden","checkAllColumnsHidden","columns","size","every","getScrollDragBounds","width","height","floatingRightWidth","floatingTopHeight","floatingBottomHeight","x1","y1","x2","y2","getScrollDelta","wheelEvent","pageWidth","pageHeight","lineWidth","lineHeight","deltaX","deltaY","shiftKey","deltaMode","WheelEvent","DOM_DELTA_PAGE","DOM_DELTA_LINE","round","PIXELS_PER_LINE","compareRanges","range1","range2","mergeSortedRanges","mergedRanges"],"sources":["../src/GridUtils.ts"],"sourcesContent":["import React from 'react';\nimport clamp from 'lodash.clamp';\nimport GridRange, { GridRangeIndex } from './GridRange';\nimport {\n BoxCoordinates,\n Coordinate,\n CoordinateMap,\n VisibleIndex,\n VisibleToModelMap,\n ModelIndex,\n ModelSizeMap,\n MoveOperation,\n SizeMap,\n} from './GridMetrics';\nimport type { GridMetrics } from './GridMetrics';\nimport { GridTheme } from './GridTheme';\nimport { GridWheelEvent } from './GridMouseHandler';\nimport {\n AxisRange,\n BoundedAxisRange,\n isBoundedAxisRange,\n Range,\n} from './GridAxisRange';\n\nexport type GridPoint = {\n x: Coordinate;\n y: Coordinate;\n column: GridRangeIndex;\n row: GridRangeIndex;\n columnHeaderDepth?: number;\n};\n\nexport interface CellInfo {\n row: VisibleIndex | null;\n column: VisibleIndex | null;\n modelRow: ModelIndex | null;\n modelColumn: ModelIndex | null;\n left: Coordinate | null;\n top: Coordinate | null;\n columnWidth: number | null;\n rowHeight: number | null;\n}\n\nexport type IndexCallback<T> = (itemIndex: VisibleIndex) => T | undefined;\n\nexport class GridUtils {\n // use same constant as chrome source for windows\n // https://github.com/chromium/chromium/blob/973af9d461b6b5dc60208c8d3d66adc27e53da78/ui/events/blink/web_input_event_builders_win.cc#L285\n static PIXELS_PER_LINE = 100 / 3;\n\n /**\n * Get the GridPoint for the coordinates provided\n * @param x The grid x coordinate\n * @param y The grid y coordinate\n * @param metrics The grid metrics\n * @returns The GridPoint including the column/row information\n */\n static getGridPointFromXY(\n x: Coordinate,\n y: Coordinate,\n metrics: GridMetrics\n ): GridPoint {\n const column = GridUtils.getColumnAtX(x, metrics);\n const row = GridUtils.getRowAtY(y, metrics);\n const columnHeaderDepth = GridUtils.getColumnHeaderDepthAtY(y, metrics);\n\n return { x, y, row, column, columnHeaderDepth };\n }\n\n static getCellInfoFromXY(\n x: Coordinate,\n y: Coordinate,\n metrics: GridMetrics\n ): CellInfo {\n const { row, column } = GridUtils.getGridPointFromXY(x, y, metrics);\n\n const {\n allColumnWidths,\n allRowHeights,\n allColumnXs,\n allRowYs,\n modelColumns,\n modelRows,\n } = metrics;\n\n const modelRow = row !== null ? modelRows.get(row) : null;\n const modelColumn = column !== null ? modelColumns.get(column) : null;\n const left = column !== null ? allColumnXs.get(column) : null;\n const top = row !== null ? allRowYs.get(row) : null;\n const columnWidth = column !== null ? allColumnWidths.get(column) : null;\n const rowHeight = row !== null ? allRowHeights.get(row) : null;\n\n return {\n row,\n column,\n modelRow: modelRow ?? null,\n modelColumn: modelColumn ?? null,\n left: left ?? null,\n top: top ?? null,\n columnWidth: columnWidth ?? null,\n rowHeight: rowHeight ?? null,\n };\n }\n\n static getColumnHeaderDepthAtY(\n y: Coordinate,\n metrics: GridMetrics\n ): number | undefined {\n const row = GridUtils.getRowAtY(y, metrics);\n const { columnHeaderHeight, columnHeaderMaxDepth } = metrics;\n\n if (row === null && y <= columnHeaderHeight * columnHeaderMaxDepth) {\n return clamp(\n columnHeaderMaxDepth - Math.ceil(y / columnHeaderHeight),\n 0,\n columnHeaderMaxDepth - 1\n );\n }\n\n return undefined;\n }\n\n /**\n * Iterate through each floating item at the start and call a callback, returning the first result\n * @param start The count of floating items at the start\n * @param total The total number of items\n * @param callback Function to call for each item\n * @returns The result from the callback\n */\n static iterateFloatingStart<T>(\n start: number,\n total: number,\n callback: IndexCallback<T>\n ): T | undefined {\n for (let i = 0; i < start && i < total; i += 1) {\n const result = callback(i);\n if (result !== undefined) {\n return result;\n }\n }\n\n return undefined;\n }\n\n /**\n * Iterate through floating items at the end. Iterates in increasing order.\n * @param end The count of floating items at the end\n * @param total The total number of items\n * @param callback Function to call for each item\n * @returns The result from the callback\n */\n static iterateFloatingEnd<T>(\n end: number,\n total: number,\n callback: IndexCallback<T>\n ): T | undefined {\n for (let i = 0; i < end && total - (end - i) >= 0; i += 1) {\n const result = callback(total - (end - i));\n if (result !== undefined) {\n return result;\n }\n }\n\n return undefined;\n }\n\n /**\n * Iterate through all floating items in increasing order, starting with the top items.\n * @param start Count of start floating rows, e.g. floatingTopRowCount\n * @param end Count of end floating rows, e.g. floatingBottomRowCount\n * @param total Total number of items\n * @param callback Callback called for each value, stopping the iterating and returning the value if one is returned\n */\n static iterateFloating<T>(\n start: number,\n end: number,\n total: number,\n callback: IndexCallback<T>\n ): T | undefined {\n const result = GridUtils.iterateFloatingStart(start, total, callback);\n if (result !== undefined) {\n return result;\n }\n return GridUtils.iterateFloatingEnd(end, total, callback);\n }\n\n /**\n * Iterate through all items in one dimension on the grid - first floating, then visible.\n * Call the callback for each item, break if a result is returned and return that result.\n * @param visibleStart Index of the start of the visible viewport\n * @param visibleEnd Index of the end of the visible viewport\n * @param floatingStartCount Number of items floating at the start\n * @param floatingEndCount Number of items floating at the end\n * @param totalCount Total number of items\n * @param callback Callback to call for each item\n * @returns The first result from the callback called, or undefined\n */\n static iterateAllItems<T>(\n visibleStart: VisibleIndex,\n visibleEnd: VisibleIndex,\n floatingStartCount: number,\n floatingEndCount: number,\n totalCount: number,\n callback: IndexCallback<T>\n ): T | undefined {\n const visibleStartIndex = Math.max(visibleStart, floatingStartCount);\n const visibleEndIndex = Math.min(\n visibleEnd,\n totalCount - floatingEndCount - 1\n );\n let result = GridUtils.iterateFloating(\n floatingStartCount,\n floatingEndCount,\n totalCount,\n callback\n );\n if (result !== undefined) {\n return result;\n }\n\n for (let i = visibleStartIndex; i <= visibleEndIndex; i += 1) {\n result = callback(i);\n if (result !== undefined) {\n return result;\n }\n }\n\n return undefined;\n }\n\n /**\n * Check if the coordinate is within the item specified in this dimension\n * @param itemIndex Index of the item to check\n * @param itemCoordinatess Coordinate of all items in this dimension\n * @param itemSizes Size of all items in this dimension\n * @param coordinate The coordinate to check\n * @returns True if the coordinate is within the item specified, false otherwise\n */\n static isInItem(\n itemIndex: VisibleIndex,\n itemCoordinates: CoordinateMap,\n itemSizes: SizeMap,\n coordinate: Coordinate\n ): boolean {\n const itemX = itemCoordinates.get(itemIndex) ?? 0;\n const itemSize = itemSizes.get(itemIndex) ?? 0;\n return itemX <= coordinate && coordinate <= itemX + itemSize;\n }\n\n /**\n * Get the Index of the item at the provided offset\n * @param offset Coordinate of the offset to get the item of\n * @param itemCount The total count of items\n * @param floatingStart Count of floating items at the start\n * @param floatingEnd Count of floating items at the end\n * @param items Index of all items\n * @param itemCoordinates The coordinate of each item\n * @param itemSizes The size of each item\n * @returns The item index, or null if no item matches\n */\n static getItemAtOffset(\n offset: Coordinate,\n itemCount: number,\n floatingStart: number,\n floatingEnd: number,\n items: VisibleIndex[],\n itemCoordinates: CoordinateMap,\n itemSizes: SizeMap,\n ignoreFloating = false\n ): VisibleIndex | null {\n const floatingItem = ignoreFloating\n ? undefined\n : GridUtils.iterateFloating(\n floatingStart,\n floatingEnd,\n itemCount,\n item => {\n if (GridUtils.isInItem(item, itemCoordinates, itemSizes, offset)) {\n return item;\n }\n return undefined;\n }\n );\n if (!ignoreFloating && floatingItem !== undefined) {\n return floatingItem;\n }\n\n for (let i = 0; i < items.length; i += 1) {\n const item = items[i];\n if (GridUtils.isInItem(item, itemCoordinates, itemSizes, offset)) {\n return item;\n }\n }\n\n return null;\n }\n\n /**\n * Get the index of the column at the specified x coordinate\n * @param x Coordinate to get the item of\n * @param metrics Grid metrics\n * @returns Index of the column at that coordinate, or null if no column matches\n */\n static getColumnAtX(\n x: Coordinate,\n metrics: GridMetrics,\n ignoreFloating = false\n ): VisibleIndex | null {\n const {\n columnCount,\n floatingLeftColumnCount,\n floatingRightColumnCount,\n visibleColumns,\n allColumnXs,\n allColumnWidths,\n gridX,\n } = metrics;\n\n if (x < gridX) {\n return null;\n }\n\n return this.getItemAtOffset(\n x - gridX,\n columnCount,\n floatingLeftColumnCount,\n floatingRightColumnCount,\n visibleColumns,\n allColumnXs,\n allColumnWidths,\n ignoreFloating\n );\n }\n\n /**\n * Get the index of the row at the specified y coordinate\n * @param y Coordinate to get the item of\n * @param metrics Grid metrics\n * @returns Index of the row at that coordinate, or null if no row matches\n */\n static getRowAtY(y: Coordinate, metrics: GridMetrics): VisibleIndex | null {\n const {\n floatingTopRowCount,\n floatingBottomRowCount,\n rowCount,\n visibleRows,\n allRowYs,\n allRowHeights,\n gridY,\n } = metrics;\n\n if (y < gridY) {\n return null;\n }\n\n return this.getItemAtOffset(\n y - gridY,\n rowCount,\n floatingTopRowCount,\n floatingBottomRowCount,\n visibleRows,\n allRowYs,\n allRowHeights\n );\n }\n\n /**\n * Iterate backward through the visible items until a shown item is hit\n * @param startIndex The index to start from\n * @param modelIndexes The mapping of model indexes\n * @param visibleItems The visible items\n * @param userSizes The user set sizes\n * @returns Index of the next visible item, or null if no more are visible\n */\n static getNextShownItem(\n startIndex: VisibleIndex,\n modelIndexes: VisibleToModelMap,\n visibleItems: VisibleIndex[],\n userSizes: ModelSizeMap\n ): VisibleIndex | null {\n let visibleItemIndex =\n visibleItems.findIndex(value => value === startIndex) || 0;\n visibleItemIndex -= 1;\n while (visibleItemIndex != null && visibleItemIndex >= 0) {\n const item = visibleItems[visibleItemIndex];\n const modelIndex = modelIndexes.get(item);\n if (modelIndex != null && userSizes.get(modelIndex) !== 0) {\n return item;\n }\n\n visibleItemIndex -= 1;\n }\n\n return null;\n }\n\n /**\n * Iterate backward through the visible columns until a shown column is hit\n * @param columnIndex The column index to start iterating backward from\n * @param metrics The GridMetricCalculator metrics\n * @returns Index of the next visible item, or null if no more are visible\n */\n static getNextShownColumn(\n startIndex: VisibleIndex,\n metrics: GridMetrics\n ): VisibleIndex | null {\n const { modelColumns, visibleColumns, userColumnWidths } = metrics;\n return GridUtils.getNextShownItem(\n startIndex,\n modelColumns,\n visibleColumns,\n userColumnWidths\n );\n }\n\n /**\n * Iterate backward through the visible rows until a shown row is hit\n * @param rowIndex The row index to start iterating backward from\n * @param metrics The GridMetricCalculator metrics\n * @returns Index of the next visible item, or null if no more are visible\n */\n static getNextShownRow(\n startIndex: VisibleIndex,\n metrics: GridMetrics\n ): VisibleIndex | null {\n const { modelRows, visibleRows, userRowHeights } = metrics;\n return GridUtils.getNextShownItem(\n startIndex,\n modelRows,\n visibleRows,\n userRowHeights\n );\n }\n\n /**\n * Gets the column index if the x/y coordinates provided are close enough to the separator, otherwise null\n * @param x Mouse x coordinate\n * @param y Mouse y coordinate\n * @param metrics The grid metrics\n * @param theme The grid theme with potential user overrides\n * @returns Index of the column separator at the coordinates provided, or null if none match\n */\n static getColumnSeparatorIndex(\n x: Coordinate,\n y: Coordinate,\n metrics: GridMetrics,\n theme: GridTheme\n ): VisibleIndex | null {\n const {\n rowHeaderWidth,\n columnHeaderHeight,\n floatingColumns,\n floatingLeftWidth,\n visibleColumns,\n allColumnXs,\n allColumnWidths,\n columnHeaderMaxDepth,\n } = metrics;\n const { allowColumnResize, headerSeparatorHandleSize } = theme;\n\n if (\n columnHeaderMaxDepth * columnHeaderHeight < y ||\n !allowColumnResize ||\n headerSeparatorHandleSize <= 0\n ) {\n return null;\n }\n\n const gridX = x - rowHeaderWidth;\n const halfSeparatorSize = headerSeparatorHandleSize * 0.5;\n\n // Iterate through the floating columns first since they're on top\n let isPreviousColumnHidden = false;\n for (let i = floatingColumns.length - 1; i >= 0; i -= 1) {\n const column = floatingColumns[i];\n const columnX = allColumnXs.get(column) ?? 0;\n const columnWidth = allColumnWidths.get(column) ?? 0;\n const isColumnHidden = columnWidth === 0;\n if (!isPreviousColumnHidden || !isColumnHidden) {\n let midX = columnX + columnWidth;\n if (isColumnHidden) {\n midX += halfSeparatorSize;\n } else if (isPreviousColumnHidden) {\n midX -= halfSeparatorSize;\n }\n\n const minX = midX - halfSeparatorSize;\n const maxX = midX + halfSeparatorSize;\n if (minX <= gridX && gridX <= maxX) {\n return column;\n }\n\n isPreviousColumnHidden = isColumnHidden;\n }\n }\n\n // Iterate backward so that you can reveal hidden columns properly\n isPreviousColumnHidden = false;\n for (let i = visibleColumns.length - 1; i >= 0; i -= 1) {\n const column = visibleColumns[i];\n const columnX = allColumnXs.get(column) ?? 0;\n const columnWidth = allColumnWidths.get(column) ?? 0;\n const isColumnHidden = columnWidth === 0;\n\n // If this column is under the floating columns \"layer\". Terminate early.\n if (columnX < floatingLeftWidth - columnWidth) {\n return null;\n }\n\n if (!isPreviousColumnHidden || !isColumnHidden) {\n let midX = columnX + columnWidth;\n if (isColumnHidden) {\n midX += halfSeparatorSize;\n } else if (isPreviousColumnHidden) {\n midX -= halfSeparatorSize;\n }\n\n const minX = midX - halfSeparatorSize;\n const maxX = midX + halfSeparatorSize;\n if (minX <= gridX && gridX <= maxX) {\n return column;\n }\n\n isPreviousColumnHidden = isColumnHidden;\n }\n }\n\n return null;\n }\n\n /**\n * Check if the item specified is hidden\n * @param itemIndex Index of the item to check\n * @param visibleSizes Sizes of all visible items\n * @returns True if the item is hidden, false otherwise\n */\n static isItemHidden(itemIndex: VisibleIndex, visibleSizes: SizeMap): boolean {\n return visibleSizes.get(itemIndex) === 0;\n }\n\n /**\n * Check if the column specified is hidden\n * @param columnIndex Index of the column to check\n * @param metrics Grid metrics\n * @returns True if the column is hidden, false otherwise\n */\n static isColumnHidden(\n columnIndex: VisibleIndex,\n metrics: GridMetrics\n ): boolean {\n const { allColumnWidths } = metrics;\n return GridUtils.isItemHidden(columnIndex, allColumnWidths);\n }\n\n /**\n * Check if the provided row is a floating row\n * @param row The row index to check\n * @param metrics The grid metrics to check against\n * @returns True if it's a floating row, false otherwise\n */\n static isFloatingRow(row: VisibleIndex, metrics: GridMetrics): boolean {\n if (row == null) {\n return false;\n }\n\n const { floatingTopRowCount, floatingBottomRowCount, rowCount } = metrics;\n return (\n row < floatingTopRowCount || row >= rowCount - floatingBottomRowCount\n );\n }\n\n /**\n * Check if the provided column is a floating column\n * @param column The column index to check\n * @param metrics The grid metrics to check against\n * @returns True if it's a floating column, false otherwise\n */\n static isFloatingColumn(column: VisibleIndex, metrics: GridMetrics): boolean {\n if (column == null) {\n return false;\n }\n\n const {\n floatingLeftColumnCount,\n floatingRightColumnCount,\n columnCount,\n } = metrics;\n return (\n column < floatingLeftColumnCount ||\n column >= columnCount - floatingRightColumnCount\n );\n }\n\n /**\n * Get all the items that are hidden under the same Index\n * E.g. If columns are 1, 2, 3, 4, 5, and column 2, 3, 4 are hidden, and we check for item 4, the return will be [2, 3, 4]\n * @param itemIndex Index of the item to start at\n * @param visibleSizes Visible size map\n * @param visibleItems Visible items\n * @returns Array of items that are hidden\n */\n static getHiddenItems(\n itemIndex: VisibleIndex,\n visibleSizes: SizeMap,\n visibleItems: VisibleIndex[]\n ): VisibleIndex[] {\n if (!GridUtils.isItemHidden(itemIndex, visibleSizes)) {\n return [];\n }\n\n const hiddenItems = [itemIndex];\n const visibleItemIndex = visibleItems.findIndex(\n value => value === itemIndex\n );\n for (let i = visibleItemIndex - 1; i >= 0; i -= 1) {\n const item = visibleItems[i];\n if (!GridUtils.isItemHidden(item, visibleSizes)) {\n break;\n }\n\n hiddenItems.push(item);\n }\n\n return hiddenItems;\n }\n\n /**\n * Get all the columns that are hidden under the same Index\n * @param columnIndex Index of the item to start at\n * @param metrics Grid metrics\n * @returns Array of items that are hidden\n */\n static getHiddenColumns(\n columnIndex: VisibleIndex,\n metrics: GridMetrics\n ): VisibleIndex[] {\n const { visibleColumns, allColumnWidths } = metrics;\n return GridUtils.getHiddenItems(\n columnIndex,\n allColumnWidths,\n visibleColumns\n );\n }\n\n /**\n * Returns the row index if the x/y coordinates provided are close enough to the separator, otherwise null\n * @param x X coordinate to check\n * @param y Y coordinate to check\n * @param metrics The grid metrics\n * @param theme The grid theme\n * @returns Index of the row separator at the coordinates provided, or null if none match\n */\n static getRowSeparatorIndex(\n x: Coordinate,\n y: Coordinate,\n metrics: GridMetrics,\n theme: GridTheme\n ): VisibleIndex | null {\n const {\n rowHeaderWidth,\n columnHeaderHeight,\n visibleRows,\n allRowYs,\n allRowHeights,\n } = metrics;\n const { allowRowResize, headerSeparatorHandleSize } = theme;\n\n if (\n rowHeaderWidth < x ||\n !allowRowResize ||\n headerSeparatorHandleSize <= 0\n ) {\n return null;\n }\n\n const gridY = y - columnHeaderHeight;\n const halfSeparatorSize = headerSeparatorHandleSize * 0.5;\n\n // Iterate backward so you can reveal hidden rows properly\n let isPreviousRowHidden = false;\n for (let i = visibleRows.length - 1; i >= 0; i -= 1) {\n const row = visibleRows[i];\n const rowY = allRowYs.get(row) ?? 0;\n const rowHeight = allRowHeights.get(row) ?? 0;\n const isRowHidden = rowHeight === 0;\n if (!isPreviousRowHidden || !isRowHidden) {\n let midY = rowY + rowHeight;\n if (isRowHidden) {\n midY += halfSeparatorSize;\n } else if (isPreviousRowHidden) {\n midY -= halfSeparatorSize;\n }\n\n const minY = midY - halfSeparatorSize;\n const maxY = midY + halfSeparatorSize;\n\n if (minY <= gridY && gridY <= maxY) {\n return row;\n }\n\n isPreviousRowHidden = isRowHidden;\n }\n }\n\n return null;\n }\n\n /**\n * Check if the row specified is hidden\n * @param rowIndex Index of the row to check\n * @param metrics Grid metrics\n * @returns True if the row is hidden, false otherwise\n */\n static isRowHidden(rowIndex: VisibleIndex, metrics: GridMetrics): boolean {\n const { allRowHeights } = metrics;\n return GridUtils.isItemHidden(rowIndex, allRowHeights);\n }\n\n /**\n * Get all the rows that are hidden under the same Index\n * @param rowIndex Index of the item to start at\n * @param metrics Grid metrics\n * @returns Array of items that are hidden\n */\n static getHiddenRows(\n rowIndex: VisibleIndex,\n metrics: GridMetrics\n ): VisibleIndex[] {\n const { visibleRows, allRowHeights } = metrics;\n return GridUtils.getHiddenItems(rowIndex, allRowHeights, visibleRows);\n }\n\n /**\n * Set a new order for items in the grid\n * @param from The visible index to move from\n * @param to The visible index to move the item to\n * @param oldMovedItems The old reordered items\n * @returns The new reordered items\n */\n static moveItem(\n from: VisibleIndex,\n to: VisibleIndex,\n oldMovedItems: MoveOperation[]\n ): MoveOperation[] {\n if (from === to) {\n return oldMovedItems;\n }\n\n const movedItems: MoveOperation[] = [...oldMovedItems];\n const lastMovedItem = movedItems[movedItems.length - 1];\n\n // Check if we should combine with the previous move\n // E.g. 1 -> 2, 2 -> 3 can just be 1 -> 3\n if (\n lastMovedItem != null &&\n !isBoundedAxisRange(lastMovedItem.from) &&\n lastMovedItem.to === from\n ) {\n // Remove the move if it is now a no-op\n if (lastMovedItem.from === to) {\n movedItems.pop();\n } else {\n movedItems[movedItems.length - 1] = {\n ...lastMovedItem,\n to,\n };\n }\n } else {\n movedItems.push({ from, to });\n }\n\n return movedItems;\n }\n\n /**\n * Move a visible range in the grid\n *\n * This will effectively slice the range out of the grid,\n * re-index the remaining columns,\n * then insert the range with the first element at the provided index\n *\n * @param from The visible axis range to move\n * @param to The visible index to move the start of the range to\n * @param oldMovedItems The old reordered items\n * @param isPreMoveTo If toParam is the index before the movement\n * If true, this will account for the shift when moving\n * a range before the drop positin\n * E.g. Move range [0, 2] 1 item down (after element 3)\n * The move is [0, 2] -> 1 if this is false. [0, 2] -> 3 if this is true\n * Both will result in [0, 2] -> 1\n * @returns The new reordered items\n */\n static moveRange(\n from: BoundedAxisRange,\n toParam: VisibleIndex,\n oldMovedItems: MoveOperation[],\n isPreMoveTo = false\n ): MoveOperation[] {\n if (from[0] === from[1]) {\n return GridUtils.moveItem(from[0], toParam, oldMovedItems);\n }\n\n let to = toParam;\n\n if (isPreMoveTo && from[0] < toParam) {\n to -= from[1] - from[0];\n }\n\n if (from[0] === to) {\n return oldMovedItems;\n }\n\n const movedItems: MoveOperation[] = [...oldMovedItems];\n const lastMovedItem = movedItems[movedItems.length - 1];\n\n // Check if we should combine with the previous move\n // E.g. [1, 2] -> 2, [2, 3] -> 3 can just be [1, 2] -> 3\n if (\n lastMovedItem != null &&\n isBoundedAxisRange(lastMovedItem.from) &&\n lastMovedItem.from[1] - lastMovedItem.from[0] === from[1] - from[0] &&\n lastMovedItem.to === from[0]\n ) {\n movedItems[movedItems.length - 1] = {\n ...lastMovedItem,\n to,\n };\n } else {\n movedItems.push({ from, to });\n }\n\n const newLastMovedItem = movedItems[movedItems.length - 1];\n // Remove the move if it is now a no-op\n if (\n isBoundedAxisRange(newLastMovedItem.from) &&\n newLastMovedItem.from[0] === newLastMovedItem.to\n ) {\n movedItems.pop();\n }\n\n return movedItems;\n }\n\n static moveItemOrRange(\n from: VisibleIndex | BoundedAxisRange,\n to: VisibleIndex,\n oldMovedItems: MoveOperation[],\n isPreMoveTo = false\n ): MoveOperation[] {\n return Array.isArray(from)\n ? GridUtils.moveRange(from, to, oldMovedItems, isPreMoveTo)\n : GridUtils.moveItem(from, to, oldMovedItems);\n }\n\n /**\n * Applies the items moves to the AxisRange\n * @param start The start index of the range\n * @param end The end index of the range\n * @param movedItems The move operations to apply\n * @param reverse If the moved items should be applied in reverse (this reverses the effects of the moves)\n * @returns A list of AxisRanges in the translated space. Possibly multiple non-continuous ranges\n */\n static applyItemMoves<T extends number | GridRangeIndex>(\n start: T,\n end: T,\n movedItems: MoveOperation[],\n reverse = false\n ): Range<T>[] {\n let result: Range<T>[] = [[start, end]];\n\n for (\n let i = reverse ? movedItems.length - 1 : 0;\n reverse ? i >= 0 : i < movedItems.length;\n reverse ? (i -= 1) : (i += 1)\n ) {\n const { from: fromItemOrRange, to: toItem } = movedItems[i];\n let length = 1;\n let fromItem: number;\n if (isBoundedAxisRange(fromItemOrRange)) {\n length = fromItemOrRange[1] - fromItemOrRange[0] + 1; // Ranges are inclusive\n [fromItem] = fromItemOrRange;\n } else {\n fromItem = fromItemOrRange;\n }\n\n const fromStart = reverse ? toItem : fromItem;\n const fromEnd = fromStart + length - 1;\n const toStart = reverse ? fromItem : toItem;\n const moveDistance = toStart - fromStart;\n\n const nextResult: Range<number>[] = [];\n for (let j = 0; j < result.length; j += 1) {\n const currentStart = result[j][0] ?? Number.NEGATIVE_INFINITY;\n const currentEnd = result[j][1] ?? Number.POSITIVE_INFINITY;\n\n let movedRange: Range<number> | undefined;\n const currentResult: Range<number>[] = [\n [currentStart, fromStart - 1],\n [fromStart, fromEnd],\n [fromEnd + 1, currentEnd],\n ]\n .map(\n ([s, e]): Range<number> => [\n // Cap the ranges to within the current range bounds\n Math.max(s, currentStart),\n Math.min(e, currentEnd),\n ]\n )\n .filter(([s, e]) => s <= e) // Remove invalid ranges\n .map(\n (range): Range<number> => {\n const [s, e] = range;\n if (fromStart <= s && fromEnd >= e) {\n // Current range in moved range\n movedRange = [s + moveDistance, e + moveDistance];\n return movedRange;\n }\n\n if (fromEnd < s) {\n // Current range is after moved range\n return [s - length, e - length];\n }\n return range;\n }\n )\n .map((range): Range<number>[] => {\n const [s, e] = range;\n if (toStart > s && toStart <= e) {\n // Moved range splits this range\n return [\n [s, toStart - 1],\n [toStart + length, e + length],\n ];\n }\n\n if (range === movedRange) {\n // Moved range has already been shifted\n return [range];\n }\n\n if (toStart <= s) {\n // Moved range shifts this range right\n return [[s + length, e + length]];\n }\n return [range];\n })\n .flat();\n\n nextResult.push(...currentResult);\n }\n\n // Return infinity values back to null\n result = nextResult.map(([s, e]) => [\n Number.isFinite(s) ? s : null,\n Number.isFinite(e) ? e : null,\n ]) as Range<T>[];\n }\n return result;\n }\n\n /**\n * Applies the items moves to the givengrid range\n * @param range The grid range to translate\n * @param movedColumns The moved columns\n * @param movedRows The moved rows\n * @param reverse If the moved items should be reversed (i.e. visible to model range)\n * @returns A list of grid ranges in the translated space. Possibly multiple non-continuous ranges\n */\n static translateRange(\n range: GridRange,\n movedColumns: MoveOperation[],\n movedRows: MoveOperation[],\n reverse: boolean\n ): GridRange[] {\n const columnRanges = GridUtils.applyItemMoves(\n range.startColumn,\n range.endColumn,\n movedColumns,\n reverse\n );\n const rowRanges = GridUtils.applyItemMoves(\n range.startRow,\n range.endRow,\n movedRows,\n reverse\n );\n const ranges: GridRange[] = [];\n for (let i = 0; i < columnRanges.length; i += 1) {\n const c = columnRanges[i];\n for (let j = 0; j < rowRanges.length; j += 1) {\n const r = rowRanges[j];\n ranges.push(new GridRange(c[0], r[0], c[1], r[1]));\n }\n }\n return ranges;\n }\n\n /**\n * Retrieve the model index given the currently moved items\n * @param visibleIndex The visible index of the item to get the model index for\n * @param movedItems The moved items\n * @returns The model index of the item\n */\n static getModelIndex(\n visibleIndex: VisibleIndex,\n movedItems: MoveOperation[]\n ): ModelIndex {\n const modelIndex = GridUtils.applyItemMoves(\n visibleIndex,\n visibleIndex,\n movedItems,\n true\n )[0][0];\n\n return modelIndex;\n }\n\n /**\n * Retrieve the model indexes given the currently moved items\n * @param visibleIndexes The visible indexes of the item to get the model indexes for\n * @param movedItems The moved items\n * @returns The model indexes of the item\n */\n static getModelIndexes(\n visibleIndexes: ModelIndex[],\n movedItems: MoveOperation[]\n ): VisibleIndex[] {\n return visibleIndexes.map(i => GridUtils.getModelIndex(i, movedItems));\n }\n\n /**\n * Translate the provided UI start/end indexes to the model start/end indexes by applying the `movedItems` transformations.\n * Since moved items can split apart a range, multiple pairs of indexes are returned\n *\n * @param start Start item in one dimension\n * @param end End item in one dimension\n * @param movedItems Moved item pairs in this dimension\n * @returns Array of start/end pairs of the indexes after transformations applied.\n */\n static getModelRangeIndexes(\n start: GridRangeIndex,\n end: GridRangeIndex,\n movedItems: MoveOperation[]\n ): AxisRange[] {\n return GridUtils.applyItemMoves(start, end, movedItems, true);\n }\n\n /**\n * Translate the provided UI range into model range, using the `movedColumns` and `movedRows` to apply the necessary transforms.\n * `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items\n *\n * @param uiRange The currently selected UI ranges\n * @param movedColumns The moved column pairs\n * @param movedRows The moved row pairs\n * @returns The model ranges after translation.\n */\n static getModelRange(\n uiRange: GridRange,\n movedColumns: MoveOperation[] = [],\n movedRows: MoveOperation[] = []\n ): GridRange[] {\n return GridUtils.translateRange(uiRange, movedColumns, movedRows, true);\n }\n\n /**\n * Translate the provided UI range into model ranges, using the `movedColumns` and `movedRows` to apply the necessary transforms.\n * `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items\n *\n * @param uiRanges The currently selected UI ranges\n * @param movedColumns The moved column pairs\n * @param movedRows The moved row pairs\n * @returns The model ranges after translation.\n */\n static getModelRanges(\n uiRanges: GridRange[],\n movedColumns: MoveOperation[] = [],\n movedRows: MoveOperation[] = []\n ): GridRange[] {\n const modelRanges = [];\n for (let i = 0; i < uiRanges.length; i += 1) {\n modelRanges.push(\n ...GridUtils.getModelRange(uiRanges[i], movedColumns, movedRows)\n );\n }\n return modelRanges;\n }\n\n /**\n * Translate the provided UI start/end indexes to the visible start/end indexes by applying the `movedItems` transformations.\n * Since moved items can split apart a range, multiple pairs of indexes are returned\n *\n * @param start Start item in one dimension\n * @param end End item in one dimension\n * @param movedItems Moved item pairs in this dimension\n * @returns Array of start/end pairs of the indexes after transformations applied.\n */\n static getVisibleRangeIndexes(\n start: GridRangeIndex,\n end: GridRangeIndex,\n movedItems: MoveOperation[]\n ): AxisRange[] {\n return GridUtils.applyItemMoves(start, end, movedItems, false);\n }\n\n /**\n * Translate the provided UI range into visible range, using the `movedColumns` and `movedRows` to apply the necessary transforms.\n * `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items\n *\n * @param uiRange The currently selected UI ranges\n * @param movedColumns The moved column pairs\n * @param movedRows The moved row pairs\n * @returns The model ranges after translation.\n */\n static getVisibleRange(\n modelRange: GridRange,\n movedColumns: MoveOperation[] = [],\n movedRows: MoveOperation[] = []\n ): GridRange[] {\n return this.translateRange(modelRange, movedColumns, movedRows, false);\n }\n\n /**\n * Translate the provided model ranges into visible ranges, using the `movedColumns` and `movedRows` to apply the necessary transforms.\n * `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items\n *\n * @param modelRanges The model ranges\n * @param movedColumns The moved column pairs\n * @param movedRows The moved row pairs\n * @returns The model ranges after translation.\n */\n static getVisibleRanges(\n modelRanges: GridRange[],\n movedColumns: MoveOperation[] = [],\n movedRows: MoveOperation[] = []\n ): GridRange[] {\n const visibleRanges = [];\n for (let i = 0; i < modelRanges.length; i += 1) {\n visibleRanges.push(\n ...GridUtils.getVisibleRange(modelRanges[i], movedColumns, movedRows)\n );\n }\n return visibleRanges;\n }\n\n /**\n * Retrieve the visible index given the currently moved items\n * @param modelIndex The model index to get the visible index for\n * @param movedItems Moved items\n * @returns The visible index of the item\n */\n static getVisibleIndex(\n modelIndex: ModelIndex,\n movedItems: MoveOperation[]\n ): VisibleIndex {\n const visibleIndex = GridUtils.applyItemMoves(\n modelIndex,\n modelIndex,\n movedItems\n )[0][0];\n\n return visibleIndex;\n }\n\n /**\n * Retrieve the visible indexes given the currently moved items\n * @param modelIndexes The model indexes to get the visible indexes for\n * @param movedItems Moved items\n * @returns The visible indexes of the item\n */\n static getVisibleIndexes(\n modelIndexes: ModelIndex[],\n movedItems: MoveOperation[]\n ): VisibleIndex[] {\n return modelIndexes.map(i => GridUtils.getVisibleIndex(i, movedItems));\n }\n\n /**\n * Check if the current platform is Mac\n * @returns True if this platform is a Mac, false otherwise\n */\n static isMacPlatform(): boolean {\n const { platform } = window.navigator;\n return platform.startsWith('Mac');\n }\n\n /**\n * Get the modifier key for the current platform\n * @returns The modifier key for the current platform\n */\n static getModifierKey(): 'metaKey' | 'ctrlKey' {\n if (GridUtils.isMacPlatform()) {\n return 'metaKey';\n }\n\n return 'ctrlKey';\n }\n\n /**\n * Check if the modifier key is down for the given event\n * @param event The event to check\n * @returns True if the modifier key is down, false otherwise\n */\n static isModifierKeyDown(\n event: MouseEvent | KeyboardEvent | React.KeyboardEvent | React.MouseEvent\n ): boolean {\n const modifierKey = GridUtils.getModifierKey();\n return event[modifierKey];\n }\n\n /**\n * Check if the user has hidden the specified column\n * @param modelIndex The model index to check\n * @param userColumnWidths The user set column widths\n * @returns True if the user has hidden the column\n */\n static checkColumnHidden(\n modelIndex: ModelIndex,\n userColumnWidths: ModelSizeMap\n ): boolean {\n return userColumnWidths.get(modelIndex) === 0;\n }\n\n /**\n * Check if all the columns specified are hidden\n * @param columns Columns to check\n * @param userColumnWidths The user set column widths\n * @returns True if the user has hidden all of the columns\n */\n static checkAllColumnsHidden(\n columns: ModelIndex[],\n userColumnWidths: ModelSizeMap\n ): boolean {\n if (userColumnWidths.size === 0) {\n return false;\n }\n return columns.every(column => userColumnWidths.get(column) === 0);\n }\n\n /**\n * Get the bounds the mouse needs to be dragged outside of from an initial selection before scrolling occurs.\n * Taking into account any floating rows that may be covering the viewport.\n * @param metrics Grid metrics\n * @param row The row they started dragging in\n * @param column The column they started the drag from\n * @returns Dimensions of the drag area in relation to the canvas they need to drag outside of to start scrolling\n */\n static getScrollDragBounds(\n metrics: GridMetrics,\n row: GridRangeIndex,\n column: GridRangeIndex\n ): BoxCoordinates {\n const {\n gridX,\n gridY,\n width,\n height,\n floatingTopRowCount,\n floatingBottomRowCount,\n floatingLeftColumnCount,\n floatingRightColumnCount,\n floatingLeftWidth,\n floatingRightWidth,\n floatingTopHeight,\n floatingBottomHeight,\n columnCount,\n rowCount,\n } = metrics;\n let x1 = gridX;\n let y1 = gridY;\n let x2 = width;\n let y2 = height;\n if (column != null) {\n if (column > floatingLeftColumnCount) {\n x1 += floatingLeftWidth;\n }\n if (column < columnCount - floatingRightColumnCount) {\n x2 -= floatingRightWidth;\n }\n }\n\n if (row != null) {\n if (row > floatingTopRowCount) {\n y1 += floatingTopHeight;\n }\n if (row < rowCount - floatingBottomRowCount) {\n y2 -= floatingBottomHeight;\n }\n }\n return { x1, y1, x2, y2 };\n }\n\n /**\n * Converts the delta coordinates from the provided wheel event to pixels\n * Different platforms have different ways of providing the delta so this normalizes it\n * @param wheelEvent The mouse wheel event to get the scrolling delta for\n * @param pageWidth The width of the page that is scrolling\n * @param pageHeight The height of the page that is scrolling\n * @param lineWidth The width of the line scrolling in line mode\n * @param lineHeight The height of the line scrolling in line mode\n * @returns The delta coordinates normalized to pixels\n */\n static getScrollDelta(\n wheelEvent: GridWheelEvent,\n pageWidth = 1024,\n pageHeight = 768,\n lineWidth = 20,\n lineHeight = 20\n ): { deltaX: number; deltaY: number } {\n let { deltaX, deltaY } = wheelEvent;\n\n // Flip scroll direction if shiftKey is held on windows/linux.\n // On mac, deltaX/Y values are switched at the event level when shiftKey=true.\n // Guard on strictly Y only changing, to ignore trackpad diagonal motion,\n // through that guard may not be necessary, but it is difficult to determine for\n // all platforms/browser/scroll method combos.\n if (\n !GridUtils.isMacPlatform() &&\n wheelEvent.shiftKey &&\n wheelEvent.deltaX === 0 &&\n wheelEvent.deltaY !== 0\n ) {\n deltaX = wheelEvent.deltaY;\n deltaY = wheelEvent.deltaX;\n }\n\n // Normalize other deltaMode values to pixel units\n // deltaMode 0, is already in pixel units\n if (wheelEvent?.deltaMode === WheelEvent.DOM_DELTA_PAGE) {\n // Users can set OS to be in deltaMode page\n // scrolly by page units as pixels\n deltaX *= pageWidth;\n deltaY *= pageHeight;\n } else if (wheelEvent?.deltaMode === WheelEvent.DOM_DELTA_LINE) {\n // Firefox reports deltaMode line\n // Normalize distance travelled between browsers\n // but remain ~platform/browser combo consistent\n if (GridUtils.isMacPlatform()) {\n // for mac treat lines as a standard row height\n // on mac, firefox travels less distance then chrome per tick\n deltaX = Math.round(deltaX * lineWidth);\n deltaY = Math.round(deltaY * lineHeight);\n } else {\n // for windows convert to pixels using the same method as chrome\n // chrome goes 100 per 3 lines, and firefox would go 102 per 3 (17 lineheight * 3 lines * 2)\n // make the behaviour the same between as it's close enough\n deltaX = Math.round(deltaX * this.PIXELS_PER_LINE);\n deltaY = Math.round(deltaY * this.PIXELS_PER_LINE);\n }\n }\n\n return { deltaX, deltaY };\n }\n\n static compareRanges(range1: AxisRange, range2: AxisRange): number {\n if (\n range1[0] == null ||\n range1[1] == null ||\n range2[0] == null ||\n range2[1] == null\n ) {\n return 0;\n }\n return range1[0] !== range2[0]\n ? range1[0] - range2[0]\n : range1[1] - range2[1];\n }\n\n static mergeSortedRanges(ranges: BoundedAxisRange[]): BoundedAxisRange[] {\n const mergedRanges: BoundedAxisRange[] = [];\n\n for (let i = 0; i < ranges.length; i += 1) {\n const range = ranges[i];\n const start = range[0];\n const end = range[1];\n if (i === 0) {\n mergedRanges.push([start, end]);\n } else if (start - 1 <= mergedRanges[mergedRanges.length - 1][1]) {\n mergedRanges[mergedRanges.length - 1][1] = Math.max(\n mergedRanges[mergedRanges.length - 1][1],\n end\n );\n } else {\n mergedRanges.push([start, end]);\n }\n }\n return mergedRanges;\n }\n}\n\nexport default GridUtils;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"GridUtils.js","names":["clamp","EMPTY_ARRAY","GridRange","isBoundedAxisRange","GridUtils","getGridPointFromXY","x","y","metrics","column","getColumnAtX","row","getRowAtY","columnHeaderDepth","getColumnHeaderDepthAtY","getCellInfoFromXY","allColumnWidths","allRowHeights","allColumnXs","allRowYs","modelColumns","modelRows","modelRow","get","modelColumn","left","top","columnWidth","rowHeight","columnHeaderHeight","columnHeaderMaxDepth","Math","ceil","undefined","iterateFloatingStart","start","total","callback","i","result","iterateFloatingEnd","end","iterateFloating","iterateAllItems","visibleStart","visibleEnd","floatingStartCount","floatingEndCount","totalCount","visibleStartIndex","max","visibleEndIndex","min","isInItem","itemIndex","itemCoordinates","itemSizes","coordinate","itemX","itemSize","getItemAtOffset","offset","itemCount","floatingStart","floatingEnd","items","ignoreFloating","floatingItem","item","length","columnCount","floatingLeftColumnCount","floatingRightColumnCount","visibleColumns","gridX","floatingTopRowCount","floatingBottomRowCount","rowCount","visibleRows","gridY","getNextShownItem","startIndex","modelIndexes","visibleItems","userSizes","visibleItemIndex","findIndex","value","modelIndex","getNextShownColumn","userColumnWidths","getNextShownRow","userRowHeights","getColumnSeparatorIndex","theme","rowHeaderWidth","floatingColumns","floatingLeftWidth","allowColumnResize","headerSeparatorHandleSize","halfSeparatorSize","isPreviousColumnHidden","columnX","isColumnHidden","midX","minX","maxX","isItemHidden","visibleSizes","columnIndex","isFloatingRow","isFloatingColumn","getHiddenItems","hiddenItems","push","getHiddenColumns","getRowSeparatorIndex","allowRowResize","isPreviousRowHidden","rowY","isRowHidden","midY","minY","maxY","rowIndex","getHiddenRows","moveItem","from","to","oldMovedItems","movedItems","lastMovedItem","pop","moveRange","toParam","isPreMoveTo","newLastMovedItem","moveItemOrRange","Array","isArray","applyItemMoves","reverse","fromItemOrRange","toItem","fromItem","fromStart","fromEnd","toStart","moveDistance","nextResult","currentStart","j","Number","NEGATIVE_INFINITY","currentEnd","POSITIVE_INFINITY","movedRange","currentResult","map","s","e","filter","range","flat","isFinite","translateRange","movedColumns","movedRows","columnRanges","startColumn","endColumn","rowRanges","startRow","endRow","ranges","c","r","getModelIndex","visibleIndex","getModelIndexes","visibleIndexes","getModelRangeIndexes","getModelRange","uiRange","getModelRanges","uiRanges","modelRanges","getVisibleRangeIndexes","getVisibleRange","modelRange","getVisibleRanges","visibleRanges","getVisibleIndex","getVisibleIndexes","isMacPlatform","platform","window","navigator","startsWith","getModifierKey","isModifierKeyDown","event","modifierKey","checkColumnHidden","checkAllColumnsHidden","columns","size","every","getScrollDragBounds","width","height","floatingRightWidth","floatingTopHeight","floatingBottomHeight","x1","y1","x2","y2","getScrollDelta","wheelEvent","pageWidth","pageHeight","lineWidth","lineHeight","deltaX","deltaY","shiftKey","deltaMode","WheelEvent","DOM_DELTA_PAGE","DOM_DELTA_LINE","round","PIXELS_PER_LINE","compareRanges","range1","range2","mergeSortedRanges","mergedRanges"],"sources":["../src/GridUtils.ts"],"sourcesContent":["import React from 'react';\nimport clamp from 'lodash.clamp';\nimport { EMPTY_ARRAY } from '@deephaven/utils';\nimport GridRange, { GridRangeIndex } from './GridRange';\nimport {\n BoxCoordinates,\n Coordinate,\n CoordinateMap,\n VisibleIndex,\n VisibleToModelMap,\n ModelIndex,\n ModelSizeMap,\n MoveOperation,\n SizeMap,\n} from './GridMetrics';\nimport type { GridMetrics } from './GridMetrics';\nimport { GridTheme } from './GridTheme';\nimport { GridWheelEvent } from './GridMouseHandler';\nimport {\n AxisRange,\n BoundedAxisRange,\n isBoundedAxisRange,\n Range,\n} from './GridAxisRange';\n\nexport type GridPoint = {\n x: Coordinate;\n y: Coordinate;\n column: GridRangeIndex;\n row: GridRangeIndex;\n columnHeaderDepth?: number;\n};\n\nexport interface CellInfo {\n row: VisibleIndex | null;\n column: VisibleIndex | null;\n modelRow: ModelIndex | null;\n modelColumn: ModelIndex | null;\n left: Coordinate | null;\n top: Coordinate | null;\n columnWidth: number | null;\n rowHeight: number | null;\n}\n\nexport type IndexCallback<T> = (itemIndex: VisibleIndex) => T | undefined;\n\nexport class GridUtils {\n // use same constant as chrome source for windows\n // https://github.com/chromium/chromium/blob/973af9d461b6b5dc60208c8d3d66adc27e53da78/ui/events/blink/web_input_event_builders_win.cc#L285\n static PIXELS_PER_LINE = 100 / 3;\n\n /**\n * Get the GridPoint for the coordinates provided\n * @param x The grid x coordinate\n * @param y The grid y coordinate\n * @param metrics The grid metrics\n * @returns The GridPoint including the column/row information\n */\n static getGridPointFromXY(\n x: Coordinate,\n y: Coordinate,\n metrics: GridMetrics\n ): GridPoint {\n const column = GridUtils.getColumnAtX(x, metrics);\n const row = GridUtils.getRowAtY(y, metrics);\n const columnHeaderDepth = GridUtils.getColumnHeaderDepthAtY(y, metrics);\n\n return { x, y, row, column, columnHeaderDepth };\n }\n\n static getCellInfoFromXY(\n x: Coordinate,\n y: Coordinate,\n metrics: GridMetrics\n ): CellInfo {\n const { row, column } = GridUtils.getGridPointFromXY(x, y, metrics);\n\n const {\n allColumnWidths,\n allRowHeights,\n allColumnXs,\n allRowYs,\n modelColumns,\n modelRows,\n } = metrics;\n\n const modelRow = row !== null ? modelRows.get(row) : null;\n const modelColumn = column !== null ? modelColumns.get(column) : null;\n const left = column !== null ? allColumnXs.get(column) : null;\n const top = row !== null ? allRowYs.get(row) : null;\n const columnWidth = column !== null ? allColumnWidths.get(column) : null;\n const rowHeight = row !== null ? allRowHeights.get(row) : null;\n\n return {\n row,\n column,\n modelRow: modelRow ?? null,\n modelColumn: modelColumn ?? null,\n left: left ?? null,\n top: top ?? null,\n columnWidth: columnWidth ?? null,\n rowHeight: rowHeight ?? null,\n };\n }\n\n static getColumnHeaderDepthAtY(\n y: Coordinate,\n metrics: GridMetrics\n ): number | undefined {\n const row = GridUtils.getRowAtY(y, metrics);\n const { columnHeaderHeight, columnHeaderMaxDepth } = metrics;\n\n if (row === null && y <= columnHeaderHeight * columnHeaderMaxDepth) {\n return clamp(\n columnHeaderMaxDepth - Math.ceil(y / columnHeaderHeight),\n 0,\n columnHeaderMaxDepth - 1\n );\n }\n\n return undefined;\n }\n\n /**\n * Iterate through each floating item at the start and call a callback, returning the first result\n * @param start The count of floating items at the start\n * @param total The total number of items\n * @param callback Function to call for each item\n * @returns The result from the callback\n */\n static iterateFloatingStart<T>(\n start: number,\n total: number,\n callback: IndexCallback<T>\n ): T | undefined {\n for (let i = 0; i < start && i < total; i += 1) {\n const result = callback(i);\n if (result !== undefined) {\n return result;\n }\n }\n\n return undefined;\n }\n\n /**\n * Iterate through floating items at the end. Iterates in increasing order.\n * @param end The count of floating items at the end\n * @param total The total number of items\n * @param callback Function to call for each item\n * @returns The result from the callback\n */\n static iterateFloatingEnd<T>(\n end: number,\n total: number,\n callback: IndexCallback<T>\n ): T | undefined {\n for (let i = 0; i < end && total - (end - i) >= 0; i += 1) {\n const result = callback(total - (end - i));\n if (result !== undefined) {\n return result;\n }\n }\n\n return undefined;\n }\n\n /**\n * Iterate through all floating items in increasing order, starting with the top items.\n * @param start Count of start floating rows, e.g. floatingTopRowCount\n * @param end Count of end floating rows, e.g. floatingBottomRowCount\n * @param total Total number of items\n * @param callback Callback called for each value, stopping the iterating and returning the value if one is returned\n */\n static iterateFloating<T>(\n start: number,\n end: number,\n total: number,\n callback: IndexCallback<T>\n ): T | undefined {\n const result = GridUtils.iterateFloatingStart(start, total, callback);\n if (result !== undefined) {\n return result;\n }\n return GridUtils.iterateFloatingEnd(end, total, callback);\n }\n\n /**\n * Iterate through all items in one dimension on the grid - first floating, then visible.\n * Call the callback for each item, break if a result is returned and return that result.\n * @param visibleStart Index of the start of the visible viewport\n * @param visibleEnd Index of the end of the visible viewport\n * @param floatingStartCount Number of items floating at the start\n * @param floatingEndCount Number of items floating at the end\n * @param totalCount Total number of items\n * @param callback Callback to call for each item\n * @returns The first result from the callback called, or undefined\n */\n static iterateAllItems<T>(\n visibleStart: VisibleIndex,\n visibleEnd: VisibleIndex,\n floatingStartCount: number,\n floatingEndCount: number,\n totalCount: number,\n callback: IndexCallback<T>\n ): T | undefined {\n const visibleStartIndex = Math.max(visibleStart, floatingStartCount);\n const visibleEndIndex = Math.min(\n visibleEnd,\n totalCount - floatingEndCount - 1\n );\n let result = GridUtils.iterateFloating(\n floatingStartCount,\n floatingEndCount,\n totalCount,\n callback\n );\n if (result !== undefined) {\n return result;\n }\n\n for (let i = visibleStartIndex; i <= visibleEndIndex; i += 1) {\n result = callback(i);\n if (result !== undefined) {\n return result;\n }\n }\n\n return undefined;\n }\n\n /**\n * Check if the coordinate is within the item specified in this dimension\n * @param itemIndex Index of the item to check\n * @param itemCoordinatess Coordinate of all items in this dimension\n * @param itemSizes Size of all items in this dimension\n * @param coordinate The coordinate to check\n * @returns True if the coordinate is within the item specified, false otherwise\n */\n static isInItem(\n itemIndex: VisibleIndex,\n itemCoordinates: CoordinateMap,\n itemSizes: SizeMap,\n coordinate: Coordinate\n ): boolean {\n const itemX = itemCoordinates.get(itemIndex) ?? 0;\n const itemSize = itemSizes.get(itemIndex) ?? 0;\n return itemX <= coordinate && coordinate <= itemX + itemSize;\n }\n\n /**\n * Get the Index of the item at the provided offset\n * @param offset Coordinate of the offset to get the item of\n * @param itemCount The total count of items\n * @param floatingStart Count of floating items at the start\n * @param floatingEnd Count of floating items at the end\n * @param items Index of all items\n * @param itemCoordinates The coordinate of each item\n * @param itemSizes The size of each item\n * @returns The item index, or null if no item matches\n */\n static getItemAtOffset(\n offset: Coordinate,\n itemCount: number,\n floatingStart: number,\n floatingEnd: number,\n items: readonly VisibleIndex[],\n itemCoordinates: CoordinateMap,\n itemSizes: SizeMap,\n ignoreFloating = false\n ): VisibleIndex | null {\n const floatingItem = ignoreFloating\n ? undefined\n : GridUtils.iterateFloating(\n floatingStart,\n floatingEnd,\n itemCount,\n item => {\n if (GridUtils.isInItem(item, itemCoordinates, itemSizes, offset)) {\n return item;\n }\n return undefined;\n }\n );\n if (!ignoreFloating && floatingItem !== undefined) {\n return floatingItem;\n }\n\n for (let i = 0; i < items.length; i += 1) {\n const item = items[i];\n if (GridUtils.isInItem(item, itemCoordinates, itemSizes, offset)) {\n return item;\n }\n }\n\n return null;\n }\n\n /**\n * Get the index of the column at the specified x coordinate\n * @param x Coordinate to get the item of\n * @param metrics Grid metrics\n * @returns Index of the column at that coordinate, or null if no column matches\n */\n static getColumnAtX(\n x: Coordinate,\n metrics: GridMetrics,\n ignoreFloating = false\n ): VisibleIndex | null {\n const {\n columnCount,\n floatingLeftColumnCount,\n floatingRightColumnCount,\n visibleColumns,\n allColumnXs,\n allColumnWidths,\n gridX,\n } = metrics;\n\n if (x < gridX) {\n return null;\n }\n\n return this.getItemAtOffset(\n x - gridX,\n columnCount,\n floatingLeftColumnCount,\n floatingRightColumnCount,\n visibleColumns,\n allColumnXs,\n allColumnWidths,\n ignoreFloating\n );\n }\n\n /**\n * Get the index of the row at the specified y coordinate\n * @param y Coordinate to get the item of\n * @param metrics Grid metrics\n * @returns Index of the row at that coordinate, or null if no row matches\n */\n static getRowAtY(y: Coordinate, metrics: GridMetrics): VisibleIndex | null {\n const {\n floatingTopRowCount,\n floatingBottomRowCount,\n rowCount,\n visibleRows,\n allRowYs,\n allRowHeights,\n gridY,\n } = metrics;\n\n if (y < gridY) {\n return null;\n }\n\n return this.getItemAtOffset(\n y - gridY,\n rowCount,\n floatingTopRowCount,\n floatingBottomRowCount,\n visibleRows,\n allRowYs,\n allRowHeights\n );\n }\n\n /**\n * Iterate backward through the visible items until a shown item is hit\n * @param startIndex The index to start from\n * @param modelIndexes The mapping of model indexes\n * @param visibleItems The visible items\n * @param userSizes The user set sizes\n * @returns Index of the next visible item, or null if no more are visible\n */\n static getNextShownItem(\n startIndex: VisibleIndex,\n modelIndexes: VisibleToModelMap,\n visibleItems: readonly VisibleIndex[],\n userSizes: ModelSizeMap\n ): VisibleIndex | null {\n let visibleItemIndex =\n visibleItems.findIndex(value => value === startIndex) || 0;\n visibleItemIndex -= 1;\n while (visibleItemIndex != null && visibleItemIndex >= 0) {\n const item = visibleItems[visibleItemIndex];\n const modelIndex = modelIndexes.get(item);\n if (modelIndex != null && userSizes.get(modelIndex) !== 0) {\n return item;\n }\n\n visibleItemIndex -= 1;\n }\n\n return null;\n }\n\n /**\n * Iterate backward through the visible columns until a shown column is hit\n * @param columnIndex The column index to start iterating backward from\n * @param metrics The GridMetricCalculator metrics\n * @returns Index of the next visible item, or null if no more are visible\n */\n static getNextShownColumn(\n startIndex: VisibleIndex,\n metrics: GridMetrics\n ): VisibleIndex | null {\n const { modelColumns, visibleColumns, userColumnWidths } = metrics;\n return GridUtils.getNextShownItem(\n startIndex,\n modelColumns,\n visibleColumns,\n userColumnWidths\n );\n }\n\n /**\n * Iterate backward through the visible rows until a shown row is hit\n * @param rowIndex The row index to start iterating backward from\n * @param metrics The GridMetricCalculator metrics\n * @returns Index of the next visible item, or null if no more are visible\n */\n static getNextShownRow(\n startIndex: VisibleIndex,\n metrics: GridMetrics\n ): VisibleIndex | null {\n const { modelRows, visibleRows, userRowHeights } = metrics;\n return GridUtils.getNextShownItem(\n startIndex,\n modelRows,\n visibleRows,\n userRowHeights\n );\n }\n\n /**\n * Gets the column index if the x/y coordinates provided are close enough to the separator, otherwise null\n * @param x Mouse x coordinate\n * @param y Mouse y coordinate\n * @param metrics The grid metrics\n * @param theme The grid theme with potential user overrides\n * @returns Index of the column separator at the coordinates provided, or null if none match\n */\n static getColumnSeparatorIndex(\n x: Coordinate,\n y: Coordinate,\n metrics: GridMetrics,\n theme: GridTheme\n ): VisibleIndex | null {\n const {\n rowHeaderWidth,\n columnHeaderHeight,\n floatingColumns,\n floatingLeftWidth,\n visibleColumns,\n allColumnXs,\n allColumnWidths,\n columnHeaderMaxDepth,\n } = metrics;\n const { allowColumnResize, headerSeparatorHandleSize } = theme;\n\n if (\n columnHeaderMaxDepth * columnHeaderHeight < y ||\n !allowColumnResize ||\n headerSeparatorHandleSize <= 0\n ) {\n return null;\n }\n\n const gridX = x - rowHeaderWidth;\n const halfSeparatorSize = headerSeparatorHandleSize * 0.5;\n\n // Iterate through the floating columns first since they're on top\n let isPreviousColumnHidden = false;\n for (let i = floatingColumns.length - 1; i >= 0; i -= 1) {\n const column = floatingColumns[i];\n const columnX = allColumnXs.get(column) ?? 0;\n const columnWidth = allColumnWidths.get(column) ?? 0;\n const isColumnHidden = columnWidth === 0;\n if (!isPreviousColumnHidden || !isColumnHidden) {\n let midX = columnX + columnWidth;\n if (isColumnHidden) {\n midX += halfSeparatorSize;\n } else if (isPreviousColumnHidden) {\n midX -= halfSeparatorSize;\n }\n\n const minX = midX - halfSeparatorSize;\n const maxX = midX + halfSeparatorSize;\n if (minX <= gridX && gridX <= maxX) {\n return column;\n }\n\n isPreviousColumnHidden = isColumnHidden;\n }\n }\n\n // Iterate backward so that you can reveal hidden columns properly\n isPreviousColumnHidden = false;\n for (let i = visibleColumns.length - 1; i >= 0; i -= 1) {\n const column = visibleColumns[i];\n const columnX = allColumnXs.get(column) ?? 0;\n const columnWidth = allColumnWidths.get(column) ?? 0;\n const isColumnHidden = columnWidth === 0;\n\n // If this column is under the floating columns \"layer\". Terminate early.\n if (columnX < floatingLeftWidth - columnWidth) {\n return null;\n }\n\n if (!isPreviousColumnHidden || !isColumnHidden) {\n let midX = columnX + columnWidth;\n if (isColumnHidden) {\n midX += halfSeparatorSize;\n } else if (isPreviousColumnHidden) {\n midX -= halfSeparatorSize;\n }\n\n const minX = midX - halfSeparatorSize;\n const maxX = midX + halfSeparatorSize;\n if (minX <= gridX && gridX <= maxX) {\n return column;\n }\n\n isPreviousColumnHidden = isColumnHidden;\n }\n }\n\n return null;\n }\n\n /**\n * Check if the item specified is hidden\n * @param itemIndex Index of the item to check\n * @param visibleSizes Sizes of all visible items\n * @returns True if the item is hidden, false otherwise\n */\n static isItemHidden(itemIndex: VisibleIndex, visibleSizes: SizeMap): boolean {\n return visibleSizes.get(itemIndex) === 0;\n }\n\n /**\n * Check if the column specified is hidden\n * @param columnIndex Index of the column to check\n * @param metrics Grid metrics\n * @returns True if the column is hidden, false otherwise\n */\n static isColumnHidden(\n columnIndex: VisibleIndex,\n metrics: GridMetrics\n ): boolean {\n const { allColumnWidths } = metrics;\n return GridUtils.isItemHidden(columnIndex, allColumnWidths);\n }\n\n /**\n * Check if the provided row is a floating row\n * @param row The row index to check\n * @param metrics The grid metrics to check against\n * @returns True if it's a floating row, false otherwise\n */\n static isFloatingRow(row: VisibleIndex, metrics: GridMetrics): boolean {\n if (row == null) {\n return false;\n }\n\n const { floatingTopRowCount, floatingBottomRowCount, rowCount } = metrics;\n return (\n row < floatingTopRowCount || row >= rowCount - floatingBottomRowCount\n );\n }\n\n /**\n * Check if the provided column is a floating column\n * @param column The column index to check\n * @param metrics The grid metrics to check against\n * @returns True if it's a floating column, false otherwise\n */\n static isFloatingColumn(column: VisibleIndex, metrics: GridMetrics): boolean {\n if (column == null) {\n return false;\n }\n\n const {\n floatingLeftColumnCount,\n floatingRightColumnCount,\n columnCount,\n } = metrics;\n return (\n column < floatingLeftColumnCount ||\n column >= columnCount - floatingRightColumnCount\n );\n }\n\n /**\n * Get all the items that are hidden under the same Index\n * E.g. If columns are 1, 2, 3, 4, 5, and column 2, 3, 4 are hidden, and we check for item 4, the return will be [2, 3, 4]\n * @param itemIndex Index of the item to start at\n * @param visibleSizes Visible size map\n * @param visibleItems Visible items\n * @returns Array of items that are hidden\n */\n static getHiddenItems(\n itemIndex: VisibleIndex,\n visibleSizes: SizeMap,\n visibleItems: readonly VisibleIndex[]\n ): VisibleIndex[] {\n if (!GridUtils.isItemHidden(itemIndex, visibleSizes)) {\n return [];\n }\n\n const hiddenItems = [itemIndex];\n const visibleItemIndex = visibleItems.findIndex(\n value => value === itemIndex\n );\n for (let i = visibleItemIndex - 1; i >= 0; i -= 1) {\n const item = visibleItems[i];\n if (!GridUtils.isItemHidden(item, visibleSizes)) {\n break;\n }\n\n hiddenItems.push(item);\n }\n\n return hiddenItems;\n }\n\n /**\n * Get all the columns that are hidden under the same Index\n * @param columnIndex Index of the item to start at\n * @param metrics Grid metrics\n * @returns Array of items that are hidden\n */\n static getHiddenColumns(\n columnIndex: VisibleIndex,\n metrics: GridMetrics\n ): VisibleIndex[] {\n const { visibleColumns, allColumnWidths } = metrics;\n return GridUtils.getHiddenItems(\n columnIndex,\n allColumnWidths,\n visibleColumns\n );\n }\n\n /**\n * Returns the row index if the x/y coordinates provided are close enough to the separator, otherwise null\n * @param x X coordinate to check\n * @param y Y coordinate to check\n * @param metrics The grid metrics\n * @param theme The grid theme\n * @returns Index of the row separator at the coordinates provided, or null if none match\n */\n static getRowSeparatorIndex(\n x: Coordinate,\n y: Coordinate,\n metrics: GridMetrics,\n theme: GridTheme\n ): VisibleIndex | null {\n const {\n rowHeaderWidth,\n columnHeaderHeight,\n visibleRows,\n allRowYs,\n allRowHeights,\n } = metrics;\n const { allowRowResize, headerSeparatorHandleSize } = theme;\n\n if (\n rowHeaderWidth < x ||\n !allowRowResize ||\n headerSeparatorHandleSize <= 0\n ) {\n return null;\n }\n\n const gridY = y - columnHeaderHeight;\n const halfSeparatorSize = headerSeparatorHandleSize * 0.5;\n\n // Iterate backward so you can reveal hidden rows properly\n let isPreviousRowHidden = false;\n for (let i = visibleRows.length - 1; i >= 0; i -= 1) {\n const row = visibleRows[i];\n const rowY = allRowYs.get(row) ?? 0;\n const rowHeight = allRowHeights.get(row) ?? 0;\n const isRowHidden = rowHeight === 0;\n if (!isPreviousRowHidden || !isRowHidden) {\n let midY = rowY + rowHeight;\n if (isRowHidden) {\n midY += halfSeparatorSize;\n } else if (isPreviousRowHidden) {\n midY -= halfSeparatorSize;\n }\n\n const minY = midY - halfSeparatorSize;\n const maxY = midY + halfSeparatorSize;\n\n if (minY <= gridY && gridY <= maxY) {\n return row;\n }\n\n isPreviousRowHidden = isRowHidden;\n }\n }\n\n return null;\n }\n\n /**\n * Check if the row specified is hidden\n * @param rowIndex Index of the row to check\n * @param metrics Grid metrics\n * @returns True if the row is hidden, false otherwise\n */\n static isRowHidden(rowIndex: VisibleIndex, metrics: GridMetrics): boolean {\n const { allRowHeights } = metrics;\n return GridUtils.isItemHidden(rowIndex, allRowHeights);\n }\n\n /**\n * Get all the rows that are hidden under the same Index\n * @param rowIndex Index of the item to start at\n * @param metrics Grid metrics\n * @returns Array of items that are hidden\n */\n static getHiddenRows(\n rowIndex: VisibleIndex,\n metrics: GridMetrics\n ): VisibleIndex[] {\n const { visibleRows, allRowHeights } = metrics;\n return GridUtils.getHiddenItems(rowIndex, allRowHeights, visibleRows);\n }\n\n /**\n * Set a new order for items in the grid\n * @param from The visible index to move from\n * @param to The visible index to move the item to\n * @param oldMovedItems The old reordered items\n * @returns The new reordered items\n */\n static moveItem(\n from: VisibleIndex,\n to: VisibleIndex,\n oldMovedItems: readonly MoveOperation[]\n ): MoveOperation[] {\n if (from === to) {\n return [...oldMovedItems];\n }\n\n const movedItems: MoveOperation[] = [...oldMovedItems];\n const lastMovedItem = movedItems[movedItems.length - 1];\n\n // Check if we should combine with the previous move\n // E.g. 1 -> 2, 2 -> 3 can just be 1 -> 3\n if (\n lastMovedItem != null &&\n !isBoundedAxisRange(lastMovedItem.from) &&\n lastMovedItem.to === from\n ) {\n // Remove the move if it is now a no-op\n if (lastMovedItem.from === to) {\n movedItems.pop();\n } else {\n movedItems[movedItems.length - 1] = {\n ...lastMovedItem,\n to,\n };\n }\n } else {\n movedItems.push({ from, to });\n }\n\n return movedItems;\n }\n\n /**\n * Move a visible range in the grid\n *\n * This will effectively slice the range out of the grid,\n * re-index the remaining columns,\n * then insert the range with the first element at the provided index\n *\n * @param from The visible axis range to move\n * @param to The visible index to move the start of the range to\n * @param oldMovedItems The old reordered items\n * @param isPreMoveTo If toParam is the index before the movement\n * If true, this will account for the shift when moving\n * a range before the drop positin\n * E.g. Move range [0, 2] 1 item down (after element 3)\n * The move is [0, 2] -> 1 if this is false. [0, 2] -> 3 if this is true\n * Both will result in [0, 2] -> 1\n * @returns The new reordered items\n */\n static moveRange(\n from: BoundedAxisRange,\n toParam: VisibleIndex,\n oldMovedItems: readonly MoveOperation[],\n isPreMoveTo = false\n ): MoveOperation[] {\n if (from[0] === from[1]) {\n return GridUtils.moveItem(from[0], toParam, oldMovedItems);\n }\n\n let to = toParam;\n\n if (isPreMoveTo && from[0] < toParam) {\n to -= from[1] - from[0];\n }\n\n if (from[0] === to) {\n return [...oldMovedItems];\n }\n\n const movedItems: MoveOperation[] = [...oldMovedItems];\n const lastMovedItem = movedItems[movedItems.length - 1];\n\n // Check if we should combine with the previous move\n // E.g. [1, 2] -> 2, [2, 3] -> 3 can just be [1, 2] -> 3\n if (\n lastMovedItem != null &&\n isBoundedAxisRange(lastMovedItem.from) &&\n lastMovedItem.from[1] - lastMovedItem.from[0] === from[1] - from[0] &&\n lastMovedItem.to === from[0]\n ) {\n movedItems[movedItems.length - 1] = {\n ...lastMovedItem,\n to,\n };\n } else {\n movedItems.push({ from, to });\n }\n\n const newLastMovedItem = movedItems[movedItems.length - 1];\n // Remove the move if it is now a no-op\n if (\n isBoundedAxisRange(newLastMovedItem.from) &&\n newLastMovedItem.from[0] === newLastMovedItem.to\n ) {\n movedItems.pop();\n }\n\n return movedItems;\n }\n\n static moveItemOrRange(\n from: VisibleIndex | BoundedAxisRange,\n to: VisibleIndex,\n oldMovedItems: MoveOperation[],\n isPreMoveTo = false\n ): MoveOperation[] {\n return Array.isArray(from)\n ? GridUtils.moveRange(from, to, oldMovedItems, isPreMoveTo)\n : GridUtils.moveItem(from, to, oldMovedItems);\n }\n\n /**\n * Applies the items moves to the AxisRange\n * @param start The start index of the range\n * @param end The end index of the range\n * @param movedItems The move operations to apply\n * @param reverse If the moved items should be applied in reverse (this reverses the effects of the moves)\n * @returns A list of AxisRanges in the translated space. Possibly multiple non-continuous ranges\n */\n static applyItemMoves<T extends number | GridRangeIndex>(\n start: T,\n end: T,\n movedItems: readonly MoveOperation[],\n reverse = false\n ): Range<T>[] {\n let result: Range<T>[] = [[start, end]];\n\n for (\n let i = reverse ? movedItems.length - 1 : 0;\n reverse ? i >= 0 : i < movedItems.length;\n reverse ? (i -= 1) : (i += 1)\n ) {\n const { from: fromItemOrRange, to: toItem } = movedItems[i];\n let length = 1;\n let fromItem: number;\n if (isBoundedAxisRange(fromItemOrRange)) {\n length = fromItemOrRange[1] - fromItemOrRange[0] + 1; // Ranges are inclusive\n [fromItem] = fromItemOrRange;\n } else {\n fromItem = fromItemOrRange;\n }\n\n const fromStart = reverse ? toItem : fromItem;\n const fromEnd = fromStart + length - 1;\n const toStart = reverse ? fromItem : toItem;\n const moveDistance = toStart - fromStart;\n\n const nextResult: Range<number>[] = [];\n for (let j = 0; j < result.length; j += 1) {\n const currentStart = result[j][0] ?? Number.NEGATIVE_INFINITY;\n const currentEnd = result[j][1] ?? Number.POSITIVE_INFINITY;\n\n let movedRange: Range<number> | undefined;\n const currentResult: Range<number>[] = [\n [currentStart, fromStart - 1],\n [fromStart, fromEnd],\n [fromEnd + 1, currentEnd],\n ]\n .map(\n ([s, e]): Range<number> => [\n // Cap the ranges to within the current range bounds\n Math.max(s, currentStart),\n Math.min(e, currentEnd),\n ]\n )\n .filter(([s, e]) => s <= e) // Remove invalid ranges\n .map(\n (range): Range<number> => {\n const [s, e] = range;\n if (fromStart <= s && fromEnd >= e) {\n // Current range in moved range\n movedRange = [s + moveDistance, e + moveDistance];\n return movedRange;\n }\n\n if (fromEnd < s) {\n // Current range is after moved range\n return [s - length, e - length];\n }\n return range;\n }\n )\n .map((range): Range<number>[] => {\n const [s, e] = range;\n if (toStart > s && toStart <= e) {\n // Moved range splits this range\n return [\n [s, toStart - 1],\n [toStart + length, e + length],\n ];\n }\n\n if (range === movedRange) {\n // Moved range has already been shifted\n return [range];\n }\n\n if (toStart <= s) {\n // Moved range shifts this range right\n return [[s + length, e + length]];\n }\n return [range];\n })\n .flat();\n\n nextResult.push(...currentResult);\n }\n\n // Return infinity values back to null\n result = nextResult.map(([s, e]) => [\n Number.isFinite(s) ? s : null,\n Number.isFinite(e) ? e : null,\n ]) as Range<T>[];\n }\n return result;\n }\n\n /**\n * Applies the items moves to the givengrid range\n * @param range The grid range to translate\n * @param movedColumns The moved columns\n * @param movedRows The moved rows\n * @param reverse If the moved items should be reversed (i.e. visible to model range)\n * @returns A list of grid ranges in the translated space. Possibly multiple non-continuous ranges\n */\n static translateRange(\n range: GridRange,\n movedColumns: readonly MoveOperation[],\n movedRows: readonly MoveOperation[],\n reverse: boolean\n ): GridRange[] {\n const columnRanges = GridUtils.applyItemMoves(\n range.startColumn,\n range.endColumn,\n movedColumns,\n reverse\n );\n const rowRanges = GridUtils.applyItemMoves(\n range.startRow,\n range.endRow,\n movedRows,\n reverse\n );\n const ranges: GridRange[] = [];\n for (let i = 0; i < columnRanges.length; i += 1) {\n const c = columnRanges[i];\n for (let j = 0; j < rowRanges.length; j += 1) {\n const r = rowRanges[j];\n ranges.push(new GridRange(c[0], r[0], c[1], r[1]));\n }\n }\n return ranges;\n }\n\n /**\n * Retrieve the model index given the currently moved items\n * @param visibleIndex The visible index of the item to get the model index for\n * @param movedItems The moved items\n * @returns The model index of the item\n */\n static getModelIndex(\n visibleIndex: VisibleIndex,\n movedItems: readonly MoveOperation[]\n ): ModelIndex {\n const modelIndex = GridUtils.applyItemMoves(\n visibleIndex,\n visibleIndex,\n movedItems,\n true\n )[0][0];\n\n return modelIndex;\n }\n\n /**\n * Retrieve the model indexes given the currently moved items\n * @param visibleIndexes The visible indexes of the item to get the model indexes for\n * @param movedItems The moved items\n * @returns The model indexes of the item\n */\n static getModelIndexes(\n visibleIndexes: ModelIndex[],\n movedItems: MoveOperation[]\n ): VisibleIndex[] {\n return visibleIndexes.map(i => GridUtils.getModelIndex(i, movedItems));\n }\n\n /**\n * Translate the provided UI start/end indexes to the model start/end indexes by applying the `movedItems` transformations.\n * Since moved items can split apart a range, multiple pairs of indexes are returned\n *\n * @param start Start item in one dimension\n * @param end End item in one dimension\n * @param movedItems Moved item pairs in this dimension\n * @returns Array of start/end pairs of the indexes after transformations applied.\n */\n static getModelRangeIndexes(\n start: GridRangeIndex,\n end: GridRangeIndex,\n movedItems: readonly MoveOperation[]\n ): AxisRange[] {\n return GridUtils.applyItemMoves(start, end, movedItems, true);\n }\n\n /**\n * Translate the provided UI range into model range, using the `movedColumns` and `movedRows` to apply the necessary transforms.\n * `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items\n *\n * @param uiRange The currently selected UI ranges\n * @param movedColumns The moved column pairs\n * @param movedRows The moved row pairs\n * @returns The model ranges after translation.\n */\n static getModelRange(\n uiRange: GridRange,\n movedColumns: readonly MoveOperation[] = EMPTY_ARRAY,\n movedRows: readonly MoveOperation[] = EMPTY_ARRAY\n ): GridRange[] {\n return GridUtils.translateRange(uiRange, movedColumns, movedRows, true);\n }\n\n /**\n * Translate the provided UI range into model ranges, using the `movedColumns` and `movedRows` to apply the necessary transforms.\n * `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items\n *\n * @param uiRanges The currently selected UI ranges\n * @param movedColumns The moved column pairs\n * @param movedRows The moved row pairs\n * @returns The model ranges after translation.\n */\n static getModelRanges(\n uiRanges: readonly GridRange[],\n movedColumns: readonly MoveOperation[] = EMPTY_ARRAY,\n movedRows: readonly MoveOperation[] = EMPTY_ARRAY\n ): GridRange[] {\n const modelRanges = [];\n for (let i = 0; i < uiRanges.length; i += 1) {\n modelRanges.push(\n ...GridUtils.getModelRange(uiRanges[i], movedColumns, movedRows)\n );\n }\n return modelRanges;\n }\n\n /**\n * Translate the provided UI start/end indexes to the visible start/end indexes by applying the `movedItems` transformations.\n * Since moved items can split apart a range, multiple pairs of indexes are returned\n *\n * @param start Start item in one dimension\n * @param end End item in one dimension\n * @param movedItems Moved item pairs in this dimension\n * @returns Array of start/end pairs of the indexes after transformations applied.\n */\n static getVisibleRangeIndexes(\n start: GridRangeIndex,\n end: GridRangeIndex,\n movedItems: readonly MoveOperation[]\n ): AxisRange[] {\n return GridUtils.applyItemMoves(start, end, movedItems, false);\n }\n\n /**\n * Translate the provided UI range into visible range, using the `movedColumns` and `movedRows` to apply the necessary transforms.\n * `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items\n *\n * @param uiRange The currently selected UI ranges\n * @param movedColumns The moved column pairs\n * @param movedRows The moved row pairs\n * @returns The model ranges after translation.\n */\n static getVisibleRange(\n modelRange: GridRange,\n movedColumns: readonly MoveOperation[] = EMPTY_ARRAY,\n movedRows: readonly MoveOperation[] = EMPTY_ARRAY\n ): GridRange[] {\n return this.translateRange(modelRange, movedColumns, movedRows, false);\n }\n\n /**\n * Translate the provided model ranges into visible ranges, using the `movedColumns` and `movedRows` to apply the necessary transforms.\n * `movedColumns` and `movedRows` are array of operations done to the UI indexes to re-order items\n *\n * @param modelRanges The model ranges\n * @param movedColumns The moved column pairs\n * @param movedRows The moved row pairs\n * @returns The model ranges after translation.\n */\n static getVisibleRanges(\n modelRanges: readonly GridRange[],\n movedColumns: readonly MoveOperation[] = EMPTY_ARRAY,\n movedRows: readonly MoveOperation[] = EMPTY_ARRAY\n ): GridRange[] {\n const visibleRanges = [];\n for (let i = 0; i < modelRanges.length; i += 1) {\n visibleRanges.push(\n ...GridUtils.getVisibleRange(modelRanges[i], movedColumns, movedRows)\n );\n }\n return visibleRanges;\n }\n\n /**\n * Retrieve the visible index given the currently moved items\n * @param modelIndex The model index to get the visible index for\n * @param movedItems Moved items\n * @returns The visible index of the item\n */\n static getVisibleIndex(\n modelIndex: ModelIndex,\n movedItems: readonly MoveOperation[]\n ): VisibleIndex {\n const visibleIndex = GridUtils.applyItemMoves(\n modelIndex,\n modelIndex,\n movedItems\n )[0][0];\n\n return visibleIndex;\n }\n\n /**\n * Retrieve the visible indexes given the currently moved items\n * @param modelIndexes The model indexes to get the visible indexes for\n * @param movedItems Moved items\n * @returns The visible indexes of the item\n */\n static getVisibleIndexes(\n modelIndexes: readonly ModelIndex[],\n movedItems: readonly MoveOperation[]\n ): VisibleIndex[] {\n return modelIndexes.map(i => GridUtils.getVisibleIndex(i, movedItems));\n }\n\n /**\n * Check if the current platform is Mac\n * @returns True if this platform is a Mac, false otherwise\n */\n static isMacPlatform(): boolean {\n const { platform } = window.navigator;\n return platform.startsWith('Mac');\n }\n\n /**\n * Get the modifier key for the current platform\n * @returns The modifier key for the current platform\n */\n static getModifierKey(): 'metaKey' | 'ctrlKey' {\n if (GridUtils.isMacPlatform()) {\n return 'metaKey';\n }\n\n return 'ctrlKey';\n }\n\n /**\n * Check if the modifier key is down for the given event\n * @param event The event to check\n * @returns True if the modifier key is down, false otherwise\n */\n static isModifierKeyDown(\n event: MouseEvent | KeyboardEvent | React.KeyboardEvent | React.MouseEvent\n ): boolean {\n const modifierKey = GridUtils.getModifierKey();\n return event[modifierKey];\n }\n\n /**\n * Check if the user has hidden the specified column\n * @param modelIndex The model index to check\n * @param userColumnWidths The user set column widths\n * @returns True if the user has hidden the column\n */\n static checkColumnHidden(\n modelIndex: ModelIndex,\n userColumnWidths: ModelSizeMap\n ): boolean {\n return userColumnWidths.get(modelIndex) === 0;\n }\n\n /**\n * Check if all the columns specified are hidden\n * @param columns Columns to check\n * @param userColumnWidths The user set column widths\n * @returns True if the user has hidden all of the columns\n */\n static checkAllColumnsHidden(\n columns: readonly ModelIndex[],\n userColumnWidths: ModelSizeMap\n ): boolean {\n if (userColumnWidths.size === 0) {\n return false;\n }\n return columns.every(column => userColumnWidths.get(column) === 0);\n }\n\n /**\n * Get the bounds the mouse needs to be dragged outside of from an initial selection before scrolling occurs.\n * Taking into account any floating rows that may be covering the viewport.\n * @param metrics Grid metrics\n * @param row The row they started dragging in\n * @param column The column they started the drag from\n * @returns Dimensions of the drag area in relation to the canvas they need to drag outside of to start scrolling\n */\n static getScrollDragBounds(\n metrics: GridMetrics,\n row: GridRangeIndex,\n column: GridRangeIndex\n ): BoxCoordinates {\n const {\n gridX,\n gridY,\n width,\n height,\n floatingTopRowCount,\n floatingBottomRowCount,\n floatingLeftColumnCount,\n floatingRightColumnCount,\n floatingLeftWidth,\n floatingRightWidth,\n floatingTopHeight,\n floatingBottomHeight,\n columnCount,\n rowCount,\n } = metrics;\n let x1 = gridX;\n let y1 = gridY;\n let x2 = width;\n let y2 = height;\n if (column != null) {\n if (column > floatingLeftColumnCount) {\n x1 += floatingLeftWidth;\n }\n if (column < columnCount - floatingRightColumnCount) {\n x2 -= floatingRightWidth;\n }\n }\n\n if (row != null) {\n if (row > floatingTopRowCount) {\n y1 += floatingTopHeight;\n }\n if (row < rowCount - floatingBottomRowCount) {\n y2 -= floatingBottomHeight;\n }\n }\n return { x1, y1, x2, y2 };\n }\n\n /**\n * Converts the delta coordinates from the provided wheel event to pixels\n * Different platforms have different ways of providing the delta so this normalizes it\n * @param wheelEvent The mouse wheel event to get the scrolling delta for\n * @param pageWidth The width of the page that is scrolling\n * @param pageHeight The height of the page that is scrolling\n * @param lineWidth The width of the line scrolling in line mode\n * @param lineHeight The height of the line scrolling in line mode\n * @returns The delta coordinates normalized to pixels\n */\n static getScrollDelta(\n wheelEvent: GridWheelEvent,\n pageWidth = 1024,\n pageHeight = 768,\n lineWidth = 20,\n lineHeight = 20\n ): { deltaX: number; deltaY: number } {\n let { deltaX, deltaY } = wheelEvent;\n\n // Flip scroll direction if shiftKey is held on windows/linux.\n // On mac, deltaX/Y values are switched at the event level when shiftKey=true.\n // Guard on strictly Y only changing, to ignore trackpad diagonal motion,\n // through that guard may not be necessary, but it is difficult to determine for\n // all platforms/browser/scroll method combos.\n if (\n !GridUtils.isMacPlatform() &&\n wheelEvent.shiftKey &&\n wheelEvent.deltaX === 0 &&\n wheelEvent.deltaY !== 0\n ) {\n deltaX = wheelEvent.deltaY;\n deltaY = wheelEvent.deltaX;\n }\n\n // Normalize other deltaMode values to pixel units\n // deltaMode 0, is already in pixel units\n if (wheelEvent?.deltaMode === WheelEvent.DOM_DELTA_PAGE) {\n // Users can set OS to be in deltaMode page\n // scrolly by page units as pixels\n deltaX *= pageWidth;\n deltaY *= pageHeight;\n } else if (wheelEvent?.deltaMode === WheelEvent.DOM_DELTA_LINE) {\n // Firefox reports deltaMode line\n // Normalize distance travelled between browsers\n // but remain ~platform/browser combo consistent\n if (GridUtils.isMacPlatform()) {\n // for mac treat lines as a standard row height\n // on mac, firefox travels less distance then chrome per tick\n deltaX = Math.round(deltaX * lineWidth);\n deltaY = Math.round(deltaY * lineHeight);\n } else {\n // for windows convert to pixels using the same method as chrome\n // chrome goes 100 per 3 lines, and firefox would go 102 per 3 (17 lineheight * 3 lines * 2)\n // make the behaviour the same between as it's close enough\n deltaX = Math.round(deltaX * this.PIXELS_PER_LINE);\n deltaY = Math.round(deltaY * this.PIXELS_PER_LINE);\n }\n }\n\n return { deltaX, deltaY };\n }\n\n static compareRanges(range1: AxisRange, range2: AxisRange): number {\n if (\n range1[0] == null ||\n range1[1] == null ||\n range2[0] == null ||\n range2[1] == null\n ) {\n return 0;\n }\n return range1[0] !== range2[0]\n ? range1[0] - range2[0]\n : range1[1] - range2[1];\n }\n\n static mergeSortedRanges(ranges: BoundedAxisRange[]): BoundedAxisRange[] {\n const mergedRanges: BoundedAxisRange[] = [];\n\n for (let i = 0; i < ranges.length; i += 1) {\n const range = ranges[i];\n const start = range[0];\n const end = range[1];\n if (i === 0) {\n mergedRanges.push([start, end]);\n } else if (start - 1 <= mergedRanges[mergedRanges.length - 1][1]) {\n mergedRanges[mergedRanges.length - 1][1] = Math.max(\n mergedRanges[mergedRanges.length - 1][1],\n end\n );\n } else {\n mergedRanges.push([start, end]);\n }\n }\n return mergedRanges;\n }\n}\n\nexport default GridUtils;\n"],"mappings":"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"}
|