mirror of
https://github.com/ascribe/onion.git
synced 2025-01-23 16:23:33 +01:00
113 lines
3.4 KiB
JavaScript
113 lines
3.4 KiB
JavaScript
'use strict';
|
|
|
|
import React from 'react';
|
|
|
|
import Alert from 'react-bootstrap/lib/Alert';
|
|
|
|
import ApiUrls from '../../constants/api_urls';
|
|
import FormMixin from '../../mixins/form_mixin';
|
|
|
|
import AclButton from './../ascribe_buttons/acl_button';
|
|
import ActionPanel from '../ascribe_panel/action_panel';
|
|
|
|
import AppConstants from '../../constants/application_constants';
|
|
import { getLangText } from '../../utils/lang_utils.js';
|
|
|
|
let RequestActionForm = React.createClass({
|
|
mixins: [FormMixin],
|
|
|
|
url(e){
|
|
let edition = this.props.editions[0];
|
|
if (e.target.id === 'request_accept'){
|
|
if (edition.request_action === 'consign'){
|
|
return ApiUrls.ownership_consigns_confirm;
|
|
}
|
|
else if (edition.request_action === 'unconsign'){
|
|
return ApiUrls.ownership_unconsigns;
|
|
}
|
|
else if (edition.request_action === 'loan'){
|
|
return ApiUrls.ownership_loans_confirm;
|
|
}
|
|
}
|
|
else if(e.target.id === 'request_deny'){
|
|
if (edition.request_action === 'consign') {
|
|
return ApiUrls.ownership_consigns_deny;
|
|
}
|
|
else if (edition.request_action === 'unconsign') {
|
|
return ApiUrls.ownership_unconsigns_deny;
|
|
}
|
|
else if (edition.request_action === 'loan') {
|
|
return ApiUrls.ownership_loans_deny;
|
|
}
|
|
}
|
|
},
|
|
|
|
handleRequest: function(e){
|
|
e.preventDefault();
|
|
this.submit(e);
|
|
},
|
|
|
|
getFormData() {
|
|
return {
|
|
bitcoin_id: this.getBitcoinIds().join()
|
|
};
|
|
},
|
|
|
|
getContent() {
|
|
let edition = this.props.editions[0];
|
|
let message = edition.owner + ' ' + getLangText('requests you') + ' ' + edition.request_action + ' ' + getLangText('this edition%s', '.');
|
|
|
|
return (
|
|
<span>
|
|
{message}
|
|
</span>
|
|
);
|
|
},
|
|
|
|
renderForm() {
|
|
let edition = this.props.editions[0];
|
|
let buttonAccept = (
|
|
<div id="request_accept"
|
|
onClick={this.handleRequest}
|
|
className='btn btn-default btn-sm ascribe-margin-1px'>{getLangText('ACCEPT')}
|
|
</div>);
|
|
if (edition.request_action === 'unconsign') {
|
|
buttonAccept = (
|
|
<AclButton
|
|
availableAcls={{'acl_unconsign': true}}
|
|
action="acl_unconsign"
|
|
pieceOrEditions={this.props.editions}
|
|
currentUser={this.props.currentUser}
|
|
handleSuccess={this.props.handleSuccess} />
|
|
);
|
|
}
|
|
let buttons = (
|
|
<span>
|
|
<span>
|
|
{buttonAccept}
|
|
</span>
|
|
<span>
|
|
<div id="request_deny" onClick={this.handleRequest} className='btn btn-danger btn-delete btn-sm ascribe-margin-1px'>{getLangText('REJECT')}</div>
|
|
</span>
|
|
</span>
|
|
);
|
|
if (this.state.submitted){
|
|
buttons = (
|
|
<span>
|
|
<img src={AppConstants.baseUrl + 'static/img/ascribe_animated_medium.gif'} />
|
|
</span>
|
|
);
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
<ActionPanel
|
|
content={this.getContent()}
|
|
buttons={buttons}/>
|
|
);
|
|
}
|
|
});
|
|
|
|
|
|
export default RequestActionForm; |