import React from 'react' import PropTypes from 'prop-types' import { CX } from '../constants' import Button from './button' import Icon from './icon' import Text from './text' class Input extends React.PureComponent { handleOnChange = (e) => { this.props.onChange(e.target.value) } render() { const { placeholder, prependIcon, value, hasClear, onChange, onKeyUp, onFocus, onBlur, onClear, title, small, readOnly, inputRef, id, hideLabel, maxLength, } = this.props const inputClasses = CX({ d: 1, text: 1, outlineNone: 1, lineHeight125: !small, lineHeight1: small, displayBlock: 1, py10: !small, py5: small, bgTransparent: !readOnly, bgSecondary: readOnly, cPrimary: !readOnly, cSecondary: readOnly, fs15PX: !small, fs13PX: small, flexGrow1: 1, circle: 1, px5: !!prependIcon, pl15: !prependIcon, pr15: !hasClear, }) const btnClasses = CX({ displayNone: !value || value.length === 0, px10: 1, mr5: 1, }) return ( { !!title && !hideLabel &&
{title}
}
{ !!prependIcon && } { !!title && hideLabel && } { hasClear &&
) } } Input.propTypes = { placeholder: PropTypes.string, prependIcon: PropTypes.string, value: PropTypes.string, hasClear: PropTypes.bool, onChange: PropTypes.func, onKeyUp: PropTypes.func, onFocus: PropTypes.func, onBlur: PropTypes.func, onClear: PropTypes.func, title: PropTypes.string, small: PropTypes.bool, readOnly: PropTypes.string, inputRef: PropTypes.func, id: PropTypes.string.isRequired, hideLabel: PropTypes.bool, maxLength: PropTypes.number, } export default Input