1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-10 21:18:38 +01:00
onion/js/components/ascribe_forms/form_piece_extradata.js

48 lines
1.2 KiB
JavaScript
Raw Normal View History

'use strict';
import React from 'react';
2015-06-09 17:24:06 +02:00
import fetch from '../../utils/fetch';
import apiUrls from '../../constants/api_urls';
import FormMixin from '../../mixins/form_mixin';
import InputTextAreaToggable from './input_textarea_toggable';
2015-06-09 17:24:06 +02:00
let PieceExtraDataForm = React.createClass({
mixins: [FormMixin],
url() {
2015-06-09 17:24:06 +02:00
return fetch.prepareUrl(apiUrls.piece_extradata, {piece_id: this.props.editions[0].bitcoin_id});
},
getFormData() {
2015-06-09 17:24:06 +02:00
let extradata = {};
extradata[this.props.name] = this.refs[this.props.name].state.value;
return {
bitcoin_id: this.getBitcoinIds().join(),
2015-06-09 17:24:06 +02:00
extradata: extradata
};
},
renderForm() {
return (
2015-06-09 17:24:06 +02:00
<form role="form" key={this.props.name}>
<h5>{this.props.title}</h5>
<InputTextAreaToggable
2015-06-09 17:24:06 +02:00
ref={this.props.name}
className="form-control"
2015-06-09 17:24:06 +02:00
defaultValue={this.props.editions[0].extra_data[this.props.name]}
rows={3}
editable={true}
required=""
onSubmit={this.submit}
/>
</form>
);
}
});
2015-06-09 17:24:06 +02:00
export default PieceExtraDataForm;