add send message to chat

This commit is contained in:
Peter Maquiran
2024-06-05 15:35:38 +01:00
parent 619465c10d
commit 486e0e8e72
6 changed files with 99 additions and 19 deletions
@@ -19,6 +19,12 @@ const tableSchema = z.object({
canEdit: z.boolean(), canEdit: z.boolean(),
oneShot: z.boolean(), oneShot: z.boolean(),
requireUnlock: z.boolean(), requireUnlock: z.boolean(),
sender: z.object({
wxUserId: z.number(),
wxFullName: z.string(),
wxeMail: z.string(),
userPhoto: z.string()
})
}) })
export type TableMessage = z.infer<typeof tableSchema> export type TableMessage = z.infer<typeof tableSchema>
@@ -45,9 +51,11 @@ export class MessageLocalDataSourceService {
async createMessage(data: MessageInputDTO) { async createMessage(data: MessageInputDTO) {
try { try {
console.log('add', data)
const result = await messageDataSource.message.add(data) const result = await messageDataSource.message.add(data)
return ok(result as string) return ok(result as string)
} catch (e) { } catch (e) {
console.log('add error')
return err(false) return err(false)
} }
@@ -57,6 +65,7 @@ export class MessageLocalDataSourceService {
async update(data: TableMessage) { async update(data: TableMessage) {
try { try {
console.log('update', data)
const result = await messageDataSource.message.update(data.id, data) const result = await messageDataSource.message.update(data.id, data)
return ok(result) return ok(result)
} catch (e) { } catch (e) {
@@ -65,12 +74,41 @@ export class MessageLocalDataSourceService {
} }
async findOrUpdate(data: TableMessage) {
const findResult = await this.findMessageById(data.messageId)
console.log('findOrUpdate', findResult)
if(findResult.isOk()) {
return this.update({...findResult.value, ...data})
} else {
return this.createMessage(data)
}
}
getItemsLive(roomId: string): Observable<RoomListOutPutDTO> { getItemsLive(roomId: string): Observable<RoomListOutPutDTO> {
return liveQuery(() => messageDataSource.message.where('roomId').equals(roomId).toArray() as any) as any return liveQuery(() => messageDataSource.message.where('roomId').equals(roomId).toArray() as any) as any
} }
addIdToMessage() {} async findMessageById(messageId: string) {
try {
console.log('messageId', messageId)
const a = await messageDataSource.message.where('messageId').equals(messageId).first()
if(a) {
return ok(a)
} else {
return err('not found')
}
} catch (e) {
console.log('error')
return err('DB error')
}
}
} }
@@ -5,6 +5,7 @@ import { DataSourceReturn } from '../../../type';
import { MessageInputDTO, MessageInputDTOSchema } from '../../dto/message/messageInputDtO'; import { MessageInputDTO, MessageInputDTOSchema } from '../../dto/message/messageInputDtO';
import { ValidateSchema } from 'src/app/services/decorators/validate-schema.decorator'; import { ValidateSchema } from 'src/app/services/decorators/validate-schema.decorator';
import { MessageOutPutDTO } from '../../dto/message/messageOutputDTO'; import { MessageOutPutDTO } from '../../dto/message/messageOutputDTO';
import { MessageListOutput } from '../../dto/message/messageListOutputDTO';
@Injectable({ @Injectable({
providedIn: 'root' providedIn: 'root'
@@ -24,9 +25,8 @@ export class MessageRemoteDataSourceService {
return await this.httpService.post<any>(`${this.baseUrl}/Messages/${id}/React`, reaction); return await this.httpService.post<any>(`${this.baseUrl}/Messages/${id}/React`, reaction);
} }
async getMessagesFromRoom(id: MessageListInputDTO): DataSourceReturn<MessageListInputDTO> { async getMessagesFromRoom(id: string): DataSourceReturn<MessageListOutput> {
return await this.httpService.get(`${this.baseUrl}/Room/${id}/Messages`); return await this.httpService.get(`${this.baseUrl}/Room/${id}/Messages`);
} }
} }
@@ -0,0 +1,29 @@
import { z } from "zod"
const SenderSchema = z.object({
wxUserId: z.number(),
wxFullName: z.string(),
wxeMail: z.string(),
userPhoto: z.string()
});
const DataSchema = z.object({
id: z.string(),
sender: SenderSchema,
message: z.string(),
messageType: z.number(),
sentAt: z.string().datetime(),
deliverAt: z.string().datetime().nullable(),
canEdit: z.boolean(),
oneShot: z.boolean(),
requireUnlock: z.boolean()
});
const MessageListOutputSchema = z.object({
success: z.boolean(),
message: z.string().nullable(),
data: z.array(DataSchema)
});
export type MessageListOutput = z.infer<typeof MessageListOutputSchema>
@@ -23,13 +23,19 @@ export class MessageRepositoryService {
if(localActionResult.isOk()) { if(localActionResult.isOk()) {
const sendMessageResult = await this.messageRemoteDataSourceService.sendMessage(data) const sendMessageResult = await this.messageRemoteDataSourceService.sendMessage(data)
if(sendMessageResult.isOk()) { if(sendMessageResult.isOk()) {
let clone: TableMessage = sendMessageResult.value.data let clone: TableMessage = {
...sendMessageResult.value.data,
clone.messageId = sendMessageResult.value.data.id sender: {
clone.id = localActionResult.value userPhoto: '',
wxeMail: '',
wxFullName: '',
wxUserId: 0
},
messageId: sendMessageResult.value.data.id,
id : localActionResult.value
}
return this.messageLocalDataSourceService.update(clone) return this.messageLocalDataSourceService.update(clone)
} }
@@ -37,13 +43,21 @@ export class MessageRepositoryService {
} }
} }
async listAllMessagesByRoomId() { async listAllMessagesByRoomId(id: string) {
this.messageRemoteDataSourceService const result = await this.messageRemoteDataSourceService.getMessagesFromRoom(id)
if(result.isOk()) {
console.log({result})
for(const message of result.value.data) {
let clone: TableMessage = message
clone.messageId = message.id
clone.roomId = id
delete clone.id
await this.messageLocalDataSourceService.findOrUpdate(clone)
}
} }
async getMessagesFromRoom(data: MessageListInputDTO) {
const result = await this.messageRemoteDataSourceService.getMessagesFromRoom(data)
return result return result
} }
@@ -1,8 +1,5 @@
import { Injectable } from '@angular/core'; import { Injectable } from '@angular/core';
import { HttpService } from 'src/app/services/http.service'; import { HttpService } from 'src/app/services/http.service';
import { MessageOutPutDTO } from '../../chat/dto/message/messageOutputDTO';
import { MessageListInputDTO } from '../../chat/dto/message/messageListInputDTO';
export interface UserContacts { export interface UserContacts {
wxUserId: number; wxUserId: number;
@@ -143,6 +143,8 @@ export class MessagesPage implements OnInit, OnChanges, AfterViewInit, OnDestroy
ngOnChanges(changes: SimpleChanges): void { ngOnChanges(changes: SimpleChanges): void {
this.roomData$ = this.roomRepositoryService.getItemByIdLive(this.roomId) this.roomData$ = this.roomRepositoryService.getItemByIdLive(this.roomId)
this.roomMessage$ = this.messageRepositoryService.getItemsLive(this.roomId) this.roomMessage$ = this.messageRepositoryService.getItemsLive(this.roomId)
this.messageRepositoryService.listAllMessagesByRoomId(this.roomId)
} }
sendTyping() {} sendTyping() {}
@@ -408,7 +410,7 @@ export class MessagesPage implements OnInit, OnChanges, AfterViewInit, OnDestroy
const data: MessageInputDTO = { const data: MessageInputDTO = {
roomId: this.roomId, roomId: this.roomId,
senderId: SessionStore.user.UserId, senderId: SessionStore.user.UserId,
message: "hello", message: this.textField,
messageType: 0, messageType: 0,
canEdit: false, canEdit: false,
oneShot:false, oneShot:false,