123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219 |
- /**
- * Firebase Cloud Messaging
- *
- * @packageDocumentation
- */
-
- import { FirebaseApp } from '@firebase/app';
- import { NextFn } from '@firebase/util';
- import { Observer } from '@firebase/util';
- import { Unsubscribe } from '@firebase/util';
-
- /**
- * Deletes the registration token associated with this {@link Messaging} instance and unsubscribes
- * the {@link Messaging} instance from the push subscription.
- *
- * @param messaging - The {@link Messaging} instance.
- *
- * @returns The promise resolves when the token has been successfully deleted.
- *
- * @public
- */
- export declare function deleteToken(messaging: Messaging): Promise<boolean>;
-
- /**
- * Options for features provided by the FCM SDK for Web. See {@link
- * https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#webpushfcmoptions |
- * WebpushFcmOptions}
- *
- * @public
- */
- export declare interface FcmOptions {
- /**
- * The link to open when the user clicks on the notification.
- */
- link?: string;
- /**
- * The label associated with the message's analytics data.
- */
- analyticsLabel?: string;
- }
-
- /**
- * @internal
- */
- export declare type _FirebaseMessagingName = 'messaging';
-
- /**
- * Retrieves a Firebase Cloud Messaging instance.
- *
- * @returns The Firebase Cloud Messaging instance associated with the provided firebase app.
- *
- * @public
- */
- export declare function getMessaging(app?: FirebaseApp): Messaging;
-
- /**
- * Subscribes the {@link Messaging} instance to push notifications. Returns an Firebase Cloud
- * Messaging registration token that can be used to send push messages to that {@link Messaging}
- * instance.
- *
- * If a notification permission isn't already granted, this method asks the user for permission. The
- * returned promise rejects if the user does not allow the app to show notifications.
- *
- * @param messaging - The {@link Messaging} instance.
- * @param options - Provides an optional vapid key and an optinoal service worker registration
- *
- * @returns The promise resolves with an FCM registration token.
- *
- * @public
- */
- export declare function getToken(messaging: Messaging, options?: GetTokenOptions): Promise<string>;
-
- /**
- * Options for {@link getToken}
- *
- * @public
- */
- export declare interface GetTokenOptions {
- /**
- * The public server key provided to push services. It is used to
- * authenticate the push subscribers to receive push messages only from sending servers that hold
- * the corresponding private key. If it is not provided, a default VAPID key is used. Note that some
- * push services (Chrome Push Service) require a non-default VAPID key. Therefore, it is recommended
- * to generate and import a VAPID key for your project with
- * {@link https://firebase.google.com/docs/cloud-messaging/js/client#configure_web_credentials_with_fcm | Configure Web Credentials with FCM}.
- * See
- * {@link https://developers.google.com/web/fundamentals/push-notifications/web-push-protocol | The Web Push Protocol}
- * for details on web push services.
- */
- vapidKey?: string;
- /**
- * The service worker registration for receiving push
- * messaging. If the registration is not provided explicitly, you need to have a
- * `firebase-messaging-sw.js` at your root location. See
- * {@link https://firebase.google.com/docs/cloud-messaging/js/client#retrieve-the-current-registration-token | Retrieve the current registration token}
- * for more details.
- */
- serviceWorkerRegistration?: ServiceWorkerRegistration;
- }
-
- /**
- * @license
- * Copyright 2020 Google LLC
- *
- * 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.
- */
- /**
- * Checks if all required APIs exist in the browser.
- * @returns a Promise that resolves to a boolean.
- *
- * @public
- */
- export declare function isSupported(): Promise<boolean>;
-
- /**
- * Message payload that contains the notification payload that is represented with
- * {@link NotificationPayload} and the data payload that contains an arbitrary
- * number of key-value pairs sent by developers through the
- * {@link https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#notification | Send API}
- *
- * @public
- */
- export declare interface MessagePayload {
- /**
- * {@inheritdoc NotificationPayload}
- */
- notification?: NotificationPayload;
- /**
- * Arbitrary key/value payload.
- */
- data?: {
- [key: string]: string;
- };
- /**
- * {@inheritdoc FcmOptions}
- */
- fcmOptions?: FcmOptions;
- /**
- * The sender of this message.
- */
- from: string;
- /**
- * The collapse key of the message. See
- * {@link https://firebase.google.com/docs/cloud-messaging/concept-options#collapsible_and_non-collapsible_messages | Non-collapsible and collapsible messages}
- */
- collapseKey: string;
- /**
- * The message id of a message.
- */
- messageId: string;
- }
-
- /**
- * Public interface of the Firebase Cloud Messaging SDK.
- *
- * @public
- */
- export declare interface Messaging {
- /**
- * The {@link @firebase/app#FirebaseApp} this `Messaging` instance is associated with.
- */
- app: FirebaseApp;
- }
- export { NextFn }
-
- /**
- * Display notification details. They are sent through the
- * {@link https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#notification | Send API}
- *
- * @public
- */
- export declare interface NotificationPayload {
- /**
- * The notification's title.
- */
- title?: string;
- /**
- * The notification's body text.
- */
- body?: string;
- /**
- * The URL of an image that is downloaded on the device and displayed in the notification.
- */
- image?: string;
- /**
- * The URL to use for the notification's icon. If you don't send this key in the request,
- * FCM displays the launcher icon specified in your app manifest.
- */
- icon?: string;
- }
- export { Observer }
-
- /**
- * When a push message is received and the user is currently on a page for your origin, the
- * message is passed to the page and an `onMessage()` event is dispatched with the payload of
- * the push message.
- *
- *
- * @param messaging - The {@link Messaging} instance.
- * @param nextOrObserver - This function, or observer object with `next` defined,
- * is called when a message is received and the user is currently viewing your page.
- * @returns To stop listening for messages execute this returned function.
- *
- * @public
- */
- export declare function onMessage(messaging: Messaging, nextOrObserver: NextFn<MessagePayload> | Observer<MessagePayload>): Unsubscribe;
- export { Unsubscribe }
-
- export { }
|