import React, { useState } from "react"; import { Button, Menu, MenuItem, Box, Tooltip, IconButton, Divider, TextField, InputAdornment } from "@mui/material"; import InfoOutlinedIcon from "@mui/icons-material/InfoOutlined"; import InventoryIcon from "@mui/icons-material/Inventory"; import AddIcon from "@mui/icons-material/Add"; import PlayArrowIcon from "@mui/icons-material/PlayArrow"; import DownloadIcon from "@mui/icons-material/Download"; import ReplayIcon from "@mui/icons-material/Replay"; import DeleteIcon from "@mui/icons-material/Delete"; import VpnKeyIcon from "@mui/icons-material/VpnKey"; import RefreshIcon from "@mui/icons-material/Refresh"; import FileDownloadIcon from "@mui/icons-material/FileDownload"; import SearchIcon from "@mui/icons-material/Search"; import ClearIcon from "@mui/icons-material/Clear"; import AutoRefreshControl from "components/common/AutoRefreshControl"; import type { AutoRefreshInterval } from "api/types/AutoRefreshInterval"; import type { BuildStatus } from "api/types/BuildStatus"; import { StatusColors } from "theme/status/StatusColors"; export interface AutoRefreshProps { intervals: AutoRefreshInterval[]; enabled: boolean; currentInterval: number; onToggle: (enabled: boolean) => void; onIntervalChange: (interval: number) => void; } export interface ToolbarActions { onDashboardClick: () => void; onAddClick: () => void; onUpdateClick: () => void; onRefreshDbClick: () => void; onRebuildClick: () => void; onRemoveClick: () => void; onKeyImportClick: () => void; onReloadClick: () => void; onExportClick: () => void; } interface PackageTableToolbarProps { hasSelection: boolean; isAuthorized: boolean; repoStatus?: BuildStatus; searchText: string; onSearchChange: (text: string) => void; autoRefresh: AutoRefreshProps; actions: ToolbarActions; } export default function PackageTableToolbar({ hasSelection, isAuthorized, repoStatus, searchText, onSearchChange, autoRefresh, actions, }: PackageTableToolbarProps): React.JSX.Element { const [packagesAnchorEl, setPackagesAnchorEl] = useState(null); return ( {isAuthorized && ( <> setPackagesAnchorEl(null)} > { setPackagesAnchorEl(null); actions.onAddClick(); }}> add { setPackagesAnchorEl(null); actions.onUpdateClick(); }}> update { setPackagesAnchorEl(null); actions.onRefreshDbClick(); }}> update pacman databases { setPackagesAnchorEl(null); actions.onRebuildClick(); }}> rebuild { setPackagesAnchorEl(null); actions.onRemoveClick(); }} disabled={!hasSelection}> remove )} onSearchChange(e.target.value)} slotProps={{ input: { startAdornment: ( ), endAdornment: searchText ? ( onSearchChange("")}> ) : undefined, }, }} sx={{ minWidth: 200 }} /> ); }