UNPKG

@primer/components

Version:
68 lines (52 loc) 3.56 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _classnames = _interopRequireDefault(require("classnames")); var _react = _interopRequireDefault(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _constants = require("./constants"); var _sx = _interopRequireDefault(require("./sx")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } const ITEM_CLASS = 'UnderlineNav-item'; const SELECTED_CLASS = 'selected'; const UnderlineNavBase = _styledComponents.default.nav.withConfig({ displayName: "UnderlineNav__UnderlineNavBase", componentId: "zrnxqt-0" })(["display:flex;justify-content:space-between;border-bottom:1px solid ", ";&.UnderlineNav--right{justify-content:flex-end;.UnderlineNav-item{margin-right:0;margin-left:", ";}.UnderlineNav-actions{flex:1 1 auto;}}&.UnderlineNav--full{display:block;}.UnderlineNav-body{display:flex;margin-bottom:-1px;}.UnderlineNav-actions{align-self:center;}", ";", ";"], (0, _constants.get)('colors.border.muted'), (0, _constants.get)('space.3'), _constants.COMMON, _sx.default); function UnderlineNav({ actions, className, align, children, full, label, theme, ...rest }) { const classes = (0, _classnames.default)(className, 'UnderlineNav', align && `UnderlineNav--${align}`, full && 'UnderlineNav--full'); return /*#__PURE__*/_react.default.createElement(UnderlineNavBase, _extends({ className: classes, "aria-label": label, theme: theme }, rest), /*#__PURE__*/_react.default.createElement("div", { className: "UnderlineNav-body" }, children), actions && /*#__PURE__*/_react.default.createElement("div", { className: "UnderlineNav-actions" }, actions)); } UnderlineNav.displayName = "UnderlineNav"; const UnderlineNavLink = _styledComponents.default.a.attrs(props => ({ activeClassName: typeof props.to === 'string' ? 'selected' : '', className: (0, _classnames.default)(ITEM_CLASS, props.selected && SELECTED_CLASS, props.className) })).withConfig({ displayName: "UnderlineNav__UnderlineNavLink", componentId: "zrnxqt-1" })(["padding:", " ", ";margin-right:", ";font-size:", ";line-height:", ";color:", ";text-align:center;border-bottom:2px solid transparent;text-decoration:none;&:hover,&:focus{color:", ";text-decoration:none;border-bottom-color:", ";transition:0.2s ease;.UnderlineNav-octicon{color:", ";}}&.selected{color:", ";border-bottom-color:", ";.UnderlineNav-octicon{color:", ";}}", ";", ";"], (0, _constants.get)('space.3'), (0, _constants.get)('space.2'), (0, _constants.get)('space.3'), (0, _constants.get)('fontSizes.1'), (0, _constants.get)('lineHeights.default'), (0, _constants.get)('colors.fg.default'), (0, _constants.get)('colors.fg.default'), (0, _constants.get)('colors.neutral.muted'), (0, _constants.get)('colors.fg.muted'), (0, _constants.get)('colors.fg.default'), (0, _constants.get)('colors.primer.border.active'), (0, _constants.get)('colors.fg.default'), _constants.COMMON, _sx.default); UnderlineNavLink.displayName = 'UnderlineNav.Link'; var _default = Object.assign(UnderlineNav, { Link: UnderlineNavLink }); exports.default = _default;