@ariakit/react-core
Version:
Ariakit React core
67 lines (65 loc) • 1.76 kB
JavaScript
"use client";
import {
useSelectProviderContext
} from "../__chunks/QI6TYHPV.js";
import "../__chunks/MWF5B7KS.js";
import "../__chunks/63N3TCQX.js";
import "../__chunks/FFSBKSAM.js";
import "../__chunks/72IB6YNO.js";
import "../__chunks/45YOMIF3.js";
import {
createElement,
createHook,
forwardRef,
memo
} from "../__chunks/ILRXHV7V.js";
import {
useEvent,
useId,
useMergeRefs
} from "../__chunks/K2XTQB3X.js";
import "../__chunks/YXGXYGQX.js";
// src/select/select-label.tsx
import { invariant, removeUndefinedValues } from "@ariakit/core/utils/misc";
var TagName = "div";
var useSelectLabel = createHook(
function useSelectLabel2({ store, ...props }) {
const context = useSelectProviderContext();
store = store || context;
invariant(
store,
process.env.NODE_ENV !== "production" && "SelectLabel must receive a `store` prop or be wrapped in a SelectProvider component."
);
const id = useId(props.id);
const onClickProp = props.onClick;
const onClick = useEvent((event) => {
onClickProp == null ? void 0 : onClickProp(event);
if (event.defaultPrevented) return;
queueMicrotask(() => {
const select = store == null ? void 0 : store.getState().selectElement;
select == null ? void 0 : select.focus();
});
});
props = {
id,
...props,
ref: useMergeRefs(store.setLabelElement, props.ref),
onClick,
style: {
cursor: "default",
...props.style
}
};
return removeUndefinedValues(props);
}
);
var SelectLabel = memo(
forwardRef(function SelectLabel2(props) {
const htmlProps = useSelectLabel(props);
return createElement(TagName, htmlProps);
})
);
export {
SelectLabel,
useSelectLabel
};