import { useCallback } from 'react' import { useShareProjectContext } from './share-project-modal' import { useTranslation } from 'react-i18next' import MemberPrivileges from './member-privileges' import { resendInvite, revokeInvite } from '../utils/api' import { useProjectContext } from '@/shared/context/project-context' import { sendMB } from '@/infrastructure/event-tracking' import OLRow from '@/features/ui/components/ol/ol-row' import OLCol from '@/features/ui/components/ol/ol-col' import OLTooltip from '@/features/ui/components/ol/ol-tooltip' import OLButton from '@/features/ui/components/ol/ol-button' import MaterialIcon from '@/shared/components/material-icon' import { ProjectMember } from '@/shared/context/types/project-metadata' export default function Invite({ invite, isProjectOwner, }: { invite: ProjectMember isProjectOwner: boolean }) { const { t } = useTranslation() return ( {invite.email} {t('invite_not_accepted')} . {isProjectOwner && } {isProjectOwner && ( )} ) } function ResendInvite({ invite }: { invite: ProjectMember }) { const { t } = useTranslation() const { monitorRequest, setError, inFlight } = useShareProjectContext() const { projectId } = useProjectContext() // const buttonRef = useRef(null) // const handleClick = useCallback( () => monitorRequest(() => resendInvite(projectId, invite)) .catch(error => { if (error?.response?.status === 404) { setError('invite_expired') } if (error?.response?.status === 429) { setError('invite_resend_limit_hit') } }) .finally(() => { // NOTE: disabled as react-bootstrap v0.33.1 isn't forwarding the ref to the `button` // if (buttonRef.current) { // buttonRef.current.blur() // } if (document.activeElement) { ;(document.activeElement as HTMLElement).blur() } }), [invite, monitorRequest, projectId, setError] ) return ( {t('resend')} ) } function RevokeInvite({ invite }: { invite: ProjectMember }) { const { t } = useTranslation() const { monitorRequest } = useShareProjectContext() const { projectId, project, updateProject } = useProjectContext() const { invites, members } = project || {} function handleClick(event: React.MouseEvent) { event.preventDefault() monitorRequest(() => revokeInvite(projectId, invite)).then(() => { const updatedInvites = invites?.filter(existing => existing !== invite) || [] updateProject({ invites: updatedInvites, }) sendMB('collaborator-invite-revoked', { project_id: projectId, current_invites_amount: updatedInvites.length, current_collaborators_amount: members?.length || 0, }) }) } return ( ) }