sanksi.controller.js 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  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. const ip = require('ip')
  16. const osValue = require('../utils/osValue')
  17. exports.create = handleError(async (req, res) => {
  18. const { no_sanksi, keterangan, from_date, to_date } = req.body
  19. let { pelanggaran_id } = req.body
  20. const { laporan_id } = req.params
  21. const files = req.files
  22. const user = req.user
  23. const isValid = validate(res, req.body, {
  24. no_sanksi: 'string',
  25. keterangan: 'string',
  26. pelanggaran_id: 'string',
  27. from_date: 'string',
  28. to_date: 'string',
  29. })
  30. if (!isValid) return
  31. const laporan = await cekSatuDataLaporan(res, user, laporan_id, {
  32. evaluasi: { $exists: true, $ne: [] },
  33. })
  34. if (!laporan) return
  35. pelanggaran_id = await cekBanyakDataPelanggaran(res, pelanggaran_id)
  36. if (!pelanggaran_id) return
  37. const sanksi = await sanksiModel.findOne({ laporan: laporan_id })
  38. if (sanksi) {
  39. return response.error(res, {
  40. message: 'Sanksi sudah ada',
  41. })
  42. }
  43. if (!files.length) {
  44. return response.error(res, {
  45. message: 'dokumen harus ada',
  46. })
  47. }
  48. const dokumen = await addManyDokumen(files)
  49. const dokumen_id = dokumen.map((e) => e._id)
  50. const data = await sanksiModel.create({
  51. no_sanksi,
  52. laporan: laporan._id,
  53. user: user._id,
  54. pelanggaran: pelanggaran_id,
  55. keterangan,
  56. dokumen: dokumen_id,
  57. masa_berlaku: {
  58. from_date,
  59. to_date,
  60. },
  61. batas_waktu: {
  62. keberatan: hariKerja(10),
  63. },
  64. })
  65. await laporanModel.findByIdAndUpdate(laporan._id, { sanksi: data._id })
  66. await pemantauanModel.create({
  67. laporan: laporan._id,
  68. sanksi: data._id,
  69. action: 'CREATE SANKSI',
  70. pt_id: laporan.pt.id,
  71. user: user._id,
  72. keterangan: 'Melakukan penetapan Sanksi',
  73. dokumen: dokumen_id,
  74. })
  75. return response.success(res, {
  76. message: 'Berhasil membuat Sanksi',
  77. data,
  78. })
  79. })
  80. exports.getAll = handleError(async (req, res) => {
  81. const user = req.user
  82. const {
  83. keberatan,
  84. jawaban,
  85. banding,
  86. cabutSanksi,
  87. perbaikan,
  88. aktif,
  89. delegasi,
  90. } = req.query
  91. const where = {}
  92. if (aktif && aktif === 'false') {
  93. where.aktif = false
  94. }
  95. if (keberatan === 'true') {
  96. where['pengajuan.keberatan'] = { $exists: true, $ne: null }
  97. if (jawaban === 'true') {
  98. where['jawaban.keberatan'] = { $exists: true, $ne: null }
  99. }
  100. } else if (banding === 'true') {
  101. where.banding = true
  102. where['pengajuan.keberatan'] = { $exists: true, $ne: null }
  103. where['jawaban.keberatan'] = { $exists: true, $ne: null }
  104. where['pengajuan.banding'] = { $exists: true, $ne: null }
  105. if (jawaban === 'true') {
  106. where['jawaban.banding'] = { $exists: true, $ne: null }
  107. }
  108. } else if (cabutSanksi === 'true') {
  109. where.perbaikan = { $exists: true, $ne: [] }
  110. if (jawaban === 'true') {
  111. where['pengajuan.cabut_sanksi'] = { $exists: true, $ne: null }
  112. // where['jawaban.cabut_sanksi'] = { $exists: true, $ne: null }
  113. }
  114. } else if (perbaikan === 'true') {
  115. where['jawaban.banding'] = { $exists: true, $ne: null }
  116. } else if (delegasi === 'true') {
  117. where.delegasi = true
  118. }
  119. const data = await cekBanyakDataSanksi(user, where)
  120. return response.success(res, {
  121. message: 'Berhasil ambil data Sanksi',
  122. data,
  123. })
  124. })
  125. exports.getOne = handleError(async (req, res) => {
  126. const user = req.user
  127. const { sanksi_id } = req.params
  128. const w = {}
  129. const { banding, aktif, delegasi, all } = req.query
  130. if (banding === 'true') {
  131. w.banding = true
  132. w['pengajuan.keberatan'] = { $exists: true, $ne: null }
  133. w['jawaban.keberatan'] = { $exists: true, $ne: null }
  134. w['pengajuan.banding'] = { $exists: true, $ne: null }
  135. }
  136. if (delegasi === 'true') {
  137. w.delegasi = true
  138. }
  139. if (all === 'true') {
  140. w.all = true
  141. }
  142. if (aktif && aktif === 'false') {
  143. w.aktif = false
  144. }
  145. const sanksi = await cekSatuDataSanksi(res, user, sanksi_id, w)
  146. if (!sanksi) return
  147. return response.success(res, {
  148. message: 'Berhasil ambil satu data Sanksi',
  149. data: sanksi,
  150. })
  151. })
  152. exports.editTmt = handleError(async (req, res) => {
  153. const user = req.user
  154. const { id } = req.params
  155. const { from_date, to_date } = req.body
  156. const files = req.files
  157. const sanksi = await cekSatuDataSanksi(res, user, id)
  158. if (!sanksi) return
  159. const isValid = validate(res, req.body, {
  160. from_date: { type: 'date', convert: true },
  161. to_date: { type: 'date', convert: true },
  162. })
  163. if (!isValid) return
  164. if (!files.length) {
  165. return response.error(res, {
  166. message: 'dokumen harus ada',
  167. })
  168. }
  169. const dokumen = await addManyDokumen(files)
  170. const dokumen_id = dokumen.map((e) => e._id)
  171. const data = await sanksiModel.findByIdAndUpdate(sanksi._id, {
  172. masa_berlaku: {
  173. from_date,
  174. to_date,
  175. },
  176. 'pengajuan.update_tmt': { dokumen: dokumen_id },
  177. })
  178. await pemantauanModel.create({
  179. laporan: sanksi.laporan._id,
  180. user: user._id,
  181. action: 'EDIT TMT',
  182. pt_id: sanksi.laporan.pt.id,
  183. keterangan: 'Mengubah masa berlaku sanksi',
  184. for_public: true,
  185. })
  186. return response.success(res, {
  187. message: 'Berhasil update tmt',
  188. data,
  189. })
  190. })