@base-ui/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.
38 lines (37 loc) • 1.46 kB
JavaScript
'use client';
import * as React from 'react';
import { useMergedRefs } from '@base-ui/utils/useMergedRefs';
import { useStableCallback } from '@base-ui/utils/useStableCallback';
import { visuallyHiddenInput } from '@base-ui/utils/visuallyHidden';
import { useButton } from "../../internals/use-button/index.js";
import { createChangeEventDetails } from "../../internals/createBaseUIEventDetails.js";
import { REASONS } from "../../internals/reasons.js";
import { useComboboxRootContext } from "../root/ComboboxRootContext.js";
import { jsx as _jsx } from "react/jsx-runtime";
/**
* @internal
*/
export const ComboboxInternalDismissButton = /*#__PURE__*/React.forwardRef(function ComboboxInternalDismissButton(_, forwardedRef) {
const store = useComboboxRootContext();
const {
buttonRef,
getButtonProps
} = useButton({
native: false
});
const mergedRef = useMergedRefs(forwardedRef, buttonRef);
const handleDismiss = useStableCallback(event => {
store.state.setOpen(false, createChangeEventDetails(REASONS.closePress, event.nativeEvent, event.currentTarget));
});
const dismissProps = getButtonProps({
onClick: handleDismiss
});
return /*#__PURE__*/_jsx("span", {
ref: mergedRef,
...dismissProps,
"aria-label": "Dismiss",
tabIndex: undefined,
style: visuallyHiddenInput
});
});
if (process.env.NODE_ENV !== "production") ComboboxInternalDismissButton.displayName = "ComboboxInternalDismissButton";