/* @flow */ import React from 'react' import classnames from 'classnames' import type { InputCallback } from '../types' import { globalProps } from '../utilities/globalProps' import { buildAriaProps, buildCss, buildDataProps, noop, } from '../utilities/props' import Icon from '../pb_icon/_icon' import Checkbox from '../pb_checkbox/_checkbox' import Card from '../pb_card/_card' import Flex from '../pb_flex/_flex' import Radio from '../pb_radio/_radio' type SelectableCardProps = { aria?: object, checked: boolean, children?: array, className?: string, customIcon?: SVGElement, dark?: boolean, data: object, disabled?: boolean, error?: boolean, icon?: boolean, id?: string, inputId?: string, multi?: boolean, name?: string, onChange: InputCallback, text?: string, value?: string, variant?: string, } const SelectableCard = ({ aria = {}, checked = false, children, className, customIcon, dark = false, data = {}, disabled = false, error = false, icon = false, inputId = null, multi = true, name, onChange = noop, text, value, variant = 'default', ...props }: SelectableCardProps) => { const ariaProps = buildAriaProps(aria) const dataProps = buildDataProps(data) const classes = classnames(buildCss('pb_selectable_card_kit', { 'checked': checked, 'disabled': disabled, 'enabled': !disabled, }), { error }, dark ? 'dark' : '', className ) const displayIcon = () => { if (icon === true) { return (
) } } const inputRef = React.createRef() // Delegate clicks to hidden input from visible one const handleClick = () => { inputRef.current.click() } const inputType = multi ? 'checkbox' : 'radio' const inputIdPresent = inputId !== null ? inputId : name const Input = multi ? Checkbox : Radio const labelProps = variant === 'displayInput' ? Object.assign(props, { padding: 'none' }) : props return (