summaryrefslogtreecommitdiff
path: root/src/client/sw
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2020-12-26 14:11:08 +0900
committersyuilo <syuilotan@yahoo.co.jp>2020-12-26 14:11:08 +0900
commitec4d5857d80938758ce64930159be2c941d4e30f (patch)
treebfa24ed39ef9b90e290a504ca5ed2ee00ef280c7 /src/client/sw
parentAdd note (diff)
downloadmisskey-ec4d5857d80938758ce64930159be2c941d4e30f.tar.gz
misskey-ec4d5857d80938758ce64930159be2c941d4e30f.tar.bz2
misskey-ec4d5857d80938758ce64930159be2c941d4e30f.zip
Fix service worker generation
Diffstat (limited to 'src/client/sw')
-rw-r--r--src/client/sw/compose-notification.ts90
-rw-r--r--src/client/sw/i18n.ts3
-rw-r--r--src/client/sw/sw.ts66
3 files changed, 159 insertions, 0 deletions
diff --git a/src/client/sw/compose-notification.ts b/src/client/sw/compose-notification.ts
new file mode 100644
index 0000000000..0863d7ef8b
--- /dev/null
+++ b/src/client/sw/compose-notification.ts
@@ -0,0 +1,90 @@
+import getNoteSummary from '../../misc/get-note-summary';
+import getUserName from '../../misc/get-user-name';
+import { i18n } from '@/sw/i18n';
+
+export default async function(type, data): Promise<[string, NotificationOptions]> {
+ switch (type) {
+ case 'driveFileCreated': // TODO (Server Side)
+ return [i18n.t('_notification.fileUploaded'), {
+ body: data.name,
+ icon: data.url
+ }];
+ case 'notification':
+ switch (data.type) {
+ case 'mention':
+ return [i18n.t('_notification.youGotMention', { name: getUserName(data.user) }), {
+ body: getNoteSummary(data.note, i18n.locale),
+ icon: data.user.avatarUrl
+ }];
+
+ case 'reply':
+ return [i18n.t('_notification.youGotReply', { name: getUserName(data.user) }), {
+ body: getNoteSummary(data.note, i18n.locale),
+ icon: data.user.avatarUrl
+ }];
+
+ case 'renote':
+ return [i18n.t('_notification.youRenoted', { name: getUserName(data.user) }), {
+ body: getNoteSummary(data.note, i18n.locale),
+ icon: data.user.avatarUrl
+ }];
+
+ case 'quote':
+ return [i18n.t('_notification.youGotQuote', { name: getUserName(data.user) }), {
+ body: getNoteSummary(data.note, i18n.locale),
+ icon: data.user.avatarUrl
+ }];
+
+ case 'reaction':
+ return [`${data.reaction} ${getUserName(data.user)}`, {
+ body: getNoteSummary(data.note, i18n.locale),
+ icon: data.user.avatarUrl
+ }];
+
+ case 'pollVote':
+ return [i18n.t('_notification.youGotPoll', { name: getUserName(data.user) }), {
+ body: getNoteSummary(data.note, i18n.locale),
+ icon: data.user.avatarUrl
+ }];
+
+ case 'follow':
+ return [i18n.t('_notification.youWereFollowed'), {
+ body: getUserName(data.user),
+ icon: data.user.avatarUrl
+ }];
+
+ case 'receiveFollowRequest':
+ return [i18n.t('_notification.youReceivedFollowRequest'), {
+ body: getUserName(data.user),
+ icon: data.user.avatarUrl
+ }];
+
+ case 'followRequestAccepted':
+ return [i18n.t('_notification.yourFollowRequestAccepted'), {
+ body: getUserName(data.user),
+ icon: data.user.avatarUrl
+ }];
+
+ case 'groupInvited':
+ return [i18n.t('_notification.youWereInvitedToGroup'), {
+ body: data.group.name
+ }];
+
+ default:
+ return null;
+ }
+ case 'unreadMessagingMessage':
+ if (data.groupId === null) {
+ return [i18n.t('_notification.youGotMessagingMessageFromUser', { name: getUserName(data.user) }), {
+ icon: data.user.avatarUrl,
+ tag: `messaging:user:${data.user.id}`
+ }];
+ }
+ return [i18n.t('_notification.youGotMessagingMessageFromGroup', { name: data.group.name }), {
+ icon: data.user.avatarUrl,
+ tag: `messaging:group:${data.group.id}`
+ }];
+ default:
+ return null;
+ }
+}
diff --git a/src/client/sw/i18n.ts b/src/client/sw/i18n.ts
new file mode 100644
index 0000000000..524a205b2f
--- /dev/null
+++ b/src/client/sw/i18n.ts
@@ -0,0 +1,3 @@
+import { I18n } from '@/i18n';
+
+export const i18n = new I18n(_LOCALE_);
diff --git a/src/client/sw/sw.ts b/src/client/sw/sw.ts
new file mode 100644
index 0000000000..91d668c27b
--- /dev/null
+++ b/src/client/sw/sw.ts
@@ -0,0 +1,66 @@
+/**
+ * Service Worker
+ */
+declare var self: ServiceWorkerGlobalScope;
+
+import composeNotification from '@/sw/compose-notification';
+
+const version = _VERSION_;
+const cacheName = `mk-cache-${version}`;
+
+const apiUrl = `${location.origin}/api/`;
+
+// インストールされたとき
+self.addEventListener('install', ev => {
+ console.info('installed');
+
+ ev.waitUntil(
+ caches.open(cacheName)
+ .then(cache => {
+ return cache.addAll([
+ `/?v=${version}`
+ ]);
+ })
+ .then(() => self.skipWaiting())
+ );
+});
+
+self.addEventListener('activate', ev => {
+ ev.waitUntil(
+ caches.keys()
+ .then(cacheNames => Promise.all(
+ cacheNames
+ .filter((v) => v !== cacheName)
+ .map(name => caches.delete(name))
+ ))
+ .then(() => self.clients.claim())
+ );
+});
+
+self.addEventListener('fetch', ev => {
+ if (ev.request.method !== 'GET' || ev.request.url.startsWith(apiUrl)) return;
+ ev.respondWith(
+ caches.match(ev.request)
+ .then(response => {
+ return response || fetch(ev.request);
+ })
+ .catch(() => {
+ return caches.match(`/?v=${version}`);
+ })
+ );
+});
+
+// プッシュ通知を受け取ったとき
+self.addEventListener('push', ev => {
+ // クライアント取得
+ ev.waitUntil(self.clients.matchAll({
+ includeUncontrolled: true
+ }).then(async clients => {
+ // クライアントがあったらストリームに接続しているということなので通知しない
+ if (clients.length != 0) return;
+
+ const { type, body } = ev.data.json();
+
+ return self.registration.showNotification(...(await composeNotification(type, body)));
+ }));
+});