UNPKG

@mskcc/carbon-react

Version:

Carbon react components for the MSKCC DSM

98 lines (90 loc) 3.75 kB
/** * MSKCC 2021, 2024 */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var _rollupPluginBabelHelpers = require('../../_virtual/_rollupPluginBabelHelpers.js'); var PropTypes = require('prop-types'); var React = require('react'); var cx = require('classnames'); var Link = require('../Link/Link.js'); var MskIcon = require('../Icon/MskIcon.js'); var usePrefix = require('../../internal/usePrefix.js'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes); var React__default = /*#__PURE__*/_interopDefaultLegacy(React); var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx); const BreadcrumbItem = /*#__PURE__*/React__default["default"].forwardRef(function BreadcrumbItem(_ref, ref) { let { 'aria-current': ariaCurrent, children, className: customClassName, href, isCurrentPage, ...rest } = _ref; const prefix = usePrefix.usePrefix(); const className = cx__default["default"]({ [`${prefix}--breadcrumb-item`]: true, // We set the current class only if `isCurrentPage` is passed in and we do // not have an `aria-current="page"` set for the breadcrumb item [`${prefix}--breadcrumb-item--current`]: isCurrentPage && ariaCurrent !== 'page', [customClassName]: !!customClassName }); if (children.type && children.type.displayName !== undefined && children.type.displayName.includes('OverflowMenu')) { const horizontalOverflowIcon = /*#__PURE__*/React__default["default"].createElement(MskIcon.Icon, { icon: "more_horiz", className: `${prefix}--overflow-menu__icon` }); return /*#__PURE__*/React__default["default"].createElement("li", _rollupPluginBabelHelpers["extends"]({ className: className }, rest), /*#__PURE__*/React__default["default"].cloneElement(children, { menuOptionsClass: `${prefix}--breadcrumb-menu-options`, menuOffset: { top: 10, left: 59 }, renderIcon: () => horizontalOverflowIcon })); } if (typeof children === 'string') { return /*#__PURE__*/React__default["default"].createElement("li", _rollupPluginBabelHelpers["extends"]({ className: className, ref: ref }, rest), href ? /*#__PURE__*/React__default["default"].createElement(Link["default"], { href: href, "aria-current": ariaCurrent }, children) : /*#__PURE__*/React__default["default"].createElement("span", { className: `${prefix}--link` }, children)); } return /*#__PURE__*/React__default["default"].createElement("li", _rollupPluginBabelHelpers["extends"]({ className: className, ref: ref }, rest), /*#__PURE__*/React__default["default"].cloneElement(children, { 'aria-current': ariaCurrent, className: cx__default["default"](`${prefix}--link`, children.props.className) })); }); BreadcrumbItem.displayName = 'BreadcrumbItem'; BreadcrumbItem.propTypes = { 'aria-current': PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].bool]), /** * Pass in content that will be inside of the BreadcrumbItem */ children: PropTypes__default["default"].node, /** * Specify an optional className to be applied to the container node */ className: PropTypes__default["default"].string, /** * Optional string representing the link location for the BreadcrumbItem */ href: PropTypes__default["default"].string, /** * Provide if this breadcrumb item represents the current page */ isCurrentPage: PropTypes__default["default"].bool }; var BreadcrumbItem$1 = BreadcrumbItem; exports["default"] = BreadcrumbItem$1;