您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

middleware.web.ts 2.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. // @ts-expect-error
  2. import VideoLayout from '../../../modules/UI/videolayout/VideoLayout.js';
  3. import { CONFERENCE_WILL_INIT, CONFERENCE_WILL_LEAVE } from '../base/conference/actionTypes';
  4. import { MEDIA_TYPE } from '../base/media/constants';
  5. import { PARTICIPANT_JOINED } from '../base/participants/actionTypes';
  6. import { getLocalParticipant } from '../base/participants/functions';
  7. import MiddlewareRegistry from '../base/redux/MiddlewareRegistry';
  8. import { TRACK_ADDED, TRACK_REMOVED, TRACK_STOPPED } from '../base/tracks/actionTypes';
  9. import { PARTICIPANTS_PANE_CLOSE, PARTICIPANTS_PANE_OPEN } from '../participants-pane/actionTypes';
  10. import './middleware.any';
  11. /**
  12. * Middleware which intercepts actions and updates the legacy component
  13. * {@code VideoLayout} as needed. The purpose of this middleware is to redux-ify
  14. * {@code VideoLayout} without having to simultaneously react-ifying it.
  15. *
  16. * @param {Store} store - The redux store.
  17. * @returns {Function}
  18. */
  19. // eslint-disable-next-line no-unused-vars
  20. MiddlewareRegistry.register(store => next => action => {
  21. // Purposefully perform additional actions after state update to mimic
  22. // being connected to the store for updates.
  23. const result = next(action);
  24. switch (action.type) {
  25. case CONFERENCE_WILL_INIT:
  26. // Reset VideoLayout. It's destroyed on CONFERENCE_WILL_LEAVE so re-initialize it.
  27. VideoLayout.initLargeVideo();
  28. VideoLayout.resizeVideoArea();
  29. break;
  30. case CONFERENCE_WILL_LEAVE:
  31. VideoLayout.reset();
  32. break;
  33. case PARTICIPANT_JOINED:
  34. if (!action.participant.local) {
  35. VideoLayout.updateVideoMutedForNoTracks(action.participant.id);
  36. }
  37. break;
  38. case PARTICIPANTS_PANE_CLOSE:
  39. case PARTICIPANTS_PANE_OPEN:
  40. VideoLayout.resizeVideoArea();
  41. break;
  42. case TRACK_ADDED:
  43. if (action.track.mediaType !== MEDIA_TYPE.AUDIO) {
  44. VideoLayout._updateLargeVideoIfDisplayed(action.track.participantId, true);
  45. }
  46. break;
  47. case TRACK_STOPPED: {
  48. if (action.track.jitsiTrack.isLocal()) {
  49. const participant = getLocalParticipant(store.getState);
  50. VideoLayout._updateLargeVideoIfDisplayed(participant?.id);
  51. }
  52. break;
  53. }
  54. case TRACK_REMOVED:
  55. if (!action.track.local && action.track.mediaType !== MEDIA_TYPE.AUDIO) {
  56. VideoLayout.updateVideoMutedForNoTracks(action.track.jitsiTrack.getParticipantId());
  57. }
  58. break;
  59. }
  60. return result;
  61. });