sanksi.controller.js 7.5 KB

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