Merge branch 'sdm'

This commit is contained in:
Salman Manoe 2023-04-17 16:50:38 +07:00
commit 29247ed49d
4 changed files with 70 additions and 18 deletions

View File

@ -15,9 +15,13 @@ import com.jasamedika.medifirst2000.entities.SlipGajiKomponen;
* @since Jan 30, 2023
*/
public interface SlipGajiKomponenDao extends JpaRepository<SlipGajiKomponen, String> {
@Query("select new Map(sgk.id as id," + "sgk.komponen.id as idKomponen,"
+ "sgk.komponen.namaKomponen as namaKomponen," + "sgk.nominal as nominal) " + "from SlipGajiKomponen sgk "
+ "where sgk.slipGaji.pegawai.id = :pegawaiId " + "and sgk.slipGaji.bulan between :start and :end")
@Query("select new Map(sgk.id as id," + "sgk.komponen.jenisKomponen as idJenisKomponen,"
+ "case when sgk.komponen.jenisKomponen = 1 then 'Penerimaan' "
+ "when sgk.komponen.jenisKomponen = 2 then 'Pemotongan' end as jenisKomponen,"
+ "sgk.komponen.id as idKomponen," + "sgk.komponen.namaKomponen as namaKomponen,"
+ "sgk.nominal as nominal) " + "from SlipGajiKomponen sgk " + "where sgk.slipGaji.pegawai.id = :pegawaiId "
+ "and sgk.slipGaji.bulan between :start and :end "
+ "order by sgk.komponen.jenisKomponen, sgk.komponen.id")
List<Map<String, Object>> findAll(@Param("pegawaiId") Integer pegawaiId, @Param("start") Date start,
@Param("end") Date end);

View File

@ -10,7 +10,6 @@ import java.util.ArrayList;
import java.util.Comparator;
import java.util.Date;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Locale;
import java.util.Map;
@ -141,13 +140,20 @@ public class SlipGajiServiceImpl implements SlipGajiService {
@Override
public void save(SlipGajiDto dto) {
SlipGaji.SlipGajiBuilder slipGaji = SlipGaji.builder();
if (CommonUtil.isNotNullOrEmpty(dto.getId()))
Date month = new Date(dto.getBulan());
Date start = DateUtil.startMonth(month);
Date end = DateUtil.endMonth(month);
Optional<SlipGaji> existedSlipGaji = slipGajiDao.findByPegawaiAndBulan(dto.getIdPegawai(), start, end);
if (existedSlipGaji.isPresent()) {
slipGaji.id(existedSlipGaji.get().getId());
} else if (CommonUtil.isNotNullOrEmpty(dto.getId())) {
slipGaji.id(dto.getId());
}
slipGaji.pegawai(pegawaiDao.findById(dto.getIdPegawai()));
slipGaji.bulan(new Date(dto.getBulan()));
slipGaji.bulan(month);
SlipGaji savedSlip = slipGajiDao.save(slipGaji.build());
if (CommonUtil.isNotNullOrEmpty(savedSlip)) {
if (CommonUtil.isNullOrEmpty(dto.getId())) {
if (!existedSlipGaji.isPresent() && CommonUtil.isNullOrEmpty(dto.getId())) {
List<MapPegawaiJabatanToUnitKerja> listMapping = mappingJabatanDao.findByPegawaiId(dto.getIdPegawai());
List<SlipGajiDetail> listDetail = new ArrayList<>();
listMapping.forEach(j -> {
@ -167,7 +173,7 @@ public class SlipGajiServiceImpl implements SlipGajiService {
}
{
List<SlipGajiKomponen> listKomponen = new ArrayList<>();
Set<SlipGajiKomponenDto> dtos = dto.getKomponen();
List<SlipGajiKomponenDto> dtos = dto.getKomponen();
dtos.forEach(k -> {
SlipGajiKomponen.SlipGajiKomponenBuilder kBuilder = SlipGajiKomponen.builder();
if (CommonUtil.isNotNullOrEmpty(k.getId()))
@ -258,15 +264,19 @@ public class SlipGajiServiceImpl implements SlipGajiService {
}
{
List<Map<String, Object>> listKomponen = slipGajiKomponenDao.findAll(pegawaiId, start, end);
Set<SlipGajiKomponenDto> dtoList = new HashSet<>();
List<SlipGajiKomponenDto> dtoList = new ArrayList<>();
listKomponen.forEach(k -> {
SlipGajiKomponenDto.SlipGajiKomponenDtoBuilder kBuilder = SlipGajiKomponenDto.builder();
kBuilder.id(k.get("id").toString());
kBuilder.idJenisKomponen(Integer.valueOf(k.get("idJenisKomponen").toString()));
kBuilder.jenisKomponen(k.get("jenisKomponen").toString());
kBuilder.idKomponen(Integer.valueOf(k.get("idKomponen").toString()));
kBuilder.namaKomponen(k.get("namaKomponen").toString());
kBuilder.nominal(new BigDecimal(k.get("nominal").toString()));
dtoList.add(kBuilder.build());
});
dtoList.stream().sorted(Comparator.comparing(o1 -> o1.getIdKomponen()))
.sorted(Comparator.comparing(o2 -> o2.getIdJenisKomponen())).collect(Collectors.toList());
dto.komponen(dtoList);
}
}

View File

@ -1,6 +1,6 @@
package com.jasamedika.medifirst2000.dto;
import java.util.Set;
import java.util.List;
import javax.validation.constraints.NotNull;
@ -37,13 +37,13 @@ public class SlipGajiDto {
private Long bulan;
@Caption(value = "Komponen Gaji")
private Set<SlipGajiKomponenDto> komponen;
private List<SlipGajiKomponenDto> komponen;
public SlipGajiDto() {
}
public SlipGajiDto(String id, Integer idPegawai, String namaPegawai, String jabatan, String unitKerja,
String subUnitKerja, String grade, Long bulan, Set<SlipGajiKomponenDto> komponen) {
String subUnitKerja, String grade, Long bulan, List<SlipGajiKomponenDto> komponen) {
super();
this.id = id;
this.idPegawai = idPegawai;
@ -120,11 +120,11 @@ public class SlipGajiDto {
this.bulan = bulan;
}
public Set<SlipGajiKomponenDto> getKomponen() {
public List<SlipGajiKomponenDto> getKomponen() {
return komponen;
}
public void setKomponen(Set<SlipGajiKomponenDto> komponen) {
public void setKomponen(List<SlipGajiKomponenDto> komponen) {
this.komponen = komponen;
}
@ -145,7 +145,7 @@ public class SlipGajiDto {
private String subUnitKerja;
private String grade;
private Long bulan;
private Set<SlipGajiKomponenDto> komponen;
private List<SlipGajiKomponenDto> komponen;
public SlipGajiDtoBuilder() {
}
@ -190,7 +190,7 @@ public class SlipGajiDto {
return this;
}
public SlipGajiDtoBuilder komponen(final Set<SlipGajiKomponenDto> komponen) {
public SlipGajiDtoBuilder komponen(final List<SlipGajiKomponenDto> komponen) {
this.komponen = komponen;
return this;
}

View File

@ -8,6 +8,12 @@ public class SlipGajiKomponenDto {
@Caption(value = "ID")
private String id;
@Caption(value = "ID Jenis Komponen Gaji")
private Integer idJenisKomponen;
@Caption(value = "Jenis Komponen Gaji")
private String jenisKomponen;
@Caption(value = "ID Komponen Gaji")
private Integer idKomponen;
@ -20,8 +26,11 @@ public class SlipGajiKomponenDto {
public SlipGajiKomponenDto() {
}
public SlipGajiKomponenDto(String id, Integer idKomponen, String namaKomponen, BigDecimal nominal) {
public SlipGajiKomponenDto(String id, Integer idJenisKomponen, String jenisKomponen, Integer idKomponen,
String namaKomponen, BigDecimal nominal) {
this.id = id;
this.idJenisKomponen = idJenisKomponen;
this.jenisKomponen = jenisKomponen;
this.idKomponen = idKomponen;
this.namaKomponen = namaKomponen;
this.nominal = nominal;
@ -35,6 +44,22 @@ public class SlipGajiKomponenDto {
this.id = id;
}
public Integer getIdJenisKomponen() {
return idJenisKomponen;
}
public void setIdJenisKomponen(Integer idJenisKomponen) {
this.idJenisKomponen = idJenisKomponen;
}
public String getJenisKomponen() {
return jenisKomponen;
}
public void setJenisKomponen(String jenisKomponen) {
this.jenisKomponen = jenisKomponen;
}
public Integer getIdKomponen() {
return idKomponen;
}
@ -65,6 +90,8 @@ public class SlipGajiKomponenDto {
public static class SlipGajiKomponenDtoBuilder {
private String id;
private Integer idJenisKomponen;
private String jenisKomponen;
private Integer idKomponen;
private String namaKomponen;
private BigDecimal nominal;
@ -77,6 +104,16 @@ public class SlipGajiKomponenDto {
return this;
}
public SlipGajiKomponenDtoBuilder idJenisKomponen(final Integer idJenisKomponen) {
this.idJenisKomponen = idJenisKomponen;
return this;
}
public SlipGajiKomponenDtoBuilder jenisKomponen(final String jenisKomponen) {
this.jenisKomponen = jenisKomponen;
return this;
}
public SlipGajiKomponenDtoBuilder idKomponen(final Integer idKomponen) {
this.idKomponen = idKomponen;
return this;
@ -93,7 +130,8 @@ public class SlipGajiKomponenDto {
}
public SlipGajiKomponenDto build() {
return new SlipGajiKomponenDto(this.id, this.idKomponen, this.namaKomponen, this.nominal);
return new SlipGajiKomponenDto(this.id, this.idJenisKomponen, this.jenisKomponen, this.idKomponen,
this.namaKomponen, this.nominal);
}
}
}