From c2d8465faade429e8b8f677864b0bc2da763e71c Mon Sep 17 00:00:00 2001
From: Tomas <tomasysh@gmail.com>
Date: 星期二, 23 十一月 2021 11:57:55 +0800
Subject: [PATCH] Merge branch 'master' of ssh://192.168.0.10:29418/pcalife/PAM

---
 pamapi/src/main/java/com/pollex/pam/service/mapper/ConsultantMapper.java |   47 ++++++++++++++++++++++++++++++++---------------
 1 files changed, 32 insertions(+), 15 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 782e459..138c713 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
@@ -1,16 +1,17 @@
 package com.pollex.pam.service.mapper;
 
+import com.pollex.pam.domain.Appointment;
 import com.pollex.pam.domain.Consultant;
-import com.pollex.pam.domain.CustomFavoriteConsultant;
+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 org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
-import java.time.Instant;
-import java.util.Arrays;
-import java.util.List;
+import java.util.*;
 import java.util.stream.Collectors;
 
 @Service
@@ -18,7 +19,9 @@
 
     private final static Character SPLIT_MASK = ',';
 
-    // todo convert
+    @Autowired
+    AppointmentService appointmentService;
+
     public ConsultantDTO toDto(Consultant source) {
         ConsultantDTO consultantDTO = new ConsultantDTO();
         consultantDTO.setAgentNo(source.getAgentNo());
@@ -26,22 +29,35 @@
         consultantDTO.setAvgScore(source.getAvgScore());
         consultantDTO.setSeniority(source.getSeniority());
         consultantDTO.setExpertise(splitStringWithChar(source.getExpertise()));
+        consultantDTO.setImg(source.getPhotoPath());
+        consultantDTO.setRole(source.getRole());
 
-        // todo
-        consultantDTO.setImg("");
         consultantDTO.setContactStatus(null);
         consultantDTO.setUpdateTime(null);
+        consultantDTO.setLatestAppointmentId(null);
 
         return consultantDTO;
     }
 
-    public ConsultantDTO toDto(CustomFavoriteConsultant customFavoriteConsultant) {
-        Consultant consultant = customFavoriteConsultant.getConsultant();
+    public ConsultantDTO toDto(CustomerFavoriteConsultant customerFavoriteConsultant) {
+        Consultant consultant = customerFavoriteConsultant.getConsultant();
         ConsultantDTO dto = toDto(consultant);
 
-        Instant updateTime = customFavoriteConsultant.getLastModifiedDate();
-        dto.setContactStatus(customFavoriteConsultant.getContactStatus());
-        dto.setUpdateTime(updateTime);
+        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;
     }
@@ -60,10 +76,11 @@
         consultantDetailDTO.setSeniority(source.getSeniority());
         consultantDetailDTO.setConcept(source.getConcept());
         consultantDetailDTO.setAwards(source.getAward());
+        consultantDetailDTO.setImage(source.getPhotoPath());
 
-        consultantDetailDTO.setImage("");
-        consultantDetailDTO.setSuitability(0);
-        consultantDetailDTO.setEvaluation(0);
+        // todo 瘙箏����漲
+        consultantDetailDTO.setSuitability(50);
+        consultantDetailDTO.setEvaluation(50);
         consultantDetailDTO.setExpertises(splitStringWithChar(source.getExpertise()));
         consultantDetailDTO.setExperiences(splitStringWithChar(source.getExperience()));
 

--
Gitblit v1.8.0