lbry-desktop/src/renderer/modal/modalRouter/view.jsx

201 lines
6.5 KiB
React
Raw Normal View History

2018-09-26 02:12:07 +02:00
// @flow
import React from 'react';
import * as MODALS from 'constants/modal_types';
import ModalError from 'modal/modalError';
import ModalAuthFailure from 'modal/modalAuthFailure';
import ModalDownloading from 'modal/modalDownloading';
import ModalAutoUpdateDownloaded from 'modal/modalAutoUpdateDownloaded';
import ModalAutoUpdateConfirm from 'modal/modalAutoUpdateConfirm';
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 'modal/modalEmailCollection';
import ModalPhoneCollection from 'modal/modalPhoneCollection';
import ModalFirstSubscription from 'modal/modalFirstSubscription';
import ModalConfirmTransaction from 'modal/modalConfirmTransaction';
2018-09-12 18:42:15 +02:00
import ModalSocialShare from 'modal/modalSocialShare';
import ModalSendTip from 'modal/modalSendTip';
import ModalPublish from 'modal/modalPublish';
import ModalOpenExternalLink from 'modal/modalOpenExternalLink';
2018-04-02 18:03:12 +02:00
import ModalConfirmThumbnailUpload from 'modal/modalConfirmThumbnailUpload';
2018-07-18 21:48:30 +02:00
import ModalWalletEncrypt from 'modal/modalWalletEncrypt';
import ModalWalletDecrypt from 'modal/modalWalletDecrypt';
import ModalWalletUnlock from 'modal/modalWalletUnlock';
2018-09-26 02:12:07 +02:00
import ModalRewardCode from 'modal/modalRewardCode';
2018-04-02 18:03:12 +02:00
type Props = {
2019-01-08 03:46:33 +01:00
modal: { id: string, modalProps: {} },
error: string | { message: string },
2018-04-02 18:03:12 +02:00
};
class ModalRouter extends React.PureComponent<Props> {
2018-09-26 02:12:07 +02:00
constructor(props: Props) {
2017-08-26 05:21:26 +02:00
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) {
2018-09-26 02:12:07 +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.checkShowEmail,
2017-08-26 05:21:26 +02:00
this.checkShowCreditIntro,
].reduce((acc, func) => (!acc ? func.bind(this)(props) : acc), false);
2017-08-26 05:21:26 +02:00
if (
transitionModal &&
2018-04-02 18:03:12 +02:00
(transitionModal !== this.state.lastTransitionModal || page !== this.state.lastTransitionPage)
2017-08-26 05:21:26 +02:00
) {
openModal(transitionModal);
2017-08-26 05:21:26 +02:00
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;
2019-01-08 03:46:33 +01:00
if (!isWelcomeAcknowledged && user && !user.is_reward_approved && !user.is_identity_verified) {
return MODALS.WELCOME;
}
2018-09-26 02:12:07 +02:00
return undefined;
}
checkShowEmail(props) {
const { isEmailCollectionAcknowledged, isVerificationCandidate, user } = props;
2017-08-21 05:06:26 +02:00
if (
!isEmailCollectionAcknowledged &&
isVerificationCandidate &&
2017-08-21 05:06:26 +02:00
user &&
!user.has_verified_email
2017-08-21 05:06:26 +02:00
) {
return MODALS.EMAIL_COLLECTION;
}
2018-09-26 02:12:07 +02:00
return undefined;
}
checkShowCreditIntro(props) {
const { balance, page, isCreditIntroAcknowledged } = props;
2017-08-26 05:21:26 +02:00
if (
balance === 0 &&
!isCreditIntroAcknowledged &&
(['send', 'publish'].includes(page) || this.isPaidShowPage(props))
) {
return MODALS.INSUFFICIENT_CREDITS;
2017-08-26 05:21:26 +02:00
}
2018-09-26 02:12:07 +02:00
return undefined;
2017-08-26 05:21:26 +02:00
}
isPaidShowPage(props) {
const { page, showPageCost } = props;
return page === 'show' && showPageCost > 0;
2017-08-26 05:21:26 +02:00
}
render() {
const { modal, error } = this.props;
if (error) {
return <ModalError {...error} />;
2018-04-23 07:04:11 +02:00
}
if (!modal) {
return null;
}
const { id, modalProps } = modal;
switch (id) {
case MODALS.UPGRADE:
return <ModalUpgrade {...modalProps} />;
case MODALS.DOWNLOADING:
return <ModalDownloading {...modalProps} />;
case MODALS.AUTO_UPDATE_DOWNLOADED:
return <ModalAutoUpdateDownloaded {...modalProps} />;
case MODALS.AUTO_UPDATE_CONFIRM:
return <ModalAutoUpdateConfirm {...modalProps} />;
case MODALS.ERROR:
return <ModalError {...modalProps} />;
case MODALS.FILE_TIMEOUT:
return <ModalFileTimeout {...modalProps} />;
case MODALS.INSUFFICIENT_CREDITS:
return <ModalCreditIntro {...modalProps} />;
case MODALS.WELCOME:
return <ModalWelcome {...modalProps} />;
case MODALS.FIRST_REWARD:
return <ModalFirstReward {...modalProps} />;
case MODALS.AUTHENTICATION_FAILURE:
return <ModalAuthFailure {...modalProps} />;
case MODALS.TRANSACTION_FAILED:
return <ModalTransactionFailed {...modalProps} />;
case MODALS.REWARD_APPROVAL_REQUIRED:
return <ModalRewardApprovalRequired {...modalProps} />;
case MODALS.CONFIRM_FILE_REMOVE:
return <ModalRemoveFile {...modalProps} />;
case MODALS.AFFIRM_PURCHASE:
return <ModalAffirmPurchase {...modalProps} />;
case MODALS.CONFIRM_CLAIM_REVOKE:
return <ModalRevokeClaim {...modalProps} />;
case MODALS.PHONE_COLLECTION:
return <ModalPhoneCollection {...modalProps} />;
case MODALS.EMAIL_COLLECTION:
return <ModalEmailCollection {...modalProps} />;
case MODALS.FIRST_SUBSCRIPTION:
return <ModalFirstSubscription {...modalProps} />;
case MODALS.SEND_TIP:
return <ModalSendTip {...modalProps} />;
2018-09-12 18:42:15 +02:00
case MODALS.SOCIAL_SHARE:
return <ModalSocialShare {...modalProps} />;
case MODALS.PUBLISH:
return <ModalPublish {...modalProps} />;
case MODALS.CONFIRM_EXTERNAL_LINK:
return <ModalOpenExternalLink {...modalProps} />;
case MODALS.CONFIRM_TRANSACTION:
return <ModalConfirmTransaction {...modalProps} />;
2018-04-02 18:03:12 +02:00
case MODALS.CONFIRM_THUMBNAIL_UPLOAD:
return <ModalConfirmThumbnailUpload {...modalProps} />;
2018-07-18 21:48:30 +02:00
case MODALS.WALLET_ENCRYPT:
return <ModalWalletEncrypt {...modalProps} />;
2018-07-18 21:48:30 +02:00
case MODALS.WALLET_DECRYPT:
return <ModalWalletDecrypt {...modalProps} />;
2018-07-18 21:48:30 +02:00
case MODALS.WALLET_UNLOCK:
return <ModalWalletUnlock {...modalProps} />;
2018-09-26 02:12:07 +02:00
case MODALS.REWARD_GENERATED_CODE:
return <ModalRewardCode {...modalProps} />;
default:
return null;
}
}
}
export default ModalRouter;