1
0
mirror of https://github.com/musix-org/musix-oss synced 2025-06-17 10:46:01 +00:00
This commit is contained in:
MatteZ02
2020-03-03 22:30:50 +02:00
parent edfcc6f474
commit 30022c7634
11800 changed files with 1984416 additions and 1 deletions

View File

@ -0,0 +1,68 @@
/**
* @license
* Copyright 2017 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { FirebaseInternalDependencies } from '../interfaces/internal-dependencies';
import { FirebaseMessaging } from '@firebase/messaging-types';
import { MessagePayload } from '../interfaces/message-payload';
import { Unsubscribe } from '@firebase/util';
import { FirebaseApp } from '@firebase/app-types';
import { FirebaseService } from '@firebase/app-types/private';
export declare type BgMessageHandler = (payload: MessagePayload) => unknown;
export declare class SwController implements FirebaseMessaging, FirebaseService {
private readonly firebaseDependencies;
private vapidKey;
private bgMessageHandler;
constructor(firebaseDependencies: FirebaseInternalDependencies);
get app(): FirebaseApp;
/**
* Calling setBackgroundMessageHandler will opt in to some specific
* behaviours.
* 1.) If a notification doesn't need to be shown due to a window already
* being visible, then push messages will be sent to the page.
* 2.) If a notification needs to be shown, and the message contains no
* notification data this method will be called
* and the promise it returns will be passed to event.waitUntil.
* If you do not set this callback then all push messages will let and the
* developer can handle them in a their own 'push' event callback
*
* @param callback The callback to be called when a push message is received
* and a notification must be shown. The callback will be given the data from
* the push message.
*/
setBackgroundMessageHandler(callback: BgMessageHandler): void;
getToken(): Promise<string>;
deleteToken(): Promise<boolean>;
requestPermission(): Promise<void>;
usePublicVapidKey(vapidKey: string): void;
useServiceWorker(): void;
onMessage(): Unsubscribe;
onTokenRefresh(): Unsubscribe;
/**
* A handler for push events that shows notifications based on the content of
* the payload.
*
* The payload must be a JSON-encoded Object with a `notification` key. The
* value of the `notification` property will be used as the NotificationOptions
* object passed to showNotification. Additionally, the `title` property of the
* notification object will be used as the title.
*
* If there is no notification data in the payload then no notification will be
* shown.
*/
onPush(event: PushEvent): Promise<void>;
onSubChange(event: PushSubscriptionChangeEvent): Promise<void>;
onNotificationClick(event: NotificationEvent): Promise<void>;
}

View File

@ -0,0 +1 @@
import '../testing/setup';

View File

@ -0,0 +1,57 @@
/**
* @license
* Copyright 2017 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { FirebaseInternalDependencies } from '../interfaces/internal-dependencies';
import { FirebaseMessaging } from '@firebase/messaging-types';
import { NextFn, Observer, Unsubscribe } from '@firebase/util';
import { FirebaseApp } from '@firebase/app-types';
import { FirebaseService } from '@firebase/app-types/private';
export declare class WindowController implements FirebaseMessaging, FirebaseService {
private readonly firebaseDependencies;
private vapidKey;
private swRegistration?;
private onMessageCallback;
constructor(firebaseDependencies: FirebaseInternalDependencies);
get app(): FirebaseApp;
getToken(): Promise<string>;
deleteToken(): Promise<boolean>;
/**
* Request permission if it is not currently granted.
*
* @return Resolves if the permission was granted, rejects otherwise.
*
* @deprecated Use Notification.requestPermission() instead.
* https://developer.mozilla.org/en-US/docs/Web/API/Notification/requestPermission
*/
requestPermission(): Promise<void>;
usePublicVapidKey(vapidKey: string): void;
useServiceWorker(swRegistration: ServiceWorkerRegistration): void;
/**
* @param nextOrObserver An observer object or a function triggered on
* message.
* @return The unsubscribe function for the observer.
*/
onMessage(nextOrObserver: NextFn<object> | Observer<object>): Unsubscribe;
setBackgroundMessageHandler(): void;
onTokenRefresh(): Unsubscribe;
/**
* Creates or updates the default service worker registration.
* @return The service worker registration to be used for the push service.
*/
private getServiceWorkerRegistration;
private messageEventListener;
private logEvent;
}

View File

@ -0,0 +1 @@
import '../testing/setup';