@mui/core
Version:
Unstyled React components with which to implement custom design systems.
33 lines (32 loc) • 1.3 kB
TypeScript
import { OverrideProps } from '@mui/types';
import React from 'react';
import UseButtonProps from './UseButtonProps';
export interface ButtonUnstyledActions {
focusVisible(): void;
}
export interface ButtonUnstyledComponentsPropsOverrides {
}
export interface ButtonUnstyledOwnProps extends Omit<UseButtonProps, 'ref'> {
/**
* A ref for imperative actions. It currently only supports `focusVisible()` action.
*/
action?: React.Ref<ButtonUnstyledActions>;
children?: React.ReactNode;
className?: string;
componentsProps?: {
root?: React.ButtonHTMLAttributes<HTMLButtonElement> & ButtonUnstyledComponentsPropsOverrides;
};
}
declare type ButtonUnstyledProps<D extends React.ElementType = ButtonUnstyledTypeMap['defaultComponent'], P = {}> = OverrideProps<ButtonUnstyledTypeMap<P, D>, D> & {
/**
* The component used for the Root slot.
* Either a string to use a HTML element or a component.
* This is equivalent to `components.Root`. If both are provided, the `component` is used.
*/
component?: D;
};
export interface ButtonUnstyledTypeMap<P = {}, D extends React.ElementType = 'button'> {
props: P & ButtonUnstyledOwnProps;
defaultComponent: D;
}
export default ButtonUnstyledProps;