UNPKG

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