var React = require("react/addons"),
UserRegistration = require('../../models/userRegistration'),
RibicaValidationMixin = require('../../components/shared/mixins/ribicaValidationMixin'),
UserStore = require('../../stores/userStore'),
NavigationActions = require('../../actions/navigationActions'),
UserActions = require('../../actions/userActions'),
ValidationUtils = require('../../utils/validation');
var Register = React.createClass({
mixins: [React.addons.LinkedStateMixin, RibicaValidationMixin],
getInitialState: function() {
return {
myBabyDetailsVisible: false,
firstName: '',
lastName: '',
email: '',
password: '',
passwordConfirmation: '',
registration: UserStore.getRegistrationState(),
myBabyDOBDay: -1,
myBabyDOBMonth: -1,
myBabyDOBYear: -1,
myBabyOnTheWay: true,
loginState : UserStore.getLoginState()
};
},
myBabyChange: function(e) {
this.setState({
myBabyDetailsVisible: true,
myBabyOnTheWay: (e.currentTarget.value === "1" ? true: false)
});
},
onKeyPress: function(e) {
var enterKeyCode = 13;
if(e.which == enterKeyCode) {
this.doRegister();
}
},
renderMonthSelector: function() {
var months = ['Januar', 'Februar', 'Mart', 'April', 'Maj', 'Juni',
'Juli','August','Septembar', 'Oktobar','Novembar','Decembar'];
var monthsSelect = [];
for(var i = 1; i <= months.length; i++) {
monthsSelect.push()
}
return ()
},
renderYearSelector: function() {
var currentYear = (new Date().getFullYear());
var years = [];
years.push()
for(var i = 0; i < 12; i++) {
years.push()
}
return ()
},
renderDaySelector: function() {
var days = [];
days.push()
for(var i = 1; i <= 31; i++) {
days.push()
}
return ()
},
onBabyDOBDayChange: function(e) {
this.setState({
myBabyDOBDay: e.currentTarget.value
});
},
onBabyDOBMonthChange: function(e) {
this.setState({
myBabyDOBMonth: e.currentTarget.value
});
},
onBabyDOBYearChange: function(e) {
this.setState({
myBabyDOBYear: e.currentTarget.value
});
},
myBabyNameChange: function(e) {
this.setState({
babyName: e.currentTarget.value
});
},
myBabyGenderChange: function(e) {
this.setState({
babyGender: e.currentTarget.value
});
},
validations: {
firstName: function(value) {
if (!ValidationUtils.isValidRequired(value)) {
return ["Ime je obavezno."];
}
},
password: function(value, callback) {
if(!ValidationUtils.isValidRequired(value)) {
return ["Šifra je obavezna."];
}
if (value.length < 6) {
return ["Šifra mora sadržavati minimalno 6 karaktera."]
}
if (callback) {
callback([], ["passwordConfirmation"]);
}
},
passwordConfirmation: function(value) {
if (this.getState().password !== value) {
return ["Šifre se ne podudaraju."];
}
},
lastName : function(value) {
if (!ValidationUtils.isValidRequired(value)) {
return ["Prezime je obavezno."];
}
},
_emailTimeoutId: null,
email: function(value, callback) {
if (ValidationUtils.isValidEmail(value)) {
//clearTimeout(this._emailTimeoutId);
//this._emailTimeoutId = setTimeout(function(){
//// TODO: check if email exists
//if (value === 'edin@edin.com') {
//if(callback) {
//var errors= ['Email is already taken'];
//callback(errors);
//}
//} else {
//if(callback) {
//callback([]);
//}
//}
//}.bind(this), 1000);
} else {
return ['Neispravna email adresa.'];
}
}
},
renderGenderImage: function() {
if(this.state.babyGender === "boy") {
return
} else if (this.state.babyGender === "girl") {
return
}
return
},
renderErrorMessage: function(message){
return (