From fa782dca2a00e9a4a48c5b3588f5eb3b47af93cf Mon Sep 17 00:00:00 2001
From: wayne <wayne8692wayne8692@gmail.com>
Date: 星期二, 01 三月 2022 15:41:05 +0800
Subject: [PATCH] [update] [todo 136031] 諮詢度表現,提供前端該顧問所有預約單數量以及近一個月的預約單數量

---
 pamapi/src/main/java/com/pollex/pam/service/mapper/ConsultantMapper.java |   73 +++++++++++++++++++-----------------
 1 files changed, 39 insertions(+), 34 deletions(-)

diff --git a/pamapi/src/main/java/com/pollex/pam/service/mapper/ConsultantMapper.java b/pamapi/src/main/java/com/pollex/pam/service/mapper/ConsultantMapper.java
index 8a8d485..a5f8a21 100644
--- a/pamapi/src/main/java/com/pollex/pam/service/mapper/ConsultantMapper.java
+++ b/pamapi/src/main/java/com/pollex/pam/service/mapper/ConsultantMapper.java
@@ -2,25 +2,43 @@
 
 import com.pollex.pam.domain.Appointment;
 import com.pollex.pam.domain.Consultant;
-import com.pollex.pam.domain.CustomerFavoriteConsultant;
-import com.pollex.pam.enums.ContactStatusEnum;
 import com.pollex.pam.service.AppointmentService;
 import com.pollex.pam.service.dto.ConsultantDTO;
 import com.pollex.pam.service.dto.ConsultantDetailDTO;
+import com.pollex.pam.service.dto.CustomerFavoriteConsultantDTO;
 import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
+import java.time.Instant;
+import java.time.ZonedDateTime;
 import java.util.*;
 import java.util.stream.Collectors;
 
 @Service
 public class ConsultantMapper {
 
-    private static final Character SPLIT_MASK = ',';
-
     @Autowired
     AppointmentService appointmentService;
+
+    private static final Character SPLIT_MASK = ',';
+
+    public CustomerFavoriteConsultantDTO toCustomerFavoriteConsultantDto(Consultant source) {
+        CustomerFavoriteConsultantDTO consultantDTO = new CustomerFavoriteConsultantDTO();
+        consultantDTO.setAgentNo(source.getAgentNo());
+        consultantDTO.setName(source.getName());
+        consultantDTO.setAvgScore(source.getAvgScore());
+        consultantDTO.setSeniority(source.getSeniorityDTOString());
+        consultantDTO.setExpertise(splitStringWithChar(source.getExpertise()));
+        consultantDTO.setImg(source.getPhotoPath());
+        consultantDTO.setRole(source.getRole());
+
+        consultantDTO.setContactStatus(null);
+        consultantDTO.setUpdateTime(null);
+
+        return consultantDTO;
+    }
 
     public ConsultantDTO toDto(Consultant source) {
         ConsultantDTO consultantDTO = new ConsultantDTO();
@@ -32,38 +50,17 @@
         consultantDTO.setImg(source.getPhotoPath());
         consultantDTO.setRole(source.getRole());
 
+        consultantDTO.setSuitability(0);
         consultantDTO.setContactStatus(null);
         consultantDTO.setUpdateTime(null);
-        consultantDTO.setLatestAppointmentId(null);
+//        consultantDTO.setLatestAppointmentId(null);
 
         return consultantDTO;
     }
 
-    public ConsultantDTO toDto(CustomerFavoriteConsultant customerFavoriteConsultant) {
-        Consultant consultant = customerFavoriteConsultant.getConsultant();
-        ConsultantDTO dto = toDto(consultant);
-
-        final Optional<Appointment> latestAppointmentOptional = appointmentService.findByAgentNoAndCustomerId(consultant.getAgentNo(), customerFavoriteConsultant.getCustomerId())
-            .stream()
-            .max(Comparator.comparing(Appointment::getAppointmentDate));
-
-        if(latestAppointmentOptional.isPresent()) {
-            Appointment latestAppointment = latestAppointmentOptional.get();
-            dto.setContactStatus(latestAppointment.getCommunicateStatus());
-            dto.setLatestAppointmentId(latestAppointment.getId());
-            dto.setUpdateTime(latestAppointment.getAppointmentDate());
-        }
-        else {
-            dto.setContactStatus(ContactStatusEnum.PICKED);
-            dto.setLatestAppointmentId(null);
-            dto.setUpdateTime(customerFavoriteConsultant.getLastModifiedDate());
-        }
-
-        return dto;
-    }
-
     public ConsultantDetailDTO toDetailDto(Consultant source) {
         ConsultantDetailDTO consultantDetailDTO = new ConsultantDetailDTO();
+        BeanUtils.copyProperties(source, consultantDetailDTO);
         consultantDetailDTO.setName(source.getName());
         consultantDetailDTO.setAgentNo(source.getAgentNo());
         consultantDetailDTO.setRole(source.getRole());
@@ -75,13 +72,21 @@
         consultantDetailDTO.setSeniority(source.getSeniorityDTOString());
         consultantDetailDTO.setConcept(source.getConcept());
         consultantDetailDTO.setAwards(source.getAward());
-        consultantDetailDTO.setImage(source.getPhotoPath());
-        consultantDetailDTO.setExpertises(splitStringWithChar(source.getExpertise()));
-        consultantDetailDTO.setExperiences(splitStringWithChar(source.getExperience()));
+        consultantDetailDTO.setImg(source.getPhotoPath());
+        consultantDetailDTO.setExpertise(splitStringWithChar(source.getExpertise()));
+        consultantDetailDTO.setExperiences(source.getExperience());
 
-        // todo 瘙箏����漲
-        consultantDetailDTO.setSuitability(50);
-        consultantDetailDTO.setEvaluation(50);
+        List<Appointment> appointments = appointmentService.findByAgentNo(source.getAgentNo());
+        long allAppointmentCount = appointments.size();
+        long nearlyMonthAppointmentCount = appointments
+            .stream()
+            .filter(appointment -> {
+                Instant oneMonthAgo = ZonedDateTime.now().minusMonths(1).toInstant();
+                return appointment.getAppointmentDate().isAfter(oneMonthAgo);
+            }).count();
+
+        consultantDetailDTO.setAllAppointmentCount(allAppointmentCount);
+        consultantDetailDTO.setNearlyMonthAppointmentCount(nearlyMonthAppointmentCount);
 
         return consultantDetailDTO;
     }

--
Gitblit v1.8.0