mirror of
https://github.com/ascribe/onion.git
synced 2025-01-03 10:25:08 +01:00
loan request actions for multiple actions
This commit is contained in:
parent
79106dd106
commit
bc28f3d8f5
@ -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>
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
currentUser={this.props.currentUser}
|
|
||||||
pieceOrEditions={[this.props.edition]}
|
pieceOrEditions={[this.props.edition]}
|
||||||
requestAction={this.props.edition.request_action}
|
currentUser={this.props.currentUser}
|
||||||
requestUser={this.props.edition.owner}
|
handleSuccess={this.showNotification}
|
||||||
handleSuccess={this.showNotification}/>);
|
requestActions={this.props.edition.request_action}/>);
|
||||||
}
|
}
|
||||||
|
|
||||||
else {
|
else {
|
||||||
|
@ -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
|
||||||
currentUser={this.state.currentUser}
|
|
||||||
pieceOrEditions={this.state.piece}
|
pieceOrEditions={this.state.piece}
|
||||||
requestAction={this.state.piece.request_action}
|
currentUser={this.state.currentUser}
|
||||||
requestUser={this.state.piece.user_registered}
|
handleSuccess={this.loadPiece}
|
||||||
handleSuccess={this.loadPiece}/>);
|
requestActions={this.state.piece.request_action}/>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return (
|
return (
|
||||||
|
@ -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';
|
||||||
|
@ -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}
|
||||||
|
37
js/components/ascribe_forms/list_form_request_actions.js
Normal file
37
js/components/ascribe_forms/list_form_request_actions.js
Normal 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;
|
@ -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>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -29,6 +29,6 @@
|
|||||||
.rating-note {
|
.rating-note {
|
||||||
color: #666;
|
color: #666;
|
||||||
font-style: italic;
|
font-style: italic;
|
||||||
padding: 0.2em;
|
padding: 0.7em;
|
||||||
|
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user