import React from 'react'; import ModalError from 'modal/modalError'; import ModalAuthFailure from 'modal/modalAuthFailure'; import ModalDownloading from 'modal/modalDownloading'; import ModalUpgrade from 'modal/modalUpgrade'; import ModalWelcome from 'modal/modalWelcome'; import ModalFirstReward from 'modal/modalFirstReward'; import ModalRewardApprovalRequired from 'modal/modalRewardApprovalRequired'; import ModalCreditIntro from 'modal/modalCreditIntro'; import ModalRemoveFile from 'modal/modalRemoveFile'; import ModalTransactionFailed from 'modal/modalTransactionFailed'; import ModalFileTimeout from 'modal/modalFileTimeout'; import ModalAffirmPurchase from 'modal/modalAffirmPurchase'; import ModalRevokeClaim from 'modal/modalRevokeClaim'; import ModalEmailCollection from '../modalEmailCollection'; import * as modals from 'constants/modal_types'; class ModalRouter extends React.PureComponent { constructor(props) { super(props); this.state = { lastTransitionModal: null, lastTransitionPage: null, }; } componentWillMount() { this.showTransitionModals(this.props); } componentWillReceiveProps(nextProps) { this.showTransitionModals(nextProps); } showTransitionModals(props) { const { modal, modalProps, openModal, page } = props; if (modal) { return; } const transitionModal = [ this.checkShowWelcome, this.checkShowEmail, this.checkShowCreditIntro, ].reduce((acc, func) => (!acc ? func.bind(this)(props) : acc), false); if ( transitionModal && (transitionModal != this.state.lastTransitionModal || page != this.state.lastTransitionPage) ) { openModal(transitionModal); this.setState({ lastTransitionModal: transitionModal, lastTransitionPage: page, }); } } checkShowWelcome(props) { const { isWelcomeAcknowledged, user } = props; if (!isWelcomeAcknowledged && user && !user.is_reward_approved && !user.is_identity_verified) { return modals.WELCOME; } } checkShowEmail(props) { const { isEmailCollectionAcknowledged, isVerificationCandidate, user } = props; if ( !isEmailCollectionAcknowledged && isVerificationCandidate && user && !user.has_verified_email ) { return modals.EMAIL_COLLECTION; } } checkShowCreditIntro(props) { const { balance, page, isCreditIntroAcknowledged } = props; if ( balance <= 0 && !isCreditIntroAcknowledged && (['send', 'publish'].includes(page) || this.isPaidShowPage(props)) ) { return modals.INSUFFICIENT_CREDITS; } } isPaidShowPage(props) { const { page, showPageCost } = props; return page === 'show' && showPageCost > 0; } render() { const { modal, modalProps } = this.props; switch (modal) { case modals.UPGRADE: return ; case modals.DOWNLOADING: return ; case modals.ERROR: return ; case modals.FILE_TIMEOUT: return ; case modals.INSUFFICIENT_CREDITS: return ; case modals.WELCOME: return ; case modals.FIRST_REWARD: return ; case modals.AUTHENTICATION_FAILURE: return ; case modals.TRANSACTION_FAILED: return ; case modals.REWARD_APPROVAL_REQUIRED: return ; case modals.CONFIRM_FILE_REMOVE: return ; case modals.AFFIRM_PURCHASE: return ; case modals.CONFIRM_CLAIM_REVOKE: return ; case modals.EMAIL_COLLECTION: return ; default: return null; } } } export default ModalRouter;