lbry-desktop/ui/js/modal/modalRouter/view.jsx

133 lines
3.5 KiB
React
Raw Normal View History

import React from "react";
import ModalError from "modal/modalError";
import ModalAuthFailure from "modal/modalAuthFailure";
import ModalDownloading from "modal/modalDownloading";
import ModalInsufficientCredits from "modal/modalInsufficientCredits";
import ModalUpgrade from "modal/modalUpgrade";
import ModalWelcome from "modal/modalWelcome";
import ModalFirstReward from "modal/modalFirstReward";
2017-08-26 05:21:26 +02:00
import ModalRewardApprovalRequired from "modal/modalRewardApprovalRequired";
import ModalCreditIntro from "modal/modalCreditIntro";
2017-08-31 06:15:13 +02:00
import ModalTransactionFailed from "modal/modalTransactionFailed";
import ModalInsufficientBalance from "modal/modalInsufficientBalance";
import * as modals from "constants/modal_types";
class ModalRouter extends React.PureComponent {
2017-08-26 05:21:26 +02:00
constructor(props) {
super(props);
this.state = {
lastTransitionModal: null,
lastTransitionPage: null,
};
}
componentWillMount() {
2017-08-21 05:06:26 +02:00
this.showTransitionModals(this.props);
}
componentWillReceiveProps(nextProps) {
2017-08-21 05:06:26 +02:00
this.showTransitionModals(nextProps);
}
2017-08-21 05:06:26 +02:00
showTransitionModals(props) {
2017-08-26 05:21:26 +02:00
const { modal, openModal, page } = props;
2017-08-21 05:06:26 +02:00
if (modal) {
return;
}
2017-08-26 05:21:26 +02:00
const transitionModal = [
this.checkShowWelcome,
this.checkShowCreditIntro,
this.checkShowInsufficientCredits,
].reduce((acc, func) => {
return !acc ? func.bind(this)(props) : acc;
}, false);
2017-08-26 05:21:26 +02:00
if (
transitionModal &&
(transitionModal != this.state.lastTransitionModal ||
page != this.state.lastTransitionPage)
) {
openModal(transitionModal);
this.setState({
lastTransitionModal: transitionModal,
lastTransitionPage: page,
});
}
2017-08-21 05:06:26 +02:00
}
checkShowWelcome(props) {
2017-08-26 05:21:26 +02:00
const { isWelcomeAcknowledged, user } = props;
if (
!isWelcomeAcknowledged &&
user &&
!user.is_reward_approved &&
!user.is_identity_verified
) {
2017-08-26 05:21:26 +02:00
return modals.WELCOME;
}
}
2017-08-21 05:06:26 +02:00
checkShowCreditIntro(props) {
2017-08-26 05:21:26 +02:00
const { page, isCreditIntroAcknowledged, user } = props;
2017-08-21 05:06:26 +02:00
if (
!isCreditIntroAcknowledged &&
user &&
!user.is_reward_approved &&
2017-08-26 05:21:26 +02:00
(["rewards", "send", "receive", "publish", "wallet"].includes(page) ||
this.isPaidShowPage(props))
2017-08-21 05:06:26 +02:00
) {
2017-08-26 05:21:26 +02:00
return modals.CREDIT_INTRO;
}
}
2017-08-26 05:21:26 +02:00
checkShowInsufficientCredits(props) {
const { balance, page } = props;
if (balance <= 0 && ["send", "publish"].includes(page)) {
return modals.INSUFFICIENT_CREDITS;
}
}
isPaidShowPage(props) {
const { page, showPageCost } = props;
return page === "show" && showPageCost > 0;
}
render() {
const { modal } = this.props;
switch (modal) {
case modals.UPGRADE:
return <ModalUpgrade />;
case modals.DOWNLOADING:
return <ModalDownloading />;
case modals.ERROR:
return <ModalError />;
case modals.INSUFFICIENT_CREDITS:
return <ModalInsufficientCredits />;
case modals.WELCOME:
return <ModalWelcome />;
case modals.FIRST_REWARD:
return <ModalFirstReward />;
case modals.AUTHENTICATION_FAILURE:
return <ModalAuthFailure />;
case modals.CREDIT_INTRO:
return <ModalCreditIntro />;
2017-08-31 06:15:13 +02:00
case modals.TRANSACTION_FAILED:
return <ModalTransactionFailed />;
case modals.INSUFFICIENT_BALANCE:
return <ModalInsufficientBalance />;
2017-08-26 05:21:26 +02:00
case modals.REWARD_APPROVAL_REQUIRED:
return <ModalRewardApprovalRequired />;
default:
return null;
}
}
}
export default ModalRouter;