mirror of
https://github.com/owncast/owncast.git
synced 2025-11-03 21:08:36 +08:00
Fill out some more components + add application state enums
This commit is contained in:
@ -1,5 +1,46 @@
|
||||
interface Props {}
|
||||
import { Menu, Dropdown } from 'antd';
|
||||
import { DownOutlined } from '@ant-design/icons';
|
||||
import { useRecoilState } from 'recoil';
|
||||
import { ChatVisibilityState, ChatState } from '../interfaces/application-state';
|
||||
import { chatVisibility as chatVisibilityAtom } from './stores/ClientConfigStore';
|
||||
|
||||
interface Props {
|
||||
username: string;
|
||||
chatState: ChatState;
|
||||
}
|
||||
|
||||
export default function UserDropdown(props: Props) {
|
||||
return <div>User settings dropdown component goes here</div>;
|
||||
const { username, chatState } = props;
|
||||
|
||||
const chatEnabled = chatState !== ChatState.NotAvailable;
|
||||
const [chatVisibility, setChatVisibility] =
|
||||
useRecoilState<ChatVisibilityState>(chatVisibilityAtom);
|
||||
|
||||
const toggleChatVisibility = () => {
|
||||
if (chatVisibility === ChatVisibilityState.Hidden) {
|
||||
setChatVisibility(ChatVisibilityState.Visible);
|
||||
} else {
|
||||
setChatVisibility(ChatVisibilityState.Hidden);
|
||||
}
|
||||
};
|
||||
|
||||
const menu = (
|
||||
<Menu>
|
||||
<Menu.Item key="0">Change name</Menu.Item>
|
||||
<Menu.Item key="1">Authenticate</Menu.Item>
|
||||
{chatEnabled && (
|
||||
<Menu.Item key="3" onClick={() => toggleChatVisibility()}>
|
||||
Toggle chat
|
||||
</Menu.Item>
|
||||
)}
|
||||
</Menu>
|
||||
);
|
||||
|
||||
return (
|
||||
<Dropdown overlay={menu} trigger={['click']}>
|
||||
<button type="button" className="ant-dropdown-link" onClick={e => e.preventDefault()}>
|
||||
{username} <DownOutlined />
|
||||
</button>
|
||||
</Dropdown>
|
||||
);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user