| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216 |
- 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, from_date, to_date } = 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',
- from_date: 'string',
- to_date: '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,
- user: user._id,
- pelanggaran: pelanggaran_id,
- keterangan,
- dokumen: dokumen_id,
- 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.getAll = handleError(async (req, res) => {
- const user = req.user
- const {
- keberatan,
- jawaban,
- banding,
- cabutSanksi,
- perbaikan,
- aktif,
- delegasi,
- } = req.query
- const where = {}
- if (aktif && aktif === 'false') {
- where.aktif = false
- }
- if (keberatan === 'true') {
- where['pengajuan.keberatan'] = { $exists: true, $ne: null }
- if (jawaban === 'true') {
- where['jawaban.keberatan'] = { $exists: true, $ne: null }
- }
- }
- 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 }
- }
- }
- 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['jawaban.banding'] = { $exists: true, $ne: null }
- }
- if (delegasi === 'true') {
- where.delegasi = true
- }
- 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, 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 } = 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 },
- })
- 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': { 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,
- })
- })
|