UNPKG

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