You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

54 lines
1.2 KiB

import React from 'react'
import ReactDOM from 'react-dom'
import { Provider } from 'react-intl-redux'
import jstz from 'jstimezonedetect'
import { configureStore, history } from './store/configureStore'
import { getDefaultLocale } from './lib/i18n'
import Root from './containers/Root'
import db from './store/db'
// Load global styles.
import './styles/app.global.scss'
8 years ago
// Register supported locales.
import './lib/i18n/locale'
// Get translations.
import translations from './lib/i18n/translation'
// Initialise the database.
db.open()
// Default the locale to English.
const defaultLocale = getDefaultLocale()
// Initialise the intl store with data from the users current locale.
const initialState = {
intl: {
locale: defaultLocale,
messages: translations[defaultLocale],
timeZone: jstz.determine().name()
}
}
8 years ago
// Set up the redux store.
const store = configureStore(initialState)
const MOUNT_NODE = document.getElementById('root')
8 years ago
const render = Component => {
ReactDOM.render(
<Provider store={store}>
<Component history={history} />
</Provider>,
MOUNT_NODE
)
8 years ago
}
render(Root)
if (module.hot) {
module.hot.accept('./containers/Root', () => {
render(Root)
})
}