UNPKG

3.9 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
4
5exports.__esModule = true;
6exports.default = void 0;
7
8var _values = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/values"));
9
10var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/objectWithoutPropertiesLoose"));
11
12var _extends3 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/extends"));
13
14var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/inheritsLoose"));
15
16var _classnames = _interopRequireDefault(require("classnames"));
17
18var _react = _interopRequireDefault(require("react"));
19
20var _propTypes = _interopRequireDefault(require("prop-types"));
21
22var _elementType = _interopRequireDefault(require("prop-types-extra/lib/elementType"));
23
24var _bootstrapUtils = require("./utils/bootstrapUtils");
25
26var _StyleConfig = require("./utils/StyleConfig");
27
28var _SafeAnchor = _interopRequireDefault(require("./SafeAnchor"));
29
30var propTypes = {
31 active: _propTypes.default.bool,
32 disabled: _propTypes.default.bool,
33 block: _propTypes.default.bool,
34 onClick: _propTypes.default.func,
35 componentClass: _elementType.default,
36 href: _propTypes.default.string,
37
38 /**
39 * Defines HTML button type attribute
40 * @defaultValue 'button'
41 */
42 type: _propTypes.default.oneOf(['button', 'reset', 'submit'])
43};
44var defaultProps = {
45 active: false,
46 block: false,
47 disabled: false
48};
49
50var Button =
51/*#__PURE__*/
52function (_React$Component) {
53 (0, _inheritsLoose2.default)(Button, _React$Component);
54
55 function Button() {
56 return _React$Component.apply(this, arguments) || this;
57 }
58
59 var _proto = Button.prototype;
60
61 _proto.renderAnchor = function renderAnchor(elementProps, className) {
62 return _react.default.createElement(_SafeAnchor.default, (0, _extends3.default)({}, elementProps, {
63 className: (0, _classnames.default)(className, elementProps.disabled && 'disabled')
64 }));
65 };
66
67 _proto.renderButton = function renderButton(_ref, className) {
68 var componentClass = _ref.componentClass,
69 elementProps = (0, _objectWithoutPropertiesLoose2.default)(_ref, ["componentClass"]);
70 var Component = componentClass || 'button';
71 return _react.default.createElement(Component, (0, _extends3.default)({}, elementProps, {
72 type: elementProps.type || 'button',
73 className: className
74 }));
75 };
76
77 _proto.render = function render() {
78 var _extends2;
79
80 var _this$props = this.props,
81 active = _this$props.active,
82 block = _this$props.block,
83 className = _this$props.className,
84 props = (0, _objectWithoutPropertiesLoose2.default)(_this$props, ["active", "block", "className"]);
85
86 var _splitBsProps = (0, _bootstrapUtils.splitBsProps)(props),
87 bsProps = _splitBsProps[0],
88 elementProps = _splitBsProps[1];
89
90 var classes = (0, _extends3.default)({}, (0, _bootstrapUtils.getClassSet)(bsProps), (_extends2 = {
91 active: active
92 }, _extends2[(0, _bootstrapUtils.prefix)(bsProps, 'block')] = block, _extends2));
93 var fullClassName = (0, _classnames.default)(className, classes);
94
95 if (elementProps.href) {
96 return this.renderAnchor(elementProps, fullClassName);
97 }
98
99 return this.renderButton(elementProps, fullClassName);
100 };
101
102 return Button;
103}(_react.default.Component);
104
105Button.propTypes = propTypes;
106Button.defaultProps = defaultProps;
107
108var _default = (0, _bootstrapUtils.bsClass)('btn', (0, _bootstrapUtils.bsSizes)([_StyleConfig.Size.LARGE, _StyleConfig.Size.SMALL, _StyleConfig.Size.XSMALL], (0, _bootstrapUtils.bsStyles)((0, _values.default)(_StyleConfig.State).concat([_StyleConfig.Style.DEFAULT, _StyleConfig.Style.PRIMARY, _StyleConfig.Style.LINK]), _StyleConfig.Style.DEFAULT, Button)));
109
110exports.default = _default;
111module.exports = exports["default"];
\No newline at end of file