mirror of
https://github.com/ascribe/onion.git
synced 2025-01-18 16:57:00 +01:00
109 lines
3.0 KiB
JavaScript
109 lines
3.0 KiB
JavaScript
'use strict';
|
|
|
|
require('babel/polyfill');
|
|
|
|
import React from 'react';
|
|
import { Router, Redirect } from 'react-router';
|
|
import history from './history';
|
|
|
|
/* eslint-disable */
|
|
import fetch from 'isomorphic-fetch';
|
|
/* eslint-enable */
|
|
|
|
import ApiUrls from './constants/api_urls';
|
|
|
|
import AppConstants from './constants/application_constants';
|
|
import getRoutes from './routes';
|
|
import requests from './utils/requests';
|
|
|
|
import { updateApiUrls } from './constants/api_urls';
|
|
import { getSubdomainSettings } from './utils/constants_utils';
|
|
import { initLogging } from './utils/error_utils';
|
|
import { getSubdomain } from './utils/general_utils';
|
|
|
|
import EventActions from './actions/event_actions';
|
|
|
|
/* eslint-disable */
|
|
// You can comment out the modules you don't need
|
|
// import DebugHandler from './third_party/debug';
|
|
import GoogleAnalyticsHandler from './third_party/ga';
|
|
import RavenHandler from './third_party/raven';
|
|
import IntercomHandler from './third_party/intercom';
|
|
import NotificationsHandler from './third_party/notifications';
|
|
import FacebookHandler from './third_party/facebook';
|
|
/* eslint-enable */
|
|
|
|
initLogging();
|
|
|
|
let headers = {
|
|
'Accept': 'application/json',
|
|
'Content-Type': 'application/json'
|
|
};
|
|
|
|
requests.defaults({
|
|
urlMap: ApiUrls,
|
|
http: {
|
|
headers: headers,
|
|
credentials: 'include'
|
|
}
|
|
});
|
|
|
|
class AppGateway {
|
|
start() {
|
|
let settings;
|
|
let subdomain = getSubdomain();
|
|
|
|
try {
|
|
settings = getSubdomainSettings(subdomain);
|
|
AppConstants.whitelabel = settings;
|
|
updateApiUrls(settings.type, subdomain);
|
|
this.load(settings);
|
|
} catch(err) {
|
|
// if there are no matching subdomains, we're routing
|
|
// to the default frontend
|
|
console.logGlobal(err);
|
|
this.load();
|
|
}
|
|
}
|
|
|
|
load(settings) {
|
|
let type = 'default';
|
|
let subdomain = 'www';
|
|
let redirectRoute = (<Redirect from="/" to="/collection" />);
|
|
|
|
if (settings) {
|
|
type = settings.type;
|
|
subdomain = settings.subdomain;
|
|
}
|
|
|
|
// www and cc do not have a landing page
|
|
if(subdomain && subdomain !== 'cc') {
|
|
redirectRoute = null;
|
|
}
|
|
|
|
// Adds a client specific class to the body for whitelabel styling
|
|
window.document.body.classList.add('client--' + subdomain);
|
|
|
|
// Send the applicationWillBoot event to the third-party stores
|
|
EventActions.applicationWillBoot(settings);
|
|
|
|
// `history.listen` is called on every route change, which is perfect for
|
|
// us in that case.
|
|
history.listen(EventActions.routeDidChange);
|
|
|
|
React.render((
|
|
<Router history={history}>
|
|
{redirectRoute}
|
|
{getRoutes(type, subdomain)}
|
|
</Router>
|
|
), document.getElementById('main'));
|
|
|
|
// Send the applicationDidBoot event to the third-party stores
|
|
EventActions.applicationDidBoot(settings);
|
|
}
|
|
}
|
|
|
|
let ag = new AppGateway();
|
|
ag.start();
|
|
|