import clsx from 'clsx'; import React from 'react'; import { FormattedMessage } from 'react-intl'; import { spring } from 'react-motion'; import Icon from 'soapbox/components/icon'; import StatusContent from 'soapbox/components/status-content'; import { HStack, Stack } from 'soapbox/components/ui'; import AccountContainer from 'soapbox/containers/account-container'; import Motion from '../../util/optional-motion'; import type { Menu, MenuItem } from 'soapbox/components/dropdown-menu'; import type { Status as StatusEntity } from 'soapbox/types/entities'; interface IActionsModal { status: StatusEntity, actions: Menu, onClick: () => void, onClose: () => void, } const ActionsModal: React.FC = ({ status, actions, onClick, onClose }) => { const renderAction = (action: MenuItem | null, i: number) => { if (action === null) { return
  • ; } const { icon = null, text, meta = null, active = false, href = '#', isLogout, destructive } = action; const Comp = href === '#' ? 'button' : 'a'; const compProps = href === '#' ? { onClick: onClick } : { href: href, rel: 'noopener' }; return (
  • {icon && }
    {text}
    {meta}
  • ); }; return ( {({ top }) => (
    {status && ( )}
      {actions && actions.map(renderAction)}
    )}
    ); }; export default ActionsModal;