diff --git a/app/soapbox/components/ui/text/text.tsx b/app/soapbox/components/ui/text/text.tsx
index 5ecfadf39d..072491109c 100644
--- a/app/soapbox/components/ui/text/text.tsx
+++ b/app/soapbox/components/ui/text/text.tsx
@@ -31,7 +31,7 @@ const weights = {
const sizes = {
xs: 'text-xs',
sm: 'text-sm',
- md: 'text-md',
+ md: 'text-base',
lg: 'text-lg',
xl: 'text-xl',
'2xl': 'text-2xl',
diff --git a/app/soapbox/features/ui/components/__tests__/cta-banner.test.tsx b/app/soapbox/features/ui/components/__tests__/cta-banner.test.tsx
new file mode 100644
index 0000000000..cc4c118e69
--- /dev/null
+++ b/app/soapbox/features/ui/components/__tests__/cta-banner.test.tsx
@@ -0,0 +1,30 @@
+import { Map as ImmutableMap } from 'immutable';
+import React from 'react';
+
+import { render, screen } from '../../../../jest/test-helpers';
+import CtaBanner from '../cta-banner';
+
+describe('', () => {
+ it('renders the banner', () => {
+ render();
+ expect(screen.getByTestId('cta-banner')).toHaveTextContent(/sign up/i);
+ });
+
+ describe('with a logged in user', () => {
+ it('renders empty', () => {
+ const store = { me: true };
+
+ render(, null, store);
+ expect(screen.queryAllByTestId('cta-banner')).toHaveLength(0);
+ });
+ });
+
+ describe('with singleUserMode enabled', () => {
+ it('renders empty', () => {
+ const store = { soapbox: ImmutableMap({ singleUserMode: true }) };
+
+ render(, null, store);
+ expect(screen.queryAllByTestId('cta-banner')).toHaveLength(0);
+ });
+ });
+});
diff --git a/app/soapbox/features/ui/components/cta-banner.tsx b/app/soapbox/features/ui/components/cta-banner.tsx
new file mode 100644
index 0000000000..a1b5a8d8c5
--- /dev/null
+++ b/app/soapbox/features/ui/components/cta-banner.tsx
@@ -0,0 +1,37 @@
+import React from 'react';
+import { FormattedMessage } from 'react-intl';
+
+import { Button, HStack, Stack, Text } from 'soapbox/components/ui';
+import { useAppSelector, useSoapboxConfig } from 'soapbox/hooks';
+
+const CtaBanner = () => {
+ const { singleUserMode } = useSoapboxConfig();
+ const siteTitle = useAppSelector((state) => state.instance.title);
+ const me = useAppSelector((state) => state.me);
+
+ if (me || singleUserMode) return null;
+
+ return (
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ );
+};
+
+export default CtaBanner;
diff --git a/app/soapbox/features/ui/components/sign_up_panel.tsx b/app/soapbox/features/ui/components/panels/sign-up-panel.tsx
similarity index 96%
rename from app/soapbox/features/ui/components/sign_up_panel.tsx
rename to app/soapbox/features/ui/components/panels/sign-up-panel.tsx
index 2a54c5c113..4cabf17e8a 100644
--- a/app/soapbox/features/ui/components/sign_up_panel.tsx
+++ b/app/soapbox/features/ui/components/panels/sign-up-panel.tsx
@@ -18,7 +18,7 @@ const SignUpPanel = () => {
-
+
diff --git a/app/soapbox/features/ui/util/async-components.ts b/app/soapbox/features/ui/util/async-components.ts
index d083197356..1e6b037063 100644
--- a/app/soapbox/features/ui/util/async-components.ts
+++ b/app/soapbox/features/ui/util/async-components.ts
@@ -343,7 +343,11 @@ export function PromoPanel() {
}
export function SignUpPanel() {
- return import(/* webpackChunkName: "features/ui" */'../components/sign_up_panel');
+ return import(/* webpackChunkName: "features/ui" */'../components/panels/sign-up-panel');
+}
+
+export function CtaBanner() {
+ return import(/* webpackChunkName: "features/ui" */'../components/cta-banner');
}
export function FundingPanel() {
diff --git a/app/soapbox/locales/defaultMessages.json b/app/soapbox/locales/defaultMessages.json
index 4ae46ce45c..0ffbfa7cf1 100644
--- a/app/soapbox/locales/defaultMessages.json
+++ b/app/soapbox/locales/defaultMessages.json
@@ -6599,7 +6599,7 @@
"id": "account.register"
}
],
- "path": "app/soapbox/features/ui/components/sign_up_panel.json"
+ "path": "app/soapbox/features/ui/components/panels/sign-up-panel.json"
},
{
"descriptors": [
@@ -6949,4 +6949,4 @@
],
"path": "app/soapbox/pages/profile_page.json"
}
-]
\ No newline at end of file
+]
diff --git a/app/soapbox/pages/default_page.tsx b/app/soapbox/pages/default_page.tsx
index 21c9026f5b..b64cf452d0 100644
--- a/app/soapbox/pages/default_page.tsx
+++ b/app/soapbox/pages/default_page.tsx
@@ -6,6 +6,7 @@ import {
WhoToFollowPanel,
TrendsPanel,
SignUpPanel,
+ CtaBanner,
} from 'soapbox/features/ui/util/async-components';
import { useAppSelector, useFeatures } from 'soapbox/hooks';
@@ -19,6 +20,12 @@ const DefaultPage: React.FC = ({ children }) => {
<>
{children}
+
+ {!me && (
+
+ {Component => }
+
+ )}
diff --git a/app/soapbox/pages/home_page.tsx b/app/soapbox/pages/home_page.tsx
index 5c81ad9011..643de64191 100644
--- a/app/soapbox/pages/home_page.tsx
+++ b/app/soapbox/pages/home_page.tsx
@@ -10,6 +10,7 @@ import {
FundingPanel,
CryptoDonatePanel,
BirthdayPanel,
+ CtaBanner,
} from 'soapbox/features/ui/util/async-components';
import { useAppSelector, useOwnAccount, useFeatures, useSoapboxConfig } from 'soapbox/hooks';
@@ -56,6 +57,12 @@ const HomePage: React.FC = ({ children }) => {
)}
{children}
+
+ {!me && (
+
+ {Component => }
+
+ )}
diff --git a/app/soapbox/pages/profile_page.tsx b/app/soapbox/pages/profile_page.tsx
index e1691e14b6..c3cb65ff46 100644
--- a/app/soapbox/pages/profile_page.tsx
+++ b/app/soapbox/pages/profile_page.tsx
@@ -10,6 +10,7 @@ import {
ProfileMediaPanel,
ProfileFieldsPanel,
SignUpPanel,
+ CtaBanner,
} from 'soapbox/features/ui/util/async-components';
import { useAppSelector, useFeatures, useSoapboxConfig } from 'soapbox/hooks';
import { findAccountByUsername } from 'soapbox/selectors';
@@ -134,6 +135,12 @@ const ProfilePage: React.FC = ({ params, children }) => {
{children}
+
+ {!me && (
+
+ {Component => }
+
+ )}
diff --git a/app/soapbox/pages/status_page.js b/app/soapbox/pages/status_page.js
index 302d1238a0..e4ff9955e9 100644
Binary files a/app/soapbox/pages/status_page.js and b/app/soapbox/pages/status_page.js differ