| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  | // Copyright 2021 Signal Messenger, LLC
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import * as React from 'react'; | 
					
						
							|  |  |  | import classNames from 'classnames'; | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { LocalizerType } from '../types/Util'; | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  | import { Avatar, AvatarBlur } from './Avatar'; | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  | import { Spinner } from './Spinner'; | 
					
						
							| 
									
										
										
										
											2021-02-23 13:28:48 -06:00
										 |  |  | import { Button, ButtonVariant } from './Button'; | 
					
						
							| 
									
										
										
										
											2021-06-01 17:24:28 -07:00
										 |  |  | import { GroupDescription } from './conversation/GroupDescription'; | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { PreJoinConversationType } from '../state/ducks/conversations'; | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | type CallbackType = () => unknown; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export type DataPropsType = PreJoinConversationType & { | 
					
						
							|  |  |  |   readonly join: CallbackType; | 
					
						
							|  |  |  |   readonly onClose: CallbackType; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export type HousekeepingPropsType = { | 
					
						
							|  |  |  |   readonly i18n: LocalizerType; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export type PropsType = DataPropsType & HousekeepingPropsType; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function focusRef(el: HTMLElement | null) { | 
					
						
							|  |  |  |   if (el) { | 
					
						
							|  |  |  |     el.focus(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-13 13:44:13 -07:00
										 |  |  | export const GroupV2JoinDialog = React.memo(function GroupV2JoinDialogInner({ | 
					
						
							|  |  |  |   approvalRequired, | 
					
						
							|  |  |  |   avatar, | 
					
						
							|  |  |  |   groupDescription, | 
					
						
							|  |  |  |   i18n, | 
					
						
							|  |  |  |   join, | 
					
						
							|  |  |  |   memberCount, | 
					
						
							|  |  |  |   onClose, | 
					
						
							|  |  |  |   title, | 
					
						
							|  |  |  | }: PropsType) { | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  |   const [isWorking, setIsWorking] = React.useState(false); | 
					
						
							|  |  |  |   const [isJoining, setIsJoining] = React.useState(false); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const joinString = approvalRequired | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |     ? i18n('icu:GroupV2--join--request-to-join-button') | 
					
						
							|  |  |  |     : i18n('icu:GroupV2--join--join-button'); | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   const wrappedJoin = React.useCallback(() => { | 
					
						
							|  |  |  |     setIsWorking(true); | 
					
						
							|  |  |  |     setIsJoining(true); | 
					
						
							|  |  |  |     join(); | 
					
						
							|  |  |  |   }, [join, setIsJoining, setIsWorking]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const wrappedClose = React.useCallback(() => { | 
					
						
							|  |  |  |     setIsWorking(true); | 
					
						
							|  |  |  |     onClose(); | 
					
						
							|  |  |  |   }, [onClose, setIsWorking]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <div className="module-group-v2-join-dialog"> | 
					
						
							|  |  |  |       <button | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |         aria-label={i18n('icu:close')} | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  |         type="button" | 
					
						
							|  |  |  |         disabled={isWorking} | 
					
						
							|  |  |  |         className="module-group-v2-join-dialog__close-button" | 
					
						
							|  |  |  |         onClick={wrappedClose} | 
					
						
							|  |  |  |       /> | 
					
						
							|  |  |  |       <div className="module-group-v2-join-dialog__avatar"> | 
					
						
							|  |  |  |         <Avatar | 
					
						
							| 
									
										
										
										
											2024-07-11 12:44:09 -07:00
										 |  |  |           avatarUrl={avatar ? avatar.url : undefined} | 
					
						
							| 
									
										
										
										
											2021-12-01 11:24:00 -06:00
										 |  |  |           badge={undefined} | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  |           blur={AvatarBlur.NoBlur} | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  |           loading={avatar && !avatar.url} | 
					
						
							|  |  |  |           conversationType="group" | 
					
						
							|  |  |  |           title={title} | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  |           sharedGroupNames={[]} | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  |           size={80} | 
					
						
							|  |  |  |           i18n={i18n} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |       <div className="module-group-v2-join-dialog__title">{title}</div> | 
					
						
							|  |  |  |       <div className="module-group-v2-join-dialog__metadata"> | 
					
						
							| 
									
										
										
										
											2023-04-03 12:03:00 -07:00
										 |  |  |         {i18n('icu:GroupV2--join--group-metadata--full', { memberCount })} | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2021-06-01 17:24:28 -07:00
										 |  |  |       {groupDescription && ( | 
					
						
							|  |  |  |         <div className="module-group-v2-join-dialog__description"> | 
					
						
							|  |  |  |           <GroupDescription i18n={i18n} title={title} text={groupDescription} /> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       )} | 
					
						
							|  |  |  |       {approvalRequired ? ( | 
					
						
							|  |  |  |         <div className="module-group-v2-join-dialog__prompt--approval"> | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |           {i18n('icu:GroupV2--join--prompt-with-approval')} | 
					
						
							| 
									
										
										
										
											2021-06-01 17:24:28 -07:00
										 |  |  |         </div> | 
					
						
							|  |  |  |       ) : ( | 
					
						
							|  |  |  |         <div className="module-group-v2-join-dialog__prompt"> | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |           {i18n('icu:GroupV2--join--prompt')} | 
					
						
							| 
									
										
										
										
											2021-06-01 17:24:28 -07:00
										 |  |  |         </div> | 
					
						
							|  |  |  |       )} | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  |       <div className="module-group-v2-join-dialog__buttons"> | 
					
						
							| 
									
										
										
										
											2021-02-23 13:28:48 -06:00
										 |  |  |         <Button | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  |           className={classNames( | 
					
						
							|  |  |  |             'module-group-v2-join-dialog__button', | 
					
						
							|  |  |  |             'module-group-v2-join-dialog__button--secondary' | 
					
						
							|  |  |  |           )} | 
					
						
							|  |  |  |           disabled={isWorking} | 
					
						
							|  |  |  |           onClick={wrappedClose} | 
					
						
							| 
									
										
										
										
											2021-02-23 13:28:48 -06:00
										 |  |  |           variant={ButtonVariant.Secondary} | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  |         > | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |           {i18n('icu:cancel')} | 
					
						
							| 
									
										
										
										
											2021-02-23 13:28:48 -06:00
										 |  |  |         </Button> | 
					
						
							|  |  |  |         <Button | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  |           className="module-group-v2-join-dialog__button" | 
					
						
							|  |  |  |           disabled={isWorking} | 
					
						
							|  |  |  |           ref={focusRef} | 
					
						
							|  |  |  |           onClick={wrappedJoin} | 
					
						
							| 
									
										
										
										
											2021-02-23 13:28:48 -06:00
										 |  |  |           variant={ButtonVariant.Primary} | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  |         > | 
					
						
							|  |  |  |           {isJoining ? ( | 
					
						
							|  |  |  |             <Spinner size="20px" svgSize="small" direction="on-avatar" /> | 
					
						
							|  |  |  |           ) : ( | 
					
						
							|  |  |  |             joinString | 
					
						
							|  |  |  |           )} | 
					
						
							| 
									
										
										
										
											2021-02-23 13:28:48 -06:00
										 |  |  |         </Button> | 
					
						
							| 
									
										
										
										
											2021-01-29 14:16:48 -08:00
										 |  |  |       </div> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | }); |