2015-09-30 12:12:14 +02:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
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';
|
|
|
|
|
2016-06-08 13:52:24 +02:00
|
|
|
import GlobalNotificationModel from '../../models/global_notification_model';
|
|
|
|
import GlobalNotificationActions from '../../actions/global_notification_actions';
|
|
|
|
|
2015-09-30 12:12:14 +02:00
|
|
|
import Form from './../ascribe_forms/form';
|
2016-06-08 13:52:24 +02:00
|
|
|
import ListRequestActions from './../ascribe_forms/list_form_request_actions';
|
2015-09-30 12:12:14 +02:00
|
|
|
import Property from './../ascribe_forms/property';
|
|
|
|
|
|
|
|
import AclButtonList from './../ascribe_buttons/acl_button_list';
|
2015-11-03 10:39:01 +01:00
|
|
|
import AclInformation from '../ascribe_buttons/acl_information';
|
2016-06-08 13:52:24 +02:00
|
|
|
import DeleteButton from '../ascribe_buttons/delete_button';
|
|
|
|
import UnConsignRequestButton from './../ascribe_buttons/unconsign_request_button';
|
2015-11-03 10:39:01 +01:00
|
|
|
|
2015-09-30 12:12:14 +02:00
|
|
|
import AclProxy from '../acl_proxy';
|
2016-06-08 13:52:24 +02:00
|
|
|
import withContext from '../context/with_context';
|
|
|
|
import { routerShape } from '../prop_types';
|
2015-09-30 12:12:14 +02:00
|
|
|
|
2016-06-13 14:35:02 +02:00
|
|
|
import { getLangText } from '../../utils/lang';
|
2016-06-14 13:05:57 +02:00
|
|
|
import { resolveUrl } from '../../utils/url_resolver';
|
2015-09-30 12:12:14 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
A component that handles all the actions inside of the edition detail
|
|
|
|
handleSuccess requires a loadEdition action (could be refactored)
|
|
|
|
*/
|
2016-06-06 16:54:38 +02:00
|
|
|
const EditionActionPanel = React.createClass({
|
2015-09-30 12:12:14 +02:00
|
|
|
propTypes: {
|
2016-01-12 15:07:38 +01:00
|
|
|
edition: React.PropTypes.object.isRequired,
|
2016-01-11 17:41:31 +01:00
|
|
|
|
2015-10-28 11:26:54 +01:00
|
|
|
actionPanelButtonListType: React.PropTypes.func,
|
2016-06-08 13:52:24 +02:00
|
|
|
handleSuccess: React.PropTypes.func,
|
|
|
|
|
|
|
|
// Injected through HOCs
|
|
|
|
router: routerShape.isRequired // eslint-disable-line react/sort-prop-types
|
2015-09-30 12:12:14 +02:00
|
|
|
},
|
|
|
|
|
2015-10-28 11:26:54 +01: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();
|
|
|
|
|
2016-01-05 17:27:25 +01:00
|
|
|
const notification = new GlobalNotificationModel(response.notification, 'success');
|
2015-09-30 12:12:14 +02:00
|
|
|
GlobalNotificationActions.appendGlobalNotification(notification);
|
|
|
|
|
2016-06-06 16:54:38 +02:00
|
|
|
this.props.router.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
|
|
|
},
|
|
|
|
|
2016-01-05 17:27:25 +01:00
|
|
|
handleSuccess(response) {
|
2015-09-30 12:12:14 +02:00
|
|
|
this.refreshCollection();
|
2016-01-12 15:07:38 +01:00
|
|
|
|
|
|
|
if (response) {
|
|
|
|
const notification = new GlobalNotificationModel(response.notification, 'success');
|
2015-09-30 12:12:14 +02:00
|
|
|
GlobalNotificationActions.appendGlobalNotification(notification);
|
|
|
|
}
|
2016-01-12 15:07:38 +01:00
|
|
|
|
|
|
|
if (typeof this.props.handleSuccess === 'function') {
|
|
|
|
this.props.handleSuccess();
|
|
|
|
}
|
2015-09-30 12:12:14 +02:00
|
|
|
},
|
|
|
|
|
2016-01-05 17:27:25 +01:00
|
|
|
render() {
|
2016-06-07 14:53:48 +02:00
|
|
|
const { edition, actionPanelButtonListType: ActionPanelButtonListType } = this.props;
|
2015-09-30 12:12:14 +02:00
|
|
|
|
2016-01-12 15:07:38 +01:00
|
|
|
if (edition.notifications && edition.notifications.length) {
|
2015-09-30 12:12:14 +02:00
|
|
|
return (
|
|
|
|
<ListRequestActions
|
2016-01-11 17:41:31 +01:00
|
|
|
notifications={edition.notifications}
|
|
|
|
pieceOrEditions={[edition]}
|
|
|
|
handleSuccess={this.handleSuccess} />);
|
|
|
|
} else {
|
2015-09-30 12:12:14 +02:00
|
|
|
return (
|
|
|
|
<Row>
|
|
|
|
<Col md={12}>
|
2015-10-28 11:26:54 +01:00
|
|
|
<ActionPanelButtonListType
|
2015-09-30 12:12:14 +02:00
|
|
|
availableAcls={edition.acl}
|
2016-01-11 17:41:31 +01:00
|
|
|
className="ascribe-button-list"
|
2016-01-12 15:07:38 +01:00
|
|
|
handleSuccess={this.handleSuccess}
|
2016-06-07 14:53:48 +02:00
|
|
|
pieceOrEditions={[edition]} >
|
2015-09-30 12:12:14 +02:00
|
|
|
<AclProxy
|
|
|
|
aclObject={edition.acl}
|
|
|
|
aclName="acl_withdraw_transfer">
|
|
|
|
<Form
|
2016-06-14 13:05:57 +02:00
|
|
|
url={resolveUrl('ownership_transfers_withdraw')}
|
2015-09-30 12:12:14 +02:00
|
|
|
handleSuccess={this.handleSuccess}
|
|
|
|
className='inline'
|
|
|
|
isInline={true}>
|
|
|
|
<Property
|
|
|
|
name="bitcoin_id"
|
2015-12-03 20:26:53 +01:00
|
|
|
expanded={false}>
|
2015-09-30 12:12:14 +02:00
|
|
|
<input
|
2015-10-28 11:26:54 +01:00
|
|
|
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
|
2016-06-14 13:05:57 +02:00
|
|
|
url={resolveUrl('ownership_consigns_withdraw')}
|
2015-09-30 12:12:14 +02:00
|
|
|
handleSuccess={this.handleSuccess}
|
|
|
|
className='inline'
|
|
|
|
isInline={true}>
|
|
|
|
<Property
|
|
|
|
name="bitcoin_id"
|
2015-12-03 20:26:53 +01:00
|
|
|
expanded={false}>
|
2015-09-30 12:12:14 +02:00
|
|
|
<input
|
2015-10-28 11:26:54 +01:00
|
|
|
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
|
|
|
|
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}/>
|
2015-10-28 11:26:54 +01:00
|
|
|
</ActionPanelButtonListType>
|
2015-09-30 12:12:14 +02:00
|
|
|
</Col>
|
|
|
|
</Row>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2016-06-08 13:52:24 +02:00
|
|
|
export default withContext(EditionActionPanel, 'router');
|