mirror of
https://code.equilibrium.co.ao/ITO/doneit-web.git
synced 2026-04-18 20:47:54 +00:00
reorganizde file path
This commit is contained in:
@@ -14,7 +14,6 @@ import { Observable as DexieObservable, PromiseExtended } from 'Dexie';
|
||||
})
|
||||
export class MessageLocalDataSourceService extends DexieRepository<MessageTable, MessageEntity> {
|
||||
|
||||
messageSubject = new Subject();
|
||||
|
||||
constructor() {
|
||||
super(chatDatabase.message, MessageTableSchema)
|
||||
@@ -33,128 +32,6 @@ export class MessageLocalDataSourceService extends DexieRepository<MessageTable,
|
||||
}
|
||||
}
|
||||
|
||||
async getLastMessageByRoomId(roomId: string): Promise<Result<undefined|MessageTable, any>> {
|
||||
try {
|
||||
console.log({roomId})
|
||||
const lastMessage = await chatDatabase.message
|
||||
.where('roomId')
|
||||
.equals(roomId)
|
||||
.reverse()
|
||||
.sortBy('id');
|
||||
|
||||
return ok(lastMessage[0]); // Get the last message
|
||||
} catch (error) {
|
||||
return err(error);
|
||||
}
|
||||
}
|
||||
|
||||
async deleteByMessageId(id: string): Promise<Result<undefined|number, any>> {
|
||||
try {
|
||||
console.log(id)
|
||||
const lastMessage = await chatDatabase.message
|
||||
.where('id')
|
||||
.equals(id).delete()
|
||||
|
||||
return ok(lastMessage[0]); // Get the last message
|
||||
} catch (error) {
|
||||
return err(error);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
async sendMessage(data: MessageTable) {
|
||||
|
||||
const dataValidation = MessageTableSchema.safeParse(data)
|
||||
if(dataValidation.success) {
|
||||
|
||||
const safeData = dataValidation.data
|
||||
safeData.sending = true
|
||||
|
||||
try {
|
||||
const result = await chatDatabase.message.add(safeData)
|
||||
this.messageSubject.next({roomId: safeData.roomId});
|
||||
return ok(result as number)
|
||||
} catch (e) {
|
||||
return err(false)
|
||||
}
|
||||
|
||||
} else {
|
||||
console.log(dataValidation)
|
||||
return err(dataValidation)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// @ValidateSchema(tableSchema)
|
||||
async createMessage(data: MessageTable) {
|
||||
|
||||
try {
|
||||
const result = await chatDatabase.message.add(data)
|
||||
this.messageSubject.next({roomId: data.roomId});
|
||||
return ok(result)
|
||||
} catch (e) {
|
||||
return err(false)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
async createManyMessage(data: MessageTable[]) {
|
||||
|
||||
try {
|
||||
const result = await chatDatabase.message.bulkAdd(data)
|
||||
this.messageSubject.next({roomId: data[0].roomId});
|
||||
return ok(result)
|
||||
} catch (e) {
|
||||
return err(false)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
async messageExist({id}) {
|
||||
try {
|
||||
|
||||
console.log({id});
|
||||
|
||||
const existingMessage = await chatDatabase.message
|
||||
.where('id')
|
||||
.equals(id)
|
||||
.first();
|
||||
|
||||
if (existingMessage) {
|
||||
return ok(existingMessage)
|
||||
} else {
|
||||
return err(false)
|
||||
}
|
||||
|
||||
} catch (error) {
|
||||
return err(false);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// not used
|
||||
async updateByMessageId(data: MessageTable ) {
|
||||
|
||||
try {
|
||||
const result = await chatDatabase.message.update(data.id as any, data)
|
||||
return ok(result)
|
||||
} catch (e) {
|
||||
return err(false)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
async findOrUpdate(data: MessageTable) {
|
||||
const findResult = await this.findMessageById(data.id)
|
||||
|
||||
if(findResult.isOk()) {
|
||||
return this.update(findResult.value.$id, data)
|
||||
} else {
|
||||
return this.createMessage(data)
|
||||
}
|
||||
}
|
||||
|
||||
getItems(roomId: string): PromiseExtended<MessageEntity[]> {
|
||||
return chatDatabase.message.where('roomId').equals(roomId).sortBy('$id') as any
|
||||
}
|
||||
@@ -163,33 +40,6 @@ export class MessageLocalDataSourceService extends DexieRepository<MessageTable,
|
||||
return liveQuery(() => chatDatabase.message.where('roomId').equals(roomId).sortBy('$id') as any)
|
||||
}
|
||||
|
||||
|
||||
async findMessageById(id: string) {
|
||||
try {
|
||||
const a = await chatDatabase.message.where('id').equals(id).first()
|
||||
|
||||
if(a) {
|
||||
return ok(a)
|
||||
} else {
|
||||
return err('not found')
|
||||
}
|
||||
|
||||
} catch (e) {
|
||||
return err('DB error')
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
subscribeToNewMessage(roomId: string): Observable<MessageTable> {
|
||||
return this.messageSubject.pipe(
|
||||
filter((message: MessageTable) =>
|
||||
message.roomId === roomId
|
||||
)
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
async getOfflineMessages () {
|
||||
try {
|
||||
const allMessages = await chatDatabase.message
|
||||
|
||||
Reference in New Issue
Block a user