// @flow import * as PAGES from 'constants/pages'; import React, { useEffect } from 'react'; import { Route, Redirect, Switch } from 'react-router-dom'; import SettingsPage from 'page/settings'; import HelpPage from 'page/help'; import ReportPage from 'page/report'; import ShowPage from 'page/show'; import PublishPage from 'page/publish'; import DiscoverPage from 'page/discover'; import HomePage from 'page/home'; import InvitedPage from 'page/invited'; import RewardsPage from 'page/rewards'; import FileListDownloaded from 'page/fileListDownloaded'; import FileListPublished from 'page/fileListPublished'; import TransactionHistoryPage from 'page/transactionHistory'; import InvitePage from 'page/invite'; import SearchPage from 'page/search'; import LibraryPage from 'page/library'; import WalletPage from 'page/wallet'; import TagsPage from 'page/tags'; import TagsFollowingPage from 'page/tagsFollowing'; import ChannelsFollowingPage from 'page/channelsFollowing'; import ChannelsFollowingManagePage from 'page/channelsFollowingManage'; import TagsFollowingManagePage from 'page/tagsFollowingManage'; import ListBlockedPage from 'page/listBlocked'; import FourOhFourPage from 'page/fourOhFour'; import SignInPage from 'page/signIn'; import SignInVerifyPage from 'page/signInVerify'; import ChannelsPage from 'page/channels'; import EmbedWrapperPage from 'page/embedWrapper'; // Tell the browser we are handling scroll restoration if ('scrollRestoration' in history) { history.scrollRestoration = 'manual'; } type PrivateRouteProps = { component: any, isAuthenticated: boolean, }; function PrivateRoute(props: PrivateRouteProps) { const { component: Component, isAuthenticated, ...rest } = props; return ( isAuthenticated || !IS_WEB ? ( ) : ( ) } /> ); } type Props = { currentScroll: number, isAuthenticated: boolean, }; function AppRouter(props: Props) { const { currentScroll, isAuthenticated } = props; const { pathname } = window.location; useEffect(() => { window.scrollTo(0, currentScroll); }, [currentScroll, pathname]); // react-router doesn't decode pathanmes before doing the route matching check // We have to redirect here because if we redirect on the server, it might get encoded again // in the browser causing a redirect loop const decodedPathname = decodeURIComponent(pathname); if (decodedPathname !== pathname) { return ; } return ( {/* Below need to go at the end to make sure we don't match any of our pages first */} ); } export default AppRouter;