UNPKG

@primer/react

Version:

An implementation of GitHub's Primer Design System using React

63 lines (57 loc) 2.42 kB
import clsx from 'clsx'; import React from 'react'; import styled from 'styled-components'; import Box from '../Box/Box.js'; import { get } from '../constants.js'; import sx from '../sx.js'; const SELECTED_CLASS = 'selected'; const Wrapper = styled.li.withConfig({ displayName: "Breadcrumbs__Wrapper", componentId: "sc-9m4wsf-0" })(["display:inline-block;white-space:nowrap;list-style:none;&::after{font-size:", ";content:'';display:inline-block;height:0.8em;margin:0 0.5em;border-right:0.1em solid;border-color:", ";transform:rotate(15deg) translateY(0.0625em);}&:first-child{margin-left:0;}&:last-child{&::after{content:none;}}"], get('fontSizes.1'), get('colors.fg.muted')); const BreadcrumbsBase = styled.nav.withConfig({ displayName: "Breadcrumbs__BreadcrumbsBase", componentId: "sc-9m4wsf-1" })(["display:flex;justify-content:space-between;", ";"], sx); function Breadcrumbs({ className, children, sx: sxProp }) { const wrappedChildren = React.Children.map(children, child => /*#__PURE__*/React.createElement(Wrapper, null, child)); return /*#__PURE__*/React.createElement(BreadcrumbsBase, { className: className, "aria-label": "Breadcrumbs", sx: sxProp }, /*#__PURE__*/React.createElement(Box, { as: "ol", my: 0, pl: 0 }, wrappedChildren)); } Breadcrumbs.displayName = "Breadcrumbs"; const BreadcrumbsItem = styled.a.attrs(props => ({ className: clsx(props.selected && SELECTED_CLASS, props.className), 'aria-current': props.selected ? 'page' : null })).withConfig({ displayName: "Breadcrumbs__BreadcrumbsItem", componentId: "sc-9m4wsf-2" })(["color:", ";display:inline-block;font-size:", ";text-decoration:none;&:hover,&:focus{text-decoration:underline;}&.selected{color:", ";pointer-events:none;}&.selected:focus{text-decoration:none;}", ";"], get('colors.accent.fg'), get('fontSizes.1'), get('colors.fg.default'), sx); Breadcrumbs.displayName = 'Breadcrumbs'; BreadcrumbsItem.displayName = 'Breadcrumbs.Item'; var Breadcrumbs$1 = Object.assign(Breadcrumbs, { Item: BreadcrumbsItem }); /** * @deprecated Use the `Breadcrumbs` component instead (i.e. `<Breadcrumb>` → `<Breadcrumbs>`) */ const Breadcrumb = Object.assign(Breadcrumbs, { Item: BreadcrumbsItem }); /** * @deprecated Use the `BreadcrumbsProps` type instead */ /** * @deprecated Use the `BreadcrumbsItemProps` type instead */ export { Breadcrumb, Breadcrumbs$1 as default };