12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
-
- import { ReducerRegistry } from '../base/redux';
-
- import {
- ADD_GIF_FOR_PARTICIPANT,
- HIDE_GIF_FOR_PARTICIPANT,
- REMOVE_GIF_FOR_PARTICIPANT,
- SET_GIF_DRAWER_VISIBILITY,
- SET_GIF_MENU_VISIBILITY
- } from './actionTypes';
-
- const initialState = {
- drawerVisible: false,
- gifList: new Map(),
- menuOpen: false
- };
-
- ReducerRegistry.register(
- 'features/gifs',
- (state = initialState, action) => {
- switch (action.type) {
- case ADD_GIF_FOR_PARTICIPANT: {
- const newList = state.gifList;
-
- newList.set(action.participantId, {
- gifUrl: action.gifUrl,
- timeoutID: action.timeoutID
- });
-
- return {
- ...state,
- gifList: newList
- };
- }
- case REMOVE_GIF_FOR_PARTICIPANT: {
- const newList = state.gifList;
-
- newList.delete(action.participantId);
-
- return {
- ...state,
- gifList: newList
- };
- }
- case HIDE_GIF_FOR_PARTICIPANT: {
- const newList = state.gifList;
- const gif = state.gifList.get(action.participantId);
-
- newList.set(action.participantId, {
- gifUrl: gif.gifUrl,
- timeoutID: action.timeoutID
- });
-
- return {
- ...state,
- gifList: newList
- };
- }
- case SET_GIF_DRAWER_VISIBILITY:
- return {
- ...state,
- drawerVisible: action.visible
- };
- case SET_GIF_MENU_VISIBILITY:
- return {
- ...state,
- menuOpen: action.visible
- };
- }
-
- return state;
- });
|