scratch-www/src/components/forms/phone-input.jsx

71 lines
2.6 KiB
React
Raw Normal View History

2018-01-30 09:54:45 -05:00
var allCountries = require('react-telephone-input/lib/country_data').allCountries;
var classNames = require('classnames');
var ComponentMixin = require('formsy-react-components').ComponentMixin;
var FormsyMixin = require('formsy-react').Mixin;
var React = require('react');
var ReactPhoneInput = require('react-telephone-input/lib/withStyles');
var Row = require('formsy-react-components').Row;
2018-01-30 09:54:45 -05:00
var defaultValidationHOC = require('./validations.jsx').defaultValidationHOC;
var inputHOC = require('./input-hoc.jsx');
var intl = require('../../lib/intl.jsx');
var validationHOCFactory = require('./validations.jsx').validationHOCFactory;
2016-06-02 15:25:02 -04:00
2018-01-30 09:54:45 -05:00
var allIso2 = allCountries.map(function (country) {return country.iso2;});
require('./row.scss');
2016-06-23 07:27:43 -04:00
require('./phone-input.scss');
2018-01-30 09:54:45 -05:00
var PhoneInput = React.createClass({
2016-06-02 15:25:02 -04:00
displayName: 'PhoneInput',
mixins: [
FormsyMixin,
ComponentMixin
],
getDefaultProps: function () {
return {
validations: {
2016-08-10 07:53:49 -04:00
isPhone: true
2016-06-02 15:25:02 -04:00
},
flagsImagePath: '/images/flags.png',
defaultCountry: 'us'
2016-06-02 15:25:02 -04:00
};
},
2018-01-30 09:54:45 -05:00
onChangeInput: function (number, country) {
var value = {national_number: number, country_code: country};
2016-06-02 15:25:02 -04:00
this.setValue(value);
this.props.onChange(this.props.name, value);
},
render: function () {
2018-01-30 09:54:45 -05:00
var defaultCountry = PhoneInput.getDefaultProps().defaultCountry;
if (allIso2.indexOf(this.props.defaultCountry.toLowerCase()) !== -1) {
2018-01-30 09:54:45 -05:00
defaultCountry = this.props.defaultCountry.toLowerCase();
}
2016-06-02 15:25:02 -04:00
return (
2018-01-30 09:54:45 -05:00
<Row {... this.getRowProperties()}
htmlFor={this.getId()}
rowClassName={classNames('phone-input', this.props.className)}
2016-06-02 15:25:02 -04:00
>
<div className="input-group">
2018-01-30 09:54:45 -05:00
<ReactPhoneInput className="form-control"
{... this.props}
defaultCountry={defaultCountry}
onChange={this.onChangeInput}
id={this.getId()}
label={null}
disabled={this.isFormDisabled() || this.props.disabled}
2016-06-02 15:25:02 -04:00
/>
{this.renderHelp()}
{this.renderErrorMessage()}
2016-06-02 15:25:02 -04:00
</div>
</Row>
);
}
});
2018-01-30 09:54:45 -05:00
var phoneValidationHOC = validationHOCFactory({
2016-08-10 07:53:49 -04:00
isPhone: <intl.FormattedMessage id="teacherRegistration.validationPhoneNumber" />
2016-06-02 15:25:02 -04:00
});
module.exports = inputHOC(defaultValidationHOC(phoneValidationHOC(PhoneInput)));