/* * QQQ - Low-code Application Framework for Engineers. * Copyright (C) 2021-2024. Kingsrook, LLC * 651 N Broad St Ste 205 # 6917 | Middletown DE 19709 | United States * contact@kingsrook.com * https://github.com/Kingsrook/ * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ import {Capability} from "@kingsrook/qqq-frontend-core/lib/model/metaData/Capability"; import {QInstance} from "@kingsrook/qqq-frontend-core/lib/model/metaData/QInstance"; import {QProcessMetaData} from "@kingsrook/qqq-frontend-core/lib/model/metaData/QProcessMetaData"; import {QTableMetaData} from "@kingsrook/qqq-frontend-core/lib/model/metaData/QTableMetaData"; import Divider from "@mui/material/Divider"; import Icon from "@mui/material/Icon"; import ListItemIcon from "@mui/material/ListItemIcon"; import Menu from "@mui/material/Menu"; import MenuItem from "@mui/material/MenuItem"; import React, {useState} from "react"; import {useNavigate} from "react-router-dom"; import {QActionsMenuButton} from "qqq/components/buttons/DefaultButtons"; interface QueryScreenActionMenuProps { metaData: QInstance; tableMetaData: QTableMetaData; tableProcesses: QProcessMetaData[]; bulkLoadClicked: () => void; bulkEditClicked: () => void; bulkDeleteClicked: () => void; processClicked: (process: QProcessMetaData) => void; } QueryScreenActionMenu.defaultProps = { }; export default function QueryScreenActionMenu({metaData, tableMetaData, tableProcesses, bulkLoadClicked, bulkEditClicked, bulkDeleteClicked, processClicked}: QueryScreenActionMenuProps): JSX.Element { const [anchorElement, setAnchorElement] = useState(null) const navigate = useNavigate(); const openActionsMenu = (event: any) => { setAnchorElement(event.currentTarget); } const closeActionsMenu = () => { setAnchorElement(null); } const pushDividerIfNeeded = (menuItems: JSX.Element[]) => { if (menuItems.length > 0) { menuItems.push(); } }; const runSomething = (handler: () => void) => { closeActionsMenu(); handler(); } const menuItems: JSX.Element[] = []; if (tableMetaData.capabilities.has(Capability.TABLE_INSERT) && tableMetaData.insertPermission) { menuItems.push( runSomething(bulkLoadClicked)}>library_addBulk Load); } if (tableMetaData.capabilities.has(Capability.TABLE_UPDATE) && tableMetaData.editPermission) { menuItems.push( runSomething(bulkEditClicked)}>editBulk Edit); } if (tableMetaData.capabilities.has(Capability.TABLE_DELETE) && tableMetaData.deletePermission) { menuItems.push( runSomething(bulkDeleteClicked)}>deleteBulk Delete); } const runRecordScriptProcess = metaData?.processes.get("runRecordScript"); if (runRecordScriptProcess) { const process = runRecordScriptProcess; menuItems.push( runSomething(() => processClicked(process))}>{process.iconName ?? "arrow_forward"}{process.label}); } menuItems.push( navigate(`${metaData.getTablePathByName(tableMetaData.name)}/dev`)}>codeDeveloper Mode); if (tableProcesses && tableProcesses.length) { pushDividerIfNeeded(menuItems); } tableProcesses.sort((a, b) => a.label.localeCompare(b.label)); tableProcesses.map((process) => { menuItems.push( runSomething(() => processClicked(process))}>{process.iconName ?? "arrow_forward"}{process.label}); }); if (menuItems.length === 0) { menuItems.push(blockNo actions available); } return ( <> {menuItems} ) }