import React from 'react'; import { defineMessages, useIntl } from 'react-intl'; import { useRouteMatch } from 'react-router-dom'; import { Column, Icon, Layout, Stack, Text } from 'soapbox/components/ui'; import GroupHeader from 'soapbox/features/group/components/group-header'; import LinkFooter from 'soapbox/features/ui/components/link-footer'; import BundleContainer from 'soapbox/features/ui/containers/bundle-container'; import { CtaBanner, GroupMediaPanel, SignUpPanel, } from 'soapbox/features/ui/util/async-components'; import { useGroup, useOwnAccount } from 'soapbox/hooks'; import { Group } from 'soapbox/schemas'; import { Tabs } from '../components/ui'; const messages = defineMessages({ all: { id: 'group.tabs.all', defaultMessage: 'All' }, members: { id: 'group.tabs.members', defaultMessage: 'Members' }, }); interface IGroupPage { params?: { id?: string } children: React.ReactNode } const PrivacyBlankslate = () => (
Content is only visible to group members
); const BlockedBlankslate = ({ group }: { group: Group }) => (
You are banned from {' '}
); /** Page to display a group. */ const GroupPage: React.FC = ({ params, children }) => { const intl = useIntl(); const match = useRouteMatch(); const me = useOwnAccount(); const id = params?.id || ''; const { group } = useGroup(id); const isMember = !!group?.relationship?.member; const isBlocked = group?.relationship?.blocked_by; const isPrivate = group?.locked; const items = [ { text: intl.formatMessage(messages.all), to: `/groups/${group?.id}`, name: '/groups/:id', }, { text: intl.formatMessage(messages.members), to: `/groups/${group?.id}/members`, name: '/groups/:id/members', }, ]; const renderChildren = () => { if (!isMember && isPrivate) { return ; } else if (isBlocked) { return ; } else { return children; } }; return ( <> {renderChildren()} {!me && ( {Component => } )} {!me && ( {Component => } )} {Component => } ); }; export default GroupPage;