UNPKG

3.85 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 =
46/*#__PURE__*/
47function (_React$Component) {
48 (0, _inheritsLoose2.default)(Button, _React$Component);
49
50 function Button(props) {
51 var _this;
52
53 _this = _React$Component.call(this, props) || this;
54 _this.onClick = _this.onClick.bind((0, _assertThisInitialized2.default)(_this));
55 return _this;
56 }
57
58 var _proto = Button.prototype;
59
60 _proto.onClick = function onClick(e) {
61 if (this.props.disabled) {
62 e.preventDefault();
63 return;
64 }
65
66 if (this.props.onClick) {
67 this.props.onClick(e);
68 }
69 };
70
71 _proto.render = function render() {
72 var _this$props = this.props,
73 active = _this$props.active,
74 ariaLabel = _this$props['aria-label'],
75 block = _this$props.block,
76 className = _this$props.className,
77 close = _this$props.close,
78 cssModule = _this$props.cssModule,
79 color = _this$props.color,
80 outline = _this$props.outline,
81 size = _this$props.size,
82 Tag = _this$props.tag,
83 innerRef = _this$props.innerRef,
84 attributes = (0, _objectWithoutPropertiesLoose2.default)(_this$props, ["active", "aria-label", "block", "className", "close", "cssModule", "color", "outline", "size", "tag", "innerRef"]);
85
86 if (close && typeof attributes.children === 'undefined') {
87 attributes.children = _react.default.createElement("span", {
88 "aria-hidden": true
89 }, "\xD7");
90 }
91
92 var btnOutlineColor = "btn" + (outline ? '-outline' : '') + "-" + color;
93 var classes = (0, _utils.mapToCssModules)((0, _classnames.default)(className, {
94 close: close
95 }, close || 'btn', close || btnOutlineColor, size ? "btn-" + size : false, block ? 'btn-block' : false, {
96 active: active,
97 disabled: this.props.disabled
98 }), cssModule);
99
100 if (attributes.href && Tag === 'button') {
101 Tag = 'a';
102 }
103
104 var defaultAriaLabel = close ? 'Close' : null;
105 return _react.default.createElement(Tag, (0, _extends2.default)({
106 type: Tag === 'button' && attributes.onClick ? 'button' : undefined
107 }, attributes, {
108 className: classes,
109 ref: innerRef,
110 onClick: this.onClick,
111 "aria-label": ariaLabel || defaultAriaLabel
112 }));
113 };
114
115 return Button;
116}(_react.default.Component);
117
118Button.propTypes = propTypes;
119Button.defaultProps = defaultProps;
120var _default = Button;
121exports.default = _default;
\No newline at end of file