1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import React from 'react';
6 import { StyleRulesCallback, WithStyles, withStyles, Grid, LinearProgress } from '@material-ui/core';
7 import { User } from "models/user";
8 import { ArvadosTheme } from 'common/custom-theme';
9 import { WorkbenchPanel } from 'views/workbench/workbench';
10 import { LoginPanel } from 'views/login-panel/login-panel';
11 import { InactivePanel } from 'views/inactive-panel/inactive-panel';
12 import { WorkbenchLoadingScreen } from 'views/workbench/workbench-loading-screen';
13 import { MainAppBar } from 'views-components/main-app-bar/main-app-bar';
15 type CssRules = 'root';
17 const styles: StyleRulesCallback<CssRules> = (theme: ArvadosTheme) => ({
25 export interface MainPanelRootDataProps {
31 isNotLinking: boolean;
32 isLinkingPath: boolean;
34 sessionIdleTimeout: number;
37 type MainPanelRootProps = MainPanelRootDataProps & WithStyles<CssRules>;
39 export const MainPanelRoot = withStyles(styles)(
40 ({ classes, loading, working, user, buildInfo, uuidPrefix,
41 isNotLinking, isLinkingPath, siteBanner, sessionIdleTimeout }: MainPanelRootProps) =>
43 ? <WorkbenchLoadingScreen />
45 {isNotLinking && <MainAppBar
48 uuidPrefix={uuidPrefix}
49 siteBanner={siteBanner}>
51 ? <LinearProgress color="secondary" data-cy="linear-progress" />
54 <Grid container direction="column" className={classes.root}>
56 ? (user.isActive || (!user.isActive && isLinkingPath)
57 ? <WorkbenchPanel isNotLinking={isNotLinking} isUserActive={user.isActive} sessionIdleTimeout={sessionIdleTimeout} />