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 4.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. // @flow
  2. import { CONFERENCE_JOINED } from '../base/conference';
  3. import { updateConfig } from '../base/config';
  4. import { isIosMobileBrowser } from '../base/environment/utils';
  5. import { MEDIA_TYPE, SET_AUDIO_MUTED, SET_VIDEO_MUTED } from '../base/media';
  6. import { MiddlewareRegistry } from '../base/redux';
  7. import { updateSettings } from '../base/settings';
  8. import {
  9. getLocalTracks,
  10. replaceLocalTrack,
  11. TRACK_ADDED,
  12. TRACK_NO_DATA_FROM_SOURCE
  13. } from '../base/tracks';
  14. import { PREJOIN_START_CONFERENCE } from './actionTypes';
  15. import {
  16. setDeviceStatusOk,
  17. setDeviceStatusWarning,
  18. setPrejoinPageVisibility
  19. } from './actions';
  20. import { PREJOIN_SCREEN_STATES } from './constants';
  21. import { isPrejoinPageVisible } from './functions';
  22. declare var APP: Object;
  23. /**
  24. * The redux middleware for {@link PrejoinPage}.
  25. *
  26. * @param {Store} store - The redux store.
  27. * @returns {Function}
  28. */
  29. MiddlewareRegistry.register(store => next => async action => {
  30. switch (action.type) {
  31. case PREJOIN_START_CONFERENCE: {
  32. const { getState, dispatch } = store;
  33. const state = getState();
  34. const { userSelectedSkipPrejoin } = state['features/prejoin'];
  35. let localTracks = getLocalTracks(state['features/base/tracks']);
  36. const { options } = action;
  37. options && store.dispatch(updateConfig(options));
  38. userSelectedSkipPrejoin && dispatch(updateSettings({
  39. userSelectedSkipPrejoin
  40. }));
  41. // Do not signal audio/video tracks if the user joins muted.
  42. for (const track of localTracks) {
  43. // Always add the audio track on mobile Safari because of a known issue where audio playout doesn't happen
  44. // if the user joins audio and video muted.
  45. if (track.muted
  46. && !(isIosMobileBrowser() && track.jitsiTrack && track.jitsiTrack.getType() === MEDIA_TYPE.AUDIO)) {
  47. await dispatch(replaceLocalTrack(track.jitsiTrack, null));
  48. }
  49. }
  50. // Re-fetch the local tracks after muted tracks have been removed above.
  51. // This is needed, because the tracks are effectively disposed by the replaceLocalTrack and should not be used
  52. // anymore.
  53. localTracks = getLocalTracks(getState()['features/base/tracks']);
  54. const jitsiTracks = localTracks.map(t => t.jitsiTrack);
  55. dispatch(setPrejoinPageVisibility(PREJOIN_SCREEN_STATES.LOADING));
  56. APP.conference.prejoinStart(jitsiTracks);
  57. break;
  58. }
  59. case SET_AUDIO_MUTED: {
  60. if (isPrejoinPageVisible(store.getState())) {
  61. store.dispatch(updateSettings({
  62. startWithAudioMuted: Boolean(action.muted)
  63. }));
  64. }
  65. break;
  66. }
  67. case SET_VIDEO_MUTED: {
  68. if (isPrejoinPageVisible(store.getState())) {
  69. store.dispatch(updateSettings({
  70. startWithVideoMuted: Boolean(action.muted)
  71. }));
  72. }
  73. break;
  74. }
  75. case TRACK_ADDED:
  76. case TRACK_NO_DATA_FROM_SOURCE: {
  77. const state = store.getState();
  78. if (isPrejoinPageVisible(state)) {
  79. const { track: { jitsiTrack: track } } = action;
  80. const { deviceStatusType, deviceStatusText } = state['features/prejoin'];
  81. if (!track.isAudioTrack()) {
  82. break;
  83. }
  84. if (track.isReceivingData()) {
  85. if (deviceStatusType === 'warning'
  86. && deviceStatusText === 'prejoin.audioDeviceProblem') {
  87. store.dispatch(setDeviceStatusOk('prejoin.lookGood'));
  88. }
  89. } else if (deviceStatusType === 'ok') {
  90. store.dispatch(setDeviceStatusWarning('prejoin.audioDeviceProblem'));
  91. }
  92. }
  93. break;
  94. }
  95. case CONFERENCE_JOINED:
  96. return _conferenceJoined(store, next, action);
  97. }
  98. return next(action);
  99. });
  100. /**
  101. * Handles cleanup of prejoin state when a conference is joined.
  102. *
  103. * @param {Object} store - The Redux store.
  104. * @param {Function} next - The Redux next function.
  105. * @param {Object} action - The Redux action.
  106. * @returns {Object}
  107. */
  108. function _conferenceJoined({ dispatch }, next, action) {
  109. dispatch(setPrejoinPageVisibility(PREJOIN_SCREEN_STATES.HIDDEN));
  110. return next(action);
  111. }