UNPKG

@base-ui-components/react

Version:

Base UI is a library of headless ('unstyled') React components and low-level hooks. You gain complete control over your app's CSS and accessibility features.

50 lines (49 loc) 1.68 kB
"use strict"; 'use client'; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.ComboboxGroup = void 0; var React = _interopRequireWildcard(require("react")); var _useRenderElement = require("../../utils/useRenderElement"); var _ComboboxGroupContext = require("./ComboboxGroupContext"); var _GroupCollectionContext = require("../collection/GroupCollectionContext"); var _jsxRuntime = require("react/jsx-runtime"); /** * Groups related items with the corresponding label. * Renders a `<div>` element. */ const ComboboxGroup = exports.ComboboxGroup = /*#__PURE__*/React.forwardRef(function ComboboxGroup(componentProps, forwardedRef) { const { render, className, items, ...elementProps } = componentProps; const [labelId, setLabelId] = React.useState(); const contextValue = React.useMemo(() => ({ labelId, setLabelId, items }), [labelId, setLabelId, items]); const element = (0, _useRenderElement.useRenderElement)('div', componentProps, { ref: forwardedRef, props: [{ role: 'group', 'aria-labelledby': labelId }, elementProps] }); const wrappedElement = /*#__PURE__*/(0, _jsxRuntime.jsx)(_ComboboxGroupContext.ComboboxGroupContext.Provider, { value: contextValue, children: element }); if (items) { return /*#__PURE__*/(0, _jsxRuntime.jsx)(_GroupCollectionContext.GroupCollectionProvider, { items: items, children: wrappedElement }); } return wrappedElement; }); if (process.env.NODE_ENV !== "production") ComboboxGroup.displayName = "ComboboxGroup";