-
-
Notifications
You must be signed in to change notification settings - Fork 3.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore: split column and row pinning (#5402)
- Loading branch information
1 parent
16d16dd
commit ea4d40a
Showing
13 changed files
with
706 additions
and
643 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,266 @@ | ||
--- | ||
title: Column Pinning APIs | ||
id: column-pinning | ||
--- | ||
|
||
## Can-Pin | ||
|
||
The ability for a column to be **pinned** is determined by the following: | ||
|
||
- `options.enablePinning` is not set to `false` | ||
- `options.enableColumnPinning` is not set to `false` | ||
- `columnDefinition.enablePinning` is not set to `false` | ||
|
||
## State | ||
|
||
Pinning state is stored on the table using the following shape: | ||
|
||
```tsx | ||
export type ColumnPinningPosition = false | 'left' | 'right' | ||
|
||
export type ColumnPinningState = { | ||
left?: string[] | ||
right?: string[] | ||
} | ||
|
||
|
||
export type ColumnPinningTableState = { | ||
columnPinning: ColumnPinningState | ||
} | ||
``` | ||
## Table Options | ||
### `enableColumnPinning` | ||
```tsx | ||
enableColumnPinning?: boolean | ||
``` | ||
Enables/disables column pinning for all columns in the table. | ||
### `onColumnPinningChange` | ||
```tsx | ||
onColumnPinningChange?: OnChangeFn<ColumnPinningState> | ||
``` | ||
If provided, this function will be called with an `updaterFn` when `state.columnPinning` changes. This overrides the default internal state management, so you will also need to supply `state.columnPinning` from your own managed state. | ||
## Column Def Options | ||
### `enablePinning` | ||
```tsx | ||
enablePinning?: boolean | ||
``` | ||
Enables/disables pinning for the column. | ||
## Table API | ||
### `setColumnPinning` | ||
```tsx | ||
setColumnPinning: (updater: Updater<ColumnPinningState>) => void | ||
``` | ||
Sets or updates the `state.columnPinning` state. | ||
### `resetColumnPinning` | ||
```tsx | ||
resetColumnPinning: (defaultState?: boolean) => void | ||
``` | ||
Resets the **columnPinning** state to `initialState.columnPinning`, or `true` can be passed to force a default blank state reset to `{ left: [], right: [], }`. | ||
### `getIsSomeColumnsPinned` | ||
```tsx | ||
getIsSomeColumnsPinned: (position?: ColumnPinningPosition) => boolean | ||
``` | ||
Returns whether or not any columns are pinned. Optionally specify to only check for pinned columns in either the `left` or `right` position. | ||
_Note: Does not account for column visibility_ | ||
### `getLeftHeaderGroups` | ||
```tsx | ||
getLeftHeaderGroups: () => HeaderGroup<TData>[] | ||
``` | ||
Returns the left pinned header groups for the table. | ||
### `getCenterHeaderGroups` | ||
```tsx | ||
getCenterHeaderGroups: () => HeaderGroup<TData>[] | ||
``` | ||
Returns the unpinned/center header groups for the table. | ||
### `getRightHeaderGroups` | ||
```tsx | ||
getRightHeaderGroups: () => HeaderGroup<TData>[] | ||
``` | ||
Returns the right pinned header groups for the table. | ||
### `getLeftFooterGroups` | ||
```tsx | ||
getLeftFooterGroups: () => HeaderGroup<TData>[] | ||
``` | ||
Returns the left pinned footer groups for the table. | ||
### `getCenterFooterGroups` | ||
```tsx | ||
getCenterFooterGroups: () => HeaderGroup<TData>[] | ||
``` | ||
Returns the unpinned/center footer groups for the table. | ||
### `getRightFooterGroups` | ||
```tsx | ||
getRightFooterGroups: () => HeaderGroup<TData>[] | ||
``` | ||
Returns the right pinned footer groups for the table. | ||
### `getLeftFlatHeaders` | ||
```tsx | ||
getLeftFlatHeaders: () => Header<TData>[] | ||
``` | ||
Returns a flat array of left pinned headers for the table, including parent headers. | ||
### `getCenterFlatHeaders` | ||
```tsx | ||
getCenterFlatHeaders: () => Header<TData>[] | ||
``` | ||
Returns a flat array of unpinned/center headers for the table, including parent headers. | ||
### `getRightFlatHeaders` | ||
```tsx | ||
getRightFlatHeaders: () => Header<TData>[] | ||
``` | ||
Returns a flat array of right pinned headers for the table, including parent headers. | ||
### `getLeftLeafHeaders` | ||
```tsx | ||
getLeftLeafHeaders: () => Header<TData>[] | ||
``` | ||
Returns a flat array of leaf-node left pinned headers for the table. | ||
### `getCenterLeafHeaders` | ||
```tsx | ||
getCenterLeafHeaders: () => Header<TData>[] | ||
``` | ||
Returns a flat array of leaf-node unpinned/center headers for the table. | ||
### `getRightLeafHeaders` | ||
```tsx | ||
getRightLeafHeaders: () => Header<TData>[] | ||
``` | ||
Returns a flat array of leaf-node right pinned headers for the table. | ||
### `getLeftLeafColumns` | ||
```tsx | ||
getLeftLeafColumns: () => Column<TData>[] | ||
``` | ||
Returns all left pinned leaf columns. | ||
### `getRightLeafColumns` | ||
```tsx | ||
getRightLeafColumns: () => Column<TData>[] | ||
``` | ||
Returns all right pinned leaf columns. | ||
### `getCenterLeafColumns` | ||
```tsx | ||
getCenterLeafColumns: () => Column<TData>[] | ||
``` | ||
Returns all center pinned (unpinned) leaf columns. | ||
## Column API | ||
### `getCanPin` | ||
```tsx | ||
getCanPin: () => boolean | ||
``` | ||
Returns whether or not the column can be pinned. | ||
### `getPinnedIndex` | ||
```tsx | ||
getPinnedIndex: () => number | ||
``` | ||
Returns the numeric pinned index of the column within a pinned column group. | ||
### `getIsPinned` | ||
```tsx | ||
getIsPinned: () => ColumnPinningPosition | ||
``` | ||
Returns the pinned position of the column. (`'left'`, `'right'` or `false`) | ||
### `pin` | ||
```tsx | ||
pin: (position: ColumnPinningPosition) => void | ||
``` | ||
Pins a column to the `'left'` or `'right'`, or unpins the column to the center if `false` is passed. | ||
## Row API | ||
### `getLeftVisibleCells` | ||
```tsx | ||
getLeftVisibleCells: () => Cell<TData>[] | ||
``` | ||
Returns all left pinned leaf cells in the row. | ||
### `getRightVisibleCells` | ||
```tsx | ||
getRightVisibleCells: () => Cell<TData>[] | ||
``` | ||
Returns all right pinned leaf cells in the row. | ||
### `getCenterVisibleCells` | ||
```tsx | ||
getCenterVisibleCells: () => Cell<TData>[] | ||
``` | ||
Returns all center pinned (unpinned) leaf cells in the row. |
Oops, something went wrong.