React Table Typescript "Type is not assignable"
I've set up my React project with Typescript and React-Table. I was following the Quick Start Guide from the React-Table website and got an error.
const data = React.useMemo(
() => [
{
col1: 'Hello',
col2: 'World',
},
{
col1: 'react-table',
col2: 'rocks',
},
{
col1: 'whatever',
col2: 'you want',
},
],
[]
)
const columns = React.useMemo(
() => [
{
Header: 'Column 1',
accessor: 'col1', // accessor is the "key" in the data
},
{
Header: 'Column 2',
accessor: 'col2',
},
],
[]
)
I get an error when doing const tableInstance = useTable({ columns, data })
.
Type '{ Header: string; accessor: string; }[]' is not assignable to type 'readonly Column<{ col1: string; col2: string; }>[]'. Type '{ Header: string; accessor: string; }' is not assignable to type 'Column<{ col1: string; col2: string; }>'.
I barely just started getting into this so I don't really know what's going on. Here is a code sandbox with a recreation of the problem: Sandbox
Solution 1:
Seems that TypeScript fails with type inference, so I gave him the hint by
- Introducing new type
type Cols = { col1: string; col2: string };
- Explicitly stating type for
const columns: Column<Cols>[] = ...
Full working example is here:
import { useTable, TableOptions, Column } from "react-table";
import React from "react";
type Cols = { col1: string; col2: string };
export default function App() {
const data = React.useMemo(
(): Cols[] => [
{
col1: "Hello",
col2: "World"
},
{
col1: "react-table",
col2: "rocks"
},
{
col1: "whatever",
col2: "you want"
}
],
[]
);
const columns: Column<{ col1: string; col2: string }>[] = React.useMemo(
() => [
{
Header: "Column 1",
accessor: "col1" // accessor is the "key" in the data
},
{
Header: "Column 2",
accessor: "col2"
}
],
[]
);
const options: TableOptions<{ col1: string; col2: string }> = {
data,
columns
};
const {
getTableProps,
getTableBodyProps,
headerGroups,
rows,
prepareRow
} = useTable(options);
return (
<table {...getTableProps()} style={{ border: "solid 1px blue" }}>
<thead>
{headerGroups.map((headerGroup) => (
<tr {...headerGroup.getHeaderGroupProps()}>
{headerGroup.headers.map((column) => (
<th
{...column.getHeaderProps()}
style={{
borderBottom: "solid 3px red",
background: "aliceblue",
color: "black",
fontWeight: "bold"
}}
>
{column.render("Header")}
</th>
))}
</tr>
))}
</thead>
<tbody {...getTableBodyProps()}>
{rows.map((row) => {
prepareRow(row);
return (
<tr {...row.getRowProps()}>
{row.cells.map((cell) => {
return (
<td
{...cell.getCellProps()}
style={{
padding: "10px",
border: "solid 1px gray",
background: "papayawhip"
}}
>
{cell.render("Cell")}
</td>
);
})}
</tr>
);
})}
</tbody>
</table>
);
}