SoapboxMount: async import NotificationsContainer, ModalContainer, remove them elsewhere
This commit is contained in:
parent
8354447047
commit
e298115fcf
5 changed files with 11 additions and 45 deletions
|
@ -18,8 +18,8 @@ import LoadingScreen from 'soapbox/components/loading-screen';
|
||||||
import AuthLayout from 'soapbox/features/auth_layout';
|
import AuthLayout from 'soapbox/features/auth_layout';
|
||||||
import OnboardingWizard from 'soapbox/features/onboarding/onboarding-wizard';
|
import OnboardingWizard from 'soapbox/features/onboarding/onboarding-wizard';
|
||||||
import PublicLayout from 'soapbox/features/public_layout';
|
import PublicLayout from 'soapbox/features/public_layout';
|
||||||
import NotificationsContainer from 'soapbox/features/ui/containers/notifications_container';
|
import BundleContainer from 'soapbox/features/ui/containers/bundle_container';
|
||||||
import { ModalContainer } from 'soapbox/features/ui/util/async-components';
|
import { ModalContainer, NotificationsContainer } from 'soapbox/features/ui/util/async-components';
|
||||||
import WaitlistPage from 'soapbox/features/verification/waitlist_page';
|
import WaitlistPage from 'soapbox/features/verification/waitlist_page';
|
||||||
import { createGlobals } from 'soapbox/globals';
|
import { createGlobals } from 'soapbox/globals';
|
||||||
import { useAppSelector, useAppDispatch, useOwnAccount, useFeatures, useSoapboxConfig, useSettings, useSystemTheme } from 'soapbox/hooks';
|
import { useAppSelector, useAppDispatch, useOwnAccount, useFeatures, useSoapboxConfig, useSettings, useSystemTheme } from 'soapbox/hooks';
|
||||||
|
@ -31,7 +31,6 @@ import { checkOnboardingStatus } from '../actions/onboarding';
|
||||||
import { preload } from '../actions/preload';
|
import { preload } from '../actions/preload';
|
||||||
import ErrorBoundary from '../components/error_boundary';
|
import ErrorBoundary from '../components/error_boundary';
|
||||||
import UI from '../features/ui';
|
import UI from '../features/ui';
|
||||||
import BundleContainer from '../features/ui/containers/bundle_container';
|
|
||||||
import { store } from '../store';
|
import { store } from '../store';
|
||||||
|
|
||||||
/** Ensure the given locale exists in our codebase */
|
/** Ensure the given locale exists in our codebase */
|
||||||
|
@ -173,13 +172,7 @@ const SoapboxMount = () => {
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{waitlisted && (
|
{waitlisted && (
|
||||||
<>
|
<Route render={(props) => <WaitlistPage {...props} account={account} />} />
|
||||||
<Route render={(props) => <WaitlistPage {...props} account={account} />} />
|
|
||||||
|
|
||||||
<BundleContainer fetchComponent={ModalContainer}>
|
|
||||||
{Component => <Component />}
|
|
||||||
</BundleContainer>
|
|
||||||
</>
|
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{!me && (singleUserMode
|
{!me && (singleUserMode
|
||||||
|
@ -232,6 +225,14 @@ const SoapboxMount = () => {
|
||||||
<BrowserRouter basename={BuildConfig.FE_SUBDIRECTORY}>
|
<BrowserRouter basename={BuildConfig.FE_SUBDIRECTORY}>
|
||||||
<ScrollContext shouldUpdateScroll={shouldUpdateScroll}>
|
<ScrollContext shouldUpdateScroll={shouldUpdateScroll}>
|
||||||
{renderBody()}
|
{renderBody()}
|
||||||
|
|
||||||
|
<BundleContainer fetchComponent={NotificationsContainer}>
|
||||||
|
{(Component) => <Component />}
|
||||||
|
</BundleContainer>
|
||||||
|
|
||||||
|
<BundleContainer fetchComponent={ModalContainer}>
|
||||||
|
{Component => <Component />}
|
||||||
|
</BundleContainer>
|
||||||
</ScrollContext>
|
</ScrollContext>
|
||||||
</BrowserRouter>
|
</BrowserRouter>
|
||||||
</ErrorBoundary>
|
</ErrorBoundary>
|
||||||
|
|
|
@ -4,8 +4,6 @@ import { Link, Redirect, Route, Switch, useHistory } from 'react-router-dom';
|
||||||
|
|
||||||
import LandingGradient from 'soapbox/components/landing-gradient';
|
import LandingGradient from 'soapbox/components/landing-gradient';
|
||||||
import SiteLogo from 'soapbox/components/site-logo';
|
import SiteLogo from 'soapbox/components/site-logo';
|
||||||
import BundleContainer from 'soapbox/features/ui/containers/bundle_container';
|
|
||||||
import { NotificationsContainer } from 'soapbox/features/ui/util/async-components';
|
|
||||||
import { useAppSelector, useFeatures, useSoapboxConfig } from 'soapbox/hooks';
|
import { useAppSelector, useFeatures, useSoapboxConfig } from 'soapbox/hooks';
|
||||||
|
|
||||||
import { Button, Card, CardBody } from '../../components/ui';
|
import { Button, Card, CardBody } from '../../components/ui';
|
||||||
|
@ -86,10 +84,6 @@ const AuthLayout = () => {
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</main>
|
</main>
|
||||||
|
|
||||||
<BundleContainer fetchComponent={NotificationsContainer}>
|
|
||||||
{(Component) => <Component />}
|
|
||||||
</BundleContainer>
|
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
|
@ -2,11 +2,6 @@ import React from 'react';
|
||||||
import { Switch, Route, Redirect } from 'react-router-dom';
|
import { Switch, Route, Redirect } from 'react-router-dom';
|
||||||
|
|
||||||
import LandingGradient from 'soapbox/components/landing-gradient';
|
import LandingGradient from 'soapbox/components/landing-gradient';
|
||||||
import BundleContainer from 'soapbox/features/ui/containers/bundle_container';
|
|
||||||
import {
|
|
||||||
NotificationsContainer,
|
|
||||||
ModalContainer,
|
|
||||||
} from 'soapbox/features/ui/util/async-components';
|
|
||||||
import { useAppSelector } from 'soapbox/hooks';
|
import { useAppSelector } from 'soapbox/hooks';
|
||||||
import { isStandalone } from 'soapbox/utils/state';
|
import { isStandalone } from 'soapbox/utils/state';
|
||||||
|
|
||||||
|
@ -42,14 +37,6 @@ const PublicLayout = () => {
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<Footer />
|
<Footer />
|
||||||
|
|
||||||
<BundleContainer fetchComponent={NotificationsContainer}>
|
|
||||||
{(Component) => <Component />}
|
|
||||||
</BundleContainer>
|
|
||||||
|
|
||||||
<BundleContainer fetchComponent={ModalContainer}>
|
|
||||||
{(Component) => <Component />}
|
|
||||||
</BundleContainer>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|
|
@ -104,8 +104,6 @@ import {
|
||||||
Directory,
|
Directory,
|
||||||
SidebarMenu,
|
SidebarMenu,
|
||||||
UploadArea,
|
UploadArea,
|
||||||
NotificationsContainer,
|
|
||||||
ModalContainer,
|
|
||||||
ProfileHoverCard,
|
ProfileHoverCard,
|
||||||
Share,
|
Share,
|
||||||
NewStatus,
|
NewStatus,
|
||||||
|
@ -670,14 +668,6 @@ const UI: React.FC = ({ children }) => {
|
||||||
|
|
||||||
{me && floatingActionButton}
|
{me && floatingActionButton}
|
||||||
|
|
||||||
<BundleContainer fetchComponent={NotificationsContainer}>
|
|
||||||
{Component => <Component />}
|
|
||||||
</BundleContainer>
|
|
||||||
|
|
||||||
<BundleContainer fetchComponent={ModalContainer}>
|
|
||||||
{Component => <Component />}
|
|
||||||
</BundleContainer>
|
|
||||||
|
|
||||||
<BundleContainer fetchComponent={UploadArea}>
|
<BundleContainer fetchComponent={UploadArea}>
|
||||||
{Component => <Component active={draggingOver} onClose={closeUploadModal} />}
|
{Component => <Component active={draggingOver} onClose={closeUploadModal} />}
|
||||||
</BundleContainer>
|
</BundleContainer>
|
||||||
|
|
|
@ -7,8 +7,6 @@ import { Link } from 'react-router-dom';
|
||||||
import { openModal } from 'soapbox/actions/modals';
|
import { openModal } from 'soapbox/actions/modals';
|
||||||
import LandingGradient from 'soapbox/components/landing-gradient';
|
import LandingGradient from 'soapbox/components/landing-gradient';
|
||||||
import SiteLogo from 'soapbox/components/site-logo';
|
import SiteLogo from 'soapbox/components/site-logo';
|
||||||
import BundleContainer from 'soapbox/features/ui/containers/bundle_container';
|
|
||||||
import { NotificationsContainer } from 'soapbox/features/ui/util/async-components';
|
|
||||||
import { useAppSelector, useOwnAccount } from 'soapbox/hooks';
|
import { useAppSelector, useOwnAccount } from 'soapbox/hooks';
|
||||||
|
|
||||||
import { logOut } from '../../actions/auth';
|
import { logOut } from '../../actions/auth';
|
||||||
|
@ -74,10 +72,6 @@ const WaitlistPage = ({ account }) => {
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</main>
|
</main>
|
||||||
|
|
||||||
<BundleContainer fetchComponent={NotificationsContainer}>
|
|
||||||
{(Component) => <Component />}
|
|
||||||
</BundleContainer>
|
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue