|
@@ -1,4 +1,41 @@
|
|
|
+// import { Component, OnInit } from '@angular/core';
|
|
|
+
|
|
|
+// @Component({
|
|
|
+// selector: 'app-feedback',
|
|
|
+// templateUrl: './feedback.page.html',
|
|
|
+// styleUrls: ['./feedback.page.scss'],
|
|
|
+// })
|
|
|
+// export class FeedbackPage implements OnInit {
|
|
|
+
|
|
|
+// chatMessages: { text: string, sender: string, avatar: string }[] = [];
|
|
|
+// newMessage: string = '';
|
|
|
+
|
|
|
+// constructor() {}
|
|
|
+
|
|
|
+// ngOnInit() {
|
|
|
+// // 模拟一些聊天消息
|
|
|
+// this.chatMessages = [
|
|
|
+// { text: '你好,请问有什么可以帮助您的吗?', sender: 'customer', avatar: 'https://img-bsy.txrpic.com/preview/Element/00/00/89/11/E-891182-2418FE26A.png?imageMogr2/quality/90/thumbnail/320x%3E' },
|
|
|
+// { text: '您好,我想咨询一下关于产品的信息。', sender: 'support', avatar: 'https://tse3-mm.cn.bing.net/th/id/OIP-C.c43kVbudRWN3-pJYtmfugAAAAA?rs=1&pid=ImgDetMain' }
|
|
|
+// ];
|
|
|
+// }
|
|
|
+
|
|
|
+// sendMessage() {
|
|
|
+// if (this.newMessage.trim() !== '') {
|
|
|
+// this.chatMessages.push({ text: this.newMessage, sender: 'customer', avatar: 'https://tse3-mm.cn.bing.net/th/id/OIP-C.c43kVbudRWN3-pJYtmfugAAAAA?rs=1&pid=ImgDetMain' });
|
|
|
+// // 在这里可以添加客服回复的逻辑
|
|
|
+// this.newMessage = '';
|
|
|
+// }
|
|
|
+// }
|
|
|
+
|
|
|
+// }
|
|
|
+
|
|
|
import { Component, OnInit } from '@angular/core';
|
|
|
+import { NavController } from '@ionic/angular';
|
|
|
+import { Router } from '@angular/router';
|
|
|
+import { ActivatedRoute } from '@angular/router';
|
|
|
+import { FormsModule } from '@angular/forms';
|
|
|
+import Parse from "parse";
|
|
|
|
|
|
@Component({
|
|
|
selector: 'app-feedback',
|
|
@@ -6,26 +43,110 @@ import { Component, OnInit } from '@angular/core';
|
|
|
styleUrls: ['./feedback.page.scss'],
|
|
|
})
|
|
|
export class FeedbackPage implements OnInit {
|
|
|
-
|
|
|
- chatMessages: { text: string, sender: string, avatar: string }[] = [];
|
|
|
+ userid: string;
|
|
|
+ messageList:any = []
|
|
|
+ messages = [
|
|
|
+ { type: 'received', avatar: '/assets/img/support-avatar.png', time: '10:30 AM', text: 'Hi there!' },
|
|
|
+ { type: 'sent', avatar: '/assets/img/b.png', time: '10:31 AM', text: 'Hey! How are you?' },
|
|
|
+ // Add more messages as needed
|
|
|
+ ];
|
|
|
+
|
|
|
newMessage: string = '';
|
|
|
|
|
|
- constructor() {}
|
|
|
+ constructor(private route: ActivatedRoute) {
|
|
|
+ this.userid = this.route.snapshot.paramMap.get('userid') as string;
|
|
|
+ this.targetId = this.userid
|
|
|
+ }
|
|
|
|
|
|
- ngOnInit() {
|
|
|
- // 模拟一些聊天消息
|
|
|
- this.chatMessages = [
|
|
|
- { text: '你好,请问有什么可以帮助您的吗?', sender: 'customer', avatar: 'https://img-bsy.txrpic.com/preview/Element/00/00/89/11/E-891182-2418FE26A.png?imageMogr2/quality/90/thumbnail/320x%3E' },
|
|
|
- { text: '您好,我想咨询一下关于产品的信息。', sender: 'support', avatar: 'https://tse3-mm.cn.bing.net/th/id/OIP-C.c43kVbudRWN3-pJYtmfugAAAAA?rs=1&pid=ImgDetMain' }
|
|
|
- ];
|
|
|
+ contact:Parse.Object|undefined
|
|
|
+ user:Parse.User|undefined
|
|
|
+ targetId:string |undefined
|
|
|
+ async ngOnInit() {
|
|
|
+ this.user = Parse.User.current()
|
|
|
+ let fromId = Parse.User.current()?.id
|
|
|
+ if(this.userid && fromId){
|
|
|
+ let query = new Parse.Query("Contact");
|
|
|
+ query.include("to")
|
|
|
+ query.equalTo("from",fromId);
|
|
|
+ query.equalTo("to",this.userid);
|
|
|
+ this.contact = await query.first();
|
|
|
+ }
|
|
|
+ this.loadHistory();
|
|
|
+ return
|
|
|
}
|
|
|
+ async sendMessage() {
|
|
|
+ if (this.newMessage.trim() === '') {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ let sendUser = Parse.User?.current()?.toPointer()
|
|
|
+ let receiveUser = {__type:"Pointer",className:"_User",objectId:this.userid}
|
|
|
+ let Message = Parse.Object.extend("Message");
|
|
|
+ let message = new Message();
|
|
|
+ message.set("sendUser",sendUser)
|
|
|
+ message.set("receiveUser",receiveUser)
|
|
|
+ message.set("contentJson",{
|
|
|
+ role:"user",
|
|
|
+ content: this.newMessage
|
|
|
+ })
|
|
|
+ message = await message.save()
|
|
|
+ if(message?.id){
|
|
|
+ this.messageList.push(message)
|
|
|
+ this.syncSession(message,sendUser,receiveUser);
|
|
|
+ }
|
|
|
+ this.newMessage = '';
|
|
|
|
|
|
- sendMessage() {
|
|
|
- if (this.newMessage.trim() !== '') {
|
|
|
- this.chatMessages.push({ text: this.newMessage, sender: 'customer', avatar: 'https://tse3-mm.cn.bing.net/th/id/OIP-C.c43kVbudRWN3-pJYtmfugAAAAA?rs=1&pid=ImgDetMain' });
|
|
|
- // 在这里可以添加客服回复的逻辑
|
|
|
- this.newMessage = '';
|
|
|
+ this.loadHistory();
|
|
|
+ }
|
|
|
+ async syncSession(message:any,sendUser:any,receiveUser:any){
|
|
|
+ // 根据当前聊天,更新最新的会话状态表 MessageSession 记录最新的会话
|
|
|
+ let session = await this.checkSessionExists();
|
|
|
+ if(!session?.id){
|
|
|
+ let MessageSession = Parse.Object.extend("MessageSession")
|
|
|
+ session = new MessageSession()
|
|
|
}
|
|
|
+ session?.set("message",message?.toPointer())
|
|
|
+ session?.set("sendUser",sendUser)
|
|
|
+ session?.set("receiveUser",receiveUser)
|
|
|
+ session?.save();
|
|
|
+ }
|
|
|
+ async checkSessionExists(){
|
|
|
+ let query = Parse.Query.fromJSON('MessageSession',{where: {
|
|
|
+ $or: [
|
|
|
+ {
|
|
|
+ sendUser: this.user?.id,
|
|
|
+ receiveUser: this.targetId
|
|
|
+ },
|
|
|
+ {
|
|
|
+ sendUser: this.targetId,
|
|
|
+ receiveUser: this.user?.id
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }})
|
|
|
+ return await query.first()
|
|
|
}
|
|
|
|
|
|
+ getCurrentTime() {
|
|
|
+ const now = new Date();
|
|
|
+ return now.toLocaleTimeString([], { hour: '2-digit', minute: '2-digit' });
|
|
|
+ }
|
|
|
+
|
|
|
+ async loadHistory(){
|
|
|
+ let query = Parse.Query.fromJSON('Message',{where: {
|
|
|
+ $or: [
|
|
|
+ {
|
|
|
+ sendUser: this.user?.id,
|
|
|
+ receiveUser: this.targetId
|
|
|
+ },
|
|
|
+ {
|
|
|
+ sendUser: this.targetId,
|
|
|
+ receiveUser: this.user?.id
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }})
|
|
|
+
|
|
|
+ let list = await query.find();
|
|
|
+ if(list?.length){
|
|
|
+ this.messageList = list
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|