@ariakit/react-core
Version:
Ariakit React core
56 lines (53 loc) • 1.39 kB
JavaScript
"use client";
import {
useTagContext
} from "./IUIPXKOL.js";
import {
usePopoverStoreProps
} from "./6RB43CMC.js";
import {
useCompositeStoreOptions,
useCompositeStoreProps
} from "./VEHC2EHR.js";
import {
useStore,
useStoreProps
} from "./Q3KUZPD7.js";
import {
useUpdateEffect
} from "./K2XTQB3X.js";
// src/combobox/combobox-store.ts
import * as Core from "@ariakit/core/combobox/combobox-store";
function useComboboxStoreOptions(props) {
const tag = useTagContext();
props = {
...props,
tag: props.tag !== void 0 ? props.tag : tag
};
return useCompositeStoreOptions(props);
}
function useComboboxStoreProps(store, update, props) {
useUpdateEffect(update, [props.tag]);
useStoreProps(store, props, "value", "setValue");
useStoreProps(store, props, "selectedValue", "setSelectedValue");
useStoreProps(store, props, "resetValueOnHide");
useStoreProps(store, props, "resetValueOnSelect");
return Object.assign(
useCompositeStoreProps(
usePopoverStoreProps(store, update, props),
update,
props
),
{ tag: props.tag }
);
}
function useComboboxStore(props = {}) {
props = useComboboxStoreOptions(props);
const [store, update] = useStore(Core.createComboboxStore, props);
return useComboboxStoreProps(store, update, props);
}
export {
useComboboxStoreOptions,
useComboboxStoreProps,
useComboboxStore
};