@salt-ds/data-grid 1.0.5 → 1.0.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +216 -0
- package/dist-cjs/BaseCell.js +50 -48
- package/dist-cjs/BaseCell.js.map +1 -1
- package/dist-cjs/CellEditor.js +0 -2
- package/dist-cjs/CellEditor.js.map +1 -1
- package/dist-cjs/CellFrame.js +25 -33
- package/dist-cjs/CellFrame.js.map +1 -1
- package/dist-cjs/ColumnDataContext.js +1 -3
- package/dist-cjs/ColumnDataContext.js.map +1 -1
- package/dist-cjs/ColumnDragContext.js +1 -3
- package/dist-cjs/ColumnDragContext.js.map +1 -1
- package/dist-cjs/ColumnGroup.js +2 -6
- package/dist-cjs/ColumnGroup.js.map +1 -1
- package/dist-cjs/ColumnSortContext.js +1 -3
- package/dist-cjs/ColumnSortContext.js.map +1 -1
- package/dist-cjs/CornerTag.js +7 -6
- package/dist-cjs/CornerTag.js.map +1 -1
- package/dist-cjs/CursorContext.js +1 -3
- package/dist-cjs/CursorContext.js.map +1 -1
- package/dist-cjs/DropdownCellEditor.js +25 -28
- package/dist-cjs/DropdownCellEditor.js.map +1 -1
- package/dist-cjs/EditorContext.js +1 -3
- package/dist-cjs/EditorContext.js.map +1 -1
- package/dist-cjs/Grid.css.js +1 -1
- package/dist-cjs/Grid.js +174 -183
- package/dist-cjs/Grid.js.map +1 -1
- package/dist-cjs/GridColumn.js +4 -8
- package/dist-cjs/GridColumn.js.map +1 -1
- package/dist-cjs/GridContext.js +1 -3
- package/dist-cjs/GridContext.js.map +1 -1
- package/dist-cjs/GroupHeaderCell.js +29 -30
- package/dist-cjs/GroupHeaderCell.js.map +1 -1
- package/dist-cjs/GroupHeaderCellValue.js +1 -5
- package/dist-cjs/GroupHeaderCellValue.js.map +1 -1
- package/dist-cjs/HeaderCell.js +94 -90
- package/dist-cjs/HeaderCell.js.map +1 -1
- package/dist-cjs/HeaderCellValue.js +1 -6
- package/dist-cjs/HeaderCellValue.js.map +1 -1
- package/dist-cjs/LayoutContext.js +0 -2
- package/dist-cjs/LayoutContext.js.map +1 -1
- package/dist-cjs/NumberRange.js +2 -4
- package/dist-cjs/NumberRange.js.map +1 -1
- package/dist-cjs/NumericColumn.css.js +1 -1
- package/dist-cjs/NumericColumn.js +31 -30
- package/dist-cjs/NumericColumn.js.map +1 -1
- package/dist-cjs/RowSelectionCheckboxCellValue.js +7 -10
- package/dist-cjs/RowSelectionCheckboxCellValue.js.map +1 -1
- package/dist-cjs/RowSelectionCheckboxColumn.js +14 -13
- package/dist-cjs/RowSelectionCheckboxColumn.js.map +1 -1
- package/dist-cjs/RowSelectionCheckboxHeaderCellValue.js +22 -18
- package/dist-cjs/RowSelectionCheckboxHeaderCellValue.js.map +1 -1
- package/dist-cjs/RowSelectionRadioCellValue.js +6 -8
- package/dist-cjs/RowSelectionRadioCellValue.js.map +1 -1
- package/dist-cjs/RowSelectionRadioColumn.js +12 -11
- package/dist-cjs/RowSelectionRadioColumn.js.map +1 -1
- package/dist-cjs/RowSelectionRadioHeaderCell.js +2 -10
- package/dist-cjs/RowSelectionRadioHeaderCell.js.map +1 -1
- package/dist-cjs/RowValidationStatus.js +0 -2
- package/dist-cjs/RowValidationStatus.js.map +1 -1
- package/dist-cjs/SelectionContext.js +1 -3
- package/dist-cjs/SelectionContext.js.map +1 -1
- package/dist-cjs/SizingContext.js +1 -3
- package/dist-cjs/SizingContext.js.map +1 -1
- package/dist-cjs/TextCellEditor.css.js +1 -1
- package/dist-cjs/TextCellEditor.js +14 -20
- package/dist-cjs/TextCellEditor.js.map +1 -1
- package/dist-cjs/index.js +0 -2
- package/dist-cjs/index.js.map +1 -1
- package/dist-cjs/internal/CellMeasure.css.js +1 -1
- package/dist-cjs/internal/CellMeasure.js +3 -18
- package/dist-cjs/internal/CellMeasure.js.map +1 -1
- package/dist-cjs/internal/CellStatusIcons.js +41 -37
- package/dist-cjs/internal/CellStatusIcons.js.map +1 -1
- package/dist-cjs/internal/ColumnDropTarget.js +3 -8
- package/dist-cjs/internal/ColumnDropTarget.js.map +1 -1
- package/dist-cjs/internal/ColumnGhost.js +17 -29
- package/dist-cjs/internal/ColumnGhost.js.map +1 -1
- package/dist-cjs/internal/Cursor.js +3 -7
- package/dist-cjs/internal/Cursor.js.map +1 -1
- package/dist-cjs/internal/DefaultCellValue.js +11 -10
- package/dist-cjs/internal/DefaultCellValue.js.map +1 -1
- package/dist-cjs/internal/FakeCell.js +8 -16
- package/dist-cjs/internal/FakeCell.js.map +1 -1
- package/dist-cjs/internal/FakeGroupCell.js +0 -2
- package/dist-cjs/internal/FakeGroupCell.js.map +1 -1
- package/dist-cjs/internal/FakeHeaderCell.js +1 -5
- package/dist-cjs/internal/FakeHeaderCell.js.map +1 -1
- package/dist-cjs/internal/GroupHeaderRow.js +9 -20
- package/dist-cjs/internal/GroupHeaderRow.js.map +1 -1
- package/dist-cjs/internal/HeaderRow.js +17 -23
- package/dist-cjs/internal/HeaderRow.js.map +1 -1
- package/dist-cjs/internal/LeftPart.js +21 -27
- package/dist-cjs/internal/LeftPart.js.map +1 -1
- package/dist-cjs/internal/MiddlePart.js +19 -25
- package/dist-cjs/internal/MiddlePart.js.map +1 -1
- package/dist-cjs/internal/RightPart.js +21 -26
- package/dist-cjs/internal/RightPart.js.map +1 -1
- package/dist-cjs/internal/Scrollable.js +12 -13
- package/dist-cjs/internal/Scrollable.js.map +1 -1
- package/dist-cjs/internal/TableBody.js +17 -19
- package/dist-cjs/internal/TableBody.js.map +1 -1
- package/dist-cjs/internal/TableColGroup.js +7 -17
- package/dist-cjs/internal/TableColGroup.js.map +1 -1
- package/dist-cjs/internal/TableRow.js +87 -79
- package/dist-cjs/internal/TableRow.js.map +1 -1
- package/dist-cjs/internal/TopLeftPart.js +20 -31
- package/dist-cjs/internal/TopLeftPart.js.map +1 -1
- package/dist-cjs/internal/TopPart.js +20 -37
- package/dist-cjs/internal/TopPart.js.map +1 -1
- package/dist-cjs/internal/TopRightPart.js +26 -30
- package/dist-cjs/internal/TopRightPart.js.map +1 -1
- package/dist-cjs/internal/gridHooks.js +23 -25
- package/dist-cjs/internal/gridHooks.js.map +1 -1
- package/dist-cjs/internal/utils.js +5 -7
- package/dist-cjs/internal/utils.js.map +1 -1
- package/dist-es/BaseCell.js +50 -46
- package/dist-es/BaseCell.js.map +1 -1
- package/dist-es/CellEditor.js.map +1 -1
- package/dist-es/CellFrame.js +25 -31
- package/dist-es/CellFrame.js.map +1 -1
- package/dist-es/ColumnDataContext.js +1 -1
- package/dist-es/ColumnDataContext.js.map +1 -1
- package/dist-es/ColumnDragContext.js +1 -1
- package/dist-es/ColumnDragContext.js.map +1 -1
- package/dist-es/ColumnGroup.js +2 -4
- package/dist-es/ColumnGroup.js.map +1 -1
- package/dist-es/ColumnSortContext.js +1 -1
- package/dist-es/ColumnSortContext.js.map +1 -1
- package/dist-es/CornerTag.js +7 -4
- package/dist-es/CornerTag.js.map +1 -1
- package/dist-es/CursorContext.js +1 -1
- package/dist-es/CursorContext.js.map +1 -1
- package/dist-es/DropdownCellEditor.js +25 -26
- package/dist-es/DropdownCellEditor.js.map +1 -1
- package/dist-es/EditorContext.js +1 -1
- package/dist-es/EditorContext.js.map +1 -1
- package/dist-es/Grid.css.js +1 -1
- package/dist-es/Grid.js +174 -181
- package/dist-es/Grid.js.map +1 -1
- package/dist-es/GridColumn.js +4 -6
- package/dist-es/GridColumn.js.map +1 -1
- package/dist-es/GridContext.js +1 -1
- package/dist-es/GridContext.js.map +1 -1
- package/dist-es/GroupHeaderCell.js +29 -28
- package/dist-es/GroupHeaderCell.js.map +1 -1
- package/dist-es/GroupHeaderCellValue.js +1 -3
- package/dist-es/GroupHeaderCellValue.js.map +1 -1
- package/dist-es/HeaderCell.js +94 -88
- package/dist-es/HeaderCell.js.map +1 -1
- package/dist-es/HeaderCellValue.js +1 -4
- package/dist-es/HeaderCellValue.js.map +1 -1
- package/dist-es/LayoutContext.js.map +1 -1
- package/dist-es/NumberRange.js +2 -2
- package/dist-es/NumberRange.js.map +1 -1
- package/dist-es/NumericColumn.css.js +1 -1
- package/dist-es/NumericColumn.js +31 -28
- package/dist-es/NumericColumn.js.map +1 -1
- package/dist-es/RowSelectionCheckboxCellValue.js +7 -8
- package/dist-es/RowSelectionCheckboxCellValue.js.map +1 -1
- package/dist-es/RowSelectionCheckboxColumn.js +14 -11
- package/dist-es/RowSelectionCheckboxColumn.js.map +1 -1
- package/dist-es/RowSelectionCheckboxHeaderCellValue.js +22 -16
- package/dist-es/RowSelectionCheckboxHeaderCellValue.js.map +1 -1
- package/dist-es/RowSelectionRadioCellValue.js +6 -6
- package/dist-es/RowSelectionRadioCellValue.js.map +1 -1
- package/dist-es/RowSelectionRadioColumn.js +12 -9
- package/dist-es/RowSelectionRadioColumn.js.map +1 -1
- package/dist-es/RowSelectionRadioHeaderCell.js +2 -8
- package/dist-es/RowSelectionRadioHeaderCell.js.map +1 -1
- package/dist-es/RowValidationStatus.js.map +1 -1
- package/dist-es/SelectionContext.js +1 -1
- package/dist-es/SelectionContext.js.map +1 -1
- package/dist-es/SizingContext.js +1 -1
- package/dist-es/SizingContext.js.map +1 -1
- package/dist-es/TextCellEditor.css.js +1 -1
- package/dist-es/TextCellEditor.js +14 -18
- package/dist-es/TextCellEditor.js.map +1 -1
- package/dist-es/internal/CellMeasure.css.js +1 -1
- package/dist-es/internal/CellMeasure.js +3 -16
- package/dist-es/internal/CellMeasure.js.map +1 -1
- package/dist-es/internal/CellStatusIcons.js +41 -35
- package/dist-es/internal/CellStatusIcons.js.map +1 -1
- package/dist-es/internal/ColumnDropTarget.js +3 -6
- package/dist-es/internal/ColumnDropTarget.js.map +1 -1
- package/dist-es/internal/ColumnGhost.js +17 -27
- package/dist-es/internal/ColumnGhost.js.map +1 -1
- package/dist-es/internal/Cursor.js +3 -5
- package/dist-es/internal/Cursor.js.map +1 -1
- package/dist-es/internal/DefaultCellValue.js +11 -8
- package/dist-es/internal/DefaultCellValue.js.map +1 -1
- package/dist-es/internal/FakeCell.js +8 -14
- package/dist-es/internal/FakeCell.js.map +1 -1
- package/dist-es/internal/FakeGroupCell.js.map +1 -1
- package/dist-es/internal/FakeHeaderCell.js +1 -3
- package/dist-es/internal/FakeHeaderCell.js.map +1 -1
- package/dist-es/internal/GroupHeaderRow.js +9 -18
- package/dist-es/internal/GroupHeaderRow.js.map +1 -1
- package/dist-es/internal/HeaderRow.js +17 -21
- package/dist-es/internal/HeaderRow.js.map +1 -1
- package/dist-es/internal/LeftPart.js +21 -25
- package/dist-es/internal/LeftPart.js.map +1 -1
- package/dist-es/internal/MiddlePart.js +19 -23
- package/dist-es/internal/MiddlePart.js.map +1 -1
- package/dist-es/internal/RightPart.js +21 -24
- package/dist-es/internal/RightPart.js.map +1 -1
- package/dist-es/internal/Scrollable.js +12 -11
- package/dist-es/internal/Scrollable.js.map +1 -1
- package/dist-es/internal/TableBody.js +17 -17
- package/dist-es/internal/TableBody.js.map +1 -1
- package/dist-es/internal/TableColGroup.js +7 -15
- package/dist-es/internal/TableColGroup.js.map +1 -1
- package/dist-es/internal/TableRow.js +87 -77
- package/dist-es/internal/TableRow.js.map +1 -1
- package/dist-es/internal/TopLeftPart.js +20 -29
- package/dist-es/internal/TopLeftPart.js.map +1 -1
- package/dist-es/internal/TopPart.js +20 -35
- package/dist-es/internal/TopPart.js.map +1 -1
- package/dist-es/internal/TopRightPart.js +26 -28
- package/dist-es/internal/TopRightPart.js.map +1 -1
- package/dist-es/internal/gridHooks.js +23 -23
- package/dist-es/internal/gridHooks.js.map +1 -1
- package/dist-es/internal/utils.js +5 -5
- package/dist-es/internal/utils.js.map +1 -1
- package/dist-types/BaseCell.d.ts +3 -3
- package/dist-types/CellEditor.d.ts +1 -1
- package/dist-types/CellFrame.d.ts +2 -2
- package/dist-types/ColumnDragContext.d.ts +1 -1
- package/dist-types/ColumnGroup.d.ts +4 -4
- package/dist-types/ColumnSortContext.d.ts +5 -5
- package/dist-types/CornerTag.d.ts +1 -1
- package/dist-types/DropdownCellEditor.d.ts +2 -2
- package/dist-types/Grid.d.ts +4 -4
- package/dist-types/GridColumn.d.ts +3 -3
- package/dist-types/GridContext.d.ts +2 -2
- package/dist-types/GroupHeaderCell.d.ts +3 -3
- package/dist-types/GroupHeaderCellValue.d.ts +2 -2
- package/dist-types/HeaderCell.d.ts +5 -5
- package/dist-types/HeaderCellValue.d.ts +2 -2
- package/dist-types/NumericColumn.d.ts +6 -6
- package/dist-types/RowSelectionCheckboxCellValue.d.ts +2 -2
- package/dist-types/RowSelectionCheckboxColumn.d.ts +2 -2
- package/dist-types/RowSelectionCheckboxHeaderCellValue.d.ts +2 -2
- package/dist-types/RowSelectionRadioCellValue.d.ts +2 -2
- package/dist-types/RowSelectionRadioColumn.d.ts +2 -2
- package/dist-types/RowSelectionRadioHeaderCell.d.ts +2 -2
- package/dist-types/RowValidationStatus.d.ts +2 -2
- package/dist-types/SelectionContext.d.ts +1 -1
- package/dist-types/SizingContext.d.ts +3 -3
- package/dist-types/TextCellEditor.d.ts +2 -2
- package/dist-types/internal/CellMeasure.d.ts +1 -1
- package/dist-types/internal/CellStatusIcons.d.ts +3 -3
- package/dist-types/internal/ColumnDropTarget.d.ts +1 -1
- package/dist-types/internal/ColumnGhost.d.ts +3 -3
- package/dist-types/internal/Cursor.d.ts +1 -3
- package/dist-types/internal/DefaultCellValue.d.ts +2 -2
- package/dist-types/internal/FakeCell.d.ts +2 -2
- package/dist-types/internal/FakeGroupCell.d.ts +1 -1
- package/dist-types/internal/FakeHeaderCell.d.ts +1 -1
- package/dist-types/internal/GroupHeaderRow.d.ts +2 -2
- package/dist-types/internal/HeaderRow.d.ts +2 -2
- package/dist-types/internal/LeftPart.d.ts +4 -4
- package/dist-types/internal/MiddlePart.d.ts +4 -4
- package/dist-types/internal/RightPart.d.ts +4 -4
- package/dist-types/internal/Scrollable.d.ts +2 -2
- package/dist-types/internal/TableBody.d.ts +3 -3
- package/dist-types/internal/TableColGroup.d.ts +3 -3
- package/dist-types/internal/TableRow.d.ts +4 -4
- package/dist-types/internal/TopLeftPart.d.ts +2 -2
- package/dist-types/internal/TopPart.d.ts +3 -3
- package/dist-types/internal/TopRightPart.d.ts +2 -2
- package/dist-types/internal/gridHooks.d.ts +13 -13
- package/dist-types/internal/utils.d.ts +1 -1
- package/package.json +11 -8
- package/dist-cjs/internal/FakeCell.css.js +0 -6
- package/dist-cjs/internal/FakeCell.css.js.map +0 -1
- package/dist-es/internal/FakeCell.css.js +0 -4
- package/dist-es/internal/FakeCell.css.js.map +0 -1
package/dist-es/Grid.js
CHANGED
|
@@ -1,9 +1,18 @@
|
|
|
1
1
|
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
-
import { useRef, useState, useCallback, useMemo, useEffect } from 'react';
|
|
3
2
|
import { makePrefixer } from '@salt-ds/core';
|
|
4
|
-
import { useWindow } from '@salt-ds/window';
|
|
5
3
|
import { useComponentCssInjection } from '@salt-ds/styles';
|
|
4
|
+
import { useWindow } from '@salt-ds/window';
|
|
6
5
|
import { clsx } from 'clsx';
|
|
6
|
+
import { useRef, useState, useCallback, useMemo, useEffect } from 'react';
|
|
7
|
+
import { ColumnDataContext } from './ColumnDataContext.js';
|
|
8
|
+
import { ColumnDragContext } from './ColumnDragContext.js';
|
|
9
|
+
import { ColumnSortContext } from './ColumnSortContext.js';
|
|
10
|
+
import { CursorContext } from './CursorContext.js';
|
|
11
|
+
import { EditorContext } from './EditorContext.js';
|
|
12
|
+
import { GridContext } from './GridContext.js';
|
|
13
|
+
import { LayoutContext } from './LayoutContext.js';
|
|
14
|
+
import { SelectionContext } from './SelectionContext.js';
|
|
15
|
+
import { SizingContext } from './SizingContext.js';
|
|
7
16
|
import { CellMeasure } from './internal/CellMeasure.js';
|
|
8
17
|
import './internal/Cursor.js';
|
|
9
18
|
import './internal/GroupHeaderRow.js';
|
|
@@ -14,23 +23,14 @@ import { RightPart } from './internal/RightPart.js';
|
|
|
14
23
|
import { Scrollable } from './internal/Scrollable.js';
|
|
15
24
|
import './internal/TableRow.js';
|
|
16
25
|
import { clamp, getFocusablePosition } from './internal/utils.js';
|
|
17
|
-
import { SelectionContext } from './SelectionContext.js';
|
|
18
|
-
import { EditorContext } from './EditorContext.js';
|
|
19
|
-
import { CursorContext } from './CursorContext.js';
|
|
20
26
|
import { useColumnRegistry, useSumWidth, useSum, useClientMidWidth, useBodyVisibleColumnRange, useVisibleColumnGroupRange, useHeadVisibleColumnRange, useLeftScrolledOutWidth, useClientMidHeight, useVisibleRowRange, useBodyVisibleAreaTop, useColumnRange, useSumRangeWidth, useScrollToCell, useRowSelection, useRangeSelection, useRowModels, useColumnResize, useColumnMove } from './internal/gridHooks.js';
|
|
21
27
|
import { TopLeftPart } from './internal/TopLeftPart.js';
|
|
22
28
|
import { TopPart } from './internal/TopPart.js';
|
|
23
29
|
import { TopRightPart } from './internal/TopRightPart.js';
|
|
24
30
|
import './CellFrame.js';
|
|
25
31
|
import './internal/DefaultCellValue.js';
|
|
26
|
-
import { GridContext } from './GridContext.js';
|
|
27
|
-
import { SizingContext } from './SizingContext.js';
|
|
28
|
-
import { LayoutContext } from './LayoutContext.js';
|
|
29
|
-
import { ColumnDragContext } from './ColumnDragContext.js';
|
|
30
|
-
import { ColumnGhost } from './internal/ColumnGhost.js';
|
|
31
32
|
import { ColumnDropTarget } from './internal/ColumnDropTarget.js';
|
|
32
|
-
import {
|
|
33
|
-
import { ColumnSortContext } from './ColumnSortContext.js';
|
|
33
|
+
import { ColumnGhost } from './internal/ColumnGhost.js';
|
|
34
34
|
import css_248z from './Grid.css.js';
|
|
35
35
|
|
|
36
36
|
const withBaseName = makePrefixer("saltGrid");
|
|
@@ -111,8 +111,11 @@ const Grid = function Grid2(props) {
|
|
|
111
111
|
);
|
|
112
112
|
const {
|
|
113
113
|
leftCols,
|
|
114
|
+
// Columns pinned to left
|
|
114
115
|
midCols,
|
|
116
|
+
// Scrollable columns
|
|
115
117
|
rightCols,
|
|
118
|
+
// Columns pinned to right
|
|
116
119
|
leftGroups,
|
|
117
120
|
midGroups,
|
|
118
121
|
rightGroups,
|
|
@@ -120,7 +123,9 @@ const Grid = function Grid2(props) {
|
|
|
120
123
|
} = useColumnRegistry(children);
|
|
121
124
|
const midColsById = useMemo(
|
|
122
125
|
() => new Map(
|
|
123
|
-
midCols.map(
|
|
126
|
+
midCols.map(
|
|
127
|
+
(c) => [c.info.props.id, c]
|
|
128
|
+
)
|
|
124
129
|
),
|
|
125
130
|
[midCols]
|
|
126
131
|
);
|
|
@@ -232,7 +237,8 @@ const Grid = function Grid2(props) {
|
|
|
232
237
|
if (s) {
|
|
233
238
|
s.scrollLeft += deltaX;
|
|
234
239
|
s.scrollTop += deltaY;
|
|
235
|
-
if (!(Math.round(s.scrollHeight - s.scrollTop) === s.clientHeight ||
|
|
240
|
+
if (!(Math.round(s.scrollHeight - s.scrollTop) === s.clientHeight || // reached the bottom
|
|
241
|
+
s.scrollTop === 0 && deltaY < 0)) {
|
|
236
242
|
event.preventDefault();
|
|
237
243
|
event.stopPropagation();
|
|
238
244
|
}
|
|
@@ -269,8 +275,7 @@ const Grid = function Grid2(props) {
|
|
|
269
275
|
});
|
|
270
276
|
const customSortingFn = (_c = getColById(sortByColumnId)) == null ? void 0 : _c.info.props.customSort;
|
|
271
277
|
const sortedRowData = useMemo(() => {
|
|
272
|
-
if (!isSortMode || onSortOrderChange)
|
|
273
|
-
return rowData;
|
|
278
|
+
if (!isSortMode || onSortOrderChange) return rowData;
|
|
274
279
|
if (customSortingFn) {
|
|
275
280
|
return customSortingFn({ rowData, sortOrder });
|
|
276
281
|
}
|
|
@@ -360,7 +365,7 @@ const Grid = function Grid2(props) {
|
|
|
360
365
|
}, 0);
|
|
361
366
|
};
|
|
362
367
|
const startEditMode = (text) => {
|
|
363
|
-
if (editMode || cursorRowIdx
|
|
368
|
+
if (editMode || cursorRowIdx === void 0 || cursorColIdx === void 0) {
|
|
364
369
|
return;
|
|
365
370
|
}
|
|
366
371
|
const c = cols[cursorColIdx];
|
|
@@ -374,14 +379,14 @@ const Grid = function Grid2(props) {
|
|
|
374
379
|
if (!editMode) {
|
|
375
380
|
return;
|
|
376
381
|
}
|
|
377
|
-
if (cursorColIdx
|
|
378
|
-
console.error(
|
|
382
|
+
if (cursorColIdx === void 0) {
|
|
383
|
+
console.error("endEditMode: cursorColIdx is undefined in edit mode");
|
|
379
384
|
return;
|
|
380
385
|
}
|
|
381
386
|
const c = cols[cursorColIdx];
|
|
382
387
|
const handler = c.info.props.onChange;
|
|
383
|
-
if (cursorRowIdx
|
|
384
|
-
console.error(
|
|
388
|
+
if (cursorRowIdx === void 0) {
|
|
389
|
+
console.error("endEditMode: cursorRowIdx is undefined in edit mode");
|
|
385
390
|
return;
|
|
386
391
|
}
|
|
387
392
|
if (!handler) {
|
|
@@ -500,18 +505,12 @@ const Grid = function Grid2(props) {
|
|
|
500
505
|
[editMode, startEditMode, endEditMode, cancelEditMode, initialText]
|
|
501
506
|
);
|
|
502
507
|
const [isFocused, setFocused] = useState(false);
|
|
503
|
-
const onFocus = useCallback(
|
|
504
|
-
(
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
);
|
|
509
|
-
const onBlur = useCallback(
|
|
510
|
-
(event) => {
|
|
511
|
-
setFocused(false);
|
|
512
|
-
},
|
|
513
|
-
[setFocused]
|
|
514
|
-
);
|
|
508
|
+
const onFocus = useCallback(() => {
|
|
509
|
+
setFocused(true);
|
|
510
|
+
}, []);
|
|
511
|
+
const onBlur = useCallback(() => {
|
|
512
|
+
setFocused(false);
|
|
513
|
+
}, []);
|
|
515
514
|
const cursorContext = useMemo(
|
|
516
515
|
() => ({
|
|
517
516
|
isFocused,
|
|
@@ -595,9 +594,8 @@ const Grid = function Grid2(props) {
|
|
|
595
594
|
if (editMode) {
|
|
596
595
|
cancelEditMode();
|
|
597
596
|
break;
|
|
598
|
-
} else {
|
|
599
|
-
return false;
|
|
600
597
|
}
|
|
598
|
+
return false;
|
|
601
599
|
default:
|
|
602
600
|
if (!editMode && !event.ctrlKey && !event.metaKey && !event.altKey && /^[\w\d ]$/.test(key)) {
|
|
603
601
|
startEditMode(key);
|
|
@@ -624,14 +622,14 @@ const Grid = function Grid2(props) {
|
|
|
624
622
|
case " ":
|
|
625
623
|
if (focusedPart === "body") {
|
|
626
624
|
if (event.ctrlKey) {
|
|
627
|
-
if (cursorColIdx
|
|
625
|
+
if (cursorColIdx !== void 0) {
|
|
628
626
|
rangeSelection.selectRange({
|
|
629
627
|
start: { rowIdx: 0, colIdx: cursorColIdx },
|
|
630
628
|
end: { rowIdx: sortedRowData.length, colIdx: cursorColIdx }
|
|
631
629
|
});
|
|
632
630
|
}
|
|
633
631
|
} else {
|
|
634
|
-
if (cursorRowIdx
|
|
632
|
+
if (cursorRowIdx !== void 0) {
|
|
635
633
|
selectRows({
|
|
636
634
|
rowIndex: cursorRowIdx,
|
|
637
635
|
isRange: false,
|
|
@@ -641,9 +639,8 @@ const Grid = function Grid2(props) {
|
|
|
641
639
|
}
|
|
642
640
|
}
|
|
643
641
|
break;
|
|
644
|
-
} else {
|
|
645
|
-
return false;
|
|
646
642
|
}
|
|
643
|
+
return false;
|
|
647
644
|
case "a":
|
|
648
645
|
if (event.ctrlKey || event.metaKey) {
|
|
649
646
|
rangeSelection.selectRange({
|
|
@@ -652,9 +649,8 @@ const Grid = function Grid2(props) {
|
|
|
652
649
|
});
|
|
653
650
|
selectAll();
|
|
654
651
|
return true;
|
|
655
|
-
} else {
|
|
656
|
-
return false;
|
|
657
652
|
}
|
|
653
|
+
return false;
|
|
658
654
|
default:
|
|
659
655
|
return false;
|
|
660
656
|
}
|
|
@@ -676,6 +672,7 @@ const Grid = function Grid2(props) {
|
|
|
676
672
|
);
|
|
677
673
|
const clipboardKeyHandler = useCallback(
|
|
678
674
|
(event) => {
|
|
675
|
+
var _a2, _b2;
|
|
679
676
|
const { key } = event;
|
|
680
677
|
if (key === "c" && (event.ctrlKey || event.metaKey) && rangeSelection.selectedCellRange) {
|
|
681
678
|
const { start, end } = rangeSelection.selectedCellRange;
|
|
@@ -688,7 +685,7 @@ const Grid = function Grid2(props) {
|
|
|
688
685
|
const rowText = [];
|
|
689
686
|
for (let c2 = minCol; c2 <= maxCol; ++c2) {
|
|
690
687
|
const col = cols[c2];
|
|
691
|
-
const cellValue = col.info.props.getValue(row);
|
|
688
|
+
const cellValue = (_b2 = col == null ? void 0 : (_a2 = col.info.props).getValue) == null ? void 0 : _b2.call(_a2, row);
|
|
692
689
|
rowText.push(cellValue);
|
|
693
690
|
}
|
|
694
691
|
text.push(rowText.join(" "));
|
|
@@ -788,7 +785,7 @@ const Grid = function Grid2(props) {
|
|
|
788
785
|
break;
|
|
789
786
|
case "Enter":
|
|
790
787
|
if (editMode && !event.ctrlKey && !event.metaKey && !event.altKey && !event.shiftKey) {
|
|
791
|
-
if (cursorRowIdx
|
|
788
|
+
if (cursorRowIdx === void 0) {
|
|
792
789
|
moveCursor(focusedPart, 0, 0);
|
|
793
790
|
} else {
|
|
794
791
|
moveCursor(focusedPart, cursorRowIdx + 1, cursorColIdx);
|
|
@@ -829,7 +826,7 @@ const Grid = function Grid2(props) {
|
|
|
829
826
|
);
|
|
830
827
|
const onKeyDown = useCallback(
|
|
831
828
|
(event) => {
|
|
832
|
-
if (cursorColIdx
|
|
829
|
+
if (cursorColIdx !== void 0 && cursorRowIdx !== void 0) {
|
|
833
830
|
const column = cols[cursorColIdx];
|
|
834
831
|
if (column.info.props.onKeyDown) {
|
|
835
832
|
column.info.props.onKeyDown(event, cursorRowIdx);
|
|
@@ -880,143 +877,139 @@ const Grid = function Grid2(props) {
|
|
|
880
877
|
onVisibleRowRangeChange(visRowRng.start, visRowRng.end);
|
|
881
878
|
}
|
|
882
879
|
}, [onVisibleRowRangeChange, visRowRng]);
|
|
883
|
-
return /* @__PURE__ */ jsx(GridContext.Provider, {
|
|
884
|
-
|
|
885
|
-
|
|
886
|
-
|
|
887
|
-
|
|
888
|
-
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
|
|
892
|
-
|
|
893
|
-
|
|
894
|
-
|
|
895
|
-
|
|
896
|
-
|
|
897
|
-
|
|
898
|
-
|
|
899
|
-
|
|
900
|
-
|
|
901
|
-
|
|
902
|
-
|
|
903
|
-
|
|
904
|
-
|
|
905
|
-
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
909
|
-
|
|
910
|
-
|
|
911
|
-
|
|
912
|
-
|
|
913
|
-
|
|
914
|
-
|
|
915
|
-
|
|
916
|
-
|
|
917
|
-
|
|
918
|
-
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
944
|
-
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
|
|
948
|
-
|
|
949
|
-
|
|
950
|
-
|
|
951
|
-
|
|
952
|
-
|
|
953
|
-
|
|
954
|
-
|
|
955
|
-
|
|
956
|
-
|
|
957
|
-
|
|
958
|
-
|
|
959
|
-
|
|
960
|
-
|
|
961
|
-
|
|
962
|
-
|
|
963
|
-
|
|
964
|
-
|
|
965
|
-
|
|
966
|
-
|
|
967
|
-
|
|
968
|
-
|
|
969
|
-
|
|
970
|
-
|
|
971
|
-
|
|
972
|
-
|
|
973
|
-
|
|
974
|
-
|
|
975
|
-
|
|
976
|
-
|
|
977
|
-
|
|
978
|
-
|
|
979
|
-
|
|
980
|
-
|
|
981
|
-
|
|
982
|
-
|
|
983
|
-
|
|
984
|
-
|
|
985
|
-
|
|
986
|
-
|
|
987
|
-
|
|
988
|
-
|
|
989
|
-
|
|
990
|
-
|
|
991
|
-
|
|
992
|
-
|
|
993
|
-
|
|
994
|
-
|
|
995
|
-
|
|
996
|
-
|
|
997
|
-
|
|
998
|
-
|
|
999
|
-
|
|
1000
|
-
|
|
1001
|
-
|
|
1002
|
-
|
|
1003
|
-
|
|
1004
|
-
|
|
1005
|
-
|
|
1006
|
-
|
|
1007
|
-
|
|
1008
|
-
|
|
1009
|
-
|
|
1010
|
-
|
|
1011
|
-
|
|
1012
|
-
|
|
1013
|
-
|
|
1014
|
-
|
|
1015
|
-
|
|
1016
|
-
})
|
|
1017
|
-
})
|
|
1018
|
-
})
|
|
1019
|
-
});
|
|
880
|
+
return /* @__PURE__ */ jsx(GridContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsx(LayoutContext.Provider, { value: layoutContext, children: /* @__PURE__ */ jsx(SelectionContext.Provider, { value: selectionContext, children: /* @__PURE__ */ jsx(ColumnDragContext.Provider, { value: columnDragContext, children: /* @__PURE__ */ jsx(CursorContext.Provider, { value: cursorContext, children: /* @__PURE__ */ jsx(SizingContext.Provider, { value: sizingContext, children: /* @__PURE__ */ jsx(EditorContext.Provider, { value: editorContext, children: /* @__PURE__ */ jsx(ColumnDataContext.Provider, { value: columnDataContext, children: /* @__PURE__ */ jsxs(ColumnSortContext.Provider, { value: columnSortContext, children: [
|
|
881
|
+
props.children,
|
|
882
|
+
/* @__PURE__ */ jsxs(
|
|
883
|
+
"div",
|
|
884
|
+
{
|
|
885
|
+
className: clsx(
|
|
886
|
+
withBaseName(),
|
|
887
|
+
{
|
|
888
|
+
[withBaseName("zebra")]: zebra,
|
|
889
|
+
[withBaseName("columnSeparators")]: columnSeparators,
|
|
890
|
+
[withBaseName("pinnedSeparators")]: pinnedSeparators,
|
|
891
|
+
[withBaseName("primaryBackground")]: variant === "primary",
|
|
892
|
+
[withBaseName("secondaryBackground")]: variant === "secondary"
|
|
893
|
+
},
|
|
894
|
+
className
|
|
895
|
+
),
|
|
896
|
+
style: rootStyle,
|
|
897
|
+
ref: rootRef,
|
|
898
|
+
onKeyDown,
|
|
899
|
+
onKeyUp,
|
|
900
|
+
onMouseDown,
|
|
901
|
+
onFocus,
|
|
902
|
+
onBlur,
|
|
903
|
+
"data-name": "grid-root",
|
|
904
|
+
role: "grid",
|
|
905
|
+
"aria-colcount": cols.length,
|
|
906
|
+
"aria-rowcount": rowCount + headRowCount,
|
|
907
|
+
"aria-multiselectable": rowSelectionMode === "multi",
|
|
908
|
+
children: [
|
|
909
|
+
/* @__PURE__ */ jsx(CellMeasure, { setRowHeight }),
|
|
910
|
+
/* @__PURE__ */ jsx(
|
|
911
|
+
Scrollable,
|
|
912
|
+
{
|
|
913
|
+
resizeClient,
|
|
914
|
+
scrollLeft,
|
|
915
|
+
scrollTop,
|
|
916
|
+
scrollSource,
|
|
917
|
+
scroll,
|
|
918
|
+
scrollerRef: scrollableRef,
|
|
919
|
+
topRef,
|
|
920
|
+
rightRef,
|
|
921
|
+
bottomRef,
|
|
922
|
+
leftRef,
|
|
923
|
+
middleRef
|
|
924
|
+
}
|
|
925
|
+
),
|
|
926
|
+
!hideHeader && leftCols.length > 0 && /* @__PURE__ */ jsx(
|
|
927
|
+
TopLeftPart,
|
|
928
|
+
{
|
|
929
|
+
onWheel,
|
|
930
|
+
columns: leftCols,
|
|
931
|
+
columnGroups: leftGroups,
|
|
932
|
+
rightShadow: isLeftRaised,
|
|
933
|
+
bottomShadow: isHeaderRaised
|
|
934
|
+
}
|
|
935
|
+
),
|
|
936
|
+
!hideHeader && /* @__PURE__ */ jsx(
|
|
937
|
+
TopPart,
|
|
938
|
+
{
|
|
939
|
+
columns: headVisibleColumns,
|
|
940
|
+
columnGroups: visColGrps,
|
|
941
|
+
topRef,
|
|
942
|
+
onWheel,
|
|
943
|
+
midGap,
|
|
944
|
+
bottomShadow: isHeaderRaised
|
|
945
|
+
}
|
|
946
|
+
),
|
|
947
|
+
!hideHeader && rightCols.length > 0 && /* @__PURE__ */ jsx(
|
|
948
|
+
TopRightPart,
|
|
949
|
+
{
|
|
950
|
+
onWheel,
|
|
951
|
+
columns: rightCols,
|
|
952
|
+
columnGroups: rightGroups,
|
|
953
|
+
leftShadow: isRightRaised,
|
|
954
|
+
bottomShadow: isHeaderRaised
|
|
955
|
+
}
|
|
956
|
+
),
|
|
957
|
+
leftCols.length > 0 && /* @__PURE__ */ jsx(
|
|
958
|
+
LeftPart,
|
|
959
|
+
{
|
|
960
|
+
leftRef,
|
|
961
|
+
onWheel,
|
|
962
|
+
columns: leftCols,
|
|
963
|
+
rows,
|
|
964
|
+
rightShadow: isLeftRaised,
|
|
965
|
+
hoverOverRowKey: hoverRowKey,
|
|
966
|
+
setHoverOverRowKey: setHoverRowKey,
|
|
967
|
+
zebra,
|
|
968
|
+
getRowValidationStatus
|
|
969
|
+
}
|
|
970
|
+
),
|
|
971
|
+
/* @__PURE__ */ jsx(
|
|
972
|
+
MiddlePart,
|
|
973
|
+
{
|
|
974
|
+
middleRef,
|
|
975
|
+
onWheel,
|
|
976
|
+
columns: bodyVisibleColumns,
|
|
977
|
+
rows,
|
|
978
|
+
hoverOverRowKey: hoverRowKey,
|
|
979
|
+
setHoverOverRowKey: setHoverRowKey,
|
|
980
|
+
midGap,
|
|
981
|
+
zebra,
|
|
982
|
+
getRowValidationStatus
|
|
983
|
+
}
|
|
984
|
+
),
|
|
985
|
+
rightCols.length > 0 && /* @__PURE__ */ jsx(
|
|
986
|
+
RightPart,
|
|
987
|
+
{
|
|
988
|
+
rightRef,
|
|
989
|
+
onWheel,
|
|
990
|
+
columns: rightCols,
|
|
991
|
+
rows,
|
|
992
|
+
leftShadow: isRightRaised,
|
|
993
|
+
hoverOverRowKey: hoverRowKey,
|
|
994
|
+
setHoverOverRowKey: setHoverRowKey,
|
|
995
|
+
zebra,
|
|
996
|
+
getRowValidationStatus
|
|
997
|
+
}
|
|
998
|
+
),
|
|
999
|
+
/* @__PURE__ */ jsx(ColumnDropTarget, { x: activeTarget == null ? void 0 : activeTarget.x }),
|
|
1000
|
+
/* @__PURE__ */ jsx(
|
|
1001
|
+
ColumnGhost,
|
|
1002
|
+
{
|
|
1003
|
+
columns: cols,
|
|
1004
|
+
rows,
|
|
1005
|
+
dragState,
|
|
1006
|
+
zebra
|
|
1007
|
+
}
|
|
1008
|
+
)
|
|
1009
|
+
]
|
|
1010
|
+
}
|
|
1011
|
+
)
|
|
1012
|
+
] }) }) }) }) }) }) }) }) });
|
|
1020
1013
|
};
|
|
1021
1014
|
|
|
1022
1015
|
export { Grid, SortOrder };
|