// src/gcodefiles.js import { useState, useRef } from 'react' import { Button, Flex, Space, Modal, Dropdown } from 'antd' import NewGCodeFile from './GCodeFiles/NewGCodeFile' import useColumnVisibility from '../hooks/useColumnVisibility' import PlusIcon from '../../Icons/PlusIcon' import ReloadIcon from '../../Icons/ReloadIcon' import ObjectTable from '../common/ObjectTable' import ObjectTableViewButton from '../common/ObjectTableViewButton' import FilterSidebarButton from '../common/FilterSidebarButton' import useViewMode from '../hooks/useViewMode' import useFilterSidebarVisibility from '../hooks/useFilterSidebarVisibility' import ColumnViewButton from '../common/ColumnViewButton' import ExportListButton from '../common/ExportListButton' const GCodeFiles = () => { const [newGCodeFileOpen, setNewGCodeFileOpen] = useState(false) const tableRef = useRef() const [viewMode, setViewMode] = useViewMode('gcodeFile') const [columnVisibility, setColumnVisibility] = useColumnVisibility('gcodeFile') const [showFilterSidebar, setShowFilterSidebar] = useFilterSidebarVisibility('GCodeFiles') const actionItems = { items: [ { label: 'New GCodeFile', key: 'newGCodeFile', icon: }, { type: 'divider' }, { label: 'Reload List', key: 'reloadList', icon: } ], onClick: ({ key }) => { if (key === 'reloadList') { tableRef.current?.reload() } else if (key === 'newGCodeFile') { setNewGCodeFileOpen(true) } } } return ( <> setShowFilterSidebar(!showFilterSidebar)} /> { setNewGCodeFileOpen(false) }} destroyOnHidden={true} > { setNewGCodeFileOpen(false) tableRef.current?.reload() }} reset={newGCodeFileOpen} /> ) } export default GCodeFiles