polfan-server-js-client 0.2.32 → 0.2.34
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.idea/workspace.xml +29 -3
- package/build/index.cjs.js +16 -7
- package/build/index.cjs.js.map +1 -1
- package/build/index.umd.js +1 -1
- package/build/index.umd.js.map +1 -1
- package/build/types/state-tracker/UsersManager.d.ts +3 -1
- package/package.json +1 -1
- package/src/state-tracker/MessagesManager.ts +4 -3
- package/src/state-tracker/UsersManager.ts +16 -6
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { ChatStateTracker } from "./ChatStateTracker";
|
|
2
2
|
import { ObservableIndexedObjectCollection } from "../IndexedObjectCollection";
|
|
3
3
|
import { User } from "../types/src";
|
|
4
|
+
import { EventTarget } from "../EventTarget";
|
|
4
5
|
export declare class UsersManager {
|
|
5
6
|
private tracker;
|
|
7
|
+
readonly onlineStatus: EventTarget<any>;
|
|
6
8
|
private readonly users;
|
|
7
9
|
constructor(tracker: ChatStateTracker);
|
|
8
10
|
/**
|
|
@@ -10,6 +12,6 @@ export declare class UsersManager {
|
|
|
10
12
|
*/
|
|
11
13
|
getAvailable(): Promise<ObservableIndexedObjectCollection<User>>;
|
|
12
14
|
private handleMembers;
|
|
13
|
-
private handleUsers;
|
|
14
15
|
private handleSession;
|
|
16
|
+
private handleUsers;
|
|
15
17
|
}
|
package/package.json
CHANGED
|
@@ -8,7 +8,7 @@ import {
|
|
|
8
8
|
RoomDeleted,
|
|
9
9
|
RoomLeft,
|
|
10
10
|
TopicDeleted,
|
|
11
|
-
FollowedTopicUpdated, RoomJoined, NewTopic, Session, Room,
|
|
11
|
+
FollowedTopicUpdated, RoomJoined, NewTopic, Session, Room, MessageType,
|
|
12
12
|
} from "../types/src";
|
|
13
13
|
import {
|
|
14
14
|
IndexedCollection,
|
|
@@ -209,9 +209,10 @@ export class MessagesManager {
|
|
|
209
209
|
private updateLocallyFollowedTopicOnNewMessage(ev: NewMessage): void {
|
|
210
210
|
const roomFollowedTopics = this.followedTopics.get(ev.message.location.roomId);
|
|
211
211
|
const followedTopic = roomFollowedTopics?.get(ev.message.location.topicId);
|
|
212
|
+
const ephemeralMessageTypes = ['System'] as MessageType[];
|
|
212
213
|
|
|
213
|
-
if (!
|
|
214
|
-
// Skip if we don't follow this room or targeted topic
|
|
214
|
+
if (!roomFollowedTopics || !followedTopic || ephemeralMessageTypes.includes(ev.message.type)) {
|
|
215
|
+
// Skip if we don't follow this room or targeted topic or message is ephemeral
|
|
215
216
|
return;
|
|
216
217
|
}
|
|
217
218
|
|
|
@@ -2,8 +2,11 @@ import {ChatStateTracker} from "./ChatStateTracker";
|
|
|
2
2
|
import {ObservableIndexedObjectCollection} from "../IndexedObjectCollection";
|
|
3
3
|
import {RoomMember, Session, SpaceMember, User} from "../types/src";
|
|
4
4
|
import {extractUserFromMember} from "./functions";
|
|
5
|
+
import {EventTarget} from "../EventTarget";
|
|
5
6
|
|
|
6
7
|
export class UsersManager {
|
|
8
|
+
public readonly onlineStatus = new EventTarget();
|
|
9
|
+
|
|
7
10
|
private readonly users: ObservableIndexedObjectCollection<User> = new ObservableIndexedObjectCollection('id');
|
|
8
11
|
|
|
9
12
|
public constructor(private tracker: ChatStateTracker) {
|
|
@@ -26,15 +29,22 @@ export class UsersManager {
|
|
|
26
29
|
}
|
|
27
30
|
|
|
28
31
|
private handleMembers(members: (RoomMember | SpaceMember)[]): void {
|
|
29
|
-
this.
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
private handleUsers(users: User[]): void {
|
|
33
|
-
this.users.set(...users);
|
|
32
|
+
this.handleUsers(members.map(extractUserFromMember));
|
|
34
33
|
}
|
|
35
34
|
|
|
36
35
|
private handleSession(session: Session): void {
|
|
37
36
|
this.users.deleteAll();
|
|
38
|
-
this.
|
|
37
|
+
this.handleUsers([session.user]);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
private handleUsers(users: User[]): void {
|
|
41
|
+
users.forEach(newUser => {
|
|
42
|
+
const oldUser = this.users.get(newUser.id);
|
|
43
|
+
if (oldUser && oldUser.online !== newUser.online) {
|
|
44
|
+
this.onlineStatus.emit('changed', newUser);
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
this.users.set(...users);
|
|
39
49
|
}
|
|
40
50
|
}
|