const sanksiModel = require('../model/sanksi.model') const handleError = require('../utils/handleError') const response = require('../utils/responseHandler') const { addManyDokumen } = require('../utils/dokumenFunction') const { validate } = require('../utils/validation') const pemantauanModel = require('../model/pemantauan.model') const { hariKerja } = require('../utils/hariKerja') const { cekSatuDataSanksi, cekSatuDataLaporan, cekBanyakDataPelanggaran, cekBanyakDataSanksi, } = require('../utils/cekData') const laporanModel = require('../model/laporan.model') exports.create = handleError(async (req, res) => { const { no_sanksi, keterangan } = req.body let { pelanggaran_id } = req.body const { laporan_id } = req.params const files = req.files const user = req.user const isValid = validate(res, req.body, { no_sanksi: 'string', keterangan: 'string', pelanggaran_id: 'string', }) if (!isValid) return const laporan = await cekSatuDataLaporan(res, user, laporan_id, { evaluasi: { $exists: true, $ne: [] }, }) if (!laporan) return pelanggaran_id = await cekBanyakDataPelanggaran(res, pelanggaran_id) if (!pelanggaran_id) return const sanksi = await sanksiModel.findOne({ laporan: laporan_id }) if (sanksi) { return response.error(res, { message: 'Sanksi sudah ada', }) } if (!files.length) { return response.error(res, { message: 'dokumen harus ada', }) } const dokumen = await addManyDokumen(files) const dokumen_id = dokumen.map((e) => e._id) const data = await sanksiModel.create({ no_sanksi, laporan: laporan._id, pelanggaran: pelanggaran_id, keterangan, dokumen: dokumen_id, batas_waktu: { keberatan: hariKerja(10), }, }) await laporanModel.findByIdAndUpdate(laporan._id, { sanksi: data._id }) await pemantauanModel.create({ laporan: laporan._id, sanksi: data._id, pt_id: laporan.pt.id, user: user._id, keterangan: 'Melakukan penetapan Sanksi', dokumen: dokumen_id, }) return response.success(res, { message: 'Berhasil membuat Sanksi', data, }) }) exports.getAll = handleError(async (req, res) => { const user = req.user const { keberatan, jawaban, banding, cabutSanksi, perbaikan } = req.query const where = {} if (keberatan === 'true') { where['pengajuan.keberatan'] = { $exists: true, $ne: null } if (jawaban === 'true') { where['jawaban.keberatan'] = { $exists: true, $ne: null } } } else if (banding === 'true') { where.banding = true where['pengajuan.keberatan'] = { $exists: true, $ne: null } where['jawaban.keberatan'] = { $exists: true, $ne: null } where['pengajuan.banding'] = { $exists: true, $ne: null } if (jawaban === 'true') { where['jawaban.banding'] = { $exists: true, $ne: null } } } else if (cabutSanksi === 'true') { where['pengajuan.cabut_sanksi'] = { $exists: true, $ne: null } if (jawaban === 'true') { where['jawaban.cabut_sanksi'] = { $exists: true, $ne: null } } } else if (perbaikan === 'true') { where.$or = [ { 'jawaban.cabut_sanksi': { $exists: true, $ne: null } }, { 'jawaban.banding': { $exists: true, $ne: null } }, ] } const data = await cekBanyakDataSanksi(user, where) return response.success(res, { message: 'Berhasil ambil data Sanksi', data, }) }) exports.getOne = handleError(async (req, res) => { const user = req.user const { sanksi_id } = req.params const w = {} const { banding } = req.query if (banding === 'true') { w.banding = true w['pengajuan.keberatan'] = { $exists: true, $ne: null } w['jawaban.keberatan'] = { $exists: true, $ne: null } w['pengajuan.banding'] = { $exists: true, $ne: null } } const sanksi = await cekSatuDataSanksi(res, user, sanksi_id, w) if (!sanksi) return return response.success(res, { message: 'Berhasil ambil satu data Sanksi', data: sanksi, }) })