You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

middleware.js 2.3KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. // @flow
  2. import { CONFERENCE_JOINED } from '../base/conference';
  3. import {
  4. DOMINANT_SPEAKER_CHANGED,
  5. PARTICIPANT_JOINED,
  6. PARTICIPANT_LEFT,
  7. PIN_PARTICIPANT,
  8. getLocalParticipant
  9. } from '../base/participants';
  10. import { MiddlewareRegistry } from '../base/redux';
  11. import {
  12. getTrackByJitsiTrack,
  13. TRACK_ADDED,
  14. TRACK_REMOVED,
  15. TRACK_UPDATED
  16. } from '../base/tracks';
  17. import { selectParticipant, selectParticipantInLargeVideo } from './actions';
  18. /**
  19. * Middleware that catches actions related to participants and tracks and
  20. * dispatches an action to select a participant depicted by LargeVideo.
  21. *
  22. * @param {Store} store - Redux store.
  23. * @returns {Function}
  24. */
  25. MiddlewareRegistry.register(store => next => action => {
  26. const result = next(action);
  27. switch (action.type) {
  28. case DOMINANT_SPEAKER_CHANGED: {
  29. const localParticipant = getLocalParticipant(store.getState());
  30. if (localParticipant && localParticipant.id !== action.participant.id) {
  31. store.dispatch(selectParticipantInLargeVideo());
  32. }
  33. break;
  34. }
  35. case PARTICIPANT_JOINED:
  36. case PARTICIPANT_LEFT:
  37. case PIN_PARTICIPANT:
  38. case TRACK_ADDED:
  39. case TRACK_REMOVED:
  40. store.dispatch(selectParticipantInLargeVideo());
  41. break;
  42. case CONFERENCE_JOINED:
  43. // Ensure a participant is selected on conference join. This addresses
  44. // the case where video tracks were received before CONFERENCE_JOINED
  45. // fired; without the conference selection may not happen.
  46. store.dispatch(selectParticipant());
  47. break;
  48. case TRACK_UPDATED:
  49. // In order to minimize re-calculations, we need to select participant
  50. // only if the videoType of the current participant rendered in
  51. // LargeVideo has changed.
  52. if ('videoType' in action.track) {
  53. const state = store.getState();
  54. const track
  55. = getTrackByJitsiTrack(
  56. state['features/base/tracks'],
  57. action.track.jitsiTrack);
  58. const participantId = state['features/large-video'].participantId;
  59. (track.participantId === participantId)
  60. && store.dispatch(selectParticipant());
  61. }
  62. break;
  63. }
  64. return result;
  65. });