mirror of
https://github.com/ascribe/onion.git
synced 2025-01-03 10:25:08 +01:00
Don't redirect to register piece and then to contract notifications
Avoids new user getting asked if they want to cancel registration of a piece before they even agree to the Ikono contract.
This commit is contained in:
parent
38ef18a192
commit
6cc9ce8094
@ -9,10 +9,13 @@ class NotificationActions {
|
|||||||
constructor() {
|
constructor() {
|
||||||
this.generateActions(
|
this.generateActions(
|
||||||
'updatePieceListNotifications',
|
'updatePieceListNotifications',
|
||||||
|
'flushPieceListNotifications',
|
||||||
'updateEditionListNotifications',
|
'updateEditionListNotifications',
|
||||||
|
'flushEditionListNotifications',
|
||||||
'updateEditionNotifications',
|
'updateEditionNotifications',
|
||||||
'updatePieceNotifications',
|
'updatePieceNotifications',
|
||||||
'updateContractAgreementListNotifications'
|
'updateContractAgreementListNotifications',
|
||||||
|
'flushContractAgreementListNotifications'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,6 +37,7 @@ let PieceList = React.createClass({
|
|||||||
bulkModalButtonListType: React.PropTypes.func,
|
bulkModalButtonListType: React.PropTypes.func,
|
||||||
canLoadPieceList: React.PropTypes.bool,
|
canLoadPieceList: React.PropTypes.bool,
|
||||||
redirectTo: React.PropTypes.string,
|
redirectTo: React.PropTypes.string,
|
||||||
|
shouldRedirect: React.PropTypes.func,
|
||||||
customSubmitButton: React.PropTypes.element,
|
customSubmitButton: React.PropTypes.element,
|
||||||
customThumbnailPlaceholder: React.PropTypes.func,
|
customThumbnailPlaceholder: React.PropTypes.func,
|
||||||
filterParams: React.PropTypes.array,
|
filterParams: React.PropTypes.array,
|
||||||
@ -114,7 +115,11 @@ let PieceList = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
componentDidUpdate() {
|
componentDidUpdate() {
|
||||||
if (this.props.redirectTo && this.state.unfilteredPieceListCount === 0) {
|
const { redirectTo, shouldRedirect } = this.props;
|
||||||
|
const { unfilteredPieceListCount } = this.state;
|
||||||
|
|
||||||
|
if (redirectTo && unfilteredPieceListCount === 0 &&
|
||||||
|
(typeof shouldRedirect === 'function' && shouldRedirect(unfilteredPieceListCount))) {
|
||||||
// FIXME: hack to redirect out of the dispatch cycle
|
// FIXME: hack to redirect out of the dispatch cycle
|
||||||
window.setTimeout(() => this.history.pushState(null, this.props.redirectTo, this.props.location.query), 0);
|
window.setTimeout(() => this.history.pushState(null, this.props.redirectTo, this.props.location.query), 0);
|
||||||
}
|
}
|
||||||
|
@ -106,22 +106,27 @@ let IkonotvContractNotifications = React.createClass({
|
|||||||
|
|
||||||
handleConfirm() {
|
handleConfirm() {
|
||||||
let contractAgreement = this.state.contractAgreementListNotifications[0].contract_agreement;
|
let contractAgreement = this.state.contractAgreementListNotifications[0].contract_agreement;
|
||||||
OwnershipFetcher.confirmContractAgreement(contractAgreement).then(
|
OwnershipFetcher
|
||||||
() => this.handleConfirmSuccess()
|
.confirmContractAgreement(contractAgreement)
|
||||||
);
|
.then(this.handleConfirmSuccess);
|
||||||
},
|
},
|
||||||
|
|
||||||
handleConfirmSuccess() {
|
handleConfirmSuccess() {
|
||||||
let notification = new GlobalNotificationModel(getLangText('You have accepted the conditions'), 'success', 5000);
|
let notification = new GlobalNotificationModel(getLangText('You have accepted the conditions'), 'success', 5000);
|
||||||
GlobalNotificationActions.appendGlobalNotification(notification);
|
GlobalNotificationActions.appendGlobalNotification(notification);
|
||||||
|
|
||||||
|
// Flush contract notifications and refetch
|
||||||
|
NotificationActions.flushContractAgreementListNotifications();
|
||||||
|
NotificationActions.fetchContractAgreementListNotifications();
|
||||||
|
|
||||||
this.history.pushState(null, '/collection');
|
this.history.pushState(null, '/collection');
|
||||||
},
|
},
|
||||||
|
|
||||||
handleDeny() {
|
handleDeny() {
|
||||||
let contractAgreement = this.state.contractAgreementListNotifications[0].contract_agreement;
|
let contractAgreement = this.state.contractAgreementListNotifications[0].contract_agreement;
|
||||||
OwnershipFetcher.denyContractAgreement(contractAgreement).then(
|
OwnershipFetcher
|
||||||
() => this.handleDenySuccess()
|
.denyContractAgreement(contractAgreement)
|
||||||
);
|
.then(this.handleDenySuccess);
|
||||||
},
|
},
|
||||||
|
|
||||||
handleDenySuccess() {
|
handleDenySuccess() {
|
||||||
|
@ -1,15 +1,18 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
import PieceList from '../../../../piece_list';
|
import PieceList from '../../../../piece_list';
|
||||||
|
|
||||||
import UserActions from '../../../../../actions/user_actions';
|
import UserActions from '../../../../../actions/user_actions';
|
||||||
import UserStore from '../../../../../stores/user_store';
|
import UserStore from '../../../../../stores/user_store';
|
||||||
|
import NotificationStore from '../../../../../stores/notification_store';
|
||||||
|
|
||||||
import IkonotvAccordionListItem from './ikonotv_accordion_list/ikonotv_accordion_list_item';
|
import IkonotvAccordionListItem from './ikonotv_accordion_list/ikonotv_accordion_list_item';
|
||||||
|
|
||||||
import { getLangText } from '../../../../../utils/lang_utils';
|
|
||||||
import { setDocumentTitle } from '../../../../../utils/dom_utils';
|
import { setDocumentTitle } from '../../../../../utils/dom_utils';
|
||||||
|
import { mergeOptions } from '../../../../../utils/general_utils';
|
||||||
|
import { getLangText } from '../../../../../utils/lang_utils';
|
||||||
|
|
||||||
|
|
||||||
let IkonotvPieceList = React.createClass({
|
let IkonotvPieceList = React.createClass({
|
||||||
@ -18,20 +21,33 @@ let IkonotvPieceList = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
return UserStore.getState();
|
return mergeOptions(
|
||||||
|
NotificationStore.getState(),
|
||||||
|
UserStore.getState()
|
||||||
|
);
|
||||||
},
|
},
|
||||||
|
|
||||||
componentDidMount() {
|
componentDidMount() {
|
||||||
|
NotificationStore.listen(this.onChange);
|
||||||
UserStore.listen(this.onChange);
|
UserStore.listen(this.onChange);
|
||||||
|
|
||||||
UserActions.fetchCurrentUser();
|
UserActions.fetchCurrentUser();
|
||||||
},
|
},
|
||||||
|
|
||||||
componentWillUnmount() {
|
componentWillUnmount() {
|
||||||
|
NotificationStore.unlisten(this.onChange);
|
||||||
UserStore.unlisten(this.onChange);
|
UserStore.unlisten(this.onChange);
|
||||||
},
|
},
|
||||||
|
|
||||||
onChange(state) {
|
onChange(state) {
|
||||||
this.setState(state);
|
this.setState(state);
|
||||||
|
|
||||||
|
},
|
||||||
|
|
||||||
|
redirectIfNoContractNotifications() {
|
||||||
|
const { contractAgreementListNotifications } = this.state;
|
||||||
|
|
||||||
|
return contractAgreementListNotifications && !contractAgreementListNotifications.length;
|
||||||
},
|
},
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
@ -41,6 +57,7 @@ let IkonotvPieceList = React.createClass({
|
|||||||
<div>
|
<div>
|
||||||
<PieceList
|
<PieceList
|
||||||
redirectTo="/register_piece?slide_num=0"
|
redirectTo="/register_piece?slide_num=0"
|
||||||
|
shouldRedirect={this.redirectIfNoContractNotifications}
|
||||||
accordionListItemType={IkonotvAccordionListItem}
|
accordionListItemType={IkonotvAccordionListItem}
|
||||||
filterParams={[{
|
filterParams={[{
|
||||||
label: getLangText('Show works I have'),
|
label: getLangText('Show works I have'),
|
||||||
|
@ -10,6 +10,8 @@ class NotificationStore {
|
|||||||
constructor() {
|
constructor() {
|
||||||
this.pieceListNotifications = {};
|
this.pieceListNotifications = {};
|
||||||
this.editionListNotifications = {};
|
this.editionListNotifications = {};
|
||||||
|
// Need to determine if contract agreement notifications have been loaded or not,
|
||||||
|
// so we use null here instead of an empty array
|
||||||
this.contractAgreementListNotifications = null;
|
this.contractAgreementListNotifications = null;
|
||||||
this.editionNotifications = null;
|
this.editionNotifications = null;
|
||||||
this.pieceNotifications = null;
|
this.pieceNotifications = null;
|
||||||
@ -20,6 +22,10 @@ class NotificationStore {
|
|||||||
this.pieceListNotifications = res.notifications;
|
this.pieceListNotifications = res.notifications;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onFlushPieceListNotifications() {
|
||||||
|
this.pieceListNotifications = [];
|
||||||
|
}
|
||||||
|
|
||||||
onUpdatePieceNotifications(res) {
|
onUpdatePieceNotifications(res) {
|
||||||
this.pieceNotifications = res.notification;
|
this.pieceNotifications = res.notification;
|
||||||
}
|
}
|
||||||
@ -28,6 +34,10 @@ class NotificationStore {
|
|||||||
this.editionListNotifications = res.notifications;
|
this.editionListNotifications = res.notifications;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onFlushPieceListNotifications() {
|
||||||
|
this.editionListNotifications = [];
|
||||||
|
}
|
||||||
|
|
||||||
onUpdateEditionNotifications(res) {
|
onUpdateEditionNotifications(res) {
|
||||||
this.editionNotifications = res.notification;
|
this.editionNotifications = res.notification;
|
||||||
}
|
}
|
||||||
@ -36,6 +46,9 @@ class NotificationStore {
|
|||||||
this.contractAgreementListNotifications = res.notifications;
|
this.contractAgreementListNotifications = res.notifications;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onFlushContractAgreementListNotifications() {
|
||||||
|
this.contractAgreementListNotifications = null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export default alt.createStore(NotificationStore, 'NotificationStore');
|
export default alt.createStore(NotificationStore, 'NotificationStore');
|
||||||
|
Loading…
Reference in New Issue
Block a user