'use strict'; import React from 'react'; import Router from 'react-router'; import Button from 'react-bootstrap/lib/Button'; import EditionDeleteForm from '../ascribe_forms/form_delete_edition'; import PieceDeleteForm from '../ascribe_forms/form_delete_piece'; import EditionRemoveFromCollectionForm from '../ascribe_forms/form_remove_editions_from_collection'; import PieceRemoveFromCollectionForm from '../ascribe_forms/form_remove_piece_from_collection'; import ModalWrapper from '../ascribe_modal/modal_wrapper'; import { getAvailableAcls } from '../../utils/acl_utils'; import { getLangText } from '../../utils/lang_utils.js'; let DeleteButton = React.createClass({ propTypes: { editions: React.PropTypes.array, piece: React.PropTypes.object, handleSuccess: React.PropTypes.func }, mixins: [Router.Navigation], render: function () { let availableAcls; let btnDelete; let content; let title; if(this.props.piece && !this.props.editions) { availableAcls = getAvailableAcls([this.props.piece]); } else { availableAcls = getAvailableAcls(this.props.editions); } if(availableAcls.acl_delete) { if(this.props.piece && !this.props.editions) { content = ; title = getLangText('Remove Piece'); } else { content = ; title = getLangText('Remove Edition'); } btnDelete = ; } else if(availableAcls.acl_unshare){ if(this.props.editions && this.props.editions.constructor !== Array && this.props.editions.acl.acl_unshare) { content = ; title = getLangText('Remove Edition from Collection'); } else { content = ; title = getLangText('Remove Piece from Collection'); } btnDelete = ; } else { return null; } return ( {content} ); } }); export default DeleteButton;