UNPKG

3.19 kBJavaScriptView Raw
1'use strict';
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6
7var _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; };
8
9var _react = require('react');
10
11var _react2 = _interopRequireDefault(_react);
12
13var _classnames = require('classnames');
14
15var _classnames2 = _interopRequireDefault(_classnames);
16
17var _lodash = require('lodash.tonumber');
18
19var _lodash2 = _interopRequireDefault(_lodash);
20
21var _utils = require('./utils');
22
23function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
24
25function _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; }
26
27var propTypes = {
28 children: _react.PropTypes.node,
29 bar: _react.PropTypes.bool,
30 multi: _react.PropTypes.bool,
31 tag: _react.PropTypes.string,
32 value: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.number]),
33 max: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.number]),
34 animated: _react.PropTypes.bool,
35 striped: _react.PropTypes.bool,
36 color: _react.PropTypes.string,
37 className: _react.PropTypes.string,
38 barClassName: _react.PropTypes.string,
39 cssModule: _react.PropTypes.object
40};
41
42var defaultProps = {
43 tag: 'div',
44 value: 0,
45 max: 100
46};
47
48var Progress = function Progress(props) {
49 var children = props.children,
50 className = props.className,
51 barClassName = props.barClassName,
52 cssModule = props.cssModule,
53 value = props.value,
54 max = props.max,
55 animated = props.animated,
56 striped = props.striped,
57 color = props.color,
58 bar = props.bar,
59 multi = props.multi,
60 Tag = props.tag,
61 attributes = _objectWithoutProperties(props, ['children', 'className', 'barClassName', 'cssModule', 'value', 'max', 'animated', 'striped', 'color', 'bar', 'multi', 'tag']);
62
63 var percent = (0, _lodash2.default)(value) / (0, _lodash2.default)(max) * 100;
64
65 var progressClasses = (0, _utils.mapToCssModules)((0, _classnames2.default)(className, 'progress'), cssModule);
66
67 var progressBarClasses = (0, _utils.mapToCssModules)((0, _classnames2.default)('progress-bar', bar ? className || barClassName : barClassName, animated ? 'progress-bar-animated' : null, color ? 'bg-' + color : null, striped || animated ? 'progress-bar-striped' : null), cssModule);
68
69 var ProgressBar = multi ? children : _react2.default.createElement('div', {
70 className: progressBarClasses,
71 style: { width: percent + '%' },
72 role: 'progressbar',
73 'aria-valuenow': value,
74 'aria-valuemin': '0',
75 'aria-valuemax': max,
76 children: children
77 });
78
79 if (bar) {
80 return ProgressBar;
81 }
82
83 return _react2.default.createElement(Tag, _extends({}, attributes, { className: progressClasses, children: ProgressBar }));
84};
85
86Progress.propTypes = propTypes;
87Progress.defaultProps = defaultProps;
88
89exports.default = Progress;
\No newline at end of file