UNPKG

@bigbinary/neetoui

Version:

neetoUI drives the experience at all neeto products

142 lines (138 loc) 6 kB
'use strict'; var _extends = require('@babel/runtime/helpers/extends'); var _defineProperty = require('@babel/runtime/helpers/defineProperty'); var _objectWithoutProperties = require('@babel/runtime/helpers/objectWithoutProperties'); var React = require('react'); var classnames = require('classnames'); var reactRouterDom = require('react-router-dom'); var Spinner = require('./Spinner.js'); var Tooltip = require('./Tooltip.js'); require('@babel/runtime/helpers/slicedToArray'); require('@tippyjs/react'); require('tippy.js'); var _excluded = ["icon", "iconPosition", "iconSize", "label", "loading", "onClick", "to", "type", "style", "fullWidth", "className", "disabled", "size", "href", "tooltipProps", "children"]; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } var BUTTON_STYLES = { primary: "primary", secondary: "secondary", tertiary: "tertiary", danger: "danger", danger_text: "danger-text", text: "text", link: "link" }; var SIZES = { small: "small", medium: "medium", large: "large" }; var ICON_POSITIONS = { left: "left", right: "right" }; var BUTTON_TYPES = { button: "button", reset: "reset", submit: "submit" }; var Button = /*#__PURE__*/React.forwardRef(function (_ref, ref) { var _ref$icon = _ref.icon, icon = _ref$icon === void 0 ? null : _ref$icon, _ref$iconPosition = _ref.iconPosition, iconPosition = _ref$iconPosition === void 0 ? ICON_POSITIONS.right : _ref$iconPosition, _ref$iconSize = _ref.iconSize, iconSize = _ref$iconSize === void 0 ? 16 : _ref$iconSize, _ref$label = _ref.label, label = _ref$label === void 0 ? "" : _ref$label, _ref$loading = _ref.loading, loading = _ref$loading === void 0 ? false : _ref$loading, _ref$onClick = _ref.onClick, onClick = _ref$onClick === void 0 ? function () {} : _ref$onClick, _ref$to = _ref.to, to = _ref$to === void 0 ? "" : _ref$to, _ref$type = _ref.type, type = _ref$type === void 0 ? BUTTON_TYPES.button : _ref$type, _ref$style = _ref.style, style = _ref$style === void 0 ? BUTTON_STYLES.primary : _ref$style, _ref$fullWidth = _ref.fullWidth, fullWidth = _ref$fullWidth === void 0 ? false : _ref$fullWidth, _ref$className = _ref.className, className = _ref$className === void 0 ? "" : _ref$className, _ref$disabled = _ref.disabled, disabled = _ref$disabled === void 0 ? false : _ref$disabled, _ref$size = _ref.size, size = _ref$size === void 0 ? SIZES.medium : _ref$size, _ref$href = _ref.href, href = _ref$href === void 0 ? "" : _ref$href, _ref$tooltipProps = _ref.tooltipProps, tooltipProps = _ref$tooltipProps === void 0 ? null : _ref$tooltipProps, children = _ref.children, otherProps = _objectWithoutProperties(_ref, _excluded); var Parent = "button"; var elementSpecificProps = { type: type }; var renderLabel = label || children; if (!disabled) { if (to) { Parent = reactRouterDom.Link; elementSpecificProps = { to: to }; } else if (href) { Parent = "a"; elementSpecificProps = { href: href }; } } var handleClick = function handleClick(e) { if (loading || disabled) return; onClick(e); }; var Icon = typeof icon === "string" ? function () { return /*#__PURE__*/React.createElement("i", { className: classnames("neeto-ui-btn__icon", [icon]), "data-testid": "class-icon" }); } : icon || React.Fragment; return /*#__PURE__*/React.createElement(Tooltip, _extends({ disabled: !tooltipProps }, tooltipProps), /*#__PURE__*/React.createElement(Parent, _extends({ className: classnames("neeto-ui-btn", [className], { "neeto-ui-btn--style-primary": style === BUTTON_STYLES.primary, "neeto-ui-btn--style-secondary": style === BUTTON_STYLES.secondary, "neeto-ui-btn--style-tertiary": style === BUTTON_STYLES.tertiary, "neeto-ui-btn--style-danger": style === BUTTON_STYLES.danger, "neeto-ui-btn--style-danger-text": style === BUTTON_STYLES.danger_text, "neeto-ui-btn--style-text": style === BUTTON_STYLES.text, "neeto-ui-btn--style-link": style === BUTTON_STYLES.link, "neeto-ui-btn--size-medium": size === SIZES.medium, "neeto-ui-btn--size-large": size === SIZES.large, "neeto-ui-btn--width-full": fullWidth, "neeto-ui-btn--icon-left": iconPosition === ICON_POSITIONS.left, "neeto-ui-btn--icon-only": !renderLabel, "neeto-ui-btn--loading": loading, disabled: disabled }), onClick: handleClick }, _objectSpread(_objectSpread({ disabled: disabled, ref: ref }, elementSpecificProps), otherProps)), renderLabel && /*#__PURE__*/React.createElement("span", { className: "neeto-ui-btn__label" }, renderLabel), icon && /*#__PURE__*/React.createElement(Icon, { "aria-hidden": "true", className: "neeto-ui-btn__icon", size: iconSize }), loading && /*#__PURE__*/React.createElement("span", { className: "neeto-ui-btn__spinner" }, /*#__PURE__*/React.createElement(Spinner, { "aria-hidden": "true", size: "small" })))); }); Button.displayName = "Button"; module.exports = Button; //# sourceMappingURL=Button.js.map