X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/7a81b9d2c37ceb5add5df8fe9fe48b409d971e37..3c7e3cdc547ad5468421e1c049daa94b0d4b8bc0:/src/views-components/main-app-bar/admin-menu.tsx diff --git a/src/views-components/main-app-bar/admin-menu.tsx b/src/views-components/main-app-bar/admin-menu.tsx index 40ba9161..ab5c2ead 100644 --- a/src/views-components/main-app-bar/admin-menu.tsx +++ b/src/views-components/main-app-bar/admin-menu.tsx @@ -2,44 +2,44 @@ // // SPDX-License-Identifier: AGPL-3.0 -import * as React from "react"; +import React from "react"; import { MenuItem } from "@material-ui/core"; -import { User } from "~/models/user"; -import { DropdownMenu } from "~/components/dropdown-menu/dropdown-menu"; -import { AdminMenuIcon } from "~/components/icon/icon"; +import { User } from "models/user"; +import { DropdownMenu } from "components/dropdown-menu/dropdown-menu"; +import { AdminMenuIcon } from "components/icon/icon"; import { DispatchProp, connect } from 'react-redux'; -import { logout } from '~/store/auth/auth-action'; -import { RootState } from "~/store/store"; -import { openRepositoriesPanel } from "~/store/repositories/repositories-actions"; -import { - navigateToSshKeysAdmin, navigateToKeepServices, navigateToComputeNodes, - navigateToApiClientAuthorizations -} from '~/store/navigation/navigation-action'; -import { openAdminVirtualMachines } from "~/store/virtual-machines/virtual-machines-actions"; -import { openUserPanel } from "~/store/users/users-actions"; +import { RootState } from "store/store"; +import { openRepositoriesPanel } from "store/repositories/repositories-actions"; +import * as NavigationAction from 'store/navigation/navigation-action'; +import { openAdminVirtualMachines } from "store/virtual-machines/virtual-machines-actions"; +import { openUserPanel } from "store/users/users-actions"; interface AdminMenuProps { user?: User; + currentRoute: string; } const mapStateToProps = (state: RootState): AdminMenuProps => ({ - user: state.auth.user + user: state.auth.user, + currentRoute: state.router.location ? state.router.location.pathname : '' }); export const AdminMenu = connect(mapStateToProps)( - ({ user, dispatch }: AdminMenuProps & DispatchProp) => + ({ user, dispatch, currentRoute }: AdminMenuProps & DispatchProp) => user ? } id="admin-menu" - title="Admin Panel"> + title="Admin Panel" + key={currentRoute}> dispatch(openRepositoriesPanel())}>Repositories dispatch(openAdminVirtualMachines())}>Virtual Machines - dispatch(navigateToSshKeysAdmin)}>Ssh Keys - dispatch(navigateToApiClientAuthorizations)}>Api Tokens + dispatch(NavigationAction.navigateToSshKeysAdmin)}>Ssh Keys + dispatch(NavigationAction.navigateToApiClientAuthorizations)}>Api Tokens dispatch(openUserPanel())}>Users - dispatch(navigateToComputeNodes)}>Compute Nodes - dispatch(navigateToKeepServices)}>Keep Services - dispatch(logout())}>Logout + dispatch(NavigationAction.navigateToGroups)}>Groups + dispatch(NavigationAction.navigateToComputeNodes)}>Compute Nodes + dispatch(NavigationAction.navigateToKeepServices)}>Keep Services + dispatch(NavigationAction.navigateToLinks)}>Links : null);