/** * External dependencies */ import { Button as WPButton } from 'wordpress-components'; import type { ReactNode } from 'react'; import classNames from 'classnames'; import Spinner from '@woocommerce/base-components/spinner'; /** * Internal dependencies */ import './style.scss'; export interface ButtonProps extends WPButton.ButtonProps { /** * Component wrapper classname * * @default 'wc-block-components-button' */ className?: string; /** * Show spinner * * @default false */ showSpinner?: boolean; /** * Button content */ children?: ReactNode; /** * Button state */ disabled?: boolean; /** * Event handler triggered when the button is clicked */ onClick?: ( e: React.MouseEvent< HTMLButtonElement, MouseEvent > ) => void; /** * Button type */ type?: 'button' | 'input' | 'submit'; /** * Button variant */ variant?: 'text' | 'contained' | 'outlined'; /** * Button href */ href?: string | undefined; } /** * Component that visually renders a button but semantically might be `