mirror of
https://github.com/gosticks/react-table.git
synced 2025-10-16 11:55:36 +00:00
103 lines
2.1 KiB
JavaScript
103 lines
2.1 KiB
JavaScript
import React from 'react'
|
|
|
|
import 'bootstrap/dist/css/bootstrap.min.css';
|
|
|
|
import BTable from 'react-bootstrap/Table';
|
|
|
|
import { useTable } from 'react-table'
|
|
|
|
import makeData from './makeData'
|
|
|
|
function Table({ columns, data }) {
|
|
// Use the state and functions returned from useTable to build your UI
|
|
const { getTableProps, headerGroups, rows, prepareRow } = useTable({
|
|
columns,
|
|
data,
|
|
})
|
|
|
|
// Render the UI for your table
|
|
return (
|
|
<BTable striped bordered hover size="sm" {...getTableProps()}>
|
|
<thead>
|
|
{headerGroups.map(headerGroup => (
|
|
<tr {...headerGroup.getHeaderGroupProps()}>
|
|
{headerGroup.headers.map(column => (
|
|
<th {...column.getHeaderProps()}>
|
|
{column.render('Header')}
|
|
</th>
|
|
))}
|
|
</tr>
|
|
))}
|
|
</thead>
|
|
<tbody>
|
|
{rows.map((row, i) => {
|
|
prepareRow(row)
|
|
return (
|
|
<tr {...row.getRowProps()}>
|
|
{row.cells.map(cell => {
|
|
return (
|
|
<th {...cell.getCellProps()}>
|
|
{cell.render('Cell')}
|
|
</th>
|
|
)
|
|
})}
|
|
</tr>
|
|
)
|
|
})}
|
|
</tbody>
|
|
</BTable>
|
|
)
|
|
}
|
|
|
|
function App() {
|
|
const columns = React.useMemo(
|
|
() => [
|
|
{
|
|
Header: 'Name',
|
|
columns: [
|
|
{
|
|
Header: 'First Name',
|
|
accessor: 'firstName',
|
|
},
|
|
{
|
|
Header: 'Last Name',
|
|
accessor: 'lastName',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
Header: 'Info',
|
|
columns: [
|
|
{
|
|
Header: 'Age',
|
|
accessor: 'age',
|
|
},
|
|
{
|
|
Header: 'Visits',
|
|
accessor: 'visits',
|
|
},
|
|
{
|
|
Header: 'Status',
|
|
accessor: 'status',
|
|
},
|
|
{
|
|
Header: 'Profile Progress',
|
|
accessor: 'progress',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
[]
|
|
)
|
|
|
|
const data = React.useMemo(() => makeData(20), [])
|
|
|
|
return (
|
|
<div>
|
|
<Table columns={columns} data={data} />
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default App
|