2022-01-10 23:52:33 +01:00
|
|
|
import { Injectable } from '@angular/core'
|
2022-01-12 12:44:51 +01:00
|
|
|
import { WsChatService } from 'src/app/services/chat/ws-chat.service';
|
2022-01-10 23:52:33 +01:00
|
|
|
import { MessageService } from 'src/app/services/chat/message.service'
|
|
|
|
|
import { ChatUserService } from 'src/app/services/chat/chat-user.service'
|
2022-01-11 20:56:21 +01:00
|
|
|
import { showDateDuration } from 'src/plugin/showDateDuration'
|
2022-01-13 10:19:14 +01:00
|
|
|
import { ToastsService } from '../toast.service';
|
|
|
|
|
|
2022-01-10 13:31:15 +01:00
|
|
|
@Injectable({
|
|
|
|
|
providedIn: 'root'
|
|
|
|
|
})
|
|
|
|
|
export class RoomService {
|
|
|
|
|
|
2022-01-11 16:07:54 +01:00
|
|
|
massages: MessageService[] = []
|
2022-01-11 13:03:43 +01:00
|
|
|
lastMessage: MessageService;
|
|
|
|
|
|
2022-01-10 23:52:33 +01:00
|
|
|
chatUser: ChatUserService[] = []
|
2022-01-11 13:03:43 +01:00
|
|
|
id = ''
|
|
|
|
|
name = ''
|
2022-01-11 20:56:21 +01:00
|
|
|
_updatedAt = {}
|
2022-01-11 15:43:09 +01:00
|
|
|
private hasLoadHistory = false
|
2022-01-11 20:56:21 +01:00
|
|
|
duration = ''
|
|
|
|
|
|
2022-01-13 10:26:40 +01:00
|
|
|
private ToastService = ToastsService
|
2022-01-10 23:52:33 +01:00
|
|
|
|
|
|
|
|
constructor(
|
2022-01-12 12:44:51 +01:00
|
|
|
public WsChatService: WsChatService,
|
2022-01-11 20:56:21 +01:00
|
|
|
private MessageService: MessageService,
|
|
|
|
|
) {}
|
2022-01-10 23:52:33 +01:00
|
|
|
|
2022-01-11 20:56:21 +01:00
|
|
|
setData({id, name, lastMessage, _updatedAt}) {
|
2022-01-11 13:03:43 +01:00
|
|
|
this.id = id
|
|
|
|
|
this.name = name
|
|
|
|
|
this.lastMessage = lastMessage
|
2022-01-11 20:56:21 +01:00
|
|
|
this._updatedAt = _updatedAt
|
|
|
|
|
|
|
|
|
|
this.calDateDuration()
|
2022-01-10 23:52:33 +01:00
|
|
|
}
|
|
|
|
|
|
2022-01-11 15:43:09 +01:00
|
|
|
receiveMessage() {
|
2022-01-12 12:44:51 +01:00
|
|
|
this.WsChatService.receiveLiveMessageFromRoom(
|
2022-01-11 15:43:09 +01:00
|
|
|
this.id,
|
2022-01-11 19:49:43 +01:00
|
|
|
(Chatmessage) => {
|
2022-01-11 20:56:21 +01:00
|
|
|
|
|
|
|
|
Chatmessage = this.fix_updatedAt(Chatmessage)
|
2022-01-11 19:49:43 +01:00
|
|
|
const message = new MessageService()
|
|
|
|
|
message.setData(Chatmessage.result)
|
|
|
|
|
this.massages.push(message)
|
2022-01-11 20:56:21 +01:00
|
|
|
this.calDateDuration(Chatmessage.result._updatedAt)
|
2022-01-13 10:19:14 +01:00
|
|
|
this.ToastService.presentToast('nova mensagem')
|
2022-01-11 15:43:09 +01:00
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
send(msg) {
|
2022-01-12 12:44:51 +01:00
|
|
|
this.WsChatService.send(this.id, msg)
|
2022-01-11 15:43:09 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// runs onces only
|
|
|
|
|
loadHistory(limit= 100) {
|
|
|
|
|
|
2022-01-12 11:52:05 +01:00
|
|
|
if(this.hasLoadHistory){ return false}
|
2022-01-11 15:43:09 +01:00
|
|
|
|
2022-01-12 12:44:51 +01:00
|
|
|
this.WsChatService.loadHistory(this.id, limit).then((message:any) => {
|
2022-01-11 15:43:09 +01:00
|
|
|
console.log('loadHistory', message)
|
2022-01-11 16:07:54 +01:00
|
|
|
|
|
|
|
|
message.result.messages.reverse().forEach(element => {
|
2022-01-12 15:22:24 +01:00
|
|
|
|
2022-01-11 20:56:21 +01:00
|
|
|
element = this.fix_updatedAt(element)
|
2022-01-11 16:07:54 +01:00
|
|
|
const message = new MessageService()
|
|
|
|
|
message.setData(element)
|
|
|
|
|
this.massages.push(message)
|
|
|
|
|
});
|
|
|
|
|
|
2022-01-11 15:43:09 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
|
|
this.hasLoadHistory = true
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-10 23:52:33 +01:00
|
|
|
create() {}
|
2022-01-11 15:43:09 +01:00
|
|
|
deleteMessage(msgId) {}
|
2022-01-10 23:52:33 +01:00
|
|
|
ReactToMessage() {}
|
|
|
|
|
|
2022-01-11 20:56:21 +01:00
|
|
|
private calDateDuration(date = null) {
|
|
|
|
|
this.duration = showDateDuration(date || this._updatedAt);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private fix_updatedAt(message) {
|
|
|
|
|
if(message.result) {
|
|
|
|
|
message.result._updatedAt = message.result._updatedAt['$date']
|
|
|
|
|
} else{
|
|
|
|
|
message._updatedAt = message._updatedAt['$date']
|
|
|
|
|
}
|
|
|
|
|
return message
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-12 16:10:59 +01:00
|
|
|
|
|
|
|
|
// to add
|
|
|
|
|
countDownDate(){}
|
|
|
|
|
|
2022-01-10 13:31:15 +01:00
|
|
|
}
|