You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

51 lines
1.9 KiB

import * as React from 'react';
export declare type ButtonType = 'button' | 'reset' | 'submit';
export interface AnchorOptions {
href?: string;
rel?: string;
target?: string;
}
export interface UseButtonPropsOptions extends AnchorOptions {
type?: ButtonType;
disabled?: boolean;
onClick?: React.EventHandler<React.MouseEvent | React.KeyboardEvent>;
tabIndex?: number;
tagName?: keyof JSX.IntrinsicElements;
role?: React.AriaRole | undefined;
}
export declare function isTrivialHref(href?: string): boolean;
export interface AriaButtonProps {
type?: ButtonType | undefined;
disabled: boolean | undefined;
role?: React.AriaRole;
tabIndex?: number | undefined;
href?: string | undefined;
target?: string | undefined;
rel?: string | undefined;
'aria-disabled'?: true | undefined;
onClick?: (event: React.MouseEvent | React.KeyboardEvent) => void;
onKeyDown?: (event: React.KeyboardEvent) => void;
}
export interface UseButtonPropsMetadata {
tagName: React.ElementType;
}
export declare function useButtonProps({ tagName, disabled, href, target, rel, role, onClick, tabIndex, type, }: UseButtonPropsOptions): [AriaButtonProps, UseButtonPropsMetadata];
export interface BaseButtonProps {
/**
* Control the underlying rendered element directly by passing in a valid
* component type
*/
as?: keyof JSX.IntrinsicElements | undefined;
/** The disabled state of the button */
disabled?: boolean | undefined;
/** Optionally specify an href to render a `<a>` tag styled as a button */
href?: string | undefined;
/** Anchor target, when rendering an anchor as a button */
target?: string | undefined;
rel?: string | undefined;
}
export interface ButtonProps extends BaseButtonProps, React.ComponentPropsWithoutRef<'button'> {
}
declare const Button: React.ForwardRefExoticComponent<ButtonProps & React.RefAttributes<HTMLElement>>;
export default Button;