Skip to content

Commit

Permalink
chore: split column and row pinning (#5402)
Browse files Browse the repository at this point in the history
  • Loading branch information
KevinVandy authored Mar 10, 2024
1 parent 16d16dd commit ea4d40a
Show file tree
Hide file tree
Showing 13 changed files with 706 additions and 643 deletions.
266 changes: 266 additions & 0 deletions docs/api/features/column-pinning.md
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.
Loading

0 comments on commit ea4d40a

Please sign in to comment.