How to use Excel-like editing in your DataGrid
By adminยท
Excel-like editing is a very popular request we had. In this short article, we show you how to configure Excel-like editing in the Infinite React DataGrid.
Click a cell and start typing
This behavior is achieved by using the Instant Edit keyboard shorcut.
Configuring keyboard shortcuts#
import { DataSource, InfiniteTable, keyboardShortcuts } from '@infinite-table/infinite-react'; function App() { return <DataSource<Developer> primaryKey="id" data={dataSource}> <InfiniteTable<Developer> columns={columns} keyboardShortcuts={[ keyboardShortcuts.instantEdit ]} /> </DataSource> }
COPY
The
instantEdit
keyboard shorcut is configured (by default) to respond to any key (via the special *
identifier which matches anything) and will start editing the cell as soon as a key is pressed. This behavior is the same as in Excel, Google Sheets, Numbers or other spreadsheet software.To enable editing globally, you can use the
columnDefaultEditable
boolean prop on the InfiniteTable
DataGrid component. This will make all columns editable.Or you can be more specific and choose to make individual columns editable via the
column.defaultEditable
prop. This overrides the global columnDefaultEditable
.Column Editors
Read about how you can configure various editors for your columns.
Editing Flow Chart
A picture is worth a thousand words - see a chart for the editing flow.
Finishing an Edit#
An edit is generally finished by user interaction - either the user confirms the edit by pressing the
Enter
key or cancels it by pressing the Escape
key.As soon as the edit is confirmed by the user,
InfiniteTable
needs to decide whether the edit should be accepted or not.In order to decide (either synchronously or asynchronously) whether an edit should be accepted or not, you can use the global
shouldAcceptEdit
prop or the column-level column.shouldAcceptEdit
alternative.When neither the global
shouldAcceptEdit
nor the column-level column.shouldAcceptEdit
are defined, all edits are accepted by default.Once an edit is accepted, the
onEditAccepted
callback prop is called, if defined.When an edit is rejected, the
onEditRejected
callback prop is called instead.The accept/reject status of an edit is decided by using the
shouldAcceptEdit
props described above. However an edit can also be cancelled by the user pressing the Escape
key in the cell editor - to be notified of this, use the onEditCancelled
callback prop.Using shouldAcceptEdit to decide whether a value is acceptable or not
In this example, the
salary
column is configured with a shouldAcceptEdit
function property that rejects non-numeric values.Persisting an Edit#
By default, accepted edits are persisted to the
DataSource
via the DataSourceAPI.updateData
method.To change how you persist values (which might include persisting to remote locations), use the
persistEdit
function prop on the InfiniteTable
component.The
persistEdit
function prop can return a Promise
for async persistence. To signal that the persisting failed, reject the promise or resolve it with an Error
object.After persisting the edit, if all went well, the
onEditPersistSuccess
callback prop is called. If the persisting failed (was rejected), the onEditPersistError
callback prop is called instead.