81 lines
2.5 KiB
JavaScript
81 lines
2.5 KiB
JavaScript
/* global APP */
|
|
import React from 'react';
|
|
import ReactDOM from 'react-dom';
|
|
import { browserHistory } from 'react-router';
|
|
import {
|
|
routerMiddleware,
|
|
routerReducer
|
|
} from 'react-router-redux';
|
|
import { compose, createStore } from 'redux';
|
|
import Thunk from 'redux-thunk';
|
|
|
|
import config from './config';
|
|
import { App } from './features/app';
|
|
import {
|
|
MiddlewareRegistry,
|
|
ReducerRegistry
|
|
} from './features/base/redux';
|
|
|
|
const logger = require('jitsi-meet-logger').getLogger(__filename);
|
|
|
|
// Create combined reducer from all reducers in registry + routerReducer from
|
|
// 'react-router-redux' module (stores location updates from history).
|
|
// @see https://github.com/reactjs/react-router-redux#routerreducer.
|
|
const reducer = ReducerRegistry.combineReducers({
|
|
routing: routerReducer
|
|
});
|
|
|
|
// 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.
|
|
// - routerMiddleware - middleware from 'react-router-redux' module to track
|
|
// changes in browser history inside Redux state. For more information
|
|
// @see https://github.com/reactjs/react-router-redux.
|
|
let middleware = MiddlewareRegistry.applyMiddleware(
|
|
Thunk,
|
|
routerMiddleware(browserHistory));
|
|
|
|
// 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);
|
|
|
|
/**
|
|
* Render the app when DOM tree has been loaded.
|
|
*/
|
|
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 }
|
|
store = { store }
|
|
url = { window.location.toString() } />,
|
|
document.getElementById('react'));
|
|
});
|
|
|
|
/**
|
|
* Stop collecting the logs and disposing the API when
|
|
* user closes the page.
|
|
*/
|
|
window.addEventListener('beforeunload', () => {
|
|
// Stop the LogCollector
|
|
if (APP.logCollectorStarted) {
|
|
APP.logCollector.stop();
|
|
APP.logCollectorStarted = false;
|
|
}
|
|
APP.API.dispose();
|
|
});
|