summaryrefslogtreecommitdiff
path: root/src/web/app/desktop/script.js
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2017-06-07 00:04:28 +0900
committersyuilo <syuilotan@yahoo.co.jp>2017-06-07 00:04:28 +0900
commit6dd635ddf3d0928bb0a283a21f342ff05e8e61ba (patch)
tree02d294da5cb06611b7c01772f7418dc00161cbf8 /src/web/app/desktop/script.js
parentMerge branch 'master' of https://github.com/syuilo/misskey (diff)
downloadmisskey-6dd635ddf3d0928bb0a283a21f342ff05e8e61ba.tar.gz
misskey-6dd635ddf3d0928bb0a283a21f342ff05e8e61ba.tar.bz2
misskey-6dd635ddf3d0928bb0a283a21f342ff05e8e61ba.zip
Fix bug
Diffstat (limited to 'src/web/app/desktop/script.js')
-rw-r--r--src/web/app/desktop/script.js43
1 files changed, 41 insertions, 2 deletions
diff --git a/src/web/app/desktop/script.js b/src/web/app/desktop/script.js
index b3691f7ff2..6beba44ffa 100644
--- a/src/web/app/desktop/script.js
+++ b/src/web/app/desktop/script.js
@@ -11,11 +11,12 @@ import * as riot from 'riot';
import init from '../init';
import route from './router';
import fuckAdBlock from './scripts/fuck-ad-block';
+import getPostSummary from '../common/scripts/get-post-summary';
/**
* init
*/
-init(me => {
+init(async (me, stream) => {
/**
* Fuck AD Block
*/
@@ -27,10 +28,48 @@ init(me => {
if ('Notification' in window) {
// 許可を得ていなかったらリクエスト
if (Notification.permission == 'default') {
- Notification.requestPermission();
+ await Notification.requestPermission();
+ }
+
+ if (Notification.permission == 'granted') {
+ registerNotifications(stream);
}
}
// Start routing
route(me);
});
+
+function registerNotifications(stream) {
+ stream.on('drive_file_created', file => {
+ const n = new Notification('ファイルがアップロードされました', {
+ body: file.name,
+ icon: file.url + '?thumbnail&size=64'
+ });
+ setTimeout(n.close.bind(n), 5000);
+ });
+
+ stream.on('mention', post => {
+ const n = new Notification(`${post.user.name}さんから:`, {
+ body: getPostSummary(post),
+ icon: post.user.avatar_url + '?thumbnail&size=64'
+ });
+ setTimeout(n.close.bind(n), 6000);
+ });
+
+ stream.on('reply', post => {
+ const n = new Notification(`${post.user.name}さんから返信:`, {
+ body: getPostSummary(post),
+ icon: post.user.avatar_url + '?thumbnail&size=64'
+ });
+ setTimeout(n.close.bind(n), 6000);
+ });
+
+ stream.on('quote', post => {
+ const n = new Notification(`${post.user.name}さんが引用:`, {
+ body: getPostSummary(post),
+ icon: post.user.avatar_url + '?thumbnail&size=64'
+ });
+ setTimeout(n.close.bind(n), 6000);
+ });
+}