| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 | 
							- // @flow
 - 
 - import { APP_WILL_MOUNT } from '../base/app';
 - import { ReducerRegistry, set } from '../base/redux';
 - import { PersistenceRegistry } from '../base/storage';
 - 
 - import {
 -     CLEAR_CALENDAR_INTEGRATION,
 -     SET_CALENDAR_AUTH_STATE,
 -     SET_CALENDAR_AUTHORIZATION,
 -     SET_CALENDAR_EVENTS,
 -     SET_CALENDAR_INTEGRATION,
 -     SET_CALENDAR_PROFILE_EMAIL,
 -     SET_LOADING_CALENDAR_EVENTS
 - } from './actionTypes';
 - import { isCalendarEnabled } from './functions';
 - 
 - /**
 -  * The default state of the calendar feature.
 -  *
 -  * @type {Object}
 -  */
 - const DEFAULT_STATE = {
 -     authorization: undefined,
 -     events: [],
 -     integrationReady: false,
 -     integrationType: undefined,
 -     msAuthState: undefined
 - };
 - 
 - /**
 -  * Constant for the Redux subtree of the calendar feature.
 -  *
 -  * NOTE: This feature can be disabled and in that case, accessing this subtree
 -  * directly will return undefined and will need a bunch of repetitive type
 -  * checks in other features. Make sure you take care of those checks, or
 -  * consider using the {@code isCalendarEnabled} value to gate features if
 -  * needed.
 -  */
 - const STORE_NAME = 'features/calendar-sync';
 - 
 - /**
 -  * NOTE 1: For legacy purposes, read any {@code knownDomains} persisted by the
 -  * feature calendar-sync.
 -  *
 -  * NOTE 2: Never persist the authorization value as it's needed to remain a
 -  * runtime value to see if we need to re-request the calendar permission from
 -  * the user.
 -  */
 - isCalendarEnabled()
 -     && PersistenceRegistry.register(STORE_NAME, {
 -         integrationType: true,
 -         knownDomains: true,
 -         msAuthState: true
 -     });
 - 
 - isCalendarEnabled()
 -     && ReducerRegistry.register(STORE_NAME, (state = DEFAULT_STATE, action) => {
 -         switch (action.type) {
 -         case APP_WILL_MOUNT:
 -             // For legacy purposes, we've allowed the deserialization of
 -             // knownDomains. At this point, it should have already been
 -             // translated into the new state format (namely, base/known-domains)
 -             // and the app no longer needs it.
 -             // $FlowFixMe
 -             if (typeof state.knownDomains !== 'undefined') {
 -                 return set(state, 'knownDomains', undefined);
 -             }
 -             break;
 - 
 -         case CLEAR_CALENDAR_INTEGRATION:
 -             return DEFAULT_STATE;
 - 
 -         case SET_CALENDAR_AUTH_STATE: {
 -             if (!action.msAuthState) {
 -                 // received request to delete the state
 -                 return set(state, 'msAuthState', undefined);
 -             }
 - 
 -             return set(state, 'msAuthState', {
 -                 ...state.msAuthState,
 -                 ...action.msAuthState
 -             });
 -         }
 - 
 -         case SET_CALENDAR_AUTHORIZATION:
 -             return set(state, 'authorization', action.authorization);
 - 
 -         case SET_CALENDAR_EVENTS:
 -             return set(state, 'events', action.events);
 - 
 -         case SET_CALENDAR_INTEGRATION:
 -             return {
 -                 ...state,
 -                 integrationReady: action.integrationReady,
 -                 integrationType: action.integrationType
 -             };
 - 
 -         case SET_CALENDAR_PROFILE_EMAIL:
 -             return set(state, 'profileEmail', action.email);
 - 
 -         case SET_LOADING_CALENDAR_EVENTS:
 -             return set(state, 'isLoadingEvents', action.isLoadingEvents);
 -         }
 - 
 -         return state;
 -     });
 
 
  |