import React from 'react'; import { PropTypes } from 'react'; import { findDOMNode } from 'react-dom'; import classNames from 'classnames'; import Animate from 'rc-animate'; import isCssAnimationSupported from '../_util/isCssAnimationSupported'; import splitObject from '../_util/splitObject'; import omit from 'omit.js'; export interface SpinProps { prefixCls?: string; className?: string; spinning?: boolean; size?: 'small' | 'default' | 'large'; tip?: string; } export default class Spin extends React.Component { static defaultProps = { prefixCls: 'ant-spin', spinning: true, size: 'default', }; static propTypes = { prefixCls: PropTypes.string, className: PropTypes.string, spinning: PropTypes.bool, size: PropTypes.oneOf(['small', 'default', 'large']), }; debounceTimeout: number; constructor(props) { super(props); const spinning = props.spinning; this.state = { spinning, }; } isNestedPattern() { return !!(this.props && this.props.children); } componentDidMount() { if (!isCssAnimationSupported()) { // Show text in IE8/9 findDOMNode(this).className += ` ${this.props.prefixCls}-show-text`; } } componentWillUnmount() { if (this.debounceTimeout) { clearTimeout(this.debounceTimeout); } } componentWillReceiveProps(nextProps) { const currentSpinning = this.props.spinning; const spinning = nextProps.spinning; if (this.debounceTimeout) { clearTimeout(this.debounceTimeout); } if (currentSpinning && !spinning) { this.debounceTimeout = setTimeout(() => this.setState({ spinning }), 500); } else { this.setState({ spinning }); } } render() { const [{ className, size, prefixCls, tip, }, restProps] = splitObject(this.props, ['className', 'size', 'prefixCls', 'tip']); const { spinning } = this.state; const spinClassName = classNames({ [prefixCls]: true, [`${prefixCls}-sm`]: size === 'small', [`${prefixCls}-lg`]: size === 'large', [`${prefixCls}-spinning`]: spinning, [`${prefixCls}-show-text`]: !!this.props.tip, [className]: !!className, }); // fix https://fb.me/react-unknown-prop const divProps = omit(restProps, [ 'spinning', ]); const spinElement = (
{tip ?
{tip}
: null}
); if (this.isNestedPattern()) { const containerClassName = classNames({ [`${prefixCls}-container`]: true, [`${prefixCls}-filter`]: spinning, }); return ( {spinning &&
{spinElement}
}
{this.props.children}
); } return spinElement; } }