@primer/components
Version:
Primer react components
87 lines (66 loc) • 3.32 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.Breadcrumb = exports.default = void 0;
var _classnames = _interopRequireDefault(require("classnames"));
var _react = _interopRequireDefault(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _Box = _interopRequireDefault(require("./Box"));
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 SELECTED_CLASS = 'selected';
const Wrapper = _styledComponents.default.li.withConfig({
displayName: "Breadcrumbs__Wrapper",
componentId: "hwwoo0-0"
})(["display:inline-block;white-space:nowrap;list-style:none;&::after{padding-right:0.5em;padding-left:0.5em;color:", ";font-size:", ";content:'/';}&:first-child{margin-left:0;}&:last-child{&::after{content:none;}}"], (0, _constants.get)('colors.fg.muted'), (0, _constants.get)('fontSizes.1'));
const BreadcrumbsBase = _styledComponents.default.nav.withConfig({
displayName: "Breadcrumbs__BreadcrumbsBase",
componentId: "hwwoo0-1"
})(["display:flex;justify-content:space-between;", ";", ";", ";"], _constants.COMMON, _constants.FLEX, _sx.default);
function Breadcrumbs({
className,
children,
theme,
...rest
}) {
const wrappedChildren = _react.default.Children.map(children, child => /*#__PURE__*/_react.default.createElement(Wrapper, {
theme: theme
}, child));
return /*#__PURE__*/_react.default.createElement(BreadcrumbsBase, _extends({
className: className,
"aria-label": "Breadcrumbs",
theme: theme
}, rest), /*#__PURE__*/_react.default.createElement(_Box.default, {
as: "ol",
my: 0,
pl: 0
}, wrappedChildren));
}
Breadcrumbs.displayName = "Breadcrumbs";
const BreadcrumbsItem = _styledComponents.default.a.attrs(props => ({
activeClassName: typeof props.to === 'string' ? 'selected' : '',
className: (0, _classnames.default)(props.selected && SELECTED_CLASS, props.className),
'aria-current': props.selected ? 'page' : null
})).withConfig({
displayName: "Breadcrumbs__BreadcrumbsItem",
componentId: "hwwoo0-2"
})(["color:", ";display:inline-block;font-size:", ";text-decoration:none;&:hover{text-decoration:underline;}&.selected{color:", ";pointer-events:none;}", " ", ";"], (0, _constants.get)('colors.accent.fg'), (0, _constants.get)('fontSizes.1'), (0, _constants.get)('colors.fg.default'), _constants.COMMON, _sx.default);
Breadcrumbs.displayName = 'Breadcrumbs';
BreadcrumbsItem.displayName = 'Breadcrumbs.Item';
var _default = Object.assign(Breadcrumbs, {
Item: BreadcrumbsItem
});
/**
* @deprecated Use the `Breadcrumbs` component instead (i.e. `<Breadcrumb>` → `<Breadcrumbs>`)
*/
exports.default = _default;
const Breadcrumb = Object.assign(Breadcrumbs, {
Item: BreadcrumbsItem
});
/**
* @deprecated Use the `BreadcrumbsProps` type instead
*/
exports.Breadcrumb = Breadcrumb;