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.
@@ -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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "polfan-server-js-client",
3
- "version": "0.2.32",
3
+ "version": "0.2.34",
4
4
  "description": "JavaScript client library for handling communication with Polfan chat server.",
5
5
  "author": "Jarosław Żak",
6
6
  "license": "MIT",
@@ -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 (! roomFollowedTopics || ! followedTopic) {
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.users.set(...members.map(extractUserFromMember));
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.users.set(session.user);
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
  }