From b3c1bf810ea7b7c1f8088309667bc80b698b3374 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期六, 10 五月 2025 09:50:01 +0800
Subject: [PATCH] Merge branch 'devlop' of http://47.97.1.152:5880/r/wms-master into devlop

---
 rsf-admin/src/page/orders/asnOrder/OrderPrintPreview.jsx |  189 ++++++++++++++++++++++++++--------------------
 1 files changed, 107 insertions(+), 82 deletions(-)

diff --git a/rsf-admin/src/page/orders/asnOrder/OrderPrintPreview.jsx b/rsf-admin/src/page/orders/asnOrder/OrderPrintPreview.jsx
index 8f6db2f..872afee 100644
--- a/rsf-admin/src/page/orders/asnOrder/OrderPrintPreview.jsx
+++ b/rsf-admin/src/page/orders/asnOrder/OrderPrintPreview.jsx
@@ -36,6 +36,7 @@
 import { styled } from '@mui/material/styles';
 import { QRCodeSVG, QRCodeCanvas } from 'qrcode.react';  // 鐜板湪蹇呴』杩欐牱鐢�
 import PrintOutlinedIcon from '@mui/icons-material/PrintOutlined';
+import { useReactToPrint } from "react-to-print";
 
 const StyledDatagrid = styled(DatagridConfigurable)(({ theme }) => ({
     '& .css-1vooibu-MuiSvgIcon-root': {
@@ -60,8 +61,8 @@
 const OrderPrintPreview = (props) => {
     const { open, setOpen, record } = props;
     const notify = useNotify();
+    const invoiceRef = useRef();
     const translate = useTranslate();
-    const [drawerVal, setDrawerVal] = useState(false);
     const [disabled, setDisabled] = useState(false)
     const dicts = JSON.parse(localStorage.getItem('sys_dicts'))?.filter(dict => (dict.dictTypeCode == 'sys_order_type')) || [];
     const business = JSON.parse(localStorage.getItem('sys_dicts'))?.filter(dict => (dict.dictTypeCode == 'sys_business_type')) || [];
@@ -70,88 +71,112 @@
         setOpen(false);
     };
 
+    const printOrders = useReactToPrint({
+        content: () => {
+            return invoiceRef.current
+        },
+        documentTitle: `璁㈠崟`,
+        pageStyle: `
+        @page {
+            size: A4;
+            margin: 10mm;
+        }
+        @media print {
+            body {
+            -webkit-print-color-adjust: exact;
+            }
+        }`,
+        onAfterPrint: () => alert('宸插彂閫佽嚦鎵撳嵃鏈�!')
+    })
+
+
     return (
-        <>
-            <Dialog
-                open={open}
-                onClose={handleClose}
-                aria-labelledby="form-dialog-title"
-                aria-hidden
-                fullWidth
-                disableRestoreFocus
-                maxWidth="xl"   // 'xs' | 'sm' | 'md' | 'lg' | 'xl'
-            >
-                <DialogTitle id="form-dialog-title" sx={{
-                    position: 'sticky',
-                    top: 0,
-                    textAlign: 'center',
-                    backgroundColor: 'background.paper',
-                    zIndex: 1000
-                }}>
-                    {translate('menu.asnOrder')}
-                    <Box sx={{ position: 'absolute', top: 8, right: 8, zIndex: 1001 }}>
-                        <DialogCloseButton onClose={handleClose} />
-                    </Box>
-                </DialogTitle>
-                <DialogContent sx={{ mt: 2 }}>
-                    <Box sx={{ display: 'flex', flexDirection: 'column', gap: 3 }}>
-                        <Form defaultValues={record}>
-                            <Grid container spacing={2} sx={{ justifyContent: 'space-between', }}>
-                                <Grid item md={2}>
-                                    <Box sx={{ display: 'flex', justifyContent: 'center' }}>
-                                        <Typography>鍗曟嵁绫诲瀷锛�</Typography>
-                                        <Typography>{record?.type$}</Typography>
-                                    </Box>
-                                    <Box sx={{ display: 'flex', justifyContent: 'center', padding: 1 }}></Box>
-                                    <Box sx={{ display: 'flex', justifyContent: 'center' }}>
-                                        <Typography>涓氬姟绫诲瀷锛�</Typography>
-                                        <Typography>{record?.wkType$}</Typography>
-                                    </Box>
-                                </Grid>
-                                <Grid item md={2}>
-                                    <QRCodeSVG value={record?.code} />
-                                    <Typography>{record.code}</Typography>
-                                </Grid>
-                                {/* <Grid item md={2}>
-                                    <TextInput source="code" label={"table.field.asnOrder.code"} />
-                                </Grid> */}
-                            </Grid>
-                        </Form>
-                        <List
-                            resource="asnOrderItem"
-                            sx={{
-                                flexGrow: 1,
-                                transition: (theme) =>
-                                    theme.transitions.create(['all'], {
-                                        duration: theme.transitions.duration.enteringScreen,
-                                    }),
-                                marginRight: drawerVal ? `${PAGE_DRAWER_WIDTH}px` : 0,
-                            }}
-                            title={"menu.asnOrderItem"}
-                            empty={false}
-                            filter={{ asnId: record?.id }}
-                            sort={{ field: "create_time", order: "desc" }}
-                            actions={(
-                                <></>
-                            )}
-                            perPage={DEFAULT_ITEM_PAGE_SIZE}
-                        >
-                            <DynamicFields />
-                        </List>
-                    </Box>
-                </DialogContent>
-                <DialogActions sx={{ position: 'sticky', bottom: 0, backgroundColor: 'background.paper', zIndex: 1000 }}>
-                    <Toolbar sx={{ width: '100%', justifyContent: 'end' }}  >
-                        <Button disabled={disabled} variant="contained" startIcon={<PrintOutlinedIcon />} label={'toolbar.print'}>
-                        </Button>
-                    </Toolbar>
-                </DialogActions>
-            </Dialog>
-        </>
+        <Dialog
+            className="orderPrintPerview"
+            // ref={invoiceRef}
+            open={open}
+            onClose={handleClose}
+            aria-labelledby="form-dialog-title"
+            aria-hidden
+            fullWidth
+            disableRestoreFocus
+            maxWidth="xl"   // 'xs' | 'sm' | 'md' | 'lg' | 'xl'
+        >
+            <DialogTitle id="form-dialog-title" sx={{
+                position: 'sticky',
+                top: 0,
+                textAlign: 'center',
+                backgroundColor: 'background.paper',
+                zIndex: 1000
+            }}>
+                {translate('menu.asnOrder')}
+                <Box sx={{ position: 'absolute', top: 8, right: 8, zIndex: 1001 }}>
+                    <DialogCloseButton onClose={handleClose} />
+                </Box>
+            </DialogTitle>
+            <DialogContent sx={{ mt: 2 }}>
+                <OrderPreview ref={invoiceRef} record={record} />
+            </DialogContent>
+            <DialogActions sx={{ position: 'sticky', bottom: 0, backgroundColor: 'background.paper', zIndex: 1000 }}>
+                <Toolbar sx={{ width: '100%', justifyContent: 'end' }}  >
+                    <Button disabled={disabled} variant="contained" startIcon={<PrintOutlinedIcon />} label={'toolbar.print'} onClick={printOrders}></Button>
+                </Toolbar>
+            </DialogActions>
+        </Dialog>
     )
 }
 
 export default OrderPrintPreview;
+
+
+
+const OrderPreview = React.forwardRef(({ record }, ref) => (
+    <Box sx={{ display: 'flex', flexDirection: 'column', gap: 3 }} ref={ref}>
+        <Form defaultValues={record}>
+            <Grid container spacing={2} sx={{ justifyContent: 'space-between', }}>
+                <Grid item md={2}>
+                    <Box sx={{ display: 'flex', justifyContent: 'start' }}>
+                        <Typography>ASN鍗曪細</Typography>
+                        <Typography>{record?.code}</Typography>
+                    </Box>
+                    <Box sx={{ display: 'flex', justifyContent: 'start' }}>
+                        <Typography>PO鍗曪細</Typography>
+                        <Typography>{record?.poCode}</Typography>
+                    </Box>
+                    <Box sx={{ display: 'flex', justifyContent: 'start' }}>
+                        <Typography>鍗曟嵁绫诲瀷锛�</Typography>
+                        <Typography>{record?.type$}</Typography>
+                    </Box>
+                    <Box sx={{ display: 'flex', justifyContent: 'center', padding: 1 }}></Box>
+                    <Box sx={{ display: 'flex', justifyContent: 'start' }}>
+                        <Typography>涓氬姟绫诲瀷锛�</Typography>
+                        <Typography>{record?.wkType$}</Typography>
+                    </Box>
+                    <Box sx={{ display: 'flex', justifyContent: 'center', padding: 1 }}></Box>
+                </Grid>
+                <Grid item md={2}>
+                    <QRCodeSVG value={record?.code} />
+                    <Typography>{record.code}</Typography>
+                </Grid>
+            </Grid>
+        </Form>
+        <List
+            resource="asnOrderItem"
+            title={"menu.asnOrderItem"}
+            empty={false}
+            filter={{ asnId: record?.id }}
+            sort={{ field: "create_time", order: "desc" }}
+            actions={(
+                <></>
+            )}
+            perPage={DEFAULT_ITEM_PAGE_SIZE}
+        >
+            <DynamicFields />
+        </List>
+    </Box>
+));
+
+
 
 const DynamicFields = (props) => {
     const translate = useTranslate();
@@ -167,7 +192,6 @@
         const { data: { code, data, msg }, } = await request.get("/fields/enable/list");
         if (code == 200) {
             const arr = [
-                <NumberField source="id" />,
                 <NumberField source="asnId" label="table.field.asnOrderItem.asnId" />,
                 <TextField source="asnCode" label="table.field.asnOrderItem.asnCode" />,
                 <TextField source="poDetlId" label="table.field.asnOrderItem.poDetlId" />,
@@ -179,9 +203,10 @@
                 <TextField source="splrBatch" label="table.field.asnOrderItem.splrBatch" />,
                 <NumberField source="anfme" label="table.field.asnOrderItem.anfme" />,
                 <NumberField source="qty" label="table.field.asnOrderItem.qty" />,
-                <TextField source="splrName" label="table.field.asnOrderItem.splrName" />,
+                <NumberField source="purQty" label="table.field.asnOrderItem.purQty" />,
+                // <TextField source="splrName" label="table.field.asnOrderItem.splrName" />,
                 <TextField source="isptResult$" label="table.field.asnOrderItem.isptResult" />,
-                <TextField source="trackCode" label="table.field.asnOrderItem.barcode" />,
+                // <TextField source="trackCode" label="table.field.asnOrderItem.barcode" />,
                 <TextField source="packName" label="table.field.asnOrderItem.packName" />,
             ]
             const fields = data.map(el => <TextField key={el.fields} source={`extendFields.[${el.fields}]`} label={el.fieldsAlise} />)
@@ -214,7 +239,7 @@
                     preferenceKey='asnOrderItem'
                     bulkActionButtons={false}
                     rowClick={(id, resource, record) => false}
-                    omit={['id', 'asnId', 'poDetlId', 'poDetlCode', 'matnrId', 'purQty', 'purUnit', 'qrcode', 'trackCode']}
+                    omit={['id', 'asnId', 'poDetlId', 'platItemId','poDetlCode', 'matnrId', 'purQty','splrName', 'purUnit', 'qrcode', 'packName' ,'trackCode']}
                 >
                     {columns.map((column) => column)}
                 </StyledDatagrid>}

--
Gitblit v1.9.1