antd-mobile
Version:
<div align="center">
41 lines (40 loc) • 2.25 kB
TypeScript
import React from 'react';
import type { ReactNode, ButtonHTMLAttributes, DetailedHTMLProps } from 'react';
import { NativeProps } from '../../utils/native-props';
declare type NativeButtonProps = DetailedHTMLProps<ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>;
export declare type ButtonProps = {
color?: 'default' | 'primary' | 'success' | 'warning' | 'danger';
fill?: 'solid' | 'outline' | 'none';
size?: 'mini' | 'small' | 'middle' | 'large';
block?: boolean;
loading?: boolean | 'auto';
loadingText?: string;
loadingIcon?: ReactNode;
disabled?: boolean;
onClick?: (event: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void | Promise<void>;
type?: 'submit' | 'reset' | 'button';
shape?: 'default' | 'rounded' | 'rectangular';
children?: ReactNode;
} & Pick<NativeButtonProps, 'onMouseDown' | 'onMouseUp' | 'onTouchStart' | 'onTouchEnd' | 'id'> & NativeProps<'--text-color' | '--background-color' | '--border-radius' | '--border-width' | '--border-style' | '--border-color'>;
export declare type ButtonRef = {
nativeElement: HTMLButtonElement | null;
};
export declare const Button: React.ForwardRefExoticComponent<{
color?: "default" | "primary" | "success" | "warning" | "danger" | undefined;
fill?: "none" | "solid" | "outline" | undefined;
size?: "small" | "large" | "middle" | "mini" | undefined;
block?: boolean | undefined;
loading?: boolean | "auto" | undefined;
loadingText?: string | undefined;
loadingIcon?: ReactNode;
disabled?: boolean | undefined;
onClick?: ((event: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void | Promise<void>) | undefined;
type?: "reset" | "submit" | "button" | undefined;
shape?: "default" | "rounded" | "rectangular" | undefined;
children?: ReactNode;
} & Pick<NativeButtonProps, "id" | "onTouchStart" | "onMouseDown" | "onMouseUp" | "onTouchEnd"> & {
className?: string | undefined;
style?: (React.CSSProperties & Partial<Record<"--border-radius" | "--text-color" | "--background-color" | "--border-width" | "--border-style" | "--border-color", string>>) | undefined;
tabIndex?: number | undefined;
} & React.AriaAttributes & React.RefAttributes<ButtonRef>>;
export {};