import React from 'react'; import { FormattedMessage, injectIntl } from 'react-intl'; import { Modal, message, Row, Col, Badge, Icon } from 'antd'; import { isLocalStorageNameSupported, loadScript } from '../utils'; import ColorPicker from '../Color/ColorPicker'; class Footer extends React.Component { constructor(props) { super(props); this.lessLoaded = false; this.state = { color: '#1890ff', }; } componentDidMount() { // for some iOS // http://stackoverflow.com/a/14555361 if (!isLocalStorageNameSupported()) { return; } // 大版本发布后全局弹窗提示 // 1. 点击『知道了』之后不再提示 // 2. 超过截止日期后不再提示 if ( localStorage.getItem('antd@3.0.0-notification-sent') !== 'true' && Date.now() < new Date('2017/12/20').getTime() ) { this.infoNewVersion(); } } handleColorChange = (color) => { const changeColor = () => { const { intl: { messages } } = this.props; window.less.modifyVars({ '@primary-color': color, }).then(() => { Icon.setTwoToneColor({ primaryColor: color }); message.success(messages['app.footer.primary-color-changed']); this.setState({ color }); }); }; const lessUrl = 'https://gw.alipayobjects.com/os/lib/less.js/3.8.1/less.min.js'; if (this.lessLoaded) { changeColor(); } else { window.less = { async: true, javascriptEnabled: true, }; loadScript(lessUrl).then(() => { this.lessLoaded = true; changeColor(); }); } } infoNewVersion() { const { intl: { messages } } = this.props; Modal.info({ title: messages['app.publish.title'], content: (
Ant Design

{messages['app.publish.greeting']} antd@3.0.0 {messages['app.publish.intro']} {messages['app.publish.old-version-guide']} 2x.ant.design {messages['app.publish.old-version-tips']}

), okText: 'OK', onOk: () => localStorage.setItem('antd@3.0.0-notification-sent', 'true'), className: 'new-version-info-modal', width: 470, }); } render() { const { color } = this.state; return ( ); } } export default injectIntl(Footer);