sanksi.controller.js 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307
  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, from_date, to_date } = req.body
  17. let { pelanggaran_id } = req.body
  18. const { laporan_id } = req.params
  19. const {dokumen:files, berita_acara} = 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. from_date: 'string',
  26. to_date: 'string',
  27. })
  28. if (!isValid) return
  29. const laporan = await cekSatuDataLaporan(res, user, laporan_id, {
  30. evaluasi: { $exists: true, $ne: [] },
  31. })
  32. if (!laporan) return
  33. pelanggaran_id = await cekBanyakDataPelanggaran(res, pelanggaran_id)
  34. if (!pelanggaran_id) return
  35. const sanksi = await sanksiModel.findOne({ laporan: laporan_id })
  36. if (sanksi) {
  37. return response.error(res, {
  38. message: 'Sanksi sudah ada',
  39. })
  40. }
  41. if (!files) {
  42. return response.error(res, {
  43. message: 'dokumen harus ada',
  44. })
  45. }
  46. let dokumenBeritaAcara_id = null
  47. if (berita_acara) {
  48. const dokumenBeritaAcara = await addManyDokumen(berita_acara)
  49. dokumenBeritaAcara_id = dokumenBeritaAcara[0]
  50. }
  51. const dokumen = await addManyDokumen(files)
  52. const dokumen_id = dokumen.map((e) => e._id)
  53. const data = await sanksiModel.create({
  54. no_sanksi,
  55. laporan: laporan._id,
  56. user: user._id,
  57. pelanggaran: pelanggaran_id,
  58. keterangan,
  59. dokumen: dokumen_id,
  60. berita_acara: dokumenBeritaAcara_id,
  61. masa_berlaku: {
  62. from_date,
  63. to_date,
  64. },
  65. batas_waktu: {
  66. keberatan: hariKerja(10),
  67. },
  68. })
  69. await laporanModel.findByIdAndUpdate(laporan._id, {
  70. sanksi: data._id,
  71. // aktif: false,
  72. })
  73. await pemantauanModel.create({
  74. laporan: laporan._id,
  75. sanksi: data._id,
  76. action: 'CREATE SANKSI',
  77. pt_id: laporan.pt.id,
  78. user: user._id,
  79. keterangan: 'Melakukan penetapan Sanksi',
  80. dokumen: dokumen_id,
  81. })
  82. return response.success(res, {
  83. message: 'Berhasil membuat Sanksi',
  84. data,
  85. })
  86. })
  87. exports.update = handleError(async (req, res) => {
  88. const { no_sanksi, keterangan, from_date, to_date } = req.body
  89. let sanksiBody = req.body.sanksi
  90. const { sanksi_id } = req.params
  91. const files = req.files
  92. const user = req.user
  93. const isValid = validate(res, req.body, {
  94. no_sanksi: 'string',
  95. keterangan: 'string',
  96. sanksi: 'string',
  97. from_date: 'string',
  98. to_date: 'string',
  99. })
  100. if (!isValid) return
  101. const sanksi = await cekSatuDataSanksi(res, user, sanksi_id, { all: true })
  102. if (!sanksi) return
  103. // pelanggaran_id = await cekBanyakDataPelanggaran(res, pelanggaran_id)
  104. // if (!pelanggaran_id) return
  105. sanksiBody = JSON.parse(sanksiBody)
  106. // const sanksi = await sanksiModel.findOne({ laporan: laporan_id })
  107. // if (sanksi) {
  108. // return response.error(res, {
  109. // message: 'Sanksi sudah ada',
  110. // })
  111. // }
  112. if (!files.length) {
  113. return response.error(res, {
  114. message: 'dokumen harus ada',
  115. })
  116. }
  117. const dokumen = await addManyDokumen(files)
  118. const dokumen_id = dokumen.map((e) => e._id)
  119. const data = await sanksiModel.updateOne(
  120. { _id: sanksi._id },
  121. {
  122. no_sanksi,
  123. // pelanggaran: pelanggaran_id,
  124. sanksi: sanksiBody,
  125. keterangan,
  126. dokumen: dokumen_id,
  127. masa_berlaku: {
  128. from_date,
  129. to_date,
  130. },
  131. $push: {
  132. riwayat_sanksi: sanksi,
  133. },
  134. }
  135. )
  136. // await laporanModel.findByIdAndUpdate(laporan._id, {
  137. // sanksi: data._id,
  138. // // aktif: false,
  139. // })
  140. await pemantauanModel.create({
  141. laporan: sanksi.laporan._id,
  142. sanksi: sanksi._id,
  143. action: 'UPDATE SANKSI',
  144. pt_id: sanksi.laporan.pt.id,
  145. user: user._id,
  146. keterangan: 'Melakukan Perubahan Sanksi',
  147. dokumen: dokumen_id,
  148. })
  149. return response.success(res, {
  150. message: 'Berhasil merubah Sanksi',
  151. data,
  152. })
  153. })
  154. exports.getAll = handleError(async (req, res) => {
  155. const user = req.user
  156. const {
  157. keberatan,
  158. jawaban,
  159. banding,
  160. cabutSanksi,
  161. perbaikan,
  162. aktif,
  163. delegasi,
  164. naikSanksi,
  165. turunSanksi,
  166. } = req.query
  167. const where = {}
  168. const q = {}
  169. if (aktif && aktif === 'false') {
  170. where.aktif = false
  171. }
  172. if (keberatan === 'true') {
  173. where['pengajuan.keberatan'] = { $exists: true, $ne: null }
  174. if (jawaban === 'true') {
  175. where['jawaban.keberatan'] = { $exists: true, $ne: null }
  176. }
  177. }
  178. if (banding === 'true') {
  179. where.banding = true
  180. where['pengajuan.keberatan'] = { $exists: true, $ne: null }
  181. where['jawaban.keberatan'] = { $exists: true, $ne: null }
  182. where['pengajuan.banding'] = { $exists: true, $ne: null }
  183. if (jawaban === 'true') {
  184. where['jawaban.banding'] = { $exists: true, $ne: null }
  185. }
  186. }
  187. if (cabutSanksi === 'true') {
  188. where.perbaikan = { $exists: true, $ne: [] }
  189. if (jawaban === 'true') {
  190. where['pengajuan.cabut_sanksi'] = { $exists: true, $ne: null }
  191. // where['jawaban.cabut_sanksi'] = { $exists: true, $ne: null }
  192. }
  193. }
  194. if (perbaikan === 'true') {
  195. where['jawaban.banding'] = { $exists: true, $ne: null }
  196. }
  197. if (delegasi === 'true') {
  198. where.delegasi = true
  199. }
  200. if (naikSanksi === 'true') {
  201. q.level_sanksi = { $in: [1, 2] }
  202. }
  203. if (turunSanksi === 'true') {
  204. q.level_sanksi = { $in: [2, 3] }
  205. }
  206. const data = await cekBanyakDataSanksi(user, where, q)
  207. return response.success(res, {
  208. message: 'Berhasil ambil data Sanksi',
  209. data,
  210. })
  211. })
  212. exports.getOne = handleError(async (req, res) => {
  213. const user = req.user
  214. const { sanksi_id } = req.params
  215. const w = {}
  216. const { banding, aktif, delegasi, all } = req.query
  217. if (banding === 'true') {
  218. w.banding = true
  219. w['pengajuan.keberatan'] = { $exists: true, $ne: null }
  220. w['jawaban.keberatan'] = { $exists: true, $ne: null }
  221. w['pengajuan.banding'] = { $exists: true, $ne: null }
  222. }
  223. if (delegasi === 'true') {
  224. w.delegasi = true
  225. }
  226. if (all === 'true') {
  227. w.all = true
  228. }
  229. if (aktif && aktif === 'false') {
  230. w.aktif = false
  231. }
  232. const sanksi = await cekSatuDataSanksi(res, user, sanksi_id, w)
  233. if (!sanksi) return
  234. return response.success(res, {
  235. message: 'Berhasil ambil satu data Sanksi',
  236. data: sanksi,
  237. })
  238. })
  239. exports.editTmt = handleError(async (req, res) => {
  240. const user = req.user
  241. const { id } = req.params
  242. const { from_date, to_date } = req.body
  243. const files = req.files
  244. const sanksi = await cekSatuDataSanksi(res, user, id)
  245. if (!sanksi) return
  246. const isValid = validate(res, req.body, {
  247. from_date: { type: 'date', convert: true },
  248. to_date: { type: 'date', convert: true },
  249. })
  250. if (!isValid) return
  251. if (!files.length) {
  252. return response.error(res, {
  253. message: 'dokumen harus ada',
  254. })
  255. }
  256. const dokumen = await addManyDokumen(files)
  257. const dokumen_id = dokumen.map((e) => e._id)
  258. const data = await sanksiModel.findByIdAndUpdate(sanksi._id, {
  259. masa_berlaku: {
  260. from_date,
  261. to_date,
  262. },
  263. 'pengajuan.update_tmt': { dokumen: dokumen_id },
  264. })
  265. await pemantauanModel.create({
  266. laporan: sanksi.laporan._id,
  267. user: user._id,
  268. action: 'EDIT TMT',
  269. pt_id: sanksi.laporan.pt.id,
  270. keterangan: 'Mengubah masa berlaku sanksi',
  271. for_public: true,
  272. })
  273. return response.success(res, {
  274. message: 'Berhasil update tmt',
  275. data,
  276. })
  277. })