| | |
| | | type: "string", |
| | | width: 160, |
| | | align: "left", |
| | | formatter: (row) => { |
| | | const materialNos = row.materialNos; |
| | | if (!materialNos) return materialNos; |
| | | |
| | | // æå»ºç©æç¼ºæç¶ææ å° |
| | | const lackStatusMap = new Map(); |
| | | |
| | | // 注æï¼å段åå·²ç»è¢«è½¬æ¢ä¸ºé©¼å³°å½åæ³ |
| | | const statusField = row.materialLackStatus; |
| | | if (statusField) { |
| | | const statusPairs = statusField.split(','); |
| | | statusPairs.forEach(pair => { |
| | | const [materialNo, isLack] = pair.split(':'); |
| | | lackStatusMap.set(materialNo.trim(), isLack.trim() === 'true'); |
| | | }); |
| | | } |
| | | |
| | | // å¤çç©æç¼å·ï¼æ ¹æ®ç¶æè®¾ç½®é¢è² |
| | | const materialList = materialNos.split('/'); |
| | | const formattedMaterials = materialList.map(materialNo => { |
| | | const trimmedMaterialNo = materialNo.trim(); |
| | | const isLack = lackStatusMap.get(trimmedMaterialNo) || false; |
| | | if (isLack) { |
| | | return `<span style="color: red;">${trimmedMaterialNo}</span>`; |
| | | } |
| | | return trimmedMaterialNo; |
| | | }); |
| | | |
| | | return formattedMaterials.join('/'); |
| | | } |
| | | }, |
| | | { |
| | | field: "materialWides", |
| | |
| | | type: "string", |
| | | width: 100, |
| | | align: "left", |
| | | formatter: (row) => { |
| | | const value = row.materialWides; |
| | | if (value && typeof value === 'string') { |
| | | return value.replace(/\.\d+$/, ''); |
| | | } |
| | | return value; |
| | | } |
| | | }, |
| | | { |
| | | field: "isLackMaterial", |
| | |
| | | align: "left", |
| | | edit: { type: "string" }, |
| | | required: true, |
| | | |
| | | }, |
| | | { |
| | | field: "xqLen", |