| 
									
										
										
										
											2023-01-03 11:55:46 -08:00
										 |  |  | // Copyright 2019 Signal Messenger, LLC
 | 
					
						
							| 
									
										
										
										
											2020-10-30 15:34:04 -05:00
										 |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 13:36:16 -08:00
										 |  |  | import * as React from 'react'; | 
					
						
							|  |  |  | import { createPortal } from 'react-dom'; | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { LocalizerType } from '../types/Util'; | 
					
						
							| 
									
										
										
										
											2019-11-07 13:36:16 -08:00
										 |  |  | import { ShortcutGuide } from './ShortcutGuide'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export type PropsType = { | 
					
						
							|  |  |  |   hasInstalledStickers: boolean; | 
					
						
							|  |  |  |   platform: string; | 
					
						
							| 
									
										
										
										
											2022-12-21 22:07:45 -05:00
										 |  |  |   readonly closeShortcutGuideModal: () => unknown; | 
					
						
							| 
									
										
										
										
											2019-11-07 13:36:16 -08:00
										 |  |  |   readonly i18n: LocalizerType; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | export const ShortcutGuideModal = React.memo(function ShortcutGuideModalInner( | 
					
						
							|  |  |  |   props: PropsType | 
					
						
							|  |  |  | ) { | 
					
						
							| 
									
										
										
										
											2022-12-21 22:07:45 -05:00
										 |  |  |   const { i18n, closeShortcutGuideModal, hasInstalledStickers, platform } = | 
					
						
							|  |  |  |     props; | 
					
						
							| 
									
										
										
										
											2020-09-11 17:46:52 -07:00
										 |  |  |   const [root, setRoot] = React.useState<HTMLElement | null>(null); | 
					
						
							| 
									
										
										
										
											2019-11-07 13:36:16 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-11 17:46:52 -07:00
										 |  |  |   React.useEffect(() => { | 
					
						
							|  |  |  |     const div = document.createElement('div'); | 
					
						
							|  |  |  |     document.body.appendChild(div); | 
					
						
							|  |  |  |     setRoot(div); | 
					
						
							| 
									
										
										
										
											2019-11-07 13:36:16 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-11 17:46:52 -07:00
										 |  |  |     return () => { | 
					
						
							|  |  |  |       document.body.removeChild(div); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |   }, []); | 
					
						
							| 
									
										
										
										
											2019-11-07 13:36:16 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-11 17:46:52 -07:00
										 |  |  |   return root | 
					
						
							|  |  |  |     ? createPortal( | 
					
						
							|  |  |  |         <div className="module-shortcut-guide-modal"> | 
					
						
							|  |  |  |           <div className="module-shortcut-guide-container"> | 
					
						
							|  |  |  |             <ShortcutGuide | 
					
						
							| 
									
										
										
										
											2022-12-21 22:07:45 -05:00
										 |  |  |               close={closeShortcutGuideModal} | 
					
						
							| 
									
										
										
										
											2020-09-11 17:46:52 -07:00
										 |  |  |               hasInstalledStickers={hasInstalledStickers} | 
					
						
							|  |  |  |               i18n={i18n} | 
					
						
							| 
									
										
										
										
											2022-12-21 22:07:45 -05:00
										 |  |  |               platform={platform} | 
					
						
							| 
									
										
										
										
											2020-09-11 17:46:52 -07:00
										 |  |  |             /> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |         </div>, | 
					
						
							|  |  |  |         root | 
					
						
							|  |  |  |       ) | 
					
						
							|  |  |  |     : null; | 
					
						
							|  |  |  | }); |