UNPKG

@mui/material

Version:

Material UI is an open-source React component library that implements Google's Material Design. It's comprehensive and can be used in production out of the box.

82 lines (81 loc) 2.79 kB
import * as React from 'react'; import { OverridableStringUnion } from '@mui/types'; import { SxProps } from '@mui/system'; import { PropTypes, Theme } from "../index.js"; import { ExtendButtonBase, ExtendButtonBaseTypeMap } from "../ButtonBase/index.js"; import { OverrideProps } from "../OverridableComponent/index.js"; import { FabClasses } from "./fabClasses.js"; export interface FabPropsVariantOverrides {} export interface FabPropsSizeOverrides {} export interface FabPropsColorOverrides {} export interface FabOwnProps { /** * The content of the component. */ children?: React.ReactNode; /** * Override or extend the styles applied to the component. */ classes?: Partial<FabClasses>; /** * The color of the component. * It supports both default and custom theme colors, which can be added as shown in the * [palette customization guide](https://mui.com/material-ui/customization/palette/#custom-colors). * @default 'default' */ color?: OverridableStringUnion<PropTypes.Color | 'success' | 'error' | 'info' | 'warning', FabPropsColorOverrides>; /** * If `true`, the component is disabled. * @default false */ disabled?: boolean; /** * If `true`, the keyboard focus ripple is disabled. * @default false */ disableFocusRipple?: boolean; /** * If `true`, the ripple effect is disabled. */ disableRipple?: boolean; /** * The URL to link to when the button is clicked. * If defined, an `a` element will be used as the root node. */ href?: string; /** * The size of the component. * `small` is equivalent to the dense button styling. * @default 'large' */ size?: OverridableStringUnion<'small' | 'medium' | 'large', FabPropsSizeOverrides>; /** * The variant to use. * @default 'circular' */ variant?: OverridableStringUnion<'circular' | 'extended', FabPropsVariantOverrides>; /** * The system prop that allows defining system overrides as well as additional CSS styles. */ sx?: SxProps<Theme>; } export type FabTypeMap<AdditionalProps = {}, RootComponent extends React.ElementType = 'button'> = ExtendButtonBaseTypeMap<{ props: AdditionalProps & FabOwnProps; defaultComponent: RootComponent; }>; /** * * Demos: * * - [Floating Action Button](https://mui.com/material-ui/react-floating-action-button/) * * API: * * - [Fab API](https://mui.com/material-ui/api/fab/) * - inherits [ButtonBase API](https://mui.com/material-ui/api/button-base/) */ declare const Fab: ExtendButtonBase<FabTypeMap>; export type FabProps<RootComponent extends React.ElementType = FabTypeMap['defaultComponent'], AdditionalProps = {}> = OverrideProps<FabTypeMap<AdditionalProps, RootComponent>, RootComponent> & { component?: React.ElementType; }; export default Fab;