@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,102 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import { GridColumn } from './GridColumn.js';
|
|
3
|
+
import './NumericColumn.css.js';
|
|
4
|
+
import { useRef, useState, useEffect } from 'react';
|
|
5
|
+
import { useEditorContext } from './EditorContext.js';
|
|
6
|
+
import { CornerTag } from './CornerTag.js';
|
|
7
|
+
import { Cell } from './internal/Cell.js';
|
|
8
|
+
import './internal/CellMeasure.js';
|
|
9
|
+
import './internal/Cursor.js';
|
|
10
|
+
import './internal/GroupHeaderRow.js';
|
|
11
|
+
import './internal/HeaderRow.js';
|
|
12
|
+
import './internal/LeftPart.js';
|
|
13
|
+
import './internal/MiddlePart.js';
|
|
14
|
+
import './internal/RightPart.js';
|
|
15
|
+
import './internal/Scrollable.js';
|
|
16
|
+
import './internal/TableRow.js';
|
|
17
|
+
import './SelectionContext.js';
|
|
18
|
+
import './CursorContext.js';
|
|
19
|
+
import './NumberRange.js';
|
|
20
|
+
import '@salt-ds/core';
|
|
21
|
+
import './internal/TopLeftPart.js';
|
|
22
|
+
import './internal/TopPart.js';
|
|
23
|
+
import './internal/TopRightPart.js';
|
|
24
|
+
import './internal/FakeCell.css.js';
|
|
25
|
+
import './internal/DefaultCellValue.js';
|
|
26
|
+
|
|
27
|
+
function isNumber(value) {
|
|
28
|
+
return typeof value === "number" && Number.isFinite(value);
|
|
29
|
+
}
|
|
30
|
+
function NumericCellValue(props) {
|
|
31
|
+
const { column, value } = props;
|
|
32
|
+
const columnProps = column.info.props;
|
|
33
|
+
const { precision } = columnProps;
|
|
34
|
+
const text = isNumber(value) ? value.toFixed(precision) : "";
|
|
35
|
+
return /* @__PURE__ */ jsx("div", {
|
|
36
|
+
className: "saltGridNumericCellValue",
|
|
37
|
+
children: text
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
function NumericCellEditor(props) {
|
|
41
|
+
const { column, row } = props;
|
|
42
|
+
const inputRef = useRef(null);
|
|
43
|
+
const { endEditMode, cancelEditMode, initialText } = useEditorContext();
|
|
44
|
+
const [editorText, setEditorText] = useState(
|
|
45
|
+
initialText != null ? initialText : column.info.props.getValue(row.data)
|
|
46
|
+
);
|
|
47
|
+
const initialSelectionRef = useRef(!!initialText);
|
|
48
|
+
const onChange = (e) => {
|
|
49
|
+
setEditorText(e.target.value);
|
|
50
|
+
};
|
|
51
|
+
const onKeyDown = (event) => {
|
|
52
|
+
if (event.key === "Enter") {
|
|
53
|
+
endEditMode(editorText);
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
if (event.key === "Escape") {
|
|
57
|
+
cancelEditMode();
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
if (event.key === "Tab") {
|
|
61
|
+
endEditMode(editorText);
|
|
62
|
+
event.preventDefault();
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
event.stopPropagation();
|
|
66
|
+
};
|
|
67
|
+
useEffect(() => {
|
|
68
|
+
if (inputRef.current && !initialSelectionRef.current) {
|
|
69
|
+
inputRef.current.select();
|
|
70
|
+
initialSelectionRef.current = true;
|
|
71
|
+
}
|
|
72
|
+
}, [inputRef.current]);
|
|
73
|
+
return /* @__PURE__ */ jsxs(Cell, {
|
|
74
|
+
separator: column == null ? void 0 : column.separator,
|
|
75
|
+
className: "saltGridNumericCellEditor",
|
|
76
|
+
children: [
|
|
77
|
+
/* @__PURE__ */ jsx("div", {
|
|
78
|
+
className: "saltGridNumericCellEditor-inputContainer",
|
|
79
|
+
children: /* @__PURE__ */ jsx("input", {
|
|
80
|
+
ref: inputRef,
|
|
81
|
+
"data-testid": "grid-cell-editor-input",
|
|
82
|
+
autoFocus: true,
|
|
83
|
+
value: editorText,
|
|
84
|
+
onChange,
|
|
85
|
+
onKeyDown
|
|
86
|
+
})
|
|
87
|
+
}),
|
|
88
|
+
/* @__PURE__ */ jsx(CornerTag, {})
|
|
89
|
+
]
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
function NumericColumn(props) {
|
|
93
|
+
return /* @__PURE__ */ jsx(GridColumn, {
|
|
94
|
+
...props,
|
|
95
|
+
align: "right",
|
|
96
|
+
cellValueComponent: NumericCellValue,
|
|
97
|
+
children: props.children
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
export { NumericCellEditor, NumericCellValue, NumericColumn };
|
|
102
|
+
//# sourceMappingURL=NumericColumn.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NumericColumn.js","sources":["../src/NumericColumn.tsx"],"sourcesContent":["import { GridCellValueProps, GridColumn, GridColumnProps } from \"./GridColumn\";\nimport \"./NumericColumn.css\";\nimport { GridColumnModel, GridRowModel } from \"./Grid\";\nimport {\n ChangeEventHandler,\n KeyboardEventHandler,\n ReactNode,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport { useEditorContext } from \"./EditorContext\";\nimport { CornerTag } from \"./CornerTag\";\nimport { Cell } from \"./internal\";\n\nexport interface NumericColumnProps<T> extends GridColumnProps<T> {\n precision: number;\n}\n\nfunction isNumber(value: any): value is number {\n return typeof value === \"number\" && Number.isFinite(value);\n}\n\nexport function NumericCellValue<T>(props: GridCellValueProps<T>) {\n const { column, value } = props;\n const columnProps = column.info.props as NumericColumnProps<T>;\n const { precision } = columnProps;\n const text = isNumber(value) ? value.toFixed(precision) : \"\";\n return <div className=\"saltGridNumericCellValue\">{text}</div>;\n}\n\nexport interface NumericEditorProps<T> {\n row?: GridRowModel<T>;\n column?: GridColumnModel<T>;\n children?: ReactNode;\n}\n\nexport function NumericCellEditor<T>(props: NumericEditorProps<T>) {\n const { column, row } = props;\n const inputRef = useRef<HTMLInputElement>(null);\n\n const { endEditMode, cancelEditMode, initialText } = useEditorContext();\n\n const [editorText, setEditorText] = useState<string>(\n initialText != null ? initialText : column!.info.props.getValue!(row!.data)\n );\n\n const initialSelectionRef = useRef(!!initialText);\n\n const onChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n setEditorText(e.target.value);\n };\n\n const onKeyDown: KeyboardEventHandler<HTMLInputElement> = (event) => {\n if (event.key === \"Enter\") {\n endEditMode(editorText);\n return;\n }\n if (event.key === \"Escape\") {\n cancelEditMode();\n return;\n }\n if (event.key === \"Tab\") {\n endEditMode(editorText);\n event.preventDefault();\n return;\n }\n event.stopPropagation();\n };\n\n useEffect(() => {\n if (inputRef.current && !initialSelectionRef.current) {\n inputRef.current.select();\n initialSelectionRef.current = true;\n }\n }, [inputRef.current]);\n\n return (\n <Cell separator={column?.separator} className=\"saltGridNumericCellEditor\">\n <div className=\"saltGridNumericCellEditor-inputContainer\">\n <input\n ref={inputRef}\n data-testid=\"grid-cell-editor-input\"\n autoFocus={true}\n value={editorText}\n onChange={onChange}\n onKeyDown={onKeyDown}\n />\n </div>\n <CornerTag />\n </Cell>\n );\n}\n\nexport function NumericColumn<T>(props: NumericColumnProps<T>) {\n return (\n <GridColumn\n {...props}\n align={\"right\"}\n cellValueComponent={NumericCellValue}\n >\n {props.children}\n </GridColumn>\n );\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAmBA,SAAS,SAAS,KAA6B,EAAA;AAC7C,EAAA,OAAO,OAAO,KAAA,KAAU,QAAY,IAAA,MAAA,CAAO,SAAS,KAAK,CAAA,CAAA;AAC3D,CAAA;AAEO,SAAS,iBAAoB,KAA8B,EAAA;AAChE,EAAM,MAAA,EAAE,MAAQ,EAAA,KAAA,EAAU,GAAA,KAAA,CAAA;AAC1B,EAAM,MAAA,WAAA,GAAc,OAAO,IAAK,CAAA,KAAA,CAAA;AAChC,EAAM,MAAA,EAAE,WAAc,GAAA,WAAA,CAAA;AACtB,EAAA,MAAM,OAAO,QAAS,CAAA,KAAK,IAAI,KAAM,CAAA,OAAA,CAAQ,SAAS,CAAI,GAAA,EAAA,CAAA;AAC1D,EAAA,uBAAQ,GAAA,CAAA,KAAA,EAAA;AAAA,IAAI,SAAU,EAAA,0BAAA;AAAA,IAA4B,QAAA,EAAA,IAAA;AAAA,GAAK,CAAA,CAAA;AACzD,CAAA;AAQO,SAAS,kBAAqB,KAA8B,EAAA;AACjE,EAAM,MAAA,EAAE,MAAQ,EAAA,GAAA,EAAQ,GAAA,KAAA,CAAA;AACxB,EAAM,MAAA,QAAA,GAAW,OAAyB,IAAI,CAAA,CAAA;AAE9C,EAAA,MAAM,EAAE,WAAA,EAAa,cAAgB,EAAA,WAAA,KAAgB,gBAAiB,EAAA,CAAA;AAEtE,EAAM,MAAA,CAAC,UAAY,EAAA,aAAa,CAAI,GAAA,QAAA;AAAA,IAClC,WAAA,IAAe,OAAO,WAAc,GAAA,MAAA,CAAQ,KAAK,KAAM,CAAA,QAAA,CAAU,IAAK,IAAI,CAAA;AAAA,GAC5E,CAAA;AAEA,EAAA,MAAM,mBAAsB,GAAA,MAAA,CAAO,CAAC,CAAC,WAAW,CAAA,CAAA;AAEhD,EAAM,MAAA,QAAA,GAAiD,CAAC,CAAM,KAAA;AAC5D,IAAc,aAAA,CAAA,CAAA,CAAE,OAAO,KAAK,CAAA,CAAA;AAAA,GAC9B,CAAA;AAEA,EAAM,MAAA,SAAA,GAAoD,CAAC,KAAU,KAAA;AACnE,IAAI,IAAA,KAAA,CAAM,QAAQ,OAAS,EAAA;AACzB,MAAA,WAAA,CAAY,UAAU,CAAA,CAAA;AACtB,MAAA,OAAA;AAAA,KACF;AACA,IAAI,IAAA,KAAA,CAAM,QAAQ,QAAU,EAAA;AAC1B,MAAe,cAAA,EAAA,CAAA;AACf,MAAA,OAAA;AAAA,KACF;AACA,IAAI,IAAA,KAAA,CAAM,QAAQ,KAAO,EAAA;AACvB,MAAA,WAAA,CAAY,UAAU,CAAA,CAAA;AACtB,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,OAAA;AAAA,KACF;AACA,IAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,GACxB,CAAA;AAEA,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,QAAS,CAAA,OAAA,IAAW,CAAC,mBAAA,CAAoB,OAAS,EAAA;AACpD,MAAA,QAAA,CAAS,QAAQ,MAAO,EAAA,CAAA;AACxB,MAAA,mBAAA,CAAoB,OAAU,GAAA,IAAA,CAAA;AAAA,KAChC;AAAA,GACC,EAAA,CAAC,QAAS,CAAA,OAAO,CAAC,CAAA,CAAA;AAErB,EAAA,uBACG,IAAA,CAAA,IAAA,EAAA;AAAA,IAAK,WAAW,MAAQ,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,MAAA,CAAA,SAAA;AAAA,IAAW,SAAU,EAAA,2BAAA;AAAA,IAC5C,QAAA,EAAA;AAAA,sBAAC,GAAA,CAAA,KAAA,EAAA;AAAA,QAAI,SAAU,EAAA,0CAAA;AAAA,QACb,QAAC,kBAAA,GAAA,CAAA,OAAA,EAAA;AAAA,UACC,GAAK,EAAA,QAAA;AAAA,UACL,aAAY,EAAA,wBAAA;AAAA,UACZ,SAAW,EAAA,IAAA;AAAA,UACX,KAAO,EAAA,UAAA;AAAA,UACP,QAAA;AAAA,UACA,SAAA;AAAA,SACF,CAAA;AAAA,OACF,CAAA;AAAA,0BACC,SAAU,EAAA,EAAA,CAAA;AAAA,KAAA;AAAA,GACb,CAAA,CAAA;AAEJ,CAAA;AAEO,SAAS,cAAiB,KAA8B,EAAA;AAC7D,EAAA,uBACG,GAAA,CAAA,UAAA,EAAA;AAAA,IACE,GAAG,KAAA;AAAA,IACJ,KAAO,EAAA,OAAA;AAAA,IACP,kBAAoB,EAAA,gBAAA;AAAA,IAEnB,QAAM,EAAA,KAAA,CAAA,QAAA;AAAA,GACT,CAAA,CAAA;AAEJ;;;;"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { CheckboxBase } from '@salt-ds/lab';
|
|
3
|
+
import { useSelectionContext } from './SelectionContext.js';
|
|
4
|
+
import './CheckboxCell.css.js';
|
|
5
|
+
import { useCursorContext } from './CursorContext.js';
|
|
6
|
+
|
|
7
|
+
function RowSelectionCheckboxCellValue(props) {
|
|
8
|
+
const { row, column, isFocused } = props;
|
|
9
|
+
const { selRowIdxs, selectRows } = useSelectionContext();
|
|
10
|
+
const { moveCursor } = useCursorContext();
|
|
11
|
+
const isSelected = selRowIdxs.has(row.index);
|
|
12
|
+
const onMouseDown = (event) => {
|
|
13
|
+
selectRows({ rowIndex: row.index, incremental: true });
|
|
14
|
+
moveCursor("body", row.index, column.index);
|
|
15
|
+
event.preventDefault();
|
|
16
|
+
event.stopPropagation();
|
|
17
|
+
};
|
|
18
|
+
return /* @__PURE__ */ jsx("div", {
|
|
19
|
+
className: "saltGridCheckboxContainer",
|
|
20
|
+
onMouseDown,
|
|
21
|
+
children: /* @__PURE__ */ jsx(CheckboxBase, {
|
|
22
|
+
"data-testid": "grid-row-selection-checkbox",
|
|
23
|
+
inputProps: {
|
|
24
|
+
"aria-label": "Select Row",
|
|
25
|
+
tabIndex: isFocused ? 0 : -1
|
|
26
|
+
},
|
|
27
|
+
checked: isSelected
|
|
28
|
+
})
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export { RowSelectionCheckboxCellValue };
|
|
33
|
+
//# sourceMappingURL=RowSelectionCheckboxCellValue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RowSelectionCheckboxCellValue.js","sources":["../src/RowSelectionCheckboxCellValue.tsx"],"sourcesContent":["import { CheckboxBase } from \"@salt-ds/lab\";\nimport { GridCellValueProps } from \"./GridColumn\";\nimport { useSelectionContext } from \"./SelectionContext\";\nimport \"./CheckboxCell.css\";\nimport { MouseEventHandler } from \"react\";\nimport { useCursorContext } from \"./CursorContext\";\n\nexport function RowSelectionCheckboxCellValue<T>(props: GridCellValueProps<T>) {\n const { row, column, isFocused } = props;\n const { selRowIdxs, selectRows } = useSelectionContext();\n const { moveCursor } = useCursorContext();\n\n const isSelected = selRowIdxs.has(row.index);\n\n const onMouseDown: MouseEventHandler<HTMLDivElement> = (event) => {\n selectRows({ rowIndex: row.index, incremental: true });\n moveCursor(\"body\", row.index, column.index);\n event.preventDefault();\n event.stopPropagation();\n };\n\n return (\n <div className=\"saltGridCheckboxContainer\" onMouseDown={onMouseDown}>\n <CheckboxBase\n data-testid=\"grid-row-selection-checkbox\"\n inputProps={{\n \"aria-label\": \"Select Row\",\n tabIndex: isFocused ? 0 : -1,\n }}\n checked={isSelected}\n />\n </div>\n );\n}\n"],"names":[],"mappings":";;;;;;AAOO,SAAS,8BAAiC,KAA8B,EAAA;AAC7E,EAAA,MAAM,EAAE,GAAA,EAAK,MAAQ,EAAA,SAAA,EAAc,GAAA,KAAA,CAAA;AACnC,EAAA,MAAM,EAAE,UAAA,EAAY,UAAW,EAAA,GAAI,mBAAoB,EAAA,CAAA;AACvD,EAAM,MAAA,EAAE,UAAW,EAAA,GAAI,gBAAiB,EAAA,CAAA;AAExC,EAAA,MAAM,UAAa,GAAA,UAAA,CAAW,GAAI,CAAA,GAAA,CAAI,KAAK,CAAA,CAAA;AAE3C,EAAM,MAAA,WAAA,GAAiD,CAAC,KAAU,KAAA;AAChE,IAAA,UAAA,CAAW,EAAE,QAAU,EAAA,GAAA,CAAI,KAAO,EAAA,WAAA,EAAa,MAAM,CAAA,CAAA;AACrD,IAAA,UAAA,CAAW,MAAQ,EAAA,GAAA,CAAI,KAAO,EAAA,MAAA,CAAO,KAAK,CAAA,CAAA;AAC1C,IAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,IAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,GACxB,CAAA;AAEA,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IAAI,SAAU,EAAA,2BAAA;AAAA,IAA4B,WAAA;AAAA,IACzC,QAAC,kBAAA,GAAA,CAAA,YAAA,EAAA;AAAA,MACC,aAAY,EAAA,6BAAA;AAAA,MACZ,UAAY,EAAA;AAAA,QACV,YAAc,EAAA,YAAA;AAAA,QACd,QAAA,EAAU,YAAY,CAAI,GAAA,CAAA,CAAA;AAAA,OAC5B;AAAA,MACA,OAAS,EAAA,UAAA;AAAA,KACX,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { RowSelectionCheckboxHeaderCellValue } from './RowSelectionCheckboxHeaderCellValue.js';
|
|
3
|
+
import { RowSelectionCheckboxCellValue } from './RowSelectionCheckboxCellValue.js';
|
|
4
|
+
import { GridColumn } from './GridColumn.js';
|
|
5
|
+
import { useSelectionContext } from './SelectionContext.js';
|
|
6
|
+
import { AutoSizeHeaderCell } from './HeaderCell.js';
|
|
7
|
+
|
|
8
|
+
function RowSelectionCheckboxColumn(props) {
|
|
9
|
+
const { selectRows } = useSelectionContext();
|
|
10
|
+
const onKeyDown = (event, rowIndex) => {
|
|
11
|
+
if (event.key === " ") {
|
|
12
|
+
selectRows({ rowIndex, incremental: true });
|
|
13
|
+
event.preventDefault();
|
|
14
|
+
event.stopPropagation();
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
return /* @__PURE__ */ jsx(GridColumn, {
|
|
18
|
+
...props,
|
|
19
|
+
defaultWidth: 100,
|
|
20
|
+
headerComponent: AutoSizeHeaderCell,
|
|
21
|
+
headerValueComponent: RowSelectionCheckboxHeaderCellValue,
|
|
22
|
+
cellValueComponent: RowSelectionCheckboxCellValue,
|
|
23
|
+
onKeyDown
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export { RowSelectionCheckboxColumn };
|
|
28
|
+
//# sourceMappingURL=RowSelectionCheckboxColumn.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RowSelectionCheckboxColumn.js","sources":["../src/RowSelectionCheckboxColumn.tsx"],"sourcesContent":["import { KeyboardEvent } from \"react\";\nimport { RowSelectionCheckboxHeaderCellValue } from \"./RowSelectionCheckboxHeaderCellValue\";\nimport { RowSelectionCheckboxCellValue } from \"./RowSelectionCheckboxCellValue\";\nimport { GridColumn, GridColumnProps } from \"./GridColumn\";\nimport { useSelectionContext } from \"./SelectionContext\";\nimport { AutoSizeHeaderCell } from \"./HeaderCell\";\n\nexport type RowSelectionCheckboxColumnProps<T> = Omit<\n GridColumnProps<T>,\n \"width\" | \"name\"\n>;\n\nexport function RowSelectionCheckboxColumn<T>(\n props: RowSelectionCheckboxColumnProps<T>\n) {\n const { selectRows } = useSelectionContext();\n\n const onKeyDown = (\n event: KeyboardEvent<HTMLDivElement>,\n rowIndex: number\n ) => {\n if (event.key === \" \") {\n selectRows({ rowIndex, incremental: true });\n event.preventDefault();\n event.stopPropagation();\n }\n };\n\n return (\n <GridColumn\n {...props}\n defaultWidth={100}\n headerComponent={AutoSizeHeaderCell}\n headerValueComponent={RowSelectionCheckboxHeaderCellValue}\n cellValueComponent={RowSelectionCheckboxCellValue}\n onKeyDown={onKeyDown}\n />\n );\n}\n"],"names":[],"mappings":";;;;;;;AAYO,SAAS,2BACd,KACA,EAAA;AACA,EAAM,MAAA,EAAE,UAAW,EAAA,GAAI,mBAAoB,EAAA,CAAA;AAE3C,EAAM,MAAA,SAAA,GAAY,CAChB,KAAA,EACA,QACG,KAAA;AACH,IAAI,IAAA,KAAA,CAAM,QAAQ,GAAK,EAAA;AACrB,MAAA,UAAA,CAAW,EAAE,QAAA,EAAU,WAAa,EAAA,IAAA,EAAM,CAAA,CAAA;AAC1C,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,KACxB;AAAA,GACF,CAAA;AAEA,EAAA,uBACG,GAAA,CAAA,UAAA,EAAA;AAAA,IACE,GAAG,KAAA;AAAA,IACJ,YAAc,EAAA,GAAA;AAAA,IACd,eAAiB,EAAA,kBAAA;AAAA,IACjB,oBAAsB,EAAA,mCAAA;AAAA,IACtB,kBAAoB,EAAA,6BAAA;AAAA,IACpB,SAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useSelectionContext } from './SelectionContext.js';
|
|
3
|
+
import { CheckboxBase } from '@salt-ds/lab';
|
|
4
|
+
import './CheckboxCell.css.js';
|
|
5
|
+
|
|
6
|
+
function RowSelectionCheckboxHeaderCellValue(props) {
|
|
7
|
+
const { isFocused } = props;
|
|
8
|
+
const { selectAll, unselectAll, isAllSelected, isAnySelected } = useSelectionContext();
|
|
9
|
+
const onMousedown = (event) => {
|
|
10
|
+
if (isAllSelected) {
|
|
11
|
+
unselectAll();
|
|
12
|
+
} else {
|
|
13
|
+
selectAll();
|
|
14
|
+
}
|
|
15
|
+
};
|
|
16
|
+
const onKeyDown = (event) => {
|
|
17
|
+
if (event.key === " ") {
|
|
18
|
+
if (isAllSelected) {
|
|
19
|
+
unselectAll();
|
|
20
|
+
} else {
|
|
21
|
+
selectAll();
|
|
22
|
+
}
|
|
23
|
+
event.preventDefault();
|
|
24
|
+
event.stopPropagation();
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
return /* @__PURE__ */ jsx("div", {
|
|
28
|
+
onMouseDown: onMousedown,
|
|
29
|
+
className: "saltGridCheckboxContainer",
|
|
30
|
+
onKeyDown,
|
|
31
|
+
children: /* @__PURE__ */ jsx(CheckboxBase, {
|
|
32
|
+
"data-testid": "grid-row-select-all-checkbox",
|
|
33
|
+
inputProps: {
|
|
34
|
+
"aria-label": "Select All",
|
|
35
|
+
tabIndex: isFocused ? 0 : -1
|
|
36
|
+
},
|
|
37
|
+
checked: isAllSelected,
|
|
38
|
+
indeterminate: !isAllSelected && isAnySelected
|
|
39
|
+
})
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export { RowSelectionCheckboxHeaderCellValue };
|
|
44
|
+
//# sourceMappingURL=RowSelectionCheckboxHeaderCellValue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RowSelectionCheckboxHeaderCellValue.js","sources":["../src/RowSelectionCheckboxHeaderCellValue.tsx"],"sourcesContent":["import { useSelectionContext } from \"./SelectionContext\";\nimport { KeyboardEventHandler, MouseEventHandler } from \"react\";\nimport { CheckboxBase } from \"@salt-ds/lab\";\nimport \"./CheckboxCell.css\";\nimport { GridHeaderValueProps } from \"./GridColumn\";\n\nexport function RowSelectionCheckboxHeaderCellValue<T>(\n props: GridHeaderValueProps<T>\n) {\n const { isFocused } = props;\n\n const { selectAll, unselectAll, isAllSelected, isAnySelected } =\n useSelectionContext();\n\n const onMousedown: MouseEventHandler<HTMLDivElement> = (event) => {\n if (isAllSelected) {\n unselectAll();\n } else {\n selectAll();\n }\n };\n\n const onKeyDown: KeyboardEventHandler<HTMLDivElement> = (event) => {\n if (event.key === \" \") {\n if (isAllSelected) {\n unselectAll();\n } else {\n selectAll();\n }\n event.preventDefault();\n event.stopPropagation();\n }\n };\n\n return (\n <div\n onMouseDown={onMousedown}\n className=\"saltGridCheckboxContainer\"\n onKeyDown={onKeyDown}\n >\n <CheckboxBase\n data-testid=\"grid-row-select-all-checkbox\"\n inputProps={{\n \"aria-label\": \"Select All\",\n tabIndex: isFocused ? 0 : -1,\n }}\n checked={isAllSelected}\n indeterminate={!isAllSelected && isAnySelected}\n />\n </div>\n );\n}\n"],"names":[],"mappings":";;;;;AAMO,SAAS,oCACd,KACA,EAAA;AACA,EAAM,MAAA,EAAE,WAAc,GAAA,KAAA,CAAA;AAEtB,EAAA,MAAM,EAAE,SAAW,EAAA,WAAA,EAAa,aAAe,EAAA,aAAA,KAC7C,mBAAoB,EAAA,CAAA;AAEtB,EAAM,MAAA,WAAA,GAAiD,CAAC,KAAU,KAAA;AAChE,IAAA,IAAI,aAAe,EAAA;AACjB,MAAY,WAAA,EAAA,CAAA;AAAA,KACP,MAAA;AACL,MAAU,SAAA,EAAA,CAAA;AAAA,KACZ;AAAA,GACF,CAAA;AAEA,EAAM,MAAA,SAAA,GAAkD,CAAC,KAAU,KAAA;AACjE,IAAI,IAAA,KAAA,CAAM,QAAQ,GAAK,EAAA;AACrB,MAAA,IAAI,aAAe,EAAA;AACjB,QAAY,WAAA,EAAA,CAAA;AAAA,OACP,MAAA;AACL,QAAU,SAAA,EAAA,CAAA;AAAA,OACZ;AACA,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,KACxB;AAAA,GACF,CAAA;AAEA,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IACC,WAAa,EAAA,WAAA;AAAA,IACb,SAAU,EAAA,2BAAA;AAAA,IACV,SAAA;AAAA,IAEA,QAAC,kBAAA,GAAA,CAAA,YAAA,EAAA;AAAA,MACC,aAAY,EAAA,8BAAA;AAAA,MACZ,UAAY,EAAA;AAAA,QACV,YAAc,EAAA,YAAA;AAAA,QACd,QAAA,EAAU,YAAY,CAAI,GAAA,CAAA,CAAA;AAAA,OAC5B;AAAA,MACA,OAAS,EAAA,aAAA;AAAA,MACT,aAAA,EAAe,CAAC,aAAiB,IAAA,aAAA;AAAA,KACnC,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { RadioButtonBase } from '@salt-ds/lab';
|
|
3
|
+
import { useSelectionContext } from './SelectionContext.js';
|
|
4
|
+
import './CheckboxCell.css.js';
|
|
5
|
+
|
|
6
|
+
function RowSelectionRadioCellValue(props) {
|
|
7
|
+
const { row, isFocused } = props;
|
|
8
|
+
const { selRowIdxs } = useSelectionContext();
|
|
9
|
+
const isSelected = selRowIdxs.has(row.index);
|
|
10
|
+
return /* @__PURE__ */ jsx("div", {
|
|
11
|
+
className: "saltGridCheckboxContainer",
|
|
12
|
+
children: /* @__PURE__ */ jsx(RadioButtonBase, {
|
|
13
|
+
checked: isSelected,
|
|
14
|
+
tabIndex: isFocused ? 0 : -1,
|
|
15
|
+
"data-testid": "grid-row-selection-radiobox"
|
|
16
|
+
})
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export { RowSelectionRadioCellValue };
|
|
21
|
+
//# sourceMappingURL=RowSelectionRadioCellValue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RowSelectionRadioCellValue.js","sources":["../src/RowSelectionRadioCellValue.tsx"],"sourcesContent":["import { RadioButtonBase } from \"@salt-ds/lab\";\nimport { GridCellValueProps } from \"./GridColumn\";\nimport { useSelectionContext } from \"./SelectionContext\";\nimport \"./CheckboxCell.css\";\n\nexport function RowSelectionRadioCellValue<T>(props: GridCellValueProps<T>) {\n const { row, isFocused } = props;\n const { selRowIdxs } = useSelectionContext();\n\n const isSelected = selRowIdxs.has(row.index);\n\n return (\n <div className=\"saltGridCheckboxContainer\">\n <RadioButtonBase\n checked={isSelected}\n tabIndex={isFocused ? 0 : -1}\n data-testid=\"grid-row-selection-radiobox\"\n />\n </div>\n );\n}\n"],"names":[],"mappings":";;;;;AAKO,SAAS,2BAA8B,KAA8B,EAAA;AAC1E,EAAM,MAAA,EAAE,GAAK,EAAA,SAAA,EAAc,GAAA,KAAA,CAAA;AAC3B,EAAM,MAAA,EAAE,UAAW,EAAA,GAAI,mBAAoB,EAAA,CAAA;AAE3C,EAAA,MAAM,UAAa,GAAA,UAAA,CAAW,GAAI,CAAA,GAAA,CAAI,KAAK,CAAA,CAAA;AAE3C,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IAAI,SAAU,EAAA,2BAAA;AAAA,IACb,QAAC,kBAAA,GAAA,CAAA,eAAA,EAAA;AAAA,MACC,OAAS,EAAA,UAAA;AAAA,MACT,QAAA,EAAU,YAAY,CAAI,GAAA,CAAA,CAAA;AAAA,MAC1B,aAAY,EAAA,6BAAA;AAAA,KACd,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { RowSelectionRadioCellValue } from './RowSelectionRadioCellValue.js';
|
|
3
|
+
import { GridColumn } from './GridColumn.js';
|
|
4
|
+
import { RowSelectionRadioHeaderCell } from './RowSelectionRadioHeaderCell.js';
|
|
5
|
+
import { useSelectionContext } from './SelectionContext.js';
|
|
6
|
+
|
|
7
|
+
function RowSelectionRadioColumn(props) {
|
|
8
|
+
const { selectRows } = useSelectionContext();
|
|
9
|
+
const onKeyDown = (event, rowIndex) => {
|
|
10
|
+
if (event.key === " ") {
|
|
11
|
+
selectRows({ rowIndex });
|
|
12
|
+
event.preventDefault();
|
|
13
|
+
event.stopPropagation();
|
|
14
|
+
}
|
|
15
|
+
};
|
|
16
|
+
return /* @__PURE__ */ jsx(GridColumn, {
|
|
17
|
+
...props,
|
|
18
|
+
defaultWidth: 100,
|
|
19
|
+
headerComponent: RowSelectionRadioHeaderCell,
|
|
20
|
+
cellValueComponent: RowSelectionRadioCellValue,
|
|
21
|
+
onKeyDown
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export { RowSelectionRadioColumn };
|
|
26
|
+
//# sourceMappingURL=RowSelectionRadioColumn.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RowSelectionRadioColumn.js","sources":["../src/RowSelectionRadioColumn.tsx"],"sourcesContent":["import { RowSelectionRadioCellValue } from \"./RowSelectionRadioCellValue\";\nimport { GridColumn, GridColumnProps } from \"./GridColumn\";\nimport { RowSelectionRadioHeaderCell } from \"./RowSelectionRadioHeaderCell\";\nimport { useSelectionContext } from \"./SelectionContext\";\nimport { KeyboardEvent } from \"react\";\n\nexport type RowSelectionRadioColumnProps<T> = Omit<\n GridColumnProps<T>,\n \"width\" | \"name\"\n>;\n\nexport function RowSelectionRadioColumn<T>(\n props: RowSelectionRadioColumnProps<T>\n) {\n const { selectRows } = useSelectionContext();\n\n const onKeyDown = (\n event: KeyboardEvent<HTMLDivElement>,\n rowIndex: number\n ) => {\n if (event.key === \" \") {\n selectRows({ rowIndex });\n event.preventDefault();\n event.stopPropagation();\n }\n };\n\n return (\n <GridColumn\n {...props}\n defaultWidth={100}\n headerComponent={RowSelectionRadioHeaderCell}\n cellValueComponent={RowSelectionRadioCellValue}\n onKeyDown={onKeyDown}\n />\n );\n}\n"],"names":[],"mappings":";;;;;;AAWO,SAAS,wBACd,KACA,EAAA;AACA,EAAM,MAAA,EAAE,UAAW,EAAA,GAAI,mBAAoB,EAAA,CAAA;AAE3C,EAAM,MAAA,SAAA,GAAY,CAChB,KAAA,EACA,QACG,KAAA;AACH,IAAI,IAAA,KAAA,CAAM,QAAQ,GAAK,EAAA;AACrB,MAAW,UAAA,CAAA,EAAE,UAAU,CAAA,CAAA;AACvB,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,KACxB;AAAA,GACF,CAAA;AAEA,EAAA,uBACG,GAAA,CAAA,UAAA,EAAA;AAAA,IACE,GAAG,KAAA;AAAA,IACJ,YAAc,EAAA,GAAA;AAAA,IACd,eAAiB,EAAA,2BAAA;AAAA,IACjB,kBAAoB,EAAA,0BAAA;AAAA,IACpB,SAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { AutoSizeHeaderCell } from './HeaderCell.js';
|
|
3
|
+
import { RadioButtonIcon } from '@salt-ds/lab';
|
|
4
|
+
import './CheckboxCell.css.js';
|
|
5
|
+
import cn from 'classnames';
|
|
6
|
+
|
|
7
|
+
function RowSelectionRadioHeaderCell(props) {
|
|
8
|
+
return /* @__PURE__ */ jsx(AutoSizeHeaderCell, {
|
|
9
|
+
...props,
|
|
10
|
+
children: /* @__PURE__ */ jsx("div", {
|
|
11
|
+
className: cn("saltGridCheckboxContainer", "saltGrid-hidden"),
|
|
12
|
+
children: /* @__PURE__ */ jsx(RadioButtonIcon, {})
|
|
13
|
+
})
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export { RowSelectionRadioHeaderCell };
|
|
18
|
+
//# sourceMappingURL=RowSelectionRadioHeaderCell.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RowSelectionRadioHeaderCell.js","sources":["../src/RowSelectionRadioHeaderCell.tsx"],"sourcesContent":["import { AutoSizeHeaderCell } from \"./HeaderCell\";\nimport { RadioButtonIcon } from \"@salt-ds/lab\";\nimport \"./CheckboxCell.css\";\nimport cx from \"classnames\";\nimport { HeaderCellProps } from \"./GridColumn\";\n\nexport function RowSelectionRadioHeaderCell<T>(props: HeaderCellProps<T>) {\n return (\n <AutoSizeHeaderCell {...props}>\n <div className={cx(\"saltGridCheckboxContainer\", \"saltGrid-hidden\")}>\n <RadioButtonIcon />\n </div>\n </AutoSizeHeaderCell>\n );\n}\n"],"names":["cx"],"mappings":";;;;;;AAMO,SAAS,4BAA+B,KAA2B,EAAA;AACxE,EAAA,uBACG,GAAA,CAAA,kBAAA,EAAA;AAAA,IAAoB,GAAG,KAAA;AAAA,IACtB,QAAC,kBAAA,GAAA,CAAA,KAAA,EAAA;AAAA,MAAI,SAAA,EAAWA,EAAG,CAAA,2BAAA,EAA6B,iBAAiB,CAAA;AAAA,MAC/D,8BAAC,eAAgB,EAAA,EAAA,CAAA;AAAA,KACnB,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { createContext, useContext } from 'react';
|
|
2
|
+
|
|
3
|
+
const SelectionContext = createContext(
|
|
4
|
+
void 0
|
|
5
|
+
);
|
|
6
|
+
const useSelectionContext = () => {
|
|
7
|
+
const c = useContext(SelectionContext);
|
|
8
|
+
if (!c) {
|
|
9
|
+
throw new Error(`useSelectionContext invoked outside of a Grid`);
|
|
10
|
+
}
|
|
11
|
+
return c;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export { SelectionContext, useSelectionContext };
|
|
15
|
+
//# sourceMappingURL=SelectionContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SelectionContext.js","sources":["../src/SelectionContext.ts"],"sourcesContent":["import { createContext, useContext } from \"react\";\nimport { CellRange, SelectRowsOptions } from \"./internal\";\n\nexport interface SelectionContext {\n selectedCellRange: CellRange | undefined;\n selRowIdxs: Set<number>;\n isAnySelected: boolean;\n isAllSelected: boolean;\n selectRows: (args: SelectRowsOptions) => void;\n selectAll: () => void;\n unselectAll: () => void;\n}\n\nexport const SelectionContext = createContext<SelectionContext | undefined>(\n undefined\n);\n\nexport const useSelectionContext = () => {\n const c = useContext(SelectionContext);\n if (!c) {\n throw new Error(`useSelectionContext invoked outside of a Grid`);\n }\n return c;\n};\n"],"names":[],"mappings":";;AAaO,MAAM,gBAAmB,GAAA,aAAA;AAAA,EAC9B,KAAA,CAAA;AACF,EAAA;AAEO,MAAM,sBAAsB,MAAM;AACvC,EAAM,MAAA,CAAA,GAAI,WAAW,gBAAgB,CAAA,CAAA;AACrC,EAAA,IAAI,CAAC,CAAG,EAAA;AACN,IAAM,MAAA,IAAI,MAAM,CAA+C,6CAAA,CAAA,CAAA,CAAA;AAAA,GACjE;AACA,EAAO,OAAA,CAAA,CAAA;AACT;;;;"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { createContext, useContext } from 'react';
|
|
2
|
+
|
|
3
|
+
const SizingContext = createContext(
|
|
4
|
+
void 0
|
|
5
|
+
);
|
|
6
|
+
const useSizingContext = () => {
|
|
7
|
+
const c = useContext(SizingContext);
|
|
8
|
+
if (!c) {
|
|
9
|
+
throw new Error(`useSizingContext invoked outside of a Grid`);
|
|
10
|
+
}
|
|
11
|
+
return c;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export { SizingContext, useSizingContext };
|
|
15
|
+
//# sourceMappingURL=SizingContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SizingContext.js","sources":["../src/SizingContext.ts"],"sourcesContent":["import React, { createContext, useContext } from \"react\";\n\nexport interface SizingContext {\n rowHeight: number;\n resizeColumn: (colIdx: number, width: number) => void;\n onResizeHandleMouseDown: (event: React.MouseEvent<HTMLDivElement>) => void;\n}\n\nexport const SizingContext = createContext<SizingContext | undefined>(\n undefined\n);\nexport const useSizingContext = () => {\n const c = useContext(SizingContext);\n if (!c) {\n throw new Error(`useSizingContext invoked outside of a Grid`);\n }\n return c;\n};\n"],"names":[],"mappings":";;AAQO,MAAM,aAAgB,GAAA,aAAA;AAAA,EAC3B,KAAA,CAAA;AACF,EAAA;AACO,MAAM,mBAAmB,MAAM;AACpC,EAAM,MAAA,CAAA,GAAI,WAAW,aAAa,CAAA,CAAA;AAClC,EAAA,IAAI,CAAC,CAAG,EAAA;AACN,IAAM,MAAA,IAAI,MAAM,CAA4C,0CAAA,CAAA,CAAA,CAAA;AAAA,GAC9D;AACA,EAAO,OAAA,CAAA,CAAA;AACT;;;;"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import styleInject from '../../../node_modules/style-inject/dist/style-inject.es.js';
|
|
2
|
+
|
|
3
|
+
var css_248z = ".saltGridTextCellEditor {\n}\n\n.saltGridTextCellEditor-inputContainer {\n background: var(--grid-background);\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n box-sizing: border-box;\n border-style: var(--grid-cursor-border-style);\n border-width: var(--grid-cursor-border-width);\n border-color: var(--grid-cursor-borderColor);\n padding: 0;\n}\n\n.saltGridTextCellEditor input {\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n right: 0;\n outline: none;\n border: none;\n padding: 0 calc(var(--grid-padding) - 2px);\n font-size: var(--grid-fontSize);\n font-family: inherit;\n background: var(--grid-editableCell-background-active);\n color: var(--grid-editableCell-color-active);\n}\n";
|
|
4
|
+
styleInject(css_248z);
|
|
5
|
+
|
|
6
|
+
export { css_248z as default };
|
|
7
|
+
//# sourceMappingURL=TextCellEditor.css.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TextCellEditor.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useRef, useState, useEffect } from 'react';
|
|
3
|
+
import './TextCellEditor.css.js';
|
|
4
|
+
import { makePrefixer } from '@salt-ds/core';
|
|
5
|
+
import { useEditorContext } from './EditorContext.js';
|
|
6
|
+
import { CornerTag } from './CornerTag.js';
|
|
7
|
+
import { Cell } from './internal/Cell.js';
|
|
8
|
+
import './internal/CellMeasure.js';
|
|
9
|
+
import './internal/Cursor.js';
|
|
10
|
+
import './internal/GroupHeaderRow.js';
|
|
11
|
+
import './internal/HeaderRow.js';
|
|
12
|
+
import './internal/LeftPart.js';
|
|
13
|
+
import './internal/MiddlePart.js';
|
|
14
|
+
import './internal/RightPart.js';
|
|
15
|
+
import './internal/Scrollable.js';
|
|
16
|
+
import './internal/TableRow.js';
|
|
17
|
+
import './SelectionContext.js';
|
|
18
|
+
import './CursorContext.js';
|
|
19
|
+
import './NumberRange.js';
|
|
20
|
+
import './internal/TopLeftPart.js';
|
|
21
|
+
import './internal/TopPart.js';
|
|
22
|
+
import './internal/TopRightPart.js';
|
|
23
|
+
import './internal/FakeCell.css.js';
|
|
24
|
+
import './internal/DefaultCellValue.js';
|
|
25
|
+
|
|
26
|
+
const withBaseName = makePrefixer("saltGridTextCellEditor");
|
|
27
|
+
function TextCellEditor(props) {
|
|
28
|
+
const { column, row } = props;
|
|
29
|
+
const inputRef = useRef(null);
|
|
30
|
+
const { endEditMode, cancelEditMode, initialText } = useEditorContext();
|
|
31
|
+
const [editorText, setEditorText] = useState(
|
|
32
|
+
initialText != null ? initialText : column.info.props.getValue(row.data)
|
|
33
|
+
);
|
|
34
|
+
const initialSelectionRef = useRef(!!initialText);
|
|
35
|
+
const onChange = (e) => {
|
|
36
|
+
setEditorText(e.target.value);
|
|
37
|
+
};
|
|
38
|
+
const onKeyDown = (event) => {
|
|
39
|
+
if (event.key === "Enter") {
|
|
40
|
+
endEditMode(editorText);
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
if (event.key === "Escape") {
|
|
44
|
+
cancelEditMode();
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
if (event.key === "Tab") {
|
|
48
|
+
endEditMode(editorText);
|
|
49
|
+
event.preventDefault();
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
event.stopPropagation();
|
|
53
|
+
};
|
|
54
|
+
useEffect(() => {
|
|
55
|
+
if (inputRef.current && !initialSelectionRef.current) {
|
|
56
|
+
inputRef.current.select();
|
|
57
|
+
initialSelectionRef.current = true;
|
|
58
|
+
}
|
|
59
|
+
}, [inputRef.current]);
|
|
60
|
+
return /* @__PURE__ */ jsxs(Cell, {
|
|
61
|
+
separator: column == null ? void 0 : column.separator,
|
|
62
|
+
className: withBaseName(),
|
|
63
|
+
children: [
|
|
64
|
+
/* @__PURE__ */ jsx("div", {
|
|
65
|
+
className: withBaseName("inputContainer"),
|
|
66
|
+
children: /* @__PURE__ */ jsx("input", {
|
|
67
|
+
"data-testid": "grid-cell-editor-input",
|
|
68
|
+
ref: inputRef,
|
|
69
|
+
autoFocus: true,
|
|
70
|
+
value: editorText,
|
|
71
|
+
onChange,
|
|
72
|
+
onKeyDown
|
|
73
|
+
})
|
|
74
|
+
}),
|
|
75
|
+
/* @__PURE__ */ jsx(CornerTag, {})
|
|
76
|
+
]
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
export { TextCellEditor };
|
|
81
|
+
//# sourceMappingURL=TextCellEditor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TextCellEditor.js","sources":["../src/TextCellEditor.tsx"],"sourcesContent":["import {\n ChangeEventHandler,\n KeyboardEventHandler,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport \"./TextCellEditor.css\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { useEditorContext } from \"./EditorContext\";\nimport { GridColumnModel, GridRowModel } from \"./Grid\";\nimport { CornerTag } from \"./CornerTag\";\nimport { Cell } from \"./internal\";\n\nconst withBaseName = makePrefixer(\"saltGridTextCellEditor\");\n\nexport interface TextCellEditorProps<T> {\n row?: GridRowModel<T>;\n column?: GridColumnModel<T>;\n}\n\nexport function TextCellEditor<T>(props: TextCellEditorProps<T>) {\n const { column, row } = props;\n const inputRef = useRef<HTMLInputElement>(null);\n\n const { endEditMode, cancelEditMode, initialText } = useEditorContext();\n\n const [editorText, setEditorText] = useState<string>(\n initialText != null ? initialText : column!.info.props.getValue!(row!.data)\n );\n\n const initialSelectionRef = useRef(!!initialText);\n\n const onChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n setEditorText(e.target.value);\n };\n\n const onKeyDown: KeyboardEventHandler<HTMLInputElement> = (event) => {\n if (event.key === \"Enter\") {\n endEditMode(editorText);\n return;\n }\n if (event.key === \"Escape\") {\n cancelEditMode();\n return;\n }\n if (event.key === \"Tab\") {\n endEditMode(editorText);\n event.preventDefault();\n return;\n }\n event.stopPropagation();\n };\n\n useEffect(() => {\n if (inputRef.current && !initialSelectionRef.current) {\n inputRef.current.select();\n initialSelectionRef.current = true;\n }\n }, [inputRef.current]);\n\n return (\n <Cell separator={column?.separator} className={withBaseName()}>\n <div className={withBaseName(\"inputContainer\")}>\n <input\n data-testid=\"grid-cell-editor-input\"\n ref={inputRef}\n autoFocus={true}\n value={editorText}\n onChange={onChange}\n onKeyDown={onKeyDown}\n />\n </div>\n <CornerTag />\n </Cell>\n );\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAcA,MAAM,YAAA,GAAe,aAAa,wBAAwB,CAAA,CAAA;AAOnD,SAAS,eAAkB,KAA+B,EAAA;AAC/D,EAAM,MAAA,EAAE,MAAQ,EAAA,GAAA,EAAQ,GAAA,KAAA,CAAA;AACxB,EAAM,MAAA,QAAA,GAAW,OAAyB,IAAI,CAAA,CAAA;AAE9C,EAAA,MAAM,EAAE,WAAA,EAAa,cAAgB,EAAA,WAAA,KAAgB,gBAAiB,EAAA,CAAA;AAEtE,EAAM,MAAA,CAAC,UAAY,EAAA,aAAa,CAAI,GAAA,QAAA;AAAA,IAClC,WAAA,IAAe,OAAO,WAAc,GAAA,MAAA,CAAQ,KAAK,KAAM,CAAA,QAAA,CAAU,IAAK,IAAI,CAAA;AAAA,GAC5E,CAAA;AAEA,EAAA,MAAM,mBAAsB,GAAA,MAAA,CAAO,CAAC,CAAC,WAAW,CAAA,CAAA;AAEhD,EAAM,MAAA,QAAA,GAAiD,CAAC,CAAM,KAAA;AAC5D,IAAc,aAAA,CAAA,CAAA,CAAE,OAAO,KAAK,CAAA,CAAA;AAAA,GAC9B,CAAA;AAEA,EAAM,MAAA,SAAA,GAAoD,CAAC,KAAU,KAAA;AACnE,IAAI,IAAA,KAAA,CAAM,QAAQ,OAAS,EAAA;AACzB,MAAA,WAAA,CAAY,UAAU,CAAA,CAAA;AACtB,MAAA,OAAA;AAAA,KACF;AACA,IAAI,IAAA,KAAA,CAAM,QAAQ,QAAU,EAAA;AAC1B,MAAe,cAAA,EAAA,CAAA;AACf,MAAA,OAAA;AAAA,KACF;AACA,IAAI,IAAA,KAAA,CAAM,QAAQ,KAAO,EAAA;AACvB,MAAA,WAAA,CAAY,UAAU,CAAA,CAAA;AACtB,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,OAAA;AAAA,KACF;AACA,IAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,GACxB,CAAA;AAEA,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,QAAS,CAAA,OAAA,IAAW,CAAC,mBAAA,CAAoB,OAAS,EAAA;AACpD,MAAA,QAAA,CAAS,QAAQ,MAAO,EAAA,CAAA;AACxB,MAAA,mBAAA,CAAoB,OAAU,GAAA,IAAA,CAAA;AAAA,KAChC;AAAA,GACC,EAAA,CAAC,QAAS,CAAA,OAAO,CAAC,CAAA,CAAA;AAErB,EAAA,uBACG,IAAA,CAAA,IAAA,EAAA;AAAA,IAAK,WAAW,MAAQ,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,MAAA,CAAA,SAAA;AAAA,IAAW,WAAW,YAAa,EAAA;AAAA,IAC1D,QAAA,EAAA;AAAA,sBAAC,GAAA,CAAA,KAAA,EAAA;AAAA,QAAI,SAAA,EAAW,aAAa,gBAAgB,CAAA;AAAA,QAC3C,QAAC,kBAAA,GAAA,CAAA,OAAA,EAAA;AAAA,UACC,aAAY,EAAA,wBAAA;AAAA,UACZ,GAAK,EAAA,QAAA;AAAA,UACL,SAAW,EAAA,IAAA;AAAA,UACX,KAAO,EAAA,UAAA;AAAA,UACP,QAAA;AAAA,UACA,SAAA;AAAA,SACF,CAAA;AAAA,OACF,CAAA;AAAA,0BACC,SAAU,EAAA,EAAA,CAAA;AAAA,KAAA;AAAA,GACb,CAAA,CAAA;AAEJ;;;;"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export { BaseCell, getCellId } from './BaseCell.js';
|
|
2
|
+
export { ColumnGroup } from './ColumnGroup.js';
|
|
3
|
+
export { CellEditor } from './CellEditor.js';
|
|
4
|
+
export { CornerTag } from './CornerTag.js';
|
|
5
|
+
export { GroupHeaderCell } from './GroupHeaderCell.js';
|
|
6
|
+
export { GroupHeaderCellValue } from './GroupHeaderCellValue.js';
|
|
7
|
+
export { AutoSizeHeaderCell, HeaderCell, HeaderCellSeparator } from './HeaderCell.js';
|
|
8
|
+
export { HeaderCellValue } from './HeaderCellValue.js';
|
|
9
|
+
export { NumberRange, range } from './NumberRange.js';
|
|
10
|
+
export { RowSelectionCheckboxHeaderCellValue } from './RowSelectionCheckboxHeaderCellValue.js';
|
|
11
|
+
export { RowSelectionCheckboxCellValue } from './RowSelectionCheckboxCellValue.js';
|
|
12
|
+
export { RowSelectionRadioColumn } from './RowSelectionRadioColumn.js';
|
|
13
|
+
export { SelectionContext, useSelectionContext } from './SelectionContext.js';
|
|
14
|
+
export { SizingContext, useSizingContext } from './SizingContext.js';
|
|
15
|
+
export { Grid } from './Grid.js';
|
|
16
|
+
export { GridColumn } from './GridColumn.js';
|
|
17
|
+
export { GridContext, useGridContext } from './GridContext.js';
|
|
18
|
+
export { RowSelectionCheckboxColumn } from './RowSelectionCheckboxColumn.js';
|
|
19
|
+
export { TextCellEditor } from './TextCellEditor.js';
|
|
20
|
+
export { DropdownCellEditor } from './DropdownCellEditor.js';
|
|
21
|
+
export { NumericCellEditor, NumericCellValue, NumericColumn } from './NumericColumn.js';
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import styleInject from '../../../../node_modules/style-inject/dist/style-inject.es.js';
|
|
2
|
+
|
|
3
|
+
var css_248z = ".saltGridCell {\n box-sizing: border-box;\n overflow: hidden;\n margin: 0;\n padding: 0;\n\n white-space: nowrap;\n position: relative;\n font-size: var(--grid-fontSize);\n font-weight: normal;\n\n outline: 0;\n}\n\n.saltGridCell-selected {\n background: var(--grid-cell-background-selected);\n}\n\n.saltGridCell-rowSeparator {\n position: absolute;\n right: 0;\n bottom: 0;\n left: 0;\n height: 1px;\n background-color: var(--grid-row-borderColor);\n}\n\n.saltGridCell-topSeparator {\n position: absolute;\n top: 0;\n right: 0;\n left: 0;\n height: 1px;\n background-color: transparent;\n display: none;\n}\n\n.saltGridTableRow-first .saltGridCell-topSeparator {\n display: unset;\n}\n\n.saltGridCell-columnSeparator {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n width: 1px;\n background-color: var(--grid-row-background);\n}\n\n.saltGrid-columnSeparators .saltGridCell-regularSeparator .saltGridCell-columnSeparator {\n background-color: var(--grid-columnSeparator-color);\n}\n\n.saltGrid-columnSeparators .saltGridCell-pinnedSeparator .saltGridCell-columnSeparator {\n background-color: var(--grid-columnSeparator-color);\n}\n\n.saltGrid-pinnedSeparators .saltGridCell-pinnedSeparator .saltGridCell-columnSeparator {\n background-color: var(--grid-pinnedSeparator-color);\n}\n\n.saltGridTableRow-selected.saltGridTableRow-first .saltGridCell-topSeparator {\n background-color: var(--grid-row-borderColor);\n}\n\n.saltGridCell-body {\n box-sizing: border-box;\n position: absolute;\n top: 0;\n right: 0;\n bottom: 1px;\n left: 0;\n background: var(--grid-row-background);\n border-right: solid 1px transparent;\n}\n\n.saltGridTableRow-first .saltGridCell-body {\n top: 1px;\n}\n";
|
|
4
|
+
styleInject(css_248z);
|
|
5
|
+
|
|
6
|
+
export { css_248z as default };
|
|
7
|
+
//# sourceMappingURL=Cell.css.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Cell.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { makePrefixer } from '@salt-ds/core';
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import cn from 'classnames';
|
|
5
|
+
import './Cell.css.js';
|
|
6
|
+
|
|
7
|
+
const withBaseName = makePrefixer("saltGridCell");
|
|
8
|
+
const Cell = forwardRef(
|
|
9
|
+
function CellFrame(props, ref) {
|
|
10
|
+
const {
|
|
11
|
+
children,
|
|
12
|
+
separator,
|
|
13
|
+
isSelected,
|
|
14
|
+
isEditable,
|
|
15
|
+
className,
|
|
16
|
+
...tdProps
|
|
17
|
+
} = props;
|
|
18
|
+
return /* @__PURE__ */ jsxs("td", {
|
|
19
|
+
ref,
|
|
20
|
+
className: cn(
|
|
21
|
+
withBaseName(),
|
|
22
|
+
{
|
|
23
|
+
[withBaseName("selected")]: isSelected,
|
|
24
|
+
[withBaseName("editable")]: isEditable,
|
|
25
|
+
[withBaseName("regularSeparator")]: separator === "regular" || separator === "groupEdge",
|
|
26
|
+
[withBaseName("pinnedSeparator")]: separator === "pinned"
|
|
27
|
+
},
|
|
28
|
+
className
|
|
29
|
+
),
|
|
30
|
+
...tdProps,
|
|
31
|
+
children: [
|
|
32
|
+
/* @__PURE__ */ jsx("div", {
|
|
33
|
+
className: withBaseName("body"),
|
|
34
|
+
children: props.children
|
|
35
|
+
}),
|
|
36
|
+
/* @__PURE__ */ jsx("div", {
|
|
37
|
+
className: withBaseName("columnSeparator")
|
|
38
|
+
}),
|
|
39
|
+
/* @__PURE__ */ jsx("div", {
|
|
40
|
+
className: withBaseName("rowSeparator")
|
|
41
|
+
}),
|
|
42
|
+
/* @__PURE__ */ jsx("div", {
|
|
43
|
+
className: withBaseName("topSeparator")
|
|
44
|
+
})
|
|
45
|
+
]
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
);
|
|
49
|
+
|
|
50
|
+
export { Cell };
|
|
51
|
+
//# sourceMappingURL=Cell.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Cell.js","sources":["../src/internal/Cell.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { forwardRef, HTMLAttributes } from \"react\";\nimport cn from \"classnames\";\nimport \"./Cell.css\";\nimport { ColumnSeparatorType } from \"../Grid\";\n\nexport interface CellProps extends HTMLAttributes<HTMLTableCellElement> {\n isSelected?: boolean;\n isEditable?: boolean;\n separator?: ColumnSeparatorType;\n}\n\nconst withBaseName = makePrefixer(\"saltGridCell\");\n\nexport const Cell = forwardRef<HTMLTableCellElement, CellProps>(\n function CellFrame(props, ref) {\n const {\n children,\n separator,\n isSelected,\n isEditable,\n className,\n ...tdProps\n } = props;\n return (\n <td\n ref={ref}\n className={cn(\n withBaseName(),\n {\n [withBaseName(\"selected\")]: isSelected,\n [withBaseName(\"editable\")]: isEditable,\n [withBaseName(\"regularSeparator\")]:\n separator === \"regular\" || separator === \"groupEdge\",\n [withBaseName(\"pinnedSeparator\")]: separator === \"pinned\",\n },\n className\n )}\n {...tdProps}\n >\n <div className={withBaseName(\"body\")}>{props.children}</div>\n <div className={withBaseName(\"columnSeparator\")} />\n <div className={withBaseName(\"rowSeparator\")} />\n <div className={withBaseName(\"topSeparator\")} />\n </td>\n );\n }\n);\n"],"names":[],"mappings":";;;;;;AAYA,MAAM,YAAA,GAAe,aAAa,cAAc,CAAA,CAAA;AAEzC,MAAM,IAAO,GAAA,UAAA;AAAA,EAClB,SAAS,SAAU,CAAA,KAAA,EAAO,GAAK,EAAA;AAC7B,IAAM,MAAA;AAAA,MACJ,QAAA;AAAA,MACA,SAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAA;AAAA,MACA,SAAA;AAAA,MACG,GAAA,OAAA;AAAA,KACD,GAAA,KAAA,CAAA;AACJ,IAAA,uBACG,IAAA,CAAA,IAAA,EAAA;AAAA,MACC,GAAA;AAAA,MACA,SAAW,EAAA,EAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb;AAAA,UACE,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,UAAA;AAAA,UAC5B,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,UAAA;AAAA,UAC5B,CAAC,YAAa,CAAA,kBAAkB,CAC9B,GAAA,SAAA,KAAc,aAAa,SAAc,KAAA,WAAA;AAAA,UAC3C,CAAC,YAAA,CAAa,iBAAiB,CAAA,GAAI,SAAc,KAAA,QAAA;AAAA,SACnD;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACC,GAAG,OAAA;AAAA,MAEJ,QAAA,EAAA;AAAA,wBAAC,GAAA,CAAA,KAAA,EAAA;AAAA,UAAI,SAAA,EAAW,aAAa,MAAM,CAAA;AAAA,UAAI,QAAM,EAAA,KAAA,CAAA,QAAA;AAAA,SAAS,CAAA;AAAA,wBACrD,GAAA,CAAA,KAAA,EAAA;AAAA,UAAI,SAAA,EAAW,aAAa,iBAAiB,CAAA;AAAA,SAAG,CAAA;AAAA,wBAChD,GAAA,CAAA,KAAA,EAAA;AAAA,UAAI,SAAA,EAAW,aAAa,cAAc,CAAA;AAAA,SAAG,CAAA;AAAA,wBAC7C,GAAA,CAAA,KAAA,EAAA;AAAA,UAAI,SAAA,EAAW,aAAa,cAAc,CAAA;AAAA,SAAG,CAAA;AAAA,OAAA;AAAA,KAChD,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import styleInject from '../../../../node_modules/style-inject/dist/style-inject.es.js';
|
|
2
|
+
|
|
3
|
+
var css_248z = ".saltGridCellMeasure {\n position: fixed;\n top: -1000px;\n left: 0;\n}\n\n.saltGridCellMeasure table {\n}\n\n.saltGridCellMeasure tr {\n height: var(--grid-row-height);\n}\n\n.saltGridCellMeasure th {\n box-sizing: border-box;\n overflow: hidden;\n}\n";
|
|
4
|
+
styleInject(css_248z);
|
|
5
|
+
|
|
6
|
+
export { css_248z as default };
|
|
7
|
+
//# sourceMappingURL=CellMeasure.css.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CellMeasure.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import './CellMeasure.css.js';
|
|
3
|
+
import { useRef, useEffect } from 'react';
|
|
4
|
+
import { makePrefixer } from '@salt-ds/core';
|
|
5
|
+
|
|
6
|
+
const withBaseName = makePrefixer("saltGridCellMeasure");
|
|
7
|
+
function CellMeasure(props) {
|
|
8
|
+
const rowRef = useRef(null);
|
|
9
|
+
const heightRef = useRef(-1);
|
|
10
|
+
const { setRowHeight } = props;
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
if (rowRef.current) {
|
|
13
|
+
const height = rowRef.current.getBoundingClientRect().height;
|
|
14
|
+
if (heightRef.current !== height) {
|
|
15
|
+
heightRef.current = height;
|
|
16
|
+
setRowHeight(height);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
return /* @__PURE__ */ jsx("div", {
|
|
21
|
+
className: withBaseName(),
|
|
22
|
+
children: /* @__PURE__ */ jsx("table", {
|
|
23
|
+
"aria-hidden": true,
|
|
24
|
+
children: /* @__PURE__ */ jsx("thead", {
|
|
25
|
+
children: /* @__PURE__ */ jsx("tr", {
|
|
26
|
+
ref: rowRef,
|
|
27
|
+
children: /* @__PURE__ */ jsx("th", {
|
|
28
|
+
children: "Invisible Cell"
|
|
29
|
+
})
|
|
30
|
+
})
|
|
31
|
+
})
|
|
32
|
+
})
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export { CellMeasure };
|
|
37
|
+
//# sourceMappingURL=CellMeasure.js.map
|