index.jsx 1.6 KB
Newer Older
A
afc163 已提交
1
import React from 'react';
B
Benjy Cui 已提交
2
import ReactDOM from 'react-dom';
J
jljsj 已提交
3
import Animate from 'rc-animate';
A
afc163 已提交
4
import Icon from '../icon';
A
afc163 已提交
5
import classNames from 'classnames';
J
jljsj 已提交
6

A
afc163 已提交
7
class AntTag extends React.Component {
A
afc163 已提交
8 9 10 11
  constructor(props) {
    super(props);

    this.state = {
A
afc163 已提交
12
      closing: false,
A
afc163 已提交
13
      closed: false,
A
afc163 已提交
14 15
    };
  }
A
afc163 已提交
16

A
afc163 已提交
17
  close(e) {
A
afc163 已提交
18
    const dom = ReactDOM.findDOMNode(this);
19
    dom.style.width = `${dom.offsetWidth}px`;
A
afc163 已提交
20
    // It's Magic Code, don't know why
21
    dom.style.width = `${dom.offsetWidth}px`;
A
afc163 已提交
22
    this.setState({
A
afc163 已提交
23
      closing: true,
A
afc163 已提交
24
    });
A
afc163 已提交
25
    this.props.onClose(e);
A
afc163 已提交
26
  }
A
afc163 已提交
27

A
afc163 已提交
28 29 30 31 32 33 34 35
  animationEnd(key, existed) {
    if (!existed) {
      this.setState({
        closed: true,
        closing: false,
      });
      this.props.afterClose();
    }
J
jljsj 已提交
36
  }
J
jljsj 已提交
37

A
afc163 已提交
38
  render() {
A
afc163 已提交
39 40 41 42
    const { prefixCls, closable, color, ...restProps } = this.props;
    const close = closable ? <Icon type="cross" onClick={this.close.bind(this)} /> : '';
    const className = classNames({
      [prefixCls]: true,
43 44
      [`${prefixCls}-${color}`]: !!color,
      [`${prefixCls}-close`]: this.state.closing,
A
afc163 已提交
45
    });
A
afc163 已提交
46
    return (
A
afc163 已提交
47 48
      <Animate component=""
        showProp="data-show"
49
        transitionName={`${prefixCls}-zoom`}
A
afc163 已提交
50 51
        transitionAppear
        onEnd={this.animationEnd.bind(this)}>
A
afc163 已提交
52 53
        {this.state.closed ? null : (
          <div data-show={!this.state.closing} className={className}>
54
            <span className={`${prefixCls}-text`} {...restProps} />
A
afc163 已提交
55 56 57
            {close}
          </div>
        )}
A
afc163 已提交
58 59
      </Animate>
    );
A
afc163 已提交
60 61 62 63
  }
}

AntTag.defaultProps = {
A
afc163 已提交
64
  prefixCls: 'ant-tag',
A
afc163 已提交
65
  closable: false,
A
afc163 已提交
66
  onClose() {},
A
afc163 已提交
67
  afterClose() {},
A
afc163 已提交
68 69 70
};

export default AntTag;