123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- import { ReducerRegistry, setStateProperty } from '../redux';
-
- import {
- CONFERENCE_JOINED,
- CONFERENCE_LEFT,
- CONFERENCE_WILL_LEAVE,
- SET_ROOM
- } from './actionTypes';
- import { isRoomValid } from './functions';
-
- const INITIAL_STATE = {
- jitsiConference: null,
-
- /**
- * Instance of JitsiConference that is currently in 'leaving' state.
- */
- leavingJitsiConference: null,
-
- /**
- * The name of the room of the conference (to be) joined (i.e.
- * {@link #jitsiConference}).
- *
- * @type {string}
- */
- room: null
- };
-
- /**
- * Listen for actions that contain the conference object, so that it can be
- * stored for use by other action creators.
- */
- ReducerRegistry.register('features/base/conference',
- (state = INITIAL_STATE, action) => {
- switch (action.type) {
- case CONFERENCE_JOINED:
- return (
- setStateProperty(
- state,
- 'jitsiConference',
- action.conference.jitsiConference));
-
- case CONFERENCE_LEFT:
- if (state.jitsiConference === action.conference.jitsiConference) {
- return {
- ...state,
- jitsiConference: null,
- leavingJitsiConference: state.leavingJitsiConference
- === action.conference.jitsiConference
- ? null
- : state.leavingJitsiConference
- };
- }
- break;
-
- case CONFERENCE_WILL_LEAVE:
- return (
- setStateProperty(
- state,
- 'leavingJitsiConference',
- action.conference.jitsiConference));
-
- case SET_ROOM: {
- let room = action.room;
-
- // Technically, there're multiple values which don't represent
- // valid room names. Practically, each of them is as bad as the rest
- // of them because we can't use any of them to join a conference.
- isRoomValid(room) || (room = INITIAL_STATE.room);
-
- return setStateProperty(state, 'room', room);
- }
- }
-
- return state;
- });
|