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:
<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.