sanksi.controller.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. const sanksiModel = require('../model/sanksi.model')
  2. const handleError = require('../utils/handleError')
  3. const response = require('../utils/responseHandler')
  4. const { addManyDokumen } = require('../utils/dokumenFunction')
  5. const { validate } = require('../utils/validation')
  6. const pemantauanModel = require('../model/pemantauan.model')
  7. const { hariKerja } = require('../utils/hariKerja')
  8. const {
  9. cekSatuDataSanksi,
  10. cekSatuDataLaporan,
  11. cekBanyakDataPelanggaran,
  12. cekBanyakDataSanksi,
  13. } = require('../utils/cekData')
  14. const laporanModel = require('../model/laporan.model')
  15. exports.create = handleError(async (req, res) => {
  16. const { no_sanksi, keterangan } = req.body
  17. let { pelanggaran_id } = req.body
  18. const { laporan_id } = req.params
  19. const files = req.files
  20. const user = req.user
  21. const isValid = validate(res, req.body, {
  22. no_sanksi: 'string',
  23. keterangan: 'string',
  24. pelanggaran_id: 'string',
  25. })
  26. if (!isValid) return
  27. const laporan = await cekSatuDataLaporan(res, user, laporan_id, {
  28. evaluasi: { $exists: true, $ne: [] },
  29. })
  30. if (!laporan) return
  31. pelanggaran_id = await cekBanyakDataPelanggaran(res, pelanggaran_id)
  32. if (!pelanggaran_id) return
  33. const sanksi = await sanksiModel.findOne({ laporan: laporan_id })
  34. if (sanksi) {
  35. return response.error(res, {
  36. message: 'Sanksi sudah ada',
  37. })
  38. }
  39. if (!files.length) {
  40. return response.error(res, {
  41. message: 'dokumen harus ada',
  42. })
  43. }
  44. const dokumen = await addManyDokumen(files)
  45. const dokumen_id = dokumen.map((e) => e._id)
  46. const data = await sanksiModel.create({
  47. no_sanksi,
  48. laporan: laporan._id,
  49. user: user._id,
  50. pelanggaran: pelanggaran_id,
  51. keterangan,
  52. dokumen: dokumen_id,
  53. batas_waktu: {
  54. keberatan: hariKerja(10),
  55. },
  56. })
  57. await laporanModel.findByIdAndUpdate(laporan._id, { sanksi: data._id })
  58. await pemantauanModel.create({
  59. laporan: laporan._id,
  60. sanksi: data._id,
  61. pt_id: laporan.pt.id,
  62. user: user._id,
  63. keterangan: 'Melakukan penetapan Sanksi',
  64. dokumen: dokumen_id,
  65. })
  66. return response.success(res, {
  67. message: 'Berhasil membuat Sanksi',
  68. data,
  69. })
  70. })
  71. exports.getAll = handleError(async (req, res) => {
  72. const user = req.user
  73. const { keberatan, jawaban, banding, cabutSanksi, perbaikan } = req.query
  74. const where = {}
  75. if (keberatan === 'true') {
  76. where['pengajuan.keberatan'] = { $exists: true, $ne: null }
  77. if (jawaban === 'true') {
  78. where['jawaban.keberatan'] = { $exists: true, $ne: null }
  79. }
  80. } else if (banding === 'true') {
  81. where.banding = true
  82. where['pengajuan.keberatan'] = { $exists: true, $ne: null }
  83. where['jawaban.keberatan'] = { $exists: true, $ne: null }
  84. where['pengajuan.banding'] = { $exists: true, $ne: null }
  85. if (jawaban === 'true') {
  86. where['jawaban.banding'] = { $exists: true, $ne: null }
  87. }
  88. } else if (cabutSanksi === 'true') {
  89. where['pengajuan.cabut_sanksi'] = { $exists: true, $ne: null }
  90. if (jawaban === 'true') {
  91. where['jawaban.cabut_sanksi'] = { $exists: true, $ne: null }
  92. }
  93. } else if (perbaikan === 'true') {
  94. where.$or = [
  95. { 'jawaban.cabut_sanksi': { $exists: true, $ne: null } },
  96. { 'jawaban.banding': { $exists: true, $ne: null } },
  97. ]
  98. }
  99. const data = await cekBanyakDataSanksi(user, where)
  100. return response.success(res, {
  101. message: 'Berhasil ambil data Sanksi',
  102. data,
  103. })
  104. })
  105. exports.getOne = handleError(async (req, res) => {
  106. const user = req.user
  107. const { sanksi_id } = req.params
  108. const w = {}
  109. const { banding } = req.query
  110. if (banding === 'true') {
  111. w.banding = true
  112. w['pengajuan.keberatan'] = { $exists: true, $ne: null }
  113. w['jawaban.keberatan'] = { $exists: true, $ne: null }
  114. w['pengajuan.banding'] = { $exists: true, $ne: null }
  115. }
  116. const sanksi = await cekSatuDataSanksi(res, user, sanksi_id, w)
  117. if (!sanksi) return
  118. return response.success(res, {
  119. message: 'Berhasil ambil satu data Sanksi',
  120. data: sanksi,
  121. })
  122. })