Files
doneit-web/src/app/services/chat/room.service.ts
T

97 lines
2.2 KiB
TypeScript
Raw Normal View History

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-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-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 15:43:09 +01:00
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,
this.constructor.name+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-12 11:52:05 +01:00
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-10 13:31:15 +01:00
}