Update JatahCutiDanIzinServiceImpl.java

Perbaikan urutan hitung jatab cuti bersama ditangguhkan dipakai dalam pengajuan cuti
This commit is contained in:
Salman Manoe 2025-01-22 11:31:57 +07:00
parent 02c5f250f3
commit b64bb1d054

View File

@ -54,9 +54,7 @@ public class JatahCutiDanIzinServiceImpl implements JatahCutiDanIzinService {
@Override @Override
public DataCutiDto getDataCuti(Integer pegawaiId, String year, Integer statusPegawaiId) { public DataCutiDto getDataCuti(Integer pegawaiId, String year, Integer statusPegawaiId) {
DataCutiDto dto = calculateCutiIzin(pegawaiId, year, statusPegawaiId); return calculateCutiIzin(pegawaiId, year, statusPegawaiId);
JatahCutiRequest jatahCutiRequest = transform(pegawaiId, year, statusPegawaiId);
return tangguhkanCutiBersama(dto, jatahCutiRequest);
} }
private DataCutiDto calculateCutiIzin(Integer pegawaiId, String year, Integer statusPegawaiId) { private DataCutiDto calculateCutiIzin(Integer pegawaiId, String year, Integer statusPegawaiId) {
@ -231,7 +229,6 @@ public class JatahCutiDanIzinServiceImpl implements JatahCutiDanIzinService {
} }
} }
dataCutiB = countDataHabsen; dataCutiB = countDataHabsen;
cutiIzinBuilder.dataCutiB(dataCutiB);
// kondisikan cuti bersama yg sudah berlalu // kondisikan cuti bersama yg sudah berlalu
if (cutiTerpakaiN2 > dataCutiB2) { if (cutiTerpakaiN2 > dataCutiB2) {
cutiTerpakaiB2 = dataCutiB2; cutiTerpakaiB2 = dataCutiB2;
@ -243,6 +240,10 @@ public class JatahCutiDanIzinServiceImpl implements JatahCutiDanIzinService {
} else { } else {
cutiTerpakaiB1 = cutiTerpakaiN1; cutiTerpakaiB1 = cutiTerpakaiN1;
} }
JatahCutiRequest jatahCutiRequest = transform(pegawaiId, year, statusPegawaiId);
int jatahCutiBersamaDitangguhkan = tangguhkanCutiBersama(cutiTerpakaiB1, jatahCutiRequest);
dataCutiB += jatahCutiBersamaDitangguhkan;
cutiIzinBuilder.dataCutiB(dataCutiB);
// Mendapatkan kondisi penangguhan saat ini // Mendapatkan kondisi penangguhan saat ini
cutiIzinBuilder.isTangguhkanB2(false); cutiIzinBuilder.isTangguhkanB2(false);
cutiIzinBuilder.isTangguhkanB1(false); cutiIzinBuilder.isTangguhkanB1(false);
@ -552,7 +553,7 @@ public class JatahCutiDanIzinServiceImpl implements JatahCutiDanIzinService {
return JatahCutiRequest.builder().pegawaiId(pegawaiId).year(year).statusPegawaiId(statusPegawaiId).build(); return JatahCutiRequest.builder().pegawaiId(pegawaiId).year(year).statusPegawaiId(statusPegawaiId).build();
} }
private DataCutiDto tangguhkanCutiBersama(DataCutiDto dto, JatahCutiRequest request) { private int tangguhkanCutiBersama(Integer cutiBersamaTerpakaiTahunLalu, JatahCutiRequest request) {
if (CommonUtil.isNullOrEmpty(request.getYear())) if (CommonUtil.isNullOrEmpty(request.getYear()))
request.setYear(String.valueOf(DateUtil.getYear(new Date()))); request.setYear(String.valueOf(DateUtil.getYear(new Date())));
Date tahunLalu = DateUtil.getInstanceCalendar(-1); Date tahunLalu = DateUtil.getInstanceCalendar(-1);
@ -563,7 +564,7 @@ public class JatahCutiDanIzinServiceImpl implements JatahCutiDanIzinService {
List<HariLiburTerpakai> listPresensiCutiBersamaBisaDitangguhkan = listPresensiTahunLalu.stream() List<HariLiburTerpakai> listPresensiCutiBersamaBisaDitangguhkan = listPresensiTahunLalu.stream()
.filter(HariLiburTerpakai::getIsCutiBersamaDitangguhkan).collect(Collectors.toList()); .filter(HariLiburTerpakai::getIsCutiBersamaDitangguhkan).collect(Collectors.toList());
if (listPresensiCutiBersamaBisaDitangguhkan.isEmpty()) if (listPresensiCutiBersamaBisaDitangguhkan.isEmpty())
return dto; return 0;
List<HariLiburTerpakai> listCutiDiCutiBersamaTahunLalu = tanggalCutiDao.getCutiByTahun(request.getPegawaiId(), List<HariLiburTerpakai> listCutiDiCutiBersamaTahunLalu = tanggalCutiDao.getCutiByTahun(request.getPegawaiId(),
LIBUR_CB, awalTahunLalu, akhirTahunLalu); LIBUR_CB, awalTahunLalu, akhirTahunLalu);
if (DateUtil.getYear(new Date()) == Integer.parseInt(request.getYear())) { if (DateUtil.getYear(new Date()) == Integer.parseInt(request.getYear())) {
@ -571,17 +572,16 @@ public class JatahCutiDanIzinServiceImpl implements JatahCutiDanIzinService {
.notApprovedByPermohonan(request.getPegawaiId(), CUTI_TAHUNAN, awalTahunLalu, akhirTahunLalu); .notApprovedByPermohonan(request.getPegawaiId(), CUTI_TAHUNAN, awalTahunLalu, akhirTahunLalu);
int presensiCutiBersama = listPresensiTahunLalu.size(); int presensiCutiBersama = listPresensiTahunLalu.size();
int cutiDiCutiBersama = listCutiDiCutiBersamaTahunLalu.size(); int cutiDiCutiBersama = listCutiDiCutiBersamaTahunLalu.size();
int sisaJatah = presensiCutiBersama + cutiDiCutiBersama - dto.getCutiTerpakaiB1(); int sisaJatah = presensiCutiBersama + cutiDiCutiBersama - cutiBersamaTerpakaiTahunLalu;
int jatahDitangguhkan = listPresensiCutiBersamaBisaDitangguhkan.size() int jatahDitangguhkan = listPresensiCutiBersamaBisaDitangguhkan.size()
- listCutiTahunLaluBelumDisetujui.size(); - listCutiTahunLaluBelumDisetujui.size();
if (jatahDitangguhkan >= sisaJatah) { if (jatahDitangguhkan >= sisaJatah) {
if (jatahDitangguhkan < 0) if (jatahDitangguhkan < 0)
jatahDitangguhkan = 0; jatahDitangguhkan = 0;
dto.setDataCutiB(dto.getDataCutiB() + jatahDitangguhkan); return jatahDitangguhkan;
dto.setSisaCutiB(dto.getDataCutiB() - dto.getCutiTerpakaiB());
} }
} }
return dto; return 0;
} }
} }