import React from 'react' import classnames from 'classnames' import Title from '../pb_title/_title' import Icon from '../pb_icon/_icon' import Avatar from '../pb_avatar/_avatar' import Tooltip from '../pb_tooltip/_tooltip' import { globalProps, GlobalProps } from '../utilities/globalProps' import { buildDataProps, buildHtmlProps } from '../utilities/props' type FormPillProps = { className?: string, htmlOptions?: {[key: string]: string | number | boolean | (() => void)}, id?: string, text: string, name?: string, onClick?: React.MouseEventHandler, avatar?: boolean, avatarUrl?: string, size?: string, textTransform?: 'none' | 'lowercase', color?: "primary" | "neutral" | "success" | "warning" | "error" | "info" | "data_1" | "data_2" | "data_3" | "data_4" | "data_5" | "data_6" | "data_7" | "data_8" | "windows" | "siding" | "roofing" | "doors" | "gutters" | "solar" | "insulation" | "accessories", data?: {[key: string]: string}, tabIndex?: number, icon?: string, closeProps?: { onClick?: React.MouseEventHandler, onMouseDown?: React.MouseEventHandler, onTouchEnd?: React.TouchEventHandler, }, } & GlobalProps const FormPill = (props: FormPillProps): React.ReactElement => { const { className, htmlOptions = {}, id, text, name, onClick = () => undefined, avatarUrl, closeProps = {}, size = '', textTransform = 'none', color = "primary", data = {}, tabIndex, icon = "", } = props const iconClass = icon ? "_icon" : "" const closeIconSize = size === "small" ? "xs" : "sm" const filteredProps: FormPillProps = {...props} delete filteredProps.truncate const css = classnames( `pb_form_pill_kit_${color}${iconClass}`, globalProps(filteredProps), className, size === 'small' ? 'small' : null, textTransform, ) const dataProps = buildDataProps(data) const htmlProps = buildHtmlProps(htmlOptions) const renderTitle = (content: string, className: string) => { const titleComponent = ( ) if (props.truncate) { return ( <Tooltip interaction placement="top" position="fixed" text={content} > {titleComponent} </Tooltip> ) } return titleComponent } return ( <div className={css} id={id} tabIndex={tabIndex} {...dataProps} {...htmlProps} > {((name && !icon && !text) || (name && !icon && text)) && ( <> <Avatar imageUrl={avatarUrl} name={name} size="xxs" status={null} /> {renderTitle(name, "pb_form_pill_text")} </> )} {((name && icon && !text) || (name && icon && text)) && ( <> <Avatar imageUrl={avatarUrl} name={name} size="xxs" status={null} /> {renderTitle(name, "pb_form_pill_text")} <Icon className="pb_form_pill_icon" color={color} icon={icon} /> </> )} {(!name && icon && text) && ( <> <Icon className="pb_form_pill_icon" color={color} icon={icon} /> {renderTitle(text, "pb_form_pill_tag")} </> )} {(!name && !icon && text) && renderTitle(text, "pb_form_pill_tag")} <div className="pb_form_pill_close" onClick={onClick} {...closeProps} > <Icon fixedWidth icon="times" size={closeIconSize} /> </div> </div> ) } export default FormPill