VirtWebRemote/remote_frontend/src/App.tsx

77 lines
1.9 KiB
TypeScript
Raw Normal View History

2024-05-03 20:03:25 +00:00
import {
Menu,
MenuButton,
MenuItem,
MenuList,
MenuPopover,
MenuTrigger,
makeStyles,
typographyStyles,
} from "@fluentui/react-components";
import { ServerApi } from "./api/ServerApi";
2024-05-02 20:14:20 +00:00
import { AuthRouteWidget } from "./routes/AuthRouteWidget";
import { AsyncWidget } from "./widgets/AsyncWidget";
2024-05-03 20:03:25 +00:00
import { AuthApi } from "./api/AuthApi";
import { useAlert } from "./hooks/providers/AlertDialogProvider";
import { useConfirm } from "./hooks/providers/ConfirmDialogProvider";
const useStyles = makeStyles({
title: typographyStyles.title2,
});
export function App() {
return (
<AsyncWidget
loadKey={1}
errMsg="Failed to load server configuration!"
load={ServerApi.LoadConfig}
loadingMessage="Loading server configuration..."
2024-05-02 20:14:20 +00:00
build={() => <AppInner />}
/>
);
}
2024-05-02 20:14:20 +00:00
function AppInner(): React.ReactElement {
2024-05-03 20:03:25 +00:00
const alert = useAlert();
const confirm = useConfirm();
const styles = useStyles();
const signOut = async () => {
try {
if (!(await confirm("Do you really want to sign out?"))) return;
await AuthApi.SignOut();
} catch (e) {
console.error(e);
alert("Failed to perform sign out!");
}
};
2024-05-02 20:14:20 +00:00
if (!ServerApi.Config.authenticated && !ServerApi.Config.disable_auth)
return <AuthRouteWidget />;
2024-05-03 20:03:25 +00:00
return (
<div
style={{
width: "100%",
maxWidth: "1000px",
margin: "50px auto",
}}
>
<div style={{ display: "flex", justifyContent: "space-between" }}>
<span className={styles.title}>VirtWebRemote</span>
<Menu>
<MenuTrigger disableButtonEnhancement>
<MenuButton>Account</MenuButton>
</MenuTrigger>
<MenuPopover>
<MenuList>
<MenuItem onClick={signOut}>Sign out</MenuItem>
</MenuList>
</MenuPopover>
</Menu>
</div>
</div>
);
2024-05-02 20:14:20 +00:00
}