ant-design/components/locale-provider/index.tsx

78 lines
1.6 KiB
TypeScript
Raw Normal View History

import * as React from 'react';
2018-08-07 21:07:52 +08:00
import * as PropTypes from 'prop-types';
2018-01-13 17:53:25 +08:00
import * as moment from 'moment';
import interopDefault from '../_util/interopDefault';
2017-07-31 01:50:46 +08:00
import { ModalLocale, changeConfirmLocale } from '../modal/locale';
2016-03-03 16:28:02 +08:00
2018-01-13 17:53:25 +08:00
export interface Locale {
locale: string;
Pagination?: Object;
DatePicker?: Object;
TimePicker?: Object;
Calendar?: Object;
Table?: Object;
Modal?: ModalLocale;
Popconfirm?: Object;
Transfer?: Object;
Select?: Object;
Upload?: Object;
}
2016-08-02 16:10:26 +08:00
export interface LocaleProviderProps {
2018-01-13 17:53:25 +08:00
locale: Locale;
2018-12-13 22:03:12 +08:00
children?: React.ReactNode;
2016-08-02 16:10:26 +08:00
}
2018-01-13 17:53:25 +08:00
function setMomentLocale(locale: Locale) {
if (locale && locale.locale) {
interopDefault(moment).locale(locale.locale);
} else {
interopDefault(moment).locale('en');
2018-01-13 17:53:25 +08:00
}
}
2016-08-02 16:10:26 +08:00
export default class LocaleProvider extends React.Component<LocaleProviderProps, any> {
static propTypes = {
locale: PropTypes.object,
2016-07-13 11:14:24 +08:00
};
2018-01-13 17:53:25 +08:00
static defaultProps = {
locale: {},
};
static childContextTypes = {
antLocale: PropTypes.object,
2016-07-13 11:14:24 +08:00
};
constructor(props: LocaleProviderProps) {
super(props);
setMomentLocale(props.locale);
changeConfirmLocale(props.locale && props.locale.Modal);
}
2016-03-03 16:28:02 +08:00
getChildContext() {
return {
antLocale: {
...this.props.locale,
exist: true,
},
2016-03-03 16:28:02 +08:00
};
}
componentDidUpdate(prevProps: LocaleProviderProps) {
2018-01-13 17:53:25 +08:00
const { locale } = this.props;
if (prevProps.locale !== locale) {
setMomentLocale(locale);
2018-01-13 17:53:25 +08:00
}
changeConfirmLocale(locale && locale.Modal);
}
2018-01-13 17:53:25 +08:00
componentWillUnmount() {
changeConfirmLocale();
}
2016-03-03 16:28:02 +08:00
render() {
2016-03-05 16:39:27 +08:00
return React.Children.only(this.props.children);
2016-03-03 16:28:02 +08:00
}
}