[Table][m]: Add simple table component for first test
This commit is contained in:
parent
6ead0c9ca2
commit
d1aa1f3d5e
28
packages/portal/src/components/explorer/Table/index.js
Normal file
28
packages/portal/src/components/explorer/Table/index.js
Normal file
@ -0,0 +1,28 @@
|
||||
/* eslint-disable max-len */
|
||||
import React from 'react';
|
||||
import { DataGrid } from '@material-ui/data-grid';
|
||||
|
||||
/*
|
||||
* @param schema: Frictionless Table Schmea
|
||||
* @param data: an array of data objects e.g. [ {a: 1, b: 2}, {a: 5, b: 7} ]
|
||||
*/
|
||||
export const Table = ({ schema, data }) => {
|
||||
const columns = schema.fields.map((field) => (
|
||||
{
|
||||
field: field.title || field.name,
|
||||
headerName: field.name,
|
||||
width: 300
|
||||
}
|
||||
))
|
||||
data = data.map((item, index)=>{
|
||||
item.id = index //Datagrid requires every row to have an ID
|
||||
return item
|
||||
})
|
||||
|
||||
return (
|
||||
<div data-testid="tableGrid" style={{ height: 400, width: '100%' }}>
|
||||
<DataGrid rows={data} columns={columns} pageSize={5} />
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
0
packages/portal/src/components/page/index.js
Normal file
0
packages/portal/src/components/page/index.js
Normal file
0
packages/portal/src/components/ui/index.js
Normal file
0
packages/portal/src/components/ui/index.js
Normal file
3
packages/portal/src/index.js
Normal file
3
packages/portal/src/index.js
Normal file
@ -0,0 +1,3 @@
|
||||
import { Table } from './components/explorer/Table/index'
|
||||
|
||||
export { Table }
|
||||
Loading…
x
Reference in New Issue
Block a user