| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 | const handleError = require('../../utils/handleError')const sanksiModel = require('../../model/sanksi.model')const { addManyDokumen } = require('../../utils/dokumenFunction')const { validate } = require('../../utils/validation')const { cekSatuDataSanksi } = require('../../utils/cekData')const response = require('../../utils/responseHandler')const { hariKerja } = require('../../utils/hariKerja')const pemantauanModel = require('../../model/pemantauan.model')const { notifWA } = require('../../utils/notifFunction')exports.create = handleError(async (req, res) => {  const user = req.user  const { sanksi_id } = req.params  if (!sanksi_id) {    return response.error(res, {      message: 'query sanksi_id harus ada',    })  }  const sanksi = await cekSatuDataSanksi(res, user, sanksi_id)  if (!sanksi) return  const files = req.files  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.findOneAndUpdate(    {      laporan: sanksi.laporan._id,      _id: sanksi._id,      ['pengajuan.keberatan']: { $exists: false, $eq: null },    },    {      ['pengajuan.keberatan']: {        dokumen: dokumen_id,      },      ['batas_waktu.jawaban_keberatan']: hariKerja(10),    }  )  if (!data) {    return response.error(res, {      message: 'Pengajuan Keberatan sudah ada',    })  }  await pemantauanModel.create({    laporan: sanksi.laporan._id,    sanksi: sanksi._id,    user: user._id,    pt_id: sanksi.laporan.pt.id,    keterangan: 'Mengajukan Keberatan',    dokumen: dokumen_id,  })  await notifWA('8d2d8bfd-4100-4f78-b877-caffded2d56a', [    { key: '1', value: 'pt', value_text: sanksi.laporan.pt.nama },    {      key: '2',      value: 'pemberi_sanksi',      value_text: `${sanksi.user.nama} - ${sanksi.user.role.nama}`,    },    { key: '3', value: 'no_sanksi', value_text: sanksi.no_sanksi },  ])  return response.success(res, {    data,    message: 'Berhasil menambah keberatan',  })})exports.createJawaban = handleError(async (req, res) => {  const user = req.user  const { sanksi_id } = req.params  if (!sanksi_id) {    return response.error(res, {      message: 'query sanksi_id harus ada',    })  }  const sanksi = await cekSatuDataSanksi(res, user, sanksi_id)  if (!sanksi) return  const isValid = validate(res, req.body, {    status: 'string',    keterangan: 'string',  })  if (!isValid) return  const files = req.files  let dokumen_id = []  if (files?.length) {    const dokumen = await addManyDokumen(files)    dokumen_id = dokumen.map((e) => e._id)  }  const { status, keterangan } = req.body  const data = await sanksiModel.findOneAndUpdate(    {      laporan: sanksi.laporan._id,      _id: sanksi._id,      ['pengajuan.keberatan']: { $exists: true, $ne: null },    },    {      ['jawaban.keberatan']: {        status,        keterangan,        dokumen: dokumen_id,      },      ['batas_waktu.banding']: hariKerja(21),    }  )  if (!data) {    return response.error(res, {      message: 'keberatan tidak ada',    })  }  let message = 'Menjawab Pengajuan Keberatan'  let for_public = true  if (sanksi.jawaban?.keberatan) {    message = 'Mengubah jawaban Pengajuan Keberatan'    for_public = false  }  await pemantauanModel.create({    laporan: sanksi.laporan._id,    sanksi: sanksi._id,    user: user._id,    pt_id: sanksi.laporan.pt.id,    keterangan: message,    dokumen: dokumen_id,    for_public,  })  return response.success(res, {    data,  })})
 |