TableLaporan.js 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  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 card-over">
  9. {listData && (
  10. <Datatable options={{ responsive: false, ordering: true }}>
  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>
  26. <div className="media align-items-center">
  27. <div className="media-body d-flex">
  28. <div>
  29. <h4>{data.laporan?.no_laporan || data.no_laporan}</h4>
  30. <p>{moment(data.createdAt).format("MM-DD-YYYY")}</p>
  31. </div>
  32. </div>
  33. </div>
  34. </td>
  35. <td>
  36. <div className="table-desc">
  37. <div className="media align-items-center">
  38. <div className="media-body d-flex">
  39. <div>
  40. <h4 className="m-0">{data.pt?.nama.length > 64 || data.laporan?.pt.nama.length > 64 ? data.pt?.nama.substring(0, 64) + "..." || data.laporan?.pt.nama.substring(0, 64) + "..." : data.pt?.nama || data.laporan?.pt.nama}</h4>
  41. <p className="w-105">{data.keterangan}</p>
  42. </div>
  43. </div>
  44. </div>
  45. </div>
  46. </td>
  47. <td>
  48. {data.aktif === false ? <div className="badge badge-green">Selesai</div> : <div className="badge badge-red">Ditutup</div>}
  49. </td>
  50. <td>
  51. <div className="ml-auto">
  52. <Link
  53. href={{
  54. pathname: to,
  55. query: { id: data._id },
  56. }}
  57. >
  58. <Button className="btn-login loader" color>
  59. <span className="font-color-white">
  60. {linkName}
  61. </span>
  62. </Button>
  63. </Link>
  64. </div>
  65. </td>
  66. </tr>
  67. );
  68. })}
  69. </tbody>
  70. </table>
  71. </Datatable>
  72. )}
  73. </div>
  74. </div >
  75. );
  76. }
  77. export default TableLaporan;