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.locked && (
  • )} {features.importAPI && (
  • )} {(features.federating && features.accountAliasesAPI) && (
  • )}
  • }
{soapboxConfig.linkFooterMessage ? ( ) : ( {sourceCode.repository}, code_version: sourceCode.version, }} /> )}
); }; export default LinkFooter;