-
Notifications
You must be signed in to change notification settings - Fork 78
Expand file tree
/
Copy pathuseUnreadMessagesTracker.ts
More file actions
62 lines (53 loc) · 2.42 KB
/
useUnreadMessagesTracker.ts
File metadata and controls
62 lines (53 loc) · 2.42 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
// Copyright (c) Microsoft Corporation.
// Licensed under the MIT License.
import { useEffect, useState } from 'react';
import { ChatAdapter } from '../../ChatComposite/adapter/ChatAdapter';
import { ChatMessage } from '@azure/communication-chat';
/**
* Used by the CallWithChatComposite to track unread messages for showing as a badge on the Chat Button.
* @private
*/
export const useUnreadMessagesTracker = (chatAdapter: ChatAdapter, isChatPaneVisible: boolean): number => {
// Store messageIds of unread messages
const [unreadChatMessages, setUnreadChatMessages] = useState<Set<string>>(new Set());
useEffect(() => {
// Clear unread messages when chat pane is opened
if (isChatPaneVisible) {
setUnreadChatMessages(new Set());
return;
}
// Increment unread messages when a new message is received and the chat pane is closed
const incrementUnreadChatMessagesCount = (event: { message: ChatMessage }): void => {
if (!isChatPaneVisible && validNewChatMessage(event.message)) {
setUnreadChatMessages((prevUnreadChatMessages) => {
const newUnreadChatMessages = new Set(prevUnreadChatMessages);
newUnreadChatMessages.add(event.message.id);
return newUnreadChatMessages;
});
}
};
// Decrement unread messages when a message is deleted and the chat pane is closed
const decrementUnreadChatMessagesCount = (event: { message: ChatMessage }): void => {
if (!isChatPaneVisible) {
setUnreadChatMessages((prevUnreadChatMessages) => {
const newUnreadChatMessages = new Set(prevUnreadChatMessages);
newUnreadChatMessages.delete(event.message.id);
return newUnreadChatMessages;
});
}
};
chatAdapter.on('messageReceived', incrementUnreadChatMessagesCount);
chatAdapter.on('messageDeleted', decrementUnreadChatMessagesCount);
return () => {
chatAdapter.off('messageReceived', incrementUnreadChatMessagesCount);
chatAdapter.off('messageDeleted', decrementUnreadChatMessagesCount);
};
}, [chatAdapter, setUnreadChatMessages, isChatPaneVisible]);
return unreadChatMessages.size;
};
/**
* Helper function to determine if the message in the event is a valid one from a user.
* Display name is used since system messages will not have one.
*/
const validNewChatMessage = (message): boolean =>
!!message.senderDisplayName && (message.type === 'text' || message.type === 'html');