From def95d2b5cddaf722f80bc07bc7685673809b590 Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Thu, 21 Sep 2023 12:02:02 -0500 Subject: [PATCH 1/8] Add a LandingTimeline, put the site name and description on it --- src/containers/soapbox.tsx | 9 +- .../landing-timeline/components/logo-text.tsx | 16 ++ .../components/site-banner.tsx | 24 +++ src/features/landing-timeline/index.tsx | 68 +++++++++ src/features/ui/index.tsx | 11 +- src/features/ui/util/async-components.ts | 4 + src/pages/landing-page.tsx | 137 ++++++++++++++++++ 7 files changed, 260 insertions(+), 9 deletions(-) create mode 100644 src/features/landing-timeline/components/logo-text.tsx create mode 100644 src/features/landing-timeline/components/site-banner.tsx create mode 100644 src/features/landing-timeline/index.tsx create mode 100644 src/pages/landing-page.tsx diff --git a/src/containers/soapbox.tsx b/src/containers/soapbox.tsx index fb5a159718..21897ab8cc 100644 --- a/src/containers/soapbox.tsx +++ b/src/containers/soapbox.tsx @@ -18,7 +18,6 @@ import Helmet from 'soapbox/components/helmet'; import LoadingScreen from 'soapbox/components/loading-screen'; import { StatProvider } from 'soapbox/contexts/stat-context'; import EmbeddedStatus from 'soapbox/features/embedded-status'; -import PublicLayout from 'soapbox/features/public-layout'; import BundleContainer from 'soapbox/features/ui/containers/bundle-container'; import { ModalContainer, @@ -95,12 +94,8 @@ const SoapboxMount = () => { /** Render the auth layout or UI. */ const renderSwitch = () => ( - {!me && (redirectRootNoLogin - ? - : )} - - {!me && ( - + {(!me && redirectRootNoLogin) && ( + )} diff --git a/src/features/landing-timeline/components/logo-text.tsx b/src/features/landing-timeline/components/logo-text.tsx new file mode 100644 index 0000000000..eeaaa0070b --- /dev/null +++ b/src/features/landing-timeline/components/logo-text.tsx @@ -0,0 +1,16 @@ +import React from 'react'; + +interface ILogoText { + children: React.ReactNode +} + +/** Big text in site colors, for displaying the site name. Resizes itself according to the screen size. */ +const LogoText: React.FC = ({ children }) => { + return ( +

+ {children} +

+ ); +}; + +export { LogoText }; \ No newline at end of file diff --git a/src/features/landing-timeline/components/site-banner.tsx b/src/features/landing-timeline/components/site-banner.tsx new file mode 100644 index 0000000000..91bd0bcc3c --- /dev/null +++ b/src/features/landing-timeline/components/site-banner.tsx @@ -0,0 +1,24 @@ +import React from 'react'; + +import Markup from 'soapbox/components/markup'; +import { Stack } from 'soapbox/components/ui'; +import { useInstance } from 'soapbox/hooks'; + +import { LogoText } from './logo-text'; + +const SiteBanner: React.FC = () => { + const instance = useInstance(); + + return ( + + {instance.title} + + + + ); +}; + +export { SiteBanner }; \ No newline at end of file diff --git a/src/features/landing-timeline/index.tsx b/src/features/landing-timeline/index.tsx new file mode 100644 index 0000000000..4cba394601 --- /dev/null +++ b/src/features/landing-timeline/index.tsx @@ -0,0 +1,68 @@ +import React, { useEffect } from 'react'; +import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; + +import { expandCommunityTimeline } from 'soapbox/actions/timelines'; +import { useCommunityStream } from 'soapbox/api/hooks'; +import PullToRefresh from 'soapbox/components/pull-to-refresh'; +import { Column } from 'soapbox/components/ui'; +import { useAppSelector, useAppDispatch, useSettings } from 'soapbox/hooks'; + +import Sonar from '../public-layout/components/sonar'; +import Timeline from '../ui/components/timeline'; + +import { SiteBanner } from './components/site-banner'; + +const messages = defineMessages({ + title: { id: 'column.community', defaultMessage: 'Local timeline' }, +}); + +const LandingTimeline = () => { + const intl = useIntl(); + const dispatch = useAppDispatch(); + + const settings = useSettings(); + const onlyMedia = !!settings.getIn(['community', 'other', 'onlyMedia'], false); + const next = useAppSelector(state => state.timelines.get('community')?.next); + + const timelineId = 'community'; + + const handleLoadMore = (maxId: string) => { + dispatch(expandCommunityTimeline({ url: next, maxId, onlyMedia })); + }; + + const handleRefresh = () => { + return dispatch(expandCommunityTimeline({ onlyMedia })); + }; + + useCommunityStream({ onlyMedia }); + + useEffect(() => { + dispatch(expandCommunityTimeline({ onlyMedia })); + }, [onlyMedia]); + + return ( + +
+
+ +
+
+ +
+
+ + + } + divideType='space' + /> + +
+ ); +}; + +export default LandingTimeline; diff --git a/src/features/ui/index.tsx b/src/features/ui/index.tsx index 5ff06223ec..fa1e206dd4 100644 --- a/src/features/ui/index.tsx +++ b/src/features/ui/index.tsx @@ -21,7 +21,7 @@ import withHoc from 'soapbox/components/hoc/with-hoc'; import SidebarNavigation from 'soapbox/components/sidebar-navigation'; import ThumbNavigation from 'soapbox/components/thumb-navigation'; import { Layout } from 'soapbox/components/ui'; -import { useAppDispatch, useAppSelector, useOwnAccount, useSoapboxConfig, useFeatures, useDraggedFiles, useInstance } from 'soapbox/hooks'; +import { useAppDispatch, useAppSelector, useOwnAccount, useSoapboxConfig, useFeatures, useDraggedFiles, useInstance, useLoggedIn } from 'soapbox/hooks'; import AdminPage from 'soapbox/pages/admin-page'; import ChatsPage from 'soapbox/pages/chats-page'; import DefaultPage from 'soapbox/pages/default-page'; @@ -31,6 +31,7 @@ import GroupPage from 'soapbox/pages/group-page'; import GroupsPage from 'soapbox/pages/groups-page'; import GroupsPendingPage from 'soapbox/pages/groups-pending-page'; import HomePage from 'soapbox/pages/home-page'; +import LandingPage from 'soapbox/pages/landing-page'; import ManageGroupsPage from 'soapbox/pages/manage-groups-page'; import ProfilePage from 'soapbox/pages/profile-page'; import RemoteInstancePage from 'soapbox/pages/remote-instance-page'; @@ -139,6 +140,7 @@ import { PasswordResetConfirm, RegisterInvite, ExternalLogin, + LandingTimeline, } from './util/async-components'; import GlobalHotkeys from './util/global-hotkeys'; import { WrappedRoute } from './util/react-router-helpers'; @@ -167,6 +169,7 @@ const SwitchingColumnsArea: React.FC = ({ children }) => const instance = useInstance(); const features = useFeatures(); const { search } = useLocation(); + const { isLoggedIn } = useLoggedIn(); const { authenticatedProfile, cryptoAddresses } = useSoapboxConfig(); const hasCrypto = cryptoAddresses.size > 0; @@ -181,7 +184,11 @@ const SwitchingColumnsArea: React.FC = ({ children }) => - + {isLoggedIn ? ( + + ) : ( + + )} {/* NOTE: we cannot nest routes in a fragment diff --git a/src/features/ui/util/async-components.ts b/src/features/ui/util/async-components.ts index bef8fcf30c..120617f49d 100644 --- a/src/features/ui/util/async-components.ts +++ b/src/features/ui/util/async-components.ts @@ -10,6 +10,10 @@ export function Notifications() { return import('../../notifications'); } +export function LandingTimeline() { + return import('../../landing-timeline'); +} + export function HomeTimeline() { return import('../../home-timeline'); } diff --git a/src/pages/landing-page.tsx b/src/pages/landing-page.tsx new file mode 100644 index 0000000000..8a892e938e --- /dev/null +++ b/src/pages/landing-page.tsx @@ -0,0 +1,137 @@ +import clsx from 'clsx'; +import React, { useRef } from 'react'; +import { useIntl } from 'react-intl'; +import { Link } from 'react-router-dom'; + +import { uploadCompose } from 'soapbox/actions/compose'; +import LinkFooter from 'soapbox/features/ui/components/link-footer'; +import { + WhoToFollowPanel, + TrendsPanel, + SignUpPanel, + PromoPanel, + FundingPanel, + CryptoDonatePanel, + BirthdayPanel, + CtaBanner, + AnnouncementsPanel, +} from 'soapbox/features/ui/util/async-components'; +import { useAppSelector, useOwnAccount, useFeatures, useSoapboxConfig, useDraggedFiles, useAppDispatch } from 'soapbox/hooks'; + +import { Avatar, Card, CardBody, HStack, Layout } from '../components/ui'; +import ComposeForm from '../features/compose/components/compose-form'; +import BundleContainer from '../features/ui/containers/bundle-container'; + +interface ILandingPage { + children: React.ReactNode +} + +const LandingPage: React.FC = ({ children }) => { + const intl = useIntl(); + const dispatch = useAppDispatch(); + + const me = useAppSelector(state => state.me); + const { account } = useOwnAccount(); + const features = useFeatures(); + const soapboxConfig = useSoapboxConfig(); + + const composeId = 'home'; + const composeBlock = useRef(null); + + const hasPatron = soapboxConfig.extensions.getIn(['patron', 'enabled']) === true; + const hasCrypto = typeof soapboxConfig.cryptoAddresses.getIn([0, 'ticker']) === 'string'; + const cryptoLimit = soapboxConfig.cryptoDonatePanel.get('limit', 0); + + const { isDragging, isDraggedOver } = useDraggedFiles(composeBlock, (files) => { + dispatch(uploadCompose(composeId, files, intl)); + }); + + const acct = account ? account.acct : ''; + const avatar = account ? account.avatar : ''; + + return ( + <> + + {me && ( + + + + + + + +
+ +
+
+
+
+ )} + + {children} + + {!me && ( + + {Component => } + + )} +
+ + + {!me && ( + + {Component => } + + )} + {me && features.announcements && ( + + {Component => } + + )} + {features.trends && ( + + {Component => } + + )} + {hasPatron && ( + + {Component => } + + )} + {hasCrypto && cryptoLimit > 0 && ( + + {Component => } + + )} + + {Component => } + + {features.birthdays && ( + + {Component => } + + )} + {me && features.suggestions && ( + + {Component => } + + )} + + + + ); +}; + +export default LandingPage; From a131f274b43366412aca3ef8512b4eb8babeb352 Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Thu, 21 Sep 2023 13:08:33 -0500 Subject: [PATCH 2/8] LandingPage: remove donation widgets from sidebar when logged out --- src/pages/landing-page.tsx | 96 ++------------------------------------ 1 file changed, 5 insertions(+), 91 deletions(-) diff --git a/src/pages/landing-page.tsx b/src/pages/landing-page.tsx index 8a892e938e..1eba1de91b 100644 --- a/src/pages/landing-page.tsx +++ b/src/pages/landing-page.tsx @@ -1,25 +1,14 @@ -import clsx from 'clsx'; -import React, { useRef } from 'react'; -import { useIntl } from 'react-intl'; -import { Link } from 'react-router-dom'; +import React from 'react'; -import { uploadCompose } from 'soapbox/actions/compose'; import LinkFooter from 'soapbox/features/ui/components/link-footer'; import { - WhoToFollowPanel, TrendsPanel, SignUpPanel, - PromoPanel, - FundingPanel, - CryptoDonatePanel, - BirthdayPanel, CtaBanner, - AnnouncementsPanel, } from 'soapbox/features/ui/util/async-components'; -import { useAppSelector, useOwnAccount, useFeatures, useSoapboxConfig, useDraggedFiles, useAppDispatch } from 'soapbox/hooks'; +import { useAppSelector, useFeatures } from 'soapbox/hooks'; -import { Avatar, Card, CardBody, HStack, Layout } from '../components/ui'; -import ComposeForm from '../features/compose/components/compose-form'; +import { Layout } from '../components/ui'; import BundleContainer from '../features/ui/containers/bundle-container'; interface ILandingPage { @@ -27,64 +16,17 @@ interface ILandingPage { } const LandingPage: React.FC = ({ children }) => { - const intl = useIntl(); - const dispatch = useAppDispatch(); - const me = useAppSelector(state => state.me); - const { account } = useOwnAccount(); const features = useFeatures(); - const soapboxConfig = useSoapboxConfig(); - - const composeId = 'home'; - const composeBlock = useRef(null); - - const hasPatron = soapboxConfig.extensions.getIn(['patron', 'enabled']) === true; - const hasCrypto = typeof soapboxConfig.cryptoAddresses.getIn([0, 'ticker']) === 'string'; - const cryptoLimit = soapboxConfig.cryptoDonatePanel.get('limit', 0); - - const { isDragging, isDraggedOver } = useDraggedFiles(composeBlock, (files) => { - dispatch(uploadCompose(composeId, files, intl)); - }); - - const acct = account ? account.acct : ''; - const avatar = account ? account.avatar : ''; return ( <> - {me && ( - - - - - - - -
- -
-
-
-
- )} - {children} {!me && ( - {Component => } + {Component => } )}
@@ -95,40 +37,12 @@ const LandingPage: React.FC = ({ children }) => { {Component => } )} - {me && features.announcements && ( - - {Component => } - - )} {features.trends && ( {Component => } )} - {hasPatron && ( - - {Component => } - - )} - {hasCrypto && cryptoLimit > 0 && ( - - {Component => } - - )} - - {Component => } - - {features.birthdays && ( - - {Component => } - - )} - {me && features.suggestions && ( - - {Component => } - - )} - + ); From ae86a17ea146be6751d74ef9a80da5f458e3bbeb Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Thu, 21 Sep 2023 13:10:25 -0500 Subject: [PATCH 3/8] HomePage: hide donation widgets until logged in --- src/pages/home-page.tsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/pages/home-page.tsx b/src/pages/home-page.tsx index 6ed7b8eea8..06a9311e2a 100644 --- a/src/pages/home-page.tsx +++ b/src/pages/home-page.tsx @@ -108,12 +108,12 @@ const HomePage: React.FC = ({ children }) => { {Component => } )} - {hasPatron && ( + {(hasPatron && me) && ( {Component => } )} - {hasCrypto && cryptoLimit > 0 && ( + {(hasCrypto && cryptoLimit > 0 && me) && ( {Component => } From c697f9a92cef26005be319e772699944f164e09c Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Thu, 21 Sep 2023 13:12:31 -0500 Subject: [PATCH 4/8] LandingTimeline: remove page title --- src/features/landing-timeline/index.tsx | 9 ++------- 1 file changed, 2 insertions(+), 7 deletions(-) diff --git a/src/features/landing-timeline/index.tsx b/src/features/landing-timeline/index.tsx index 4cba394601..cbe25e2aaa 100644 --- a/src/features/landing-timeline/index.tsx +++ b/src/features/landing-timeline/index.tsx @@ -1,5 +1,5 @@ import React, { useEffect } from 'react'; -import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; +import { FormattedMessage } from 'react-intl'; import { expandCommunityTimeline } from 'soapbox/actions/timelines'; import { useCommunityStream } from 'soapbox/api/hooks'; @@ -12,12 +12,7 @@ import Timeline from '../ui/components/timeline'; import { SiteBanner } from './components/site-banner'; -const messages = defineMessages({ - title: { id: 'column.community', defaultMessage: 'Local timeline' }, -}); - const LandingTimeline = () => { - const intl = useIntl(); const dispatch = useAppDispatch(); const settings = useSettings(); @@ -41,7 +36,7 @@ const LandingTimeline = () => { }, [onlyMedia]); return ( - +
From 2f3350267c6778b88d263f4d34c04288c4f61ea3 Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Thu, 21 Sep 2023 13:43:52 -0500 Subject: [PATCH 5/8] LandingTimeline: remove sonar animation --- src/features/landing-timeline/index.tsx | 12 +++--------- 1 file changed, 3 insertions(+), 9 deletions(-) diff --git a/src/features/landing-timeline/index.tsx b/src/features/landing-timeline/index.tsx index cbe25e2aaa..f485a831b7 100644 --- a/src/features/landing-timeline/index.tsx +++ b/src/features/landing-timeline/index.tsx @@ -7,7 +7,6 @@ import PullToRefresh from 'soapbox/components/pull-to-refresh'; import { Column } from 'soapbox/components/ui'; import { useAppSelector, useAppDispatch, useSettings } from 'soapbox/hooks'; -import Sonar from '../public-layout/components/sonar'; import Timeline from '../ui/components/timeline'; import { SiteBanner } from './components/site-banner'; @@ -36,14 +35,9 @@ const LandingTimeline = () => { }, [onlyMedia]); return ( - -
-
- -
-
- -
+ +
+
From ecc0897ee6f8cf2c8374c1280cdd99d1cc650c1d Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Thu, 21 Sep 2023 13:45:58 -0500 Subject: [PATCH 6/8] Delete PublicLayout and legacy LandingPage --- .../__tests__/landing-page.test.tsx | 40 ---- src/features/landing-page/index.tsx | 108 ----------- .../components/__tests__/header.test.tsx | 25 --- .../public-layout/components/footer.tsx | 51 ------ .../public-layout/components/header.tsx | 171 ------------------ .../public-layout/components/sonar.tsx | 16 -- src/features/public-layout/index.tsx | 41 ----- 7 files changed, 452 deletions(-) delete mode 100644 src/features/landing-page/__tests__/landing-page.test.tsx delete mode 100644 src/features/landing-page/index.tsx delete mode 100644 src/features/public-layout/components/__tests__/header.test.tsx delete mode 100644 src/features/public-layout/components/footer.tsx delete mode 100644 src/features/public-layout/components/header.tsx delete mode 100644 src/features/public-layout/components/sonar.tsx delete mode 100644 src/features/public-layout/index.tsx diff --git a/src/features/landing-page/__tests__/landing-page.test.tsx b/src/features/landing-page/__tests__/landing-page.test.tsx deleted file mode 100644 index bbc96deebf..0000000000 --- a/src/features/landing-page/__tests__/landing-page.test.tsx +++ /dev/null @@ -1,40 +0,0 @@ -import React from 'react'; - -import { rememberInstance } from 'soapbox/actions/instance'; -import { render, screen, rootReducer } from 'soapbox/jest/test-helpers'; - -import LandingPage from '..'; - -describe('', () => { - it('renders a RegistrationForm for an open Pleroma instance', () => { - - const state = rootReducer(undefined, { - type: rememberInstance.fulfilled.type, - payload: { - version: '2.7.2 (compatible; Pleroma 2.3.0)', - registrations: true, - }, - }); - - render(, undefined, state); - - expect(screen.queryByTestId('registrations-open')).toBeInTheDocument(); - expect(screen.queryByTestId('registrations-closed')).not.toBeInTheDocument(); - }); - - it('renders "closed" message for a closed Pleroma instance', () => { - - const state = rootReducer(undefined, { - type: rememberInstance.fulfilled.type, - payload: { - version: '2.7.2 (compatible; Pleroma 2.3.0)', - registrations: false, - }, - }); - - render(, undefined, state); - - expect(screen.queryByTestId('registrations-closed')).toBeInTheDocument(); - expect(screen.queryByTestId('registrations-open')).not.toBeInTheDocument(); - }); -}); diff --git a/src/features/landing-page/index.tsx b/src/features/landing-page/index.tsx deleted file mode 100644 index a31d7d3137..0000000000 --- a/src/features/landing-page/index.tsx +++ /dev/null @@ -1,108 +0,0 @@ -import React from 'react'; -import { FormattedMessage } from 'react-intl'; - -import { prepareRequest } from 'soapbox/actions/consumer-auth'; -import Markup from 'soapbox/components/markup'; -import { Button, Card, CardBody, Stack, Text } from 'soapbox/components/ui'; -import RegistrationForm from 'soapbox/features/auth-login/components/registration-form'; -import { useAppDispatch, useFeatures, useInstance, useSoapboxConfig } from 'soapbox/hooks'; -import { capitalize } from 'soapbox/utils/strings'; - -const LandingPage = () => { - const dispatch = useAppDispatch(); - const features = useFeatures(); - const soapboxConfig = useSoapboxConfig(); - const instance = useInstance(); - - /** Registrations are closed */ - const renderClosed = () => { - return ( - - - - - - - - - ); - }; - - /** Mastodon API registrations are open */ - const renderOpen = () => { - return ; - }; - - /** Display login button for external provider. */ - const renderProvider = () => { - const { authProvider } = soapboxConfig; - - return ( - - - - - - - - - - ); - }; - - // Render registration flow depending on features - const renderBody = () => { - if (soapboxConfig.authProvider) { - return renderProvider(); - } else if (features.accountCreation && instance.registrations) { - return renderOpen(); - } else { - return renderClosed(); - } - }; - - return ( -
-
-
-
-
- -

- {instance.title} -

- - -
-
-
-
- - - {renderBody()} - - -
-
-
-
- ); -}; - -export default LandingPage; diff --git a/src/features/public-layout/components/__tests__/header.test.tsx b/src/features/public-layout/components/__tests__/header.test.tsx deleted file mode 100644 index 4472ce7b44..0000000000 --- a/src/features/public-layout/components/__tests__/header.test.tsx +++ /dev/null @@ -1,25 +0,0 @@ -import React from 'react'; - -import { storeOpen } from 'soapbox/jest/mock-stores'; -import { render, screen } from 'soapbox/jest/test-helpers'; - -import Header from '../header'; - -describe('
', () => { - it('successfully renders', () => { - render(
); - expect(screen.getByTestId('public-layout-header')).toBeInTheDocument(); - }); - - it('doesn\'t display the signup button by default', () => { - render(
); - expect(screen.queryByText('Register')).not.toBeInTheDocument(); - }); - - describe('with registrations enabled', () => { - it('displays the signup button', () => { - render(
, undefined, storeOpen); - expect(screen.getByText('Register')).toBeInTheDocument(); - }); - }); -}); \ No newline at end of file diff --git a/src/features/public-layout/components/footer.tsx b/src/features/public-layout/components/footer.tsx deleted file mode 100644 index 4038b5d186..0000000000 --- a/src/features/public-layout/components/footer.tsx +++ /dev/null @@ -1,51 +0,0 @@ -import { List as ImmutableList } from 'immutable'; -import React from 'react'; -import { Link } from 'react-router-dom'; - -import { getSettings } from 'soapbox/actions/settings'; -import { getSoapboxConfig } from 'soapbox/actions/soapbox'; -import { Text } from 'soapbox/components/ui'; -import { useAppSelector } from 'soapbox/hooks'; - -import type { FooterItem } from 'soapbox/types/soapbox'; - -const Footer = () => { - const { copyright, navlinks, locale } = useAppSelector((state) => { - const soapboxConfig = getSoapboxConfig(state); - - return { - copyright: soapboxConfig.copyright, - navlinks: (soapboxConfig.navlinks.get('homeFooter') || ImmutableList()) as ImmutableList, - locale: getSettings(state).get('locale') as string, - }; - }); - - return ( -
-
- {navlinks.map((link, idx) => { - const url = link.get('url'); - const isExternal = url.startsWith('http'); - const Comp = (isExternal ? 'a' : Link) as 'a'; - const compProps = isExternal ? { href: url, target: '_blank' } : { to: url }; - - return ( -
- - - {(link.getIn(['titleLocales', locale]) || link.get('title')) as string} - - -
- ); - })} -
- -
- {copyright} -
-
- ); -}; - -export default Footer; diff --git a/src/features/public-layout/components/header.tsx b/src/features/public-layout/components/header.tsx deleted file mode 100644 index 1d6edae19c..0000000000 --- a/src/features/public-layout/components/header.tsx +++ /dev/null @@ -1,171 +0,0 @@ -import React from 'react'; -import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; -import { Link, Redirect } from 'react-router-dom'; - -import { logIn, verifyCredentials } from 'soapbox/actions/auth'; -import { fetchInstance } from 'soapbox/actions/instance'; -import { openModal } from 'soapbox/actions/modals'; -import SiteLogo from 'soapbox/components/site-logo'; -import { Button, Form, HStack, IconButton, Input, Tooltip } from 'soapbox/components/ui'; -import { useSoapboxConfig, useOwnAccount, useAppDispatch, useRegistrationStatus, useFeatures } from 'soapbox/hooks'; - -import Sonar from './sonar'; - -import type { AxiosError } from 'axios'; - -const messages = defineMessages({ - menu: { id: 'header.menu.title', defaultMessage: 'Open menu' }, - home: { id: 'header.home.label', defaultMessage: 'Home' }, - login: { id: 'header.login.label', defaultMessage: 'Log in' }, - register: { id: 'header.register.label', defaultMessage: 'Register' }, - username: { id: 'header.login.username.placeholder', defaultMessage: 'E-mail or username' }, - email: { id: 'header.login.email.placeholder', defaultMessage: 'E-mail address' }, - password: { id: 'header.login.password.label', defaultMessage: 'Password' }, - forgotPassword: { id: 'header.login.forgot_password', defaultMessage: 'Forgot password?' }, -}); - -const Header = () => { - const dispatch = useAppDispatch(); - const intl = useIntl(); - const features = useFeatures(); - - const { account } = useOwnAccount(); - const soapboxConfig = useSoapboxConfig(); - const { isOpen } = useRegistrationStatus(); - const { links } = soapboxConfig; - - const [isLoading, setLoading] = React.useState(false); - const [username, setUsername] = React.useState(''); - const [password, setPassword] = React.useState(''); - const [shouldRedirect, setShouldRedirect] = React.useState(false); - const [mfaToken, setMfaToken] = React.useState(false); - - const open = () => dispatch(openModal('LANDING_PAGE')); - - const handleSubmit: React.FormEventHandler = (event) => { - event.preventDefault(); - setLoading(true); - - dispatch(logIn(username, password) as any) - .then(({ access_token }: { access_token: string }) => ( - dispatch(verifyCredentials(access_token) as any) - // Refetch the instance for authenticated fetch - .then(() => dispatch(fetchInstance())) - .then(() => setShouldRedirect(true)) - )) - .catch((error: AxiosError) => { - setLoading(false); - - const data: any = error.response?.data; - if (data?.error === 'mfa_required') { - setMfaToken(data.mfa_token); - } - }); - }; - - if (account && shouldRedirect) return ; - if (mfaToken) return ; - - return ( -
- -
- ); -}; - -export default Header; diff --git a/src/features/public-layout/components/sonar.tsx b/src/features/public-layout/components/sonar.tsx deleted file mode 100644 index 1106d5ba5c..0000000000 --- a/src/features/public-layout/components/sonar.tsx +++ /dev/null @@ -1,16 +0,0 @@ -import React from 'react'; - -const Sonar = () => ( -
-
-
-
-
-
- -
-
-
-); - -export default Sonar; diff --git a/src/features/public-layout/index.tsx b/src/features/public-layout/index.tsx deleted file mode 100644 index e39bb7508b..0000000000 --- a/src/features/public-layout/index.tsx +++ /dev/null @@ -1,41 +0,0 @@ -import React from 'react'; -import { Switch, Route, Redirect } from 'react-router-dom'; - -import LandingGradient from 'soapbox/components/landing-gradient'; -import { useAppSelector } from 'soapbox/hooks'; -import { isStandalone } from 'soapbox/utils/state'; - -import LandingPage from '../landing-page'; - -import Footer from './components/footer'; -import Header from './components/header'; - -const PublicLayout = () => { - const standalone = useAppSelector((state) => isStandalone(state)); - - if (standalone) { - return ; - } - - return ( -
- - -
-
-
- -
- - - -
-
- -
-
-
- ); -}; - -export default PublicLayout; From f0cc9ed4d4c173856665cea1d125982f7414d1ae Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Thu, 21 Sep 2023 13:50:31 -0500 Subject: [PATCH 7/8] Fix EmptyPage being an actual empty page --- src/features/ui/index.tsx | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/src/features/ui/index.tsx b/src/features/ui/index.tsx index fa1e206dd4..7eb39b30bd 100644 --- a/src/features/ui/index.tsx +++ b/src/features/ui/index.tsx @@ -25,6 +25,7 @@ import { useAppDispatch, useAppSelector, useOwnAccount, useSoapboxConfig, useFea import AdminPage from 'soapbox/pages/admin-page'; import ChatsPage from 'soapbox/pages/chats-page'; import DefaultPage from 'soapbox/pages/default-page'; +import EmptyPage from 'soapbox/pages/empty-page'; import EventPage from 'soapbox/pages/event-page'; import EventsPage from 'soapbox/pages/events-page'; import GroupPage from 'soapbox/pages/group-page'; @@ -159,8 +160,6 @@ const EditGroupSlug = withHoc(EditGroup as any, GroupLookupHoc); const GroupBlockedMembersSlug = withHoc(GroupBlockedMembers as any, GroupLookupHoc); const GroupMembershipRequestsSlug = withHoc(GroupMembershipRequests as any, GroupLookupHoc); -const EmptyPage = HomePage; - interface ISwitchingColumnsArea { children: React.ReactNode } @@ -366,7 +365,7 @@ const SwitchingColumnsArea: React.FC = ({ children }) => {(features.accountCreation && instance.registrations) && ( - + )} From 2e35c426d4c7c73e1730ff248e54a35b2864bbc7 Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Thu, 21 Sep 2023 13:51:09 -0500 Subject: [PATCH 8/8] Fix search being a public route --- src/features/ui/index.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/features/ui/index.tsx b/src/features/ui/index.tsx index 7eb39b30bd..179f123e27 100644 --- a/src/features/ui/index.tsx +++ b/src/features/ui/index.tsx @@ -260,7 +260,7 @@ const SwitchingColumnsArea: React.FC = ({ children }) => - + {features.suggestions && } {features.profileDirectory && } {features.events && }