Merge branch 'dev/pegawai/cuti' into dev/no-cron
This commit is contained in:
commit
c32ab9b8f0
@ -49,10 +49,4 @@ public interface MapKalenderToHariLiburDao extends PagingAndSortingRepository<Ma
|
||||
@Param("idHariLibur") Integer idHariLibur, @Param("tglAwal") Date tglAwal,
|
||||
@Param("tglAkhir") Date tglAkhir);
|
||||
|
||||
@Query("select mkl from MapKalenderToHariLibur mkl " + "inner join mkl.tanggal kld "
|
||||
+ "where mkl.statusEnabled is true " + "and kld.tanggal between :tglAwal and :tglAkhir "
|
||||
+ "and mkl.hariLiburId = :idHariLibur")
|
||||
List<MapKalenderToHariLibur> getByTahun(@Param("idHariLibur") Integer idHariLibur, @Param("tglAwal") Date tglAwal,
|
||||
@Param("tglAkhir") Date tglAkhir);
|
||||
|
||||
}
|
||||
|
||||
@ -6,7 +6,6 @@ import com.jasamedika.medifirst2000.dto.DataCutiDto;
|
||||
import com.jasamedika.medifirst2000.dto.JatahCutiRequest;
|
||||
import com.jasamedika.medifirst2000.dto.PresensiHariLibur;
|
||||
import com.jasamedika.medifirst2000.entities.ListTanggalCuti;
|
||||
import com.jasamedika.medifirst2000.entities.MapKalenderToHariLibur;
|
||||
import com.jasamedika.medifirst2000.service.JatahCutiDanIzinService;
|
||||
import com.jasamedika.medifirst2000.util.CommonUtil;
|
||||
import com.jasamedika.medifirst2000.util.DateUtil;
|
||||
@ -556,34 +555,22 @@ public class JatahCutiDanIzinServiceImpl implements JatahCutiDanIzinService {
|
||||
Date tahunLalu = DateUtil.getInstanceCalendar(-1);
|
||||
Date awalTahunLalu = DateUtil.startYear(tahunLalu);
|
||||
Date akhirTahunLalu = DateUtil.endYear(tahunLalu);
|
||||
List<MapKalenderToHariLibur> listKalenderCutiBersama = mapKalenderToHariLiburDao.getByTahun(LIBUR_CB,
|
||||
awalTahunLalu, akhirTahunLalu);
|
||||
List<MapKalenderToHariLibur> listKalenderCutiBersamaBisaDitangguhkan = listKalenderCutiBersama.stream()
|
||||
.filter(MapKalenderToHariLibur::getIsCutiBersamaDitangguhkan).collect(Collectors.toList());
|
||||
List<ListTanggalCuti> listCutiTahunLaluBelumDisetujui = tanggalCutiDao
|
||||
.notApprovedByPermohonan(request.getPegawaiId(), CUTI_TAHUNAN, awalTahunLalu, akhirTahunLalu);
|
||||
List<PresensiHariLibur> listPresensiTahunLalu = mapKalenderToHariLiburDao
|
||||
.getPresensiByTahun(request.getPegawaiId(), LIBUR_CB, awalTahunLalu, akhirTahunLalu);
|
||||
int presensiCutiBersama = countValidPresensi(listPresensiTahunLalu, listKalenderCutiBersama);
|
||||
int jatahDitangguhkan = countValidPresensi(listPresensiTahunLalu, listKalenderCutiBersamaBisaDitangguhkan);
|
||||
List<PresensiHariLibur> listPresensiCutiBersamaBisaDitangguhkan = listPresensiTahunLalu.stream()
|
||||
.filter(PresensiHariLibur::getIsCutiBersamaDitangguhkan).collect(Collectors.toList());
|
||||
if (listPresensiCutiBersamaBisaDitangguhkan.isEmpty())
|
||||
return dto;
|
||||
List<ListTanggalCuti> listCutiTahunLaluBelumDisetujui = tanggalCutiDao
|
||||
.notApprovedByPermohonan(request.getPegawaiId(), CUTI_TAHUNAN, awalTahunLalu, akhirTahunLalu);
|
||||
int presensiCutiBersama = listPresensiTahunLalu.size();
|
||||
int jatahDitangguhkan = listPresensiCutiBersamaBisaDitangguhkan.size();
|
||||
if (presensiCutiBersama - dto.getCutiTerpakaiB1()
|
||||
+ listCutiTahunLaluBelumDisetujui.size() > jatahDitangguhkan) {
|
||||
- listCutiTahunLaluBelumDisetujui.size() >= jatahDitangguhkan) {
|
||||
dto.setDataCutiB(dto.getDataCutiB() + jatahDitangguhkan);
|
||||
dto.setSisaCutiB(dto.getDataCutiB() - dto.getCutiTerpakaiB());
|
||||
}
|
||||
return dto;
|
||||
}
|
||||
|
||||
private int countValidPresensi(List<PresensiHariLibur> listPresensiDiCutiBersama,
|
||||
List<MapKalenderToHariLibur> listKalenderCutiBersama) {
|
||||
int result = 0;
|
||||
for (PresensiHariLibur presensiDiCutiBersama : listPresensiDiCutiBersama) {
|
||||
Optional<MapKalenderToHariLibur> any = listKalenderCutiBersama.stream()
|
||||
.filter(k -> presensiDiCutiBersama.getTanggal().equals(k.getTanggal().getTanggal())).findAny();
|
||||
if (any.isPresent())
|
||||
result++;
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user