@salt-ds/data-grid 1.0.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-cjs/node_modules/style-inject/dist/style-inject.es.js +31 -0
- package/dist-cjs/node_modules/style-inject/dist/style-inject.es.js.map +1 -0
- package/dist-cjs/packages/grid/src/BaseCell.css.js +9 -0
- package/dist-cjs/packages/grid/src/BaseCell.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/BaseCell.js +81 -0
- package/dist-cjs/packages/grid/src/BaseCell.js.map +1 -0
- package/dist-cjs/packages/grid/src/CellEditor.js +29 -0
- package/dist-cjs/packages/grid/src/CellEditor.js.map +1 -0
- package/dist-cjs/packages/grid/src/CheckboxCell.css.js +9 -0
- package/dist-cjs/packages/grid/src/CheckboxCell.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/ColumnDataContext.js +18 -0
- package/dist-cjs/packages/grid/src/ColumnDataContext.js.map +1 -0
- package/dist-cjs/packages/grid/src/ColumnDragContext.js +20 -0
- package/dist-cjs/packages/grid/src/ColumnDragContext.js.map +1 -0
- package/dist-cjs/packages/grid/src/ColumnGroup.js +32 -0
- package/dist-cjs/packages/grid/src/ColumnGroup.js.map +1 -0
- package/dist-cjs/packages/grid/src/CornerTag.css.js +9 -0
- package/dist-cjs/packages/grid/src/CornerTag.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/CornerTag.js +15 -0
- package/dist-cjs/packages/grid/src/CornerTag.js.map +1 -0
- package/dist-cjs/packages/grid/src/CursorContext.js +20 -0
- package/dist-cjs/packages/grid/src/CursorContext.js.map +1 -0
- package/dist-cjs/packages/grid/src/DropdownCellEditor.css.js +9 -0
- package/dist-cjs/packages/grid/src/DropdownCellEditor.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/DropdownCellEditor.js +75 -0
- package/dist-cjs/packages/grid/src/DropdownCellEditor.js.map +1 -0
- package/dist-cjs/packages/grid/src/EditorContext.js +20 -0
- package/dist-cjs/packages/grid/src/EditorContext.js.map +1 -0
- package/dist-cjs/packages/grid/src/Grid.css.js +9 -0
- package/dist-cjs/packages/grid/src/Grid.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/Grid.js +938 -0
- package/dist-cjs/packages/grid/src/Grid.js.map +1 -0
- package/dist-cjs/packages/grid/src/GridColumn.js +43 -0
- package/dist-cjs/packages/grid/src/GridColumn.js.map +1 -0
- package/dist-cjs/packages/grid/src/GridContext.js +20 -0
- package/dist-cjs/packages/grid/src/GridContext.js.map +1 -0
- package/dist-cjs/packages/grid/src/GroupHeaderCell.css.js +9 -0
- package/dist-cjs/packages/grid/src/GroupHeaderCell.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/GroupHeaderCell.js +50 -0
- package/dist-cjs/packages/grid/src/GroupHeaderCell.js.map +1 -0
- package/dist-cjs/packages/grid/src/GroupHeaderCellValue.js +16 -0
- package/dist-cjs/packages/grid/src/GroupHeaderCellValue.js.map +1 -0
- package/dist-cjs/packages/grid/src/HeaderCell.css.js +9 -0
- package/dist-cjs/packages/grid/src/HeaderCell.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/HeaderCell.js +120 -0
- package/dist-cjs/packages/grid/src/HeaderCell.js.map +1 -0
- package/dist-cjs/packages/grid/src/HeaderCellValue.js +19 -0
- package/dist-cjs/packages/grid/src/HeaderCellValue.js.map +1 -0
- package/dist-cjs/packages/grid/src/LayoutContext.js +12 -0
- package/dist-cjs/packages/grid/src/LayoutContext.js.map +1 -0
- package/dist-cjs/packages/grid/src/NumberRange.js +63 -0
- package/dist-cjs/packages/grid/src/NumberRange.js.map +1 -0
- package/dist-cjs/packages/grid/src/NumericColumn.css.js +9 -0
- package/dist-cjs/packages/grid/src/NumericColumn.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/NumericColumn.js +108 -0
- package/dist-cjs/packages/grid/src/NumericColumn.js.map +1 -0
- package/dist-cjs/packages/grid/src/RowSelectionCheckboxCellValue.js +37 -0
- package/dist-cjs/packages/grid/src/RowSelectionCheckboxCellValue.js.map +1 -0
- package/dist-cjs/packages/grid/src/RowSelectionCheckboxColumn.js +32 -0
- package/dist-cjs/packages/grid/src/RowSelectionCheckboxColumn.js.map +1 -0
- package/dist-cjs/packages/grid/src/RowSelectionCheckboxHeaderCellValue.js +48 -0
- package/dist-cjs/packages/grid/src/RowSelectionCheckboxHeaderCellValue.js.map +1 -0
- package/dist-cjs/packages/grid/src/RowSelectionRadioCellValue.js +25 -0
- package/dist-cjs/packages/grid/src/RowSelectionRadioCellValue.js.map +1 -0
- package/dist-cjs/packages/grid/src/RowSelectionRadioColumn.js +30 -0
- package/dist-cjs/packages/grid/src/RowSelectionRadioColumn.js.map +1 -0
- package/dist-cjs/packages/grid/src/RowSelectionRadioHeaderCell.js +26 -0
- package/dist-cjs/packages/grid/src/RowSelectionRadioHeaderCell.js.map +1 -0
- package/dist-cjs/packages/grid/src/SelectionContext.js +20 -0
- package/dist-cjs/packages/grid/src/SelectionContext.js.map +1 -0
- package/dist-cjs/packages/grid/src/SizingContext.js +20 -0
- package/dist-cjs/packages/grid/src/SizingContext.js.map +1 -0
- package/dist-cjs/packages/grid/src/TextCellEditor.css.js +9 -0
- package/dist-cjs/packages/grid/src/TextCellEditor.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/TextCellEditor.js +85 -0
- package/dist-cjs/packages/grid/src/TextCellEditor.js.map +1 -0
- package/dist-cjs/packages/grid/src/index.js +59 -0
- package/dist-cjs/packages/grid/src/index.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/Cell.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/Cell.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/Cell.js +59 -0
- package/dist-cjs/packages/grid/src/internal/Cell.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/CellMeasure.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/CellMeasure.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/CellMeasure.js +41 -0
- package/dist-cjs/packages/grid/src/internal/CellMeasure.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/ColumnDropTarget.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/ColumnDropTarget.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/ColumnDropTarget.js +28 -0
- package/dist-cjs/packages/grid/src/internal/ColumnDropTarget.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/ColumnGhost.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/ColumnGhost.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/ColumnGhost.js +51 -0
- package/dist-cjs/packages/grid/src/internal/ColumnGhost.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/Cursor.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/Cursor.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/Cursor.js +17 -0
- package/dist-cjs/packages/grid/src/internal/Cursor.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/DefaultCellValue.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/DefaultCellValue.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/DefaultCellValue.js +26 -0
- package/dist-cjs/packages/grid/src/internal/DefaultCellValue.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/FakeCell.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/FakeCell.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/FakeCell.js +19 -0
- package/dist-cjs/packages/grid/src/internal/FakeCell.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/FakeGroupCell.js +12 -0
- package/dist-cjs/packages/grid/src/internal/FakeGroupCell.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/FakeHeaderCell.js +14 -0
- package/dist-cjs/packages/grid/src/internal/FakeHeaderCell.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/GroupHeaderRow.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/GroupHeaderRow.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/GroupHeaderRow.js +38 -0
- package/dist-cjs/packages/grid/src/internal/GroupHeaderRow.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/HeaderRow.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/HeaderRow.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/HeaderRow.js +42 -0
- package/dist-cjs/packages/grid/src/internal/HeaderRow.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/LeftPart.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/LeftPart.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/LeftPart.js +62 -0
- package/dist-cjs/packages/grid/src/internal/LeftPart.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/MiddlePart.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/MiddlePart.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/MiddlePart.js +54 -0
- package/dist-cjs/packages/grid/src/internal/MiddlePart.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/RightPart.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/RightPart.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/RightPart.js +62 -0
- package/dist-cjs/packages/grid/src/internal/RightPart.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/Scrollable.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/Scrollable.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/Scrollable.js +89 -0
- package/dist-cjs/packages/grid/src/internal/Scrollable.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/TableBody.js +70 -0
- package/dist-cjs/packages/grid/src/internal/TableBody.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/TableColGroup.js +37 -0
- package/dist-cjs/packages/grid/src/internal/TableColGroup.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/TableRow.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/TableRow.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/TableRow.js +99 -0
- package/dist-cjs/packages/grid/src/internal/TableRow.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/TopLeftPart.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/TopLeftPart.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/TopLeftPart.js +54 -0
- package/dist-cjs/packages/grid/src/internal/TopLeftPart.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/TopPart.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/TopPart.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/TopPart.js +57 -0
- package/dist-cjs/packages/grid/src/internal/TopPart.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/TopRightPart.css.js +9 -0
- package/dist-cjs/packages/grid/src/internal/TopRightPart.css.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/TopRightPart.js +55 -0
- package/dist-cjs/packages/grid/src/internal/TopRightPart.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/gridHooks.js +916 -0
- package/dist-cjs/packages/grid/src/internal/gridHooks.js.map +1 -0
- package/dist-cjs/packages/grid/src/internal/utils.js +71 -0
- package/dist-cjs/packages/grid/src/internal/utils.js.map +1 -0
- package/dist-es/node_modules/style-inject/dist/style-inject.es.js +29 -0
- package/dist-es/node_modules/style-inject/dist/style-inject.es.js.map +1 -0
- package/dist-es/packages/grid/src/BaseCell.css.js +7 -0
- package/dist-es/packages/grid/src/BaseCell.css.js.map +1 -0
- package/dist-es/packages/grid/src/BaseCell.js +72 -0
- package/dist-es/packages/grid/src/BaseCell.js.map +1 -0
- package/dist-es/packages/grid/src/CellEditor.js +25 -0
- package/dist-es/packages/grid/src/CellEditor.js.map +1 -0
- package/dist-es/packages/grid/src/CheckboxCell.css.js +7 -0
- package/dist-es/packages/grid/src/CheckboxCell.css.js.map +1 -0
- package/dist-es/packages/grid/src/ColumnDataContext.js +13 -0
- package/dist-es/packages/grid/src/ColumnDataContext.js.map +1 -0
- package/dist-es/packages/grid/src/ColumnDragContext.js +15 -0
- package/dist-es/packages/grid/src/ColumnDragContext.js.map +1 -0
- package/dist-es/packages/grid/src/ColumnGroup.js +28 -0
- package/dist-es/packages/grid/src/ColumnGroup.js.map +1 -0
- package/dist-es/packages/grid/src/CornerTag.css.js +7 -0
- package/dist-es/packages/grid/src/CornerTag.css.js.map +1 -0
- package/dist-es/packages/grid/src/CornerTag.js +11 -0
- package/dist-es/packages/grid/src/CornerTag.js.map +1 -0
- package/dist-es/packages/grid/src/CursorContext.js +15 -0
- package/dist-es/packages/grid/src/CursorContext.js.map +1 -0
- package/dist-es/packages/grid/src/DropdownCellEditor.css.js +7 -0
- package/dist-es/packages/grid/src/DropdownCellEditor.css.js.map +1 -0
- package/dist-es/packages/grid/src/DropdownCellEditor.js +71 -0
- package/dist-es/packages/grid/src/DropdownCellEditor.js.map +1 -0
- package/dist-es/packages/grid/src/EditorContext.js +15 -0
- package/dist-es/packages/grid/src/EditorContext.js.map +1 -0
- package/dist-es/packages/grid/src/Grid.css.js +7 -0
- package/dist-es/packages/grid/src/Grid.css.js.map +1 -0
- package/dist-es/packages/grid/src/Grid.js +930 -0
- package/dist-es/packages/grid/src/Grid.js.map +1 -0
- package/dist-es/packages/grid/src/GridColumn.js +39 -0
- package/dist-es/packages/grid/src/GridColumn.js.map +1 -0
- package/dist-es/packages/grid/src/GridContext.js +15 -0
- package/dist-es/packages/grid/src/GridContext.js.map +1 -0
- package/dist-es/packages/grid/src/GroupHeaderCell.css.js +7 -0
- package/dist-es/packages/grid/src/GroupHeaderCell.css.js.map +1 -0
- package/dist-es/packages/grid/src/GroupHeaderCell.js +42 -0
- package/dist-es/packages/grid/src/GroupHeaderCell.js.map +1 -0
- package/dist-es/packages/grid/src/GroupHeaderCellValue.js +12 -0
- package/dist-es/packages/grid/src/GroupHeaderCellValue.js.map +1 -0
- package/dist-es/packages/grid/src/HeaderCell.css.js +7 -0
- package/dist-es/packages/grid/src/HeaderCell.css.js.map +1 -0
- package/dist-es/packages/grid/src/HeaderCell.js +110 -0
- package/dist-es/packages/grid/src/HeaderCell.js.map +1 -0
- package/dist-es/packages/grid/src/HeaderCellValue.js +15 -0
- package/dist-es/packages/grid/src/HeaderCellValue.js.map +1 -0
- package/dist-es/packages/grid/src/LayoutContext.js +8 -0
- package/dist-es/packages/grid/src/LayoutContext.js.map +1 -0
- package/dist-es/packages/grid/src/NumberRange.js +58 -0
- package/dist-es/packages/grid/src/NumberRange.js.map +1 -0
- package/dist-es/packages/grid/src/NumericColumn.css.js +7 -0
- package/dist-es/packages/grid/src/NumericColumn.css.js.map +1 -0
- package/dist-es/packages/grid/src/NumericColumn.js +102 -0
- package/dist-es/packages/grid/src/NumericColumn.js.map +1 -0
- package/dist-es/packages/grid/src/RowSelectionCheckboxCellValue.js +33 -0
- package/dist-es/packages/grid/src/RowSelectionCheckboxCellValue.js.map +1 -0
- package/dist-es/packages/grid/src/RowSelectionCheckboxColumn.js +28 -0
- package/dist-es/packages/grid/src/RowSelectionCheckboxColumn.js.map +1 -0
- package/dist-es/packages/grid/src/RowSelectionCheckboxHeaderCellValue.js +44 -0
- package/dist-es/packages/grid/src/RowSelectionCheckboxHeaderCellValue.js.map +1 -0
- package/dist-es/packages/grid/src/RowSelectionRadioCellValue.js +21 -0
- package/dist-es/packages/grid/src/RowSelectionRadioCellValue.js.map +1 -0
- package/dist-es/packages/grid/src/RowSelectionRadioColumn.js +26 -0
- package/dist-es/packages/grid/src/RowSelectionRadioColumn.js.map +1 -0
- package/dist-es/packages/grid/src/RowSelectionRadioHeaderCell.js +18 -0
- package/dist-es/packages/grid/src/RowSelectionRadioHeaderCell.js.map +1 -0
- package/dist-es/packages/grid/src/SelectionContext.js +15 -0
- package/dist-es/packages/grid/src/SelectionContext.js.map +1 -0
- package/dist-es/packages/grid/src/SizingContext.js +15 -0
- package/dist-es/packages/grid/src/SizingContext.js.map +1 -0
- package/dist-es/packages/grid/src/TextCellEditor.css.js +7 -0
- package/dist-es/packages/grid/src/TextCellEditor.css.js.map +1 -0
- package/dist-es/packages/grid/src/TextCellEditor.js +81 -0
- package/dist-es/packages/grid/src/TextCellEditor.js.map +1 -0
- package/dist-es/packages/grid/src/index.js +22 -0
- package/dist-es/packages/grid/src/index.js.map +1 -0
- package/dist-es/packages/grid/src/internal/Cell.css.js +7 -0
- package/dist-es/packages/grid/src/internal/Cell.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/Cell.js +51 -0
- package/dist-es/packages/grid/src/internal/Cell.js.map +1 -0
- package/dist-es/packages/grid/src/internal/CellMeasure.css.js +7 -0
- package/dist-es/packages/grid/src/internal/CellMeasure.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/CellMeasure.js +37 -0
- package/dist-es/packages/grid/src/internal/CellMeasure.js.map +1 -0
- package/dist-es/packages/grid/src/internal/ColumnDropTarget.css.js +7 -0
- package/dist-es/packages/grid/src/internal/ColumnDropTarget.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/ColumnDropTarget.js +24 -0
- package/dist-es/packages/grid/src/internal/ColumnDropTarget.js.map +1 -0
- package/dist-es/packages/grid/src/internal/ColumnGhost.css.js +7 -0
- package/dist-es/packages/grid/src/internal/ColumnGhost.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/ColumnGhost.js +47 -0
- package/dist-es/packages/grid/src/internal/ColumnGhost.js.map +1 -0
- package/dist-es/packages/grid/src/internal/Cursor.css.js +7 -0
- package/dist-es/packages/grid/src/internal/Cursor.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/Cursor.js +13 -0
- package/dist-es/packages/grid/src/internal/Cursor.js.map +1 -0
- package/dist-es/packages/grid/src/internal/DefaultCellValue.css.js +7 -0
- package/dist-es/packages/grid/src/internal/DefaultCellValue.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/DefaultCellValue.js +18 -0
- package/dist-es/packages/grid/src/internal/DefaultCellValue.js.map +1 -0
- package/dist-es/packages/grid/src/internal/FakeCell.css.js +7 -0
- package/dist-es/packages/grid/src/internal/FakeCell.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/FakeCell.js +15 -0
- package/dist-es/packages/grid/src/internal/FakeCell.js.map +1 -0
- package/dist-es/packages/grid/src/internal/FakeGroupCell.js +8 -0
- package/dist-es/packages/grid/src/internal/FakeGroupCell.js.map +1 -0
- package/dist-es/packages/grid/src/internal/FakeHeaderCell.js +10 -0
- package/dist-es/packages/grid/src/internal/FakeHeaderCell.js.map +1 -0
- package/dist-es/packages/grid/src/internal/GroupHeaderRow.css.js +7 -0
- package/dist-es/packages/grid/src/internal/GroupHeaderRow.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/GroupHeaderRow.js +34 -0
- package/dist-es/packages/grid/src/internal/GroupHeaderRow.js.map +1 -0
- package/dist-es/packages/grid/src/internal/HeaderRow.css.js +7 -0
- package/dist-es/packages/grid/src/internal/HeaderRow.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/HeaderRow.js +38 -0
- package/dist-es/packages/grid/src/internal/HeaderRow.js.map +1 -0
- package/dist-es/packages/grid/src/internal/LeftPart.css.js +7 -0
- package/dist-es/packages/grid/src/internal/LeftPart.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/LeftPart.js +54 -0
- package/dist-es/packages/grid/src/internal/LeftPart.js.map +1 -0
- package/dist-es/packages/grid/src/internal/MiddlePart.css.js +7 -0
- package/dist-es/packages/grid/src/internal/MiddlePart.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/MiddlePart.js +50 -0
- package/dist-es/packages/grid/src/internal/MiddlePart.js.map +1 -0
- package/dist-es/packages/grid/src/internal/RightPart.css.js +7 -0
- package/dist-es/packages/grid/src/internal/RightPart.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/RightPart.js +54 -0
- package/dist-es/packages/grid/src/internal/RightPart.js.map +1 -0
- package/dist-es/packages/grid/src/internal/Scrollable.css.js +7 -0
- package/dist-es/packages/grid/src/internal/Scrollable.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/Scrollable.js +85 -0
- package/dist-es/packages/grid/src/internal/Scrollable.js.map +1 -0
- package/dist-es/packages/grid/src/internal/TableBody.js +66 -0
- package/dist-es/packages/grid/src/internal/TableBody.js.map +1 -0
- package/dist-es/packages/grid/src/internal/TableColGroup.js +32 -0
- package/dist-es/packages/grid/src/internal/TableColGroup.js.map +1 -0
- package/dist-es/packages/grid/src/internal/TableRow.css.js +7 -0
- package/dist-es/packages/grid/src/internal/TableRow.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/TableRow.js +91 -0
- package/dist-es/packages/grid/src/internal/TableRow.js.map +1 -0
- package/dist-es/packages/grid/src/internal/TopLeftPart.css.js +7 -0
- package/dist-es/packages/grid/src/internal/TopLeftPart.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/TopLeftPart.js +46 -0
- package/dist-es/packages/grid/src/internal/TopLeftPart.js.map +1 -0
- package/dist-es/packages/grid/src/internal/TopPart.css.js +7 -0
- package/dist-es/packages/grid/src/internal/TopPart.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/TopPart.js +49 -0
- package/dist-es/packages/grid/src/internal/TopPart.js.map +1 -0
- package/dist-es/packages/grid/src/internal/TopRightPart.css.js +7 -0
- package/dist-es/packages/grid/src/internal/TopRightPart.css.js.map +1 -0
- package/dist-es/packages/grid/src/internal/TopRightPart.js +47 -0
- package/dist-es/packages/grid/src/internal/TopRightPart.js.map +1 -0
- package/dist-es/packages/grid/src/internal/gridHooks.js +886 -0
- package/dist-es/packages/grid/src/internal/gridHooks.js.map +1 -0
- package/dist-es/packages/grid/src/internal/utils.js +61 -0
- package/dist-es/packages/grid/src/internal/utils.js.map +1 -0
- package/dist-types/BaseCell.d.ts +6 -0
- package/dist-types/CellEditor.d.ts +10 -0
- package/dist-types/ColumnDataContext.d.ts +7 -0
- package/dist-types/ColumnDragContext.d.ts +7 -0
- package/dist-types/ColumnGroup.d.ts +18 -0
- package/dist-types/CornerTag.d.ts +6 -0
- package/dist-types/CursorContext.d.ts +12 -0
- package/dist-types/DropdownCellEditor.d.ts +9 -0
- package/dist-types/EditorContext.d.ts +10 -0
- package/dist-types/Grid.d.ts +99 -0
- package/dist-types/GridColumn.d.ts +113 -0
- package/dist-types/GridContext.d.ts +16 -0
- package/dist-types/GroupHeaderCell.d.ts +8 -0
- package/dist-types/GroupHeaderCellValue.d.ts +3 -0
- package/dist-types/HeaderCell.d.ts +10 -0
- package/dist-types/HeaderCellValue.d.ts +3 -0
- package/dist-types/LayoutContext.d.ts +9 -0
- package/dist-types/NumberRange.d.ts +15 -0
- package/dist-types/NumericColumn.d.ts +15 -0
- package/dist-types/RowSelectionCheckboxCellValue.d.ts +4 -0
- package/dist-types/RowSelectionCheckboxColumn.d.ts +4 -0
- package/dist-types/RowSelectionCheckboxHeaderCellValue.d.ts +4 -0
- package/dist-types/RowSelectionRadioCellValue.d.ts +4 -0
- package/dist-types/RowSelectionRadioColumn.d.ts +4 -0
- package/dist-types/RowSelectionRadioHeaderCell.d.ts +4 -0
- package/dist-types/SelectionContext.d.ts +13 -0
- package/dist-types/SizingContext.d.ts +8 -0
- package/dist-types/TextCellEditor.d.ts +8 -0
- package/dist-types/index.d.ts +21 -0
- package/dist-types/internal/Cell.d.ts +9 -0
- package/dist-types/internal/CellMeasure.d.ts +6 -0
- package/dist-types/internal/ColumnDropTarget.d.ts +6 -0
- package/dist-types/internal/ColumnGhost.d.ts +11 -0
- package/dist-types/internal/Cursor.d.ts +5 -0
- package/dist-types/internal/DefaultCellValue.d.ts +4 -0
- package/dist-types/internal/FakeCell.d.ts +5 -0
- package/dist-types/internal/FakeGroupCell.d.ts +2 -0
- package/dist-types/internal/FakeHeaderCell.d.ts +2 -0
- package/dist-types/internal/GroupHeaderRow.d.ts +8 -0
- package/dist-types/internal/HeaderRow.d.ts +8 -0
- package/dist-types/internal/LeftPart.d.ts +14 -0
- package/dist-types/internal/MiddlePart.d.ts +14 -0
- package/dist-types/internal/RightPart.d.ts +14 -0
- package/dist-types/internal/Scrollable.d.ts +16 -0
- package/dist-types/internal/TableBody.d.ts +11 -0
- package/dist-types/internal/TableColGroup.d.ts +11 -0
- package/dist-types/internal/TableRow.d.ts +19 -0
- package/dist-types/internal/TopLeftPart.d.ts +11 -0
- package/dist-types/internal/TopPart.d.ts +12 -0
- package/dist-types/internal/TopRightPart.d.ts +11 -0
- package/dist-types/internal/gridHooks.d.ts +91 -0
- package/dist-types/internal/index.d.ts +21 -0
- package/dist-types/internal/utils.d.ts +13 -0
- package/package.json +41 -0
|
@@ -0,0 +1,886 @@
|
|
|
1
|
+
import { useRef, useState, useMemo, useCallback, Children, isValidElement, useEffect } from 'react';
|
|
2
|
+
import { NumberRange } from '../NumberRange.js';
|
|
3
|
+
import { getAttribute, makeMapAdder, makeMapDeleter, getCellPosition } from './utils.js';
|
|
4
|
+
import { useControlled } from '@salt-ds/core';
|
|
5
|
+
|
|
6
|
+
function useActiveOnWheel(onWheel) {
|
|
7
|
+
const tableRef = useRef(null);
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
const table = tableRef.current;
|
|
10
|
+
if (table && onWheel) {
|
|
11
|
+
table.addEventListener("wheel", onWheel, { passive: false });
|
|
12
|
+
return () => {
|
|
13
|
+
table.removeEventListener("wheel", onWheel);
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
}, [tableRef.current]);
|
|
17
|
+
return tableRef;
|
|
18
|
+
}
|
|
19
|
+
function sumWidth(columns) {
|
|
20
|
+
return columns.reduce((p, x) => p + x.info.width, 0);
|
|
21
|
+
}
|
|
22
|
+
function useSumWidth(columns) {
|
|
23
|
+
return useMemo(() => sumWidth(columns), [columns]);
|
|
24
|
+
}
|
|
25
|
+
function useSum(source) {
|
|
26
|
+
return useMemo(() => source.reduce((p, x) => p + x, 0), source);
|
|
27
|
+
}
|
|
28
|
+
function sumRangeWidth(columns, range) {
|
|
29
|
+
let w = 0;
|
|
30
|
+
range.forEach((i) => {
|
|
31
|
+
w += columns[i].info.width;
|
|
32
|
+
});
|
|
33
|
+
return w;
|
|
34
|
+
}
|
|
35
|
+
function useSumRangeWidth(columns, range) {
|
|
36
|
+
return useMemo(() => sumRangeWidth(columns, range), [columns, range]);
|
|
37
|
+
}
|
|
38
|
+
function useMemoRng(fn, deps) {
|
|
39
|
+
const prevRef = useRef(NumberRange.empty);
|
|
40
|
+
const range = useMemo(fn, deps);
|
|
41
|
+
if (!NumberRange.equals(prevRef.current, range)) {
|
|
42
|
+
prevRef.current = range;
|
|
43
|
+
}
|
|
44
|
+
return prevRef.current;
|
|
45
|
+
}
|
|
46
|
+
function useBodyVisibleColumnRange(midColumns, scrollLeft, clientMidWidth) {
|
|
47
|
+
return useMemoRng(() => {
|
|
48
|
+
if (clientMidWidth === 0 || midColumns.length === 0) {
|
|
49
|
+
return NumberRange.empty;
|
|
50
|
+
}
|
|
51
|
+
let width = scrollLeft;
|
|
52
|
+
let start = 0;
|
|
53
|
+
for (let i = 0; i < midColumns.length; ++i) {
|
|
54
|
+
const colWidth = midColumns[i].info.width;
|
|
55
|
+
if (width > colWidth) {
|
|
56
|
+
width -= colWidth;
|
|
57
|
+
} else {
|
|
58
|
+
start = i;
|
|
59
|
+
width += clientMidWidth;
|
|
60
|
+
break;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
let end = start + 1;
|
|
64
|
+
for (let i = start; i < midColumns.length; ++i) {
|
|
65
|
+
const colWidth = midColumns[i].info.width;
|
|
66
|
+
width -= colWidth;
|
|
67
|
+
end = i + 1;
|
|
68
|
+
if (width <= 0) {
|
|
69
|
+
break;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
if (end > midColumns.length) {
|
|
73
|
+
end = midColumns.length;
|
|
74
|
+
}
|
|
75
|
+
return new NumberRange(start, end);
|
|
76
|
+
}, [midColumns, scrollLeft, clientMidWidth]);
|
|
77
|
+
}
|
|
78
|
+
function useClientMidWidth(clientWidth, leftWidth, rightWidth) {
|
|
79
|
+
return useMemo(
|
|
80
|
+
() => clientWidth - leftWidth - rightWidth,
|
|
81
|
+
[clientWidth, leftWidth, rightWidth]
|
|
82
|
+
);
|
|
83
|
+
}
|
|
84
|
+
function useClientMidHeight(clientHeight, topHeight, botHeight) {
|
|
85
|
+
return useMemo(
|
|
86
|
+
() => clientHeight - topHeight - botHeight,
|
|
87
|
+
[clientHeight, topHeight, botHeight]
|
|
88
|
+
);
|
|
89
|
+
}
|
|
90
|
+
function useBodyVisibleAreaTop(rowHeight, visibleRowRange, topHeight) {
|
|
91
|
+
return useMemo(() => {
|
|
92
|
+
let top = topHeight + visibleRowRange.start * rowHeight;
|
|
93
|
+
if (visibleRowRange.start > 0) {
|
|
94
|
+
top += 1;
|
|
95
|
+
}
|
|
96
|
+
return top;
|
|
97
|
+
}, [rowHeight, visibleRowRange, topHeight]);
|
|
98
|
+
}
|
|
99
|
+
function useVisibleRowRange(scrollTop, clientMidHeight, rowHeight, rowCount) {
|
|
100
|
+
return useMemoRng(() => {
|
|
101
|
+
if (rowHeight < 1) {
|
|
102
|
+
return NumberRange.empty;
|
|
103
|
+
}
|
|
104
|
+
const firstRowHeight = rowHeight + 1;
|
|
105
|
+
const start = scrollTop > firstRowHeight ? 1 + Math.floor((scrollTop - firstRowHeight) / rowHeight) : 0;
|
|
106
|
+
let endPos = scrollTop + clientMidHeight;
|
|
107
|
+
if (start === 0) {
|
|
108
|
+
endPos -= 1;
|
|
109
|
+
}
|
|
110
|
+
const end = Math.min(
|
|
111
|
+
rowCount,
|
|
112
|
+
Math.max(start, Math.ceil(endPos / rowHeight))
|
|
113
|
+
);
|
|
114
|
+
return new NumberRange(start, end);
|
|
115
|
+
}, [scrollTop, clientMidHeight, rowHeight, rowCount]);
|
|
116
|
+
}
|
|
117
|
+
function useColumnRange(columns, range) {
|
|
118
|
+
return useMemo(() => columns.slice(range.start, range.end), [columns, range]);
|
|
119
|
+
}
|
|
120
|
+
function useLeftScrolledOutWidth(midColumns, bodyVisibleColumnRange) {
|
|
121
|
+
return useMemo(() => {
|
|
122
|
+
let w = 0;
|
|
123
|
+
for (let i = 0; i < bodyVisibleColumnRange.start; ++i) {
|
|
124
|
+
w += midColumns[i].info.width;
|
|
125
|
+
}
|
|
126
|
+
return w;
|
|
127
|
+
}, [midColumns, bodyVisibleColumnRange]);
|
|
128
|
+
}
|
|
129
|
+
function useRowModels(getKey, rowData, visibleRowRange) {
|
|
130
|
+
return useMemo(() => {
|
|
131
|
+
const rows = [];
|
|
132
|
+
visibleRowRange.forEach((i) => {
|
|
133
|
+
const key = getKey(rowData[i], i);
|
|
134
|
+
rows.push({ data: rowData[i], key, index: i });
|
|
135
|
+
});
|
|
136
|
+
return rows;
|
|
137
|
+
}, [getKey, rowData, visibleRowRange]);
|
|
138
|
+
}
|
|
139
|
+
const useColumnGroups = (grpPs, startIdx) => useMemo(
|
|
140
|
+
() => grpPs.map((data, i) => {
|
|
141
|
+
const childrenIds = Children.toArray(data.children).map((child) => {
|
|
142
|
+
if (!isValidElement(child)) {
|
|
143
|
+
return void 0;
|
|
144
|
+
}
|
|
145
|
+
return child.props.id;
|
|
146
|
+
}).filter((x) => x !== void 0);
|
|
147
|
+
const colSpan = childrenIds.length;
|
|
148
|
+
return {
|
|
149
|
+
data,
|
|
150
|
+
index: i + startIdx,
|
|
151
|
+
childrenIds,
|
|
152
|
+
colSpan,
|
|
153
|
+
columnSeparator: "regular",
|
|
154
|
+
rowSeparator: "regular"
|
|
155
|
+
};
|
|
156
|
+
}),
|
|
157
|
+
[grpPs, startIdx]
|
|
158
|
+
);
|
|
159
|
+
function useVisibleColumnGroupRange(bodyVisColRng, midCols, midGrpByColId, leftGrpCount) {
|
|
160
|
+
return useMemoRng(() => {
|
|
161
|
+
if (bodyVisColRng.length === 0) {
|
|
162
|
+
return NumberRange.empty;
|
|
163
|
+
}
|
|
164
|
+
const firstVisibleCol = midCols[bodyVisColRng.start];
|
|
165
|
+
const lastVisibleCol = midCols[bodyVisColRng.end - 1];
|
|
166
|
+
const firstVisibleGroup = midGrpByColId.get(firstVisibleCol.info.props.id);
|
|
167
|
+
const lastVisibleGroup = midGrpByColId.get(lastVisibleCol.info.props.id);
|
|
168
|
+
if (!firstVisibleGroup || !lastVisibleGroup) {
|
|
169
|
+
return NumberRange.empty;
|
|
170
|
+
}
|
|
171
|
+
return new NumberRange(
|
|
172
|
+
firstVisibleGroup.index - leftGrpCount,
|
|
173
|
+
lastVisibleGroup.index + 1 - leftGrpCount
|
|
174
|
+
);
|
|
175
|
+
}, [bodyVisColRng, midCols, midGrpByColId, leftGrpCount]);
|
|
176
|
+
}
|
|
177
|
+
function last(source) {
|
|
178
|
+
return source[source.length - 1];
|
|
179
|
+
}
|
|
180
|
+
function useHeadVisibleColumnRange(bodyVisColRng, visColGrps, midColsById, leftColCount) {
|
|
181
|
+
return useMemoRng(() => {
|
|
182
|
+
var _a, _b;
|
|
183
|
+
if (visColGrps.length === 0) {
|
|
184
|
+
return bodyVisColRng;
|
|
185
|
+
}
|
|
186
|
+
const firstVisibleGroup = visColGrps[0];
|
|
187
|
+
const lastVisibleGroup = last(visColGrps);
|
|
188
|
+
const firstColId = firstVisibleGroup.childrenIds[0];
|
|
189
|
+
const lastColId = last(lastVisibleGroup.childrenIds);
|
|
190
|
+
const firstColIdx = (_a = midColsById.get(firstColId)) == null ? void 0 : _a.index;
|
|
191
|
+
const lastColIdx = (_b = midColsById.get(lastColId)) == null ? void 0 : _b.index;
|
|
192
|
+
if (firstColIdx === void 0 || lastColIdx === void 0) {
|
|
193
|
+
return NumberRange.empty;
|
|
194
|
+
}
|
|
195
|
+
return new NumberRange(
|
|
196
|
+
firstColIdx - leftColCount,
|
|
197
|
+
lastColIdx + 1 - leftColCount
|
|
198
|
+
);
|
|
199
|
+
}, [bodyVisColRng, visColGrps, midColsById, leftColCount]);
|
|
200
|
+
}
|
|
201
|
+
function useCols(colInfos, startIdx, groups) {
|
|
202
|
+
return useMemo(() => {
|
|
203
|
+
const edgeColIds = /* @__PURE__ */ new Set();
|
|
204
|
+
groups.forEach((g) => {
|
|
205
|
+
edgeColIds.add(last(g.childrenIds));
|
|
206
|
+
});
|
|
207
|
+
const columnModels = colInfos.map((info, i) => ({
|
|
208
|
+
info,
|
|
209
|
+
index: i + startIdx,
|
|
210
|
+
separator: edgeColIds.has(info.props.id) ? "groupEdge" : "regular"
|
|
211
|
+
}));
|
|
212
|
+
return columnModels;
|
|
213
|
+
}, [colInfos, startIdx, groups]);
|
|
214
|
+
}
|
|
215
|
+
function useScrollToCell(visRowRng, rowHeight, clientMidHeight, midCols, bodyVisColRng, clientMidWidth, scroll) {
|
|
216
|
+
return useCallback(
|
|
217
|
+
(part, rowIdx, colIdx) => {
|
|
218
|
+
if (part !== "body") {
|
|
219
|
+
return;
|
|
220
|
+
}
|
|
221
|
+
let x = void 0;
|
|
222
|
+
let y = void 0;
|
|
223
|
+
if (rowIdx <= visRowRng.start) {
|
|
224
|
+
y = rowIdx === 0 ? 0 : 1 + rowHeight * rowIdx;
|
|
225
|
+
} else if (rowIdx >= visRowRng.end - 1) {
|
|
226
|
+
const extraBorder = rowIdx > 0 ? 1 : 0;
|
|
227
|
+
y = Math.max(
|
|
228
|
+
0,
|
|
229
|
+
rowHeight * rowIdx + extraBorder - clientMidHeight + rowHeight
|
|
230
|
+
);
|
|
231
|
+
}
|
|
232
|
+
const isMidCol = midCols.length > 0 && colIdx >= midCols[0].index && colIdx <= last(midCols).index;
|
|
233
|
+
if (isMidCol) {
|
|
234
|
+
const midColIdx = colIdx - midCols[0].index;
|
|
235
|
+
if (midColIdx <= bodyVisColRng.start) {
|
|
236
|
+
let w = 0;
|
|
237
|
+
for (let i = 0; i < midColIdx; ++i) {
|
|
238
|
+
w += midCols[i].info.width;
|
|
239
|
+
}
|
|
240
|
+
x = w;
|
|
241
|
+
} else if (midColIdx >= bodyVisColRng.end - 1) {
|
|
242
|
+
let w = 0;
|
|
243
|
+
for (let i = 0; i <= midColIdx; ++i) {
|
|
244
|
+
w += midCols[i].info.width;
|
|
245
|
+
}
|
|
246
|
+
x = Math.max(0, w - clientMidWidth);
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
if (x !== void 0 || y !== void 0) {
|
|
250
|
+
scroll(x, y, "table");
|
|
251
|
+
}
|
|
252
|
+
},
|
|
253
|
+
[
|
|
254
|
+
visRowRng,
|
|
255
|
+
rowHeight,
|
|
256
|
+
clientMidHeight,
|
|
257
|
+
midCols,
|
|
258
|
+
bodyVisColRng,
|
|
259
|
+
clientMidWidth,
|
|
260
|
+
scroll
|
|
261
|
+
]
|
|
262
|
+
);
|
|
263
|
+
}
|
|
264
|
+
const MIN_COLUMN_WIDTH = 10;
|
|
265
|
+
function useColumnResize(cols, resizeColumn) {
|
|
266
|
+
const columnResizeDataRef = useRef();
|
|
267
|
+
const onMouseUp = useCallback(() => {
|
|
268
|
+
var _a;
|
|
269
|
+
(_a = columnResizeDataRef.current) == null ? void 0 : _a.eventsUnsubscription();
|
|
270
|
+
columnResizeDataRef.current = void 0;
|
|
271
|
+
}, []);
|
|
272
|
+
const onMouseMove = useCallback((event) => {
|
|
273
|
+
const x = event.screenX;
|
|
274
|
+
const { startX, columnIndex, initialColumnWidth, minWidth } = columnResizeDataRef.current;
|
|
275
|
+
const shift = x - startX;
|
|
276
|
+
let width = Math.max(minWidth, initialColumnWidth + shift);
|
|
277
|
+
columnResizeDataRef.current.resizeColumn(columnIndex, Math.round(width));
|
|
278
|
+
}, []);
|
|
279
|
+
return useCallback(
|
|
280
|
+
(event) => {
|
|
281
|
+
const targetElement = event.target;
|
|
282
|
+
const [columnIndexAttribute, thElement] = getAttribute(
|
|
283
|
+
targetElement,
|
|
284
|
+
"data-column-index"
|
|
285
|
+
);
|
|
286
|
+
const columnIndex = parseInt(columnIndexAttribute, 10);
|
|
287
|
+
document.addEventListener("mouseup", onMouseUp);
|
|
288
|
+
document.addEventListener("mousemove", onMouseMove);
|
|
289
|
+
const initialColumnWidth = thElement.getBoundingClientRect().width;
|
|
290
|
+
columnResizeDataRef.current = {
|
|
291
|
+
startX: event.screenX,
|
|
292
|
+
startY: event.screenY,
|
|
293
|
+
eventsUnsubscription: () => {
|
|
294
|
+
document.removeEventListener("mouseup", onMouseUp);
|
|
295
|
+
document.removeEventListener("mousemove", onMouseMove);
|
|
296
|
+
},
|
|
297
|
+
columnIndex,
|
|
298
|
+
initialColumnWidth,
|
|
299
|
+
resizeColumn,
|
|
300
|
+
minWidth: cols[columnIndex].info.props.minWidth || MIN_COLUMN_WIDTH
|
|
301
|
+
};
|
|
302
|
+
event.preventDefault();
|
|
303
|
+
},
|
|
304
|
+
[resizeColumn]
|
|
305
|
+
);
|
|
306
|
+
}
|
|
307
|
+
function useFlatten(map) {
|
|
308
|
+
return useMemo(() => {
|
|
309
|
+
const entries = [...map.entries()].filter(([index, value]) => !!value);
|
|
310
|
+
entries.sort((a, b) => a[0] - b[0]);
|
|
311
|
+
return entries.map((x) => x[1]);
|
|
312
|
+
}, [map]);
|
|
313
|
+
}
|
|
314
|
+
function useColMap() {
|
|
315
|
+
return useState(/* @__PURE__ */ new Map());
|
|
316
|
+
}
|
|
317
|
+
function useGrpMap() {
|
|
318
|
+
return useState(/* @__PURE__ */ new Map());
|
|
319
|
+
}
|
|
320
|
+
function useColumnRegistry(children) {
|
|
321
|
+
const [leftColMap, setLeftColMap] = useColMap();
|
|
322
|
+
const [rightColMap, setRightColMap] = useColMap();
|
|
323
|
+
const [midColMap, setMidColMap] = useColMap();
|
|
324
|
+
const [leftGrpMap, setLeftGrpMap] = useGrpMap();
|
|
325
|
+
const [rightGrpMap, setRightGrpMap] = useGrpMap();
|
|
326
|
+
const [midGrpMap, setMidGrpMap] = useGrpMap();
|
|
327
|
+
const [editorMap, setEditorMap] = useState(
|
|
328
|
+
/* @__PURE__ */ new Map()
|
|
329
|
+
);
|
|
330
|
+
const leftColInfos = useFlatten(leftColMap);
|
|
331
|
+
const rightColInfos = useFlatten(rightColMap);
|
|
332
|
+
const midColInfos = useFlatten(midColMap);
|
|
333
|
+
const leftGrpPs = useFlatten(leftGrpMap);
|
|
334
|
+
const rightGrpPs = useFlatten(rightGrpMap);
|
|
335
|
+
const midGrpPs = useFlatten(midGrpMap);
|
|
336
|
+
const leftGroups = useColumnGroups(leftGrpPs, 0);
|
|
337
|
+
const midGroups = useColumnGroups(midGrpPs, leftGroups.length);
|
|
338
|
+
const rightGroups = useColumnGroups(
|
|
339
|
+
rightGrpPs,
|
|
340
|
+
leftGroups.length + midGroups.length
|
|
341
|
+
);
|
|
342
|
+
if (leftGroups.length > 0) {
|
|
343
|
+
last(leftGroups).columnSeparator = "pinned";
|
|
344
|
+
}
|
|
345
|
+
if (rightGroups.length > 0 && midGroups.length > 0) {
|
|
346
|
+
last(midGroups).columnSeparator = "pinned";
|
|
347
|
+
}
|
|
348
|
+
const leftCols = useCols(leftColInfos, 0, leftGroups);
|
|
349
|
+
const midCols = useCols(
|
|
350
|
+
midColInfos,
|
|
351
|
+
leftCols.length,
|
|
352
|
+
midGroups
|
|
353
|
+
);
|
|
354
|
+
const rightCols = useCols(
|
|
355
|
+
rightColInfos,
|
|
356
|
+
leftCols.length + midCols.length,
|
|
357
|
+
rightGroups
|
|
358
|
+
);
|
|
359
|
+
if (leftCols.length > 0) {
|
|
360
|
+
last(leftCols).separator = "pinned";
|
|
361
|
+
}
|
|
362
|
+
if (rightCols.length > 0 && midCols.length > 0) {
|
|
363
|
+
last(midCols).separator = "pinned";
|
|
364
|
+
}
|
|
365
|
+
const chPosById = useRef(/* @__PURE__ */ new Map());
|
|
366
|
+
const indexChildren = () => {
|
|
367
|
+
const m = /* @__PURE__ */ new Map();
|
|
368
|
+
let i = 0;
|
|
369
|
+
const indexChildrenRec = (c) => {
|
|
370
|
+
if (!c) {
|
|
371
|
+
return;
|
|
372
|
+
}
|
|
373
|
+
Children.forEach(c, (x) => {
|
|
374
|
+
if (isValidElement(x) && x.props.id !== void 0) {
|
|
375
|
+
m.set(x.props.id, i);
|
|
376
|
+
i++;
|
|
377
|
+
indexChildrenRec(x.props.children);
|
|
378
|
+
}
|
|
379
|
+
});
|
|
380
|
+
};
|
|
381
|
+
indexChildrenRec(children);
|
|
382
|
+
return m;
|
|
383
|
+
};
|
|
384
|
+
chPosById.current = indexChildren();
|
|
385
|
+
const getChildIndex = useCallback((id) => {
|
|
386
|
+
const idx = chPosById.current.get(id);
|
|
387
|
+
if (idx === void 0) {
|
|
388
|
+
console.log(`Unknown child id "${id}"`);
|
|
389
|
+
console.log(
|
|
390
|
+
`Known ids: ${Array.from(chPosById.current.keys()).map((x) => `"${x}"`).join(", ")}`
|
|
391
|
+
);
|
|
392
|
+
throw new Error(`Unknown child id: "${id}"`);
|
|
393
|
+
}
|
|
394
|
+
return idx;
|
|
395
|
+
}, []);
|
|
396
|
+
const getColMapSet = (pinned) => pinned === "left" ? setLeftColMap : pinned === "right" ? setRightColMap : setMidColMap;
|
|
397
|
+
const onColumnAdded = useCallback((columnInfo) => {
|
|
398
|
+
const { id, pinned } = columnInfo.props;
|
|
399
|
+
const index = getChildIndex(id);
|
|
400
|
+
getColMapSet(pinned)(makeMapAdder(index, columnInfo));
|
|
401
|
+
}, []);
|
|
402
|
+
const onColumnRemoved = useCallback(
|
|
403
|
+
(index, columnInfo) => {
|
|
404
|
+
const { id, pinned } = columnInfo.props;
|
|
405
|
+
getColMapSet(pinned)(makeMapDeleter(index));
|
|
406
|
+
},
|
|
407
|
+
[]
|
|
408
|
+
);
|
|
409
|
+
const getGrpMapSet = (pinned) => pinned === "left" ? setLeftGrpMap : pinned === "right" ? setRightGrpMap : setMidGrpMap;
|
|
410
|
+
const onColumnGroupAdded = useCallback((colGroupProps) => {
|
|
411
|
+
const { id, pinned } = colGroupProps;
|
|
412
|
+
getGrpMapSet(pinned)(makeMapAdder(getChildIndex(id), colGroupProps));
|
|
413
|
+
}, []);
|
|
414
|
+
const onColumnGroupRemoved = useCallback(
|
|
415
|
+
(index, colGroupProps) => {
|
|
416
|
+
const { id, pinned } = colGroupProps;
|
|
417
|
+
getGrpMapSet(pinned)(makeMapDeleter(index));
|
|
418
|
+
},
|
|
419
|
+
[]
|
|
420
|
+
);
|
|
421
|
+
const onEditorAdded = useCallback((info) => {
|
|
422
|
+
const { columnId } = info;
|
|
423
|
+
setEditorMap(makeMapAdder(columnId, info));
|
|
424
|
+
}, []);
|
|
425
|
+
const onEditorRemoved = useCallback((info) => {
|
|
426
|
+
const { columnId } = info;
|
|
427
|
+
setEditorMap(makeMapDeleter(columnId));
|
|
428
|
+
}, []);
|
|
429
|
+
const getEditor = useCallback(
|
|
430
|
+
(columnId) => editorMap.get(columnId),
|
|
431
|
+
[editorMap]
|
|
432
|
+
);
|
|
433
|
+
const contextValue = useMemo(
|
|
434
|
+
() => ({
|
|
435
|
+
getChildIndex,
|
|
436
|
+
onColumnAdded,
|
|
437
|
+
onColumnRemoved,
|
|
438
|
+
onColumnGroupAdded,
|
|
439
|
+
onColumnGroupRemoved,
|
|
440
|
+
onEditorAdded,
|
|
441
|
+
onEditorRemoved,
|
|
442
|
+
getEditor
|
|
443
|
+
}),
|
|
444
|
+
[
|
|
445
|
+
getChildIndex,
|
|
446
|
+
onColumnAdded,
|
|
447
|
+
onColumnRemoved,
|
|
448
|
+
onColumnGroupAdded,
|
|
449
|
+
onColumnGroupRemoved,
|
|
450
|
+
onEditorAdded,
|
|
451
|
+
onEditorRemoved,
|
|
452
|
+
getEditor
|
|
453
|
+
]
|
|
454
|
+
);
|
|
455
|
+
return {
|
|
456
|
+
leftCols,
|
|
457
|
+
midCols,
|
|
458
|
+
rightCols,
|
|
459
|
+
leftGroups,
|
|
460
|
+
midGroups,
|
|
461
|
+
rightGroups,
|
|
462
|
+
contextValue
|
|
463
|
+
};
|
|
464
|
+
}
|
|
465
|
+
function useRowSelection(rowKeyGetter, rowData, defaultSelectedRowIdxs, selectedRowIdxs, rowSelectionMode, onRowSelected) {
|
|
466
|
+
const selectedRowIdxsProp = useMemo(() => {
|
|
467
|
+
if (selectedRowIdxs == void 0) {
|
|
468
|
+
return void 0;
|
|
469
|
+
}
|
|
470
|
+
return new Set(selectedRowIdxs);
|
|
471
|
+
}, [selectedRowIdxs]);
|
|
472
|
+
const defaultSelectedRowIdxsProp = useMemo(() => {
|
|
473
|
+
if (defaultSelectedRowIdxs == void 0) {
|
|
474
|
+
return /* @__PURE__ */ new Set([]);
|
|
475
|
+
}
|
|
476
|
+
return new Set(defaultSelectedRowIdxs);
|
|
477
|
+
}, [defaultSelectedRowIdxs]);
|
|
478
|
+
const [selRowIdxs, setSelRowIdxs] = useControlled({
|
|
479
|
+
controlled: selectedRowIdxsProp,
|
|
480
|
+
default: defaultSelectedRowIdxsProp,
|
|
481
|
+
name: "useRowSelection",
|
|
482
|
+
state: "selRowIdxs"
|
|
483
|
+
});
|
|
484
|
+
const [lastSelRowIdx, setLastSelRowIdx] = useState(
|
|
485
|
+
void 0
|
|
486
|
+
);
|
|
487
|
+
useEffect(() => {
|
|
488
|
+
if (rowSelectionMode === "none" && selRowIdxs.size > 0 || rowSelectionMode === "single" && selRowIdxs.size > 1) {
|
|
489
|
+
setSelRowIdxs(/* @__PURE__ */ new Set());
|
|
490
|
+
}
|
|
491
|
+
}, [rowSelectionMode, selRowIdxs, setSelRowIdxs]);
|
|
492
|
+
const selectRows = useCallback(
|
|
493
|
+
({
|
|
494
|
+
rowIndex,
|
|
495
|
+
isRange = false,
|
|
496
|
+
incremental = false,
|
|
497
|
+
unselectOtherRows = false
|
|
498
|
+
}) => {
|
|
499
|
+
const idxFrom = rowSelectionMode === "multi" && lastSelRowIdx !== void 0 && isRange ? lastSelRowIdx : void 0;
|
|
500
|
+
let nextSelRowIdxs = void 0;
|
|
501
|
+
let nextLastSelRowIdx = void 0;
|
|
502
|
+
if (idxFrom === void 0) {
|
|
503
|
+
if (unselectOtherRows) {
|
|
504
|
+
if (incremental && selRowIdxs.has(rowIndex)) {
|
|
505
|
+
nextSelRowIdxs = /* @__PURE__ */ new Set([]);
|
|
506
|
+
nextLastSelRowIdx = void 0;
|
|
507
|
+
} else {
|
|
508
|
+
nextSelRowIdxs = /* @__PURE__ */ new Set([rowIndex]);
|
|
509
|
+
nextLastSelRowIdx = rowIndex;
|
|
510
|
+
}
|
|
511
|
+
} else {
|
|
512
|
+
if (incremental && rowSelectionMode === "multi") {
|
|
513
|
+
nextSelRowIdxs = new Set(selRowIdxs);
|
|
514
|
+
if (nextSelRowIdxs.has(rowIndex)) {
|
|
515
|
+
nextSelRowIdxs.delete(rowIndex);
|
|
516
|
+
nextLastSelRowIdx = void 0;
|
|
517
|
+
} else {
|
|
518
|
+
nextSelRowIdxs.add(rowIndex);
|
|
519
|
+
nextLastSelRowIdx = rowIndex;
|
|
520
|
+
}
|
|
521
|
+
} else {
|
|
522
|
+
nextSelRowIdxs = /* @__PURE__ */ new Set([rowIndex]);
|
|
523
|
+
nextLastSelRowIdx = rowIndex;
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
} else {
|
|
527
|
+
const s = incremental ? new Set(selRowIdxs) : /* @__PURE__ */ new Set();
|
|
528
|
+
const idxs = [rowIndex, idxFrom];
|
|
529
|
+
idxs.sort((a, b) => a - b);
|
|
530
|
+
const rowIdxs = [];
|
|
531
|
+
for (let i = idxs[0]; i <= idxs[1]; ++i) {
|
|
532
|
+
rowIdxs.push(i);
|
|
533
|
+
}
|
|
534
|
+
if (selRowIdxs.has(rowIndex)) {
|
|
535
|
+
rowIdxs.forEach((k) => s.delete(k));
|
|
536
|
+
} else {
|
|
537
|
+
rowIdxs.forEach((k) => s.add(k));
|
|
538
|
+
}
|
|
539
|
+
nextSelRowIdxs = s;
|
|
540
|
+
nextLastSelRowIdx = rowIndex;
|
|
541
|
+
}
|
|
542
|
+
setSelRowIdxs(nextSelRowIdxs);
|
|
543
|
+
setLastSelRowIdx(nextLastSelRowIdx);
|
|
544
|
+
if (onRowSelected) {
|
|
545
|
+
onRowSelected(Array.from(nextSelRowIdxs.keys()));
|
|
546
|
+
}
|
|
547
|
+
},
|
|
548
|
+
[
|
|
549
|
+
selRowIdxs,
|
|
550
|
+
lastSelRowIdx,
|
|
551
|
+
setSelRowIdxs,
|
|
552
|
+
setLastSelRowIdx,
|
|
553
|
+
rowData,
|
|
554
|
+
rowKeyGetter,
|
|
555
|
+
onRowSelected
|
|
556
|
+
]
|
|
557
|
+
);
|
|
558
|
+
const isAllSelected = selRowIdxs.size === rowData.length;
|
|
559
|
+
const isAnySelected = selRowIdxs.size > 0;
|
|
560
|
+
const selectAll = useCallback(() => {
|
|
561
|
+
const allRowIdxs = [...new Array(rowData.length).keys()].map((_, i) => i);
|
|
562
|
+
setSelRowIdxs(new Set(allRowIdxs));
|
|
563
|
+
if (onRowSelected) {
|
|
564
|
+
onRowSelected(allRowIdxs);
|
|
565
|
+
}
|
|
566
|
+
}, [rowData, setSelRowIdxs]);
|
|
567
|
+
const unselectAll = useCallback(() => {
|
|
568
|
+
setSelRowIdxs(/* @__PURE__ */ new Set());
|
|
569
|
+
if (onRowSelected) {
|
|
570
|
+
onRowSelected([]);
|
|
571
|
+
}
|
|
572
|
+
}, [setSelRowIdxs]);
|
|
573
|
+
const onMouseDown = useCallback(
|
|
574
|
+
(event) => {
|
|
575
|
+
if (rowSelectionMode === "none") {
|
|
576
|
+
return;
|
|
577
|
+
}
|
|
578
|
+
const target = event.target;
|
|
579
|
+
try {
|
|
580
|
+
const [rowIndex] = getCellPosition(target);
|
|
581
|
+
selectRows({
|
|
582
|
+
rowIndex,
|
|
583
|
+
isRange: event.shiftKey,
|
|
584
|
+
incremental: event.metaKey || event.ctrlKey
|
|
585
|
+
});
|
|
586
|
+
} catch (e) {
|
|
587
|
+
}
|
|
588
|
+
},
|
|
589
|
+
[selectRows, rowSelectionMode]
|
|
590
|
+
);
|
|
591
|
+
return {
|
|
592
|
+
onMouseDown,
|
|
593
|
+
selRowIdxs,
|
|
594
|
+
isAllSelected,
|
|
595
|
+
isAnySelected,
|
|
596
|
+
selectRows,
|
|
597
|
+
selectAll,
|
|
598
|
+
unselectAll
|
|
599
|
+
};
|
|
600
|
+
}
|
|
601
|
+
const COLUMN_DRAG_TOLERANCE = 10;
|
|
602
|
+
function useColumnMove(columnMove, rootRef, leftCols, midCols, rightCols, cols, scrollLeft, clientMidWidth, onColumnMove) {
|
|
603
|
+
const moveRef = useRef();
|
|
604
|
+
const activeTargetRef = useRef(void 0);
|
|
605
|
+
const [dragState, setDragState] = useState(
|
|
606
|
+
void 0
|
|
607
|
+
);
|
|
608
|
+
const columnDragStart = useCallback(
|
|
609
|
+
(columnIndex, x, y) => {
|
|
610
|
+
setDragState({ columnIndex, x, y });
|
|
611
|
+
},
|
|
612
|
+
[setDragState]
|
|
613
|
+
);
|
|
614
|
+
const columnDrag = useCallback(
|
|
615
|
+
(x, y) => {
|
|
616
|
+
setDragState((old) => {
|
|
617
|
+
return { ...old, x, y };
|
|
618
|
+
});
|
|
619
|
+
},
|
|
620
|
+
[setDragState]
|
|
621
|
+
);
|
|
622
|
+
const columnDrop = useCallback(() => {
|
|
623
|
+
var _a, _b, _c, _d;
|
|
624
|
+
const toIndex = (_a = activeTargetRef.current) == null ? void 0 : _a.columnIndex;
|
|
625
|
+
const fromIndex = (_b = moveRef.current) == null ? void 0 : _b.columnIndex;
|
|
626
|
+
const columnId = (_c = moveRef.current) == null ? void 0 : _c.columnId;
|
|
627
|
+
const handler = (_d = moveRef.current) == null ? void 0 : _d.onColumnMove;
|
|
628
|
+
if (toIndex !== void 0 && fromIndex !== void 0 && handler !== void 0 && columnId !== void 0) {
|
|
629
|
+
handler(columnId, fromIndex, toIndex);
|
|
630
|
+
}
|
|
631
|
+
setDragState(void 0);
|
|
632
|
+
}, [setDragState]);
|
|
633
|
+
const onMouseUp = useCallback(() => {
|
|
634
|
+
var _a, _b;
|
|
635
|
+
if ((_a = moveRef.current) == null ? void 0 : _a.dragTriggered) {
|
|
636
|
+
columnDrop();
|
|
637
|
+
}
|
|
638
|
+
(_b = moveRef.current) == null ? void 0 : _b.unsubscribe();
|
|
639
|
+
moveRef.current = void 0;
|
|
640
|
+
}, [columnDrop]);
|
|
641
|
+
const onMouseMove = useCallback(
|
|
642
|
+
(event) => {
|
|
643
|
+
const {
|
|
644
|
+
columnIndex,
|
|
645
|
+
startHeaderX,
|
|
646
|
+
startHeaderY,
|
|
647
|
+
startScreenX,
|
|
648
|
+
startScreenY,
|
|
649
|
+
dragTriggered
|
|
650
|
+
} = moveRef.current;
|
|
651
|
+
const shiftX = event.screenX - startScreenX;
|
|
652
|
+
const shiftY = event.screenY - startScreenY;
|
|
653
|
+
const x = startHeaderX + shiftX;
|
|
654
|
+
const y = startHeaderY + shiftY;
|
|
655
|
+
if (!dragTriggered) {
|
|
656
|
+
if (Math.sqrt(shiftX * shiftX + shiftY * shiftY) > COLUMN_DRAG_TOLERANCE) {
|
|
657
|
+
moveRef.current.dragTriggered = true;
|
|
658
|
+
columnDragStart(columnIndex, x, y);
|
|
659
|
+
}
|
|
660
|
+
} else {
|
|
661
|
+
columnDrag(x, y);
|
|
662
|
+
}
|
|
663
|
+
},
|
|
664
|
+
[columnDrag]
|
|
665
|
+
);
|
|
666
|
+
const onColumnMoveHandleMouseDown = useCallback(
|
|
667
|
+
(event) => {
|
|
668
|
+
const [columnIndexAttribute, thElement] = getAttribute(
|
|
669
|
+
event.target,
|
|
670
|
+
"data-column-index"
|
|
671
|
+
);
|
|
672
|
+
const rootElement = rootRef.current;
|
|
673
|
+
document.addEventListener("mouseup", onMouseUp);
|
|
674
|
+
document.addEventListener("mousemove", onMouseMove);
|
|
675
|
+
const columnIndex = parseInt(columnIndexAttribute, 10);
|
|
676
|
+
const columnId = cols[columnIndex].info.props.id;
|
|
677
|
+
const thRect = thElement.getBoundingClientRect();
|
|
678
|
+
const rootRect = rootElement.getBoundingClientRect();
|
|
679
|
+
const x = thRect.x - rootRect.x;
|
|
680
|
+
const y = thRect.y - rootRect.y;
|
|
681
|
+
moveRef.current = {
|
|
682
|
+
unsubscribe: () => {
|
|
683
|
+
document.removeEventListener("mouseup", onMouseUp);
|
|
684
|
+
document.removeEventListener("mousemove", onMouseMove);
|
|
685
|
+
},
|
|
686
|
+
startScreenX: event.screenX,
|
|
687
|
+
startScreenY: event.screenY,
|
|
688
|
+
startHeaderX: x,
|
|
689
|
+
startHeaderY: y,
|
|
690
|
+
columnIndex,
|
|
691
|
+
columnId,
|
|
692
|
+
dragTriggered: false,
|
|
693
|
+
onColumnMove
|
|
694
|
+
};
|
|
695
|
+
event.preventDefault();
|
|
696
|
+
},
|
|
697
|
+
[columnDragStart, cols]
|
|
698
|
+
);
|
|
699
|
+
const onColumnMoveCancel = useCallback(() => {
|
|
700
|
+
var _a;
|
|
701
|
+
setDragState(void 0);
|
|
702
|
+
(_a = moveRef.current) == null ? void 0 : _a.unsubscribe();
|
|
703
|
+
moveRef.current = void 0;
|
|
704
|
+
}, [setDragState]);
|
|
705
|
+
const targets = useMemo(() => {
|
|
706
|
+
if (!dragState) {
|
|
707
|
+
return void 0;
|
|
708
|
+
}
|
|
709
|
+
let ts = [];
|
|
710
|
+
let x = 0;
|
|
711
|
+
leftCols.forEach((c, i2) => {
|
|
712
|
+
ts.push({ columnIndex: c.index, x });
|
|
713
|
+
x += c.info.width;
|
|
714
|
+
});
|
|
715
|
+
let w = scrollLeft;
|
|
716
|
+
let i = 0;
|
|
717
|
+
while (w > 0 && i < midCols.length) {
|
|
718
|
+
w -= midCols[i].info.width;
|
|
719
|
+
i++;
|
|
720
|
+
}
|
|
721
|
+
x -= w;
|
|
722
|
+
w += clientMidWidth;
|
|
723
|
+
while (w > 0 && i < midCols.length) {
|
|
724
|
+
const c = midCols[i];
|
|
725
|
+
ts.push({ columnIndex: c.index, x });
|
|
726
|
+
x += c.info.width;
|
|
727
|
+
w -= c.info.width;
|
|
728
|
+
i++;
|
|
729
|
+
}
|
|
730
|
+
if (rightCols.length > 0) {
|
|
731
|
+
x += w;
|
|
732
|
+
rightCols.forEach((c, i2) => {
|
|
733
|
+
ts.push({ columnIndex: c.index, x });
|
|
734
|
+
x += c.info.width;
|
|
735
|
+
});
|
|
736
|
+
ts.push({ columnIndex: last(rightCols).index + 1, x });
|
|
737
|
+
} else {
|
|
738
|
+
ts.push({ columnIndex: last(midCols).index + 1, x });
|
|
739
|
+
}
|
|
740
|
+
return ts;
|
|
741
|
+
}, [dragState, leftCols, midCols, rightCols, scrollLeft, clientMidWidth]);
|
|
742
|
+
const activeTargetIdx = useMemo(() => {
|
|
743
|
+
const x = dragState == null ? void 0 : dragState.x;
|
|
744
|
+
if (x === void 0 || targets === void 0 || targets.length < 1) {
|
|
745
|
+
return void 0;
|
|
746
|
+
}
|
|
747
|
+
let i = 0;
|
|
748
|
+
while (i < targets.length && targets[i].x < x) {
|
|
749
|
+
i++;
|
|
750
|
+
}
|
|
751
|
+
if (i === 0) {
|
|
752
|
+
return 0;
|
|
753
|
+
}
|
|
754
|
+
if (i >= targets.length) {
|
|
755
|
+
return targets.length - 1;
|
|
756
|
+
}
|
|
757
|
+
return targets[i].x - x < x - targets[i - 1].x ? i : i - 1;
|
|
758
|
+
}, [targets, dragState == null ? void 0 : dragState.x]);
|
|
759
|
+
const activeTarget = activeTargetIdx === void 0 ? void 0 : targets[activeTargetIdx];
|
|
760
|
+
activeTargetRef.current = activeTarget;
|
|
761
|
+
return {
|
|
762
|
+
onColumnMoveHandleMouseDown,
|
|
763
|
+
dragState,
|
|
764
|
+
activeTarget,
|
|
765
|
+
onColumnMoveCancel
|
|
766
|
+
};
|
|
767
|
+
}
|
|
768
|
+
function cellPositionEquals(a, b) {
|
|
769
|
+
return a.rowIdx === b.rowIdx && a.colIdx === b.colIdx;
|
|
770
|
+
}
|
|
771
|
+
function cellRangeEquals(a, b) {
|
|
772
|
+
if (!a) {
|
|
773
|
+
return !b;
|
|
774
|
+
}
|
|
775
|
+
return !!b && cellPositionEquals(a.start, b.start) && cellPositionEquals(a.end, b.end);
|
|
776
|
+
}
|
|
777
|
+
function useRangeSelection(cellSelectionMode) {
|
|
778
|
+
const mouseSelectionRef = useRef();
|
|
779
|
+
const keyboardSelectionRef = useRef();
|
|
780
|
+
if (cellSelectionMode !== "range") {
|
|
781
|
+
if (mouseSelectionRef.current) {
|
|
782
|
+
mouseSelectionRef.current.unsubscribe();
|
|
783
|
+
mouseSelectionRef.current = void 0;
|
|
784
|
+
}
|
|
785
|
+
if (keyboardSelectionRef.current) {
|
|
786
|
+
keyboardSelectionRef.current = void 0;
|
|
787
|
+
}
|
|
788
|
+
}
|
|
789
|
+
const [selectedCellRange, setSelectedCellRange] = useState(void 0);
|
|
790
|
+
const onMouseMove = useCallback((event) => {
|
|
791
|
+
const { clientX, clientY } = event;
|
|
792
|
+
const element = document.elementFromPoint(clientX, clientY);
|
|
793
|
+
try {
|
|
794
|
+
const [rowIdx, colIdx] = getCellPosition(element);
|
|
795
|
+
setSelectedCellRange((old) => {
|
|
796
|
+
const { start } = mouseSelectionRef.current;
|
|
797
|
+
const p = { start, end: { rowIdx, colIdx } };
|
|
798
|
+
return cellRangeEquals(old, p) ? old : p;
|
|
799
|
+
});
|
|
800
|
+
} catch (exc) {
|
|
801
|
+
}
|
|
802
|
+
}, []);
|
|
803
|
+
const onMouseUp = useCallback((event) => {
|
|
804
|
+
if (!mouseSelectionRef.current) {
|
|
805
|
+
throw new Error(`useRangeSelection state is not initialized`);
|
|
806
|
+
}
|
|
807
|
+
mouseSelectionRef.current.unsubscribe();
|
|
808
|
+
mouseSelectionRef.current = void 0;
|
|
809
|
+
}, []);
|
|
810
|
+
const onCellMouseDown = useCallback(
|
|
811
|
+
(event) => {
|
|
812
|
+
if (cellSelectionMode !== "range") {
|
|
813
|
+
return;
|
|
814
|
+
}
|
|
815
|
+
const target = event.target;
|
|
816
|
+
try {
|
|
817
|
+
const [rowIdx, colIdx] = getCellPosition(target);
|
|
818
|
+
document.addEventListener("mouseup", onMouseUp);
|
|
819
|
+
document.addEventListener("mousemove", onMouseMove);
|
|
820
|
+
const pos = { rowIdx, colIdx };
|
|
821
|
+
mouseSelectionRef.current = {
|
|
822
|
+
start: pos,
|
|
823
|
+
unsubscribe: () => {
|
|
824
|
+
document.removeEventListener("mouseup", onMouseUp);
|
|
825
|
+
document.removeEventListener("mousemove", onMouseMove);
|
|
826
|
+
}
|
|
827
|
+
};
|
|
828
|
+
setSelectedCellRange({ start: pos, end: pos });
|
|
829
|
+
} catch (exc) {
|
|
830
|
+
}
|
|
831
|
+
},
|
|
832
|
+
[cellSelectionMode]
|
|
833
|
+
);
|
|
834
|
+
const onKeyboardRangeSelectionStart = useCallback((pos) => {
|
|
835
|
+
keyboardSelectionRef.current = {
|
|
836
|
+
start: pos
|
|
837
|
+
};
|
|
838
|
+
}, []);
|
|
839
|
+
const onKeyboardRangeSelectionEnd = useCallback(() => {
|
|
840
|
+
keyboardSelectionRef.current = void 0;
|
|
841
|
+
}, []);
|
|
842
|
+
const onCursorMove = useCallback((pos) => {
|
|
843
|
+
if (!keyboardSelectionRef.current) {
|
|
844
|
+
return;
|
|
845
|
+
}
|
|
846
|
+
setSelectedCellRange((old) => {
|
|
847
|
+
if (!keyboardSelectionRef.current) {
|
|
848
|
+
return old;
|
|
849
|
+
}
|
|
850
|
+
const { start } = keyboardSelectionRef.current;
|
|
851
|
+
const p = { start, end: pos };
|
|
852
|
+
return cellRangeEquals(old, p) ? old : p;
|
|
853
|
+
});
|
|
854
|
+
}, []);
|
|
855
|
+
const selectRange = useCallback((range) => {
|
|
856
|
+
if (cellSelectionMode !== "range") {
|
|
857
|
+
return;
|
|
858
|
+
}
|
|
859
|
+
setSelectedCellRange(range);
|
|
860
|
+
}, []);
|
|
861
|
+
return {
|
|
862
|
+
selectedCellRange,
|
|
863
|
+
onCellMouseDown,
|
|
864
|
+
onKeyboardRangeSelectionStart,
|
|
865
|
+
onKeyboardRangeSelectionEnd,
|
|
866
|
+
onCursorMove,
|
|
867
|
+
selectRange
|
|
868
|
+
};
|
|
869
|
+
}
|
|
870
|
+
function useFocusableContent() {
|
|
871
|
+
const ref = useRef(null);
|
|
872
|
+
const [isFocusableContent, setFocusableContent] = useState(false);
|
|
873
|
+
const onFocus = (event) => {
|
|
874
|
+
if (event.target === ref.current) {
|
|
875
|
+
const nestedInteractive = ref.current.querySelector(`[tabindex="0"]`);
|
|
876
|
+
if (nestedInteractive) {
|
|
877
|
+
nestedInteractive.focus();
|
|
878
|
+
setFocusableContent(true);
|
|
879
|
+
}
|
|
880
|
+
}
|
|
881
|
+
};
|
|
882
|
+
return { ref, isFocusableContent, onFocus };
|
|
883
|
+
}
|
|
884
|
+
|
|
885
|
+
export { cellPositionEquals, cellRangeEquals, last, useActiveOnWheel, useBodyVisibleAreaTop, useBodyVisibleColumnRange, useClientMidHeight, useClientMidWidth, useCols, useColumnGroups, useColumnMove, useColumnRange, useColumnRegistry, useColumnResize, useFlatten, useFocusableContent, useHeadVisibleColumnRange, useLeftScrolledOutWidth, useRangeSelection, useRowModels, useRowSelection, useScrollToCell, useSum, useSumRangeWidth, useSumWidth, useVisibleColumnGroupRange, useVisibleRowRange };
|
|
886
|
+
//# sourceMappingURL=gridHooks.js.map
|