mirror of
https://code.equilibrium.co.ao/ITO/doneit-web.git
synced 2026-04-18 20:47:54 +00:00
fix duplicate message
This commit is contained in:
@@ -72,7 +72,7 @@ export type IMessage = z.infer<typeof MessageEntitySchema>;
|
|||||||
|
|
||||||
export class MessageEntity {
|
export class MessageEntity {
|
||||||
|
|
||||||
$id?: number
|
$id?: string
|
||||||
id?: string
|
id?: string
|
||||||
roomId?: string
|
roomId?: string
|
||||||
receiverId?: number
|
receiverId?: number
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { Observable as DexieObservable, PromiseExtended } from 'Dexie';
|
|||||||
import { AttachmentTable } from "src/app/infra/database/dexie/instance/chat/schema/attachment";
|
import { AttachmentTable } from "src/app/infra/database/dexie/instance/chat/schema/attachment";
|
||||||
import { Result } from "neverthrow";
|
import { Result } from "neverthrow";
|
||||||
import { MemberTable, MemberTableSchema } from "src/app/infra/database/dexie/instance/chat/schema/members";
|
import { MemberTable, MemberTableSchema } from "src/app/infra/database/dexie/instance/chat/schema/members";
|
||||||
import { RepositoryResult, RepositoryResultNew } from "src/app/infra/repository";
|
import { RepositoryResult } from "src/app/infra/repository";
|
||||||
import { z } from "zod";
|
import { z } from "zod";
|
||||||
import { MemberListUPdateStatusInputDTO } from "src/app/module/chat/domain/use-case/socket/member-list-update-status-use-case.service";
|
import { MemberListUPdateStatusInputDTO } from "src/app/module/chat/domain/use-case/socket/member-list-update-status-use-case.service";
|
||||||
import { Observable } from "rxjs";
|
import { Observable } from "rxjs";
|
||||||
@@ -26,7 +26,7 @@ export type IGetMemberLive = z.infer<typeof GetMemberLiveInput>
|
|||||||
export abstract class IMemberLocalRepository extends DexieRepository<AttachmentTable, AttachmentTable> {
|
export abstract class IMemberLocalRepository extends DexieRepository<AttachmentTable, AttachmentTable> {
|
||||||
|
|
||||||
abstract directMember(input:IDirectMemberInput): Promise<Result<MemberTable, any>>
|
abstract directMember(input:IDirectMemberInput): Promise<Result<MemberTable, any>>
|
||||||
abstract addMember(data: MemberTable): Promise<RepositoryResultNew<number, MemberTable>>
|
abstract addMember(data: MemberTable): Promise<RepositoryResult<number, MemberTable>>
|
||||||
abstract updateMemberRole(data: MemberTable): Promise<Result<number, any>>
|
abstract updateMemberRole(data: MemberTable): Promise<Result<number, any>>
|
||||||
abstract updateMembersStatus(data: MemberListUPdateStatusInputDTO): Promise<Result<true, any>>
|
abstract updateMembersStatus(data: MemberListUPdateStatusInputDTO): Promise<Result<true, any>>
|
||||||
abstract allMemberOnline(roomId:string): DexieObservable<boolean>
|
abstract allMemberOnline(roomId:string): DexieObservable<boolean>
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ import { MessageAttachmentFileType, MessageAttachmentSource } from "src/app/core
|
|||||||
|
|
||||||
export const AttachmentTableSchema = z.object({
|
export const AttachmentTableSchema = z.object({
|
||||||
$id: z.number().optional(), // local id
|
$id: z.number().optional(), // local id
|
||||||
$messageId: z.number(),
|
$messageId: z.string(),
|
||||||
attachmentId: z.string().optional(),
|
attachmentId: z.string().optional(),
|
||||||
file: z.instanceof(Blob),
|
file: z.instanceof(Blob),
|
||||||
base64: zodDataUrlSchema.nullable().optional(),
|
base64: zodDataUrlSchema.nullable().optional(),
|
||||||
|
|||||||
@@ -3,7 +3,8 @@ import { MessageAttachmentFileType, MessageAttachmentSource } from 'src/app/core
|
|||||||
import { z } from 'zod';
|
import { z } from 'zod';
|
||||||
|
|
||||||
export const MessageTableSchema = z.object({
|
export const MessageTableSchema = z.object({
|
||||||
$id: z.number().optional(),
|
$id: z.string().optional(),
|
||||||
|
$createAt: z.number().optional(),
|
||||||
id: z.string().uuid().optional(),
|
id: z.string().uuid().optional(),
|
||||||
roomId: z.string().uuid().optional(),
|
roomId: z.string().uuid().optional(),
|
||||||
message: z.string().nullable().optional(),
|
message: z.string().nullable().optional(),
|
||||||
@@ -48,5 +49,5 @@ export const MessageTableSchema = z.object({
|
|||||||
|
|
||||||
export type MessageTable = z.infer<typeof MessageTableSchema>
|
export type MessageTable = z.infer<typeof MessageTableSchema>
|
||||||
export type DexieMessageTable = EntityTable<MessageTable, '$id'>;
|
export type DexieMessageTable = EntityTable<MessageTable, '$id'>;
|
||||||
export const messageTableColumn = '++$id, id, roomId, senderId, message, messageType, canEdit, oneShot, requireUnlock'
|
export const messageTableColumn = '$id, id, roomId, senderId, message, messageType, canEdit, oneShot, requireUnlock'
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ import { BoldTableColumn, DexieBoldTable } from './instance/chat/schema/bold';
|
|||||||
|
|
||||||
|
|
||||||
// Database declaration (move this to its own module also)
|
// Database declaration (move this to its own module also)
|
||||||
export const chatDatabase = new Dexie('chat-database-infra',{
|
export const chatDatabase = new Dexie('chat-database-v1',{
|
||||||
// indexedDB: new FDBFactory,
|
// indexedDB: new FDBFactory,
|
||||||
// IDBKeyRange: FDBKeyRange, // Mocking IDBKeyRange
|
// IDBKeyRange: FDBKeyRange, // Mocking IDBKeyRange
|
||||||
}) as Dexie & {
|
}) as Dexie & {
|
||||||
|
|||||||
@@ -3,13 +3,12 @@ import { ZodError} from 'zod';
|
|||||||
import { IDBError } from './types';
|
import { IDBError } from './types';
|
||||||
|
|
||||||
// Define a type for the Result of repository operations
|
// Define a type for the Result of repository operations
|
||||||
export type RepositoryResult<T, E> = Result<T, Error | ZodError<E>>;
|
export type RepositoryResult<T, E> = Result<T, IDBError<E>>;
|
||||||
export type RepositoryResultNew<T, E> = Result<T, IDBError<E>>;
|
|
||||||
export abstract class IDexieRepository<T, R> {
|
export abstract class IDexieRepository<T, R> {
|
||||||
|
|
||||||
abstract insert(document: T): Promise<RepositoryResultNew<number, T>>
|
abstract insert(document: T): Promise<RepositoryResult<number, T>>
|
||||||
|
|
||||||
abstract insertMany(documents: T[]): Promise<RepositoryResult<number[], ZodError<T>>>
|
abstract insertMany(documents: T[]): Promise<RepositoryResult<number[], T[]>>
|
||||||
|
|
||||||
abstract update(id: any, updatedDocument: Partial<T>) : Promise<RepositoryResult<number, T>>
|
abstract update(id: any, updatedDocument: Partial<T>) : Promise<RepositoryResult<number, T>>
|
||||||
|
|
||||||
|
|||||||
@@ -2,15 +2,15 @@ import { Result, ok, err } from 'neverthrow';
|
|||||||
import { EntityTable } from 'Dexie';
|
import { EntityTable } from 'Dexie';
|
||||||
import { ZodError, ZodObject, ZodSchema } from 'zod';
|
import { ZodError, ZodObject, ZodSchema } from 'zod';
|
||||||
import { Logger } from 'src/app/services/logger/main/service';
|
import { Logger } from 'src/app/services/logger/main/service';
|
||||||
import { IDexieRepository, RepositoryResultNew } from '../adapter'
|
import { IDexieRepository, RepositoryResult } from '../adapter'
|
||||||
import { IDBError } from '../types';
|
import { IDBError, IDexieError } from '../types';
|
||||||
|
|
||||||
// Define a type for the Result of repository operations
|
// Define a type for the Result of repository operations
|
||||||
|
|
||||||
class DBError<T> extends Error implements IDBError<T> {
|
class DBError<T> extends Error implements IDBError<T> {
|
||||||
zodError?: ZodError<T>;
|
zodError?: ZodError<T>;
|
||||||
parameters: T;
|
parameters: T;
|
||||||
error?: any;
|
error?: IDexieError;
|
||||||
|
|
||||||
constructor(data: IDBError<T>) {
|
constructor(data: IDBError<T>) {
|
||||||
super(data.message);
|
super(data.message);
|
||||||
@@ -18,6 +18,11 @@ class DBError<T> extends Error implements IDBError<T> {
|
|||||||
this.parameters = data.parameters;
|
this.parameters = data.parameters;
|
||||||
this.error = data.error;
|
this.error = data.error;
|
||||||
|
|
||||||
|
Logger.error(data.message, {
|
||||||
|
zodError: this.zodError,
|
||||||
|
parameters: this.parameters
|
||||||
|
})
|
||||||
|
|
||||||
// // Manually capture the stack trace if needed
|
// // Manually capture the stack trace if needed
|
||||||
// if (Error.captureStackTrace) {
|
// if (Error.captureStackTrace) {
|
||||||
// Error.captureStackTrace(this, DBError);
|
// Error.captureStackTrace(this, DBError);
|
||||||
@@ -25,9 +30,6 @@ class DBError<T> extends Error implements IDBError<T> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
type RepositoryResult<T, E> = Result<T, Error | ZodError<E>>;
|
|
||||||
|
|
||||||
export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
||||||
private table: EntityTable<any, any>;
|
private table: EntityTable<any, any>;
|
||||||
private ZodSchema: ZodSchema<T>
|
private ZodSchema: ZodSchema<T>
|
||||||
@@ -39,7 +41,7 @@ export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
|||||||
this.ZodPartialSchema = (ZodSchema as ZodObject<any>).partial() as any;
|
this.ZodPartialSchema = (ZodSchema as ZodObject<any>).partial() as any;
|
||||||
}
|
}
|
||||||
|
|
||||||
async insert(document: T): Promise<RepositoryResultNew<number, T>> {
|
async insert(document: T): Promise<RepositoryResult<any, T>> {
|
||||||
|
|
||||||
const dataValidation = this.ZodSchema.safeParse(document)
|
const dataValidation = this.ZodSchema.safeParse(document)
|
||||||
|
|
||||||
@@ -47,19 +49,15 @@ export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
|||||||
try {
|
try {
|
||||||
const id = await this.table.add(dataValidation.data);
|
const id = await this.table.add(dataValidation.data);
|
||||||
return ok(id);
|
return ok(id);
|
||||||
} catch (error) {
|
} catch (_error) {
|
||||||
console.log(error)
|
const error: IDexieError = _error
|
||||||
return err(new DBError({
|
return err(new DBError({
|
||||||
message: `dexie.js failed to insert into ${this.table.name}`,
|
message: `dexie.js failed to insert into ${this.table.name}, ${error.message}`,
|
||||||
parameters: document,
|
parameters: document,
|
||||||
error: error
|
error: error
|
||||||
}))
|
}))
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Logger.error(`dexie.js failed to insert into ${this.table.name}, invalid data`, {
|
|
||||||
data: document,
|
|
||||||
zodError: dataValidation.error.issues
|
|
||||||
});
|
|
||||||
return err(new DBError({
|
return err(new DBError({
|
||||||
message: `dexie.js failed to insert into ${this.table.name}, invalid data`,
|
message: `dexie.js failed to insert into ${this.table.name}, invalid data`,
|
||||||
parameters: document,
|
parameters: document,
|
||||||
@@ -68,27 +66,29 @@ export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async insertMany(documents: T[]): Promise<RepositoryResult<number[], ZodError<T>>> {
|
async insertMany(documents: T[]): Promise<RepositoryResult<number[], T[]>> {
|
||||||
// Validate each document
|
// Validate each document
|
||||||
const schema = this.ZodSchema.array()
|
const schema = this.ZodSchema.array()
|
||||||
|
|
||||||
const validationResult = schema.safeParse(documents)
|
const validationResult = schema.safeParse(documents)
|
||||||
if(!validationResult.success) {
|
if(!validationResult.success) {
|
||||||
Logger.error(`dexie.js failed to insert many into ${this.table.name}, invalid data`, {
|
return err(new DBError({
|
||||||
data: document,
|
message: `dexie.js failed to insert many into ${this.table.name}, invalid data`,
|
||||||
zodError: validationResult.error.issues
|
parameters: documents,
|
||||||
});
|
zodError: validationResult.error
|
||||||
return err((validationResult as unknown as ZodError<T>))
|
}))
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const ids = await this.table.bulkAdd(documents as any);
|
const ids = await this.table.bulkAdd(documents as any);
|
||||||
return ok(ids);
|
return ok(ids);
|
||||||
} catch (error) {
|
} catch (_error) {
|
||||||
Logger.error(`dexie.js failed to insert many into ${this.table.name}`, {
|
const error: IDexieError = _error
|
||||||
data: document
|
return err(new DBError({
|
||||||
});
|
message: `dexie.js failed to insert into many ${this.table.name}, ${error.message}`,
|
||||||
return err(new Error('Failed to insert multiple documents: ' + error.message));
|
parameters: documents,
|
||||||
|
error: error
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -100,19 +100,26 @@ export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
|||||||
try {
|
try {
|
||||||
const updatedCount = await this.table.update(id, dataValidation.data);
|
const updatedCount = await this.table.update(id, dataValidation.data);
|
||||||
return ok(updatedCount);
|
return ok(updatedCount);
|
||||||
} catch (error) {
|
} catch (_error) {
|
||||||
Logger.error(`dexie.js failed to update into ${this.table.name}, invalid data`, {
|
const error: IDexieError = _error
|
||||||
data: updatedDocument,
|
return err(new DBError({
|
||||||
id,
|
message: `dexie.js Failed to update into ${this.table.name}, ${error.message} `,
|
||||||
});
|
parameters: {
|
||||||
return err(new Error('Failed to update document: ' + error.message));
|
...updatedDocument,
|
||||||
|
[this.table.schema.primKey.name]: id
|
||||||
|
} as unknown as T,
|
||||||
|
error: error
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Logger.error(`dexie.js failed to update into ${this.table.name}, invalid data`, {
|
return err(new DBError({
|
||||||
data: document,
|
message: `dexie.js failed to update into ${this.table.name}, invalid data`,
|
||||||
zodError: dataValidation.error.issues
|
parameters: {
|
||||||
});
|
...updatedDocument,
|
||||||
return err((dataValidation as unknown as ZodError<T>))
|
[this.table.schema.primKey.name]: id
|
||||||
|
} as unknown as T,
|
||||||
|
zodError: dataValidation.error
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -125,15 +132,20 @@ export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
|||||||
try {
|
try {
|
||||||
const updatedCount = await this.table.bulkPut(dataValidation.data);
|
const updatedCount = await this.table.bulkPut(dataValidation.data);
|
||||||
return ok(updatedCount);
|
return ok(updatedCount);
|
||||||
} catch (error) {
|
} catch (_error) {
|
||||||
return err(new Error('Failed to update document: ' + error.message));
|
const error: IDexieError = _error
|
||||||
|
return err(new DBError({
|
||||||
|
message: `dexie.js Failed to update into ${this.table.name}, ${error.message} `,
|
||||||
|
parameters: document,
|
||||||
|
error: error
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Logger.error(`dexie.js failed to update many into ${this.table.name}, invalid data`, {
|
return err(new DBError({
|
||||||
data: document,
|
message: `dexie.js failed to update many into ${this.table.name}, invalid data`,
|
||||||
zodError: dataValidation.error.issues
|
parameters: updatedDocument ,
|
||||||
});
|
zodError: dataValidation.error
|
||||||
return err((dataValidation as unknown as ZodError<T>))
|
}))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -142,8 +154,13 @@ export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
|||||||
try {
|
try {
|
||||||
await this.table.delete(id);
|
await this.table.delete(id);
|
||||||
return ok(undefined);
|
return ok(undefined);
|
||||||
} catch (error) {
|
} catch (_error) {
|
||||||
return err(new Error('Failed to delete document: ' + error.message));
|
const error: IDexieError = _error
|
||||||
|
return err(new DBError({
|
||||||
|
message: `dexie.js Failed to delete into ${this.table.name}, ${error.message} `,
|
||||||
|
parameters: id,
|
||||||
|
error: error
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -151,8 +168,13 @@ export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
|||||||
try {
|
try {
|
||||||
const document = await this.table.get(id);
|
const document = await this.table.get(id);
|
||||||
return ok(document);
|
return ok(document);
|
||||||
} catch (error) {
|
} catch (_error) {
|
||||||
return err(new Error('Failed to find document by ID: ' + error.message));
|
const error: IDexieError = _error
|
||||||
|
return err(new DBError({
|
||||||
|
message: `dexie.js Failed to delete into ${this.table.name}, ${error.message} `,
|
||||||
|
parameters: id,
|
||||||
|
error: error
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -160,11 +182,13 @@ export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
|||||||
try {
|
try {
|
||||||
const documents: any = await this.table.where(filter).toArray();
|
const documents: any = await this.table.where(filter).toArray();
|
||||||
return ok(documents);
|
return ok(documents);
|
||||||
} catch (error) {
|
} catch (_error) {
|
||||||
Logger.error(`dexie.js failed to find into ${this.table.name}`, {
|
const error: IDexieError = _error;
|
||||||
data: filter,
|
return err(new DBError({
|
||||||
});
|
message: `dexie.js Failed to find into ${this.table.name}, ${error.message} `,
|
||||||
return err(new Error('Failed to find documents: ' + error.message));
|
parameters: filter as any,
|
||||||
|
error: error
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -172,12 +196,13 @@ export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
|||||||
try {
|
try {
|
||||||
const document = await this.table.where(filter).first();
|
const document = await this.table.where(filter).first();
|
||||||
return ok(document);
|
return ok(document);
|
||||||
} catch (error) {
|
} catch (_error) {
|
||||||
Logger.error(`dexie.js failed to findOne into ${this.table.name}`, {
|
const error: IDexieError = _error
|
||||||
data: filter,
|
return err(new DBError({
|
||||||
error
|
message: `dexie.js Failed to findOne into ${this.table.name}, ${error.message} `,
|
||||||
});
|
parameters: filter as any,
|
||||||
return err(new Error('Failed to find document: ' + error.message));
|
error: error
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -185,8 +210,13 @@ export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
|||||||
try {
|
try {
|
||||||
const documents = await this.table.toArray()
|
const documents = await this.table.toArray()
|
||||||
return ok(documents);
|
return ok(documents);
|
||||||
} catch (error) {
|
} catch (_error) {
|
||||||
return err(new Error('Failed to retrieve all documents: ' + error.message));
|
const error: IDexieError = _error
|
||||||
|
return err(new DBError({
|
||||||
|
message: `dexie.js Failed to findAll into ${this.table.name}, ${error.message} `,
|
||||||
|
parameters: null,
|
||||||
|
error: error
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -194,8 +224,13 @@ export class DexieRepository<T, R> implements IDexieRepository<T, R> {
|
|||||||
try {
|
try {
|
||||||
const count = filter ? await this.table.where(filter).count() : await this.table.count();
|
const count = filter ? await this.table.where(filter).count() : await this.table.count();
|
||||||
return ok(count);
|
return ok(count);
|
||||||
} catch (error) {
|
} catch (_error) {
|
||||||
return err(new Error('Failed to count documents: ' + error.message));
|
const error: IDexieError = _error
|
||||||
|
return err(new DBError({
|
||||||
|
message: `dexie.js Failed to count into ${this.table.name}, ${error.message}`,
|
||||||
|
parameters: filter as any,
|
||||||
|
error: error
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -37,10 +37,20 @@ import { ZodError } from "zod"
|
|||||||
// command: DatabaseOperationEnum;
|
// command: DatabaseOperationEnum;
|
||||||
// };
|
// };
|
||||||
|
|
||||||
|
|
||||||
export type IDBError<T> = {
|
export type IDBError<T> = {
|
||||||
message: string,
|
message: string,
|
||||||
zodError?: ZodError<T>,
|
zodError?: ZodError<T>,
|
||||||
parameters?: T,
|
parameters?: T,
|
||||||
error?: any
|
error?: IDexieError
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface IDexieError extends Error {
|
||||||
|
name: string; // The name of the error, e.g., 'NotFoundError', 'ConstraintError'
|
||||||
|
message: string; // The error message
|
||||||
|
stack?: string; // Optional stack trace
|
||||||
|
inner?: Error; // Some Dexie errors have an inner error
|
||||||
|
dbName?: string; // The name of the Dexie database where the error occurred
|
||||||
|
tableName?: string; // The name of the table where the error occurred
|
||||||
|
operation?: string; // The operation being performed (e.g., 'put', 'get', 'delete')
|
||||||
|
key?: any; // The key involved in the operation, if applicable
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ import { chatDatabase } from 'src/app/infra/database/dexie/service';
|
|||||||
import { IMessageLocalRepository } from 'src/app/core/chat/repository/message/message-local-repository';
|
import { IMessageLocalRepository } from 'src/app/core/chat/repository/message/message-local-repository';
|
||||||
import { BehaviorSubject, combineLatest, from, Observable } from 'rxjs';
|
import { BehaviorSubject, combineLatest, from, Observable } from 'rxjs';
|
||||||
import { filter, map } from 'rxjs/operators';
|
import { filter, map } from 'rxjs/operators';
|
||||||
|
import { v4 as uuidv4 } from 'uuid'
|
||||||
|
|
||||||
@Injectable({
|
@Injectable({
|
||||||
providedIn: 'root'
|
providedIn: 'root'
|
||||||
@@ -15,6 +16,7 @@ import { filter, map } from 'rxjs/operators';
|
|||||||
export class MessageLocalDataSourceService extends DexieRepository<MessageTable, MessageEntity> implements IMessageLocalRepository {
|
export class MessageLocalDataSourceService extends DexieRepository<MessageTable, MessageEntity> implements IMessageLocalRepository {
|
||||||
|
|
||||||
private creatingSubject : BehaviorSubject<MessageTable> = new BehaviorSubject<MessageTable>(null);
|
private creatingSubject : BehaviorSubject<MessageTable> = new BehaviorSubject<MessageTable>(null);
|
||||||
|
private lastTimestamp = 0;
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
super(chatDatabase.message, MessageTableSchema)
|
super(chatDatabase.message, MessageTableSchema)
|
||||||
@@ -26,6 +28,23 @@ export class MessageLocalDataSourceService extends DexieRepository<MessageTable,
|
|||||||
private onCreatingHook() {
|
private onCreatingHook() {
|
||||||
chatDatabase.message.hook('creating', (primaryKey, obj, transaction) => {
|
chatDatabase.message.hook('creating', (primaryKey, obj, transaction) => {
|
||||||
|
|
||||||
|
let now = Date.now();
|
||||||
|
|
||||||
|
// If the current time is the same as the last, increment
|
||||||
|
if (now <= this.lastTimestamp) {
|
||||||
|
obj.$createAt = this.lastTimestamp + 1;
|
||||||
|
this.lastTimestamp = this.lastTimestamp + 1;
|
||||||
|
} else {
|
||||||
|
this.lastTimestamp = now;
|
||||||
|
obj.$createAt = now;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(obj.id) {
|
||||||
|
obj.$id = obj.id
|
||||||
|
} else {
|
||||||
|
obj.$id = 'Local-'+uuidv4()
|
||||||
|
}
|
||||||
|
|
||||||
this.creatingSubject.next(obj)
|
this.creatingSubject.next(obj)
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
+2
-2
@@ -6,7 +6,7 @@ import { AttachmentLocalDataSource } from 'src/app/module/chat/data/repository/a
|
|||||||
import { z } from 'zod';
|
import { z } from 'zod';
|
||||||
|
|
||||||
const DownloadMessageAttachmentByMessageIdSchema = z.object({
|
const DownloadMessageAttachmentByMessageIdSchema = z.object({
|
||||||
$messageId: z.number(),
|
$messageId: z.string(),
|
||||||
id: z.string()
|
id: z.string()
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -30,7 +30,7 @@ export class DownloadMessageAttachmentUserCaseService {
|
|||||||
const dataUrl = await createBlobUrl(blob)
|
const dataUrl = await createBlobUrl(blob)
|
||||||
|
|
||||||
if(dataUrl.isOk()) {
|
if(dataUrl.isOk()) {
|
||||||
|
|
||||||
Logger.info('downloaded file #1', {
|
Logger.info('downloaded file #1', {
|
||||||
// data: dataUrl.slice(0, 100)+'...',
|
// data: dataUrl.slice(0, 100)+'...',
|
||||||
context: 'DownloadMessageAttachmentUserCaseService'
|
context: 'DownloadMessageAttachmentUserCaseService'
|
||||||
|
|||||||
@@ -90,7 +90,7 @@ export class RoomBoldSyncUseCaseService {
|
|||||||
await this.boldLocalRepository.open()
|
await this.boldLocalRepository.open()
|
||||||
const result = await this.boldLocalRepository.findOne({roomId: newMessage.roomId})
|
const result = await this.boldLocalRepository.findOne({roomId: newMessage.roomId})
|
||||||
|
|
||||||
if(result.isOk() && !result.value) {
|
if(result.isOk() && !result.value?.bold) {
|
||||||
const result = await this.boldLocalRepository.insert({roomId: newMessage.roomId, bold: 1})
|
const result = await this.boldLocalRepository.insert({roomId: newMessage.roomId, bold: 1})
|
||||||
} else if(result.isOk() && result.value.bold == 0) {
|
} else if(result.isOk() && result.value.bold == 0) {
|
||||||
const result = await this.boldLocalRepository.update(newMessage.roomId, {bold: 1})
|
const result = await this.boldLocalRepository.update(newMessage.roomId, {bold: 1})
|
||||||
|
|||||||
@@ -154,7 +154,7 @@
|
|||||||
<div *ngIf="message.ballon" class="text-center ballon">
|
<div *ngIf="message.ballon" class="text-center ballon">
|
||||||
{{ message.message }}
|
{{ message.message }}
|
||||||
</div>
|
</div>
|
||||||
<div class="rotate-div emoji-container" *ngIf="message.isDeleted != true && message.messageType != IMessageType.information">
|
<div class="rotate-div emoji-container" *ngIf="message.isDeleted != true && message.messageType != IMessageType.information && message.ballon != true">
|
||||||
<span *ngFor="let reaction of message.reactions" class="emoji-icon">
|
<span *ngFor="let reaction of message.reactions" class="emoji-icon">
|
||||||
{{ reaction.reaction }}
|
{{ reaction.reaction }}
|
||||||
</span>
|
</span>
|
||||||
|
|||||||
@@ -307,6 +307,23 @@ export class MessagesPage implements OnInit, OnChanges, AfterViewInit, OnDestroy
|
|||||||
this.date = {}
|
this.date = {}
|
||||||
const allMessage = [];
|
const allMessage = [];
|
||||||
|
|
||||||
|
// let ids = {}
|
||||||
|
// messages = messages.filter((message: any) => {
|
||||||
|
// if (message.$createAt) {
|
||||||
|
// if (!ids[message.$createAt]) {
|
||||||
|
// ids[message.$createAt] = true;
|
||||||
|
// return true; // Keep this message
|
||||||
|
// } else {
|
||||||
|
// console.log('delete');
|
||||||
|
// return false; // Remove this message
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// return true; // Keep messages without an id
|
||||||
|
// });
|
||||||
|
|
||||||
|
|
||||||
|
messages = messages.sort((a: any, b: any) => a.$createAt - b.$createAt)
|
||||||
|
|
||||||
for(const message of messages) {
|
for(const message of messages) {
|
||||||
const date = whatsappDate(message.sentAt, false)
|
const date = whatsappDate(message.sentAt, false)
|
||||||
if(!this.date[date]) {
|
if(!this.date[date]) {
|
||||||
|
|||||||
Reference in New Issue
Block a user