@mui/x-tree-view
Version:
The community edition of the MUI X Tree View components.
20 lines • 1.29 kB
TypeScript
import * as React from 'react';
import { EventHandlers } from '@mui/utils/types';
import type { TreeViewContextValue } from "../TreeViewProvider/index.js";
import { TreeViewAnyPluginSignature, ConvertSignaturesIntoPlugins, TreeViewPublicAPI } from "../models/index.js";
export interface UseTreeViewParameters<TSignatures extends readonly TreeViewAnyPluginSignature[], TProps extends Partial<UseTreeViewBaseProps<TSignatures>>> {
plugins: ConvertSignaturesIntoPlugins<TSignatures>;
rootRef?: React.Ref<HTMLUListElement> | undefined;
props: TProps;
}
export interface UseTreeViewBaseProps<TSignatures extends readonly TreeViewAnyPluginSignature[]> {
apiRef: React.RefObject<Partial<TreeViewPublicAPI<TSignatures>> | undefined> | undefined;
}
export interface UseTreeViewRootSlotProps extends Pick<React.HTMLAttributes<HTMLUListElement>, 'onFocus' | 'onBlur' | 'onKeyDown' | 'id' | 'aria-multiselectable' | 'role' | 'tabIndex'> {
ref: React.Ref<HTMLUListElement>;
}
export interface UseTreeViewReturnValue<TSignatures extends readonly TreeViewAnyPluginSignature[]> {
getRootProps: <TOther extends EventHandlers = {}>(otherHandlers?: TOther) => UseTreeViewRootSlotProps;
rootRef: React.RefCallback<HTMLUListElement> | null;
contextValue: TreeViewContextValue<TSignatures>;
}