|  |  | 
 |  |  |   CreateButton, | 
 |  |  |   ExportButton, | 
 |  |  |   BulkDeleteButton, | 
 |  |  |   useDataProvider, | 
 |  |  |   WrapperField, | 
 |  |  |   useRecordContext, | 
 |  |  |   useTranslate, | 
 |  |  | 
 |  |  |   DeleteButton, | 
 |  |  |   Button, | 
 |  |  |   useRedirect, | 
 |  |  |   useUnselectAll, | 
 |  |  | } from 'react-admin'; | 
 |  |  | import { Box, Typography, Card, Stack } from '@mui/material'; | 
 |  |  | import { styled } from '@mui/material/styles'; | 
 |  |  | 
 |  |  | import BillStatusField from '../../components/BillStatusField'; | 
 |  |  | import ConfirmButton from '../../components/ConfirmButton'; | 
 |  |  | import PageDrawer from "../../components/PageDrawer"; | 
 |  |  | import MyField from "../../components/MyField"; | 
 |  |  | import { PAGE_DRAWER_WIDTH, OPERATE_MODE, DEFAULT_PAGE_SIZE } from '@/config/setting'; | 
 |  |  | import * as Common from '@/utils/common'; | 
 |  |  | import ConstructionIcon from "@mui/icons-material/Construction"; | 
 |  |  | import FileDownloadIcon from '@mui/icons-material/FileDownload'; | 
 |  |  | import EditIcon from '@mui/icons-material/Edit'; | 
 |  |  | import TaskIcon from '@mui/icons-material/Task'; | 
 |  |  | import CloseIcon from '@mui/icons-material/Close'; | 
 |  |  | import request from '@/utils/request'; | 
 |  |  | import DictionarySelect from "../../components/DictionarySelect"; | 
 |  |  |  | 
 |  |  | import ExitToAppIcon from '@mui/icons-material/ExitToApp'; | 
 |  |  | import ImportButton from "../../components/ImportButton"; | 
 |  |  | import PrintOutlinedIcon from '@mui/icons-material/PrintOutlined'; | 
 |  |  | import OrderPrintPreview from "./OrderPrintPreview"; | 
 |  |  | import CreateNewFolderOutlinedIcon from '@mui/icons-material/CreateNewFolderOutlined'; | 
 |  |  | import AsnCreateByPoModal from "./AsnCreateByPoModal"; | 
 |  |  | const StyledDatagrid = styled(DatagridConfigurable)(({ theme }) => ({ | 
 |  |  |   '& .css-1vooibu-MuiSvgIcon-root': { | 
 |  |  |     height: '.9em' | 
 |  |  | 
 |  |  |  | 
 |  |  | ] | 
 |  |  |  | 
 |  |  | const AsnOrderList = () => { | 
 |  |  | const AsnOrderList = (props) => { | 
 |  |  |   const translate = useTranslate(); | 
 |  |  |   const [createDialog, setCreateDialog] = useState(false); | 
 |  |  |   const [drawerVal, setDrawerVal] = useState(false); | 
 |  |  |   const [modalType, setmodalType] = useState(0); | 
 |  |  |   const [select, setSelect] = useState(0); | 
 |  |  |   const [poCreate, setPoCreate] = useState(false); | 
 |  |  |   const [printOrder, setPrintOrder] = useState(false); | 
 |  |  |   const [select, setSelect] = useState({}); | 
 |  |  |   const invoiceRef = useRef(); | 
 |  |  |   const billReload = useRef(); | 
 |  |  |   const location = useLocation(); | 
 |  |  |   const notify = useNotify(); | 
 |  |  |   const refresh = useRefresh(); | 
 |  |  |   const dicts = JSON.parse(localStorage.getItem('sys_dicts'))?.filter(dict => (dict.dictTypeCode == 'sys_business_type')) || []; | 
 |  |  |   return ( | 
 |  |  |     <Box display="flex"> | 
 |  |  |       <List | 
 |  |  |         resource="asnOrder" | 
 |  |  |         sx={{ | 
 |  |  |           flexGrow: 1, | 
 |  |  |           transition: (theme) => | 
 |  |  | 
 |  |  |           marginRight: drawerVal ? `${PAGE_DRAWER_WIDTH}px` : 0, | 
 |  |  |         }} | 
 |  |  |         title={"menu.asnOrder"} | 
 |  |  |         empty={<EmptyData onClick={() => { setCreateDialog(true); setmodalType(0) }} />} | 
 |  |  |         empty={false} | 
 |  |  |         filters={filters} | 
 |  |  |         sort={{ field: "create_time", order: "desc" }} | 
 |  |  |         actions={( | 
 |  |  |           <TopToolbar> | 
 |  |  |             <FilterButton /> | 
 |  |  |             <MyCreateButton onClick={() => { setCreateDialog(true); setmodalType(0) }} /> | 
 |  |  |             <CreateByPoButton setPoCreate={setPoCreate}/> | 
 |  |  |             <SelectColumnsButton preferenceKey='asnOrder' /> | 
 |  |  |             <ImportButton value={'asnOrderItem'} /> | 
 |  |  |             <MyExportButton /> | 
 |  |  |           </TopToolbar> | 
 |  |  |         )} | 
 |  |  | 
 |  |  |         <StyledDatagrid | 
 |  |  |           sx={{ width: '100%' }} | 
 |  |  |           preferenceKey='asnOrder' | 
 |  |  |           bulkActionButtons={<> <InspectionsButton /><BulkDeleteButton mutationMode={OPERATE_MODE} /></>} | 
 |  |  |           bulkActionButtons={ | 
 |  |  |             <> | 
 |  |  |               <InspectionsButton /> | 
 |  |  |               <MyExportButton /> | 
 |  |  |               {/* <BtnBulkExport></BtnBulkExport> */} | 
 |  |  |             </>} | 
 |  |  |           rowClick={false} | 
 |  |  |           expandSingle={true} | 
 |  |  |           omit={['id', 'createTime', 'createBy', 'memo', 'poId', 'rleStatus$']} | 
 |  |  |           omit={['id', 'createTime', 'createBy', 'memo', 'logisNo', 'poId', 'rleStatus$']} | 
 |  |  |         > | 
 |  |  |           <NumberField source="id" /> | 
 |  |  |           <TextField source="code" label="table.field.asnOrder.code" /> | 
 |  |  | 
 |  |  |           <TextField cellClassName="wkType" source="wkType$" label="table.field.asnOrder.wkType" /> | 
 |  |  |           <NumberField source="anfme" label="table.field.asnOrder.anfme" /> | 
 |  |  |           <NumberField source="qty" label="table.field.asnOrder.qty" /> | 
 |  |  |           <TextField source="logisNo" label="table.field.asnOrder.logisNo" /> | 
 |  |  |           <DateField source="arrTime" label="table.field.asnOrder.arrTime" showTime /> | 
 |  |  |           <TextField source="rleStatus$" label="table.field.asnOrder.rleStatus" sortable={false} /> | 
 |  |  |           <TextField source="logisNo" label="table.field.asnOrder.logisNo" /> | 
 |  |  |           {/* <TextField source="ntyStatus$" label="table.field.asnOrder.ntyStatus" /> */} | 
 |  |  |           <TextField source="updateBy$" label="common.field.updateBy" /> | 
 |  |  |           <DateField source="updateTime" label="common.field.updateTime" showTime /> | 
 |  |  |           <TextField source="createBy$" label="common.field.createBy" /> | 
 |  |  | 
 |  |  |             <MyButton setCreateDialog={setCreateDialog} setmodalType={setmodalType} /> | 
 |  |  |             <InspectionButton /> | 
 |  |  |             <CompleteButton /> | 
 |  |  |             <CloseButton /> | 
 |  |  |             <ODeleteButton /> | 
 |  |  |             <PrintButton setPrintOrder={setPrintOrder} setSelect={setSelect} /> | 
 |  |  |             {/* <CloseButton /> */} | 
 |  |  |           </WrapperField> | 
 |  |  |         </StyledDatagrid> | 
 |  |  |       </List> | 
 |  |  | 
 |  |  |         setOpen={setCreateDialog} | 
 |  |  |         asnId={modalType} | 
 |  |  |         billReload={billReload} | 
 |  |  |       /> | 
 |  |  |       <OrderPrintPreview | 
 |  |  |         open={printOrder} | 
 |  |  |         setOpen={setPrintOrder} | 
 |  |  |         record={select} | 
 |  |  |       /> | 
 |  |  |       <AsnCreateByPoModal | 
 |  |  |         open={poCreate} | 
 |  |  |         setOpen={setPoCreate} | 
 |  |  |       /> | 
 |  |  |       <PageDrawer | 
 |  |  |         title='AsnOrder Detail' | 
 |  |  | 
 |  |  | } | 
 |  |  | export default AsnOrderList; | 
 |  |  |  | 
 |  |  | //按PO单新建 | 
 |  |  | const CreateByPoButton = ({setPoCreate}) => { | 
 |  |  |   const record = useRecordContext(); | 
 |  |  |  | 
 |  |  |   const createEvent = (event) => { | 
 |  |  |     event.stopPropagation(); | 
 |  |  |     setPoCreate(true) | 
 |  |  |   } | 
 |  |  |   return ( | 
 |  |  |     <Button label={"toolbar.poCreate"} onClick={createEvent}> | 
 |  |  |       <CreateNewFolderOutlinedIcon /> | 
 |  |  |     </Button> | 
 |  |  |   ) | 
 |  |  | } | 
 |  |  |  | 
 |  |  |  | 
 |  |  | //打印按钮 | 
 |  |  | const PrintButton = ({ setPrintOrder, setSelect }) => { | 
 |  |  |   const record = useRecordContext(); | 
 |  |  |   const printOrder = (event) => { | 
 |  |  |     event.stopPropagation(); | 
 |  |  |     setPrintOrder(true) | 
 |  |  |     setSelect(record) | 
 |  |  |   } | 
 |  |  |  | 
 |  |  |   return ( | 
 |  |  |     <Button label={"toolbar.print"} onClick={printOrder}> | 
 |  |  |       <PrintOutlinedIcon /> | 
 |  |  |     </Button> | 
 |  |  |   ) | 
 |  |  | } | 
 |  |  |  | 
 |  |  |  | 
 |  |  | const ODeleteButton = () => { | 
 |  |  |   const record = useRecordContext(); | 
 |  |  |   return ( | 
 |  |  |     record.exceStatus === 0 ? <DeleteButton mutationMode="pessimistic" /> : <></> | 
 |  |  |   ) | 
 |  |  |  | 
 |  |  | } | 
 |  |  |  | 
 |  |  | const MyButton = ({ setCreateDialog, setmodalType }) => { | 
 |  |  |   const record = useRecordContext(); | 
 |  |  |   const handleEditClick = (btn) => { | 
 |  |  | 
 |  |  |  | 
 |  |  |   }; | 
 |  |  |   return ( | 
 |  |  |     <Button | 
 |  |  |       color="primary" | 
 |  |  |       startIcon={<EditIcon />} | 
 |  |  |       onClick={(btn) => handleEditClick(btn)} | 
 |  |  |       sx={{ ml: 1 }} | 
 |  |  |       label={'ra.action.edit'} | 
 |  |  |     > | 
 |  |  |     </Button> | 
 |  |  |     record.exceStatus === 1 || record.exceStatus === 0 ? | 
 |  |  |       <Button | 
 |  |  |         color="primary" | 
 |  |  |         startIcon={<EditIcon />} | 
 |  |  |         onClick={(btn) => handleEditClick(btn)} | 
 |  |  |         sx={{ ml: 1 }} | 
 |  |  |         label={'ra.action.edit'} | 
 |  |  |       > | 
 |  |  |       </Button> | 
 |  |  |       : <></> | 
 |  |  |   ) | 
 |  |  | } | 
 |  |  |  | 
 |  |  | //报检 | 
 |  |  | const InspectionButton = () => { | 
 |  |  |   const record = useRecordContext(); | 
 |  |  |   const notify = useNotify(); | 
 |  |  | 
 |  |  |     } | 
 |  |  |   } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |   return ( | 
 |  |  |     <Button onClick={inspection} label={"toolbar.inspection"}> | 
 |  |  |       <ConstructionIcon /> | 
 |  |  |     </Button> | 
 |  |  |     <ConfirmButton label={"toolbar.inspection"} color="secondary" startIcon={<ConstructionIcon />} onConfirm={inspection} /> | 
 |  |  |   ) | 
 |  |  | } | 
 |  |  |  | 
 |  |  | 
 |  |  |   const { selectedIds, onUnselectItems, data } = useListContext(); | 
 |  |  |   const notify = useNotify(); | 
 |  |  |   const refresh = useRefresh(); | 
 |  |  |   const translate = useTranslate(); | 
 |  |  |   const inspection = (btn) => { | 
 |  |  |     btn.stopPropagation(); | 
 |  |  |     if (selectedIds.length === 0) { | 
 |  |  |       notify('请选择通知单'); | 
 |  |  |       notify(translate("request.error.select_error_order")); | 
 |  |  |       return; | 
 |  |  |     } else { | 
 |  |  |       const rows = data.filter((item) => selectedIds.includes(item.id)) | 
 |  |  | 
 |  |  |     } | 
 |  |  |   } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |   return ( | 
 |  |  |     <Button onClick={inspection} label={"toolbar.inspection"}> | 
 |  |  |       <ConstructionIcon /> | 
 |  |  | 
 |  |  |   ) | 
 |  |  | } | 
 |  |  |  | 
 |  |  | const BtnBulkExport = () => { | 
 |  |  |   const { filter, selectedIds, filterValues, resource, sort, total } = useListContext(); | 
 |  |  |   const refresh = useRefresh(); | 
 |  |  |   const dataProvider = useDataProvider(); | 
 |  |  |   const notify = useNotify(); | 
 |  |  |   const unSelect = useUnselectAll(resource); | 
 |  |  |  | 
 |  |  |   const bulkExport = () => { | 
 |  |  |     getExport() | 
 |  |  |     unSelect(); | 
 |  |  |   } | 
 |  |  |   const getExport = () => { | 
 |  |  |     dataProvider | 
 |  |  |       .export(resource, { | 
 |  |  |         ids: selectedIds, | 
 |  |  |         pagination: { page: 1, perPage: 1000 }, | 
 |  |  |       }) | 
 |  |  |       .then((res) => { | 
 |  |  |         const url = window.URL.createObjectURL( | 
 |  |  |           new Blob([res.data], { type: res.headers["content-type"] }), | 
 |  |  |         ); | 
 |  |  |         const link = document.createElement("a"); | 
 |  |  |         link.href = url; | 
 |  |  |         link.setAttribute("download", `${resource}.xlsx`); | 
 |  |  |         document.body.appendChild(link); | 
 |  |  |         link.click(); | 
 |  |  |         link.remove(); | 
 |  |  |       }) | 
 |  |  |       .catch((error) => { | 
 |  |  |         console.error(error); | 
 |  |  |         notify("ra.notification.http_error", { type: "error" }); | 
 |  |  |       }); | 
 |  |  |     if (typeof onClick === "function") { | 
 |  |  |       onClick(event); | 
 |  |  |     } | 
 |  |  |   }; | 
 |  |  |  | 
 |  |  |   return ( | 
 |  |  |     <> | 
 |  |  |       <Button label="toolbar.bulkExport" onClick={bulkExport}> | 
 |  |  |         <ExitToAppIcon /> | 
 |  |  |       </Button> | 
 |  |  |     </> | 
 |  |  |   ) | 
 |  |  | } | 
 |  |  |  | 
 |  |  | //完成单据 | 
 |  |  | const CompleteButton = () => { | 
 |  |  |   const record = useRecordContext(); | 
 |  |  |   const notify = useNotify(); | 
 |  |  | 
 |  |  |     } | 
 |  |  |   } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |   return ( | 
 |  |  |     record.exceStatus === 1 && (record.anfme === record.qty ? <Button onClick={requestComplete} label={"toolbar.complete"} color="success"> | 
 |  |  |       <TaskIcon /> | 
 |  |  |     </Button> : <ConfirmButton label={"toolbar.complete"} color="success" data={'当前收货数量小于计划数量,是否确认完成'} startIcon={<TaskIcon />} onConfirm={requestComplete} />) | 
 |  |  |  | 
 |  |  |     // record.exceStatus === 1 && (record.anfme === record.qty ? <Button onClick={requestComplete} label={"toolbar.complete"} color="secondary"> | 
 |  |  |     //   <TaskIcon /> | 
 |  |  |     // </Button> : ) | 
 |  |  |     record.exceStatus === 1 ? <ConfirmButton label={"toolbar.complete"} color="secondary" startIcon={<TaskIcon />} onConfirm={requestComplete} /> : <></> | 
 |  |  |   ) | 
 |  |  |  | 
 |  |  |  | 
 |  |  | 
 |  |  |   } | 
 |  |  |  | 
 |  |  |   return ( | 
 |  |  |     <ConfirmButton label={"toolbar.close"} color="error" data={'确认是否关闭?'} startIcon={<CloseIcon />} onConfirm={requestClose} /> | 
 |  |  |     <ConfirmButton label={"toolbar.close"} color="error" startIcon={<CloseIcon />} onConfirm={requestClose} /> | 
 |  |  |   ) | 
 |  |  | } |