diff --git a/web/redux/redux-setup.js b/web/redux/redux-setup.js --- a/web/redux/redux-setup.js +++ b/web/redux/redux-setup.js @@ -8,6 +8,7 @@ deleteAccountActionTypes, } from 'lib/actions/user-actions'; import baseReducer from 'lib/reducers/master-reducer'; +import { nonThreadCalendarFilters } from 'lib/selectors/calendar-filter-selectors'; import { mostRecentlyReadThreadSelector } from 'lib/selectors/thread-selectors'; import { isLoggedIn } from 'lib/selectors/user-selectors'; import { invalidSessionDowngrade } from 'lib/shared/account-utils'; @@ -16,6 +17,7 @@ import type { EnabledApps } from 'lib/types/enabled-apps'; import type { EntryStore } from 'lib/types/entry-types'; import type { CalendarFilter } from 'lib/types/filter-types'; +import { calendarThreadFilterTypes } from 'lib/types/filter-types'; import type { LifecycleState } from 'lib/types/lifecycle-state-types'; import type { LoadingStatus } from 'lib/types/loading-types'; import type { MessageStore } from 'lib/types/message-types'; @@ -34,6 +36,8 @@ setDeviceIDActionType, updateNavInfoActionType, updateWindowDimensionsActionType, + updateCalendarCommunityFilter, + clearCalendarCommunityFilter, } from './action-types'; import { reduceDeviceID } from './device-id-reducer'; import reduceNavInfo from './nav-reducer'; @@ -95,7 +99,15 @@ type: 'SET_DEVICE_ID', payload: string, } - | { +type: 'SET_PRIMARY_IDENTITY_PUBLIC_KEY', payload: ?string }; + | { +type: 'SET_PRIMARY_IDENTITY_PUBLIC_KEY', payload: ?string } + | { + +type: 'UPDATE_CALENDAR_COMMUNITY_FILTER', + +payload: CalendarCommunityFilter, + } + | { + +type: 'CLEAR_CALENDAR_COMMUNITY_FILTER', + +payload: void, + }; export function reducer(oldState: AppState | void, action: Action): AppState { invariant(oldState, 'should be set'); @@ -111,6 +123,28 @@ ...state, windowActive: action.payload, }); + } else if (action.type === updateCalendarCommunityFilter) { + const nonThreadFilters = nonThreadCalendarFilters(state.calendarFilters); + return { + ...state, + calendarFilters: [ + ...nonThreadFilters, + { + type: calendarThreadFilterTypes.THREAD_LIST, + threadIDs: action.payload.threadIDs, + }, + ], + communityFilter: { + threadIDs: action.payload.threadIDs, + }, + }; + } else if (action.type === clearCalendarCommunityFilter) { + const nonThreadFilters = nonThreadCalendarFilters(state.calendarFilters); + return { + ...state, + calendarFilters: [...nonThreadFilters], + communityFilter: null, + }; } else if (action.type === setNewSessionActionType) { if ( invalidSessionDowngrade(