mirror of
https://github.com/ant-design/ant-design.git
synced 2024-11-25 19:50:05 +08:00
71 lines
1.8 KiB
JavaScript
71 lines
1.8 KiB
JavaScript
import React from 'react';
|
|
import { classSet } from 'rc-util';
|
|
import { isCssAnimationSupported } from 'css-animation';
|
|
const AntSpin = React.createClass({
|
|
getDefaultProps() {
|
|
return {
|
|
size: 'default'
|
|
};
|
|
},
|
|
|
|
propTypes: {
|
|
className: React.PropTypes.string,
|
|
size: React.PropTypes.oneOf(['small', 'default', 'large'])
|
|
},
|
|
|
|
isNestedPattern() {
|
|
return this.props.children ? true : false;
|
|
},
|
|
|
|
render() {
|
|
const prefix = 'ant-spin';
|
|
const nestedStatus = this.isNestedPattern();
|
|
const { className, size, ...others } = this.props;
|
|
const sizeCls = ({
|
|
'large': 'lg',
|
|
'small': 'sm'
|
|
})[size] || '';
|
|
|
|
let loadingClassName = classSet({
|
|
'ant-spin-nested-loading': nestedStatus
|
|
});
|
|
let spinClassName = classSet({
|
|
'ant-spin': true,
|
|
[className]: !!className
|
|
});
|
|
|
|
let spinEl;
|
|
if (!isCssAnimationSupported) {
|
|
// not support for animation, just use text instead
|
|
spinEl = <div className={ spinClassName }>加载中...</div>;
|
|
}else {
|
|
let spinWrapperClassName = classSet({
|
|
'ant-spin-wrapper': true,
|
|
[`${prefix}-${sizeCls}`]: sizeCls
|
|
});
|
|
spinEl = (<div className={ spinWrapperClassName }>
|
|
<div className={ spinClassName }>
|
|
<span className="ant-spin-dot ant-spin-dot-first" />
|
|
<span className="ant-spin-dot ant-spin-dot-second" />
|
|
<span className="ant-spin-dot ant-spin-dot-third" />
|
|
</div>
|
|
</div>);
|
|
}
|
|
|
|
let spinContainerEl = nestedStatus ?
|
|
<div className="ant-spin-container">
|
|
{ this.props.children }
|
|
</div> : null;
|
|
|
|
return (
|
|
<div {...this.props} className={ loadingClassName }>
|
|
{ spinEl }
|
|
{ spinContainerEl }
|
|
</div>
|
|
);
|
|
}
|
|
});
|
|
|
|
export default AntSpin;
|
|
|