diff --git a/app/soapbox/features/account/components/header.tsx b/app/soapbox/features/account/components/header.tsx index 21e44f33b4..a8f8f2901d 100644 --- a/app/soapbox/features/account/components/header.tsx +++ b/app/soapbox/features/account/components/header.tsx @@ -21,6 +21,7 @@ import { HStack, IconButton, Menu, MenuButton, MenuItem, MenuList, MenuLink, Men import SvgIcon from 'soapbox/components/ui/icon/svg-icon'; import MovedNote from 'soapbox/features/account_timeline/components/moved_note'; import ActionButton from 'soapbox/features/ui/components/action-button'; +import FeedButton from 'soapbox/features/ui/components/feed-button'; import SubscriptionButton from 'soapbox/features/ui/components/subscription-button'; import { useAppDispatch, useFeatures, useOwnAccount } from 'soapbox/hooks'; import { normalizeAttachment } from 'soapbox/normalizers'; @@ -573,7 +574,7 @@ const Header: React.FC = ({ account }) => {
- {ownAccount && ( + {ownAccount ? ( = ({ account }) => { })} + ) : ( + )} {renderShareButton()} diff --git a/app/soapbox/features/soapbox_config/index.tsx b/app/soapbox/features/soapbox_config/index.tsx index 222c444346..0f71bbf615 100644 --- a/app/soapbox/features/soapbox_config/index.tsx +++ b/app/soapbox/features/soapbox_config/index.tsx @@ -49,6 +49,7 @@ const messages = defineMessages({ authenticatedProfileLabel: { id: 'soapbox_config.authenticated_profile_label', defaultMessage: 'Profiles require authentication' }, authenticatedProfileHint: { id: 'soapbox_config.authenticated_profile_hint', defaultMessage: 'Users must be logged-in to view replies and media on user profiles.' }, displayCtaLabel: { id: 'soapbox_config.cta_label', defaultMessage: 'Display call to action panels if not authenticated' }, + featureFeedsLabel: { id: 'soapbox_config.feature_feeds_label', defaultMessage: 'Feature RSS feeds to unauthenticated users' }, singleUserModeLabel: { id: 'soapbox_config.single_user_mode_label', defaultMessage: 'Single user mode' }, singleUserModeHint: { id: 'soapbox_config.single_user_mode_hint', defaultMessage: 'Front page will redirect to a given user profile.' }, singleUserModeProfileLabel: { id: 'soapbox_config.single_user_mode_profile_label', defaultMessage: 'Main user handle' }, @@ -269,6 +270,13 @@ const SoapboxConfig: React.FC = () => { /> + + e.target.checked)} + /> + + { + const intl = useIntl(); + const { featureFeeds } = useSoapboxConfig(); + + const { software } = useAppSelector((state) => parseVersion(state.instance.version)); + + let feedUrl: string | undefined; + + switch (software) { + case MASTODON: + feedUrl = `${account.url}.rss`; + break; + case PLEROMA: + feedUrl = `${account.url}/feed.rss`; + break; + } + + if (!featureFeeds || !feedUrl || !isLocal(account)) return null; + + return ( + window.open(feedUrl, '_blank')} + title={intl.formatMessage(messages.subscribeFeed)} + theme='outlined' + className='px-[10px]' + iconClassName='w-4 h-4' + /> + ); +}; + +export default FeedButton; diff --git a/app/soapbox/features/ui/components/subscription-button.tsx b/app/soapbox/features/ui/components/subscription-button.tsx index 8080a7c52a..242fc0cfca 100644 --- a/app/soapbox/features/ui/components/subscription-button.tsx +++ b/app/soapbox/features/ui/components/subscription-button.tsx @@ -32,12 +32,12 @@ const SubscriptionButton = ({ account }: ISubscriptionButton) => { const isFollowing = account.relationship?.following; const isRequested = account.relationship?.requested; - const isSubscribed = features.accountNotifies ? - account.relationship?.notifying : - account.relationship?.subscribing; - const title = isSubscribed ? - intl.formatMessage(messages.unsubscribe, { name: account.get('username') }) : - intl.formatMessage(messages.subscribe, { name: account.get('username') }); + const isSubscribed = features.accountNotifies + ? account.relationship?.notifying + : account.relationship?.subscribing; + const title = isSubscribed + ? intl.formatMessage(messages.unsubscribe, { name: account.get('username') }) + : intl.formatMessage(messages.subscribe, { name: account.get('username') }); const onSubscribeSuccess = () => dispatch(snackbar.success(intl.formatMessage(messages.subscribeSuccess))); diff --git a/app/soapbox/locales/pl.json b/app/soapbox/locales/pl.json index 23a13c2ba7..9d4471af2d 100644 --- a/app/soapbox/locales/pl.json +++ b/app/soapbox/locales/pl.json @@ -48,6 +48,7 @@ "account.report": "Zgłoś @{name}", "account.requested": "Oczekująca prośba, kliknij aby anulować", "account.requested_small": "Oczekująca prośba", + "account.rss_feed": "Subskrybuj kanał RSS", "account.search": "Szukaj wpisów @{name}", "account.search_self": "Szukaj własnych wpisów", "account.share": "Udostępnij profil @{name}", diff --git a/app/soapbox/normalizers/soapbox/soapbox_config.ts b/app/soapbox/normalizers/soapbox/soapbox_config.ts index 0447b3fc59..ac2ccdcf6a 100644 --- a/app/soapbox/normalizers/soapbox/soapbox_config.ts +++ b/app/soapbox/normalizers/soapbox/soapbox_config.ts @@ -112,6 +112,7 @@ export const SoapboxConfigRecord = ImmutableRecord({ linkFooterMessage: '', links: ImmutableMap(), displayCta: true, + featureFeeds: false, }, 'SoapboxConfig'); type SoapboxConfigMap = ImmutableMap; diff --git a/webpack/production.ts b/webpack/production.ts index 6115b6aa42..08bab97323 100644 --- a/webpack/production.ts +++ b/webpack/production.ts @@ -133,7 +133,7 @@ const configuration: Configuration = { '/unsubscribe', ]; - if (backendRoutes.some(path => pathname.startsWith(path)) || pathname.endsWith('/embed')) { + if (backendRoutes.some(path => pathname.startsWith(path)) || pathname.endsWith('/embed') || pathname.endsWith('.rss')) { return url; } },