// src/Printers.js import { useState, useRef } from 'react' import { Button, message, Dropdown, Space, Flex, Modal } from 'antd' import NewPrinter from './Printers/NewPrinter' import PlusIcon from '../../Icons/PlusIcon' import ReloadIcon from '../../Icons/ReloadIcon' import ObjectTable from '../common/ObjectTable' import ColumnViewButton from '../common/ColumnViewButton' import GridIcon from '../../Icons/GridIcon' import ListIcon from '../../Icons/ListIcon' import useViewMode from '../hooks/useViewMode' import useColumnVisibility from '../hooks/useColumnVisibility' const Printers = () => { const [messageApi, contextHolder] = message.useMessage() const [newPrinterOpen, setNewPrinterOpen] = useState(false) const tableRef = useRef() // View mode state (cards/list), persisted in sessionStorage via custom hook const [viewMode, setViewMode] = useViewMode('Printers') // Column visibility state, persisted in sessionStorage via custom hook const [columnVisibility, setColumnVisibility] = useColumnVisibility('printer') const actionItems = { items: [ { label: 'New Printer', key: 'newPrinter', icon: }, { type: 'divider' }, { label: 'Reload List', key: 'reloadList', icon: } ], onClick: ({ key }) => { if (key === 'reloadList') { tableRef.current?.reload() } else if (key === 'newPrinter') { setNewPrinterOpen(true) } } } return ( <> {contextHolder}