import classNames from 'classnames'; import React from 'react'; import { FormattedMessage, useIntl } from 'react-intl'; import { useDispatch } from 'react-redux'; import { Link } from 'react-router-dom'; import { logOut } from 'soapbox/actions/auth'; import { Text } from 'soapbox/components/ui'; import emojify from 'soapbox/features/emoji/emoji'; import { useSoapboxConfig, useOwnAccount, useFeatures } from 'soapbox/hooks'; import sourceCode from 'soapbox/utils/code'; interface IFooterLink { to: string, className?: string, onClick?: React.EventHandler, } const FooterLink: React.FC = ({ children, className, ...rest }): JSX.Element => { return ( {children} ); }; const LinkFooter: React.FC = (): JSX.Element => { const account = useOwnAccount(); const features = useFeatures(); const soapboxConfig = useSoapboxConfig(); const intl = useIntl(); const dispatch = useDispatch(); const onClickLogOut: React.EventHandler = (e) => { dispatch(logOut(intl)); e.preventDefault(); }; return (
{account && <> {features.profileDirectory && ( )} {features.filters && ( )} {features.federating && ( )} {account.admin && ( )} {account.locked && ( )} {features.import && ( )} }
{soapboxConfig.linkFooterMessage ? ( ) : ( {sourceCode.repository}, code_version: sourceCode.version, }} /> )}
); }; export default LinkFooter;