1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-05 11:25:09 +01:00
onion/js/components/ascribe_detail/edition_action_panel.js

193 lines
7.5 KiB
JavaScript
Raw Normal View History

2015-09-30 12:12:14 +02:00
'use strict';
import React from 'react';
2015-10-22 13:21:07 +02:00
import { History } from 'react-router';
2015-09-30 12:12:14 +02:00
import Row from 'react-bootstrap/lib/Row';
import Col from 'react-bootstrap/lib/Col';
import Button from 'react-bootstrap/lib/Button';
import EditionListActions from '../../actions/edition_list_actions';
import PieceListActions from '../../actions/piece_list_actions';
import PieceListStore from '../../stores/piece_list_store';
import Form from './../ascribe_forms/form';
import Property from './../ascribe_forms/property';
import ListRequestActions from './../ascribe_forms/list_form_request_actions';
import AclButtonList from './../ascribe_buttons/acl_button_list';
import UnConsignRequestButton from './../ascribe_buttons/unconsign_request_button';
import DeleteButton from '../ascribe_buttons/delete_button';
import GlobalNotificationModel from '../../models/global_notification_model';
import GlobalNotificationActions from '../../actions/global_notification_actions';
2015-11-03 10:39:01 +01:00
import AclInformation from '../ascribe_buttons/acl_information';
2015-09-30 12:12:14 +02:00
import AclProxy from '../acl_proxy';
import ApiUrls from '../../constants/api_urls';
import { getLangText } from '../../utils/lang_utils';
/*
A component that handles all the actions inside of the edition detail
handleSuccess requires a loadEdition action (could be refactored)
*/
2015-10-01 09:49:01 +02:00
let EditionActionPanel = React.createClass({
2015-09-30 12:12:14 +02:00
propTypes: {
currentUser: React.PropTypes.object.isRequired,
edition: React.PropTypes.object.isRequired,
whitelabel: React.PropTypes.object.isRequired,
actionPanelButtonListType: React.PropTypes.func,
2015-09-30 12:12:14 +02:00
handleSuccess: React.PropTypes.func
},
2015-10-22 13:21:07 +02:00
mixins: [History],
2015-09-30 12:12:14 +02:00
getDefaultProps() {
return {
actionPanelButtonListType: AclButtonList
};
},
2015-09-30 12:12:14 +02:00
getInitialState() {
return PieceListStore.getState();
},
componentDidMount() {
PieceListStore.listen(this.onChange);
},
componentWillUnmount() {
PieceListStore.unlisten(this.onChange);
},
onChange(state) {
this.setState(state);
},
handleDeleteSuccess(response) {
this.refreshCollection();
EditionListActions.closeAllEditionLists();
EditionListActions.clearAllEditionSelections();
const notification = new GlobalNotificationModel(response.notification, 'success');
2015-09-30 12:12:14 +02:00
GlobalNotificationActions.appendGlobalNotification(notification);
this.history.push('/collection');
2015-09-30 12:12:14 +02:00
},
refreshCollection() {
2015-12-08 15:09:03 +01:00
const { filterBy, orderAsc, orderBy, page, pageSize, search } = this.state;
2016-01-18 10:53:01 +01:00
PieceListActions.fetchPieceList({ page, pageSize, search, orderBy, orderAsc, filterBy });
EditionListActions.refreshEditionList({ pieceId: this.props.edition.parent });
2015-09-30 12:12:14 +02:00
},
handleSuccess(response) {
2015-09-30 12:12:14 +02:00
this.refreshCollection();
if (response) {
const notification = new GlobalNotificationModel(response.notification, 'success');
2015-09-30 12:12:14 +02:00
GlobalNotificationActions.appendGlobalNotification(notification);
}
if (typeof this.props.handleSuccess === 'function') {
this.props.handleSuccess();
}
2015-09-30 12:12:14 +02:00
},
render() {
const { actionPanelButtonListType: ActionPanelButtonListType,
currentUser,
2016-02-08 14:08:54 +01:00
edition,
whitelabel } = this.props;
2015-09-30 12:12:14 +02:00
if (edition.notifications && edition.notifications.length) {
2015-09-30 12:12:14 +02:00
return (
<ListRequestActions
currentUser={currentUser}
notifications={edition.notifications}
pieceOrEditions={[edition]}
handleSuccess={this.handleSuccess} />);
} else {
2015-09-30 12:12:14 +02:00
return (
<Row>
<Col md={12}>
<ActionPanelButtonListType
2015-09-30 12:12:14 +02:00
availableAcls={edition.acl}
className="ascribe-button-list"
currentUser={currentUser}
handleSuccess={this.handleSuccess}
2015-11-03 11:13:32 +01:00
pieceOrEditions={[edition]}
whitelabel={whitelabel}>
2015-09-30 12:12:14 +02:00
<AclProxy
aclObject={edition.acl}
aclName="acl_withdraw_transfer">
<Form
url={ApiUrls.ownership_transfers_withdraw}
handleSuccess={this.handleSuccess}
className='inline'
isInline={true}>
<Property
name="bitcoin_id"
expanded={false}>
2015-09-30 12:12:14 +02:00
<input
type="text"
value={edition.bitcoin_id}
readOnly />
2015-09-30 12:12:14 +02:00
</Property>
2015-11-03 10:39:01 +01:00
<Button bsStyle="default" className="pull-center" bsSize="small" type="submit">
2015-09-30 12:12:14 +02:00
{getLangText('WITHDRAW TRANSFER')}
</Button>
</Form>
</AclProxy>
<AclProxy
aclObject={edition.acl}
aclName="acl_withdraw_consign">
<Form
url={ApiUrls.ownership_consigns_withdraw}
handleSuccess={this.handleSuccess}
className='inline'
isInline={true}>
<Property
name="bitcoin_id"
expanded={false}>
2015-09-30 12:12:14 +02:00
<input
type="text"
value={edition.bitcoin_id}
readOnly />
2015-09-30 12:12:14 +02:00
</Property>
<Button bsStyle="danger" className="btn-delete pull-center" bsSize="small" type="submit">
{getLangText('WITHDRAW CONSIGN')}
</Button>
</Form>
</AclProxy>
<AclProxy
aclObject={edition.acl}
aclName="acl_request_unconsign">
<UnConsignRequestButton
currentUser={currentUser}
edition={edition}
handleSuccess={this.handleSuccess} />
</AclProxy>
<DeleteButton
handleSuccess={this.handleDeleteSuccess}
editions={[edition]}/>
2015-11-03 10:39:01 +01:00
<AclInformation
aim="button"
2015-11-19 19:47:33 +01:00
verbs={['acl_share', 'acl_transfer', 'acl_consign', 'acl_loan', 'acl_delete']}
2015-11-03 10:39:01 +01:00
aclObject={edition.acl}/>
</ActionPanelButtonListType>
2015-09-30 12:12:14 +02:00
</Col>
</Row>
);
}
}
});
export default EditionActionPanel;