@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
TypeScript
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;