| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 | 
							- import { ReducerRegistry, set } from '../redux';
 - import { randomHexString } from '../util';
 - 
 - import {
 -     DOMINANT_SPEAKER_CHANGED,
 -     PARTICIPANT_ID_CHANGED,
 -     PARTICIPANT_JOINED,
 -     PARTICIPANT_LEFT,
 -     PARTICIPANT_UPDATED,
 -     PIN_PARTICIPANT
 - } from './actionTypes';
 - import {
 -     LOCAL_PARTICIPANT_DEFAULT_ID,
 -     PARTICIPANT_ROLE
 - } from './constants';
 - 
 - /**
 -  * Participant object.
 -  * @typedef {Object} Participant
 -  * @property {string} id - Participant ID.
 -  * @property {string} name - Participant name.
 -  * @property {string} avatar - Path to participant avatar if any.
 -  * @property {string} role - Participant role.
 -  * @property {boolean} local - If true, participant is local.
 -  * @property {boolean} pinned - If true, participant is currently a
 -  * "PINNED_ENDPOINT".
 -  * @property {boolean} dominantSpeaker - If this participant is the dominant
 -  * speaker in the (associated) conference, <tt>true</tt>; otherwise,
 -  * <tt>false</tt>.
 -  * @property {string} email - Participant email.
 -  */
 - 
 - /**
 -  * These properties should not be bulk assigned when updating a particular
 -  * @see Participant.
 -  * @type {string[]}
 -  */
 - const PARTICIPANT_PROPS_TO_OMIT_WHEN_UPDATE
 -     = [ 'dominantSpeaker', 'id', 'local', 'pinned' ];
 - 
 - /**
 -  * Reducer function for a single participant.
 -  *
 -  * @param {Participant|undefined} state - Participant to be modified.
 -  * @param {Object} action - Action object.
 -  * @param {string} action.type - Type of action.
 -  * @param {Participant} action.participant - Information about participant to be
 -  * added/modified.
 -  * @param {JitsiConference} action.conference - Conference instance.
 -  * @private
 -  * @returns {Participant|undefined}
 -  */
 - function _participant(state, action) {
 -     switch (action.type) {
 -     case DOMINANT_SPEAKER_CHANGED:
 -         // Only one dominant speaker is allowed.
 -         return (
 -             set(state, 'dominantSpeaker', state.id === action.participant.id));
 - 
 -     case PARTICIPANT_ID_CHANGED:
 -         if (state.id === action.oldValue) {
 -             return {
 -                 ...state,
 -                 id: action.newValue
 -             };
 -         }
 -         break;
 - 
 -     case PARTICIPANT_JOINED: {
 -         const participant = action.participant; // eslint-disable-line no-shadow
 -         const {
 -             avatarURL,
 -             connectionStatus,
 -             dominantSpeaker,
 -             email,
 -             local,
 -             pinned,
 -             role
 -         } = participant;
 -         let { avatarID, id, name } = participant;
 - 
 -         // avatarID
 -         //
 -         // TODO Get the avatarID of the local participant from localStorage.
 -         if (!avatarID && local) {
 -             avatarID = randomHexString(32);
 -         }
 - 
 -         // id
 -         //
 -         // XXX The situation of not having an ID for a remote participant should
 -         // not happen. Maybe we should raise an error in this case or generate a
 -         // random ID.
 -         if (!id && local) {
 -             id = LOCAL_PARTICIPANT_DEFAULT_ID;
 -         }
 - 
 -         // name
 -         if (!name) {
 -             // TODO Get the from config and/or localized.
 -             name = local ? 'me' : 'Fellow Jitster';
 -         }
 - 
 -         return {
 -             avatarID,
 -             avatarURL,
 -             connectionStatus,
 -             dominantSpeaker: dominantSpeaker || false,
 -             email,
 -             id,
 -             local: local || false,
 -             name,
 -             pinned: pinned || false,
 -             role: role || PARTICIPANT_ROLE.NONE
 -         };
 -     }
 - 
 -     case PARTICIPANT_UPDATED: {
 -         const participant = action.participant; // eslint-disable-line no-shadow
 -         const { local } = participant;
 -         let { id } = participant;
 - 
 -         if (!id && local) {
 -             id = LOCAL_PARTICIPANT_DEFAULT_ID;
 -         }
 - 
 -         if (state.id === id) {
 -             const newState = { ...state };
 - 
 -             for (const key in participant) {
 -                 if (participant.hasOwnProperty(key)
 -                         && PARTICIPANT_PROPS_TO_OMIT_WHEN_UPDATE.indexOf(key)
 -                             === -1) {
 -                     newState[key] = participant[key];
 -                 }
 -             }
 - 
 -             return newState;
 -         }
 -         break;
 -     }
 - 
 -     case PIN_PARTICIPANT:
 -         // Currently, only one pinned participant is allowed.
 -         return set(state, 'pinned', state.id === action.participant.id);
 -     }
 - 
 -     return state;
 - }
 - 
 - /**
 -  * Listen for actions which add, remove, or update the set of participants in
 -  * the conference.
 -  *
 -  * @param {Participant[]} state - List of participants to be modified.
 -  * @param {Object} action - Action object.
 -  * @param {string} action.type - Type of action.
 -  * @param {Participant} action.participant - Information about participant to be
 -  * added/removed/modified.
 -  * @returns {Participant[]}
 -  */
 - ReducerRegistry.register('features/base/participants', (state = [], action) => {
 -     switch (action.type) {
 -     case PARTICIPANT_JOINED:
 -         return [ ...state, _participant(undefined, action) ];
 - 
 -     case PARTICIPANT_LEFT:
 -         return state.filter(p => p.id !== action.participant.id);
 - 
 -     case DOMINANT_SPEAKER_CHANGED:
 -     case PARTICIPANT_ID_CHANGED:
 -     case PARTICIPANT_UPDATED:
 -     case PIN_PARTICIPANT:
 -         return state.map(p => _participant(p, action));
 - 
 -     default:
 -         return state;
 -     }
 - });
 
 
  |