react-widgets-up
Version:
An à la carte set of polished, extensible, and accessible inputs built for React
29 lines • 1.2 kB
JavaScript
const _excluded = ["className", "disabled", "label", "icon", "busy", "children", "spinner"];
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; }
import cn from 'classnames';
import * as React from 'react';
import { Spinner } from './Icon';
function Button(_ref) {
let {
className,
disabled,
label,
icon,
busy,
children,
spinner = Spinner
} = _ref,
props = _objectWithoutPropertiesLoose(_ref, _excluded);
return /*#__PURE__*/React.createElement("button", _extends({
tabIndex: -1
}, props, {
title: label,
type: "button",
disabled: disabled,
"aria-label": label,
"aria-disabled": disabled,
className: cn(className, 'rw-btn')
}), busy ? spinner : icon, children);
}
export default Button;