From f5831acafe510f9a79f8e2ecf6dee09026d67fc6 Mon Sep 17 00:00:00 2001
From: HelenHuang <LinHuang@pollex.com.tw>
Date: 星期四, 20 一月 2022 16:09:09 +0800
Subject: [PATCH] Merge branch 'Phase3' of https://dev.pollex.com.tw:8443/r/pcalife/PAM into Phase3

---
 pamapi/src/main/java/com/pollex/pam/service/SatisfactionService.java |   59 +++++++++++++++++++++++++++--------------------------------
 1 files changed, 27 insertions(+), 32 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 9f8ee6c..70de68f 100644
--- a/pamapi/src/main/java/com/pollex/pam/service/SatisfactionService.java
+++ b/pamapi/src/main/java/com/pollex/pam/service/SatisfactionService.java
@@ -1,6 +1,5 @@
 package com.pollex.pam.service;
 
-import java.math.BigDecimal;
 import java.util.List;
 import java.util.Optional;
 
@@ -9,16 +8,18 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import com.pollex.pam.domain.Appointment;
-import com.pollex.pam.domain.Consultant;
 import com.pollex.pam.domain.Satisfaction;
+import com.pollex.pam.enums.SatisfactionStatusEnum;
 import com.pollex.pam.repository.ConsultantRepository;
 import com.pollex.pam.repository.CustomerRepository;
 import com.pollex.pam.repository.SatisfactionRepository;
-import com.pollex.pam.service.dto.SatisfactionCustomerCreateDTO;
+import com.pollex.pam.service.dto.SatisfactionCustomerScoreDTO;
 import com.pollex.pam.service.dto.SatisfactionDTO;
 import com.pollex.pam.service.mapper.AppointmentMapper;
 import com.pollex.pam.service.mapper.SatisfactionDTOMapper;
 import com.pollex.pam.service.mapper.SatisfactionMapper;
+import com.pollex.pam.web.rest.errors.SatisfactionAlreadyExistException;
+import com.pollex.pam.web.rest.errors.SatisfactionNotFoundException;
 
 @Service
 @Transactional
@@ -41,44 +42,38 @@
 	
 	@Autowired
 	ConsultantRepository consultantRepository;
+	
+	@Autowired
+	ConsultantService consultantService;
 
-	public Satisfaction createSatisfaction(Satisfaction satisfaction) {
+	public Satisfaction save(Satisfaction satisfaction) {
 		satisfaction = satisfactionRepository.save(satisfaction);
-		setConsultantAvgScore(satisfaction);
+		consultantService.setConsultantAvgScore(satisfaction);
 		return satisfaction;
 	}
-
-
-
-	private void setConsultantAvgScore(Satisfaction satisfaction) {
-		float avgScore = getAgentAvgScore(satisfaction);
-		Consultant consultant = consultantRepository.findOneByAgentNo(satisfaction.getAgentNo())
-				.get();
-		consultant.setAvgScore(avgScore);
-		consultantRepository.save(consultant);
-	}
-
-
-
-	private float getAgentAvgScore(Satisfaction satisfaction) {
-		Float avgScore = satisfactionRepository.getAgentScoreAvg(satisfaction.getAgentNo());
-		BigDecimal bigDecimal = new BigDecimal(avgScore);  
-		return avgScore = bigDecimal.setScale(1,BigDecimal.ROUND_HALF_UP).floatValue();
-	}
-	 
 	
+	public Satisfaction scorefaction(SatisfactionCustomerScoreDTO scoreDTO) {
+		Optional<Satisfaction> satisfactionOP = getByAppointmentId(scoreDTO.getAppointmentId());
+		Satisfaction satisfaction = satisfactionOP.orElseThrow(SatisfactionNotFoundException::new);
+		satisfaction.setScore(scoreDTO.getScore());
+		satisfaction.setStatus(SatisfactionStatusEnum.FILLED);
+		return save(satisfaction);
+	}
 
+	
 	public Satisfaction createSatisfaction(Appointment appointment) {
+		boolean isexist = getByAppointmentId(appointment.getId()).isPresent();
+		if(isexist) {
+			throw new SatisfactionAlreadyExistException();
+		}
 		Satisfaction satisfaction = appointmentMapper.toSatisfaction(appointment);
-		return createSatisfaction(satisfaction);
+		return save(satisfaction);
 	}
-
-	public Satisfaction createSatisfaction(SatisfactionCustomerCreateDTO createDTO) {
-		// todo : 撠璅�歇�蝯∠���銝府�隞交憓遛��漲閰��
-		// todo : ��撌梁���銝府�隞仿�脰����
-		Satisfaction satisfaction = satisfactionDTOMapper.toSatisfaction(createDTO);
-		return createSatisfaction(satisfaction);
-	}
+//
+//	public Satisfaction createSatisfaction(SatisfactionCustomerScoreDTO createDTO) {
+//		Satisfaction satisfaction = satisfactionDTOMapper.toSatisfaction(createDTO);
+//		return save(satisfaction);
+//	}
 
 	public List<SatisfactionDTO> getByAgentNo(String agentNo) {
 		List<Satisfaction> satisfactionList = satisfactionRepository.findByAgentNo(agentNo);

--
Gitblit v1.8.0