A Cycle.js Driver for showing and responding to HTML5 Notifications.
npm install @cycle/notification
Basics:
import Cycle from '@cycle/core';
import { makeNotificationDriver } from '@cycle/notification'
function main({notification}) {
// ...
}
const drivers = {
notification: makeNotificationDriver()
}
Cycle.run(main, drivers)
Simple and normal use case:
function main({notification}) {
let notifications$ = Rx.Observable
.interval(10000)
.startWith(-1)
.map( (value) => ({
title: 'Test Notification',
body: `Interval ${value}`,
tag: 'test-notification',
icon: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAIAAAACDbGyAAAAEUlEQVQIW2Pg3uSLjBgo5AMACSoZ+1zqJ8AAAAAASUVORK5CYII='
}) )
.take(10),
show$ = notification.get('show'),
click$ = notification.get('click'),
error$ = notification.get('error'),
close$ = notification.get('close'),
all$ = Rx.Observable.merge(show$, click$, error$, close$)
all$.do(args => console.log(args)).subscribe()
return {
notification: notifications$
}
}