2016-12-14 10:32:36 +00:00
|
|
|
/* global APP */
|
2017-01-10 21:55:31 +00:00
|
|
|
|
2016-11-23 21:46:46 +00:00
|
|
|
import React from 'react';
|
|
|
|
import ReactDOM from 'react-dom';
|
|
|
|
import { compose, createStore } from 'redux';
|
|
|
|
import Thunk from 'redux-thunk';
|
|
|
|
|
|
|
|
import config from './config';
|
|
|
|
import { App } from './features/app';
|
2017-01-10 21:55:31 +00:00
|
|
|
import { MiddlewareRegistry, ReducerRegistry } from './features/base/redux';
|
2016-11-23 21:46:46 +00:00
|
|
|
|
2016-12-14 10:32:36 +00:00
|
|
|
const logger = require('jitsi-meet-logger').getLogger(__filename);
|
|
|
|
|
2017-01-16 00:28:02 +00:00
|
|
|
// Create combined reducer from all reducers in registry.
|
|
|
|
const reducer = ReducerRegistry.combineReducers();
|
2016-11-23 21:46:46 +00:00
|
|
|
|
|
|
|
// Apply all registered middleware from the MiddlewareRegistry + additional
|
|
|
|
// 3rd party middleware:
|
|
|
|
// - Thunk - allows us to dispatch async actions easily. For more info
|
|
|
|
// @see https://github.com/gaearon/redux-thunk.
|
2017-01-16 00:28:02 +00:00
|
|
|
let middleware = MiddlewareRegistry.applyMiddleware(Thunk);
|
2016-11-23 21:46:46 +00:00
|
|
|
|
|
|
|
// Try to enable Redux DevTools Chrome extension in order to make it available
|
|
|
|
// for the purposes of facilitating development.
|
|
|
|
let devToolsExtension;
|
|
|
|
|
|
|
|
if (typeof window === 'object'
|
|
|
|
&& (devToolsExtension = window.devToolsExtension)) {
|
|
|
|
middleware = compose(middleware, devToolsExtension());
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create Redux store with our reducer and middleware.
|
|
|
|
const store = createStore(reducer, middleware);
|
|
|
|
|
2016-12-14 10:32:36 +00:00
|
|
|
/**
|
2017-01-10 21:55:31 +00:00
|
|
|
* Renders the app when the DOM tree has been loaded.
|
2016-12-14 10:32:36 +00:00
|
|
|
*/
|
|
|
|
document.addEventListener('DOMContentLoaded', () => {
|
|
|
|
const now = window.performance.now();
|
|
|
|
|
|
|
|
APP.connectionTimes['document.ready'] = now;
|
|
|
|
logger.log('(TIME) document ready:\t', now);
|
|
|
|
|
|
|
|
// Render the main Component.
|
|
|
|
ReactDOM.render(
|
|
|
|
<App
|
|
|
|
config = { config }
|
2017-01-15 19:05:17 +00:00
|
|
|
store = { store } />,
|
2016-12-14 10:32:36 +00:00
|
|
|
document.getElementById('react'));
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
2017-01-10 21:55:31 +00:00
|
|
|
* Stops collecting the logs and disposing the API when the user closes the
|
|
|
|
* page.
|
2016-12-14 10:32:36 +00:00
|
|
|
*/
|
|
|
|
window.addEventListener('beforeunload', () => {
|
|
|
|
// Stop the LogCollector
|
|
|
|
if (APP.logCollectorStarted) {
|
|
|
|
APP.logCollector.stop();
|
|
|
|
APP.logCollectorStarted = false;
|
|
|
|
}
|
|
|
|
APP.API.dispose();
|
|
|
|
});
|