@wordpress/components
Version:
UI components for WordPress.
58 lines (43 loc) • 1.5 kB
JavaScript
;
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 _lodash = require("lodash");
var _context = require("../context");
var _useNavigationTreeItem = require("./use-navigation-tree-item");
var _navigationStyles = require("../styles/navigation-styles");
/**
* External dependencies
*/
/**
* WordPress dependencies
*/
/**
* Internal dependencies
*/
function NavigationItemBase(props) {
var _navigationTree$getIt;
const {
children,
className,
...restProps
} = props;
const [itemId] = (0, _element.useState)((0, _lodash.uniqueId)('item-'));
(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