UNPKG

react-toolbox-build4server

Version:

Builds react-toolbox in such a way that it's components can be required and used in node - most likely for server-side rendered webapps - without having to depend on webpack to build your entire server-side project

91 lines (80 loc) 2.42 kB
import React from 'react'; import ClassNames from 'classnames'; import style from './style'; import prefixer from '../utils/prefixer'; class ProgressBar extends React.Component { static propTypes = { buffer: React.PropTypes.number, className: React.PropTypes.string, max: React.PropTypes.number, min: React.PropTypes.number, mode: React.PropTypes.string, multicolor: React.PropTypes.bool, type: React.PropTypes.oneOf(['linear', 'circular']), value: React.PropTypes.number }; static defaultProps = { buffer: 0, className: '', max: 100, min: 0, mode: 'indeterminate', multicolor: false, type: 'linear', value: 0 }; calculateRatio (value) { if (value < this.props.min) return 0; if (value > this.props.max) return 1; return (value - this.props.min) / (this.props.max - this.props.min); } circularStyle () { if (this.props.mode !== 'indeterminate') { return {strokeDasharray: `${2 * Math.PI * 25 * this.calculateRatio(this.props.value)}, 400`}; } } linearStyle () { if (this.props.mode !== 'indeterminate') { return { buffer: prefixer({transform: `scaleX(${this.calculateRatio(this.props.buffer)})`}), value: prefixer({transform: `scaleX(${this.calculateRatio(this.props.value)})`}) }; } else { return {}; } } renderCircular () { return ( <svg className={style.circle}> <circle className={style.path} style={this.circularStyle()} cx='30' cy='30' r='25' /> </svg> ); } renderLinear () { const {buffer, value} = this.linearStyle(); return ( <div> <span ref='buffer' data-ref='buffer' className={style.buffer} style={buffer}></span> <span ref='value' data-ref='value' className={style.value} style={value}></span> </div> ); } render () { const className = ClassNames(style[this.props.type], { [style[this.props.mode]]: this.props.mode, [style.multicolor]: this.props.multicolor }, this.props.className); return ( <div data-react-toolbox='progress-bar' aria-valuenow={this.props.value} aria-valuemin={this.props.min} aria-valuemax={this.props.max} className={className} > {this.props.type === 'circular' ? this.renderCircular() : this.renderLinear()} </div> ); } } export default ProgressBar;