74 lines
1.7 KiB
JavaScript
74 lines
1.7 KiB
JavaScript
|
|
||
|
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;
|
||
|
});
|
||
|
|