mon-entreprise/source/containers/Layout.js

104 lines
3.0 KiB
JavaScript

import { I18nextProvider } from 'react-i18next';
import i18next from 'i18next'
import XHR from 'i18next-xhr-backend';
import React, { Component } from 'react'
import './Layout.css'
import './reset.css'
import { Route, Router, Switch, Redirect } from 'react-router-dom'
import Home from 'Components/pages/Home'
import RulePage from 'Components/RulePage'
import Route404 from 'Components/Route404'
import Contact from 'Components/Contact'
import Simulateur from 'Components/Simulateur'
import RulesList from 'Components/pages/RulesList'
import Mecanisms from 'Components/Mecanisms'
import Contribution from 'Components/pages/Contribution'
import Integration from 'Components/pages/Integration'
import About from 'Components/pages/About'
import ReactPiwik from 'Components/Tracker'
import createHistory from 'history/createBrowserHistory'
import { Header, Footer } from 'Components/pages/Header'
import { getIframeOption } from '../utils'
function loadLocales(url, options, callback, data) {
try {
let translations = require('../../locales/'+url+'.json');
callback(translations, {status: '200'});
} catch (e) {
callback(null, {status: '404'});
}
}
i18next
.use(XHR)
.init({
debug: true,
lng: 'en',
backend: {
loadPath: '{{lng}}',
parse: (data) => data,
ajax: loadLocales
}
}, (err, t) => {
// ...
});
const piwik = new ReactPiwik({
url: 'stats.data.gouv.fr',
siteId: 39,
trackErrors: true
})
let integratorUrl = getIframeOption('integratorUrl')
ReactPiwik.push([
'setCustomVariable',
1,
'urlPartenaire',
decodeURIComponent(integratorUrl || 'https://embauche.beta.gouv.fr'),
'visit'
])
export default class Layout extends Component {
history = createHistory()
render() {
// track the initial pageview
ReactPiwik.push(['trackPageView'])
return (
<I18nextProvider i18n={ i18next }>
<Router history={piwik.connectToHistory(this.history)}>
<>
<Header />
<Switch>
<Route exact path="/" component={Home} />
<Route path="/contact" component={Contact} />
<Route path="/règle/:name" component={RulePage} />
{/* Redirect to be removed in March (Google should have understood...)*/}
<Route
path="/regle/:name"
render={({ match }) => (
<Redirect to={`/règle/${match.params.name}`} />
)}
/>
<Route path="/règles" component={RulesList} />
<Route path="/mecanismes" component={Mecanisms} />
<Redirect from="/simu/surcoût-CDD/intro" to="/" />
<Redirect from="/simu/surcoût-CDD" to="/" />
<Route path="/simu/:targets" component={Simulateur} />
<Route path="/à-propos" component={About} />
<Route path="/intégrer" component={Integration} />
<Route path="/contribuer" component={Contribution} />
<Redirect from="/simu/" to="/" />
<Redirect from="/simulateur" to="/" />
<Redirect from="/couleur.html" to="/" />
<Route component={Route404} />
</Switch>
<Footer />
</>
</Router>
</I18nextProvider>
)
}
}