UNPKG

@patternfly/react-core

Version:

This library provides a set of common React components for use with the PatternFly reference implementation.

22 lines 1.36 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.NavGroup = void 0; const tslib_1 = require("tslib"); const React = tslib_1.__importStar(require("react")); const nav_1 = tslib_1.__importDefault(require("@patternfly/react-styles/css/components/Nav/nav")); const react_styles_1 = require("@patternfly/react-styles"); const util_1 = require("../../helpers/util"); const NavGroup = (_a) => { var { title, children = null, className = '', id = util_1.getUniqueId() } = _a, props = tslib_1.__rest(_a, ["title", "children", "className", "id"]); if (!title && !props['aria-label']) { // eslint-disable-next-line no-console console.warn("For accessibility reasons an aria-label should be specified on nav groups if a title isn't"); } const labelledBy = title ? id : undefined; return (React.createElement("section", Object.assign({ className: react_styles_1.css(nav_1.default.navSection, className), "aria-labelledby": labelledBy }, props), title && (React.createElement("h2", { className: react_styles_1.css(nav_1.default.navSectionTitle), id: id }, title)), React.createElement("ul", { className: react_styles_1.css(nav_1.default.navList, className) }, children))); }; exports.NavGroup = NavGroup; exports.NavGroup.displayName = 'NavGroup'; //# sourceMappingURL=NavGroup.js.map