@primer/components
Version:
Primer react components
49 lines (45 loc) • 2.89 kB
JavaScript
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); }
import classnames from 'classnames'; // eslint-disable-next-line import/no-namespace
import React from 'react';
import styled from 'styled-components';
import { COMMON, get } from './constants';
import sx from './sx';
const ITEM_CLASS = 'UnderlineNav-item';
const SELECTED_CLASS = 'selected';
const UnderlineNavBase = styled.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;}", ";", ";"], get('colors.border.muted'), get('space.3'), COMMON, sx);
function UnderlineNav({
actions,
className,
align,
children,
full,
label,
theme,
...rest
}) {
const classes = classnames(className, 'UnderlineNav', align && `UnderlineNav--${align}`, full && 'UnderlineNav--full');
return /*#__PURE__*/React.createElement(UnderlineNavBase, _extends({
className: classes,
"aria-label": label,
theme: theme
}, rest), /*#__PURE__*/React.createElement("div", {
className: "UnderlineNav-body"
}, children), actions && /*#__PURE__*/React.createElement("div", {
className: "UnderlineNav-actions"
}, actions));
}
UnderlineNav.displayName = "UnderlineNav";
const UnderlineNavLink = styled.a.attrs(props => ({
activeClassName: typeof props.to === 'string' ? 'selected' : '',
className: classnames(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:", ";}}", ";", ";"], get('space.3'), get('space.2'), get('space.3'), get('fontSizes.1'), get('lineHeights.default'), get('colors.fg.default'), get('colors.fg.default'), get('colors.neutral.muted'), get('colors.fg.muted'), get('colors.fg.default'), get('colors.primer.border.active'), get('colors.fg.default'), COMMON, sx);
UnderlineNavLink.displayName = 'UnderlineNav.Link';
export default Object.assign(UnderlineNav, {
Link: UnderlineNavLink
});