UNPKG

3.88 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 _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
13
14var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/inheritsLoose"));
15
16var _react = _interopRequireDefault(require("react"));
17
18var _propTypes = _interopRequireDefault(require("prop-types"));
19
20var _classnames = _interopRequireDefault(require("classnames"));
21
22var _utils = require("./utils");
23
24var propTypes = {
25 active: _propTypes.default.bool,
26 'aria-label': _propTypes.default.string,
27 block: _propTypes.default.bool,
28 color: _propTypes.default.string,
29 disabled: _propTypes.default.bool,
30 outline: _propTypes.default.bool,
31 tag: _utils.tagPropType,
32 innerRef: _propTypes.default.oneOfType([_propTypes.default.object, _propTypes.default.func, _propTypes.default.string]),
33 onClick: _propTypes.default.func,
34 size: _propTypes.default.string,
35 children: _propTypes.default.node,
36 className: _propTypes.default.string,
37 cssModule: _propTypes.default.object,
38 close: _propTypes.default.bool
39};
40var defaultProps = {
41 color: 'secondary',
42 tag: 'button'
43};
44
45var Button = /*#__PURE__*/function (_React$Component) {
46 (0, _inheritsLoose2.default)(Button, _React$Component);
47
48 function Button(props) {
49 var _this;
50
51 _this = _React$Component.call(this, props) || this;
52 _this.onClick = _this.onClick.bind((0, _assertThisInitialized2.default)(_this));
53 return _this;
54 }
55
56 var _proto = Button.prototype;
57
58 _proto.onClick = function onClick(e) {
59 if (this.props.disabled) {
60 e.preventDefault();
61 return;
62 }
63
64 if (this.props.onClick) {
65 return this.props.onClick(e);
66 }
67 };
68
69 _proto.render = function render() {
70 var _this$props = this.props,
71 active = _this$props.active,
72 ariaLabel = _this$props['aria-label'],
73 block = _this$props.block,
74 className = _this$props.className,
75 close = _this$props.close,
76 cssModule = _this$props.cssModule,
77 color = _this$props.color,
78 outline = _this$props.outline,
79 size = _this$props.size,
80 Tag = _this$props.tag,
81 innerRef = _this$props.innerRef,
82 attributes = (0, _objectWithoutPropertiesLoose2.default)(_this$props, ["active", "aria-label", "block", "className", "close", "cssModule", "color", "outline", "size", "tag", "innerRef"]);
83
84 if (close && typeof attributes.children === 'undefined') {
85 attributes.children = /*#__PURE__*/_react.default.createElement("span", {
86 "aria-hidden": true
87 }, "\xD7");
88 }
89
90 var btnOutlineColor = "btn" + (outline ? '-outline' : '') + "-" + color;
91 var classes = (0, _utils.mapToCssModules)((0, _classnames.default)(className, {
92 close: close
93 }, close || 'btn', close || btnOutlineColor, size ? "btn-" + size : false, block ? 'btn-block' : false, {
94 active: active,
95 disabled: this.props.disabled
96 }), cssModule);
97
98 if (attributes.href && Tag === 'button') {
99 Tag = 'a';
100 }
101
102 var defaultAriaLabel = close ? 'Close' : null;
103 return /*#__PURE__*/_react.default.createElement(Tag, (0, _extends2.default)({
104 type: Tag === 'button' && attributes.onClick ? 'button' : undefined
105 }, attributes, {
106 className: classes,
107 ref: innerRef,
108 onClick: this.onClick,
109 "aria-label": ariaLabel || defaultAriaLabel
110 }));
111 };
112
113 return Button;
114}(_react.default.Component);
115
116Button.propTypes = propTypes;
117Button.defaultProps = defaultProps;
118var _default = Button;
119exports.default = _default;
\No newline at end of file