1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-03 18:35:09 +01:00

loan request actions for multiple actions

This commit is contained in:
diminator 2015-08-27 13:43:26 +02:00
parent 79106dd106
commit bc28f3d8f5
11 changed files with 78 additions and 54 deletions

View File

@ -39,7 +39,7 @@ let AccordionListItem = React.createClass({
</div> </div>
<span style={{'clear': 'both'}}></span> <span style={{'clear': 'both'}}></span>
<div className="request-action-batch"> <div className="request-action-badge">
{this.props.badge} {this.props.badge}
</div> </div>
</div> </div>

View File

@ -61,13 +61,13 @@ let AccordionListItemWallet = React.createClass({
}, },
getGlyphicon(){ getGlyphicon(){
if (this.props.content.requestAction) { if (this.props.content.requestAction && this.props.content.requestAction.length > 0) {
return ( return (
<OverlayTrigger <OverlayTrigger
delay={500} delay={500}
placement="left" placement="left"
overlay={<Tooltip>{getLangText('You have actions pending in one of your editions')}</Tooltip>}> overlay={<Tooltip>{getLangText('You have actions pending in one of your editions')}</Tooltip>}>
<Glyphicon glyph='bell'/> <Glyphicon glyph='bell' color="green"/>
</OverlayTrigger>); </OverlayTrigger>);
} }
return null; return null;

View File

@ -28,7 +28,7 @@ import EditionDetailProperty from './detail_property';
import EditionFurtherDetails from './further_details'; import EditionFurtherDetails from './further_details';
import RequestActionForm from './../ascribe_forms/form_request_action'; import ListRequestActions from './../ascribe_forms/list_form_request_actions';
import AclButtonList from './../ascribe_buttons/acl_button_list'; import AclButtonList from './../ascribe_buttons/acl_button_list';
import UnConsignRequestButton from './../ascribe_buttons/unconsign_request_button'; import UnConsignRequestButton from './../ascribe_buttons/unconsign_request_button';
import DeleteButton from '../ascribe_buttons/delete_button'; import DeleteButton from '../ascribe_buttons/delete_button';
@ -236,12 +236,11 @@ let EditionSummary = React.createClass({
let actions = null; let actions = null;
if (this.props.edition.request_action && this.props.edition.request_action.length > 0){ if (this.props.edition.request_action && this.props.edition.request_action.length > 0){
actions = ( actions = (
<RequestActionForm <ListRequestActions
pieceOrEditions={[this.props.edition]}
currentUser={this.props.currentUser} currentUser={this.props.currentUser}
pieceOrEditions={ [this.props.edition] } handleSuccess={this.showNotification}
requestAction={this.props.edition.request_action} requestActions={this.props.edition.request_action}/>);
requestUser={this.props.edition.owner}
handleSuccess={this.showNotification}/>);
} }
else { else {

View File

@ -26,7 +26,7 @@ import CreateEditionsForm from '../ascribe_forms/create_editions_form';
import CreateEditionsButton from '../ascribe_buttons/create_editions_button'; import CreateEditionsButton from '../ascribe_buttons/create_editions_button';
import DeleteButton from '../ascribe_buttons/delete_button'; import DeleteButton from '../ascribe_buttons/delete_button';
import RequestActionForm from '../ascribe_forms/form_request_action'; import ListRequestActions from '../ascribe_forms/list_form_request_actions';
import GlobalNotificationModel from '../../models/global_notification_model'; import GlobalNotificationModel from '../../models/global_notification_model';
import GlobalNotificationActions from '../../actions/global_notification_actions'; import GlobalNotificationActions from '../../actions/global_notification_actions';
@ -175,12 +175,12 @@ let PieceContainer = React.createClass({
this.state.piece.request_action && this.state.piece.request_action &&
this.state.piece.request_action.length > 0) { this.state.piece.request_action.length > 0) {
return ( return (
<RequestActionForm <ListRequestActions
pieceOrEditions={this.state.piece}
currentUser={this.state.currentUser} currentUser={this.state.currentUser}
pieceOrEditions={ this.state.piece } handleSuccess={this.loadPiece}
requestAction={this.state.piece.request_action} requestActions={this.state.piece.request_action}/>
requestUser={this.state.piece.user_registered} );
handleSuccess={this.loadPiece}/>);
} }
else { else {
return ( return (

View File

@ -2,15 +2,8 @@
import React from 'react'; import React from 'react';
import Moment from 'moment'; import Moment from 'moment';
import classnames from 'classnames';
import Button from 'react-bootstrap/lib/Button';
import LoanForm from './form_loan'; import LoanForm from './form_loan';
import Property from './property';
import InputTextAreaToggable from './input_textarea_toggable';
import InputDate from './input_date';
import InputCheckbox from './input_checkbox';
import OwnershipActions from '../../actions/ownership_actions'; import OwnershipActions from '../../actions/ownership_actions';
import OwnershipStore from '../../stores/ownership_store'; import OwnershipStore from '../../stores/ownership_store';

View File

@ -78,8 +78,11 @@ let RequestActionForm = React.createClass({
}, },
getContent() { getContent() {
let message = this.props.requestUser + ' ' + getLangText('requests you') + ' ' + this.props.requestAction + ' ' + getLangText('this edition%s', '.'); let pieceOrEditionStr = this.isPiece() ? getLangText('this work%s', '.') : getLangText('this edition%s', '.');
let message = this.props.requestUser + ' ' + getLangText('requests you') + ' ' + this.props.requestAction + ' ' + pieceOrEditionStr;
if (this.props.requestAction === 'loan_request'){
message = this.props.requestUser + ' ' + getLangText('requests you to loan') + ' ' + pieceOrEditionStr;
}
return ( return (
<span> <span>
{message} {message}

View File

@ -0,0 +1,37 @@
'use strict';
import React from 'react';
import RequestActionForm from './form_request_action';
let ListRequestActions = React.createClass({
propTypes: {
pieceOrEditions: React.PropTypes.oneOfType([
React.PropTypes.object,
React.PropTypes.array
]).isRequired,
currentUser: React.PropTypes.object.isRequired,
handleSuccess: React.PropTypes.func.isRequired,
requestActions: React.PropTypes.array.isRequired
},
render () {
if (this.props.requestActions &&
this.props.requestActions.length > 0) {
return (
<div>
{this.props.requestActions.map((requestAction) =>
<RequestActionForm
currentUser={this.props.currentUser}
pieceOrEditions={ this.props.pieceOrEditions }
requestAction={requestAction.action}
requestUser={requestAction.by}
handleSuccess={this.props.handleSuccess}/>)}
</div>
);
}
return null;
}
});
export default ListRequestActions;

View File

@ -11,10 +11,10 @@ let TableItemAclFiltered = React.createClass({
render() { render() {
var availableAcls = ['acl_consign', 'acl_loan', 'acl_transfer', 'acl_view', 'acl_share', 'acl_unshare', 'acl_delete']; var availableAcls = ['acl_consign', 'acl_loan', 'acl_transfer', 'acl_view', 'acl_share', 'acl_unshare', 'acl_delete'];
if (this.props.requestAction){ if (this.props.requestAction && this.props.requestAction.length > 0){
return ( return (
<span> <span>
{this.props.requestAction + ' request pending'} {this.props.requestAction[0].action + ' request pending'}
</span> </span>
); );
} }

View File

@ -29,7 +29,7 @@ import CollapsibleParagraph from '../../../../../components/ascribe_collapsible/
import InputCheckbox from '../../../../ascribe_forms/input_checkbox'; import InputCheckbox from '../../../../ascribe_forms/input_checkbox';
import LoanForm from '../../../../ascribe_forms/form_loan'; import LoanForm from '../../../../ascribe_forms/form_loan';
import RequestActionForm from '../../../../ascribe_forms/form_request_action'; import ListRequestActions from '../../../../ascribe_forms/list_form_request_actions';
import ModalWrapper from '../../../../ascribe_modal/modal_wrapper'; import ModalWrapper from '../../../../ascribe_modal/modal_wrapper';
import GlobalNotificationModel from '../../../../../models/global_notification_model'; import GlobalNotificationModel from '../../../../../models/global_notification_model';
@ -89,21 +89,6 @@ let PieceContainer = React.createClass({
this.setState(this.state); this.setState(this.state);
}, },
getActions(){
if (this.state.piece &&
this.state.piece.request_action &&
this.state.piece.request_action.length > 0) {
return (
<RequestActionForm
currentUser={this.state.currentUser}
pieceOrEditions={ this.state.piece }
requestAction={this.state.piece.request_action}
requestUser={this.state.piece.user_registered}
handleSuccess={this.loadPiece}/>);
}
return null;
},
render() { render() {
if('title' in this.state.piece) { if('title' in this.state.piece) {
// Only show the artist name if you are the participant or if you are a judge and the piece is shortlisted // Only show the artist name if you are the participant or if you are a judge and the piece is shortlisted
@ -112,7 +97,7 @@ let PieceContainer = React.createClass({
<span className="glyphicon glyphicon-eye-close" aria-hidden="true"/> : this.state.piece.artist_name; <span className="glyphicon glyphicon-eye-close" aria-hidden="true"/> : this.state.piece.artist_name;
// Only show the artist email if you are a judge and the piece is shortlisted // Only show the artist email if you are a judge and the piece is shortlisted
let artistEmail = (this.state.currentUser.is_judge && this.state.piece.selected ) ? let artistEmail = (this.state.currentUser.is_judge && this.state.piece.selected ) ?
<DetailProperty label="REGISTREE" value={ this.state.piece.user_registered } /> : null; <DetailProperty label={getLangText('REGISTREE')} value={ this.state.piece.user_registered } /> : null;
return ( return (
<Piece <Piece
piece={this.state.piece} piece={this.state.piece}
@ -124,10 +109,14 @@ let PieceContainer = React.createClass({
currentUser={this.state.currentUser}/> currentUser={this.state.currentUser}/>
<hr/> <hr/>
<h1 className="ascribe-detail-title">{this.state.piece.title}</h1> <h1 className="ascribe-detail-title">{this.state.piece.title}</h1>
<DetailProperty label="BY" value={artistName} /> <DetailProperty label={getLangText('BY')} value={artistName} />
<DetailProperty label="DATE" value={ this.state.piece.date_created.slice(0, 4) } /> <DetailProperty label={getLangText('DATE')} value={ this.state.piece.date_created.slice(0, 4) } />
{artistEmail} {artistEmail}
{this.getActions()} <ListRequestActions
pieceOrEditions={this.state.piece}
currentUser={this.state.currentUser}
handleSuccess={this.loadPiece}
requestActions={this.state.piece.request_action}/>
<hr/> <hr/>
</div> </div>
} }
@ -237,6 +226,11 @@ let PrizePieceRatings = React.createClass({
); );
}, },
handleLoanRequestSuccess(message){
let notification = new GlobalNotificationModel(message, 'success', 4000);
GlobalNotificationActions.appendGlobalNotification(notification);
},
getLoanButton(){ getLoanButton(){
let today = new Moment(); let today = new Moment();
let endDate = new Moment(); let endDate = new Moment();
@ -245,15 +239,15 @@ let PrizePieceRatings = React.createClass({
<ModalWrapper <ModalWrapper
trigger={ trigger={
<button className='btn btn-default btn-sm'> <button className='btn btn-default btn-sm'>
SEND LOAN REQUEST {getLangText('SEND LOAN REQUEST')}
</button> </button>
} }
handleSuccess={this.handleLoanRequestSuccess} handleSuccess={this.handleLoanRequestSuccess}
title='REQUEST LOAN'> title='REQUEST LOAN'>
<LoanForm <LoanForm
loanHeading={null} loanHeading={null}
message={'Congratulations,\nYou have been selected for the sluice screens.\n' + message={getLangText('Congratulations,\nYou have been selected for the prize.\n' +
'Please accept the loan request to proceed\n\nBest regards,\n\nSluice.'} 'Please accept the loan request to proceed.')}
id={{piece_id: this.props.piece.id}} id={{piece_id: this.props.piece.id}}
url={ApiUrls.ownership_loans_pieces_request} url={ApiUrls.ownership_loans_pieces_request}
email={this.props.currentUser.email} email={this.props.currentUser.email}
@ -266,8 +260,6 @@ let PrizePieceRatings = React.createClass({
</ModalWrapper>); </ModalWrapper>);
}, },
handleLoanRequestSuccess(){},
handleShortlistSuccess(message){ handleShortlistSuccess(message){
let notification = new GlobalNotificationModel(message, 'success', 2000); let notification = new GlobalNotificationModel(message, 'success', 2000);
GlobalNotificationActions.appendGlobalNotification(notification); GlobalNotificationActions.appendGlobalNotification(notification);

View File

@ -152,11 +152,11 @@ span.ascribe-accordion-list-table-toggle {
} }
} }
.request-action-batch { .request-action-badge {
position: absolute; position: absolute;
top: 0px; top: 0px;
right: 0px; right: 0px;
color: #666; color: $ascribe-color-green;
font-size: 1.2em; font-size: 1.2em;
padding: 0.3em; padding: 0.3em;
} }

View File

@ -29,6 +29,6 @@
.rating-note { .rating-note {
color: #666; color: #666;
font-style: italic; font-style: italic;
padding: 0.2em; padding: 0.7em;
} }