Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ngrx/notify
Web Notifications Powered by RxJS for Angular
https://github.com/ngrx/notify
Last synced: 2 months ago
JSON representation
Web Notifications Powered by RxJS for Angular
- Host: GitHub
- URL: https://github.com/ngrx/notify
- Owner: ngrx
- License: mit
- Created: 2016-06-07T16:54:24.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2018-01-11T21:47:27.000Z (almost 7 years ago)
- Last Synced: 2024-09-30T19:28:17.501Z (3 months ago)
- Language: TypeScript
- Homepage:
- Size: 9.77 KB
- Stars: 101
- Watchers: 6
- Forks: 10
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-angular-components - @ngrx/notify - Web Notifications Powered by RxJS for Angular. (Uncategorized / Uncategorized)
- awesome-angular - @ngrx/notify - Web Notifications Powered by RxJS for Angular. (Uncategorized / Uncategorized)
- awesome-angular-components - @ngrx/notify - Web Notifications Powered by RxJS for Angular 2 (Uncategorized / Uncategorized)
- awesome-angular-components - @ngrx/notify - Web Notifications Powered by RxJS for Angular. (Uncategorized / Uncategorized)
- awesome-angular-components - ngrx/notify - Web Notifications Powered by RxJS for Angular (UI Components / Notification)
README
# @ngrx/notify
### Web Notifications Powered by RxJS for Angular 2
[![Join the chat at https://gitter.im/ngrx/notify](https://badges.gitter.im/ngrx/notify.svg)](https://gitter.im/ngrx/notify?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)Easily create and handle desktop notifications in Angular 2
### Installation
Install @ngrx/notify from npm:
```bash
npm install @ngrx/notify --save
```Setup the providers, optionally providing global notification options:
```ts
import { NOTIFY_PROVIDERS, NOTIFY_GLOBAL_OPTIONS } from '@ngrx/notify';bootstrap(App, [
NOTIFY_PROVIDERS,
{ provide: NOTIFY_GLOBAL_OPTIONS, multi: true, useValue: { /* global options here */ } }
])
```## Usage
### Requesting Notification Permission
Before creating notifications, you must resolve the app's notification permission:```ts
class AppComponent {
constructor(notify: Notify) {
notify.requestPermission().subscribe(permission => {
if (permission) {
// continue
}
});
}
}
```### Creating a Notification
To create a notification observable, call the `open()` method with a title and optional config. The notification will be opened when you subscribe to the observable and will close after you unsubscribe from it. The observable will emit the instance of the notification every time it is clicked on:```ts
notify.open('Hello world!', options)
// Automatically close the notification after 5 seconds
.takeUntil(Observable.timer(5000))
// Close the notification after it has been clicked once
.take(1)
.subscribe(notification => {});
```See the [documentation on MDN](https://developer.mozilla.org/en-US/docs/Web/API/Notification/Notification) for available options.