import React, { ComponentType, FC } from 'react'; import dynamic from 'next/dynamic'; import { Skeleton, TabsProps } from 'antd'; import { ErrorBoundary } from 'react-error-boundary'; import { SocialLink } from '../../../interfaces/social-link.model'; import styles from './Content.module.scss'; import mobileStyles from './MobileContent.module.scss'; import { CustomPageContent } from '../CustomPageContent/CustomPageContent'; import { ContentHeader } from '../../common/ContentHeader/ContentHeader'; import { ChatMessage } from '../../../interfaces/chat-message.model'; import { CurrentUser } from '../../../interfaces/current-user'; import { ActionButtonMenu } from '../../action-buttons/ActionButtonMenu/ActionButtonMenu'; import { ExternalAction } from '../../../interfaces/external-action'; import { ComponentError } from '../ComponentError/ComponentError'; export type MobileContentProps = { name: string; summary: string; tags: string[]; socialHandles: SocialLink[]; extraPageContent: string; notifyItemSelected: () => void; followItemSelected: () => void; setExternalActionToDisplay: (action: ExternalAction) => void; setShowNotifyPopup: (show: boolean) => void; setShowFollowModal: (show: boolean) => void; supportFediverseFeatures: boolean; messages: ChatMessage[]; currentUser: CurrentUser; showChat: boolean; chatEnabled: boolean; actions: ExternalAction[]; externalActionSelected: (action: ExternalAction) => void; supportsBrowserNotifications: boolean; }; // lazy loaded components const Tabs: ComponentType = dynamic(() => import('antd').then(mod => mod.Tabs), { ssr: false, }); const FollowerCollection = dynamic( () => import('../followers/FollowerCollection/FollowerCollection').then( mod => mod.FollowerCollection, ), { ssr: false, }, ); const ChatContainer = dynamic( () => import('../../chat/ChatContainer/ChatContainer').then(mod => mod.ChatContainer), { ssr: false, }, ); type ChatContentProps = { showChat: boolean; chatEnabled: boolean; messages: ChatMessage[]; currentUser: CurrentUser; }; const ComponentErrorFallback = ({ error, resetErrorBoundary }) => ( ); const ChatContent: FC = ({ showChat, chatEnabled, messages, currentUser }) => { const { id, displayName } = currentUser; return showChat && !!currentUser ? ( ) : ( ); }; const ActionButton = ({ supportFediverseFeatures, supportsBrowserNotifications, actions, setExternalActionToDisplay, setShowNotifyPopup, setShowFollowModal, }) => ( setShowNotifyPopup(true)} followItemSelected={() => setShowFollowModal(true)} /> ); export const MobileContent: FC = ({ name, summary, tags, socialHandles, extraPageContent, messages, currentUser, showChat, chatEnabled, actions, setExternalActionToDisplay, setShowNotifyPopup, setShowFollowModal, supportFediverseFeatures, supportsBrowserNotifications, }) => { const aboutTabContent = ( <> {!!extraPageContent && (
)} ); const followersTabContent = (
setShowFollowModal(true)} />
); const items = []; if (showChat && currentUser) { items.push({ label: 'Chat', key: '0', children: ( ), }); } items.push({ label: 'About', key: '2', children: aboutTabContent }); if (supportFediverseFeatures) { items.push({ label: 'Followers', key: '3', children: followersTabContent }); } const replacementTabBar = (props, DefaultTabBar) => (
); return ( ( )} >
{items.length > 1 ? ( ) : ( <>
{aboutTabContent}
)}
); };