// Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 import * as 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 { 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 { navigateToUsers } from '~/store/navigation/navigation-action'; interface AdminMenuProps { user?: User; } const mapStateToProps = (state: RootState): AdminMenuProps => ({ user: state.auth.user }); export const AdminMenu = connect(mapStateToProps)( ({ user, dispatch }: AdminMenuProps & DispatchProp) => user ? } id="admin-menu" title="Admin Panel"> dispatch(openRepositoriesPanel())}>Repositories dispatch(openAdminVirtualMachines())}>Virtual Machines dispatch(navigateToSshKeysAdmin)}>Ssh Keys dispatch(navigateToApiClientAuthorizations)}>Api Tokens dispatch(navigateToUsers)}>Users dispatch(navigateToComputeNodes)}>Compute Nodes dispatch(navigateToKeepServices)}>Keep Services dispatch(logout())}>Logout : null);