李林
2023-10-07 658d4927d468c47208fd012d9128b09249c07eff
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
package com.chinaztt.mes.warehouse.service.impl;
 
import cn.hutool.core.collection.CollectionUtil;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.baomidou.mybatisplus.extension.toolkit.SqlHelper;
import com.chinaztt.mes.basic.entity.Part;
import com.chinaztt.mes.basic.mapper.PartMapper;
import com.chinaztt.mes.warehouse.dto.DeliveryDetailDTO;
import com.chinaztt.mes.warehouse.entity.DeliveryDetail;
import com.chinaztt.mes.warehouse.mapper.DeliveryDetailMapper;
import com.chinaztt.mes.warehouse.service.DeliveryDetailService;
import com.chinaztt.ztt.common.core.util.R;
import lombok.AllArgsConstructor;
import org.springframework.security.core.parameters.P;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
 
import java.math.BigDecimal;
import java.util.List;
 
/**
 * 送货清单表
 *
 * @author cxf
 * @date 2020-10-12 14:11:40
 */
@Service
@AllArgsConstructor
@Transactional(rollbackFor = Exception.class)
public class DeliveryDetailServiceImpl extends ServiceImpl<DeliveryDetailMapper, DeliveryDetail> implements DeliveryDetailService {
    private PartMapper partMapper;
    @Override
    public IPage<List<DeliveryDetailDTO>> getDeliveryDetailPage(Page page, QueryWrapper<DeliveryDetailDTO> gen) {
        return baseMapper.getDeliveryDetailPage(page, gen);
    }
 
    @Override
    public DeliveryDetailDTO getDeliveryDetailById(Long id) {
        return baseMapper.getDeliveryDetailById(id);
    }
 
    @Override
    public boolean deleteById(Long id) {
        DeliveryDetail deliveryDetail = baseMapper.selectById(id);
        if (deliveryDetail.getReceiveQty() != null && deliveryDetail.getReceiveQty().compareTo(BigDecimal.ZERO) == 1) {
            throw new RuntimeException("已收料,无法删除");
        }
        return SqlHelper.retBool(baseMapper.deleteById(id));
    }
 
    @Override
    public List<DeliveryDetail> auditDeliveryDetail(Long mainId) {
        //接收数量的过滤
        List<DeliveryDetail> deliveryDetail = baseMapper.auditDelivery(mainId);
        if (CollectionUtil.isNotEmpty(deliveryDetail)) {
            StringBuilder string = new StringBuilder();
            for (int i = 0; i<deliveryDetail.size(); i++) {
                Part part = new Part();
                part = partMapper.selectById(deliveryDetail.get(i).getPartId());
                string.append(part.getPartNo());
                string.append(",");
            }
            string.deleteCharAt(string.length()-1);
            throw new RuntimeException("请确认收料,"+string+"在收料明细中不存在");
        }
        //差异数量的过滤
        List<DeliveryDetail> deliveryDetailList = baseMapper.auditDeliveryDetail(mainId);
        return deliveryDetailList;
    }
 
    @Override
    public boolean save(DeliveryDetail deliveryDetail) {
        List<DeliveryDetail> list = baseMapper.selectList(Wrappers.<DeliveryDetail>query().lambda().eq(DeliveryDetail::getReceivingMainId, deliveryDetail.getReceivingMainId())
                .eq(DeliveryDetail::getPartId, deliveryDetail.getPartId()).eq(DeliveryDetail::getPartBatchNo, deliveryDetail.getPartBatchNo()));
        if (CollectionUtil.isNotEmpty(list)) {
            throw new RuntimeException("零件已存在,请勿重复添加");
        }
        return SqlHelper.retBool(baseMapper.insert(deliveryDetail));
    }
 
    @Override
    public boolean updateById(DeliveryDetail deliveryDetail) {
        if (deliveryDetail.getReceiveQty() != null) {
            deliveryDetail.setDifferenceQty(deliveryDetail.getDeliveryQty().subtract(deliveryDetail.getReceiveQty()));
        }
        return SqlHelper.retBool(baseMapper.updateById(deliveryDetail));
    }
}