| 
									
										
										
										
											2023-01-03 11:55:46 -08:00
										 |  |  | // Copyright 2020 Signal Messenger, LLC
 | 
					
						
							| 
									
										
										
										
											2020-10-30 15:34:04 -05:00
										 |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  | import * as React from 'react'; | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import { ContactName } from './ContactName'; | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  | import { Button, ButtonVariant } from '../Button'; | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  | import type { MessageRequestActionsConfirmationProps } from './MessageRequestActionsConfirmation'; | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  | import { | 
					
						
							|  |  |  |   MessageRequestActionsConfirmation, | 
					
						
							|  |  |  |   MessageRequestState, | 
					
						
							|  |  |  | } from './MessageRequestActionsConfirmation'; | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  | import { I18n } from '../I18n'; | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { LocalizerType } from '../../types/Util'; | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  | import { strictAssert } from '../../util/assert'; | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | export type Props = { | 
					
						
							|  |  |  |   i18n: LocalizerType; | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |   isHidden: boolean | null; | 
					
						
							| 
									
										
										
										
											2025-03-18 12:35:09 -05:00
										 |  |  |   sharedGroupNames?: ReadonlyArray<string>; | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  | } & Omit< | 
					
						
							|  |  |  |   MessageRequestActionsConfirmationProps, | 
					
						
							|  |  |  |   'i18n' | 'state' | 'onChangeState' | 
					
						
							|  |  |  | >; | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | export function MessageRequestActions({ | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |   addedByName, | 
					
						
							| 
									
										
										
										
											2022-12-06 14:03:09 -05:00
										 |  |  |   conversationId, | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |   conversationType, | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |   conversationName, | 
					
						
							| 
									
										
										
										
											2020-07-29 16:20:05 -07:00
										 |  |  |   i18n, | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |   isBlocked, | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |   isHidden, | 
					
						
							|  |  |  |   isReported, | 
					
						
							| 
									
										
										
										
											2025-03-18 12:35:09 -05:00
										 |  |  |   sharedGroupNames = [], | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |   acceptConversation, | 
					
						
							|  |  |  |   blockAndReportSpam, | 
					
						
							|  |  |  |   blockConversation, | 
					
						
							|  |  |  |   reportSpam, | 
					
						
							|  |  |  |   deleteConversation, | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | }: Props): JSX.Element { | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |   const [mrState, setMrState] = React.useState(MessageRequestState.default); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |   const nameValue = | 
					
						
							|  |  |  |     conversationType === 'direct' ? conversationName : addedByName; | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |   let message: JSX.Element | undefined; | 
					
						
							|  |  |  |   if (conversationType === 'direct') { | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |     strictAssert(nameValue != null, 'nameValue is null'); | 
					
						
							|  |  |  |     const name = ( | 
					
						
							|  |  |  |       <strong | 
					
						
							|  |  |  |         key="name" | 
					
						
							|  |  |  |         className="module-message-request-actions__message__name" | 
					
						
							|  |  |  |       > | 
					
						
							|  |  |  |         <ContactName {...nameValue} preferFirstName /> | 
					
						
							|  |  |  |       </strong> | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |     if (isBlocked) { | 
					
						
							|  |  |  |       message = ( | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  |         <I18n | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |           i18n={i18n} | 
					
						
							|  |  |  |           id="icu:MessageRequests--message-direct-blocked" | 
					
						
							|  |  |  |           components={{ name }} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     } else if (isHidden) { | 
					
						
							|  |  |  |       message = ( | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  |         <I18n | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |           i18n={i18n} | 
					
						
							|  |  |  |           id="icu:MessageRequests--message-direct-hidden" | 
					
						
							|  |  |  |           components={{ name }} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       message = ( | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  |         <I18n | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |           i18n={i18n} | 
					
						
							|  |  |  |           id="icu:MessageRequests--message-direct" | 
					
						
							|  |  |  |           components={{ name }} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } else if (conversationType === 'group') { | 
					
						
							|  |  |  |     if (isBlocked) { | 
					
						
							|  |  |  |       message = ( | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  |         <I18n i18n={i18n} id="icu:MessageRequests--message-group-blocked" /> | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |       ); | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  |       message = <I18n i18n={i18n} id="icu:MessageRequests--message-group" />; | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |   return ( | 
					
						
							|  |  |  |     <> | 
					
						
							|  |  |  |       {mrState !== MessageRequestState.default ? ( | 
					
						
							|  |  |  |         <MessageRequestActionsConfirmation | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |           addedByName={addedByName} | 
					
						
							|  |  |  |           conversationId={conversationId} | 
					
						
							|  |  |  |           conversationType={conversationType} | 
					
						
							|  |  |  |           conversationName={conversationName} | 
					
						
							|  |  |  |           i18n={i18n} | 
					
						
							|  |  |  |           isBlocked={isBlocked} | 
					
						
							|  |  |  |           isReported={isReported} | 
					
						
							|  |  |  |           state={mrState} | 
					
						
							| 
									
										
										
										
											2022-12-06 14:03:09 -05:00
										 |  |  |           acceptConversation={acceptConversation} | 
					
						
							|  |  |  |           blockAndReportSpam={blockAndReportSpam} | 
					
						
							|  |  |  |           blockConversation={blockConversation} | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |           reportSpam={reportSpam} | 
					
						
							| 
									
										
										
										
											2022-12-06 14:03:09 -05:00
										 |  |  |           deleteConversation={deleteConversation} | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |           onChangeState={setMrState} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       ) : null} | 
					
						
							|  |  |  |       <div className="module-message-request-actions"> | 
					
						
							| 
									
										
										
										
											2023-04-05 13:48:00 -07:00
										 |  |  |         <p className="module-message-request-actions__message">{message}</p> | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |         <div className="module-message-request-actions__buttons"> | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |           {!isBlocked && ( | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |             <Button | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |               onClick={() => { | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |                 setMrState(MessageRequestState.blocking); | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |               }} | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |               variant={ButtonVariant.SecondaryDestructive} | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |             > | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |               {i18n('icu:MessageRequests--block')} | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |             </Button> | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |           )} | 
					
						
							|  |  |  |           {(isReported || isBlocked) && ( | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |             <Button | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |               onClick={() => { | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |                 setMrState(MessageRequestState.deleting); | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |               }} | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |               variant={ButtonVariant.SecondaryDestructive} | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |             > | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |               {i18n('icu:MessageRequests--delete')} | 
					
						
							|  |  |  |             </Button> | 
					
						
							|  |  |  |           )} | 
					
						
							|  |  |  |           {!isReported && ( | 
					
						
							|  |  |  |             <Button | 
					
						
							|  |  |  |               onClick={() => { | 
					
						
							|  |  |  |                 setMrState(MessageRequestState.reportingAndMaybeBlocking); | 
					
						
							|  |  |  |               }} | 
					
						
							|  |  |  |               variant={ButtonVariant.SecondaryDestructive} | 
					
						
							|  |  |  |             > | 
					
						
							|  |  |  |               {i18n('icu:MessageRequests--reportAndMaybeBlock')} | 
					
						
							|  |  |  |             </Button> | 
					
						
							|  |  |  |           )} | 
					
						
							|  |  |  |           {isBlocked && ( | 
					
						
							|  |  |  |             <Button | 
					
						
							|  |  |  |               onClick={() => { | 
					
						
							|  |  |  |                 setMrState(MessageRequestState.unblocking); | 
					
						
							|  |  |  |               }} | 
					
						
							|  |  |  |               variant={ButtonVariant.SecondaryAffirmative} | 
					
						
							|  |  |  |             > | 
					
						
							|  |  |  |               {i18n('icu:MessageRequests--unblock')} | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |             </Button> | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |           )} | 
					
						
							|  |  |  |           {!isBlocked ? ( | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |             <Button | 
					
						
							| 
									
										
										
										
											2025-03-18 12:35:09 -05:00
										 |  |  |               onClick={() => { | 
					
						
							|  |  |  |                 if ( | 
					
						
							|  |  |  |                   conversationType === 'direct' && | 
					
						
							|  |  |  |                   sharedGroupNames.length > 1 | 
					
						
							|  |  |  |                 ) { | 
					
						
							|  |  |  |                   acceptConversation(conversationId); | 
					
						
							|  |  |  |                 } else { | 
					
						
							|  |  |  |                   setMrState(MessageRequestState.accepting); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |               }} | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |               variant={ButtonVariant.SecondaryAffirmative} | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |             > | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |               {i18n('icu:MessageRequests--accept')} | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |             </Button> | 
					
						
							| 
									
										
										
										
											2020-05-27 17:37:06 -04:00
										 |  |  |           ) : null} | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     </> | 
					
						
							|  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | } |