| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 | 
							- // @flow
 - 
 - import { APP_WILL_MOUNT, APP_WILL_UNMOUNT } from '../base/app';
 - import { CONFERENCE_JOINED } from '../base/conference';
 - import { JitsiConferenceEvents } from '../base/lib-jitsi-meet';
 - import { setAudioMuted } from '../base/media';
 - import { MiddlewareRegistry } from '../base/redux';
 - import { playSound, registerSound, unregisterSound } from '../base/sounds';
 - import {
 -     hideNotification,
 -     showNotification
 - } from '../notifications';
 - 
 - import { setCurrentNotificationUid } from './actions';
 - import { TALK_WHILE_MUTED_SOUND_ID } from './constants';
 - import { TALK_WHILE_MUTED_SOUND_FILE } from './sounds';
 - 
 - MiddlewareRegistry.register(store => next => action => {
 -     const result = next(action);
 -     const { dispatch, getState } = store;
 -     const { conference } = action;
 - 
 -     switch (action.type) {
 -     case APP_WILL_MOUNT:
 -         dispatch(registerSound(TALK_WHILE_MUTED_SOUND_ID, TALK_WHILE_MUTED_SOUND_FILE));
 -         break;
 -     case APP_WILL_UNMOUNT:
 -         dispatch(unregisterSound(TALK_WHILE_MUTED_SOUND_ID));
 -         break;
 - 
 -     case CONFERENCE_JOINED: {
 -         conference.on(
 -             JitsiConferenceEvents.TRACK_MUTE_CHANGED,
 -             track => {
 -                 const { currentNotificationUid } = getState()['features/talk-while-muted'];
 - 
 -                 if (currentNotificationUid && track.isAudioTrack() && track.isLocal() && !track.isMuted()) {
 -                     dispatch(hideNotification(currentNotificationUid));
 -                     dispatch(setCurrentNotificationUid());
 -                 }
 -             });
 -         conference.on(
 -             JitsiConferenceEvents.TALK_WHILE_MUTED, () => {
 -                 const notification = showNotification({
 -                     titleKey: 'toolbar.talkWhileMutedPopup',
 -                     customActionNameKey: 'notify.unmute',
 -                     customActionHandler: () => dispatch(setAudioMuted(false))
 -                 });
 - 
 -                 dispatch(notification);
 - 
 -                 dispatch(playSound(TALK_WHILE_MUTED_SOUND_ID));
 - 
 -                 // we store the last start muted notification id that we showed,
 -                 // so we can hide it when unmuted mic is detected
 -                 dispatch(setCurrentNotificationUid(notification.uid));
 -             });
 -         break;
 -     }
 -     }
 - 
 -     return result;
 - });
 
 
  |