scratch-www/src/views/studentcompleteregistration/studentcompleteregistration.jsx

177 lines
7.4 KiB
React
Raw Normal View History

2018-01-30 09:54:45 -05:00
var connect = require('react-redux').connect;
var defaults = require('lodash.defaultsdeep');
var React = require('react');
var render = require('../../lib/render.jsx');
2016-07-21 16:56:01 -04:00
2018-01-30 09:54:45 -05:00
var sessionStatus = require('../../redux/session').Status;
var api = require('../../lib/api');
var intl = require('../../lib/intl.jsx');
var log = require('../../lib/log.js');
2016-07-21 16:56:01 -04:00
2018-01-30 09:54:45 -05:00
var Deck = require('../../components/deck/deck.jsx');
var Progression = require('../../components/progression/progression.jsx');
var Spinner = require('../../components/spinner/spinner.jsx');
var Steps = require('../../components/registration/steps.jsx');
2016-07-21 16:56:01 -04:00
require('./studentcompleteregistration.scss');
2018-01-30 09:54:45 -05:00
var StudentCompleteRegistration = intl.injectIntl(React.createClass({
type: 'StudentCompleteRegistration',
getInitialState: function () {
return {
2016-07-21 16:56:01 -04:00
classroom: null,
formData: {},
registrationErrors: null,
2016-07-21 16:56:01 -04:00
step: 0,
waiting: false
};
2018-01-30 09:54:45 -05:00
},
advanceStep: function (formData) {
formData = formData || {};
this.setState({
step: this.state.step + 1,
formData: defaults({}, formData, this.state.formData)
});
},
componentDidUpdate: function (prevProps) {
if (prevProps.studentUsername !== this.props.studentUsername && this.props.newStudent) {
2018-01-30 09:54:45 -05:00
this.setState({waiting: true});
2016-07-21 16:56:01 -04:00
api({
2018-01-30 09:54:45 -05:00
uri: '/classrooms/' + this.props.classroomId
}, function (err, body, res) {
this.setState({waiting: false});
if (err || res.statusCode !== 200) {
2016-07-21 16:56:01 -04:00
return this.setState({
registrationErrors: {
__all__: this.props.intl.formatMessage({id: 'registration.classroomApiGeneralError'})
}
2016-07-21 16:56:01 -04:00
});
}
this.setState({classroom: body});
2018-01-30 09:54:45 -05:00
}.bind(this));
2016-07-21 16:56:01 -04:00
}
2018-01-30 09:54:45 -05:00
},
handleLogOut: function (e) {
e.preventDefault();
api({
host: '',
method: 'post',
uri: '/accounts/logout/',
useCsrf: true
2018-01-30 09:54:45 -05:00
}, function (err) {
if (err) return log.error(err);
window.location = '/';
2018-01-30 09:54:45 -05:00
}.bind(this));
},
register: function (formData) {
2016-07-21 16:56:01 -04:00
this.setState({waiting: true});
formData = defaults({}, formData || {}, this.state.formData);
2018-01-30 09:54:45 -05:00
var submittedData = {
2016-07-21 16:56:01 -04:00
birth_month: formData.user.birth.month,
birth_year: formData.user.birth.year,
2018-01-30 09:54:45 -05:00
gender: (
formData.user.gender === 'other' ?
formData.user.genderOther :
formData.user.gender
),
2016-07-21 16:56:01 -04:00
country: formData.user.country,
is_robot: formData.user.isRobot
};
if (this.props.must_reset_password) {
2016-07-21 16:56:01 -04:00
submittedData.password = formData.user.password;
}
api({
host: '',
uri: '/classes/student_update_registration/',
method: 'post',
useCsrf: true,
formData: submittedData
2018-01-30 09:54:45 -05:00
}, function (err, body, res) {
2016-07-21 16:56:01 -04:00
this.setState({waiting: false});
if (err) return this.setState({registrationError: err});
2018-01-30 09:54:45 -05:00
if (body.success) return this.advanceStep(formData);
this.setState({
2018-01-30 09:54:45 -05:00
registrationErrors:
body.errors || {
__all__:
this.props.intl.formatMessage({id: 'registration.generalError'}) +
' (' + res.statusCode + ')'
}
});
2018-01-30 09:54:45 -05:00
}.bind(this));
},
goToClass: function () {
window.location = '/classes/' + this.state.classroom.id + '/';
},
render: function () {
var demographicsDescription = this.props.intl.formatMessage({
id: 'registration.studentPersonalStepDescription'});
var registrationErrors = this.state.registrationErrors;
if (!this.props.newStudent) {
registrationErrors = {
__all__: this.props.intl.formatMessage({id: 'registration.mustBeNewStudent'})
};
2016-07-21 16:56:01 -04:00
}
return (
<Deck className="student-registration">
{registrationErrors ? (
<Steps.RegistrationError>
<ul>
2018-01-30 09:54:45 -05:00
{Object.keys(registrationErrors).map(function (field) {
var label = field + ': ';
if (field === '__all__') {
label = '';
}
2018-01-30 09:54:45 -05:00
return (<li>{label}{registrationErrors[field]}</li>);
})}
</ul>
</Steps.RegistrationError>
) : (
this.state.waiting || !this.state.classroom ? (
<Spinner />
) : (
2016-07-21 16:56:01 -04:00
<Progression {... this.state}>
2018-01-30 09:54:45 -05:00
<Steps.ClassInviteExistingStudentStep classroom={this.state.classroom}
onHandleLogOut={this.handleLogOut}
onNextStep={this.advanceStep}
studentUsername={this.props.studentUsername}
waiting={this.state.waiting} />
{this.props.must_reset_password ?
2018-01-30 09:54:45 -05:00
<Steps.ChoosePasswordStep onNextStep={this.advanceStep}
showPassword={true}
waiting={this.state.waiting}
username={this.props.studentUsername} />
:
[]
2016-07-21 16:56:01 -04:00
}
2018-01-30 09:54:45 -05:00
<Steps.DemographicsStep description={demographicsDescription}
onNextStep={this.register}
waiting={this.state.waiting} />
<Steps.ClassWelcomeStep classroom={this.state.classroom}
onNextStep={this.goToClass}
waiting={this.state.waiting} />
2016-07-21 16:56:01 -04:00
</Progression>
)
)}
2016-07-21 16:56:01 -04:00
</Deck>
);
}
2018-01-30 09:54:45 -05:00
}));
2016-07-21 16:56:01 -04:00
2018-01-30 09:54:45 -05:00
var mapStateToProps = function (state) {
return {
classroomId: state.session.session.user && state.session.session.user.classroomId,
must_reset_password: state.session.session.flags && state.session.session.flags.must_reset_password,
newStudent: (
state.session.session.permissions &&
state.session.session.permissions.student &&
state.session.session.flags.must_complete_registration),
sessionFetched: state.session.status === sessionStatus.FETCHED,
studentUsername: state.session.session.user && state.session.session.user.username
};
2016-07-21 16:56:01 -04:00
};
2018-01-30 09:54:45 -05:00
var ConnectedStudentCompleteRegistration = connect(mapStateToProps)(StudentCompleteRegistration);
2016-07-21 16:56:01 -04:00
render(<ConnectedStudentCompleteRegistration />, document.getElementById('app'));