commit 476cb0ae6525177d7ea0519c9f0c4de67d2bf0f3
parent 5a631d3833a63e76d3611dc97ec073e471af58ba
Author: RobinLinus <robinlinus@users.noreply.github.com>
Date: Fri, 21 Sep 2018 22:31:46 +0200
Notifications
Diffstat:
1 file changed, 16 insertions(+), 6 deletions(-)
diff --git a/client/scripts/ui.js b/client/scripts/ui.js
@@ -335,7 +335,7 @@ class Notifications {
constructor() {
// Check if the browser supports notifications
if (!('Notification' in window)) return;
-
+
// Check whether notification permissions have already been granted
if (Notification.permission !== 'granted') {
this.$button = $('notification');
@@ -361,11 +361,12 @@ class Notifications {
const config = {
body: body,
icon: '/images/logo_transparent_128x128.png',
- // vibrate: [200, 100, 200, 100, 200, 100, 400],
- // requireInteraction: true
}
if (serviceWorker && serviceWorker.showNotification) {
// android doesn't support "new Notification" if service worker is installed
+ config.actions = {
+ { "action": "yes", "title": "Yes"}
+ };
return serviceWorker.showNotification(message, config);
} else {
return new Notification(message, config);
@@ -385,11 +386,20 @@ class Notifications {
_downloadNotification(message) {
const notification = this._notify(message, 'Click to download');
if (window.isDownloadSupported) return;
- notification.onclick = e => {
- document.querySelector('x-dialog [download]').click();
- };
+ notification.onclick = e => this._download(e);
}
+ _download(e) {
+ document.querySelector('x-dialog [download]').click();
+ e.target.close();
+ }
+
+ _copyText(notification, message) {
+ console.log('message');
+ document.copy(message);
+ this._notify('Copied to clipboard');
+ notification.close();
+ }
}
class Snapdrop {