From 40ba87b958d3b53f2eef4f95eb3add6548f35006 Mon Sep 17 00:00:00 2001
From: wayne <wayne8692wayne8692@gmail.com>
Date: 星期五, 03 十二月 2021 11:18:48 +0800
Subject: [PATCH] [update] 我的顧問清單新增預約單歷史明細、預約單的更新API、預約單的邏輯刪除API

---
 pamapi/src/main/java/com/pollex/pam/web/rest/ConsultantResource.java |   47 ++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 38 insertions(+), 9 deletions(-)

diff --git a/pamapi/src/main/java/com/pollex/pam/web/rest/ConsultantResource.java b/pamapi/src/main/java/com/pollex/pam/web/rest/ConsultantResource.java
index eb20daf..d672590 100644
--- a/pamapi/src/main/java/com/pollex/pam/web/rest/ConsultantResource.java
+++ b/pamapi/src/main/java/com/pollex/pam/web/rest/ConsultantResource.java
@@ -1,26 +1,32 @@
 package com.pollex.pam.web.rest;
 
+import com.pollex.pam.service.AppointmentService;
 import com.pollex.pam.service.ConsultantService;
 import com.pollex.pam.service.dto.*;
+import org.apache.commons.compress.utils.IOUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.core.io.ClassPathResource;
+import org.springframework.core.io.Resource;
 import org.springframework.http.HttpStatus;
+import org.springframework.http.MediaType;
 import org.springframework.http.ResponseEntity;
 import org.springframework.web.bind.annotation.*;
 
+import java.io.FileNotFoundException;
+import java.io.IOException;
+import java.io.InputStream;
 import java.util.List;
 
 @RestController
 @RequestMapping("/api/consultant")
 public class ConsultantResource {
 
-    private final ConsultantService consultantService;
-
-    public ConsultantResource(ConsultantService consultantService) {
-        this.consultantService = consultantService;
-    }
+    @Autowired
+    ConsultantService consultantService;
 
     @GetMapping("/favorite")
-    public ResponseEntity<List<ConsultantDTO>> getMyConsultantList() {
-        List<ConsultantDTO> myConsultants = consultantService.getMyConsultantList();
+    public ResponseEntity<List<CustomerFavoriteConsultantDTO>> getMyConsultantList() {
+        List<CustomerFavoriteConsultantDTO> myConsultants = consultantService.getMyConsultantList();
         return new ResponseEntity<>(myConsultants, HttpStatus.OK);
     }
 
@@ -35,6 +41,13 @@
         consultantService.addConsultantToCustomList(param);
         return new ResponseEntity<>(HttpStatus.ACCEPTED);
     }
+
+    @DeleteMapping("/favorite/{agentNo}")
+    public ResponseEntity<Void> removeConsultantFromCustomList(@PathVariable String agentNo) {
+        consultantService.removeConsultantFromCustomList(agentNo);
+        return new ResponseEntity<>(HttpStatus.OK);
+    }
+
 
     @PostMapping("/strictQuery")
     public ResponseEntity<List<ConsultantDTO>> strictQueryConsultant(@RequestBody StrictQueryConsultantParam param) {
@@ -53,10 +66,26 @@
         ConsultantDetailDTO result = consultantService.getConsultantDetail(agentNo);
         return new ResponseEntity<>(result, HttpStatus.OK);
     }
-    
+
     @GetMapping("/getMyAppointment")
     public List<AppointmentCustomerViewDTO> getMyAppointment() {
     	return consultantService.getMyAppointment();
     }
-    
+
+    @GetMapping(value = "/avatar/{fileName}", produces = MediaType.IMAGE_JPEG_VALUE)
+    public ResponseEntity<byte[]> getAvatarImage(@PathVariable String fileName) throws IOException {
+        try {
+            Resource resource = new ClassPathResource("static/consultant/" + fileName);
+            InputStream in = resource.getInputStream();
+            return new ResponseEntity<>(IOUtils.toByteArray(in), HttpStatus.OK);
+        } catch (FileNotFoundException e) {
+            return new ResponseEntity<>(HttpStatus.NOT_FOUND);
+        }
+    }
+
+    @PostMapping("/record/allAppointmentsView")
+    public ResponseEntity<Void> recordAllAppointmentsView() {
+        consultantService.recordAllAppointmentsView();
+        return ResponseEntity.noContent().build();
+    }
 }

--
Gitblit v1.8.0