backpack-ui
Version:
Lonely Planet's Components
133 lines (101 loc) • 3.49 kB
JavaScript
"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);