UNPKG

backpack-ui

Version:
140 lines (105 loc) 3.77 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var _extends2 = require("babel-runtime/helpers/extends"); var _extends3 = _interopRequireDefault(_extends2); var _react = require("react"); var _react2 = _interopRequireDefault(_react); var _propTypes = require("prop-types"); var _propTypes2 = _interopRequireDefault(_propTypes); var _radium = require("radium"); var _radium2 = _interopRequireDefault(_radium); var _colors = require("../../styles/colors"); var _colors2 = _interopRequireDefault(_colors); var _timing = require("../../styles/timing"); var _timing2 = _interopRequireDefault(_timing); var _typography = require("../../styles/typography"); var _color = require("../../utils/color"); var _mixins = require("../../utils/mixins"); var _propTypes3 = require("../../utils/propTypes"); var _propTypes4 = _interopRequireDefault(_propTypes3); var _typography2 = require("../../utils/typography"); var _createQAHook = require("../../utils/createQAHook"); var _createQAHook2 = _interopRequireDefault(_createQAHook); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var fontSize = _typography.fontSizeBodySmall; var hoverStyles = { default: { backgroundColor: (0, _color.rgba)(_colors2.default.borderPrimary, 0.15) }, selected: { backgroundColor: _colors2.default.textPrimary, borderColor: _colors2.default.borderPrimary } }; var styles = { default: (0, _extends3.default)({}, { backgroundColor: _colors2.default.bgPrimary, borderColor: _colors2.default.borderLight, borderStyle: "solid", borderWidth: 1 / fontSize + "em", borderRadius: 32 / fontSize + "em", color: _colors2.default.textLight, fontSize: "20px", display: "inline-block", letterSpacing: 0, maxHeight: "30px", padding: 8 / fontSize + "em " + 20 / fontSize + "em", textDecoration: "none", textOverflow: "ellipsis", transition: "background-color " + _timing2.default.fast, whiteSpace: "nowrap" }, (0, _typography2.textBodySmall)(), { lineHeight: "15px", fontWeight: _typography.fontWeightRegular }), defaultHover: { ":hover": hoverStyles.default, ":active": hoverStyles.default, ":focus": (0, _extends3.default)({}, hoverStyles.default, (0, _mixins.outline)()) }, selected: { backgroundColor: hoverStyles.selected.backgroundColor, borderColor: hoverStyles.selected.backgroundColor, color: _colors2.default.textOverlay, ":hover": hoverStyles.selected, ":active": hoverStyles.selected, ":focus": (0, _extends3.default)({}, hoverStyles.selected, (0, _mixins.outline)()) } }; function Tag(_ref) { var children = _ref.children, href = _ref.href, onClick = _ref.onClick, selected = _ref.selected, style = _ref.style, qaHook = _ref.qaHook; var Element = "span"; if (href) Element = "a"; if (onClick) Element = "button"; return _react2.default.createElement( Element, { className: "Tag", style: [styles.default, (href || onClick) && styles.defaultHover, href || onClick ? { cursor: "pointer" } : { cursor: "default" }, selected && styles.selected, style], href: href, onClick: onClick, "data-testid": qaHook ? (0, _createQAHook2.default)(children, "tag", Element === "a" ? "link" : Element) : null }, children ); } Tag.propTypes = { children: _propTypes2.default.string.isRequired, href: _propTypes2.default.string, onClick: _propTypes2.default.func, selected: _propTypes2.default.bool, style: _propTypes4.default.style, qaHook: _propTypes2.default.bool }; Tag.defaultProps = { selected: false, qaHook: false }; exports.default = (0, _radium2.default)(Tag);