Update service logbook kinerja

Penerapan hitung akumulasi capaian by database
This commit is contained in:
Salman Manoe 2023-12-01 10:05:41 +07:00
parent 6006e2ceb7
commit adddffcc75
4 changed files with 23 additions and 74 deletions

View File

@ -1,15 +1,14 @@
package com.jasamedika.medifirst2000.dao; package com.jasamedika.medifirst2000.dao;
import java.util.Date; import com.jasamedika.medifirst2000.entities.LogbookKinerjaDetail;
import java.util.List;
import java.util.Map;
import org.springframework.data.jpa.repository.Query; import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.PagingAndSortingRepository; import org.springframework.data.repository.PagingAndSortingRepository;
import org.springframework.data.repository.query.Param; import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository; import org.springframework.stereotype.Repository;
import com.jasamedika.medifirst2000.entities.LogbookKinerjaDetail; import java.util.Date;
import java.util.List;
import java.util.Map;
@Repository("logbookKinerjaDetailDao") @Repository("logbookKinerjaDetailDao")
public interface LogbookKinerjaDetailDao extends PagingAndSortingRepository<LogbookKinerjaDetail, String> { public interface LogbookKinerjaDetailDao extends PagingAndSortingRepository<LogbookKinerjaDetail, String> {

View File

@ -11,7 +11,6 @@ import com.jasamedika.medifirst2000.exception.ServiceVOException;
import com.jasamedika.medifirst2000.service.LogbookKinerjaDetailService; import com.jasamedika.medifirst2000.service.LogbookKinerjaDetailService;
import com.jasamedika.medifirst2000.util.CommonUtil; import com.jasamedika.medifirst2000.util.CommonUtil;
import com.jasamedika.medifirst2000.util.DateUtil; import com.jasamedika.medifirst2000.util.DateUtil;
import com.jasamedika.medifirst2000.util.DoubleCounter;
import com.jasamedika.medifirst2000.vo.LogbookKinerjaDetailVO; import com.jasamedika.medifirst2000.vo.LogbookKinerjaDetailVO;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.orm.jpa.JpaSystemException; import org.springframework.orm.jpa.JpaSystemException;
@ -43,15 +42,10 @@ public class LogbookKinerjaDetailServiceImpl extends BaseVoServiceImpl implement
@Override @Override
public LogbookKinerjaDetailVO add(LogbookKinerjaDetailVO vo) throws JpaSystemException, ServiceVOException { public LogbookKinerjaDetailVO add(LogbookKinerjaDetailVO vo) throws JpaSystemException, ServiceVOException {
LogbookKinerja logbookKinerja = logbookKinerjaDao.findOne(vo.getLogbookKinerja().getNoRec()); LogbookKinerja logbookKinerja = logbookKinerjaDao.findOne(vo.getLogbookKinerja().getNoRec());
LogbookKinerjaDetail logbookKinerjaDetail = logbookKinerjaDetailConverter.transferVOToModel(vo, LogbookKinerjaDetail logbookKinerjaDetail = logbookKinerjaDetailConverter.transferVOToModel(vo,
new LogbookKinerjaDetail()); new LogbookKinerjaDetail());
logbookKinerjaDetail.setLogbookKinerja(logbookKinerja); logbookKinerjaDetail.setLogbookKinerja(logbookKinerja);
logbookKinerjaDetail.setTanggalKegiatan(new Date()); logbookKinerjaDetail.setTanggalKegiatan(new Date());
logbookKinerjaDao.save(logbookKinerja);
LogbookKinerjaDetail resultModel = logbookKinerjaDetailDao.save(logbookKinerjaDetail); LogbookKinerjaDetail resultModel = logbookKinerjaDetailDao.save(logbookKinerjaDetail);
if (CommonUtil.isNotNullOrEmpty(resultModel)) { if (CommonUtil.isNotNullOrEmpty(resultModel)) {
/* /*
@ -69,7 +63,6 @@ public class LogbookKinerjaDetailServiceImpl extends BaseVoServiceImpl implement
} }
logbookKinerjaDao.save(models); logbookKinerjaDao.save(models);
} }
/* /*
* menghitung capaian indikator satuan yang harus dihitung secara * menghitung capaian indikator satuan yang harus dihitung secara
* rata-rata * rata-rata
@ -86,10 +79,8 @@ public class LogbookKinerjaDetailServiceImpl extends BaseVoServiceImpl implement
logbookKinerjaDao.save(models); logbookKinerjaDao.save(models);
} }
} }
LogbookKinerjaDetailVO resultVO = new LogbookKinerjaDetailVO(); LogbookKinerjaDetailVO resultVO = new LogbookKinerjaDetailVO();
resultVO = logbookKinerjaDetailConverter.transferModelToVO(resultModel, resultVO); resultVO = logbookKinerjaDetailConverter.transferModelToVO(resultModel, resultVO);
return resultVO; return resultVO;
} }
@ -97,34 +88,30 @@ public class LogbookKinerjaDetailServiceImpl extends BaseVoServiceImpl implement
public LogbookKinerjaDetailVO update(LogbookKinerjaDetailVO vo) throws JpaSystemException, ServiceVOException { public LogbookKinerjaDetailVO update(LogbookKinerjaDetailVO vo) throws JpaSystemException, ServiceVOException {
LogbookKinerja logbookKinerja = logbookKinerjaDao.findOne(vo.getLogbookKinerja().getNoRec()); LogbookKinerja logbookKinerja = logbookKinerjaDao.findOne(vo.getLogbookKinerja().getNoRec());
LogbookKinerjaDetail logbookKinerjaDetailLama = logbookKinerjaDetailDao.findOne(vo.getNoRec()); LogbookKinerjaDetail logbookKinerjaDetailLama = logbookKinerjaDetailDao.findOne(vo.getNoRec());
/*
* menghitung indikator capaian satuan yang harus dihitung secara
* akumulatif
*/
if (!vo.getStatusEnabled() && !vo.getStatusVerifikasi()) {
DoubleCounter capaianSubstracted = new DoubleCounter(logbookKinerja.getCapaian());
capaianSubstracted.add(vo.getCapaian());
logbookKinerja.setCapaian(capaianSubstracted.getResult());
} else if (vo.getStatusEnabled() && vo.getStatusVerifikasi()) {
DoubleCounter capaianAdded = new DoubleCounter(logbookKinerja.getCapaian());
capaianAdded.add(vo.getCapaian());
logbookKinerja.setCapaian(capaianAdded.getResult());
}
LogbookKinerjaDetail logbookKinerjaDetailBaru = logbookKinerjaDetailConverter.transferVOToModel(vo, LogbookKinerjaDetail logbookKinerjaDetailBaru = logbookKinerjaDetailConverter.transferVOToModel(vo,
logbookKinerjaDetailLama); logbookKinerjaDetailLama);
logbookKinerjaDetailBaru.setLogbookKinerja(logbookKinerja); logbookKinerjaDetailBaru.setLogbookKinerja(logbookKinerja);
logbookKinerjaDao.save(logbookKinerja);
LogbookKinerjaDetail resultModel = logbookKinerjaDetailDao.save(logbookKinerjaDetailBaru); LogbookKinerjaDetail resultModel = logbookKinerjaDetailDao.save(logbookKinerjaDetailBaru);
/*
* menghitung capaian indikator satuan yang harus dihitung secara
* rata-rata
*/
if (CommonUtil.isNotNullOrEmpty(resultModel)) { if (CommonUtil.isNotNullOrEmpty(resultModel)) {
/*
* menghitung capaian indikator satuan yang harus dihitung secara
* akumulatif
*/
List<Map<String, Object>> dataSatuanJumlah = logbookKinerjaDetailDao.findSumCapaianByKontrak(
vo.getLogbookKinerja().getNoRec(), Arrays.asList(Master.SatuanIndikator.PERCENTAGE));
if (CommonUtil.isNotNullOrEmpty(dataSatuanJumlah)) {
List<LogbookKinerja> models = new ArrayList<>();
for (Map<String, Object> map : dataSatuanJumlah) {
LogbookKinerja model = logbookKinerjaDao.findOne(map.get("logbookId").toString());
model.setCapaian(Double.valueOf(map.get("sumCapaian").toString()));
models.add(model);
}
logbookKinerjaDao.save(models);
}
/*
* menghitung capaian indikator satuan yang harus dihitung secara
* rata-rata
*/
List<Map<String, Object>> dataSatuanRatarata = logbookKinerjaDetailDao.findAvgCapaianByKontrak( List<Map<String, Object>> dataSatuanRatarata = logbookKinerjaDetailDao.findAvgCapaianByKontrak(
vo.getLogbookKinerja().getNoRec(), Arrays.asList(Master.SatuanIndikator.PERCENTAGE)); vo.getLogbookKinerja().getNoRec(), Arrays.asList(Master.SatuanIndikator.PERCENTAGE));
if (CommonUtil.isNotNullOrEmpty(dataSatuanRatarata)) { if (CommonUtil.isNotNullOrEmpty(dataSatuanRatarata)) {
@ -137,10 +124,8 @@ public class LogbookKinerjaDetailServiceImpl extends BaseVoServiceImpl implement
logbookKinerjaDao.save(models); logbookKinerjaDao.save(models);
} }
} }
LogbookKinerjaDetailVO resultVO = new LogbookKinerjaDetailVO(); LogbookKinerjaDetailVO resultVO = new LogbookKinerjaDetailVO();
resultVO = logbookKinerjaDetailConverter.transferModelToVO(resultModel, resultVO); resultVO = logbookKinerjaDetailConverter.transferModelToVO(resultModel, resultVO);
return resultVO; return resultVO;
} }

View File

@ -76,15 +76,6 @@
<artifactId>itextpdf</artifactId> <artifactId>itextpdf</artifactId>
<version>5.5.9</version> <version>5.5.9</version>
</dependency> </dependency>
<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${project.lombok.version}</version>
<scope>provided</scope>
</dependency>
</dependencies> </dependencies>
<organization> <organization>
<name>Jasa Medika</name> <name>Jasa Medika</name>

View File

@ -1,26 +0,0 @@
package com.jasamedika.medifirst2000.util;
import lombok.AllArgsConstructor;
/**
* @author salmanoe
* @version 1.0.0
* @since 01/12/2023
*/
@AllArgsConstructor
public class DoubleCounter {
private double result;
public synchronized void add(double x) {
result += x;
}
public synchronized void substract(double x) {
result -= x;
}
public synchronized double getResult() {
return result;
}
}