2015-05-29 01:54:56 +02:00
|
|
|
import React from 'react';
|
|
|
|
|
2015-05-29 15:16:42 +02:00
|
|
|
import EditionActions from '../actions/edition_actions'
|
2015-05-29 01:54:56 +02:00
|
|
|
import AppConstants from '../constants/application_constants'
|
|
|
|
import AlertDismissable from '../components/ascribe_forms/alert'
|
|
|
|
|
|
|
|
export const FormMixin = {
|
|
|
|
getInitialState() {
|
|
|
|
return {
|
|
|
|
submitted: false
|
|
|
|
, status: null
|
2015-05-29 15:16:42 +02:00
|
|
|
, errors: []
|
2015-05-29 01:54:56 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
submit(e) {
|
|
|
|
e.preventDefault();
|
2015-05-29 10:58:07 +02:00
|
|
|
for (var ref in this.refs){
|
|
|
|
this.refs[ref].clearAlerts();
|
|
|
|
}
|
2015-05-29 15:16:42 +02:00
|
|
|
this.setState({submitted: true, errors: []});
|
2015-05-29 01:54:56 +02:00
|
|
|
fetch(this.url(), {
|
|
|
|
method: 'post',
|
|
|
|
headers: {
|
|
|
|
'Authorization': 'Basic ' + AppConstants.debugCredentialBase64,
|
|
|
|
'Accept': 'application/json',
|
|
|
|
'Content-Type': 'application/json'
|
|
|
|
},
|
|
|
|
body: JSON.stringify(this.getFormData())
|
|
|
|
})
|
|
|
|
.then(
|
|
|
|
(response) => this.handleResponse(response)
|
|
|
|
);
|
|
|
|
},
|
|
|
|
handleResponse(response){
|
2015-05-29 15:16:42 +02:00
|
|
|
let submitted = false;
|
2015-05-29 01:54:56 +02:00
|
|
|
if (response.status >= 200 && response.status < 300){
|
2015-05-29 15:16:42 +02:00
|
|
|
EditionActions.fetchOne(this.props.edition.id);
|
2015-05-29 01:54:56 +02:00
|
|
|
this.props.onRequestHide();
|
2015-05-29 15:16:42 +02:00
|
|
|
submitted = true;
|
2015-05-29 01:54:56 +02:00
|
|
|
}
|
|
|
|
else if (response.status >= 400 && response.status < 500) {
|
|
|
|
this.handleError(response);
|
|
|
|
}
|
2015-05-29 15:16:42 +02:00
|
|
|
this.setState({submitted: submitted, status: response.status});
|
2015-05-29 01:54:56 +02:00
|
|
|
},
|
|
|
|
handleError(response){
|
|
|
|
response.json().then((response) => this.dispatchErrors(response.errors));
|
|
|
|
|
|
|
|
},
|
|
|
|
dispatchErrors(errors){
|
|
|
|
for (var input in errors){
|
|
|
|
if (this.refs && this.refs[input] && this.refs[input].state){
|
|
|
|
this.refs[input].setAlerts(errors[input]);
|
|
|
|
}
|
2015-05-29 15:16:42 +02:00
|
|
|
else{
|
|
|
|
this.setState({errors: this.state.errors.concat(errors[input])});
|
|
|
|
}
|
2015-05-29 01:54:56 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
render(){
|
|
|
|
let alert = null;
|
|
|
|
if (this.state.status >= 500){
|
|
|
|
alert = <AlertDismissable error="Something went wrong, please try again later"/>;
|
|
|
|
}
|
2015-05-29 15:16:42 +02:00
|
|
|
if (this.state.errors.length > 0){
|
|
|
|
alert = this.state.errors.map(
|
|
|
|
function(error) {
|
|
|
|
return <AlertDismissable error={error} key={error}/>;
|
|
|
|
}.bind(this)
|
|
|
|
);
|
|
|
|
}
|
2015-05-29 01:54:56 +02:00
|
|
|
return (
|
|
|
|
<div>
|
|
|
|
{alert}
|
|
|
|
{this.renderForm()}
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export default FormMixin;
|
|
|
|
|