2018-09-25 20:12:07 -04:00
|
|
|
// @flow
|
2017-12-21 18:08:54 -03:00
|
|
|
import React from 'react';
|
2019-12-18 00:27:08 -05:00
|
|
|
import { withRouter } from 'react-router';
|
2021-06-01 11:04:26 +08:00
|
|
|
import LoadingBarOneOff from 'component/loadingBarOneOff';
|
2022-03-16 22:18:10 +08:00
|
|
|
import * as MODALS from 'constants/modal_types';
|
|
|
|
import { lazyImport } from 'util/lazyImport';
|
2021-06-11 14:06:29 +08:00
|
|
|
|
2022-03-16 22:18:10 +08:00
|
|
|
// prettier-ignore
|
|
|
|
const MAP = Object.freeze({
|
|
|
|
[MODALS.AFFIRM_PURCHASE]: lazyImport(() => import('modal/modalAffirmPurchase' /* webpackChunkName: "modalAffirmPurchase" */)),
|
|
|
|
[MODALS.AUTO_GENERATE_THUMBNAIL]: lazyImport(() => import('modal/modalAutoGenerateThumbnail' /* webpackChunkName: "modalAutoGenerateThumbnail" */)),
|
|
|
|
[MODALS.AUTO_UPDATE_DOWNLOADED]: lazyImport(() => import('modal/modalAutoUpdateDownloaded' /* webpackChunkName: "modalAutoUpdateDownloaded" */)),
|
|
|
|
[MODALS.BLOCK_CHANNEL]: lazyImport(() => import('modal/modalBlockChannel' /* webpackChunkName: "modalBlockChannel" */)),
|
|
|
|
[MODALS.COLLECTION_ADD]: lazyImport(() => import('modal/modalClaimCollectionAdd' /* webpackChunkName: "modalClaimCollectionAdd" */)),
|
|
|
|
[MODALS.COLLECTION_DELETE]: lazyImport(() => import('modal/modalRemoveCollection' /* webpackChunkName: "modalRemoveCollection" */)),
|
|
|
|
[MODALS.CONFIRM]: lazyImport(() => import('modal/modalConfirm' /* webpackChunkName: "modalConfirm" */)),
|
|
|
|
[MODALS.CONFIRM_AGE]: lazyImport(() => import('modal/modalConfirmAge' /* webpackChunkName: "modalConfirmAge" */)),
|
|
|
|
[MODALS.CONFIRM_CLAIM_REVOKE]: lazyImport(() => import('modal/modalRevokeClaim' /* webpackChunkName: "modalRevokeClaim" */)),
|
|
|
|
[MODALS.CONFIRM_EXTERNAL_RESOURCE]: lazyImport(() => import('modal/modalOpenExternalResource' /* webpackChunkName: "modalOpenExternalResource" */)),
|
|
|
|
[MODALS.CONFIRM_FILE_REMOVE]: lazyImport(() => import('modal/modalRemoveFile' /* webpackChunkName: "modalRemoveFile" */)),
|
|
|
|
[MODALS.CONFIRM_ODYSEE_MEMBERSHIP]: lazyImport(() => import('modal/modalConfirmOdyseeMembership' /* webpackChunkName: "modalConfirmOdyseeMembership" */)),
|
|
|
|
[MODALS.CONFIRM_REMOVE_CARD]: lazyImport(() => import('modal/modalRemoveCard' /* webpackChunkName: "modalRemoveCard" */)),
|
|
|
|
[MODALS.CONFIRM_REMOVE_COMMENT]: lazyImport(() => import('modal/modalRemoveComment' /* webpackChunkName: "modalRemoveComment" */)),
|
|
|
|
[MODALS.CONFIRM_THUMBNAIL_UPLOAD]: lazyImport(() => import('modal/modalConfirmThumbnailUpload' /* webpackChunkName: "modalConfirmThumbnailUpload" */)),
|
|
|
|
[MODALS.CONFIRM_TRANSACTION]: lazyImport(() => import('modal/modalConfirmTransaction' /* webpackChunkName: "modalConfirmTransaction" */)),
|
|
|
|
[MODALS.DOWNLOADING]: lazyImport(() => import('modal/modalDownloading' /* webpackChunkName: "modalDownloading" */)),
|
|
|
|
[MODALS.ERROR]: lazyImport(() => import('modal/modalError' /* webpackChunkName: "modalError" */)),
|
|
|
|
[MODALS.FILE_SELECTION]: lazyImport(() => import('modal/modalFileSelection' /* webpackChunkName: "modalFileSelection" */)),
|
|
|
|
[MODALS.FILE_TIMEOUT]: lazyImport(() => import('modal/modalFileTimeout' /* webpackChunkName: "modalFileTimeout" */)),
|
|
|
|
[MODALS.FIRST_REWARD]: lazyImport(() => import('modal/modalFirstReward' /* webpackChunkName: "modalFirstReward" */)),
|
|
|
|
[MODALS.IMAGE_UPLOAD]: lazyImport(() => import('modal/modalImageUpload' /* webpackChunkName: "modalImageUpload" */)),
|
|
|
|
[MODALS.LIQUIDATE_SUPPORTS]: lazyImport(() => import('modal/modalSupportsLiquidate' /* webpackChunkName: "modalSupportsLiquidate" */)),
|
|
|
|
[MODALS.MASS_TIP_UNLOCK]: lazyImport(() => import('modal/modalMassTipUnlock' /* webpackChunkName: "modalMassTipUnlock" */)),
|
|
|
|
[MODALS.MEMBERSHIP_SPLASH]: lazyImport(() => import('modal/modalMembershipSplash' /* webpackChunkName: "modalMembershipSplash" */)),
|
|
|
|
[MODALS.MIN_CHANNEL_AGE]: lazyImport(() => import('modal/modalMinChannelAge' /* webpackChunkName: "modalMinChannelAge" */)),
|
|
|
|
[MODALS.MOBILE_SEARCH]: lazyImport(() => import('modal/modalMobileSearch' /* webpackChunkName: "modalMobileSearch" */)),
|
|
|
|
[MODALS.PHONE_COLLECTION]: lazyImport(() => import('modal/modalPhoneCollection' /* webpackChunkName: "modalPhoneCollection" */)),
|
|
|
|
[MODALS.PUBLISH]: lazyImport(() => import('modal/modalPublish' /* webpackChunkName: "modalPublish" */)),
|
|
|
|
[MODALS.PUBLISH_PREVIEW]: lazyImport(() => import('modal/modalPublishPreview' /* webpackChunkName: "modalPublishPreview" */)),
|
|
|
|
[MODALS.REWARD_GENERATED_CODE]: lazyImport(() => import('modal/modalRewardCode' /* webpackChunkName: "modalRewardCode" */)),
|
|
|
|
[MODALS.SEND_TIP]: lazyImport(() => import('modal/modalSendTip' /* webpackChunkName: "modalSendTip" */)),
|
|
|
|
[MODALS.SET_REFERRER]: lazyImport(() => import('modal/modalSetReferrer' /* webpackChunkName: "modalSetReferrer" */)),
|
|
|
|
[MODALS.SOCIAL_SHARE]: lazyImport(() => import('modal/modalSocialShare' /* webpackChunkName: "modalSocialShare" */)),
|
|
|
|
[MODALS.SYNC_ENABLE]: lazyImport(() => import('modal/modalSyncEnable' /* webpackChunkName: "modalSyncEnable" */)),
|
|
|
|
[MODALS.TRANSACTION_FAILED]: lazyImport(() => import('modal/modalTransactionFailed' /* webpackChunkName: "modalTransactionFailed" */)),
|
|
|
|
[MODALS.UPGRADE]: lazyImport(() => import('modal/modalUpgrade' /* webpackChunkName: "modalUpgrade" */)),
|
|
|
|
[MODALS.VIEW_IMAGE]: lazyImport(() => import('modal/modalViewImage' /* webpackChunkName: "modalViewImage" */)),
|
|
|
|
[MODALS.WALLET_DECRYPT]: lazyImport(() => import('modal/modalWalletDecrypt' /* webpackChunkName: "modalWalletDecrypt" */)),
|
|
|
|
[MODALS.WALLET_ENCRYPT]: lazyImport(() => import('modal/modalWalletEncrypt' /* webpackChunkName: "modalWalletEncrypt" */)),
|
|
|
|
[MODALS.WALLET_PASSWORD_UNSAVE]: lazyImport(() => import('modal/modalPasswordUnsave' /* webpackChunkName: "modalPasswordUnsave" */)),
|
|
|
|
[MODALS.WALLET_UNLOCK]: lazyImport(() => import('modal/modalWalletUnlock' /* webpackChunkName: "modalWalletUnlock" */)),
|
|
|
|
[MODALS.YOUTUBE_WELCOME]: lazyImport(() => import('modal/modalYoutubeWelcome' /* webpackChunkName: "modalYoutubeWelcome" */)),
|
|
|
|
});
|
2021-11-03 10:06:57 +08:00
|
|
|
|
2018-04-02 12:03:12 -04:00
|
|
|
type Props = {
|
2019-01-07 21:46:33 -05:00
|
|
|
modal: { id: string, modalProps: {} },
|
2019-01-09 20:38:26 -05:00
|
|
|
error: { message: string },
|
2019-12-18 00:27:08 -05:00
|
|
|
location: { pathname: string },
|
|
|
|
hideModal: () => void,
|
2018-04-02 12:03:12 -04:00
|
|
|
};
|
|
|
|
|
2019-04-03 00:17:00 -04:00
|
|
|
function ModalRouter(props: Props) {
|
2019-12-18 00:27:08 -05:00
|
|
|
const { modal, error, location, hideModal } = props;
|
|
|
|
const { pathname } = location;
|
|
|
|
|
|
|
|
React.useEffect(() => {
|
|
|
|
hideModal();
|
|
|
|
}, [pathname, hideModal]);
|
2017-08-18 13:09:40 -04:00
|
|
|
|
2019-04-03 00:17:00 -04:00
|
|
|
if (error) {
|
2022-03-16 22:18:10 +08:00
|
|
|
const ModalError = MAP[MODALS.ERROR];
|
2021-11-03 10:06:57 +08:00
|
|
|
return (
|
|
|
|
<React.Suspense fallback={<LoadingBarOneOff />}>
|
|
|
|
<ModalError {...error} />
|
|
|
|
</React.Suspense>
|
|
|
|
);
|
2017-08-18 13:09:40 -04:00
|
|
|
}
|
|
|
|
|
2019-04-03 00:17:00 -04:00
|
|
|
if (!modal) {
|
|
|
|
return null;
|
2017-08-20 23:06:26 -04:00
|
|
|
}
|
|
|
|
|
2019-04-03 00:17:00 -04:00
|
|
|
const { id, modalProps } = modal;
|
2022-03-16 22:18:10 +08:00
|
|
|
const SelectedModal = MAP[id];
|
2019-04-03 00:17:00 -04:00
|
|
|
|
2022-03-16 22:18:10 +08:00
|
|
|
if (!SelectedModal) {
|
2021-06-11 14:06:29 +08:00
|
|
|
return null;
|
2017-08-18 13:09:40 -04:00
|
|
|
}
|
2021-06-11 14:06:29 +08:00
|
|
|
|
|
|
|
return (
|
2021-06-01 11:04:26 +08:00
|
|
|
<React.Suspense fallback={<LoadingBarOneOff />}>
|
2021-06-11 14:06:29 +08:00
|
|
|
<SelectedModal {...modalProps} />
|
|
|
|
</React.Suspense>
|
|
|
|
);
|
2017-08-18 13:09:40 -04:00
|
|
|
}
|
|
|
|
|
2019-12-18 00:27:08 -05:00
|
|
|
export default withRouter(ModalRouter);
|