forked from mystiq/hydrogen-web
improve notification click handling
- also here don't use client.url to figure out if a session is open as that doesn't work in FF - use tag to make sure we're dealing with the right type of notif - use findClient function
This commit is contained in:
parent
f91abe4301
commit
0b3f2a7fa0
1 changed files with 13 additions and 12 deletions
|
@ -189,23 +189,24 @@ const NOTIF_TAG_MESSAGES_READ = "messages_read";
|
|||
const NOTIF_TAG_NEW_MESSAGE = "new_message";
|
||||
|
||||
async function openClientFromNotif(event) {
|
||||
const clientList = await self.clients.matchAll({type: "window"});
|
||||
if (event.notification.tag !== NOTIF_TAG_NEW_MESSAGE) {
|
||||
return;
|
||||
}
|
||||
const {sessionId, roomId} = event.notification.data;
|
||||
const sessionHash = `#/session/${sessionId}`;
|
||||
const roomHash = `${sessionHash}/room/${roomId}`;
|
||||
const roomURL = `/${roomHash}`;
|
||||
for (let i = 0; i < clientList.length; i++) {
|
||||
const client = clientList[i];
|
||||
const url = new URL(client.url, baseURL);
|
||||
if (url.hash.startsWith(sessionHash)) {
|
||||
client.navigate(roomURL);
|
||||
if ('focus' in client) {
|
||||
await client.focus();
|
||||
}
|
||||
return;
|
||||
const clientWithSession = await findClient(async client => {
|
||||
return await sendAndWaitForReply(client, "hasSessionOpen", {sessionId});
|
||||
});
|
||||
if (clientWithSession) {
|
||||
console.log("notificationclick: client has session open, showing room there");
|
||||
clientWithSession.navigate(roomURL);
|
||||
if ('focus' in clientWithSession) {
|
||||
await clientWithSession.focus();
|
||||
}
|
||||
}
|
||||
if (self.clients.openWindow) {
|
||||
} else if (self.client.openWindow) {
|
||||
console.log("notificationclick: no client found with session open, opening new window");
|
||||
await self.clients.openWindow(roomURL);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue