| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 | // @flow
import type { Dispatch } from 'redux';
import {
    libInitError,
    WEBRTC_NOT_READY,
    WEBRTC_NOT_SUPPORTED
} from '../lib-jitsi-meet';
declare var APP: Object;
declare var config: Object;
const logger = require('jitsi-meet-logger').getLogger(__filename);
export {
    connectionEstablished,
    connectionFailed,
    setLocationURL
} from './actions.native';
/**
 * Opens new connection.
 *
 * @returns {Promise<JitsiConnection>}
 */
export function connect() {
    return (dispatch: Dispatch<*>, getState: Function) => {
        const state = getState();
        // XXX Lib-jitsi-meet does not accept uppercase letters.
        const room = state['features/base/conference'].room.toLowerCase();
        const { initPromise } = state['features/base/lib-jitsi-meet'];
        // XXX For web based version we use conference initialization logic
        // from the old app (at the moment of writing).
        return initPromise.then(() => APP.conference.init({
            roomName: room
        })).catch(error => {
            APP.API.notifyConferenceLeft(APP.conference.roomName);
            logger.error(error);
            // TODO The following are in fact Errors raised by
            // JitsiMeetJS.init() which should be taken care of in
            // features/base/lib-jitsi-meet but we are not there yet on the
            // Web at the time of this writing.
            switch (error.name) {
            case WEBRTC_NOT_READY:
            case WEBRTC_NOT_SUPPORTED:
                dispatch(libInitError(error));
            }
        });
    };
}
/**
 * Closes connection.
 *
 * @param {boolean} [requestFeedback] - Whether or not to attempt showing a
 * request for call feedback.
 * @returns {Function}
 */
export function disconnect(requestFeedback: boolean = false) {
    // XXX For web based version we use conference hanging up logic from the old
    // app.
    return () => APP.conference.hangup(requestFeedback);
}
 |