2024-05-03 20:03:25 +00:00
|
|
|
import {
|
|
|
|
Menu,
|
|
|
|
MenuButton,
|
|
|
|
MenuItem,
|
|
|
|
MenuList,
|
|
|
|
MenuPopover,
|
|
|
|
MenuTrigger,
|
|
|
|
makeStyles,
|
|
|
|
typographyStyles,
|
|
|
|
} from "@fluentui/react-components";
|
2024-04-29 20:14:16 +00:00
|
|
|
import { ServerApi } from "./api/ServerApi";
|
2024-05-02 20:14:20 +00:00
|
|
|
import { AuthRouteWidget } from "./routes/AuthRouteWidget";
|
2024-04-29 20:14:16 +00:00
|
|
|
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,
|
|
|
|
});
|
2024-04-29 20:14:16 +00:00
|
|
|
|
|
|
|
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-04-29 20:14:16 +00:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
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
|
|
|
}
|