From 3170c2aca0583f801a5527c124103cfbff2bb306 Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期一, 14 七月 2025 15:01:13 +0800 Subject: [PATCH] 盘点单功能优化 --- rsf-admin/src/page/basicInfo/matnr/MatnrList.jsx | 197 +++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 175 insertions(+), 22 deletions(-) diff --git a/rsf-admin/src/page/basicInfo/matnr/MatnrList.jsx b/rsf-admin/src/page/basicInfo/matnr/MatnrList.jsx index 3140810..d33ad5f 100644 --- a/rsf-admin/src/page/basicInfo/matnr/MatnrList.jsx +++ b/rsf-admin/src/page/basicInfo/matnr/MatnrList.jsx @@ -54,7 +54,10 @@ import PrintIcon from '@mui/icons-material/Print'; import request from '@/utils/request'; import BatchModal from './BatchModal'; +import BatchGropuModal from './BatchGropuModal'; import PrintModal from './PrintModal'; +import LinkIcon from '@mui/icons-material/Link'; +import BindModal from './BindModal'; const StyledDatagrid = styled(DatagridConfigurable)(({ theme }) => ({ '& .css-1vooibu-MuiSvgIcon-root': { @@ -64,7 +67,7 @@ '& .RaDatagrid-row': { cursor: 'auto' }, - '& .RaList-content': { + '& .RaList-content': { width: '200px' }, '& .RaList-main': { @@ -84,16 +87,16 @@ overflow: 'hidden', textOverflow: 'ellipsis', display: 'block', - width: '100px', + width: '200px', }, '& .RaDatagrid-table': { - width: '100%' + width: '100%', + position: 'relative', } })); const filters = [ <SearchInput source="condition" alwaysOn />, - <TextInput source="name" label="table.field.matnr.name" alwaysOn />, <TextInput source="code" label="table.field.matnr.code" alwaysOn />, <ReferenceInput source="shipperId$" label="table.field.matnr.shipperId" reference="shipper"> @@ -136,7 +139,6 @@ <NumberInput source="valid" label="table.field.matnr.valid" />, <NumberInput source="validWarn" label="table.field.matnr.validWarn" />, <NumberInput source="flagCheck" label="table.field.matnr.flagCheck" />, - <TextInput label="common.field.memo" source="memo" />, <SelectInput label="common.field.status" @@ -153,11 +155,8 @@ const translate = useTranslate(); const notify = useNotify(); const { isLoading } = useListContext(); - const [columns, setColumns] = useState([]); const refresh = useRefresh(); - const { refetch } = useListContext(); - useEffect(() => { getDynamicFields(); }, []); @@ -170,8 +169,8 @@ if (code === 200) { const arr = [ <NumberField key="id" source="id" />, - <TooltipField key="name" source="name" label="table.field.matnr.name" cellClassName="name" />, <TextField key="code" source="code" label="table.field.matnr.code" />, + <TooltipField key="name" source="name" label="table.field.matnr.name" cellClassName="name" />, <TextField key="shipperId$" source="shipperId$" label="table.field.matnr.shipperId" />, <ReferenceField key="groupId" source="groupId" label="table.field.matnr.groupId" reference="matnrGroup" link={false} sortable={false}> <TextField source="name" /> @@ -193,7 +192,7 @@ <NumberField key="stagn" source="stagn" label="table.field.matnr.stagn" />, <NumberField key="valid" source="valid" label="table.field.matnr.valid" />, <NumberField key="validWarn" source="validWarn" label="table.field.matnr.validWarn" />, - <NumberField key="flagCheck" source="flagCheck" label="table.field.matnr.flagCheck" />, + <BooleanField key="flagCheck" source="flagCheck" label="table.field.matnr.flagCheck" sortable={false} />, <ReferenceField key="updateBy" source="updateBy" label="common.field.updateBy" reference="user" link={false} sortable={false}> <TextField source="nickname" /> </ReferenceField>, @@ -206,12 +205,21 @@ <TextField key="memo" source="memo" label="common.field.memo" sortable={false} />, ] const fields = data.map(el => <TextField key={el.fields} source={`extendFields.[${el.fields}]`} label={el.fieldsAlise} />) - const opt = <WrapperField key="opt" cellClassName="opt" label="common.field.opt"> + const opt = <WrapperField key="opt" cellClassName="fixed" className="fixed" label="common.field.opt"> <EditButton sx={{ padding: '1px', fontSize: '.75rem' }} /> - <EnableButton /> + <PrintButton /> </WrapperField> setColumns([...arr, ...fields, opt]); - + //filters娣诲姞杩囨护瀛楁 + data.map(el => { + var i =0; + filters.map((item) =>{ + if(item.key === el.fields){ + i = 1; + } + }) + i===0 && filters.push(<TextInput key={el.fields} source={el.fields} label={el.fieldsAlise} />) + }) } else { notify(msg); } @@ -238,15 +246,20 @@ <StyledDatagrid preferenceKey='matnr' bulkActionButtons={<> - <BatchButton /> - <PrintButton /> + <BatchGroupButton /> + <BatchWarnButton /> + <BatchFlagButton /> + <BatchStatusButton /> + <BatchLevelButton /> + <BindButton /> + <BatchPrintButton /> <BulkDeleteButton mutationMode={OPERATE_MODE} /> </>} rowClick={(id, resource, record) => false} - omit={['id', 'shipperId', 'platCode', 'spec', 'model', 'weight', 'color', 'describle' - , 'nromNum', 'unit', 'purchaseUnit', 'stockUnit', 'stockLeval', 'isLabelMange', 'safeQty' + omit={['id', 'shipperId', 'platCode', 'model', 'weight', 'color', 'describle' + , 'nromNum', 'unit', 'purchaseUnit', 'stockUnit', 'isLabelMange', 'safeQty' , 'minQty', 'maxQty', 'stagn', 'valid', 'validWarn', 'flagCheck', 'updateTime', 'updateBy' - , 'createTime', 'createBy', 'memo', 'rglarId', 'groupId', 'stockLevel']} + , 'createTime', 'createBy', 'memo', 'rglarId', 'groupId','statusBool', 'stockLeval$']} > {columns.map((column) => column)} </StyledDatagrid>} @@ -257,7 +270,6 @@ const MatnrList = () => { const translate = useTranslate(); - const [createDialog, setCreateDialog] = useState(false); const [drawerVal, setDrawerVal] = useState(false); const notify = useNotify(); @@ -335,7 +347,7 @@ ) } -const BatchButton = () => { +const BatchStatusButton = () => { const record = useRecordContext(); const notify = useNotify(); const refresh = useRefresh(); @@ -345,11 +357,105 @@ return ( <> - <Button onClick={() => setCreateDialog(true)} label={"toolbar.batch"}> + <Button onClick={() => setCreateDialog(true)} label={"toolbar.batchStatus"}> <EditIcon /> </Button> <BatchModal + open={createDialog} + setOpen={setCreateDialog} + fieldType={'status'} + /> + </> + + ) +} +const BatchLevelButton = () => { + const record = useRecordContext(); + const notify = useNotify(); + const refresh = useRefresh(); + + + const [createDialog, setCreateDialog] = useState(false); + + return ( + <> + <Button onClick={() => setCreateDialog(true)} label={"toolbar.batchStockLevel"}> + <EditIcon /> + </Button> + + <BatchModal + open={createDialog} + setOpen={setCreateDialog} + fieldType={'stockLevel'} + /> + </> + + ) +} + +const BatchWarnButton = () => { + const record = useRecordContext(); + const notify = useNotify(); + const refresh = useRefresh(); + + + const [createDialog, setCreateDialog] = useState(false); + + return ( + <> + <Button onClick={() => setCreateDialog(true)} label={"toolbar.batchValidWarn"}> + <EditIcon /> + </Button> + + <BatchModal + open={createDialog} + setOpen={setCreateDialog} + fieldType={'validWarn'} + /> + </> + + ) +} + +const BatchFlagButton = () => { + const record = useRecordContext(); + const notify = useNotify(); + const refresh = useRefresh(); + + const [createDialog, setCreateDialog] = useState(false); + + return ( + <> + <Button onClick={() => setCreateDialog(true)} label={"toolbar.batchFlagCheck"}> + <EditIcon /> + </Button> + + <BatchModal + open={createDialog} + setOpen={setCreateDialog} + fieldType={'flagCheck'} + /> + </> + + ) +} + +const BatchGroupButton = () => { + const record = useRecordContext(); + const notify = useNotify(); + const refresh = useRefresh(); + + + const [createDialog, setCreateDialog] = useState(false); + + return ( + <> + <Button onClick={() => setCreateDialog(true)} label={"toolbar.batchMatnrGropu"}> + <EditIcon /> + </Button> + + <BatchGropuModal open={createDialog} setOpen={setCreateDialog} /> @@ -358,8 +464,9 @@ ) } -const PrintButton = () => { +const BatchPrintButton = () => { const record = useRecordContext(); + const { resource, selectedIds } = useListContext(); const notify = useNotify(); const refresh = useRefresh(); @@ -374,6 +481,52 @@ <PrintModal open={createDialog} setOpen={setCreateDialog} + rows={selectedIds} + /> + </> + ) +} + +const PrintButton = () => { + const record = useRecordContext(); + + const notify = useNotify(); + const refresh = useRefresh(); + + const [createDialog, setCreateDialog] = useState(false); + + return ( + <> + <Button color="secondary" onClick={() => setCreateDialog(true)} label={"toolbar.print"}> + <PrintIcon /> + </Button> + + <PrintModal + open={createDialog} + setOpen={setCreateDialog} + rows={[record.id]} + /> + </> + ) +} + +const BindButton = () => { + const record = useRecordContext(); + const notify = useNotify(); + const refresh = useRefresh(); + + + const [createDialog, setCreateDialog] = useState(false); + + return ( + <> + <Button onClick={() => setCreateDialog(true)} label={"toolbar.bindloc"}> + <LinkIcon /> + </Button> + + <BindModal + open={createDialog} + setOpen={setCreateDialog} /> </> -- Gitblit v1.9.1