|  |  |  | import React, { useState } from 'react'; | 
					
						
							|  |  |  | import { PubKey } from '../../session/types'; | 
					
						
							|  |  |  | import { ToastUtils } from '../../session/utils'; | 
					
						
							|  |  |  | import { Flex } from '../basic/Flex'; | 
					
						
							|  |  |  | import { getConversationController } from '../../session/conversations'; | 
					
						
							|  |  |  | import { useDispatch, useSelector } from 'react-redux'; | 
					
						
							|  |  |  | import { updateAddModeratorsModal } from '../../state/ducks/modalDialog'; | 
					
						
							|  |  |  | import { SessionButton, SessionButtonType } from '../basic/SessionButton'; | 
					
						
							|  |  |  | import { SessionSpinner } from '../basic/SessionSpinner'; | 
					
						
							|  |  |  | import { SessionWrapperModal } from '../SessionWrapperModal'; | 
					
						
							|  |  |  | import { sogsV3AddAdmin } from '../../session/apis/open_group_api/sogsv3/sogsV3AddRemoveMods'; | 
					
						
							|  |  |  | import { SessionHeaderSearchInput } from '../SessionHeaderSearchInput'; | 
					
						
							|  |  |  | import { getTheme } from '../../state/selectors/theme'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type Props = { | 
					
						
							|  |  |  |   conversationId: string; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const AddModeratorsDialog = (props: Props) => { | 
					
						
							|  |  |  |   const { conversationId } = props; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const dispatch = useDispatch(); | 
					
						
							|  |  |  |   const darkMode = useSelector(getTheme).includes('dark'); | 
					
						
							|  |  |  |   const convo = getConversationController().get(conversationId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const [inputBoxValue, setInputBoxValue] = useState(''); | 
					
						
							|  |  |  |   const [addingInProgress, setAddingInProgress] = useState(false); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const addAsModerator = async () => { | 
					
						
							|  |  |  |     // if we don't have valid data entered by the user
 | 
					
						
							|  |  |  |     const pubkey = PubKey.from(inputBoxValue); | 
					
						
							|  |  |  |     if (!pubkey) { | 
					
						
							|  |  |  |       window.log.info('invalid pubkey for adding as moderator:', inputBoxValue); | 
					
						
							|  |  |  |       ToastUtils.pushInvalidPubKey(); | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     window?.log?.info(`asked to add moderator: ${pubkey.key}`); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     try { | 
					
						
							|  |  |  |       setAddingInProgress(true); | 
					
						
							|  |  |  |       let isAdded: any; | 
					
						
							|  |  |  |       // this is a v2 opengroup
 | 
					
						
							|  |  |  |       const roomInfos = convo.toOpenGroupV2(); | 
					
						
							|  |  |  |       isAdded = await sogsV3AddAdmin([pubkey], roomInfos); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (!isAdded) { | 
					
						
							|  |  |  |         window?.log?.warn('failed to add moderators:', isAdded); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         ToastUtils.pushFailedToAddAsModerator(); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         window?.log?.info(`${pubkey.key} added as moderator...`); | 
					
						
							|  |  |  |         ToastUtils.pushUserAddedToModerators(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // clear input box
 | 
					
						
							|  |  |  |         setInputBoxValue(''); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } catch (e) { | 
					
						
							|  |  |  |       window?.log?.error('Got error while adding moderator:', e); | 
					
						
							|  |  |  |     } finally { | 
					
						
							|  |  |  |       setAddingInProgress(false); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const { i18n } = window; | 
					
						
							|  |  |  |   const chatName = convo.getNicknameOrRealUsernameOrPlaceholder(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const title = `${i18n('addModerators')}: ${chatName}`; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const onPubkeyBoxChanges = (e: any) => { | 
					
						
							|  |  |  |     const val = e.target.value; | 
					
						
							|  |  |  |     setInputBoxValue(val); | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <SessionWrapperModal | 
					
						
							|  |  |  |       showExitIcon={true} | 
					
						
							|  |  |  |       title={title} | 
					
						
							|  |  |  |       onClose={() => { | 
					
						
							|  |  |  |         dispatch(updateAddModeratorsModal(null)); | 
					
						
							|  |  |  |       }} | 
					
						
							|  |  |  |     > | 
					
						
							|  |  |  |       <Flex container={true} flexDirection="column" alignItems="center"> | 
					
						
							|  |  |  |         <p>Add Moderator:</p> | 
					
						
							|  |  |  |         <SessionHeaderSearchInput | 
					
						
							|  |  |  |           type="text" | 
					
						
							|  |  |  |           darkMode={darkMode} | 
					
						
							|  |  |  |           placeholder={i18n('enterSessionID')} | 
					
						
							|  |  |  |           dir="auto" | 
					
						
							|  |  |  |           onChange={onPubkeyBoxChanges} | 
					
						
							|  |  |  |           disabled={addingInProgress} | 
					
						
							|  |  |  |           value={inputBoxValue} | 
					
						
							|  |  |  |           autoFocus={true} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |         <SessionButton | 
					
						
							|  |  |  |           buttonType={SessionButtonType.Simple} | 
					
						
							|  |  |  |           onClick={addAsModerator} | 
					
						
							|  |  |  |           text={i18n('add')} | 
					
						
							|  |  |  |           disabled={addingInProgress} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         <SessionSpinner loading={addingInProgress} /> | 
					
						
							|  |  |  |       </Flex> | 
					
						
							|  |  |  |     </SessionWrapperModal> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | }; |