From 24c3eb48e27969f24c2a0b2f3f537c12e10bd5ac Mon Sep 17 00:00:00 2001 From: Akshat Jawne <69530774+AkshatJawne@users.noreply.github.com> Date: Mon, 29 Jul 2024 09:17:58 -0600 Subject: [PATCH] fix: Input Tables cannot paste more rows than number of visible rows (#2152) Resolves https://github.com/deephaven/web-client-ui/issues/2089 --- packages/grid/src/Grid.tsx | 11 +------- .../src/IrisGridTableModelTemplate.ts | 27 +++++++------------ 2 files changed, 10 insertions(+), 28 deletions(-) diff --git a/packages/grid/src/Grid.tsx b/packages/grid/src/Grid.tsx index dcbc809b5d..f56bd01cf7 100644 --- a/packages/grid/src/Grid.tsx +++ b/packages/grid/src/Grid.tsx @@ -1497,6 +1497,7 @@ class Grid extends PureComponent { const { columnCount, rowCount } = model; let ranges = selectedRanges; // If each cell is a single selection, we need to update the selection to map to the newly pasted data + // Check for if ( ranges.every( range => @@ -1518,16 +1519,6 @@ class Grid extends PureComponent { this.setSelectedRanges(ranges); } - if ( - !ranges.every( - range => - GridRange.rowCount([range]) === tableHeight && - GridRange.columnCount([range]) === tableWidth - ) - ) { - throw new PasteError('Copy and paste area are not same size.'); - } - const edits: EditOperation[] = []; ranges.forEach(range => { for (let x = 0; x < tableWidth; x += 1) { diff --git a/packages/iris-grid/src/IrisGridTableModelTemplate.ts b/packages/iris-grid/src/IrisGridTableModelTemplate.ts index 71f13e0ab5..c32ddefb5b 100644 --- a/packages/iris-grid/src/IrisGridTableModelTemplate.ts +++ b/packages/iris-grid/src/IrisGridTableModelTemplate.ts @@ -1040,7 +1040,7 @@ class IrisGridTableModelTemplate< */ pendingRow(y: ModelIndex): ModelIndex | null { const pendingRow = y - this.floatingTopRowCount - this.table.size; - if (pendingRow >= 0 && pendingRow < this.pendingNewRowCount) { + if (pendingRow >= 0) { return pendingRow; } @@ -1635,7 +1635,11 @@ class IrisGridTableModelTemplate< isEditableRange(range: GridRange): boolean { // Make sure we have an input table and a valid range - if (this.inputTable == null || !GridRange.isBounded(range)) { + if ( + this.inputTable == null || + range.startRow == null || + range.endRow == null + ) { return false; } @@ -1647,12 +1651,10 @@ class IrisGridTableModelTemplate< this.isPendingRow(range.startRow) && this.isPendingRow(range.endRow); let isKeyColumnInRange = false; + assertNotNull(range.startColumn); // Check if any of the columns in grid range are key columns - for ( - let column = range.startColumn; - column <= range.endColumn; - column += 1 - ) { + const bound = range.endColumn ?? this.table.size; + for (let column = range.startColumn; column <= bound; column += 1) { if (this.isKeyColumn(column)) { isKeyColumnInRange = true; break; @@ -1665,17 +1667,6 @@ class IrisGridTableModelTemplate< return false; } - // Editing the aggregations/totals which are floating above/below is not allowed - if ( - range.startRow < this.floatingTopRowCount || - range.startRow >= - this.floatingTopRowCount + this.table.size + this.pendingRowCount || - range.endRow >= - this.floatingTopRowCount + this.table.size + this.pendingRowCount - ) { - return false; - } - return true; }