parent
aced65293d
commit
9428c3638b
@ -28,7 +28,7 @@ export class MainComponent implements OnInit {
|
|||||||
public el: ElementRef,
|
public el: ElementRef,
|
||||||
public renderer: Renderer2,
|
public renderer: Renderer2,
|
||||||
private messageService: MessageService,
|
private messageService: MessageService,
|
||||||
private messagingService: MessagingService
|
private messagingService: MessagingService,
|
||||||
) {
|
) {
|
||||||
renderer.listen('window', 'appinstalled', (evt) => {
|
renderer.listen('window', 'appinstalled', (evt) => {
|
||||||
console.log('INSTALLED!!!')
|
console.log('INSTALLED!!!')
|
||||||
@ -64,37 +64,7 @@ export class MainComponent implements OnInit {
|
|||||||
}
|
}
|
||||||
|
|
||||||
requestPermission() {
|
requestPermission() {
|
||||||
// if (!('serviceWorker' in navigator)) {
|
this.messagingService.requestPermission()
|
||||||
// this.messageService.add({severity:'error', summary:'Не поддерживается в Вашем браузере!'});
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// if (!('PushManager' in window)) {
|
|
||||||
// // Браузер не поддерживает push-уведомления.
|
|
||||||
// this.messageService.add({severity:'error', summary:'Не поддерживается в Вашем браузере!'});
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
// this.afMessaging.requestPermission.subscribe({
|
|
||||||
// next: () => {
|
|
||||||
// console.log('Permission granted! Save to the server!')
|
|
||||||
// },
|
|
||||||
// error: e => console.error(e)
|
|
||||||
// })
|
|
||||||
|
|
||||||
// this.afMessaging.requestToken.subscribe({
|
|
||||||
// next: (token) => {
|
|
||||||
// this.messagingToken = token;
|
|
||||||
// if (this.messagingToken) {
|
|
||||||
// this.messageService.add({severity:'success', summary:'Спасибо за подписку!'});
|
|
||||||
// this.isPermissionNotifications = true;
|
|
||||||
// }
|
|
||||||
// console.log(token)
|
|
||||||
// },
|
|
||||||
// error: e => console.error(e)
|
|
||||||
// })
|
|
||||||
|
|
||||||
const userId = 'user001';
|
|
||||||
this.messagingService.requestPermission(userId)
|
|
||||||
this.messagingService.receiveMessage()
|
this.messagingService.receiveMessage()
|
||||||
this.message = this.messagingService.currentMessage
|
this.message = this.messagingService.currentMessage
|
||||||
|
|
||||||
|
|||||||
@ -1,17 +1,17 @@
|
|||||||
import { Injectable } from '@angular/core';
|
import { Injectable } from '@angular/core';
|
||||||
// import { AngularFireDatabase } from '@angular/fire/database';
|
|
||||||
// import { AngularFireAuth } from '@angular/fire/auth';
|
|
||||||
import { AngularFireMessaging } from '@angular/fire/compat/messaging';
|
import { AngularFireMessaging } from '@angular/fire/compat/messaging';
|
||||||
|
import { MessageService } from 'primeng/api';
|
||||||
import { BehaviorSubject } from 'rxjs';
|
import { BehaviorSubject } from 'rxjs';
|
||||||
|
import { JsonrpcService, RpcService } from './jsonrpc.service';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class MessagingService {
|
export class MessagingService {
|
||||||
currentMessage = new BehaviorSubject(null);
|
currentMessage = new BehaviorSubject(null);
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
// private angularFireDB: AngularFireDatabase,
|
private angularFireMessaging: AngularFireMessaging,
|
||||||
// private angularFireAuth: AngularFireAuth,
|
private jsonRpcService: JsonrpcService,
|
||||||
private angularFireMessaging: AngularFireMessaging
|
private messageService: MessageService
|
||||||
) {
|
) {
|
||||||
this.angularFireMessaging.messages.subscribe((_messaging: any) => {
|
this.angularFireMessaging.messages.subscribe((_messaging: any) => {
|
||||||
_messaging.onMessage = _messaging.onMessage.bind(_messaging);
|
_messaging.onMessage = _messaging.onMessage.bind(_messaging);
|
||||||
@ -19,38 +19,42 @@ export class MessagingService {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
updateToken(token: string | null) {
|
||||||
* update token in firebase database
|
if (!token) return;
|
||||||
*
|
this.jsonRpcService
|
||||||
* @param userId userId as a key
|
.rpc(
|
||||||
* @param token token as a value
|
{
|
||||||
*/
|
method: 'updateAdditionalInfo',
|
||||||
|
params: [
|
||||||
|
{
|
||||||
|
'fmc-token': token,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
RpcService.authService,
|
||||||
|
true
|
||||||
|
)
|
||||||
|
.subscribe({
|
||||||
|
next: () => {
|
||||||
|
this.messageService.add({
|
||||||
|
severity: 'custom',
|
||||||
|
summary: 'Спасибо за подписку!',
|
||||||
|
});
|
||||||
|
},
|
||||||
|
error: (err) => {
|
||||||
|
console.error('Error: ', err);
|
||||||
|
this.messageService.add({
|
||||||
|
severity: 'error',
|
||||||
|
summary: 'Произошла ошибка, попробуйте позже',
|
||||||
|
});
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// ОБНОВИТЬ/ДОБАВИТЬ ТОКЕН В БД
|
requestPermission() {
|
||||||
|
|
||||||
// updateToken(userId, token) {
|
|
||||||
// // we can change this function to request our backend service
|
|
||||||
// this.angularFireAuth.authState.pipe(take(1)).subscribe(
|
|
||||||
// () => {
|
|
||||||
// const data = {};
|
|
||||||
// data[userId] = token
|
|
||||||
// this.angularFireDB.object('fcmTokens/').update(data)
|
|
||||||
// })
|
|
||||||
// }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* request permission for notification from firebase cloud messaging
|
|
||||||
*
|
|
||||||
* @param userId userId
|
|
||||||
*/
|
|
||||||
requestPermission(userId: string) {
|
|
||||||
this.angularFireMessaging.requestToken.subscribe({
|
this.angularFireMessaging.requestToken.subscribe({
|
||||||
next: (token) => {
|
next: (token) => {
|
||||||
// this.messagingToken = token;
|
this.updateToken(token);
|
||||||
// if (this.messagingToken) {
|
|
||||||
// this.messageService.add({severity:'success', summary:'Спасибо за подписку!'});
|
|
||||||
// this.isPermissionNotifications = true;
|
|
||||||
// }
|
|
||||||
console.log(token);
|
console.log(token);
|
||||||
},
|
},
|
||||||
error: (e) => console.error(e),
|
error: (e) => console.error(e),
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user