fix
This commit is contained in:
parent
1fca78f0a1
commit
9e0f53a7e7
|
@ -1,47 +1,47 @@
|
||||||
import { get } from "idb-keyval";
|
import { get } from 'idb-keyval';
|
||||||
import { pushNotificationData } from '../../types';
|
import { pushNotificationData } from '../../types';
|
||||||
|
|
||||||
type Accounts = {
|
type Accounts = {
|
||||||
[x: string]: {
|
[x: string]: {
|
||||||
queue: string[],
|
queue: string[],
|
||||||
timeout: number | null,
|
timeout: number | null,
|
||||||
token: string,
|
token: string,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class SwNotificationRead {
|
class SwNotificationRead {
|
||||||
private accounts: Accounts = {};
|
private accounts: Accounts = {};
|
||||||
|
|
||||||
public async construct() {
|
public async construct() {
|
||||||
const accounts = await get('accounts') as { i: string, id: string }[];
|
const accounts = await get('accounts') as { i: string, id: string }[];
|
||||||
if (accounts) Error('Account is not recorded');
|
if (accounts) Error('Account is not recorded');
|
||||||
|
|
||||||
this.accounts = accounts.reduce((acc, e) => {
|
this.accounts = accounts.reduce((acc, e) => {
|
||||||
acc[e.id] = {
|
acc[e.id] = {
|
||||||
queue: [],
|
queue: [],
|
||||||
timeout: null,
|
timeout: null,
|
||||||
token: e.i,
|
token: e.i,
|
||||||
};
|
};
|
||||||
return acc;
|
return acc;
|
||||||
}, {} as Accounts);
|
}, {} as Accounts);
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
// プッシュ通知の既読をサーバーに送信
|
// プッシュ通知の既読をサーバーに送信
|
||||||
public async read(data: pushNotificationData) {
|
public async read(data: pushNotificationData) {
|
||||||
if (data.type !== 'notification' || !(data.userId in this.accounts)) return;
|
if (data.type !== 'notification' || !(data.userId in this.accounts)) return;
|
||||||
|
|
||||||
const account = this.accounts[data.userId]
|
const account = this.accounts[data.userId];
|
||||||
|
|
||||||
account.queue.push(data.body.id)
|
account.queue.push(data.body.id);
|
||||||
|
|
||||||
// 最後の呼び出しから100ms待ってまとめて処理する
|
// 最後の呼び出しから100ms待ってまとめて処理する
|
||||||
if (account.timeout) clearTimeout(account.timeout);
|
if (account.timeout) clearTimeout(account.timeout);
|
||||||
account.timeout = setTimeout(() => {
|
account.timeout = setTimeout(() => {
|
||||||
account.timeout = null;
|
account.timeout = null;
|
||||||
|
|
||||||
console.info(account.token, account.queue)
|
console.info(account.token, account.queue);
|
||||||
fetch(`${location.origin}/api/notifications/read`, {
|
fetch(`${location.origin}/api/notifications/read`, {
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
body: JSON.stringify({
|
body: JSON.stringify({
|
||||||
|
|
|
@ -71,8 +71,8 @@ self.addEventListener('push', ev => {
|
||||||
case 'readNotifications':
|
case 'readNotifications':
|
||||||
for (const notification of await self.registration.getNotifications()) {
|
for (const notification of await self.registration.getNotifications()) {
|
||||||
if (data.body.notificationIds.includes(notification.data.body.id)) {
|
if (data.body.notificationIds.includes(notification.data.body.id)) {
|
||||||
notification.close()
|
notification.close();
|
||||||
};
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,7 @@ export const noteVisibilities = ['public', 'home', 'followers', 'specified'] as
|
||||||
export const mutedNoteReasons = ['word', 'manual', 'spam', 'other'] as const;
|
export const mutedNoteReasons = ['word', 'manual', 'spam', 'other'] as const;
|
||||||
|
|
||||||
export type pushNotificationData = {
|
export type pushNotificationData = {
|
||||||
type: 'notification' | 'unreadMessagingMessage' | 'readNotifications' | 'readAllNotifications',
|
type: 'notification' | 'unreadMessagingMessage' | 'readNotifications' | 'readAllNotifications',
|
||||||
body: any,
|
body: any,
|
||||||
userId: string
|
userId: string
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue