| 
									
										
										
										
											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-10-16 11:31:57 -07: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-10-16 11:31:57 -07: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'; | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | export type Props = { | 
					
						
							|  |  |  |   i18n: LocalizerType; | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  | } & Pick< | 
					
						
							|  |  |  |   MessageRequestActionsConfirmationProps, | 
					
						
							|  |  |  |   | 'addedByName' | 
					
						
							|  |  |  |   | 'conversationId' | 
					
						
							|  |  |  |   | 'conversationType' | 
					
						
							|  |  |  |   | 'conversationName' | 
					
						
							|  |  |  |   | 'isBlocked' | 
					
						
							|  |  |  |   | 'isReported' | 
					
						
							|  |  |  |   | 'acceptConversation' | 
					
						
							|  |  |  |   | 'reportSpam' | 
					
						
							|  |  |  |   | 'blockAndReportSpam' | 
					
						
							|  |  |  |   | 'blockConversation' | 
					
						
							|  |  |  |   | 'deleteConversation' | 
					
						
							|  |  |  | >; | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-03 12:03:00 -07:00
										 |  |  | const learnMoreLink = (parts: Array<JSX.Element | string>) => ( | 
					
						
							|  |  |  |   <a | 
					
						
							|  |  |  |     href="https://support.signal.org/hc/articles/360007459591" | 
					
						
							|  |  |  |     target="_blank" | 
					
						
							|  |  |  |     rel="noreferrer" | 
					
						
							|  |  |  |     className="module-message-request-actions__message__learn-more" | 
					
						
							|  |  |  |   > | 
					
						
							|  |  |  |     {parts} | 
					
						
							|  |  |  |   </a> | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | export function MandatoryProfileSharingActions({ | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |   addedByName, | 
					
						
							|  |  |  |   conversationId, | 
					
						
							|  |  |  |   conversationType, | 
					
						
							|  |  |  |   conversationName, | 
					
						
							|  |  |  |   i18n, | 
					
						
							|  |  |  |   isBlocked, | 
					
						
							|  |  |  |   isReported, | 
					
						
							| 
									
										
										
										
											2022-12-06 14:03:09 -05:00
										 |  |  |   acceptConversation, | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |   reportSpam, | 
					
						
							| 
									
										
										
										
											2022-12-06 14:03:09 -05:00
										 |  |  |   blockAndReportSpam, | 
					
						
							|  |  |  |   blockConversation, | 
					
						
							|  |  |  |   deleteConversation, | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | }: Props): JSX.Element { | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  |   const [mrState, setMrState] = React.useState(MessageRequestState.default); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |   const firstNameContact = ( | 
					
						
							|  |  |  |     <strong | 
					
						
							|  |  |  |       key="name" | 
					
						
							|  |  |  |       className="module-message-request-actions__message__name" | 
					
						
							|  |  |  |     > | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |       <ContactName {...conversationName} preferFirstName /> | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |     </strong> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07: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={() => { | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  |             throw new Error( | 
					
						
							|  |  |  |               'Should not be able to unblock from MandatoryProfileSharingActions' | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |           }} | 
					
						
							| 
									
										
										
										
											2022-12-06 14:03:09 -05:00
										 |  |  |           blockConversation={blockConversation} | 
					
						
							|  |  |  |           deleteConversation={deleteConversation} | 
					
						
							| 
									
										
										
										
											2024-03-12 09:29:31 -07:00
										 |  |  |           reportSpam={reportSpam} | 
					
						
							| 
									
										
										
										
											2022-12-06 14:03:09 -05:00
										 |  |  |           blockAndReportSpam={blockAndReportSpam} | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  |           onChangeState={setMrState} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       ) : null} | 
					
						
							|  |  |  |       <div className="module-message-request-actions"> | 
					
						
							|  |  |  |         <p className="module-message-request-actions__message"> | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |           {conversationType === 'direct' ? ( | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  |             <I18n | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |               i18n={i18n} | 
					
						
							| 
									
										
										
										
											2023-04-03 12:03:00 -07:00
										 |  |  |               id="icu:MessageRequests--profile-sharing--direct--link" | 
					
						
							|  |  |  |               components={{ firstName: firstNameContact, learnMoreLink }} | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |             /> | 
					
						
							|  |  |  |           ) : ( | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  |             <I18n | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |               i18n={i18n} | 
					
						
							| 
									
										
										
										
											2023-04-03 12:03:00 -07:00
										 |  |  |               id="icu:MessageRequests--profile-sharing--group--link" | 
					
						
							| 
									
										
										
										
											2023-04-04 11:41:14 -07:00
										 |  |  |               components={{ learnMoreLink }} | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |             /> | 
					
						
							|  |  |  |           )} | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  |         </p> | 
					
						
							|  |  |  |         <div className="module-message-request-actions__buttons"> | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |           <Button | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  |             onClick={() => { | 
					
						
							|  |  |  |               setMrState(MessageRequestState.blocking); | 
					
						
							|  |  |  |             }} | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |             variant={ButtonVariant.SecondaryDestructive} | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  |           > | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |             {i18n('icu:MessageRequests--block')} | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |           </Button> | 
					
						
							|  |  |  |           <Button | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  |             onClick={() => { | 
					
						
							|  |  |  |               setMrState(MessageRequestState.deleting); | 
					
						
							|  |  |  |             }} | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |             variant={ButtonVariant.SecondaryDestructive} | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  |           > | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |             {i18n('icu:MessageRequests--delete')} | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |           </Button> | 
					
						
							|  |  |  |           <Button | 
					
						
							| 
									
										
										
										
											2022-12-06 14:03:09 -05:00
										 |  |  |             onClick={() => acceptConversation(conversationId)} | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |             variant={ButtonVariant.SecondaryAffirmative} | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  |           > | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |             {i18n('icu:MessageRequests--continue')} | 
					
						
							| 
									
										
										
										
											2021-04-06 17:14:18 -05:00
										 |  |  |           </Button> | 
					
						
							| 
									
										
										
										
											2020-10-16 11:31:57 -07:00
										 |  |  |         </div> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     </> | 
					
						
							|  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | } |