/* @flow */ import React from 'react' import classnames from 'classnames' import { spacing } from '../utilities/spacing.js' import Icon from '../pb_icon/_icon.jsx' type EventHandler = (SyntheticInputEvent) => void type ButtonPropTypes = { aria?: { label: String, }, children?: Array, className?: String | Array, dark: Boolean, disabled?: Boolean, fixedWidth?: Boolean, fullWidth?: Boolean, icon?: String, id?: String, link?: String, loading?: Boolean, newWindow?: Boolean, onClick?: EventHandler, size: 'large' | 'medium' | 'small', text?: String, type: 'inline' | null, htmlType: String | 'button', value?: String | null, variant: 'primary' | 'secondary' | 'link', wrapperClass: String, } const buttonClassName = (props: ButtonPropTypes) => { const { dark = false, disabled = false, fullWidth = false, loading = false, size = null, type = 'inline', variant = 'primary', } = props let className = 'pb_button_kit' className += `${variant !== null ? `_${variant}` : ''}` className += `${type !== null ? `_${type}` : ''}` className += `${size !== null ? `_${size}` : ''}` className += `${dark === true ? '_dark' : ''}` className += `${fullWidth ? '_block' : ''}` className += disabled ? '_disabled' : '_enabled' className += loading ? '_loading' : '' return className } const buttonAriaProps = (props: ButtonPropTypes) => { const { aria } = props if (typeof aria !== 'object') return {} const { label } = aria const ariaProps = {} if (label !== null) ariaProps['aria-label'] = label return ariaProps } const Button = (props: ButtonPropTypes) => { const { children, className, disabled, icon = null, id, loading = false, onClick = () => {}, link = null, newWindow = false, text, htmlType = 'button', value, } = props const buttonAria = buttonAriaProps(props) const css = classnames(buttonClassName(props), className, spacing(props)) const loadingIcon = (
) const content = ( {text || children} ) return ( {loadingIcon} {content} ) } export default Button