134 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			134 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
 | 
						|
 | 
						|
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
 | 
						|
 | 
						|
import React from 'react';
 | 
						|
import classNames from 'classnames';
 | 
						|
import withStyles from '../styles/withStyles';
 | 
						|
 | 
						|
const SIZE = 50;
 | 
						|
 | 
						|
function getRelativeValue(value, min, max) {
 | 
						|
  const clampedValue = Math.min(Math.max(min, value), max);
 | 
						|
  return (clampedValue - min) / (max - min);
 | 
						|
}
 | 
						|
 | 
						|
export const styles = theme => ({
 | 
						|
  root: {
 | 
						|
    display: 'inline-block'
 | 
						|
  },
 | 
						|
  primaryColor: {
 | 
						|
    color: theme.palette.primary[500]
 | 
						|
  },
 | 
						|
  accentColor: {
 | 
						|
    color: theme.palette.secondary.A200
 | 
						|
  },
 | 
						|
  svgIndeterminate: {
 | 
						|
    animation: 'mui-progress-circular-rotate 1.4s linear infinite'
 | 
						|
  },
 | 
						|
  svgDeterminate: {
 | 
						|
    transform: 'rotate(-90deg)'
 | 
						|
  },
 | 
						|
  circle: {
 | 
						|
    stroke: 'currentColor',
 | 
						|
    strokeLinecap: 'round'
 | 
						|
  },
 | 
						|
  circleIndeterminate: {
 | 
						|
    animation: 'mui-progress-circular-dash 1.4s ease-in-out infinite',
 | 
						|
    // Some default value that looks fine waiting for the animation to kicks in.
 | 
						|
    strokeDasharray: '80,200',
 | 
						|
    strokeDashoffset: 0
 | 
						|
  },
 | 
						|
  '@keyframes mui-progress-circular-rotate': {
 | 
						|
    '100%': {
 | 
						|
      transform: 'rotate(360deg)'
 | 
						|
    }
 | 
						|
  },
 | 
						|
  '@keyframes mui-progress-circular-dash': {
 | 
						|
    '0%': {
 | 
						|
      strokeDasharray: '1,200',
 | 
						|
      strokeDashoffset: 0
 | 
						|
    },
 | 
						|
    '50%': {
 | 
						|
      strokeDasharray: '100,200',
 | 
						|
      strokeDashoffset: -15
 | 
						|
    },
 | 
						|
    '100%': {
 | 
						|
      strokeDasharray: '100,200',
 | 
						|
      strokeDashoffset: -120
 | 
						|
    }
 | 
						|
  }
 | 
						|
});
 | 
						|
 | 
						|
function CircularProgress(props) {
 | 
						|
  const {
 | 
						|
    classes,
 | 
						|
    className,
 | 
						|
    color,
 | 
						|
    size,
 | 
						|
    style,
 | 
						|
    thickness,
 | 
						|
    mode,
 | 
						|
    value,
 | 
						|
    min,
 | 
						|
    max
 | 
						|
  } = props,
 | 
						|
        other = _objectWithoutProperties(props, ['classes', 'className', 'color', 'size', 'style', 'thickness', 'mode', 'value', 'min', 'max']);
 | 
						|
 | 
						|
  const rootProps = {};
 | 
						|
 | 
						|
  const circleStyle = {};
 | 
						|
  if (mode === 'determinate') {
 | 
						|
    const relVal = getRelativeValue(value, min, max) * 100;
 | 
						|
    const circumference = 2 * Math.PI * (SIZE / 2 - 5);
 | 
						|
 | 
						|
    circleStyle.strokeDashoffset = `${Math.round((100 - relVal) / 100 * circumference * 1000) / 1000}px`;
 | 
						|
    circleStyle.strokeDasharray = Math.round(circumference * 1000) / 1000;
 | 
						|
 | 
						|
    rootProps['aria-valuenow'] = value;
 | 
						|
    rootProps['aria-valuemin'] = min;
 | 
						|
    rootProps['aria-valuemax'] = max;
 | 
						|
  }
 | 
						|
 | 
						|
  return React.createElement(
 | 
						|
    'div',
 | 
						|
    _extends({
 | 
						|
      className: classNames(classes.root, color !== 'inherit' && classes[`${color}Color`], className),
 | 
						|
      style: _extends({ width: size, height: size }, style),
 | 
						|
      role: 'progressbar'
 | 
						|
    }, rootProps, other),
 | 
						|
    React.createElement(
 | 
						|
      'svg',
 | 
						|
      {
 | 
						|
        className: classNames({
 | 
						|
          [classes.svgIndeterminate]: mode === 'indeterminate',
 | 
						|
          [classes.svgDeterminate]: mode === 'determinate'
 | 
						|
        }),
 | 
						|
        viewBox: `0 0 ${SIZE} ${SIZE}`
 | 
						|
      },
 | 
						|
      React.createElement('circle', {
 | 
						|
        className: classNames(classes.circle, {
 | 
						|
          [classes.circleIndeterminate]: mode === 'indeterminate'
 | 
						|
        }),
 | 
						|
        style: circleStyle,
 | 
						|
        cx: SIZE / 2,
 | 
						|
        cy: SIZE / 2,
 | 
						|
        r: SIZE / 2 - 5,
 | 
						|
        fill: 'none',
 | 
						|
        strokeWidth: thickness
 | 
						|
      })
 | 
						|
    )
 | 
						|
  );
 | 
						|
}
 | 
						|
 | 
						|
CircularProgress.defaultProps = {
 | 
						|
  color: 'primary',
 | 
						|
  size: 40,
 | 
						|
  thickness: 3.6,
 | 
						|
  mode: 'indeterminate',
 | 
						|
  value: 0,
 | 
						|
  min: 0,
 | 
						|
  max: 100
 | 
						|
};
 | 
						|
 | 
						|
export default withStyles(styles, { name: 'MuiCircularProgress' })(CircularProgress); |