@mui/base
Version:
MUI Base is a library of headless ('unstyled') React components and low-level hooks. You gain complete control over your app's CSS and accessibility features.
47 lines (46 loc) • 1.58 kB
TypeScript
import * as React from 'react';
import { Simplify } from '@mui/types';
import { UseTabsListRootSlotProps } from '../useTabsList';
import { PolymorphicProps, SlotComponentProps } from '../utils';
export interface TabsListRootSlotPropsOverrides {
}
export interface TabsListOwnProps {
/**
* The content of the component.
*/
children?: React.ReactNode;
className?: string;
/**
* The props used for each slot inside the TabsList.
* @default {}
*/
slotProps?: {
root?: SlotComponentProps<'div', TabsListRootSlotPropsOverrides, TabsListOwnerState>;
};
/**
* The components used for each slot inside the TabsList.
* Either a string to use a HTML element or a component.
* @default {}
*/
slots?: TabsListSlots;
}
export interface TabsListSlots {
/**
* The component that renders the root.
* @default 'div'
*/
root?: React.ElementType;
}
export interface TabsListTypeMap<AdditionalProps = {}, RootComponentType extends React.ElementType = 'div'> {
props: TabsListOwnProps & AdditionalProps;
defaultComponent: RootComponentType;
}
export type TabsListProps<RootComponentType extends React.ElementType = TabsListTypeMap['defaultComponent']> = PolymorphicProps<TabsListTypeMap<{}, RootComponentType>, RootComponentType>;
export type TabsListOwnerState = Simplify<TabsListOwnProps & {
isRtl: boolean;
orientation: 'horizontal' | 'vertical';
}>;
export type TabsListRootSlotProps = UseTabsListRootSlotProps & {
className?: string;
ownerState: TabsListOwnerState;
};