2019-12-07 21:02:00 +02:00
|
|
|
import 'app/polyfills';
|
2019-11-09 19:26:46 +02:00
|
|
|
import 'react-hot-loader';
|
2016-01-02 22:24:07 +02:00
|
|
|
|
|
|
|
import React from 'react';
|
|
|
|
import ReactDOM from 'react-dom';
|
2019-12-07 21:02:00 +02:00
|
|
|
import { factory as userFactory } from 'app/components/user/factory';
|
|
|
|
import authFlow from 'app/services/authFlow';
|
|
|
|
import storeFactory from 'app/storeFactory';
|
|
|
|
import bsodFactory from 'app/components/ui/bsod/factory';
|
|
|
|
import loader from 'app/services/loader';
|
|
|
|
import logger from 'app/services/logger';
|
|
|
|
import font from 'app/services/font';
|
|
|
|
import history, { browserHistory } from 'app/services/history';
|
|
|
|
import i18n from 'app/services/i18n';
|
|
|
|
import { loadScript, debounce } from 'app/functions';
|
2019-11-09 19:26:46 +02:00
|
|
|
|
2019-12-26 14:18:58 +02:00
|
|
|
import App from './shell/App';
|
2017-01-29 17:36:21 +02:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
const win: { [key: string]: any } = window as any;
|
|
|
|
|
2017-01-29 17:36:21 +02:00
|
|
|
history.init();
|
2016-12-06 23:06:45 +02:00
|
|
|
|
|
|
|
logger.init({
|
2019-12-07 13:28:52 +02:00
|
|
|
sentryCdn: (window as any).SENTRY_CDN as string,
|
2016-12-06 23:06:45 +02:00
|
|
|
});
|
2016-01-02 22:24:07 +02:00
|
|
|
|
2016-06-18 18:00:45 +03:00
|
|
|
const store = storeFactory();
|
2016-01-02 22:24:07 +02:00
|
|
|
|
2019-12-26 14:18:58 +02:00
|
|
|
bsodFactory({
|
|
|
|
store,
|
|
|
|
history: browserHistory,
|
|
|
|
stopLoading: () => loader.hide(),
|
|
|
|
});
|
2017-05-25 22:11:57 +03:00
|
|
|
authFlow.setStore(store);
|
2016-07-29 22:29:27 +03:00
|
|
|
|
2016-10-11 07:07:09 +03:00
|
|
|
Promise.all([
|
2019-11-27 11:03:32 +02:00
|
|
|
userFactory(store),
|
|
|
|
font.load(['Roboto', 'Roboto Condensed']),
|
|
|
|
i18n.ensureIntl(), // ensure, that intl is polyfilled before any rendering
|
2019-11-09 19:26:46 +02:00
|
|
|
]).then(() => {
|
2019-11-27 11:03:32 +02:00
|
|
|
ReactDOM.render(
|
2019-12-09 09:07:07 +02:00
|
|
|
<App store={store} history={browserHistory} />,
|
2019-11-27 11:03:32 +02:00
|
|
|
document.getElementById('app'),
|
|
|
|
);
|
2017-01-03 07:56:38 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
initAnalytics();
|
2019-11-09 19:26:46 +02:00
|
|
|
});
|
2016-05-08 22:28:51 +03:00
|
|
|
|
2017-01-03 07:56:38 +02:00
|
|
|
const trackPageView = debounce(_trackPageView);
|
|
|
|
function initAnalytics() {
|
2019-12-07 13:28:52 +02:00
|
|
|
if (!win.ga) {
|
|
|
|
const ga: {
|
|
|
|
[key: string]: any;
|
|
|
|
(...args: any[]): void;
|
|
|
|
} = function(...args) {
|
2019-11-27 11:03:32 +02:00
|
|
|
// eslint-disable-next-line id-length
|
|
|
|
(ga.q = ga.q || []).push(args);
|
|
|
|
};
|
2019-12-07 13:28:52 +02:00
|
|
|
win.ga = ga;
|
2019-11-27 11:03:32 +02:00
|
|
|
ga.l = Date.now(); // eslint-disable-line
|
2017-01-03 07:56:38 +02:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
if (win.GA_ID) {
|
2019-11-27 11:03:32 +02:00
|
|
|
// when GA is not available, we will continue to push into array
|
|
|
|
// for debug purposes
|
|
|
|
// Catch to prevent "unhandled rejection" error
|
|
|
|
loadScript(
|
|
|
|
'https://www.google-analytics.com/analytics.js',
|
|
|
|
).catch(() => {});
|
|
|
|
}
|
2016-11-20 14:01:57 +02:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
ga('create', win.GA_ID, 'auto');
|
2019-11-27 11:03:32 +02:00
|
|
|
trackPageView(location);
|
2016-11-20 14:01:57 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
browserHistory.listen(trackPageView);
|
|
|
|
}
|
2017-01-03 07:56:38 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function _trackPageView(location) {
|
2019-12-07 13:28:52 +02:00
|
|
|
const { ga } = win;
|
2016-11-20 14:01:57 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
ga('set', 'page', location.pathname + location.search);
|
|
|
|
ga('send', 'pageview');
|
2016-11-20 14:01:57 +02:00
|
|
|
}
|