@wordpress/components
Version:
UI components for WordPress.
149 lines (140 loc) • 3.87 kB
text/typescript
/**
* External dependencies
*/
import type { ReactNode } from 'react';
/**
* Internal dependencies
*/
import type { Props as IconProps } from '../icon';
import type { PopoverProps } from '../popover/types';
import type { WordPressComponentProps } from '../ui/context/wordpress-component';
export type ButtonProps =
| WordPressComponentProps< ButtonAsButtonProps, 'button', false >
| WordPressComponentProps< ButtonAsAnchorProps, 'a', false >;
export type ButtonAsButtonProps = BaseButtonProps & _ButtonProps;
export type ButtonAsAnchorProps = BaseButtonProps & AnchorProps;
type BaseButtonProps = {
/**
* Start opting into the larger default height that will become the
* default size in a future version.
*
* @default false
*/
__next40pxDefaultSize?: boolean;
/**
* The button's children.
*/
children?: ReactNode;
/**
* An accessible description for the button.
*/
describedBy?: string;
/**
* Whether the button is focused.
*/
focus?: boolean;
/**
* If provided, renders an Icon component inside the button.
*/
icon?: IconProps[ 'icon' ];
/**
* If provided with `icon`, sets the position of icon relative to the `text`.
*
* @default 'left'
*/
iconPosition?: 'left' | 'right';
/**
* If provided with `icon`, sets the icon size.
* Please refer to the Icon component for more details regarding
* the default value of its `size` prop.
*/
iconSize?: IconProps[ 'size' ];
/**
* Indicates activity while a action is being performed.
*/
isBusy?: boolean;
/**
* Renders a red text-based button style to indicate destructive behavior.
*/
isDestructive?: boolean;
/**
* Renders a pressed button style.
*/
isPressed?: boolean;
/**
* Decreases the size of the button.
*/
isSmall?: boolean;
/**
* Sets the `aria-label` of the component, if none is provided.
* Sets the Tooltip content if `showTooltip` is provided.
*/
label?: string;
/**
* If provided with `showTooltip`, appends the Shortcut label to the tooltip content.
* If an object is provided, it should contain `display` and `ariaLabel` keys.
*/
shortcut?: string | { display: string; ariaLabel: string };
/**
* If provided, renders a Tooltip component for the button.
*/
showTooltip?: boolean;
/**
* If provided, displays the given text inside the button. If the button contains children elements, the text is displayed before them.
*/
text?: string;
/**
* If provided with `showTooltip`, sets the position of the tooltip.
* Please refer to the Tooltip component for more details regarding the defaults.
*/
tooltipPosition?: PopoverProps[ 'position' ];
/**
* Specifies the button's style.
* The accepted values are:
* 'primary' (the primary button styles)
* 'secondary' (the default button styles)
* 'tertiary' (the text-based button styles)
* 'link' (the link button styles)
*/
variant?: 'primary' | 'secondary' | 'tertiary' | 'link';
/**
* Whether this is focusable.
*/
__experimentalIsFocusable?: boolean;
};
type _ButtonProps = {
/**
* Whether the button is disabled.
* If `true`, this will force a `button` element to be rendered.
*/
disabled?: boolean;
};
type AnchorProps = {
/**
* Whether the button is disabled.
* If `true`, this will force a `button` element to be rendered.
*/
disabled?: false;
/**
* If provided, renders `a` instead of `button`.
*/
href: string;
/**
* If provided with `href`, sets the `target` attribute to the `a`.
*/
target?: string;
};
export type DeprecatedButtonProps = {
isDefault?: boolean;
isLink?: boolean;
isPrimary?: boolean;
isSecondary?: boolean;
isTertiary?: boolean;
};
export type DeprecatedIconButtonProps = {
labelPosition: ButtonProps[ 'tooltipPosition' ];
showTooltip?: boolean;
size: ButtonProps[ 'iconSize' ];
label: ButtonProps[ 'label' ];
tooltip: ButtonProps[ 'label' ];
};