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.

44 lines 2.23 kB
import * as React from 'react'; import { type FloatingEvents } from "../../floating-ui-react/index.js"; import type { SelectStore } from "../store.js"; import type { UseFieldValidationReturnValue } from "../../field/root/useFieldValidation.js"; import type { HTMLProps } from "../../utils/types.js"; import type { SelectRoot } from "./SelectRoot.js"; export interface SelectRootContext { store: SelectStore; name: string | undefined; disabled: boolean; readOnly: boolean; required: boolean; multiple: boolean; setValue: (nextValue: any, eventDetails: SelectRoot.ChangeEventDetails) => void; setOpen: (open: boolean, eventDetails: SelectRoot.ChangeEventDetails) => void; listRef: React.MutableRefObject<Array<HTMLElement | null>>; popupRef: React.MutableRefObject<HTMLDivElement | null>; scrollHandlerRef: React.MutableRefObject<((el: HTMLDivElement) => void) | null>; handleScrollArrowVisibility: () => void; scrollArrowsMountedCountRef: React.RefObject<number>; getItemProps: (props?: HTMLProps & { active?: boolean; selected?: boolean; }) => Record<string, unknown>; events: FloatingEvents; valueRef: React.MutableRefObject<HTMLSpanElement | null>; valuesRef: React.MutableRefObject<Array<any>>; labelsRef: React.MutableRefObject<Array<string | null>>; typingRef: React.MutableRefObject<boolean>; selectionRef: React.MutableRefObject<{ allowUnselectedMouseUp: boolean; allowSelectedMouseUp: boolean; }>; selectedItemTextRef: React.MutableRefObject<HTMLSpanElement | null>; validation: UseFieldValidationReturnValue; onOpenChangeComplete?: (open: boolean) => void; keyboardActiveRef: React.MutableRefObject<boolean>; alignItemWithTriggerActiveRef: React.RefObject<boolean>; initialValueRef: React.MutableRefObject<any>; } export declare const SelectRootContext: React.Context<SelectRootContext | null>; export declare const SelectFloatingContext: React.Context<import("../../floating-ui-react/components/FloatingRootStore.js").FloatingRootStore | null>; export declare function useSelectRootContext(): SelectRootContext; export declare function useSelectFloatingContext(): import("../../floating-ui-react/components/FloatingRootStore.js").FloatingRootStore;