From 0ddca4b46f3c9b34b018c66893b8c30624720c79 Mon Sep 17 00:00:00 2001
From: Jack <jack.su@pollex.com.tw>
Date: 星期五, 07 一月 2022 16:21:10 +0800
Subject: [PATCH] [ADD] 新增約訪紀錄API [ADD] 修改約訪記錄API [ADD] 刪除約訪記錄API [ADD] 取得顧問所有預約單的API新增約訪紀錄資料

---
 pamapi/src/main/java/com/pollex/pam/domain/Appointment.java |   81 +++++++++++++++++++++++++++++++++++++++-
 1 files changed, 78 insertions(+), 3 deletions(-)

diff --git a/pamapi/src/main/java/com/pollex/pam/domain/Appointment.java b/pamapi/src/main/java/com/pollex/pam/domain/Appointment.java
index 53fbd36..6dbf168 100644
--- a/pamapi/src/main/java/com/pollex/pam/domain/Appointment.java
+++ b/pamapi/src/main/java/com/pollex/pam/domain/Appointment.java
@@ -2,10 +2,13 @@
 
 import java.io.Serializable;
 import java.time.Instant;
+import java.util.List;
 
 import javax.persistence.*;
 
+import com.pollex.pam.enums.AppointmentStatusEnum;
 import com.pollex.pam.enums.ContactStatusEnum;
+import org.springframework.data.annotation.CreatedDate;
 import org.springframework.data.annotation.LastModifiedDate;
 import org.springframework.data.jpa.domain.support.AuditingEntityListener;
 
@@ -54,15 +57,35 @@
 	@Column(name = "other_requirement")
     private String otherRequirement;
 
-    @LastModifiedDate
-	@Column(name = "appointment_date")
-    private Instant appointmentDate;
+    @CreatedDate
+	@Column(name = "appointment_date", updatable = false)
+    private Instant appointmentDate = Instant.now();
+
+    @Column(name = "last_modified_date")
+    private Instant lastModifiedDate = Instant.now();
 
 	@Column(name = "agent_no")
     private String agentNo;
 
 	@Column(name = "customer_id")
     private Long customerId;
+
+    @Column(name = "consultant_view_time")
+    private Instant consultantViewTime;
+
+    @Column(name = "consultant_read_time")
+    private Instant consultantReadTime;
+
+    @Column(name = "contact_time")
+    private Instant contactTime;
+
+    @Enumerated(value = EnumType.STRING)
+    @Column(name = "status")
+    private AppointmentStatusEnum status;
+    
+    @JoinColumn(name = "appointment_id")
+    @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.REMOVE)
+    private List<AppointmentMemo> appointmentMemoList;
 
 	public Long getId() {
 		return id;
@@ -175,4 +198,56 @@
 	public void setCustomerId(Long customerId) {
 		this.customerId = customerId;
 	}
+
+    public Instant getConsultantViewTime() {
+        return consultantViewTime;
+    }
+
+    public void setConsultantViewTime(Instant consultantViewTime) {
+        this.consultantViewTime = consultantViewTime;
+    }
+
+    public Instant getConsultantReadTime() {
+        return consultantReadTime;
+    }
+
+    public void setConsultantReadTime(Instant consultantReadTime) {
+        this.consultantReadTime = consultantReadTime;
+    }
+
+    public Instant getContactTime() {
+        return contactTime;
+    }
+
+    public void setContactTime(Instant markCommunicateTime) {
+        this.contactTime = markCommunicateTime;
+    }
+
+    public AppointmentStatusEnum getStatus() {
+        return status;
+    }
+
+    public void setStatus(AppointmentStatusEnum status) {
+        this.status = status;
+    }
+
+    public Instant getLastModifiedDate() {
+        return lastModifiedDate;
+    }
+
+    public void setLastModifiedDate(Instant lastModifiedDate) {
+        this.lastModifiedDate = lastModifiedDate;
+    }
+
+	public List<AppointmentMemo> getAppointmentMemoList() {
+		return appointmentMemoList;
+	}
+
+	public void setAppointmentMemoList(List<AppointmentMemo> appointmentMemoList) {
+		this.appointmentMemoList = appointmentMemoList;
+	}
+    
+    
+    
+    
 }

--
Gitblit v1.8.0