| 
									
										
										
										
											2021-05-28 12:11:19 -07:00
										 |  |  | // Copyright 2021 Signal Messenger, LLC
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import * as React from 'react'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-02 14:19:18 -07:00
										 |  |  | import { Button, ButtonSize, ButtonVariant } from '../Button'; | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { ConversationType } from '../../state/ducks/conversations'; | 
					
						
							| 
									
										
										
										
											2021-05-28 12:11:19 -07:00
										 |  |  | import { Modal } from '../Modal'; | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  | import { I18n } from '../I18n'; | 
					
						
							| 
									
										
										
										
											2021-05-28 12:11:19 -07:00
										 |  |  | import { Emojify } from './Emojify'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-17 18:24:21 -04:00
										 |  |  | import { useRestoreFocus } from '../../hooks/useRestoreFocus'; | 
					
						
							| 
									
										
										
										
											2021-07-30 13:30:59 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { LocalizerType } from '../../types/Util'; | 
					
						
							| 
									
										
										
										
											2022-12-20 19:25:10 -08:00
										 |  |  | import { openLinkInWebBrowser } from '../../util/openLinkInWebBrowser'; | 
					
						
							| 
									
										
										
										
											2021-05-28 12:11:19 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | export type PropsType = { | 
					
						
							|  |  |  |   i18n: LocalizerType; | 
					
						
							|  |  |  |   sender: ConversationType; | 
					
						
							| 
									
										
										
										
											2021-07-27 13:30:41 -07:00
										 |  |  |   inGroup: boolean; | 
					
						
							| 
									
										
										
										
											2021-05-28 12:11:19 -07:00
										 |  |  |   onClose: () => unknown; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export function DeliveryIssueDialog(props: PropsType): React.ReactElement { | 
					
						
							| 
									
										
										
										
											2022-12-20 19:25:10 -08:00
										 |  |  |   const { i18n, inGroup, sender, onClose } = props; | 
					
						
							| 
									
										
										
										
											2021-07-27 13:30:41 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-30 13:30:59 -07:00
										 |  |  |   // Focus first button after initial render, restore focus on teardown
 | 
					
						
							|  |  |  |   const [focusRef] = useRestoreFocus(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-29 16:40:09 -06:00
										 |  |  |   const footer = ( | 
					
						
							|  |  |  |     <> | 
					
						
							|  |  |  |       <Button | 
					
						
							| 
									
										
										
										
											2022-12-20 19:25:10 -08:00
										 |  |  |         onClick={() => | 
					
						
							|  |  |  |           openLinkInWebBrowser( | 
					
						
							|  |  |  |             'https://support.signal.org/hc/articles/4404859745690' | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-09-29 16:40:09 -06:00
										 |  |  |         size={ButtonSize.Medium} | 
					
						
							|  |  |  |         variant={ButtonVariant.Secondary} | 
					
						
							|  |  |  |       > | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |         {i18n('icu:DeliveryIssue--learnMore')} | 
					
						
							| 
									
										
										
										
											2022-09-29 16:40:09 -06:00
										 |  |  |       </Button> | 
					
						
							|  |  |  |       <Button | 
					
						
							|  |  |  |         onClick={onClose} | 
					
						
							|  |  |  |         ref={focusRef} | 
					
						
							|  |  |  |         size={ButtonSize.Medium} | 
					
						
							|  |  |  |         variant={ButtonVariant.Primary} | 
					
						
							|  |  |  |         className="module-delivery-issue-dialog__close-button" | 
					
						
							|  |  |  |       > | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |         {i18n('icu:Confirmation--confirm')} | 
					
						
							| 
									
										
										
										
											2022-09-29 16:40:09 -06:00
										 |  |  |       </Button> | 
					
						
							|  |  |  |     </> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-04 11:41:14 -07:00
										 |  |  |   const senderTitle = <Emojify text={sender.title} />; | 
					
						
							| 
									
										
										
										
											2023-01-05 14:43:33 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-28 12:11:19 -07:00
										 |  |  |   return ( | 
					
						
							| 
									
										
										
										
											2022-09-27 13:24:21 -07:00
										 |  |  |     <Modal | 
					
						
							|  |  |  |       modalName="DeliveryIssueDialog" | 
					
						
							|  |  |  |       hasXButton={false} | 
					
						
							|  |  |  |       onClose={onClose} | 
					
						
							|  |  |  |       i18n={i18n} | 
					
						
							| 
									
										
										
										
											2022-09-29 16:40:09 -06:00
										 |  |  |       modalFooter={footer} | 
					
						
							| 
									
										
										
										
											2022-09-27 13:24:21 -07:00
										 |  |  |     > | 
					
						
							| 
									
										
										
										
											2021-08-02 14:19:18 -07:00
										 |  |  |       <section> | 
					
						
							| 
									
										
										
										
											2021-05-28 12:11:19 -07:00
										 |  |  |         <div className="module-delivery-issue-dialog__image"> | 
					
						
							|  |  |  |           <img | 
					
						
							|  |  |  |             src="images/delivery-issue.svg" | 
					
						
							|  |  |  |             height="110" | 
					
						
							|  |  |  |             width="200" | 
					
						
							|  |  |  |             alt="" | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |         <div className="module-delivery-issue-dialog__title"> | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |           {i18n('icu:DeliveryIssue--title')} | 
					
						
							| 
									
										
										
										
											2021-05-28 12:11:19 -07:00
										 |  |  |         </div> | 
					
						
							|  |  |  |         <div className="module-delivery-issue-dialog__description"> | 
					
						
							| 
									
										
										
										
											2023-01-05 14:43:33 -08:00
										 |  |  |           {inGroup ? ( | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  |             <I18n | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |               id="icu:DeliveryIssue--summary--group" | 
					
						
							| 
									
										
										
										
											2023-04-04 11:41:14 -07:00
										 |  |  |               components={{ sender: senderTitle }} | 
					
						
							| 
									
										
										
										
											2023-01-05 14:43:33 -08:00
										 |  |  |               i18n={i18n} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           ) : ( | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  |             <I18n | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |               id="icu:DeliveryIssue--summary" | 
					
						
							| 
									
										
										
										
											2023-04-04 11:41:14 -07:00
										 |  |  |               components={{ sender: senderTitle }} | 
					
						
							| 
									
										
										
										
											2023-01-05 14:43:33 -08:00
										 |  |  |               i18n={i18n} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           )} | 
					
						
							| 
									
										
										
										
											2021-05-28 12:11:19 -07:00
										 |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2021-08-02 14:19:18 -07:00
										 |  |  |       </section> | 
					
						
							| 
									
										
										
										
											2021-05-28 12:11:19 -07:00
										 |  |  |     </Modal> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | } |