jiti-meet/react/features/gifs/reducer.ts

84 lines
1.9 KiB
TypeScript
Raw Normal View History

import ReducerRegistry from '../base/redux/ReducerRegistry';
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
};
export interface IGif {
gifUrl?: string;
timeoutID?: number;
}
export interface IGifsState {
drawerVisible: boolean;
gifList: Map<string, IGif>;
menuOpen: boolean;
}
2022-09-05 09:05:07 +00:00
ReducerRegistry.register<IGifsState>(
'features/gifs',
2022-09-05 09:05:07 +00:00
(state = initialState, action): IGifsState => {
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, {
2022-09-05 09:05:07 +00:00
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;
});