| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446 | const sanksiModel = require('../model/sanksi.model')const handleError = require('../utils/handleError')const response = require('../utils/responseHandler')const { addManyDokumen, addDokumen } = require('../utils/dokumenFunction')const { validate } = require('../utils/validation')const pemantauanModel = require('../model/pemantauan.model')const pelanggaranModel = require('../model/pelanggaran.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, from_date, to_date, tanggal_terima_sanksi, tanggal_akhir_keberatan } = req.body  let { pelanggaran_id } = req.body  const { laporan_id } = req.params  const { dokumen: files, berita_acara, dokumen_terima_sanksi } = req.files  const user = req.user  const isValid = validate(res, req.body, {    no_sanksi: 'string',    keterangan: 'string',    pelanggaran_id: 'string',    from_date: 'string',    to_date: 'string',    tanggal_terima_sanksi: 'string',    tanggal_akhir_keberatan: 'string',  })  if (!isValid) return  const laporan = await cekSatuDataLaporan(res, user, laporan_id, {    evaluasi: { $exists: true, $ne: [] },  })  if (!laporan) return  const id_pelanggaran = pelanggaran_id.split(',')  const pelanggaran = await pelanggaranModel.find({    _id: {      $in: id_pelanggaran,    },  })  if (!pelanggaran.length) {    return response.error(res, { message: 'pelanggaran_id tidak ada' })  }  pelanggaran_id = pelanggaran.map((e) => e._id)  const sanksi = await sanksiModel.findOne({ laporan: laporan_id })  if (sanksi) {    return response.error(res, {      message: 'Sanksi sudah ada',    })  }  if (!files) {    return response.error(res, {      message: 'dokumen harus ada',    })  }  let dokumenBeritaAcara_id = null  if (berita_acara) {    const dokumenBeritaAcara = await addManyDokumen(berita_acara)    dokumenBeritaAcara_id = dokumenBeritaAcara[0]  }  let dokumenTerimaSanksi_id = []  if (dokumen_terima_sanksi) {    const dokumenTerimaSanksi = await addManyDokumen(dokumen_terima_sanksi)    dokumenTerimaSanksi_id = dokumenTerimaSanksi.map((e) => e._id)  }  const dokumen = await addManyDokumen(files)  const dokumen_id = dokumen.map((e) => e._id)  const data = await sanksiModel.create({    no_sanksi,    laporan: laporan._id,    user: user._id,    pelanggaran: pelanggaran_id,    keterangan,    dokumen: dokumen_id,    sanksi: pelanggaran.map(e=> ({label: e.label_sanksi, value: e.sanksi, level: e.level_sanksi})),    berita_acara: dokumenBeritaAcara_id,    tanggal_terima_sanksi,    dokumen_terima_sanksi: dokumenTerimaSanksi_id,    tanggal_akhir_keberatan,    masa_berlaku: {      from_date,      to_date,    },    batas_waktu: {      keberatan: hariKerja(10),    },  })  await laporanModel.findByIdAndUpdate(laporan._id, {    sanksi: data._id,    // aktif: false,  })  await pemantauanModel.create({    laporan: laporan._id,    sanksi: data._id,    action: 'CREATE SANKSI',    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.update = handleError(async (req, res) => {  const { no_sanksi, keterangan, from_date, to_date } = req.body  let sanksiBody = req.body.sanksi  const { sanksi_id } = req.params  const files = req.files  const user = req.user  const isValid = validate(res, req.body, {    no_sanksi: 'string',    keterangan: 'string',    sanksi: 'string',    from_date: 'string',    to_date: 'string',  })  if (!isValid) return  const sanksi = await cekSatuDataSanksi(res, user, sanksi_id, { all: true })  if (!sanksi) return  // pelanggaran_id = await cekBanyakDataPelanggaran(res, pelanggaran_id)  // if (!pelanggaran_id) return  sanksiBody = JSON.parse(sanksiBody)  // 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.updateOne(    { _id: sanksi._id },    {      no_sanksi,      // pelanggaran: pelanggaran_id,      sanksi: sanksiBody,      keterangan,      dokumen: dokumen_id,      masa_berlaku: {        from_date,        to_date,      },      $push: {        riwayat_sanksi: sanksi,      },    }  )  // await laporanModel.findByIdAndUpdate(laporan._id, {  //   sanksi: data._id,  //   // aktif: false,  // })  await pemantauanModel.create({    laporan: sanksi.laporan._id,    sanksi: sanksi._id,    action: 'UPDATE SANKSI',    pt_id: sanksi.laporan.pt.id,    user: user._id,    keterangan: 'Melakukan Perubahan Sanksi',    dokumen: dokumen_id,    data: {      no_sanksi,      // pelanggaran: pelanggaran_id,      sanksi: sanksiBody,      keterangan,      masa_berlaku: {        from_date,        to_date,      },    }  })  return response.success(res, {    message: 'Berhasil merubah Sanksi',    data,  })})exports.updatePt = handleError(async (req, res) => {  const { is_pengajuan_keberatan, is_pengajuan_banding, is_dokumen_perbaikan } = req.body  const { sanksi_id } = req.params  const user = req.user  const isValid = validate(res, req.body, {    is_pengajuan_keberatan: { type: 'boolean', optional: true },    is_pengajuan_banding: { type: 'boolean', optional: true },    is_dokumen_perbaikan: { type: 'boolean', optional: true },  })  if (!isValid) return  const sanksi = await cekSatuDataSanksi(res, user, sanksi_id)  if (!sanksi) return  let keterangan = '';  let last_step = '';  if (is_pengajuan_keberatan == true) {    last_step = 'Permohonan Keberatan'    keterangan = 'Menerima Pengajuan Keberatan';  } else if (is_pengajuan_keberatan == false) {    keterangan = 'Membatalkan Pengajuan Keberatan';    last_step = 'Dokumen Perbaikan';  }  if (is_pengajuan_banding == true) {    last_step = 'Permohonan Banding'    keterangan = 'Menerima Pengajuan Banding';  } else if (is_pengajuan_banding == false) {    keterangan = 'Membatalkan Pengajuan Banding';    last_step = 'Dokumen Perbaikan';  }  await pemantauanModel.create({    laporan: sanksi.laporan._id,    sanksi: sanksi._id,    action: 'UPDATE SANKSI',    pt_id: sanksi.laporan.pt.id,    user: user._id,    keterangan,  })  if (is_dokumen_perbaikan == true) {    last_step = 'Dokumen Perbaikan';  }  await sanksiModel.updateOne(    { _id: sanksi._id },    { is_pengajuan_keberatan, is_pengajuan_banding, last_step }  );  return response.success(res, {    message: 'Berhasil merubah Sanksi',  })})exports.getAll = handleError(async (req, res) => {  const user = req.user  const {    keberatan,    jawaban,    banding,    cabutSanksi,    perbaikan,    aktif,    delegasi,    naikSanksi,    turunSanksi,    pengajuan_keberatan  } = req.query  const where = {}  const q = {}  if (aktif && aktif === 'false') {    where.aktif = false  }  if (pengajuan_keberatan === 'true') {    where.is_pengajuan_keberatan = true;  }  if (keberatan === 'true') {    where['pengajuan.keberatan'] = { $exists: true, $ne: null }    where.is_pengajuan_keberatan = true    if (jawaban === 'true') {      where['jawaban.keberatan'] = { $exists: true, $ne: null }    }  }  if (banding === 'true') {    where.banding = true    where.is_pengajuan_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 }    }  }  if (cabutSanksi === 'true') {    where.perbaikan = { $exists: true, $ne: [] }    if (jawaban === 'true') {      where['pengajuan.cabut_sanksi'] = { $exists: true, $ne: null }      // where['jawaban.cabut_sanksi'] = { $exists: true, $ne: null }    }  }  if (perbaikan === 'true') {    where.$or = [{ 'jawaban.banding': { $exists: true, $ne: null } }, { is_pengajuan_keberatan: false }, { is_pengajuan_banding: false }]  }  if (delegasi === 'true') {    where.delegasi = true  }  if (naikSanksi === 'true') {    where['sanksi.level'] = { $in: [1, 2] }  }  if (turunSanksi === 'true') {    where['sanksi.level'] = { $in: [2, 3] }  }  const data = await cekBanyakDataSanksi(user, where, q)  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, aktif, delegasi, all } = 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 }  }  if (delegasi === 'true') {    w.delegasi = true  }  if (all === 'true') {    w.all = true  }  if (aktif && aktif === 'false') {    w.aktif = false  }  const sanksi = await cekSatuDataSanksi(res, user, sanksi_id, w)  if (!sanksi) return  return response.success(res, {    message: 'Berhasil ambil satu data Sanksi',    data: sanksi,  })})exports.editTmt = handleError(async (req, res) => {  const user = req.user  const { id } = req.params  const { from_date, to_date, no_surat } = req.body  const files = req.files  const sanksi = await cekSatuDataSanksi(res, user, id)  if (!sanksi) return  const isValid = validate(res, req.body, {    from_date: { type: 'date', convert: true },    to_date: { type: 'date', convert: true },    no_surat: 'string',  })  if (!isValid) return  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.findByIdAndUpdate(sanksi._id, {    masa_berlaku: {      from_date,      to_date,    },    'pengajuan.update_tmt': { no_surat, dokumen: dokumen_id },  })  await pemantauanModel.create({    laporan: sanksi.laporan._id,    user: user._id,    action: 'EDIT TMT',    pt_id: sanksi.laporan.pt.id,    keterangan: 'Mengubah masa berlaku sanksi',    for_public: true,  })  return response.success(res, {    message: 'Berhasil update tmt',    data,  })})exports.addPesertaPleno = handleError(async (req, res) => {  const isValid = validate(res, req.body, {    laporan_id: 'string',    nama: 'string',  })  if (!isValid) return  const { laporan_id, nama } = req.body  const laporan = await laporanModel.findOne({    _id: laporan_id,    // sanksi: {    //   $eq: null,    //   $exists: false    // }  })  if (!laporan) return response.error(res, {    code: 404,    message: 'laporan_id tidak ada'  })  const file = req.file  if (!file) {    return response.error(res, {      message: 'ttd harus ada',    })  }  const dokumen = await addDokumen(file)  await laporanModel.findOneAndUpdate(    { _id: laporan._id },    {      $push: {        peserta_penetapan_sanksi: {          nama,          ttd: dokumen.id        }      }    }  )  return response.success(res, {    message: 'Berhasil tambah peserta pleno',  })})
 |