You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
108 lines
3.3 KiB
TypeScript
108 lines
3.3 KiB
TypeScript
import { useState } from 'react';
|
|
import { useDispatch } from 'react-redux';
|
|
|
|
import { sogsV3AddAdmin } from '../../session/apis/open_group_api/sogsv3/sogsV3AddRemoveMods';
|
|
import { getConversationController } from '../../session/conversations';
|
|
import { PubKey } from '../../session/types';
|
|
import { ToastUtils } from '../../session/utils';
|
|
import { updateAddModeratorsModal } from '../../state/ducks/modalDialog';
|
|
import { useIsDarkTheme } from '../../state/selectors/theme';
|
|
import { SessionHeaderSearchInput } from '../SessionHeaderSearchInput';
|
|
import { SessionWrapperModal } from '../SessionWrapperModal';
|
|
import { Flex } from '../basic/Flex';
|
|
import { SessionButton, SessionButtonType } from '../basic/SessionButton';
|
|
import { SessionSpinner } from '../loading';
|
|
|
|
type Props = {
|
|
conversationId: string;
|
|
};
|
|
|
|
export const AddModeratorsDialog = (props: Props) => {
|
|
const { conversationId } = props;
|
|
|
|
const dispatch = useDispatch();
|
|
const isDarkTheme = useIsDarkTheme();
|
|
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);
|
|
|
|
// this is a v2 opengroup
|
|
const roomInfos = convo.toOpenGroupV2();
|
|
const 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"
|
|
isDarkTheme={isDarkTheme}
|
|
placeholder={i18n('accountIdEnter')}
|
|
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>
|
|
);
|
|
};
|