UNPKG

@mui/core

Version:

Unstyled React components with which to implement custom design systems.

33 lines (32 loc) 1.3 kB
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;