-
Notifications
You must be signed in to change notification settings - Fork 21
Expand file tree
/
Copy pathuseAnnouncementNotifier.ts
More file actions
78 lines (65 loc) · 2.92 KB
/
useAnnouncementNotifier.ts
File metadata and controls
78 lines (65 loc) · 2.92 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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/**
Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
Licensed under the Apache License, Version 2.0 (the "License").
You may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
import { useEffect, useCallback, useRef } from 'react';
import { useAppDispatch } from '@/config/store';
import { useNotificationService } from '@/shared/util/hooks';
import { clearNotification } from '@/shared/reducers/notification.reducer';
import { shouldShowAnnouncement, setDismissedTimestamp } from '@/shared/util/announcementDismissal';
import { IConfiguration } from '@/shared/model/configuration.model';
const ANNOUNCEMENT_NOTIFICATION_ID = 'announcement-notification';
/**
* Custom hook that displays announcement notifications based on the system configuration.
* Handles showing, dismissing, and persisting dismissal state for announcements.
*/
export function useAnnouncementNotifier (config: IConfiguration | undefined): void {
const dispatch = useAppDispatch();
const notificationService = useNotificationService(dispatch);
const lastAnnouncementRef = useRef<string | null>(null);
const clearAnnouncement = useCallback(() => {
dispatch(clearNotification(ANNOUNCEMENT_NOTIFICATION_ID));
}, [dispatch]);
// Extract stable primitive values to avoid re-running the effect on object reference changes
const isEnabled = config?.configuration?.announcement?.isEnabled ?? false;
const message = config?.configuration?.announcement?.message ?? '';
const createdAt = config?.createdAt;
useEffect(() => {
if (!isEnabled || !message) {
lastAnnouncementRef.current = null;
clearAnnouncement();
return;
}
if (!shouldShowAnnouncement(createdAt)) {
return;
}
// Avoid re-dispatching the same announcement notification
const announcementKey = `${message}:${createdAt}`;
if (lastAnnouncementRef.current === announcementKey) {
return;
}
lastAnnouncementRef.current = announcementKey;
const onDismiss = () => {
if (createdAt !== undefined) {
setDismissedTimestamp(createdAt);
}
clearAnnouncement();
};
notificationService.generateNotification(
'📢 Announcement: ' + message,
'info',
ANNOUNCEMENT_NOTIFICATION_ID,
null,
true,
onDismiss,
);
}, [isEnabled, message, createdAt, clearAnnouncement, notificationService]);
}