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))));