Improve notification

This commit is contained in:
Peter Maquiran
2021-08-31 22:49:37 +01:00
parent 3437c19027
commit fb22023c5d
3 changed files with 57 additions and 4 deletions
+1 -1
View File
@@ -182,7 +182,7 @@ export class HomePage implements OnInit {
synchro.registerCallback('Notification', (DataArray)=> {
this.webNotificationPopupService.sendNotification(DataArray.Object)
this.webNotificationPopupService.sendNotification(DataArray)
this.storageService.get('Notifications').then((data:any)=>{
data.push(DataArray)
+17
View File
@@ -0,0 +1,17 @@
self.addEventListener('install', function() {
self.skipWaiting();
});
self.addEventListener('activate', function(event) {
event.waitUntil(clients.claim());
});
self.addEventListener('notificationclick', function(event) {
// Close the notification when it is clicked
event.notification.close();
console.log(event)
});
@@ -1,11 +1,20 @@
import { Injectable } from '@angular/core';
import { AlertController, Platform } from '@ionic/angular';
import { v4 as uuidv4 } from 'uuid'
@Injectable({
providedIn: 'root'
})
export class WebNotificationPopupService {
constructor( private platform: Platform) { }
constructor( private platform: Platform) {
var myWorker = new Worker( new URL('./sw.js', import.meta.url));
myWorker.onmessage = function(oEvent) {
console.log('Worker said : ' + oEvent.data);
}
}
askNotificationPermission() {
@@ -44,10 +53,37 @@ export class WebNotificationPopupService {
return true;
}
sendNotification(message) {
cc = 0;
sendNotification(e) {
if (this.platform.is('desktop') || this.platform.is('mobileweb')) {}
else {return false}
Notification.requestPermission((result) => {
if (result === 'granted') {
navigator.serviceWorker.ready.then((registration)=> {
registration.showNotification(e.Object+ this.cc, {
body: e.Service,
icon: 'assets/icon/favicon.png',
requireInteraction: true,
tag: 'require-interaction'+uuidv4(),
// actions: [
// {action: 'like', title: 'Like', icon: 'https://example/like.png'},
// {action: 'reply', title: 'Reply', icon: 'https://example/reply.png'}
// ]
}).then(e =>{
console.log(e)
})
});
}
});
var n = new Notification(message);
}
}