|  |  |  | import { isEmpty } from 'lodash'; | 
					
						
							|  |  |  | import { useEffect, useState } from 'react'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import styled from 'styled-components'; | 
					
						
							|  |  |  | import { useIsPrivate, useIsPublic } from '../../../hooks/useParamSelector'; | 
					
						
							|  |  |  | import { | 
					
						
							|  |  |  |   ConversationInteractionStatus, | 
					
						
							|  |  |  |   ConversationInteractionType, | 
					
						
							|  |  |  | } from '../../../interactions/conversationInteractions'; | 
					
						
							|  |  |  | import { getConversationController } from '../../../session/conversations'; | 
					
						
							|  |  |  | import { LastMessageType } from '../../../state/ducks/conversations'; | 
					
						
							|  |  |  | import { assertUnreachable } from '../../../types/sqlSharedTypes'; | 
					
						
							|  |  |  | import { MessageBody } from '../../conversation/message/message-content/MessageBody'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const StyledInteractionItemText = styled.div<{ isError: boolean }>`
 | 
					
						
							|  |  |  |   ${props => props.isError && 'color: var(--danger-color) !important;'} | 
					
						
							|  |  |  | `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type InteractionItemProps = { | 
					
						
							|  |  |  |   conversationId: string; | 
					
						
							|  |  |  |   lastMessage: LastMessageType | null; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const InteractionItem = (props: InteractionItemProps) => { | 
					
						
							|  |  |  |   const { conversationId, lastMessage } = props; | 
					
						
							|  |  |  |   const isGroup = !useIsPrivate(conversationId); | 
					
						
							|  |  |  |   const isCommunity = useIsPublic(conversationId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const [storedLastMessageText, setStoredLastMessageText] = useState(lastMessage?.text); | 
					
						
							|  |  |  |   const [storedLastMessageInteractionStatus, setStoredLastMessageInteractionStatus] = useState( | 
					
						
							|  |  |  |     lastMessage?.interactionStatus | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // NOTE we want to reset the interaction state when the last message changes
 | 
					
						
							|  |  |  |   useEffect(() => { | 
					
						
							|  |  |  |     if (conversationId) { | 
					
						
							|  |  |  |       const convo = getConversationController().get(conversationId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (storedLastMessageInteractionStatus !== convo.get('lastMessageInteractionStatus')) { | 
					
						
							|  |  |  |         setStoredLastMessageInteractionStatus(convo.get('lastMessageInteractionStatus')); | 
					
						
							|  |  |  |         setStoredLastMessageText(convo.get('lastMessage')); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, [conversationId, storedLastMessageInteractionStatus]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!lastMessage) { | 
					
						
							|  |  |  |     return null; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const { interactionType, interactionStatus } = lastMessage || {}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!interactionType || !interactionStatus) { | 
					
						
							|  |  |  |     return null; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   let text = storedLastMessageText || ''; | 
					
						
							|  |  |  |   let errorText = ''; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   switch (interactionType) { | 
					
						
							|  |  |  |     case ConversationInteractionType.Hide: | 
					
						
							|  |  |  |       // if it's hidden or pending hiding, we don't show any text
 | 
					
						
							|  |  |  |       break; | 
					
						
							|  |  |  |     case ConversationInteractionType.Leave: | 
					
						
							|  |  |  |       errorText = isCommunity | 
					
						
							|  |  |  |         ? window.i18n('leaveCommunityFailed') | 
					
						
							|  |  |  |         : isGroup | 
					
						
							|  |  |  |           ? window.i18n('leaveGroupFailed') | 
					
						
							|  |  |  |           : window.i18n('deleteConversationFailed'); | 
					
						
							|  |  |  |       text = | 
					
						
							|  |  |  |         interactionStatus === ConversationInteractionStatus.Error | 
					
						
							|  |  |  |           ? errorText | 
					
						
							|  |  |  |           : interactionStatus === ConversationInteractionStatus.Start || | 
					
						
							|  |  |  |               interactionStatus === ConversationInteractionStatus.Loading | 
					
						
							|  |  |  |             ? window.i18n('leaving') | 
					
						
							|  |  |  |             : text; | 
					
						
							|  |  |  |       break; | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |       assertUnreachable( | 
					
						
							|  |  |  |         interactionType, | 
					
						
							|  |  |  |         `InteractionItem: Missing case error "${interactionType}"` | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (isEmpty(text)) { | 
					
						
							|  |  |  |     return null; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <div className="module-conversation-list-item__message"> | 
					
						
							|  |  |  |       <StyledInteractionItemText | 
					
						
							|  |  |  |         className="module-conversation-list-item__message__text" | 
					
						
							|  |  |  |         isError={Boolean(interactionStatus === ConversationInteractionStatus.Error)} | 
					
						
							|  |  |  |       > | 
					
						
							|  |  |  |         <MessageBody text={text} disableJumbomoji={true} disableLinks={true} isGroup={isGroup} /> | 
					
						
							|  |  |  |       </StyledInteractionItemText> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | }; |