Usage
Simple
The Spreadsheet component requires the data
property: an array of arrays with objects that have the value
key. Changes made in the Spreadsheet will not affect the passed data array as in React props values should not be mutated.
If the data
prop value is changed the component will discard any changes made by the user. If you want to make changes to data
and incorporate the user's changes see Controlled.
import Spreadsheet from "react-spreadsheet";
const App = () => {
const data = [
[{ value: "Vanilla" }, { value: "Chocolate" }],
[{ value: "Strawberry" }, { value: "Cookies" }],
];
return <Spreadsheet data={data} />;
};
Custom Columns and Rows
The Spreadsheet component accepts the columnLabels
or rowLabels
props, both of which accept arrays. If no columnLabels
are supplied, alphabetical labels are used, and row index labels are used if no rowLabels
are passed.
import Spreadsheet from "react-spreadsheet";
const App = () => {
const columnLabels = ["Flavour", "Food"];
const rowLabels = ["Item 1", "Item 2"];
const data = [
[{ value: "Vanilla" }, { value: "Chocolate" }],
[{ value: "Strawberry" }, { value: "Cookies" }],
];
return (
<Spreadsheet
data={data}
columnLabels={columnLabels}
rowLabels={rowLabels}
/>
);
};
Readonly Cells
Any particular Spreadsheet cell can be set to read-only by just specifying readOnly: true
in the cell along with the value.
import Spreadsheet from "react-spreadsheet";
const App = () => {
const data = [
[{ value: "Vanilla" }, { value: "Chocolate", readOnly: true }],
[{ value: "Strawberry" }, { value: "Cookies", readOnly: true }],
];
return <Spreadsheet data={data} />;
};
Controlled
The Spreadsheet component accepts the onChange
prop that is called every time one of the Spreadsheet's cells is changed by the user. You can use it to save the modified data and to react to changes (e.g. validating the modified data, further modifying it, persisting it).
JavaScript (See TypeScript example below):
import { useState } from "react";
import Spreadsheet from "react-spreadsheet";
const App = () => {
const [data, setData] = useState([
[{ value: "Vanilla" }, { value: "Chocolate" }, { value: "" }],
[{ value: "Strawberry" }, { value: "Cookies" }, { value: "" }],
]);
return <Spreadsheet data={data} onChange={setData} />;
};
TypeScript:
import { useState } from "react";
import Spreadsheet from "react-spreadsheet";
const App = () => {
const [data, setData] = useState<Matrix<CellBase>>([
[{ value: "Vanilla" }, { value: "Chocolate" }, { value: "" }],
[{ value: "Strawberry" }, { value: "Cookies" }, { value: "" }],
]);
return <Spreadsheet data={data} onChange={setData} />;
};