2016-10-05 14:36:59 +00:00
|
|
|
import { PARTICIPANT_LEFT } from '../participants';
|
|
|
|
import { MiddlewareRegistry } from '../redux';
|
|
|
|
|
|
|
|
import {
|
|
|
|
disposeLib,
|
|
|
|
initLib
|
|
|
|
} from './actions';
|
|
|
|
import { SET_CONFIG } from './actionTypes';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Middleware that captures PARTICIPANT_LEFT action for a local participant
|
|
|
|
* (which signalizes that we finally left the app) and disposes lib-jitsi-meet.
|
|
|
|
* Also captures SET_CONFIG action and disposes previous instance (if any) of
|
|
|
|
* lib-jitsi-meet, and initializes a new one with new config.
|
|
|
|
*
|
|
|
|
* @param {Store} store - Redux store.
|
|
|
|
* @returns {Function}
|
|
|
|
*/
|
|
|
|
MiddlewareRegistry.register(store => next => action => {
|
|
|
|
switch (action.type) {
|
|
|
|
case PARTICIPANT_LEFT:
|
2016-10-25 16:43:15 +00:00
|
|
|
action.participant.local && store.dispatch(disposeLib());
|
2016-10-05 14:36:59 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case SET_CONFIG: {
|
|
|
|
const { dispatch, getState } = store;
|
2016-10-25 16:43:15 +00:00
|
|
|
const initialized
|
|
|
|
= getState()['features/base/lib-jitsi-meet'].initialized;
|
2016-10-05 14:36:59 +00:00
|
|
|
|
|
|
|
// XXX If we already have config, that means new config is coming, which
|
|
|
|
// means that we should dispose instance of lib initialized with
|
|
|
|
// previous config first.
|
|
|
|
// TODO Currently 'disposeLib' actually does not dispose lib-jitsi-meet.
|
|
|
|
// This functionality should be implemented.
|
2016-10-25 16:43:15 +00:00
|
|
|
const promise
|
|
|
|
= initialized ? dispatch(disposeLib()) : Promise.resolve();
|
2016-10-05 14:36:59 +00:00
|
|
|
|
2016-10-25 16:43:15 +00:00
|
|
|
promise.then(dispatch(initLib()));
|
2016-10-05 14:36:59 +00:00
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return next(action);
|
|
|
|
});
|