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

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