Skip to main content

Columns

Columns are simple objects and can be declared as such:

const columns = [
{ title: 'A', id: 'a', /*...*/ },
{ title: 'B', id: 'b', /*...*/ },
]

title

Type: JSX.Element
Default: null

Element to display in the header row.

id

Type: string
Default: undefined

You can specify a unique ID for each column. This allows you to specify the column ID instead of its index when controlling the grid.

Sizing

width

Type: string | number
Default: 1

Width of the column, supports the same values as the CSS flex property.

Fixed sized columns

const column = { width: '0 0 100px' }

'0 0 <width>px' for fixed width of <width> pixels. This syntaxe is the same than the shorthand property of flex and is equivalent to:

flex-grow: 0;
flex-shrink: 0;
flex-basis: <width>px;

Relative sized columns

const columns = [
{ width: 1 },
{ width: 1 },
{ width: 2 }, // 👈 This column will grow and shrink like the others but will be twice as large
]

<number> for responsive columns. This is equivalent to:

flex-grow: <number>;
flex-shrink: <number>;
flex-basis: 0;

minWidth

Type: number
Default: 100

Minimum width of the column in pixels. Can be 0 for no minimum value.

maxWidth

Type: number | null
Default: null

Maximum width of the column in pixels. Can be null for no maximum value.

Copy pasting

copyValue

Type: ({ rowData, rowIndex }) => number | string | null

A function that returns the value of the copied cell. If the user copies multiple cells at once, this function will be called multiple times. It can return a string, a number, or null, but it will always be turned into a string in the end.

pasteValue

Type: ({ rowData, value, rowIndex }) => any

A function that takes in a row and the value to be pasted, and should return the updated row. If the value should be ignored, it should still return the unchanged row. The value is always a string, except if prePasteValues returns something else, and should therefore be casted to whatever type is needed.

It is recommended to make sure that the pasteValue can handle all values returned by copyValue otherwise a user might be able to copy something but not paste it.

prePasteValues

Type: (values: string[]) => any[] | Promise<any[]>

This function is called right before pasteValue with all the data that the user is trying to paste for that column. This gives you the opportunity to treat the pasted data as a whole and change it before passing it to pasteValue.

This is where you would do some asynchronous work (eg. mapping names to actual IDs) and return a Promise.

deleteValue

Type: ({ rowData, rowIndex }) => any

A function that deletes the column value of a row. Used when the user cuts, clears a cell, or deletes a row.

Rendering

component

Type: Component

A react component that renders a cell. See props

columnData

Type: any

A value to pass to every cell component of the column through the columnData prop. Usually used to hold some kind of options for the column.

For example, to implement a select column you would use columnData to pass the choices:

const SelectComponent = ({ columnData: choices }) => {
// Render cell using `choices`
}

const selectColumn = (choices) => ({
columnData: choices,
component: SelectComponent,
})

function App() {
return <DataSheetGrid columns={[
{ ...selectColumn(['Light', 'Dark']), title: 'Theme' }
]} />
}

headerClassName

Type: string
Default: undefined

CSS class of the header cell.

cellClassName

Type: string | (({ rowData, rowIndex }) => string | undefined)
Default: undefined

CSS class of each cell of the column. Can be a string if the class is the same for all cells, or a function if you need a different class per row.

Options

disabled

Type: boolean | (({ rowData, rowIndex }) => boolean)
Default: false

Disable the entire column by passing true, or disable it for specific rows by passing a function. Disabled cells cannot be edited but their values can still be copied.

Try toggling the "active" column:

Active
First name
Last name
1
2
3
4
5
rows
<DataSheetGrid
columns={[
{ title: 'Active', /*...*/ },
{ title: 'First name', disabled: ({ rowData }) => !rowData.active, /*...*/ },
{ title: 'Last name', disabled: true, /*...*/ },
]}
/>
note

Notice that in this example you cannot delete a row using the Del key, this is because you can only delete empty rows. This might be problematic depending on your use-case, to solve this issue you can use isCellEmpty and always return true to ignore this column.

renderWhenScrolling

Type: boolean
Default: true

When set to false, the column waits for the scroll to stop to render new cells. More details about performance.

disableKeys

Type: boolean
Default: false

Usually when the user is editing a cell, pressing the up, down, or return key will exit editing mode. Setting disableKeys to true will prevent this behavior. This is used when the widget needs to handle the up and down keys itself (eg. to increase the value, or select a choice). Usually the widget also needs to handle the return key by calling stopEditing.

keepFocus

Type: boolean
Default: false

When you implement a widget using a portal (ie. a div that is not a direct children of the cell) you might want the cell to keep focus when the user interacts with that element (even tho it is actually outside of the grid itself). This means that you have to handle the click event and call stopEditing yourself to release focus.

Behavior

isCellEmpty

Type: ({ rowData, rowIndex }) => boolean
Default: () => false

When pressing Del, a user can only delete empty rows (a user can still delete non-empty rows using a right-click). A row is considered empty when all its cells are empty. This function allows to customize what is considered an empty cell.

Because the default value is a function that always returns false (meaning the cell is never considered empty), you must implement your own logic to let the user delete rows using the Del key.