From d54da4786548ef4c4ea4d62b2754cfed2b24a698 Mon Sep 17 00:00:00 2001
From: wayne <wayne8692wayne8692@gmail.com>
Date: 星期四, 10 二月 2022 15:54:18 +0800
Subject: [PATCH] [update][todo 135158] 列出滿意度問卷也需要包含系統滿意度問卷

---
 pamapi/src/main/java/com/pollex/pam/service/SatisfactionService.java |   42 +++++++++++++++++++++++++++++++-----------
 1 files changed, 31 insertions(+), 11 deletions(-)

diff --git a/pamapi/src/main/java/com/pollex/pam/service/SatisfactionService.java b/pamapi/src/main/java/com/pollex/pam/service/SatisfactionService.java
index 0fa1b91..1d700eb 100644
--- a/pamapi/src/main/java/com/pollex/pam/service/SatisfactionService.java
+++ b/pamapi/src/main/java/com/pollex/pam/service/SatisfactionService.java
@@ -7,6 +7,8 @@
 import com.pollex.pam.enums.SatisfactionTypeEnum;
 import com.pollex.pam.security.SecurityUtils;
 import com.pollex.pam.service.dto.SatisfactionSystemScoreDTO;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -28,6 +30,8 @@
 @Service
 @Transactional
 public class SatisfactionService {
+
+    private static final Logger log = LoggerFactory.getLogger(SatisfactionService.class);
 
 	@Autowired
 	SatisfactionRepository satisfactionRepository;
@@ -60,7 +64,7 @@
 	}
 
 	public Satisfaction scorefaction(SatisfactionCustomerScoreDTO scoreDTO) {
-		Optional<Satisfaction> satisfactionOP = getByAppointmentId(scoreDTO.getAppointmentId());
+		Optional<Satisfaction> satisfactionOP = getByAppointmentIdAndType(scoreDTO.getAppointmentId(), SatisfactionTypeEnum.APPOINTMENT);
 		Satisfaction satisfaction = satisfactionOP.orElseThrow(SatisfactionNotFoundException::new);
 		satisfaction.setScore(scoreDTO.getScore());
 		satisfaction.setStatus(SatisfactionStatusEnum.FILLED);
@@ -71,7 +75,7 @@
 	}
 
 	public Satisfaction createAppointmentSatisfaction(Appointment appointment) {
-		boolean isexist = getByAppointmentId(appointment.getId()).isPresent();
+		boolean isexist = getByAppointmentIdAndType(appointment.getId(), SatisfactionTypeEnum.APPOINTMENT).isPresent();
 		if(isexist) {
 			throw new SatisfactionAlreadyExistException();
 		}
@@ -89,13 +93,13 @@
 		return satisfactionMapper.toDTO(satisfactionList);
 	}
 
-	public List<SatisfactionDTO> getByCustomerIdAndType(Long customerDBId, SatisfactionTypeEnum type) {
-		List<Satisfaction> satisfactionList = satisfactionRepository.findByCustomerIdAndType(customerDBId, type);
+	public List<SatisfactionDTO> getByCustomerId(Long customerDBId) {
+		List<Satisfaction> satisfactionList = satisfactionRepository.findByCustomerId(customerDBId);
 		return satisfactionMapper.toDTO(satisfactionList);
 	}
 
-    public Optional<Satisfaction> getByAppointmentId(Long appointmentId) {
-        return satisfactionRepository.findOneByAppointmentId(appointmentId);
+    public Optional<Satisfaction> getByAppointmentIdAndType(Long appointmentId, SatisfactionTypeEnum type) {
+        return satisfactionRepository.findOneByAppointmentIdAndType(appointmentId, type);
     }
 
     public List<Satisfaction> getByStatusAndType(SatisfactionStatusEnum status, SatisfactionTypeEnum type) {
@@ -110,13 +114,29 @@
 		return satisfactionList;
 	}
 
-    public Satisfaction createSystemSatisfaction(SatisfactionSystemScoreDTO scoreDTO) {
+    public void createUnfilledSystemSatisfaction(Appointment appointment) {
         Satisfaction satisfaction = new Satisfaction();
+        satisfaction.setAppointmentId(appointment.getId());
         satisfaction.setCustomerId(SecurityUtils.getCustomerDBId());
-        satisfaction.setAppointmentId(scoreDTO.getAppointmentId());
-        satisfaction.setStatus(SatisfactionStatusEnum.FILLED);
-        satisfaction.setScore(scoreDTO.getScore());
+        satisfaction.setStatus(SatisfactionStatusEnum.UNFILLED);
         satisfaction.setType(SatisfactionTypeEnum.SYSTEM);
-        return satisfactionRepository.save(satisfaction);
+
+        satisfactionRepository.save(satisfaction);
+    }
+
+    public Satisfaction fillSystemSatisfaction(SatisfactionSystemScoreDTO scoreDTO) {
+        Optional<Satisfaction> systemSatisfactionOptional =
+            satisfactionRepository.findOneByAppointmentIdAndType(scoreDTO.getAppointmentId(), SatisfactionTypeEnum.SYSTEM);
+
+        if(systemSatisfactionOptional.isPresent()) {
+            Satisfaction satisfaction = systemSatisfactionOptional.get();
+            satisfaction.setStatus(SatisfactionStatusEnum.FILLED);
+            satisfaction.setScore(scoreDTO.getScore());
+            return satisfactionRepository.save(satisfaction);
+        }
+        else {
+            log.warn("not found the satisfaction record, so can't fill system satisfaction");
+            return null;
+        }
     }
 }

--
Gitblit v1.8.0