UNPKG

backpack-ui

Version:
133 lines (101 loc) 3.49 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); 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 _objectAssign = require("object-assign"); var _objectAssign2 = _interopRequireDefault(_objectAssign); var _colors = require("../../styles/colors"); var _colors2 = _interopRequireDefault(_colors); var _timing = require("../../styles/timing"); var _timing2 = _interopRequireDefault(_timing); var _color = require("../../utils/color"); var _font = require("../../utils/font"); var _font2 = _interopRequireDefault(_font); var _mixins = require("../../utils/mixins"); var _icon = require("../icon"); var _createQAHook = require("../../utils/createQAHook"); var _createQAHook2 = _interopRequireDefault(_createQAHook); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var styles = { container: { display: "inline-block", fontFamily: (0, _font2.default)("benton"), lineHeight: 1 }, border: { backgroundColor: "" + _colors2.default.borderPrimary, height: "1px", marginBottom: "11px", width: "calc(100% + 64px)" }, link: (0, _objectAssign2.default)({}, (0, _mixins.blueLink)(), { display: "block", fontSize: "11px", fontWeight: 600, letterSpacing: "0.06px", textDecoration: "none", textTransform: "uppercase" }), linkWhite: { color: "rgba(" + (0, _color.rgb)(_colors2.default.bgPrimary) + ", 0.87)", ":hover": { color: _colors2.default.bgPrimary }, ":active": { color: _colors2.default.bgPrimary }, ":focus": (0, _objectAssign2.default)({}, (0, _mixins.outline)(), { color: _colors2.default.bgPrimary }) }, icon: { height: "5px", marginLeft: "8px", marginTop: "-2px", transition: "transform " + _timing2.default.fast + " ease-in-out", width: "5px" }, scoped: { ".CalloutLink > a:hover .Icon": { transform: "translateX(-3px)" }, ".CalloutLink > a:active .Icon": { transform: "translateX(-3px)" }, ".CalloutLink > a:focus .Icon": { transform: "translateX(-3px)" } } }; var CalloutLink = function CalloutLink(_ref) { var children = _ref.children, href = _ref.href, overlay = _ref.overlay, style = _ref.style, qaHook = _ref.qaHook; return _react2.default.createElement( "div", { className: "CalloutLink", style: [styles.container, style] }, _react2.default.createElement(_radium.Style, { rules: styles.scoped }), _react2.default.createElement("div", { style: styles.border }), _react2.default.createElement( "a", { style: [styles.link, overlay && styles.linkWhite], href: href, "data-testid": qaHook ? (0, _createQAHook2.default)(children, "callout", "link") : null }, children, " ", _react2.default.createElement(_icon.ChevronRight, { style: styles.icon }) ) ); }; CalloutLink.propTypes = { children: _propTypes2.default.string.isRequired, href: _propTypes2.default.string.isRequired, overlay: _propTypes2.default.bool, style: _propTypes2.default.objectOf(_propTypes2.default.object), qaHook: _propTypes2.default.bool }; CalloutLink.defaultProps = { overlay: false, qaHook: false }; exports.default = (0, _radium2.default)(CalloutLink);