mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-07 11:37:58 +08:00
80 lines
2.1 KiB
JavaScript
80 lines
2.1 KiB
JavaScript
import React, { cloneElement } from 'react';
|
|
import ReactDOM from 'react-dom';
|
|
import { addLocaleData, IntlProvider } from 'react-intl';
|
|
import { LocaleProvider } from 'antd';
|
|
import enUS from 'antd/lib/locale-provider/en_US';
|
|
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') {
|
|
/* 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 */
|
|
}
|
|
|
|
export default class Layout extends React.Component {
|
|
static contextTypes = {
|
|
router: React.PropTypes.object.isRequired,
|
|
}
|
|
|
|
constructor(props) {
|
|
super(props);
|
|
const pathname = props.location.pathname;
|
|
const appLocale = utils.isZhCN(pathname) ? cnLocale : enLocale;
|
|
addLocaleData(appLocale.data);
|
|
this.state = {
|
|
isFirstScreen: true,
|
|
appLocale,
|
|
};
|
|
}
|
|
|
|
componentDidMount() {
|
|
if (typeof ga !== 'undefined') {
|
|
this.context.router.listen((loc) => {
|
|
window.ga('send', 'pageview', loc.pathname + loc.search);
|
|
});
|
|
}
|
|
|
|
const nprogressHiddenStyle = document.getElementById('nprogress-style');
|
|
if (nprogressHiddenStyle) {
|
|
this.timer = setTimeout(() => {
|
|
nprogressHiddenStyle.parentNode.removeChild(nprogressHiddenStyle);
|
|
}, 0);
|
|
}
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
clearTimeout(this.timer);
|
|
}
|
|
|
|
onEnterChange = (mode) => {
|
|
this.setState({
|
|
isFirstScreen: mode === 'enter',
|
|
});
|
|
}
|
|
|
|
render() {
|
|
const { children, ...restProps } = this.props;
|
|
const { appLocale, isFirstScreen } = this.state;
|
|
return (
|
|
<IntlProvider locale={appLocale.locale} messages={appLocale.messages}>
|
|
<LocaleProvider locale={enUS}>
|
|
<div className="page-wrapper">
|
|
<Header {...restProps} isFirstScreen={isFirstScreen} />
|
|
{cloneElement(children, { onEnterChange: this.onEnterChange })}
|
|
<Footer />
|
|
</div>
|
|
</LocaleProvider>
|
|
</IntlProvider>
|
|
);
|
|
}
|
|
}
|