TableLaporan.js 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. import Datatable from "@/components/Tables/Datatable";
  2. import { Button } from "reactstrap";
  3. import Link from "next/link";
  4. import moment from "moment";
  5. function TableLaporan({ listData, to, linkName }) {
  6. return (
  7. <div className="card b">
  8. <div className="card-body">
  9. {listData && (
  10. <Datatable options={{ responsive: false }}>
  11. <table className="table w-100" data-order='[[2, "asc"], [3, "desc"]]'>
  12. <thead>
  13. <tr>
  14. <th>No.Laporan</th>
  15. <th>Deskripsi Laporan</th>
  16. <th>Status</th>
  17. <th>Created</th>
  18. <th></th>
  19. </tr>
  20. </thead>
  21. <tbody>
  22. {listData.map((data) => {
  23. return (
  24. <tr key={data._id}>
  25. <td>{data.no_laporan}</td>
  26. <td className="text-nowrap">
  27. <div className="media align-items-center">
  28. <div className="media-body d-flex">
  29. <div>
  30. <h4 className="m-0">{data.pt.nama}</h4>
  31. <p>{data.keterangan.length > 35 ? data.keterangan.substring(0, 35) + "..." : data.keterangan}</p>
  32. </div>
  33. </div>
  34. </div>
  35. </td>
  36. <td>
  37. {/* {data.level == 3 ? <div className="badge badge-success">Tinggi</div> : data.level == 2 ? <div className="badge badge-info">Sedang</div> : <div className="badge badge-warning">Rendah</div>} */}
  38. {data.evaluasi?.length ? <div className="badge badge-info">Sudah diperiksa</div> : <div className="badge badge-danger">Belum diperiksa</div>}
  39. </td>
  40. {/* <td>{moment(data.createdAt).fromNow()}</td> */}
  41. <td>{moment(data.createdAt).format("MM-DD-YYYY")}</td>
  42. <td>
  43. <div className="ml-auto">
  44. <Link
  45. href={{
  46. pathname: to,
  47. query: { id: data._id },
  48. }}
  49. >
  50. <Button color="primary" size="sm">
  51. {linkName}
  52. </Button>
  53. </Link>
  54. </div>
  55. </td>
  56. </tr>
  57. );
  58. })}
  59. </tbody>
  60. </table>
  61. </Datatable>
  62. )}
  63. </div>
  64. </div>
  65. );
  66. }
  67. export default TableLaporan;