| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 | 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,  })})
 |