import React from 'react'; import ReactDOM from 'react-dom'; import PropTypes from 'prop-types'; import { enquireScreen } from 'enquire-js'; import { addLocaleData, IntlProvider } from 'react-intl'; import 'moment/locale/zh-cn'; import { LocaleProvider } from 'antd'; import zhCN from 'antd/lib/locale-provider/zh_CN'; import OfflineRuntime from 'offline-plugin/runtime'; import Header from './Header'; import Footer from './Footer'; import enLocale from '../../en-US'; import cnLocale from '../../zh-CN'; import * as utils from '../utils'; if (typeof window !== 'undefined') { OfflineRuntime.install(); } if (typeof window !== 'undefined') { /* eslint-disable global-require */ require('../../static/style'); // Expose to iframe window.react = React; window['react-dom'] = ReactDOM; window.antd = require('antd'); /* eslint-enable global-require */ } let isMobile = false; enquireScreen((b) => { isMobile = b; }); export default class Layout extends React.Component { static contextTypes = { router: PropTypes.object.isRequired, } static childContextTypes = { isMobile: PropTypes.bool, }; getChildContext() { const { isMobile: mobile } = this.state; return { isMobile: mobile }; } constructor(props) { super(props); const { pathname } = props.location; const appLocale = utils.isZhCN(pathname) ? cnLocale : enLocale; addLocaleData(appLocale.data); this.state = { appLocale, isMobile, }; } componentDidMount() { const { router } = this.context; router.listen((loc) => { if (typeof window.ga !== 'undefined') { window.ga('send', 'pageview', loc.pathname + loc.search); } // eslint-disable-next-line if (typeof window._hmt !== 'undefined') { // eslint-disable-next-line window._hmt.push(['_trackPageview', loc.pathname + loc.search]); } }); const nprogressHiddenStyle = document.getElementById('nprogress-style'); if (nprogressHiddenStyle) { this.timer = setTimeout(() => { nprogressHiddenStyle.parentNode.removeChild(nprogressHiddenStyle); }, 0); } enquireScreen((b) => { this.setState({ isMobile: !!b, }); }); } componentWillUnmount() { clearTimeout(this.timer); } render() { const { children, ...restProps } = this.props; const { appLocale } = this.state; return (
{children}
); } }