Search code examples
javascriptreactjsmappingmaterial-table

Mapping Data with Material-table Reactjs


I have some problem with mapping data with material-table with Reactjs. When I click Button "Xet Duyet" it will pass data from Checkdoc to Checkdetail. Following my research, I using router params but I dont know how to pass data with Material-table

<Route path="/checkdetail/:id" component={Checkdetail} />

Checkdoc.js

import React from 'react';
import MaterialTable from 'material-table';
import {Button} from '@material-ui/core/';
import { useHistory } from "react-router-dom";
import db from "./db.json";

export default function CheckDoc() {

  const [state, setState] = React.useState({
    columns: [
      { title: 'Ngày nộp đơn', field: 'date' },
      { title: 'Tên Văn bản', field: 'namedoc' },
      { title: 'Người nộp', field: 'nameapplier'},
    ],

  });

  console.log(db);

  const history = useHistory();
  const routeChange = () => history.push("/checkdetail");

  const { useState } = React; 
  const [selectedRow, setSelectedRow] = useState(null);

  return (
    <MaterialTable

     // format some options
     options={{
      search: true,


      rowStyle: rowData => ({
        backgroundColor: (selectedRow === rowData.tableData.id) ? '#C2D6EE' : '#FFF'
      }),

      headerStyle: {
        backgroundColor: 'default ',
        color: '#111'
      },    

      actionsColumnIndex: -1,    

    }}

    localization={{        
      header: {
          actions: 'Trạng Thái',

      },  

      toolbar:{
        searchTooltip: 'Search',
        searchPlaceholder: 'Tìm kiếm...',
      }
  }}
 // Button checked
  actions={[
    {
      icon: 'save',
      tooltip: 'Save User',
    }
  ]}

  components={{
    Action: props => (
      <Button
        color="secondary"
        variant="contained"
        style={{maxWidth: '75px', maxHeight: '50px' }}
        size="small"
        onClick={routeChange}
      >
        Xét duyệt
      </Button>
    ),
  }}

      title="Xét duyệt"
      columns={state.columns}
      data={db}
      key={db.id}

    />
  );
}

DB.js

[   
    { "id": 1, "date": "20/2/02/2020", "namedoc": "Báo Cáo", "nameapplier": "Trinh Huynh" },
    { "id": 2,"date": "20/2/02/2020", "namedoc": "Báo Cáo 1", "nameapplier": "Hứa Thư" },
    { "id": 3,"date": "20/2/02/2020", "namedoc": "Báo Cáo 2", "nameapplier": "Văn Kiệt" },
    { "id": 4,"date": "20/2/02/2020", "namedoc": "Báo Cáo 3", "nameapplier": "Chiến Thành" },
    { "id": 5,"date": "20/2/02/2020", "namedoc": "Báo Cáo 4", "nameapplier": "Minh Nhựt" },
    { "id": 6,"date": "20/2/02/2020", "namedoc": "Báo Cáo 5", "nameapplier": "Phúc Hậu" }

   ]

Checkdetail.js

import React, { useState, useEffect, useRef } from 'react';

import Button from '@material-ui/core/Button';
import TextField from '@material-ui/core/TextField';
import Dialog from '@material-ui/core/Dialog';
import DialogActions from '@material-ui/core/DialogActions';
import DialogContent from '@material-ui/core/DialogContent';
import DialogContentText from '@material-ui/core/DialogContentText';
import DialogTitle from '@material-ui/core/DialogTitle';

import { usePdf } from 'react-pdf-js';

const Checkdetail = () => {

  const [open, setOpen] = React.useState(false);
  const handleClickOpen = () => {
    setOpen(true);
  };

  const handleClose = () => {
    setOpen(false);
  };

  const [page, setPage] = useState(1);
  const [pages, setPages] = useState(null);

  const renderPagination = (page, pages) => {
    if (!pages) {
      return null;
    }
    let previousButton = <Button className="previous" onClick={() => setPage(page - 1)}><a href="#"><i className="fa fa-arrow-left"></i> Previous</a></Button>;
    if (page === 1) {
      previousButton = <Button className="previous disabled"><a href="#"><i className="fa fa-arrow-left"></i> Previous</a></Button>;
    }
    let nextButton = <Button className="next" onClick={() => setPage(page + 1)}><a href="#">Next <i className="fa fa-arrow-right"></i></a></Button>;
    if (page === pages) {
      nextButton = <Button className="next disabled"><a href="#">Next <i className="fa fa-arrow-right"></i></a></Button>;
    }
    return (
      <nav>
        {previousButton}
        {nextButton}
      </nav>
    );
  }

  const canvasEl = useRef(null);

  const [loading, numPages] = usePdf({
    file: 'Test.pdf',
    page,
    canvasEl
  });

  useEffect(() => {
    setPages(numPages);
  }, [numPages]);

  return (

    <div>
      <div className="container text-right">
        <div className="text-capitalize text-left d-sm-flex justify-content-between align-items-center mb-4" style={{ fontFamily: 'ABeeZee, sans-serif' }}>
          <p>Tên văn bản: Báo Cáo Tổng Kết cuối năm</p>
          <p>Người nộp: Trinh Huỳnh</p>

        </div>

        <div class="center" style={{marginBottom: '15px'}} >
          <Button variant="outlined" color="primary" style={{ maxWidth: '75px', maxHeight: '45px' }} >Duyệt</Button> {' '}
          <Button variant="outlined" color="secondary" style={{ maxWidth: '75px', maxHeight: '45px' }} onClick={handleClickOpen}>Hủy</Button>

        </div>


        <Dialog open={open} onClose={handleClose} aria-labelledby="form-dialog-title">
          <DialogTitle id="form-dialog-title">Ghi chú</DialogTitle>
          <DialogContent>
            <DialogContentText>
              Ghi chú thông tin cần bổ sung để chỉnh sửa hoàn chỉnh
        </DialogContentText>
            <TextField
              autoFocus
              type="email"
              fullWidth
            />
          </DialogContent>
          <DialogActions>
            <Button onClick={handleClose} color="primary">
              Hủy
          </Button>
            <Button onClick={handleClose} color="primary">
              Lưu
          </Button>
          </DialogActions>
        </Dialog>
      </div>

      <form class="center">
        <div>
          {loading && <span>Loading...</span>}
          <canvas ref={canvasEl} />
          {renderPagination(page, pages)}
        </div>
      </form>
    </div>
  );
}

export default Checkdetail;

How to get data from Checkdoc.js to Checkdetail.js. Display the information when I click button "Xét Duyệt"


Solution

  • First, use the Action props to pass the data to your routeChange function, this way:

    components={{
        Action: props => (
          <Button
            color="secondary"
            variant="contained"
            style={{maxWidth: '75px', maxHeight: '50px' }}
            size="small"
            onClick={() => routeChange(props.data)} // change here
          >
            Xét duyệt
          </Button>
        ),
      }}
    

    Now, the routeChange function should receive the data and you can pass it to the CheckDetail:

    const routeChange = data => history.push(`/checkdetail/${data.id}`);
    

    And finally, in your CheckDetail you should be able to see this id like this:

    const Checkdetail = ({ match }) => {
      const { id } = match.params
      const [open, setOpen] = React.useState(false);
    
      ...