const bindAll = require('lodash.bindall'); const classNames = require('classnames'); const formsyComponent = require('formsy-react-components/release/hoc/component').default; const omit = require('lodash.omit'); const PropTypes = require('prop-types'); const React = require('react'); const ReactPhoneInput = require('react-telephone-input/lib/withStyles').default; const Row = require('formsy-react-components').Row; const defaultValidationHOC = require('./validations.jsx').defaultValidationHOC; const inputHOC = require('./input-hoc.jsx'); const intl = require('../../lib/intl.jsx'); const validationHOCFactory = require('./validations.jsx').validationHOCFactory; require('./row.scss'); require('./phone-input.scss'); class PhoneInput extends React.Component { constructor (props) { super(props); bindAll(this, [ 'handleChange', 'handleBlur' ]); this.state = {value: props.value}; } componentWillReceiveProps (nextProps) { if (nextProps.value !== this.state.value) { this.setState({value: nextProps.value}); this.props.onSetValue(nextProps.value); } } handleChange (number) { if (this.props.updateOnChange) { this.props.onSetValue(number); } } handleBlur (number) { if (this.props.updateOnBlur) { this.props.onSetValue(number); } } render () { return (
); } } PhoneInput.defaultProps = { type: 'tel', value: '', updateOnChange: true }; PhoneInput.propTypes = { className: PropTypes.string, defaultCountry: PropTypes.string, disabled: PropTypes.bool, id: PropTypes.string, name: PropTypes.string, onChange: PropTypes.func, onSetValue: PropTypes.func, updateOnBlur: PropTypes.bool, updateOnChange: PropTypes.bool, value: PropTypes.string }; const phoneValidationHOC = validationHOCFactory({ isPhone: }); module.exports = inputHOC(phoneValidationHOC(defaultValidationHOC(formsyComponent(PhoneInput))));