import React from 'react'; import ReactDOM from 'react-dom'; import Animate from 'rc-animate'; import Icon from '../icon'; import classNames from 'classnames'; class AntTag extends React.Component { constructor(props) { super(props); this.state = { closing: false, closed: false, }; } close(e) { const dom = ReactDOM.findDOMNode(this); dom.style.width = `${dom.offsetWidth}px`; // It's Magic Code, don't know why dom.style.width = `${dom.offsetWidth}px`; this.setState({ closing: true, }); this.props.onClose(e); } animationEnd(key, existed) { if (!existed) { this.setState({ closed: true, closing: false, }); this.props.afterClose(); } } render() { const { prefixCls, closable, color, ...restProps } = this.props; const close = closable ? : ''; const className = classNames({ [prefixCls]: true, [`${prefixCls}-${color}`]: !!color, [`${prefixCls}-close`]: this.state.closing, }); return ( {this.state.closed ? null : (
{close}
)}
); } } AntTag.defaultProps = { prefixCls: 'ant-tag', closable: false, onClose() {}, afterClose() {}, }; export default AntTag;