push_notifications.js (1509B)
- import { STORE_HYDRATE } from '../actions/store';
 - import { SET_BROWSER_SUPPORT, SET_SUBSCRIPTION, CLEAR_SUBSCRIPTION, SET_ALERTS } from '../actions/push_notifications';
 - import Immutable from 'immutable';
 - const initialState = Immutable.Map({
 - subscription: null,
 - alerts: new Immutable.Map({
 - follow: false,
 - favourite: false,
 - reblog: false,
 - mention: false,
 - }),
 - isSubscribed: false,
 - browserSupport: false,
 - });
 - export default function push_subscriptions(state = initialState, action) {
 - switch(action.type) {
 - case STORE_HYDRATE: {
 - const push_subscription = action.state.get('push_subscription');
 - if (push_subscription) {
 - return state
 - .set('subscription', new Immutable.Map({
 - id: push_subscription.get('id'),
 - endpoint: push_subscription.get('endpoint'),
 - }))
 - .set('alerts', push_subscription.get('alerts') || initialState.get('alerts'))
 - .set('isSubscribed', true);
 - }
 - return state;
 - }
 - case SET_SUBSCRIPTION:
 - return state
 - .set('subscription', new Immutable.Map({
 - id: action.subscription.id,
 - endpoint: action.subscription.endpoint,
 - }))
 - .set('alerts', new Immutable.Map(action.subscription.alerts))
 - .set('isSubscribed', true);
 - case SET_BROWSER_SUPPORT:
 - return state.set('browserSupport', action.value);
 - case CLEAR_SUBSCRIPTION:
 - return initialState;
 - case SET_ALERTS:
 - return state.setIn(action.path, action.value);
 - default:
 - return state;
 - }
 - };