1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-11 05:29:06 +01:00
onion/js/components/ascribe_buttons/acl_button.js

210 lines
6.8 KiB
JavaScript
Raw Normal View History

'use strict';
2015-05-27 14:35:33 +02:00
import React from 'react';
2015-06-03 10:27:11 +02:00
import ConsignForm from '../ascribe_forms/form_consign';
import UnConsignForm from '../ascribe_forms/form_unconsign';
2015-06-03 10:27:11 +02:00
import TransferForm from '../ascribe_forms/form_transfer';
import LoanForm from '../ascribe_forms/form_loan';
import ShareForm from '../ascribe_forms/form_share_email';
import ModalWrapper from '../ascribe_modal/modal_wrapper';
import AppConstants from '../../constants/application_constants';
2015-05-27 14:35:33 +02:00
import GlobalNotificationModel from '../../models/global_notification_model';
import GlobalNotificationActions from '../../actions/global_notification_actions';
import { getLangText } from '../../utils/lang_utils.js';
2015-07-13 14:10:46 +02:00
import apiUrls from '../../constants/api_urls';
2015-07-03 19:08:56 +02:00
2015-05-27 14:35:33 +02:00
let AclButton = React.createClass({
propTypes: {
action: React.PropTypes.oneOf(AppConstants.aclList).isRequired,
availableAcls: React.PropTypes.object.isRequired,
pieceOrEditions: React.PropTypes.oneOfType([
React.PropTypes.object,
React.PropTypes.array
]).isRequired,
2015-06-02 11:38:18 +02:00
currentUser: React.PropTypes.object,
2015-07-01 10:53:40 +02:00
handleSuccess: React.PropTypes.func.isRequired,
className: React.PropTypes.string
2015-05-27 14:35:33 +02:00
},
2015-07-13 14:10:46 +02:00
isPiece(){
return !(this.props.pieceOrEditions.constructor === Array);
},
2015-06-01 18:59:47 +02:00
actionProperties(){
if (this.props.action === 'acl_consign'){
2015-06-01 18:59:47 +02:00
return {
2015-07-03 19:08:56 +02:00
title: getLangText('Consign artwork'),
tooltip: getLangText('Have someone else sell the artwork'),
2015-07-14 14:16:51 +02:00
form: (
<ConsignForm
message={this.getConsignMessage()}
id={this.getFormDataId()}
url={apiUrls.ownership_consigns}/>
),
handleSuccess: this.showNotification
};
2015-06-01 18:59:47 +02:00
}
if (this.props.action === 'acl_unconsign'){
return {
2015-07-03 19:08:56 +02:00
title: getLangText('Unconsign artwork'),
tooltip: getLangText('Have the owner manage his sales again'),
2015-07-14 17:42:15 +02:00
form: (
<UnConsignForm
message={this.getUnConsignMessage()}
id={this.getFormDataId()}
url={apiUrls.ownership_unconsigns}/>
),
handleSuccess: this.showNotification
};
}else if (this.props.action === 'acl_transfer') {
2015-06-01 18:59:47 +02:00
return {
2015-07-03 19:08:56 +02:00
title: getLangText('Transfer artwork'),
tooltip: getLangText('Transfer the ownership of the artwork'),
2015-07-14 11:42:09 +02:00
form: (
<TransferForm
message={this.getTransferMessage()}
id={this.getFormDataId()}
url={apiUrls.ownership_transfers}/>
),
handleSuccess: this.showNotification
};
2015-06-01 18:59:47 +02:00
}
else if (this.props.action === 'acl_loan'){
2015-06-01 18:59:47 +02:00
return {
2015-07-03 19:08:56 +02:00
title: getLangText('Loan artwork'),
tooltip: getLangText('Loan your artwork for a limited period of time'),
form: <LoanForm currentUser={ this.props.currentUser } editions={ this.props.pieceOrEditions }/>,
handleSuccess: this.showNotification
};
2015-06-01 18:59:47 +02:00
}
else if (this.props.action === 'acl_share'){
2015-06-01 18:59:47 +02:00
return {
2015-07-03 19:08:56 +02:00
title: getLangText('Share artwork'),
tooltip: getLangText('Share the artwork'),
2015-07-13 14:10:46 +02:00
form: (
<ShareForm
message={this.getShareMessage()}
id={this.getFormDataId()}
url={this.isPiece() ? apiUrls.ownership_shares_pieces : apiUrls.ownership_shares_editions }/>
),
handleSuccess: this.showNotification
};
} else {
throw new Error('Your specified action did not match a form.');
2015-06-01 18:59:47 +02:00
}
},
2015-07-13 14:10:46 +02:00
showNotification(response){
this.props.handleSuccess();
let notification = new GlobalNotificationModel(response.notification, 'success');
GlobalNotificationActions.appendGlobalNotification(notification);
},
2015-07-13 14:10:46 +02:00
2015-07-13 23:57:16 +02:00
// plz move to share form
2015-07-13 14:10:46 +02:00
getTitlesString(){
if (this.isPiece()){
return '\"' + this.props.pieceOrEditions.title + '\"';
}
else {
return this.props.pieceOrEditions.map(function(edition) {
return '- \"' + edition.title + ', ' + getLangText('edition') + ' ' + edition.edition_number + '\"\n';
}).join('');
}
},
getFormDataId(){
if (this.isPiece()) {
return {piece_id: this.props.pieceOrEditions.id};
}
else {
return {bitcoin_id: this.props.pieceOrEditions.map(function(edition){
return edition.bitcoin_id;
}).join()};
}
},
2015-07-14 14:16:51 +02:00
// plz move to transfer form
2015-07-14 11:42:09 +02:00
getTransferMessage(){
2015-07-13 17:09:44 +02:00
return (
2015-07-14 11:42:09 +02:00
`${getLangText('Hi')},
${getLangText('I transfer ownership of')}:
${this.getTitlesString()} ${getLangText('to you')}.
2015-07-14 14:16:51 +02:00
${getLangText('Truly yours')},
${this.props.currentUser.username}
`
);
},
// plz move to consign form
getConsignMessage(){
return (
`${getLangText('Hi')},
${getLangText('I consign')}:
${this.getTitlesString()} ${getLangText('to you')}.
2015-07-14 17:42:15 +02:00
${getLangText('Truly yours')},
${this.props.currentUser.username}
`
);
},
// plz move to consign form
getUnConsignMessage(){
return (
`${getLangText('Hi')},
${getLangText('I un-consign')}:
${this.getTitlesString()} ${getLangText('from you')}.
2015-07-14 11:42:09 +02:00
${getLangText('Truly yours')},
${this.props.currentUser.username}
2015-07-13 17:09:44 +02:00
`
2015-07-14 11:42:09 +02:00
);
},
// plz move to share form
getShareMessage(){
return (
`${getLangText('Hi')},
2015-07-13 17:09:44 +02:00
${getLangText('I am sharing')}:
${this.getTitlesString()} ${getLangText('with you')}.
${getLangText('Truly yours')},
${this.props.currentUser.username}
`
);
},
// Removes the acl_ prefix and converts to upper case
sanitizeAction() {
return this.props.action.split('acl_')[1].toUpperCase();
},
2015-05-27 14:35:33 +02:00
render() {
let shouldDisplay = this.props.availableAcls[this.props.action];
2015-06-01 18:59:47 +02:00
let aclProps = this.actionProperties();
2015-05-27 14:35:33 +02:00
return (
2015-06-01 18:59:47 +02:00
<ModalWrapper
button={
2015-07-01 10:53:40 +02:00
<button className={shouldDisplay ? 'btn btn-default btn-sm ' : 'hidden'}>
{this.sanitizeAction()}
2015-06-30 17:12:13 +02:00
</button>
2015-06-01 18:59:47 +02:00
}
handleSuccess={ aclProps.handleSuccess }
2015-06-01 18:59:47 +02:00
title={ aclProps.title }
tooltip={ aclProps.tooltip }>
{ aclProps.form }
</ModalWrapper>
2015-05-27 14:35:33 +02:00
);
}
});
export default AclButton;