'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 { getLangText } from '../../utils/lang'; import { resolveUrl } from '../../utils/url_resolver'; /* 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 ( ); } else { return (
); } } }); export default withContext(EditionActionPanel, 'router');