|  |  |  | 
|---|
|  |  |  | import StatusSelectInput from "../../components/StatusSelectInput"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import { useReactToPrint } from "react-to-print"; | 
|---|
|  |  |  | import jsbarcode from 'jsbarcode' | 
|---|
|  |  |  | import { el } from "date-fns/locale"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const PrintModal = ({ open, setOpen }) => { | 
|---|
|  |  |  | const PrintModal = ({ open, setOpen, rows }) => { | 
|---|
|  |  |  | const refresh = useRefresh(); | 
|---|
|  |  |  | const translate = useTranslate(); | 
|---|
|  |  |  | const notify = useNotify(); | 
|---|
|  |  |  | const contentRef = useRef(null); | 
|---|
|  |  |  | const reactToPrintFn = useReactToPrint({ contentRef }); | 
|---|
|  |  |  | const contentRef = useRef(); | 
|---|
|  |  |  | const reactToPrintFn = useReactToPrint({ | 
|---|
|  |  |  | content: () => { | 
|---|
|  |  |  | return contentRef.current | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | documentTitle: `物料信息`, | 
|---|
|  |  |  | pageStyle: ` | 
|---|
|  |  |  | @page { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | margin: 10mm; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @media print { | 
|---|
|  |  |  | html, body { | 
|---|
|  |  |  | width: 70mm;     // A4横向宽度 | 
|---|
|  |  |  | height: 40mm;    // A4横向高度 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }` | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const handleClose = (event, reason) => { | 
|---|
|  |  |  | if (reason !== "backdropClick") { | 
|---|
|  |  |  | 
|---|
|  |  |  | </FormControl> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <Box> | 
|---|
|  |  |  | <div style={{ textAlign: 'center' }}> | 
|---|
|  |  |  | <PrintTemp /> | 
|---|
|  |  |  | <div style={{ textAlign: 'center', display: 'flex', justifyContent: 'center' }}> | 
|---|
|  |  |  | <table | 
|---|
|  |  |  | className="contain" | 
|---|
|  |  |  | style={{ | 
|---|
|  |  |  | overflow: 'hidden', | 
|---|
|  |  |  | fontSize: 'small', | 
|---|
|  |  |  | tableLayout: 'fixed', | 
|---|
|  |  |  | width: '280px', | 
|---|
|  |  |  | borderCollapse: 'collapse', // 合并边框 | 
|---|
|  |  |  | border: '1px solid black' // 设置表格整体边框 | 
|---|
|  |  |  | }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <tbody> | 
|---|
|  |  |  | <tr style={{ height: '74px' }}> | 
|---|
|  |  |  | <td | 
|---|
|  |  |  | align="center" | 
|---|
|  |  |  | colSpan={3} | 
|---|
|  |  |  | style={{ border: '1px solid black' }} // 设置单元格边框 | 
|---|
|  |  |  | > | 
|---|
|  |  |  | 商品编码 | 
|---|
|  |  |  | </td> | 
|---|
|  |  |  | <td | 
|---|
|  |  |  | align="center" | 
|---|
|  |  |  | className="barcode" | 
|---|
|  |  |  | colSpan={9} | 
|---|
|  |  |  | style={{ border: '1px solid black' }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <img className="template-code" src={'/img/barcode.jpeg'} style={{ width: '90%' }} alt="Barcode" /> | 
|---|
|  |  |  | <div style={{ letterSpacing: '2px', marginTop: '1px', textAlign: 'center' }}> | 
|---|
|  |  |  | <span>{'xxxxxx'}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </td> | 
|---|
|  |  |  | </tr> | 
|---|
|  |  |  | <tr style={{ height: '74px' }}> | 
|---|
|  |  |  | <td | 
|---|
|  |  |  | align="center" | 
|---|
|  |  |  | colSpan={3} | 
|---|
|  |  |  | style={{ border: '1px solid black' }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | 商品 | 
|---|
|  |  |  | </td> | 
|---|
|  |  |  | <td | 
|---|
|  |  |  | align="center" | 
|---|
|  |  |  | colSpan={5} | 
|---|
|  |  |  | style={{ | 
|---|
|  |  |  | overflow: 'hidden', | 
|---|
|  |  |  | whiteSpace: 'nowrap', | 
|---|
|  |  |  | textOverflow: 'ellipsis', | 
|---|
|  |  |  | border: '1px solid black' | 
|---|
|  |  |  | }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {'xxxxxxxx'} | 
|---|
|  |  |  | </td> | 
|---|
|  |  |  | <td | 
|---|
|  |  |  | align="center" | 
|---|
|  |  |  | colSpan={2} | 
|---|
|  |  |  | style={{ border: '1px solid black' }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | 备注 | 
|---|
|  |  |  | </td> | 
|---|
|  |  |  | <td | 
|---|
|  |  |  | align="center" | 
|---|
|  |  |  | colSpan={2} | 
|---|
|  |  |  | style={{ border: '1px solid black' }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {'xx'} | 
|---|
|  |  |  | </td> | 
|---|
|  |  |  | </tr> | 
|---|
|  |  |  | </tbody> | 
|---|
|  |  |  | </table> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <style>{` | 
|---|
|  |  |  | @media print { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }`} </style> | 
|---|
|  |  |  | <div ref={contentRef} className="print-content" style={{ textAlign: 'center', display: 'none' }}> | 
|---|
|  |  |  | <PrintTemp /> | 
|---|
|  |  |  | <PrintTemp key={'bb'} rows={rows} /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </Box> | 
|---|
|  |  |  | </DialogContent> | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | export default PrintModal; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const PrintTemp = (props) => { | 
|---|
|  |  |  | const [data, setData] = useState([{ | 
|---|
|  |  |  | barcode: '/img/barcode.jpeg', | 
|---|
|  |  |  | product: 'xxxxxx-xx/xx', | 
|---|
|  |  |  | remark: 'xx' | 
|---|
|  |  |  | }]); | 
|---|
|  |  |  | const PrintTemp = ({ rows }) => { | 
|---|
|  |  |  | const notify = useNotify(); | 
|---|
|  |  |  | const [data, setData] = useState([]); | 
|---|
|  |  |  | const http = async () => { | 
|---|
|  |  |  | const res = await request.post(`/matnrs/many/${rows?.join()}`); | 
|---|
|  |  |  | if (res?.data?.code === 200) { | 
|---|
|  |  |  | let val = res.data.data.map((el => { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | barcode: '/img/barcode.jpeg', | 
|---|
|  |  |  | code: el.code, | 
|---|
|  |  |  | name: el.name, | 
|---|
|  |  |  | memo: el.memo | 
|---|
|  |  |  | } | 
|---|
|  |  |  | })) | 
|---|
|  |  |  | setData(val) | 
|---|
|  |  |  | setTimeout(() => { | 
|---|
|  |  |  | val.forEach((el) => { | 
|---|
|  |  |  | jsbarcode(`#barcode${el.code}`, el.code, { height: 30 }); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, 10); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | notify(res.data.msg); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | useEffect(() => { | 
|---|
|  |  |  | if (rows?.length > 0) { | 
|---|
|  |  |  | http(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }, [rows]); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return ( | 
|---|
|  |  |  | <> | 
|---|
|  |  |  | {data.map((item, index) => ( | 
|---|
|  |  |  | 
|---|
|  |  |  | overflow: 'hidden', | 
|---|
|  |  |  | fontSize: 'small', | 
|---|
|  |  |  | tableLayout: 'fixed', | 
|---|
|  |  |  | width: '280px', | 
|---|
|  |  |  | width: '520px', | 
|---|
|  |  |  | borderCollapse: 'collapse', | 
|---|
|  |  |  | borderSpacing: 0, | 
|---|
|  |  |  | margin: '0 auto', | 
|---|
|  |  |  | 
|---|
|  |  |  | colSpan={9} | 
|---|
|  |  |  | style={{ border: '1px solid black' }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {/* <img id={"barcode" + item.code} style={{ width: '70%', verticalAlign: 'middle' }} /> */} | 
|---|
|  |  |  | <img className="template-code" src={item.barcode} style={{ width: '90%', verticalAlign: 'middle' }} alt="Barcode" /> | 
|---|
|  |  |  | <div style={{ letterSpacing: '2px', marginTop: '1px', textAlign: 'center' }}> | 
|---|
|  |  |  | <span>{'xxxxxx'}</span> | 
|---|
|  |  |  | <span>{item.code}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </td> | 
|---|
|  |  |  | </tr> | 
|---|
|  |  |  | 
|---|
|  |  |  | border: '1px solid black' | 
|---|
|  |  |  | }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {item.product} | 
|---|
|  |  |  | {item.name} | 
|---|
|  |  |  | </td> | 
|---|
|  |  |  | <td | 
|---|
|  |  |  | align="center" | 
|---|
|  |  |  | 
|---|
|  |  |  | colSpan={2} | 
|---|
|  |  |  | style={{ border: '1px solid black' }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {item.remark} | 
|---|
|  |  |  | {item.memo} | 
|---|
|  |  |  | </td> | 
|---|
|  |  |  | </tr> | 
|---|
|  |  |  | </tbody> | 
|---|