| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 | /* @flow */
import { NativeModules } from 'react-native';
import { APP_WILL_MOUNT } from '../app';
import {
    CONFERENCE_FAILED,
    CONFERENCE_LEFT,
    CONFERENCE_WILL_JOIN
} from '../base/conference';
import { MiddlewareRegistry } from '../base/redux';
/**
 * Middleware that captures conference actions and sets the correct audio mode
 * based on the type of conference. Audio-only conferences don't use the speaker
 * by default, and video conferences do.
 *
 * @param {Store} store - Redux store.
 * @returns {Function}
 */
MiddlewareRegistry.register(store => next => action => {
    const AudioMode = NativeModules.AudioMode;
    // The react-native module AudioMode is implemented on iOS at the time of
    // this writing.
    if (AudioMode) {
        let mode;
        switch (action.type) {
        case APP_WILL_MOUNT:
        case CONFERENCE_FAILED:
        case CONFERENCE_LEFT:
            mode = AudioMode.DEFAULT;
            break;
        case CONFERENCE_WILL_JOIN: {
            const conference = store.getState()['features/base/conference'];
            mode
                = conference.audioOnly
                    ? AudioMode.AUDIO_CALL
                    : AudioMode.VIDEO_CALL;
            break;
        }
        default:
            mode = null;
            break;
        }
        if (mode !== null) {
            AudioMode.setMode(mode)
                .catch(err =>
                    console.error(
                            `Failed to set audio mode ${String(mode)}: `
                                + `${err}`));
        }
    }
    return next(action);
});
 |