1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-05 11:25:09 +01:00
onion/js/mixins/form_mixin.js
2015-06-08 14:51:13 +02:00

80 lines
2.0 KiB
JavaScript

'use strict';
import fetch from '../utils/fetch';
import React from 'react';
import AlertDismissable from '../components/ascribe_forms/alert';
export const FormMixin = {
getInitialState() {
return {
submitted: false,
errors: []
};
},
submit(e) {
e.preventDefault();
this.setState({submitted: true});
this.clearErrors();
fetch
.post(this.url(), { body: this.getFormData() })
.then(() => this.props.handleSuccess())
.catch(this.handleError);
},
clearErrors(){
for (var ref in this.refs){
this.refs[ref].clearAlerts();
}
this.setState({errors: []});
},
handleError(err){
if (err.json) {
for (var input in err.json.errors){
if (this.refs && this.refs[input] && this.refs[input].state) {
this.refs[input].setAlerts( err.json.errors[input]);
} else {
this.setState({errors: this.state.errors.concat(err.json.errors[input])});
}
}
}
else {
this.setState({errors: ['Something went wrong, please try again later']});
}
this.setState({submitted: false});
},
getBitcoinIds(){
return this.props.editions.map(function(edition){
return edition.bitcoin_id;
});
},
getTitlesString(){
return this.props.editions.map(function(edition){
return '- \"' + edition.title + ', edition ' + edition.edition_number + '\"\n';
});
},
render(){
let alert = null;
if (this.state.errors.length > 0){
alert = this.state.errors.map((error) => {
return <AlertDismissable error={error} key={error}/>;
});
}
return (
<div>
{alert}
{this.renderForm()}
</div>
);
}
};
export default FormMixin;