import React from 'react' import classnames from 'classnames' import { buildAriaProps, buildDataProps, buildHtmlProps } from '../utilities/props' import { GlobalProps, globalProps } from '../utilities/globalProps' import { isValidEmoji } from '../utilities/validEmojiChecker' import { getAllIcons } from "../utilities/icons/allicons" import Icon from '../pb_icon/_icon' import Caption from "../pb_caption/_caption" import Flex from "../pb_flex/_flex" type EventHandler = (React.MouseEventHandler) type ButtonPropTypes = { aria?: { [key: string]: string }, children?: React.ReactChild[] | React.ReactChild, className?: string | string[], count?: number, data?: { [key: string]: string }, disabled?: boolean, fixedWidth?: boolean, form?: string, fullWidth?: boolean, highlight?: boolean, htmlOptions?: {[key: string]: string | number | boolean | (() => void)}, icon?: string, iconRight?: boolean, id?: string, link?: string, loading?: boolean, newWindow?: boolean, onClick?: EventHandler, tabIndex?: number, size?: 'sm' | 'md' | 'lg', target?: string, text?: string, type?: 'inline' | null, htmlType?: 'submit' | 'reset' | 'button' | undefined, value?: string | null, variant?: 'primary' | 'secondary' | 'link'| 'reaction', wrapperClass?: string, } & GlobalProps const buttonClassName = (props: ButtonPropTypes) => { const { disabled = false, fullWidth = false, highlight, icon, loading = false, type = 'inline', variant = 'primary', size = null, } = props let className = 'pb_button_kit' className += `${variant !== null ? `_${variant}` : ''}` className += `${type !== null ? `_${type}` : ''}` className += `${fullWidth ? '_block' : ''}` className += disabled ? '_disabled' : '_enabled' className += loading ? '_loading' : '' className += `${size !== null ? ` size_${size}` : ''}` className += `${variant === 'reaction' && !isValidEmoji(icon) ? ` reaction_default` : ''}` className += `${variant === 'reaction' && highlight ? ` active` : ''}` return className } const spinnerIcon = getAllIcons()["spinner"] const Button = (props: ButtonPropTypes): React.ReactElement => { const { aria = {}, children, className, count, data = {}, disabled, htmlOptions = {}, icon = null, iconRight = false, id, loading = false, onClick, tabIndex, link = null, newWindow = false, target = '', text, htmlType = 'button', value, variant, form = null } = props const ariaProps = buildAriaProps(aria) const dataProps = buildDataProps(data) const htmlProps = buildHtmlProps(htmlOptions) const css = classnames( buttonClassName(props), globalProps(props), className ) const loadingIcon = (
) const content = ( {icon && !iconRight && ( )} {text || children} {icon && iconRight && ( )} ) const ifLoading = () => { if (loading) { return ( <> {loadingIcon} ) } else { return ( content ) } } const getTargetAttribute = () => { if (target && link) { return target } else if (newWindow) { return '_blank' } return null } const displayButton = () => { if (link) { return ( {ifLoading()} ); } else if (variant === "reaction") { return ( ); } else { return ( ); } } return ( <> {displayButton()} ) } export default Button