You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
90 lines
2.1 KiB
90 lines
2.1 KiB
import React from 'react'
|
|
import { asField } from 'informed'
|
|
import { Input as Base } from 'styled-system-html'
|
|
import { withTheme } from 'styled-components'
|
|
import { Flex } from 'rebass'
|
|
import FormFieldMessage from 'components/UI/FormFieldMessage'
|
|
|
|
/**
|
|
* @render react
|
|
* @name Input
|
|
* @example
|
|
* <Input />
|
|
*/
|
|
class Input extends React.PureComponent {
|
|
static displayName = 'Input'
|
|
|
|
render() {
|
|
const {
|
|
onChange,
|
|
onBlur,
|
|
initialValue,
|
|
field,
|
|
forwardedRef,
|
|
theme,
|
|
fieldApi,
|
|
fieldState,
|
|
justifyContent,
|
|
...rest
|
|
} = this.props
|
|
const { setValue, setTouched } = fieldApi
|
|
const { value } = fieldState
|
|
|
|
let borderColor
|
|
|
|
if (fieldState.touched) {
|
|
if (fieldState.error) {
|
|
borderColor = theme.colors.superRed
|
|
} else if (value && !fieldState.error) {
|
|
borderColor = theme.colors.superGreen
|
|
}
|
|
}
|
|
|
|
return (
|
|
<Flex flexDirection="column" justifyContent={justifyContent}>
|
|
<Base
|
|
outline="none"
|
|
borderRadius="5px"
|
|
borderColor={borderColor || theme.colors.white}
|
|
border="1px solid white"
|
|
bg="transparent"
|
|
color="white"
|
|
p={3}
|
|
type="text"
|
|
fontSize="m"
|
|
width={1}
|
|
css={{
|
|
'&:focus': {
|
|
outline: 'none',
|
|
border: `1px solid ${borderColor || theme.colors.lightningOrange} }`
|
|
}
|
|
}}
|
|
{...rest}
|
|
value={!value && value !== 0 ? '' : value}
|
|
name={field}
|
|
ref={forwardedRef}
|
|
onChange={e => {
|
|
setValue(e.target.value)
|
|
if (onChange) {
|
|
onChange(e)
|
|
}
|
|
}}
|
|
onBlur={e => {
|
|
setTouched()
|
|
if (onBlur) {
|
|
onBlur(e)
|
|
}
|
|
}}
|
|
error={fieldState.error}
|
|
/>
|
|
{fieldState.error && (
|
|
<FormFieldMessage variant="error" justifyContent={justifyContent}>
|
|
{fieldState.error}
|
|
</FormFieldMessage>
|
|
)}
|
|
</Flex>
|
|
)
|
|
}
|
|
}
|
|
|
|
export default asField(withTheme(Input))
|
|
|