Add dynamically info to lookup property in material-table component
I found the way, it using Reduce, and it work perfectly: supposing that you have this array of object:
const dinamicObject = [
{ id: 4, name: "name" },
{ id: 2, name: "Mehmet" },
{ id: 3, name: "middle" }
];
var obj = dinamicObject.reduce(function(acc, cur, i) {
acc[cur.id] = cur.name;
return acc;
}, {});
And then you assign that to your lookup property in Material-Table component
Check this for more clarification https://codesandbox.io/s/vq2lj0krkl
I hope this help to others
Best regards
Create an object outside of the table.
import React from "react";
import ReactDOM from "react-dom";
import MaterialTable from "material-table";
import FilterList from "@material-ui/icons/FilterList";
import Clear from "@material-ui/icons/Clear";
import "./styles.css";
function App() {
const dynamicLookupObject = { 34: "test1", 63: "test2" }
// TODO: const createDynamicObject = () => {
// change object
// return dynamicLookupObject
})
return (
<div className="App">
<MaterialTable
icons={{
Filter: () => <FilterList />,
ResetSearch: () => <Clear />
}}
columns={[
{ title: "Name", field: "name", defaultFilter: "Meh" },
{ title: "Surname", field: "surname" },
{ title: "Birth Year", field: "birthYear", type: "numeric" },
{
title: "Birth Place",
field: "birthCity",
lookup: dynamicLookupObject,
defaultFilter: ["63"], // For numeric,
emptyValue: () => <div>"dfsdf"</div>
}
]}
data={[
{ name: "Mehmet", surname: "Baran", birthYear: null, birthCity: 63 },
{
name: "Zerya Betül",
surname: "Baran",
birthYear: 2017,
birthCity: 34
}
]}
title="Filtering Example"
options={{
filtering: true,
maxBodyHeight: 300,
rowStyle: data =>
data.surname === "Baran"
? { background: "red" }
: { background: "green" }
}}
/>
</div>
);
}
const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);