2022-05-08 09:41:47 +02:00
|
|
|
import { Menu, Dropdown, Button, Space } from 'antd';
|
2022-04-29 15:09:53 -07:00
|
|
|
import { DownOutlined } from '@ant-design/icons';
|
2022-05-13 14:44:16 -07:00
|
|
|
import { useRecoilState, useRecoilValue } from 'recoil';
|
2022-05-13 15:07:49 -07:00
|
|
|
import { useState } from 'react';
|
|
|
|
import Modal from '../../ui/Modal/Modal';
|
2022-05-13 14:44:16 -07:00
|
|
|
import { chatVisibilityAtom, chatDisplayNameAtom } from '../../stores/ClientConfigStore';
|
2022-05-08 09:41:47 +02:00
|
|
|
import { ChatState, ChatVisibilityState } from '../../../interfaces/application-state';
|
|
|
|
import s from './UserDropdown.module.scss';
|
2022-05-13 15:07:49 -07:00
|
|
|
import NameChangeModal from '../../modals/NameChangeModal';
|
2022-04-29 15:09:53 -07:00
|
|
|
|
|
|
|
interface Props {
|
2022-05-13 14:44:16 -07:00
|
|
|
username?: string;
|
2022-05-11 23:31:31 -07:00
|
|
|
chatState: ChatState;
|
2022-04-29 15:09:53 -07:00
|
|
|
}
|
2022-04-27 23:19:20 -07:00
|
|
|
|
2022-05-13 14:44:16 -07:00
|
|
|
export default function UserDropdown({ username: defaultUsername, chatState }: Props) {
|
2022-04-29 15:09:53 -07:00
|
|
|
const [chatVisibility, setChatVisibility] =
|
|
|
|
useRecoilState<ChatVisibilityState>(chatVisibilityAtom);
|
2022-05-13 14:44:16 -07:00
|
|
|
const username = defaultUsername || useRecoilValue(chatDisplayNameAtom);
|
2022-05-13 15:07:49 -07:00
|
|
|
const [showNameChangeModal, setShowNameChangeModal] = useState<boolean>(false);
|
2022-04-29 15:09:53 -07:00
|
|
|
|
|
|
|
const toggleChatVisibility = () => {
|
|
|
|
if (chatVisibility === ChatVisibilityState.Hidden) {
|
|
|
|
setChatVisibility(ChatVisibilityState.Visible);
|
|
|
|
} else {
|
|
|
|
setChatVisibility(ChatVisibilityState.Hidden);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-05-13 15:07:49 -07:00
|
|
|
const handleChangeName = () => {
|
|
|
|
setShowNameChangeModal(true);
|
|
|
|
};
|
|
|
|
|
2022-04-29 15:09:53 -07:00
|
|
|
const menu = (
|
|
|
|
<Menu>
|
2022-05-13 15:07:49 -07:00
|
|
|
<Menu.Item key="0" onClick={() => handleChangeName()}>
|
|
|
|
Change name
|
|
|
|
</Menu.Item>
|
2022-04-29 15:09:53 -07:00
|
|
|
<Menu.Item key="1">Authenticate</Menu.Item>
|
2022-05-13 14:44:16 -07:00
|
|
|
{chatState === ChatState.Available && (
|
2022-04-29 15:09:53 -07:00
|
|
|
<Menu.Item key="3" onClick={() => toggleChatVisibility()}>
|
|
|
|
Toggle chat
|
|
|
|
</Menu.Item>
|
|
|
|
)}
|
|
|
|
</Menu>
|
|
|
|
);
|
|
|
|
|
|
|
|
return (
|
2022-05-08 09:41:47 +02:00
|
|
|
<div className={`${s.root}`}>
|
|
|
|
<Dropdown overlay={menu} trigger={['click']}>
|
|
|
|
<Button>
|
|
|
|
<Space>
|
|
|
|
{username}
|
|
|
|
<DownOutlined />
|
|
|
|
</Space>
|
|
|
|
</Button>
|
|
|
|
</Dropdown>
|
2022-05-13 15:07:49 -07:00
|
|
|
<Modal
|
|
|
|
title="Change Chat Display Name"
|
|
|
|
visible={showNameChangeModal}
|
|
|
|
handleCancel={() => setShowNameChangeModal(false)}
|
|
|
|
>
|
|
|
|
<NameChangeModal />
|
|
|
|
</Modal>
|
2022-05-08 09:41:47 +02:00
|
|
|
</div>
|
2022-04-29 15:09:53 -07:00
|
|
|
);
|
2022-04-27 23:19:20 -07:00
|
|
|
}
|
2022-05-13 14:44:16 -07:00
|
|
|
|
|
|
|
UserDropdown.defaultProps = {
|
|
|
|
username: undefined,
|
|
|
|
};
|