mirror of
https://github.com/ascribe/onion.git
synced 2025-01-05 11:25:09 +01:00
185 lines
7.3 KiB
JavaScript
185 lines
7.3 KiB
JavaScript
'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';
|
|
|
|
import GlobalNotificationModel from '../../models/global_notification_model';
|
|
import GlobalNotificationActions from '../../actions/global_notification_actions';
|
|
|
|
import Form from './../ascribe_forms/form';
|
|
import ListRequestActions from './../ascribe_forms/list_form_request_actions';
|
|
import Property from './../ascribe_forms/property';
|
|
|
|
import AclButtonList from './../ascribe_buttons/acl_button_list';
|
|
import AclInformation from '../ascribe_buttons/acl_information';
|
|
import DeleteButton from '../ascribe_buttons/delete_button';
|
|
import UnConsignRequestButton from './../ascribe_buttons/unconsign_request_button';
|
|
|
|
import AclProxy from '../acl_proxy';
|
|
import withContext from '../context/with_context';
|
|
import { routerShape } from '../prop_types';
|
|
|
|
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)
|
|
*/
|
|
const EditionActionPanel = React.createClass({
|
|
propTypes: {
|
|
edition: React.PropTypes.object.isRequired,
|
|
|
|
actionPanelButtonListType: React.PropTypes.func,
|
|
handleSuccess: React.PropTypes.func,
|
|
|
|
// Injected through HOCs
|
|
router: routerShape.isRequired // eslint-disable-line react/sort-prop-types
|
|
},
|
|
|
|
getDefaultProps() {
|
|
return {
|
|
actionPanelButtonListType: AclButtonList
|
|
};
|
|
},
|
|
|
|
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');
|
|
GlobalNotificationActions.appendGlobalNotification(notification);
|
|
|
|
this.props.router.push('/collection');
|
|
},
|
|
|
|
refreshCollection() {
|
|
const { filterBy, orderAsc, orderBy, page, pageSize, search } = this.state;
|
|
|
|
PieceListActions.fetchPieceList({ page, pageSize, search, orderBy, orderAsc, filterBy });
|
|
EditionListActions.refreshEditionList({ pieceId: this.props.edition.parent });
|
|
},
|
|
|
|
handleSuccess(response) {
|
|
this.refreshCollection();
|
|
|
|
if (response) {
|
|
const notification = new GlobalNotificationModel(response.notification, 'success');
|
|
GlobalNotificationActions.appendGlobalNotification(notification);
|
|
}
|
|
|
|
if (typeof this.props.handleSuccess === 'function') {
|
|
this.props.handleSuccess();
|
|
}
|
|
},
|
|
|
|
render() {
|
|
const { edition, actionPanelButtonListType: ActionPanelButtonListType } = this.props;
|
|
|
|
if (edition.notifications && edition.notifications.length) {
|
|
return (
|
|
<ListRequestActions
|
|
notifications={edition.notifications}
|
|
pieceOrEditions={[edition]}
|
|
handleSuccess={this.handleSuccess} />);
|
|
} else {
|
|
return (
|
|
<Row>
|
|
<Col md={12}>
|
|
<ActionPanelButtonListType
|
|
availableAcls={edition.acl}
|
|
className="ascribe-button-list"
|
|
handleSuccess={this.handleSuccess}
|
|
pieceOrEditions={[edition]} >
|
|
<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}>
|
|
<input
|
|
type="text"
|
|
value={edition.bitcoin_id}
|
|
readOnly />
|
|
</Property>
|
|
<Button bsStyle="default" className="pull-center" bsSize="small" type="submit">
|
|
{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}>
|
|
<input
|
|
type="text"
|
|
value={edition.bitcoin_id}
|
|
readOnly />
|
|
</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]}/>
|
|
<AclInformation
|
|
aim="button"
|
|
verbs={['acl_share', 'acl_transfer', 'acl_consign', 'acl_loan', 'acl_delete']}
|
|
aclObject={edition.acl}/>
|
|
</ActionPanelButtonListType>
|
|
</Col>
|
|
</Row>
|
|
);
|
|
}
|
|
}
|
|
});
|
|
|
|
export default withContext(EditionActionPanel, 'router');
|