'use strict'; require('babel/polyfill'); import React from 'react'; import Router from 'react-router'; import fetch from 'isomorphic-fetch'; import ApiUrls from './constants/api_urls'; import { updateApiUrls } from './constants/api_urls'; import appConstants from './constants/application_constants'; import getRoutes from './routes'; import requests from './utils/requests'; import { getSubdomainSettings } from './utils/constants_utils'; let headers = { 'Accept': 'application/json', 'Content-Type': 'application/json' }; requests.defaults({ urlMap: ApiUrls, http: { headers: headers, credentials: 'include' }, fatalErrorHandler: (err) => { console.log(err); //alert('Something went wrong, please reload the page'); } }); class AppGateway { start() { let settings; let subdomain = window.location.host.split('.')[0]; try { settings = getSubdomainSettings(subdomain); appConstants.whitelabel = settings; updateApiUrls(settings.type, subdomain); this.load(settings.type); } catch(err) { // if there are no matching subdomains, we're routing // to the default frontend this.load('default'); } } load(type) { Router.run(getRoutes(type), Router.HistoryLocation, (App) => { React.render( , document.getElementById('main') ); }); } } let ag = new AppGateway(); ag.start();