@kiwicom/orbit-components
Version:
Orbit-components is a React component library which provides developers with the easiest possible way of building Kiwi.com’s products.
57 lines (56 loc) • 2.2 kB
JavaScript
"use strict";
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
exports.__esModule = true;
exports.default = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var React = _interopRequireWildcard(require("react"));
var _consts = require("../../primitives/ButtonPrimitive/common/consts");
var _getBoxShadow = _interopRequireDefault(require("./helpers/getBoxShadow"));
var _getPadding = _interopRequireDefault(require("../../primitives/ButtonPrimitive/common/getPadding"));
var _useTheme = _interopRequireDefault(require("../../hooks/useTheme"));
var _ButtonPrimitive = _interopRequireDefault(require("../../primitives/ButtonPrimitive"));
var _consts2 = require("./consts");
const Button = ({
selected,
iconLeft,
iconRight,
disabled,
height = _consts2.BUTTON_SIZE,
width = _consts2.BUTTON_SIZE,
children,
...props
}) => {
const theme = (0, _useTheme.default)();
const onlyIcon = Boolean(iconLeft && !children);
const padding = (0, _getPadding.default)(onlyIcon, iconRight, iconLeft, "small", theme);
const wrappedBoxShadow = state => (0, _getBoxShadow.default)({
state,
disabled,
theme,
selected
});
const boxShadow = {
boxShadow: wrappedBoxShadow(_consts.BUTTON_STATES.DEFAULT),
boxShadowHover: wrappedBoxShadow(_consts.BUTTON_STATES.HOVER),
boxShadowActive: wrappedBoxShadow(_consts.BUTTON_STATES.ACTIVE),
boxShadowFocus: wrappedBoxShadow(_consts.BUTTON_STATES.FOCUS)
};
return /*#__PURE__*/React.createElement(_ButtonPrimitive.default, (0, _extends2.default)({
circled: true,
contentAlign: "center",
icons: {
width: _consts2.ICON_SIZE,
height: _consts2.ICON_SIZE,
foreground: selected ? theme.orbit.paletteWhite : theme.orbit.paletteInkDark
},
background: selected ? theme.orbit.paletteBlueNormal : theme.orbit.paletteCloudNormal,
iconLeft: iconLeft,
height: height,
width: width,
disabled: disabled,
padding: padding
}, props, boxShadow));
};
var _default = Button;
exports.default = _default;