UNPKG

@wordpress/components

Version:
61 lines (46 loc) 1.58 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = NavigationItemBase; var _element = require("@wordpress/element"); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _classnames = _interopRequireDefault(require("classnames")); var _context = require("../context"); var _useNavigationTreeItem = require("./use-navigation-tree-item"); var _navigationStyles = require("../styles/navigation-styles"); /** * External dependencies */ /** * WordPress dependencies */ /** * Internal dependencies */ let uniqueId = 0; function NavigationItemBase(props) { var _navigationTree$getIt; // Also avoid to pass the `title` and `href` props to the ItemBaseUI styled component. const { children, className, title, href, ...restProps } = props; const [itemId] = (0, _element.useState)(`item-${++uniqueId}`); (0, _useNavigationTreeItem.useNavigationTreeItem)(itemId, props); const { navigationTree } = (0, _context.useNavigationContext)(); if (!((_navigationTree$getIt = navigationTree.getItem(itemId)) !== null && _navigationTree$getIt !== void 0 && _navigationTree$getIt._isVisible)) { return null; } const classes = (0, _classnames.default)('components-navigation__item', className); return (0, _element.createElement)(_navigationStyles.ItemBaseUI, (0, _extends2.default)({ className: classes }, restProps), children); } //# sourceMappingURL=base.js.map