const bindAll = require('lodash.bindall'); const classNames = require('classnames'); const React = require('react'); const PropTypes = require('prop-types'); import {Formik} from 'formik'; const {injectIntl, intlShape} = require('react-intl'); const FormattedMessage = require('react-intl').FormattedMessage; const FormikSelect = require('../../components/formik-forms/formik-select.jsx'); const JoinFlowStep = require('./join-flow-step.jsx'); const InfoButton = require('../info-button/info-button.jsx'); require('./join-flow-steps.scss'); const getBirthMonthOptions = intl => ([ {value: 'null', label: intl.formatMessage({id: 'general.month'}), disabled: true}, {value: '1', label: intl.formatMessage({id: 'general.monthJanuary'})}, {value: '2', label: intl.formatMessage({id: 'general.monthFebruary'})}, {value: '3', label: intl.formatMessage({id: 'general.monthMarch'})}, {value: '4', label: intl.formatMessage({id: 'general.monthApril'})}, {value: '5', label: intl.formatMessage({id: 'general.monthMay'})}, {value: '6', label: intl.formatMessage({id: 'general.monthJune'})}, {value: '7', label: intl.formatMessage({id: 'general.monthJuly'})}, {value: '8', label: intl.formatMessage({id: 'general.monthAugust'})}, {value: '9', label: intl.formatMessage({id: 'general.monthSeptember'})}, {value: '10', label: intl.formatMessage({id: 'general.monthOctober'})}, {value: '11', label: intl.formatMessage({id: 'general.monthNovember'})}, {value: '12', label: intl.formatMessage({id: 'general.monthDecember'})} ]); const getBirthYearOptions = intl => { const curYearRaw = (new Date()).getYear(); const curYear = curYearRaw + 1900; // including both 1900 and current year, there are (curYearRaw + 1) options. const numYearOptions = curYearRaw + 1; const birthYearOptions = Array(numYearOptions).fill() .map((defaultVal, i) => ( {value: String(curYear - i), label: String(curYear - i)} )); birthYearOptions.unshift({ // set placeholder as first option disabled: true, value: 'null', label: intl.formatMessage({id: 'general.year'}) }); return birthYearOptions; }; class BirthDateStep extends React.Component { constructor (props) { super(props); bindAll(this, [ 'handleValidSubmit', 'validateForm', 'validateSelect' ]); } componentDidMount () { this.props.sendAnalytics('join-birthdate'); } validateSelect (selection) { if (selection === 'null') { return this.props.intl.formatMessage({id: 'general.required'}); } return null; } validateForm () { return {}; } handleValidSubmit (formData, formikBag) { formikBag.setSubmitting(false); this.props.onNextStep(formData); } render () { const birthMonthOptions = getBirthMonthOptions(this.props.intl); const birthYearOptions = getBirthYearOptions(this.props.intl); return ( {props => { const { errors, handleSubmit, isSubmitting, setFieldError } = props; return (
setFieldError('birth_month', null)} /* eslint-enable react/jsx-no-bind */ /> setFieldError('birth_year', null)} /* eslint-enable react/jsx-no-bind */ />
); }}
); } } BirthDateStep.propTypes = { intl: intlShape, onNextStep: PropTypes.func, sendAnalytics: PropTypes.func }; const IntlBirthDateStep = injectIntl(BirthDateStep); module.exports = IntlBirthDateStep;