mirror of
https://code.equilibrium.co.ao/ITO/doneit-web.git
synced 2026-04-18 20:47:54 +00:00
add member repository
This commit is contained in:
@@ -0,0 +1,40 @@
|
||||
import { Injectable } from '@angular/core';
|
||||
import { SignalRService } from 'src/app/infra/socket/signalR/signal-r.service';
|
||||
import { IMemberSocketRepository } from 'src/app/core/chat/repository/member/member-socket-repository';
|
||||
import { IRemoveRoomMemberOutput, RemoveRoomMemberInput } from '../../../domain/use-case/member/member-remove-socket-use-case.service';
|
||||
import { InstanceId } from '../../../domain/chat-service.service';
|
||||
import { v4 as uuidv4 } from 'uuid'
|
||||
import { filter, map, tap } from 'rxjs/operators';
|
||||
import { SocketMessage } from 'src/app/infra/socket/signalR/signalR';
|
||||
|
||||
@Injectable({
|
||||
providedIn: 'root'
|
||||
})
|
||||
export class MemberSocketRepositoryService implements IMemberSocketRepository {
|
||||
|
||||
constructor(
|
||||
private socket: SignalRService
|
||||
) {
|
||||
// this.listenToRemoveMember()
|
||||
}
|
||||
async removeMember(data: RemoveRoomMemberInput) {
|
||||
|
||||
const result = await this.socket.sendData<any>({
|
||||
method: 'RemoveRoomMember',
|
||||
data: {
|
||||
...data,
|
||||
requestId: InstanceId +'@'+ uuidv4()
|
||||
},
|
||||
})
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
listenToRemoveMember() {
|
||||
return this.socket.getData().pipe(
|
||||
filter((e) : e is SocketMessage<IRemoveRoomMemberOutput>=> e?.method == 'GroupDeletedMembers'),
|
||||
map((e)=> e.data),
|
||||
)
|
||||
}
|
||||
|
||||
}
|
||||
@@ -1,7 +1,7 @@
|
||||
import { Injectable } from '@angular/core';
|
||||
import { liveQuery, Observable } from 'Dexie';
|
||||
import { DexieRepository } from 'src/app/infra/repository/dexie/dexie-repository.service';
|
||||
import { BehaviorSubject, from } from 'rxjs';
|
||||
import { BehaviorSubject, from, Subject } from 'rxjs';
|
||||
import { RoomTable, RoomTableSchema } from 'src/app/infra/database/dexie/instance/chat/schema/room';
|
||||
import { chatDatabase } from 'src/app/infra/database/dexie/instance/chat/service';
|
||||
import { IRoomLocalRepository } from 'src/app/core/chat/repository/room/room-local-repository';
|
||||
@@ -13,7 +13,7 @@ import { RoomType } from 'src/app/core/chat/entity/group';
|
||||
})
|
||||
export class RoomLocalRepository extends DexieRepository<RoomTable, RoomTable> implements IRoomLocalRepository {
|
||||
|
||||
private listenCreateSyncSubject : BehaviorSubject<RoomTable> = new BehaviorSubject<RoomTable>(null);
|
||||
private listenCreateSyncSubject : Subject<RoomTable> = new Subject<RoomTable>();
|
||||
|
||||
constructor() {
|
||||
super(chatDatabase.room, RoomTableSchema)
|
||||
|
||||
Reference in New Issue
Block a user