Update service logbook kinerja
Penerapan hitung akumulasi capaian by database
This commit is contained in:
parent
6006e2ceb7
commit
adddffcc75
@ -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> {
|
||||||
|
|||||||
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -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>
|
||||||
|
|||||||
@ -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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Loading…
x
Reference in New Issue
Block a user