@churchapps/apphelper 0.4.17 → 0.4.19
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/dist/components/DisplayBox.js +1 -1
- package/dist/components/DisplayBox.js.map +1 -1
- package/dist/components/FormCardPayment.js +2 -2
- package/dist/components/FormCardPayment.js.map +1 -1
- package/dist/components/FormSubmissionEdit.d.ts.map +1 -1
- package/dist/components/FormSubmissionEdit.js +4 -5
- package/dist/components/FormSubmissionEdit.js.map +1 -1
- package/dist/components/InputBox.js +1 -1
- package/dist/components/InputBox.js.map +1 -1
- package/dist/components/Loading.js +1 -1
- package/dist/components/Loading.js.map +1 -1
- package/dist/components/PageHeader.d.ts +15 -0
- package/dist/components/PageHeader.d.ts.map +1 -0
- package/dist/components/PageHeader.js +41 -0
- package/dist/components/PageHeader.js.map +1 -0
- package/dist/components/PersonAvatar.d.ts +12 -0
- package/dist/components/PersonAvatar.d.ts.map +1 -0
- package/dist/components/PersonAvatar.js +55 -0
- package/dist/components/PersonAvatar.js.map +1 -0
- package/dist/components/header/SiteHeader.d.ts +2 -1
- package/dist/components/header/SiteHeader.d.ts.map +1 -1
- package/dist/components/header/SiteHeader.js +100 -4
- package/dist/components/header/SiteHeader.js.map +1 -1
- package/dist/components/header/SupportDrawer.js.map +1 -1
- package/dist/components/index.d.ts +2 -0
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +2 -0
- package/dist/components/index.js.map +1 -1
- package/dist/components/notes/AddNote.d.ts.map +1 -1
- package/dist/components/notes/AddNote.js +45 -7
- package/dist/components/notes/AddNote.js.map +1 -1
- package/dist/components/notes/Note.d.ts.map +1 -1
- package/dist/components/notes/Note.js +6 -6
- package/dist/components/notes/Note.js.map +1 -1
- package/dist/components/notes/Notes.d.ts.map +1 -1
- package/dist/components/notes/Notes.js +120 -20
- package/dist/components/notes/Notes.js.map +1 -1
- package/dist/components/wrapper/ChurchList.d.ts.map +1 -1
- package/dist/components/wrapper/ChurchList.js +44 -6
- package/dist/components/wrapper/ChurchList.js.map +1 -1
- package/dist/components/wrapper/NewPrivateMessage.d.ts.map +1 -1
- package/dist/components/wrapper/NewPrivateMessage.js +28 -21
- package/dist/components/wrapper/NewPrivateMessage.js.map +1 -1
- package/dist/components/wrapper/Notifications.d.ts.map +1 -1
- package/dist/components/wrapper/Notifications.js +47 -20
- package/dist/components/wrapper/Notifications.js.map +1 -1
- package/dist/components/wrapper/PrivateMessageDetails.d.ts +1 -0
- package/dist/components/wrapper/PrivateMessageDetails.d.ts.map +1 -1
- package/dist/components/wrapper/PrivateMessageDetails.js +53 -4
- package/dist/components/wrapper/PrivateMessageDetails.js.map +1 -1
- package/dist/components/wrapper/PrivateMessages.d.ts.map +1 -1
- package/dist/components/wrapper/PrivateMessages.js +360 -41
- package/dist/components/wrapper/PrivateMessages.js.map +1 -1
- package/dist/components/wrapper/UserMenu.d.ts.map +1 -1
- package/dist/components/wrapper/UserMenu.js +164 -27
- package/dist/components/wrapper/UserMenu.js.map +1 -1
- package/dist/components/wrapper/index.d.ts +2 -1
- package/dist/components/wrapper/index.d.ts.map +1 -1
- package/dist/components/wrapper/index.js +2 -1
- package/dist/components/wrapper/index.js.map +1 -1
- package/dist/helpers/ArrayHelper.d.ts.map +1 -1
- package/dist/helpers/ArrayHelper.js +0 -1
- package/dist/helpers/ArrayHelper.js.map +1 -1
- package/dist/helpers/ErrorHelper.js +1 -1
- package/dist/helpers/ErrorHelper.js.map +1 -1
- package/dist/helpers/EventHelper.d.ts.map +1 -1
- package/dist/helpers/EventHelper.js +0 -3
- package/dist/helpers/EventHelper.js.map +1 -1
- package/dist/helpers/Locale.d.ts +1 -1
- package/dist/helpers/Locale.d.ts.map +1 -1
- package/dist/helpers/Locale.js +7 -2
- package/dist/helpers/Locale.js.map +1 -1
- package/dist/helpers/NotificationService.d.ts +56 -0
- package/dist/helpers/NotificationService.d.ts.map +1 -0
- package/dist/helpers/NotificationService.js +176 -0
- package/dist/helpers/NotificationService.js.map +1 -0
- package/dist/helpers/SocketHelper.d.ts.map +1 -1
- package/dist/helpers/SocketHelper.js +22 -17
- package/dist/helpers/SocketHelper.js.map +1 -1
- package/dist/helpers/UserHelper.js +2 -2
- package/dist/helpers/UserHelper.js.map +1 -1
- package/dist/helpers/index.d.ts +2 -0
- package/dist/helpers/index.d.ts.map +1 -1
- package/dist/helpers/index.js +1 -0
- package/dist/helpers/index.js.map +1 -1
- package/dist/hooks/index.d.ts +2 -0
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +1 -0
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/useNotifications.d.ts +30 -0
- package/dist/hooks/useNotifications.d.ts.map +1 -0
- package/dist/hooks/useNotifications.js +79 -0
- package/dist/hooks/useNotifications.js.map +1 -0
- package/dist/public/css/styles.css +6 -2
- package/package.json +1 -1
- package/public/css/styles.css +6 -2
- package/src/components/DisplayBox.tsx +8 -8
- package/src/components/FormCardPayment.tsx +2 -2
- package/src/components/FormSubmissionEdit.tsx +5 -6
- package/src/components/InputBox.tsx +8 -8
- package/src/components/Loading.tsx +1 -1
- package/src/components/PageHeader.tsx +111 -0
- package/src/components/PersonAvatar.tsx +78 -0
- package/src/components/header/SiteHeader.tsx +133 -10
- package/src/components/header/SupportDrawer.tsx +1 -1
- package/src/components/index.tsx +2 -0
- package/src/components/notes/AddNote.tsx +105 -19
- package/src/components/notes/Note.tsx +43 -22
- package/src/components/notes/Notes.tsx +160 -21
- package/src/components/wrapper/ChurchList.tsx +45 -5
- package/src/components/wrapper/NewPrivateMessage.tsx +181 -44
- package/src/components/wrapper/Notifications.tsx +165 -29
- package/src/components/wrapper/PrivateMessageDetails.tsx +100 -13
- package/src/components/wrapper/PrivateMessages.tsx +539 -65
- package/src/components/wrapper/UserMenu.tsx +223 -38
- package/src/components/wrapper/index.tsx +3 -2
- package/src/helpers/ArrayHelper.ts +0 -1
- package/src/helpers/ErrorHelper.ts +1 -1
- package/src/helpers/EventHelper.ts +0 -3
- package/src/helpers/Locale.ts +7 -2
- package/src/helpers/NotificationService.ts +211 -0
- package/src/helpers/SocketHelper.ts +23 -17
- package/src/helpers/UserHelper.ts +2 -2
- package/src/helpers/index.ts +2 -0
- package/src/hooks/index.ts +2 -0
- package/src/hooks/useNotifications.ts +94 -0
- package/dist/components/wrapper/Drawers.d.ts +0 -5
- package/dist/components/wrapper/Drawers.d.ts.map +0 -1
- package/dist/components/wrapper/Drawers.js +0 -49
- package/dist/components/wrapper/Drawers.js.map +0 -1
- package/dist/components/wrapper/SiteWrapper.d.ts +0 -15
- package/dist/components/wrapper/SiteWrapper.d.ts.map +0 -1
- package/dist/components/wrapper/SiteWrapper.js +0 -60
- package/dist/components/wrapper/SiteWrapper.js.map +0 -1
- package/dist/components/wrapper/TabPanel.d.ts +0 -9
- package/dist/components/wrapper/TabPanel.d.ts.map +0 -1
- package/dist/components/wrapper/TabPanel.js +0 -17
- package/dist/components/wrapper/TabPanel.js.map +0 -1
- package/dist/helpers/ApiHelper.d.ts +0 -18
- package/dist/helpers/ApiHelper.d.ts.map +0 -1
- package/dist/helpers/ApiHelper.js +0 -119
- package/dist/helpers/ApiHelper.js.map +0 -1
- package/src/components/wrapper/Drawers.tsx +0 -62
- package/src/components/wrapper/SiteWrapper.tsx +0 -110
- package/src/components/wrapper/TabPanel.tsx +0 -32
- package/src/helpers/ApiHelper.ts +0 -127
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
import { SocketHelper } from "./SocketHelper";
|
|
2
|
+
import { ApiHelper } from "@churchapps/helpers";
|
|
3
|
+
export class NotificationService {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.counts = { notificationCount: 0, pmCount: 0 };
|
|
6
|
+
this.listeners = [];
|
|
7
|
+
this.isInitialized = false;
|
|
8
|
+
this.currentPersonId = null;
|
|
9
|
+
this.loadTimeout = null;
|
|
10
|
+
}
|
|
11
|
+
static getInstance() {
|
|
12
|
+
if (!NotificationService.instance) {
|
|
13
|
+
NotificationService.instance = new NotificationService();
|
|
14
|
+
}
|
|
15
|
+
return NotificationService.instance;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Initialize the notification service with user context
|
|
19
|
+
*/
|
|
20
|
+
async initialize(context) {
|
|
21
|
+
if (this.isInitialized)
|
|
22
|
+
return;
|
|
23
|
+
try {
|
|
24
|
+
// Store current person ID for conversation counting
|
|
25
|
+
this.currentPersonId = context?.person?.id || null;
|
|
26
|
+
// Initialize WebSocket connection
|
|
27
|
+
await SocketHelper.init();
|
|
28
|
+
// Set person/church context for websocket
|
|
29
|
+
if (context?.person?.id && context?.userChurch?.church?.id) {
|
|
30
|
+
SocketHelper.setPersonChurch({
|
|
31
|
+
personId: context.person.id,
|
|
32
|
+
churchId: context.userChurch.church.id
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
// Register handlers for notification updates
|
|
36
|
+
this.registerWebSocketHandlers();
|
|
37
|
+
// Load initial notification counts
|
|
38
|
+
await this.loadNotificationCounts();
|
|
39
|
+
this.isInitialized = true;
|
|
40
|
+
}
|
|
41
|
+
catch (error) {
|
|
42
|
+
console.error("❌ Failed to initialize NotificationService:", error);
|
|
43
|
+
throw error;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Register websocket handlers for real-time notification updates
|
|
48
|
+
*/
|
|
49
|
+
registerWebSocketHandlers() {
|
|
50
|
+
// Handler for new private messages
|
|
51
|
+
SocketHelper.addHandler("privateMessage", "NotificationService-PM", (data) => {
|
|
52
|
+
console.log('🔔 NotificationService: New private message received, updating counts');
|
|
53
|
+
this.debouncedLoadNotificationCounts();
|
|
54
|
+
});
|
|
55
|
+
// Handler for general notifications
|
|
56
|
+
SocketHelper.addHandler("notification", "NotificationService-Notification", (data) => {
|
|
57
|
+
console.log('🔔 NotificationService: New notification received, updating counts');
|
|
58
|
+
this.debouncedLoadNotificationCounts();
|
|
59
|
+
});
|
|
60
|
+
// Handler for message updates that could affect notification counts
|
|
61
|
+
SocketHelper.addHandler("message", "NotificationService-MessageUpdate", (data) => {
|
|
62
|
+
// Only update counts if the message update involves the current person
|
|
63
|
+
if (data?.message?.personId === this.currentPersonId ||
|
|
64
|
+
data?.notifyPersonId === this.currentPersonId) {
|
|
65
|
+
console.log('🔔 NotificationService: Message update affecting current user, updating counts');
|
|
66
|
+
this.debouncedLoadNotificationCounts();
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
// Handler for reconnect events
|
|
70
|
+
SocketHelper.addHandler("reconnect", "NotificationService-Reconnect", (data) => {
|
|
71
|
+
console.log('🔔 NotificationService: WebSocket reconnected, refreshing counts');
|
|
72
|
+
this.loadNotificationCounts(); // Don't debounce reconnect - need immediate update
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Load notification counts from the API with debouncing
|
|
77
|
+
*/
|
|
78
|
+
debouncedLoadNotificationCounts() {
|
|
79
|
+
if (this.loadTimeout) {
|
|
80
|
+
clearTimeout(this.loadTimeout);
|
|
81
|
+
}
|
|
82
|
+
this.loadTimeout = setTimeout(() => {
|
|
83
|
+
this.loadNotificationCounts();
|
|
84
|
+
}, 300); // 300ms debounce
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Load notification counts from the API
|
|
88
|
+
*/
|
|
89
|
+
async loadNotificationCounts() {
|
|
90
|
+
try {
|
|
91
|
+
// Use the unreadCount endpoint which returns both notification and PM counts
|
|
92
|
+
const counts = await ApiHelper.get("/notifications/unreadCount", "MessagingApi");
|
|
93
|
+
const newCounts = {
|
|
94
|
+
notificationCount: counts?.notificationCount || 0,
|
|
95
|
+
pmCount: counts?.pmCount || 0
|
|
96
|
+
};
|
|
97
|
+
// Update counts and notify listeners
|
|
98
|
+
this.updateCounts(newCounts);
|
|
99
|
+
}
|
|
100
|
+
catch (error) {
|
|
101
|
+
console.error("❌ Failed to load notification counts:", error);
|
|
102
|
+
// Don't throw - just log the error and keep existing counts
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Update counts and notify all listeners
|
|
107
|
+
*/
|
|
108
|
+
updateCounts(newCounts) {
|
|
109
|
+
const countsChanged = this.counts.notificationCount !== newCounts.notificationCount ||
|
|
110
|
+
this.counts.pmCount !== newCounts.pmCount;
|
|
111
|
+
if (countsChanged) {
|
|
112
|
+
this.counts = { ...newCounts };
|
|
113
|
+
// Notify all listeners
|
|
114
|
+
this.listeners.forEach(listener => {
|
|
115
|
+
try {
|
|
116
|
+
listener(this.counts);
|
|
117
|
+
}
|
|
118
|
+
catch (error) {
|
|
119
|
+
console.error("❌ Error in notification listener:", error);
|
|
120
|
+
}
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Subscribe to notification count changes
|
|
126
|
+
*/
|
|
127
|
+
subscribe(listener) {
|
|
128
|
+
this.listeners.push(listener);
|
|
129
|
+
// Immediately call with current counts
|
|
130
|
+
listener(this.counts);
|
|
131
|
+
// Return unsubscribe function
|
|
132
|
+
return () => {
|
|
133
|
+
this.listeners = this.listeners.filter(l => l !== listener);
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Get current notification counts
|
|
138
|
+
*/
|
|
139
|
+
getCounts() {
|
|
140
|
+
return { ...this.counts };
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Manually refresh notification counts
|
|
144
|
+
*/
|
|
145
|
+
async refresh() {
|
|
146
|
+
await this.loadNotificationCounts();
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Cleanup the service
|
|
150
|
+
*/
|
|
151
|
+
cleanup() {
|
|
152
|
+
// Clear any pending timeout
|
|
153
|
+
if (this.loadTimeout) {
|
|
154
|
+
clearTimeout(this.loadTimeout);
|
|
155
|
+
this.loadTimeout = null;
|
|
156
|
+
}
|
|
157
|
+
// Remove websocket handlers
|
|
158
|
+
SocketHelper.removeHandler("NotificationService-PM");
|
|
159
|
+
SocketHelper.removeHandler("NotificationService-Notification");
|
|
160
|
+
SocketHelper.removeHandler("NotificationService-MessageUpdate");
|
|
161
|
+
SocketHelper.removeHandler("NotificationService-Reconnect");
|
|
162
|
+
// Clear listeners
|
|
163
|
+
this.listeners = [];
|
|
164
|
+
// Reset state
|
|
165
|
+
this.counts = { notificationCount: 0, pmCount: 0 };
|
|
166
|
+
this.currentPersonId = null;
|
|
167
|
+
this.isInitialized = false;
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* Check if service is initialized
|
|
171
|
+
*/
|
|
172
|
+
isReady() {
|
|
173
|
+
return this.isInitialized && SocketHelper.isConnected();
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
//# sourceMappingURL=NotificationService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NotificationService.js","sourceRoot":"","sources":["../../src/helpers/NotificationService.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SocketHelper.d.ts","sourceRoot":"","sources":["../../src/helpers/SocketHelper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiD,4BAA4B,EAAE,sBAAsB,EAAwE,MAAM,qBAAqB,CAAC;AAEhN,qBAAa,YAAY;IACvB,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC;IACzB,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC;IACxB,MAAM,CAAC,cAAc,EAAE,4BAA4B,EAAE,CAAM;IAC3D,OAAO,CAAC,MAAM,CAAC,gBAAgB,CAAkE;IACjG,OAAO,CAAC,MAAM,CAAC,gBAAgB,CAAuB;IACtD,OAAO,CAAC,MAAM,CAAC,WAAW,CAAkB;IAC5C,OAAO,CAAC,MAAM,CAAC,oBAAoB,CAAc;IACjD,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAa;IAE7C,MAAM,CAAC,eAAe,GAAI,IAAI;QAAC,QAAQ,EAAC,MAAM,CAAC;QAAC,QAAQ,EAAC,MAAM,CAAA;KAAC,
|
|
1
|
+
{"version":3,"file":"SocketHelper.d.ts","sourceRoot":"","sources":["../../src/helpers/SocketHelper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiD,4BAA4B,EAAE,sBAAsB,EAAwE,MAAM,qBAAqB,CAAC;AAEhN,qBAAa,YAAY;IACvB,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC;IACzB,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC;IACxB,MAAM,CAAC,cAAc,EAAE,4BAA4B,EAAE,CAAM;IAC3D,OAAO,CAAC,MAAM,CAAC,gBAAgB,CAAkE;IACjG,OAAO,CAAC,MAAM,CAAC,gBAAgB,CAAuB;IACtD,OAAO,CAAC,MAAM,CAAC,WAAW,CAAkB;IAC5C,OAAO,CAAC,MAAM,CAAC,oBAAoB,CAAc;IACjD,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAa;IAE7C,MAAM,CAAC,eAAe,GAAI,IAAI;QAAC,QAAQ,EAAC,MAAM,CAAC;QAAC,QAAQ,EAAC,MAAM,CAAA;KAAC,UAK/D;IAED,MAAM,CAAC,qBAAqB,aAQ3B;IAED,MAAM,CAAC,IAAI,sBA0EV;IAED,MAAM,CAAC,UAAU,GAAI,QAAQ,MAAM,EAAE,IAAI,MAAM,EAAE,eAAe,CAAC,IAAI,EAAE,GAAG,KAAK,IAAI,UAOlF;IAED,MAAM,CAAC,aAAa,GAAI,IAAI,MAAM,UAEjC;IAED,MAAM,CAAC,sBAAsB,GAAI,QAAQ,MAAM,UAE9C;IAED,MAAM,CAAC,gBAAgB,aAEtB;IAED,MAAM,CAAC,aAAa,GAAI,SAAS,sBAAsB,UAqBtD;IAED,MAAM,CAAC,OAAO,aAwBb;IAED,MAAM,CAAC,UAAU,aAEhB;IAED,MAAM,CAAC,WAAW,QAAO,OAAO,CAE/B;IAED,MAAM,CAAC,kBAAkB,QAAO,MAAM,CAerC;IAGD,MAAM,CAAC,kBAAkB,mBAmBxB;CAEF"}
|
|
@@ -11,7 +11,6 @@ SocketHelper.maxReconnectAttempts = 10;
|
|
|
11
11
|
SocketHelper.reconnectAttempts = 0;
|
|
12
12
|
SocketHelper.setPersonChurch = (pc) => {
|
|
13
13
|
if (pc?.personId && pc.personId && pc.churchId !== _a.personIdChurchId.churchId && pc.personId !== _a.personIdChurchId.personId) {
|
|
14
|
-
//if (pc?.personId && pc.personId!==this.personIdChurchId.personId && this.socketId!==undefined && this.socketId) {
|
|
15
14
|
_a.personIdChurchId = pc;
|
|
16
15
|
_a.createAlertConnection();
|
|
17
16
|
}
|
|
@@ -19,7 +18,9 @@ SocketHelper.setPersonChurch = (pc) => {
|
|
|
19
18
|
SocketHelper.createAlertConnection = () => {
|
|
20
19
|
if (_a.personIdChurchId.personId && _a.socketId) {
|
|
21
20
|
const connection = { conversationId: "alerts", churchId: _a.personIdChurchId.churchId, displayName: "Test", socketId: _a.socketId, personId: _a.personIdChurchId.personId };
|
|
22
|
-
ApiHelper.postAnonymous("/connections", [connection], "MessagingApi")
|
|
21
|
+
ApiHelper.postAnonymous("/connections", [connection], "MessagingApi").catch((error) => {
|
|
22
|
+
console.error("❌ Failed to create alert connection:", error);
|
|
23
|
+
});
|
|
23
24
|
}
|
|
24
25
|
};
|
|
25
26
|
SocketHelper.init = async () => {
|
|
@@ -27,12 +28,12 @@ SocketHelper.init = async () => {
|
|
|
27
28
|
_a.cleanup();
|
|
28
29
|
// Reset cleanup flag
|
|
29
30
|
_a.isCleanedUp = false;
|
|
30
|
-
if (_a.socket
|
|
31
|
+
if (_a.socket && _a.socket.readyState !== _a.socket.CLOSED) {
|
|
31
32
|
try {
|
|
32
33
|
_a.socket.close();
|
|
33
34
|
}
|
|
34
35
|
catch (e) {
|
|
35
|
-
console.
|
|
36
|
+
console.error("❌ Error closing existing socket:", e);
|
|
36
37
|
}
|
|
37
38
|
}
|
|
38
39
|
await new Promise((resolve, reject) => {
|
|
@@ -40,18 +41,18 @@ SocketHelper.init = async () => {
|
|
|
40
41
|
_a.socket = new WebSocket(CommonEnvironmentHelper.MessagingApiSocket);
|
|
41
42
|
_a.socket.onmessage = (event) => {
|
|
42
43
|
if (_a.isCleanedUp)
|
|
43
|
-
return;
|
|
44
|
+
return;
|
|
44
45
|
try {
|
|
45
46
|
const payload = JSON.parse(event.data);
|
|
46
47
|
_a.handleMessage(payload);
|
|
47
48
|
}
|
|
48
49
|
catch (error) {
|
|
49
|
-
console.error("Error parsing socket message:", error);
|
|
50
|
+
console.error("❌ Error parsing socket message:", error);
|
|
50
51
|
}
|
|
51
52
|
};
|
|
52
53
|
_a.socket.onopen = async (e) => {
|
|
53
54
|
_a.reconnectAttempts = 0; // Reset reconnect attempts on successful connection
|
|
54
|
-
_a.socket.send("getId"); //
|
|
55
|
+
_a.socket.send("getId"); // Request socket ID
|
|
55
56
|
setTimeout(() => { resolve(null); }, 500);
|
|
56
57
|
};
|
|
57
58
|
_a.socket.onclose = async (e) => {
|
|
@@ -63,25 +64,29 @@ SocketHelper.init = async () => {
|
|
|
63
64
|
// Only attempt reconnection if not manually cleaned up and within retry limits
|
|
64
65
|
if (!_a.isCleanedUp && _a.reconnectAttempts < _a.maxReconnectAttempts) {
|
|
65
66
|
_a.reconnectAttempts++;
|
|
66
|
-
const backoffDelay = Math.min(1000 * Math.pow(2, _a.reconnectAttempts - 1), 30000);
|
|
67
|
+
const backoffDelay = Math.min(1000 * Math.pow(2, _a.reconnectAttempts - 1), 30000);
|
|
68
|
+
console.log(`🔄 WebSocket reconnecting... attempt ${_a.reconnectAttempts}/${_a.maxReconnectAttempts}`);
|
|
67
69
|
_a.reconnectTimeout = setTimeout(() => {
|
|
68
|
-
if (!_a.isCleanedUp && _a.socket.readyState === _a.socket.CLOSED) {
|
|
70
|
+
if (!_a.isCleanedUp && _a.socket && _a.socket.readyState === _a.socket.CLOSED) {
|
|
69
71
|
_a.init().then(() => {
|
|
70
72
|
_a.handleMessage({ action: "reconnect", data: null });
|
|
71
73
|
}).catch((error) => {
|
|
72
|
-
console.error("Reconnection failed:", error);
|
|
74
|
+
console.error("❌ Reconnection failed:", error);
|
|
73
75
|
});
|
|
74
76
|
}
|
|
75
77
|
}, backoffDelay);
|
|
76
78
|
}
|
|
79
|
+
else if (_a.reconnectAttempts >= _a.maxReconnectAttempts) {
|
|
80
|
+
console.error("❌ WebSocket max reconnection attempts reached");
|
|
81
|
+
}
|
|
77
82
|
};
|
|
78
83
|
_a.socket.onerror = (error) => {
|
|
79
|
-
console.error("WebSocket error:", error);
|
|
84
|
+
console.error("❌ WebSocket connection error:", error);
|
|
80
85
|
reject(error);
|
|
81
86
|
};
|
|
82
87
|
}
|
|
83
88
|
catch (error) {
|
|
84
|
-
console.error("Error initializing socket:", error);
|
|
89
|
+
console.error("❌ Error initializing socket:", error);
|
|
85
90
|
reject(error);
|
|
86
91
|
}
|
|
87
92
|
});
|
|
@@ -106,26 +111,26 @@ SocketHelper.clearAllHandlers = () => {
|
|
|
106
111
|
};
|
|
107
112
|
SocketHelper.handleMessage = (payload) => {
|
|
108
113
|
if (_a.isCleanedUp)
|
|
109
|
-
return;
|
|
114
|
+
return;
|
|
110
115
|
try {
|
|
111
|
-
//console.log("MESSAGE", payload)
|
|
112
116
|
if (payload.action === "socketId") {
|
|
113
117
|
_a.socketId = payload.data;
|
|
114
118
|
_a.createAlertConnection();
|
|
115
119
|
}
|
|
116
120
|
else {
|
|
117
|
-
ArrayHelper.getAll(_a.actionHandlers, "action", payload.action)
|
|
121
|
+
const matchingHandlers = ArrayHelper.getAll(_a.actionHandlers, "action", payload.action);
|
|
122
|
+
matchingHandlers.forEach((handler) => {
|
|
118
123
|
try {
|
|
119
124
|
handler.handleMessage(payload.data);
|
|
120
125
|
}
|
|
121
126
|
catch (error) {
|
|
122
|
-
console.error(
|
|
127
|
+
console.error(`❌ Error in handler ${handler.id}:`, error);
|
|
123
128
|
}
|
|
124
129
|
});
|
|
125
130
|
}
|
|
126
131
|
}
|
|
127
132
|
catch (error) {
|
|
128
|
-
console.error("Error handling socket message:", error);
|
|
133
|
+
console.error("❌ Error handling socket message:", error);
|
|
129
134
|
}
|
|
130
135
|
};
|
|
131
136
|
SocketHelper.cleanup = () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SocketHelper.js","sourceRoot":"","sources":["../../src/helpers/SocketHelper.ts"],"names":[],"mappings":";AAAA,OAAO,EAA4H,SAAS,EAAE,WAAW,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;AAEhN,MAAM,OAAO,YAAY;;;AAGhB,2BAAc,GAAmC,EAAE,AAArC,CAAsC;AAC5C,6BAAgB,GAAuC,EAAC,QAAQ,EAAC,EAAE,EAAE,QAAQ,EAAC,EAAE,EAAC,AAAjE,CAAkE;AAClF,6BAAgB,GAAkB,IAAI,AAAtB,CAAuB;AACvC,wBAAW,GAAY,KAAK,AAAjB,CAAkB;AAC7B,iCAAoB,GAAW,EAAE,AAAb,CAAc;AAClC,8BAAiB,GAAW,CAAC,AAAZ,CAAa;AAEtC,4BAAe,GAAG,CAAC,EAAsC,EAAE,EAAE;IAClE,IAAI,EAAE,EAAE,QAAQ,IAAI,EAAE,CAAC,QAAQ,IAAI,EAAE,CAAC,QAAQ,KAAG,EAAI,CAAC,gBAAgB,CAAC,QAAQ,IAAI,EAAE,CAAC,QAAQ,KAAG,EAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"SocketHelper.js","sourceRoot":"","sources":["../../src/helpers/SocketHelper.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
var _a;
|
|
2
|
-
import { ApiHelper } from "
|
|
2
|
+
import { ApiHelper } from "@churchapps/helpers";
|
|
3
3
|
export class UserHelper {
|
|
4
4
|
static setupApiHelper(userChurch) {
|
|
5
5
|
ApiHelper.setDefaultPermissions(userChurch.jwt);
|
|
@@ -12,7 +12,7 @@ export class UserHelper {
|
|
|
12
12
|
const permissions = ApiHelper.getConfig(api)?.permissions || [];
|
|
13
13
|
let result = false;
|
|
14
14
|
if (permissions !== undefined) {
|
|
15
|
-
permissions.forEach(element => {
|
|
15
|
+
permissions.forEach((element) => {
|
|
16
16
|
if (element.contentType === contentType && element.action === action)
|
|
17
17
|
result = true;
|
|
18
18
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UserHelper.js","sourceRoot":"","sources":["../../src/helpers/UserHelper.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"UserHelper.js","sourceRoot":"","sources":["../../src/helpers/UserHelper.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAG/C,MAAM,OAAO,UAAU;IA6BtB,MAAM,CAAC,cAAc,CAAC,UAAoC;QACzD,SAAS,CAAC,qBAAqB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QAChD,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,GAAG,SAAS,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACtG,CAAC;IAED,MAAM,CAAC,sBAAsB,CAAC,IAA8B;QAC3D,SAAS,CAAC,qBAAqB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC3C,CAAC;IAED,MAAM,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,EAAkB;QAC9D,MAAM,WAAW,GAAG,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,WAAW,IAAI,EAAE,CAAC;QAEhE,IAAI,MAAM,GAAG,KAAK,CAAC;QACnB,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;YAC/B,WAAW,CAAC,OAAO,CAAC,CAAC,OAAY,EAAE,EAAE;gBACpC,IAAI,OAAO,CAAC,WAAW,KAAK,WAAW,IAAI,OAAO,CAAC,MAAM,KAAK,MAAM;oBAAE,MAAM,GAAG,IAAI,CAAC;YACrF,CAAC,CAAC,CAAC;QACJ,CAAC;QACD,OAAO,MAAM,CAAC;IACf,CAAC;IAED,MAAM,CAAC,YAAY,CAAC,MAAc,EAAE,SAAiB;QACpD,MAAM,GAAG,GAAG,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,EAAE,GAAG,CAAC;QAEtD,IAAI,GAAG,EAAE,CAAC;YACT,OAAO,GAAG,MAAM,eAAe,GAAG,cAAc,kBAAkB,CAAC,SAAS,CAAC,EAAE,CAAC;QACjF,CAAC;aAAM,CAAC;YACP,OAAO,GAAG,MAAM,qBAAqB,kBAAkB,CAAC,SAAS,CAAC,EAAE,CAAC;QACtE,CAAC;IACF,CAAC;IAED,MAAM,CAAC,eAAe,CAAC,SAAkB,EAAE,cAAsC;QAChF,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;YACnC,MAAM,UAAU,GAAG,SAAS,IAAI,MAAM,CAAC,QAAQ,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;YAClF,MAAM,gBAAgB,GAAG,kBAAkB,CAAC,UAAU,CAAC,CAAC;YACxD,MAAM,QAAQ,GAAG,oBAAoB,gBAAgB,EAAE,CAAC;YAExD,kFAAkF;YAClF,IAAI,cAAc,EAAE,CAAC;gBACpB,cAAc,CAAC,QAAQ,CAAC,CAAC;YAC1B,CAAC;iBAAM,CAAC;gBACP,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,QAAQ,CAAC;YACjC,CAAC;QACF,CAAC;IACF,CAAC;;;AArEM,wBAAa,GAAY,KAAK,AAAjB,CAAkB;AAG/B,uBAAY,GAAG,KAAK,EAAE,OAA8B,EAAE,QAAiB,EAAE,OAAgB,EAAE,EAAE;IACnG,IAAI,UAAU,GAAG,IAAI,CAAC;IAEtB,IAAI,QAAQ,EAAE,CAAC;QACd,EAAU,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;YACpC,IAAI,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,QAAQ;gBAAE,UAAU,GAAG,EAAE,CAAC;QAChD,CAAC,CAAC,CAAC;IACJ,CAAC;SACI,IAAI,OAAO;QAAE,EAAU,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,MAAM,CAAC,SAAS,KAAK,OAAO;YAAE,UAAU,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;;QAC9G,UAAU,GAAG,EAAU,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC7C,IAAI,CAAC,UAAU;QAAE,OAAO;SACnB,CAAC;QACL,EAAU,CAAC,iBAAiB,GAAG,UAAU,CAAC;QAC1C,EAAU,CAAC,cAAc,CAAC,EAAU,CAAC,iBAAiB,CAAC,CAAC;QACxD,sFAAsF;QACtF,IAAI,OAAO,EAAE,CAAC;YACb,IAAI,OAAO,CAAC,UAAU,KAAK,IAAI;gBAAE,EAAU,CAAC,aAAa,GAAG,IAAI,CAAC;YACjE,OAAO,CAAC,aAAa,CAAC,EAAU,CAAC,iBAAiB,CAAC,CAAC;QACrD,CAAC;IACF,CAAC;AACF,CAAC,AApBkB,CAoBlB"}
|
package/dist/helpers/index.d.ts
CHANGED
|
@@ -7,4 +7,6 @@ export { createEmotionCache } from "./createEmotionCache";
|
|
|
7
7
|
export { Locale } from "./Locale";
|
|
8
8
|
export { SlugHelper } from "./SlugHelper";
|
|
9
9
|
export { SocketHelper } from "./SocketHelper";
|
|
10
|
+
export { NotificationService } from "./NotificationService";
|
|
11
|
+
export type { NotificationCounts } from "./NotificationService";
|
|
10
12
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,SAAS,EACT,gBAAgB,IAAI,oBAAoB,EACxC,WAAW,EACX,uBAAuB,EACvB,cAAc,EACd,UAAU,EACV,WAAW,EACX,WAAW,EACX,UAAU,EACV,YAAY,EACZ,UAAU,EACV,cAAc,EACd,WAAW,EACZ,MAAM,qBAAqB,CAAC;AAG7B,YAAY,EACV,iBAAiB,EACjB,oBAAoB,EACpB,mBAAmB,EACnB,eAAe,EACf,eAAe,EACf,aAAa,EACb,wBAAwB,EACxB,oBAAoB,EACpB,iBAAiB,EACjB,aAAa,EACb,sBAAsB,EACtB,uBAAuB,EACvB,qBAAqB,EACrB,6BAA6B,EAC7B,8BAA8B,EAC9B,mBAAmB,EACnB,4BAA4B,EAC5B,sBAAsB,EACtB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAG7B,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,YAAY,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,SAAS,EACT,gBAAgB,IAAI,oBAAoB,EACxC,WAAW,EACX,uBAAuB,EACvB,cAAc,EACd,UAAU,EACV,WAAW,EACX,WAAW,EACX,UAAU,EACV,YAAY,EACZ,UAAU,EACV,cAAc,EACd,WAAW,EACZ,MAAM,qBAAqB,CAAC;AAG7B,YAAY,EACV,iBAAiB,EACjB,oBAAoB,EACpB,mBAAmB,EACnB,eAAe,EACf,eAAe,EACf,aAAa,EACb,wBAAwB,EACxB,oBAAoB,EACpB,iBAAiB,EACjB,aAAa,EACb,sBAAsB,EACtB,uBAAuB,EACvB,qBAAqB,EACrB,6BAA6B,EAC7B,8BAA8B,EAC9B,mBAAmB,EACnB,4BAA4B,EAC5B,sBAAsB,EACtB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAG7B,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,YAAY,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,YAAY,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC"}
|
package/dist/helpers/index.js
CHANGED
|
@@ -7,4 +7,5 @@ export { createEmotionCache } from "./createEmotionCache";
|
|
|
7
7
|
export { Locale } from "./Locale";
|
|
8
8
|
export { SlugHelper } from "./SlugHelper";
|
|
9
9
|
export { SocketHelper } from "./SocketHelper";
|
|
10
|
+
export { NotificationService } from "./NotificationService";
|
|
10
11
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":"AAAA,qCAAqC;AACrC,OAAO,EACL,SAAS,EACT,gBAAgB,IAAI,oBAAoB,EACxC,WAAW,EACX,uBAAuB,EACvB,cAAc,EACd,UAAU,EACV,WAAW,EACX,WAAW,EACX,UAAU,EACV,YAAY,EACZ,UAAU,EACV,cAAc,EACd,WAAW,EACZ,MAAM,qBAAqB,CAAC;AAyB7B,uBAAuB;AACvB,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/helpers/index.ts"],"names":[],"mappings":"AAAA,qCAAqC;AACrC,OAAO,EACL,SAAS,EACT,gBAAgB,IAAI,oBAAoB,EACxC,WAAW,EACX,uBAAuB,EACvB,cAAc,EACd,UAAU,EACV,WAAW,EACX,WAAW,EACX,UAAU,EACV,YAAY,EACZ,UAAU,EACV,cAAc,EACd,WAAW,EACZ,MAAM,qBAAqB,CAAC;AAyB7B,uBAAuB;AACvB,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC"}
|
package/dist/hooks/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,YAAY,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC"}
|
package/dist/hooks/index.js
CHANGED
package/dist/hooks/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { NotificationCounts } from '../helpers/NotificationService';
|
|
2
|
+
import { UserContextInterface } from '@churchapps/helpers';
|
|
3
|
+
export interface UseNotificationsResult {
|
|
4
|
+
counts: NotificationCounts;
|
|
5
|
+
isLoading: boolean;
|
|
6
|
+
isReady: boolean;
|
|
7
|
+
refresh: () => Promise<void>;
|
|
8
|
+
error: string | null;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Custom hook for managing real-time notifications
|
|
12
|
+
*
|
|
13
|
+
* @param context - User context containing person and church information
|
|
14
|
+
* @returns Object containing notification counts and management functions
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* ```tsx
|
|
18
|
+
* const { counts, isLoading, refresh } = useNotifications(context);
|
|
19
|
+
*
|
|
20
|
+
* return (
|
|
21
|
+
* <UserMenu
|
|
22
|
+
* notificationCounts={counts}
|
|
23
|
+
* loadCounts={refresh}
|
|
24
|
+
* // ... other props
|
|
25
|
+
* />
|
|
26
|
+
* );
|
|
27
|
+
* ```
|
|
28
|
+
*/
|
|
29
|
+
export declare function useNotifications(context: UserContextInterface | null): UseNotificationsResult;
|
|
30
|
+
//# sourceMappingURL=useNotifications.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useNotifications.d.ts","sourceRoot":"","sources":["../../src/hooks/useNotifications.ts"],"names":[],"mappings":"AACA,OAAO,EAAuB,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACzF,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAE3D,MAAM,WAAW,sBAAsB;IACrC,MAAM,EAAE,kBAAkB,CAAC;IAC3B,SAAS,EAAE,OAAO,CAAC;IACnB,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7B,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CACtB;AAED;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,oBAAoB,GAAG,IAAI,GAAG,sBAAsB,CA8D7F"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import React, { useState, useEffect, useCallback } from 'react';
|
|
2
|
+
import { NotificationService } from '../helpers/NotificationService';
|
|
3
|
+
/**
|
|
4
|
+
* Custom hook for managing real-time notifications
|
|
5
|
+
*
|
|
6
|
+
* @param context - User context containing person and church information
|
|
7
|
+
* @returns Object containing notification counts and management functions
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```tsx
|
|
11
|
+
* const { counts, isLoading, refresh } = useNotifications(context);
|
|
12
|
+
*
|
|
13
|
+
* return (
|
|
14
|
+
* <UserMenu
|
|
15
|
+
* notificationCounts={counts}
|
|
16
|
+
* loadCounts={refresh}
|
|
17
|
+
* // ... other props
|
|
18
|
+
* />
|
|
19
|
+
* );
|
|
20
|
+
* ```
|
|
21
|
+
*/
|
|
22
|
+
export function useNotifications(context) {
|
|
23
|
+
const [counts, setCounts] = useState({ notificationCount: 0, pmCount: 0 });
|
|
24
|
+
const [isLoading, setIsLoading] = useState(true);
|
|
25
|
+
const [error, setError] = useState(null);
|
|
26
|
+
// Get the singleton instance only once
|
|
27
|
+
const notificationService = React.useMemo(() => NotificationService.getInstance(), []);
|
|
28
|
+
// Initialize the service when context becomes available
|
|
29
|
+
useEffect(() => {
|
|
30
|
+
if (!context?.person?.id || !context?.userChurch?.church?.id) {
|
|
31
|
+
setIsLoading(false);
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
const initializeService = async () => {
|
|
35
|
+
try {
|
|
36
|
+
setIsLoading(true);
|
|
37
|
+
setError(null);
|
|
38
|
+
await notificationService.initialize(context);
|
|
39
|
+
}
|
|
40
|
+
catch (err) {
|
|
41
|
+
console.error("❌ useNotifications: Failed to initialize:", err);
|
|
42
|
+
setError(err instanceof Error ? err.message : 'Failed to initialize notifications');
|
|
43
|
+
}
|
|
44
|
+
finally {
|
|
45
|
+
setIsLoading(false);
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
initializeService();
|
|
49
|
+
}, [context?.person?.id, context?.userChurch?.church?.id]);
|
|
50
|
+
// Subscribe to notification count changes
|
|
51
|
+
useEffect(() => {
|
|
52
|
+
const unsubscribe = notificationService.subscribe((newCounts) => {
|
|
53
|
+
setCounts(newCounts);
|
|
54
|
+
});
|
|
55
|
+
// Cleanup subscription on unmount
|
|
56
|
+
return () => {
|
|
57
|
+
unsubscribe();
|
|
58
|
+
};
|
|
59
|
+
}, [notificationService]);
|
|
60
|
+
// Refresh function - memoized without dependencies for stable reference
|
|
61
|
+
const refresh = useCallback(async () => {
|
|
62
|
+
try {
|
|
63
|
+
setError(null);
|
|
64
|
+
await NotificationService.getInstance().refresh();
|
|
65
|
+
}
|
|
66
|
+
catch (err) {
|
|
67
|
+
console.error("❌ useNotifications: Refresh failed:", err);
|
|
68
|
+
setError(err instanceof Error ? err.message : 'Failed to refresh notifications');
|
|
69
|
+
}
|
|
70
|
+
}, []);
|
|
71
|
+
return {
|
|
72
|
+
counts,
|
|
73
|
+
isLoading,
|
|
74
|
+
isReady: notificationService.isReady(),
|
|
75
|
+
refresh,
|
|
76
|
+
error
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=useNotifications.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useNotifications.js","sourceRoot":"","sources":["../../src/hooks/useNotifications.ts"],"names":[],"mappings":"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"}
|
|
@@ -58,13 +58,17 @@
|
|
|
58
58
|
}
|
|
59
59
|
|
|
60
60
|
#primaryNavButton {
|
|
61
|
-
margin-right:
|
|
61
|
+
margin-right:15px;
|
|
62
62
|
text-transform: "none";
|
|
63
|
+
height: 48px !important;
|
|
64
|
+
min-height: 48px !important;
|
|
65
|
+
max-height: 48px !important;
|
|
63
66
|
}
|
|
64
67
|
|
|
65
68
|
#primaryNavButton img {
|
|
66
|
-
height:35px;
|
|
69
|
+
height:35px !important;
|
|
67
70
|
margin-right:15px;
|
|
71
|
+
max-height:35px !important;
|
|
68
72
|
}
|
|
69
73
|
|
|
70
74
|
#primaryNavButton h2 {
|
package/package.json
CHANGED
package/public/css/styles.css
CHANGED
|
@@ -58,13 +58,17 @@
|
|
|
58
58
|
}
|
|
59
59
|
|
|
60
60
|
#primaryNavButton {
|
|
61
|
-
margin-right:
|
|
61
|
+
margin-right:15px;
|
|
62
62
|
text-transform: "none";
|
|
63
|
+
height: 48px !important;
|
|
64
|
+
min-height: 48px !important;
|
|
65
|
+
max-height: 48px !important;
|
|
63
66
|
}
|
|
64
67
|
|
|
65
68
|
#primaryNavButton img {
|
|
66
|
-
height:35px;
|
|
69
|
+
height:35px !important;
|
|
67
70
|
margin-right:15px;
|
|
71
|
+
max-height:35px !important;
|
|
68
72
|
}
|
|
69
73
|
|
|
70
74
|
#primaryNavButton h2 {
|
|
@@ -60,22 +60,22 @@ export const DisplayBox = React.forwardRef<HTMLDivElement, Props>((props, ref) =
|
|
|
60
60
|
else if (props.editContent !== undefined) editContent = props.editContent;
|
|
61
61
|
|
|
62
62
|
return (
|
|
63
|
-
<Paper sx={{ padding: 2, marginBottom: 4 }} id={props.id} data-testid={props["data-testid"] || ""}>
|
|
63
|
+
<Paper sx={{ padding: 2, marginBottom: 4 }} id={props.id || "display-box"} data-testid={props["data-testid"] || ""}>
|
|
64
64
|
{props.help && <HelpIcon article={props.help} />}
|
|
65
|
-
<Box sx={{ display: "flex", justifyContent: "space-between", alignItems: "center" }}>
|
|
66
|
-
<Box sx={{ display: "flex", alignItems: "center" }}>
|
|
67
|
-
{props.headerIcon && <Icon sx={{ color: headerText }}>{props.headerIcon}</Icon>}
|
|
68
|
-
<Typography component="h2" sx={{ display: "inline-block", marginLeft: props.headerIcon ? 1 : 0 }} variant="h6" color={headerText}>
|
|
65
|
+
<Box id="display-box-header" sx={{ display: "flex", justifyContent: "space-between", alignItems: "center" }}>
|
|
66
|
+
<Box id="display-box-title-section" sx={{ display: "flex", alignItems: "center" }}>
|
|
67
|
+
{props.headerIcon && <Icon id="display-box-icon" sx={{ color: headerText }}>{props.headerIcon}</Icon>}
|
|
68
|
+
<Typography id="display-box-title" component="h2" sx={{ display: "inline-block", marginLeft: props.headerIcon ? 1 : 0 }} variant="h6" color={headerText}>
|
|
69
69
|
{props.headerText}
|
|
70
70
|
</Typography>
|
|
71
71
|
|
|
72
72
|
</Box>
|
|
73
|
-
<Box>
|
|
73
|
+
<Box id="display-box-actions">
|
|
74
74
|
{editContent}
|
|
75
75
|
</Box>
|
|
76
76
|
</Box>
|
|
77
|
-
<CustomContextBox ref={ref} data-testid="display-box-content">{props.children}</CustomContextBox>
|
|
78
|
-
{props.footerContent && (<div style={{ marginLeft: -16, marginRight: -16, marginBottom: -15, marginTop: 15 }}>{props.footerContent}</div>)}
|
|
77
|
+
<CustomContextBox id="display-box-content" ref={ref} data-testid="display-box-content">{props.children}</CustomContextBox>
|
|
78
|
+
{props.footerContent && (<div id="display-box-footer" style={{ marginLeft: -16, marginRight: -16, marginBottom: -15, marginTop: 15 }}>{props.footerContent}</div>)}
|
|
79
79
|
</Paper>
|
|
80
80
|
);
|
|
81
81
|
})
|