李林
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
/*
 *    Copyright (c) 2018-2025, ztt All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * Redistributions of source code must retain the above copyright notice,
 * this list of conditions and the following disclaimer.
 * Redistributions in binary form must reproduce the above copyright
 * notice, this list of conditions and the following disclaimer in the
 * documentation and/or other materials provided with the distribution.
 * Neither the name of the pig4cloud.com developer nor the names of its
 * contributors may be used to endorse or promote products derived from
 * this software without specific prior written permission.
 * Author: ztt
 */
package com.chinaztt.mes.warehouse.service.impl;
 
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.chinaztt.mes.basic.entity.Location;
import com.chinaztt.mes.basic.entity.Part;
import com.chinaztt.mes.basic.mapper.LocationMapper;
import com.chinaztt.mes.basic.mapper.PartMapper;
import com.chinaztt.mes.warehouse.dto.CheckDetailDTO;
import com.chinaztt.mes.warehouse.entity.CheckDetail;
import com.chinaztt.mes.warehouse.entity.CheckDiffAdjDetail;
import com.chinaztt.mes.warehouse.entity.CheckMain;
import com.chinaztt.mes.warehouse.mapper.CheckDetailMapper;
import com.chinaztt.mes.warehouse.mapper.CheckDiffAdjDetailMapper;
import com.chinaztt.mes.warehouse.mapper.CheckMainMapper;
import com.chinaztt.mes.warehouse.service.CheckDetailService;
import com.chinaztt.ztt.common.core.util.R;
import lombok.AllArgsConstructor;
import org.springframework.stereotype.Service;
 
import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.util.List;
 
/**
 * 盘点明细表
 *
 * @author sunxl
 * @date 2020-12-01 13:42:14
 */
@AllArgsConstructor
@Service
public class CheckDetailServiceImpl extends ServiceImpl<CheckDetailMapper, CheckDetail> implements CheckDetailService {
              private CheckDiffAdjDetailMapper checkDiffAdjDetailMapper;
              private CheckMainMapper checkMainMapper;
              private PartMapper partMapper;
              private LocationMapper locationMapper;
    @Override
    public IPage<List<CheckDetailDTO>> getCheckDetailPage(Page page, QueryWrapper<CheckDetailDTO> gen) {
        return baseMapper.getCheckDetailPage(page,gen);
    }
 
    @Override
    public CheckDetailDTO getCheckDetailById(Long id) {
        return baseMapper.getCheckDetailById(id);
    }
 
    @Override
    public R<CheckDetail> findCheckDetailByNo(CheckDetailDTO checkDetailDTO) {
        if (checkDetailDTO.getChkNo()==null){
            return R.failed("盘点编号为空,请选择盘点编号");
        }
        if (checkDetailDTO.getPartNo()==null){
            return    R.failed("盘点编号为空,请选择盘点编号");
        }
        if (checkDetailDTO.getLocNo()==null){
            return    R.failed("盘点库位号为空,请选择盘点库位号");
        }
        if (checkDetailDTO.getPartBatchNo()==null){
            return    R.failed("盘点零件批次号为空,请选择盘点零件批次号");
        }
        CheckDetailDTO checkDetail = baseMapper.getCheckDetailByNo(checkDetailDTO);
        if (checkDetail == null){
            return    R.failed("查询的盘点零件不存在");
        }
        return R.ok(checkDetail);
    }
 
    @Override
    public R pdaCheckDetailSave(CheckDetailDTO checkDetailDTO) {
            CheckDetailDTO newCheckDetailDTO = baseMapper.getCheckDetailByNo(checkDetailDTO);
            if (newCheckDetailDTO == null) {
                return R.failed("找不到对应的库存明细,请重新选择");
            }
            newCheckDetailDTO.setChkQty(checkDetailDTO.getChkQty());
            newCheckDetailDTO.setChkDiffQty(checkDetailDTO.getChkQty().subtract(newCheckDetailDTO.getLocQty()));
            if (newCheckDetailDTO.getLocQty().subtract(checkDetailDTO.getChkQty()).compareTo(BigDecimal.ZERO) == 0) {
                newCheckDetailDTO.setStatus("一致");
            }
            if (newCheckDetailDTO.getLocQty().subtract(checkDetailDTO.getChkQty()).compareTo(BigDecimal.ZERO) == 1) {
                newCheckDetailDTO.setStatus("盘亏");
            }
            if (newCheckDetailDTO.getLocQty().subtract(checkDetailDTO.getChkQty()).compareTo(BigDecimal.ZERO) == -1) {
                newCheckDetailDTO.setStatus("盘盈");
            }
            return R.ok(baseMapper.updateById(newCheckDetailDTO));
    }
 
    @Override
    public IPage<List<CheckDetailDTO>> getCheckDetailByPage(Page page, QueryWrapper<CheckDetailDTO> gen) {
        return baseMapper.getCheckDetailByPage(page,gen);
    }
 
    @Override
    public boolean fullSave(CheckDiffAdjDetail checkDiffAdjDetail) {
        CheckDiffAdjDetail checkDiffAdjDetail1 = checkDiffAdjDetailMapper.selectOne(Wrappers.<CheckDiffAdjDetail>lambdaQuery().eq(CheckDiffAdjDetail::getCheckDetailId,checkDiffAdjDetail.getCheckDetailId()));
        if (checkDiffAdjDetail1!=null){
            throw new RuntimeException("请不要重复保存");
        }
        CheckDetail checkDetail =baseMapper.selectOne(Wrappers.<CheckDetail>lambdaQuery().eq(CheckDetail::getId,checkDiffAdjDetail.getCheckDetailId()));
        CheckMain checkMain = checkMainMapper.selectOne(Wrappers.<CheckMain>lambdaQuery().eq(CheckMain::getId,checkDetail.getWarehouseCheckId()));
        if (checkDetail.getChkDiffQty().compareTo(checkDiffAdjDetail.getAdjQty())!=0){
            throw new RuntimeException("请重新确认调整数量,与差异数量不匹配");
        }
        checkDiffAdjDetail.setChkNo(checkMain.getChkNo());
        checkDiffAdjDetail.setAdjTime(LocalDateTime.now());
        checkDiffAdjDetailMapper.insert(checkDiffAdjDetail);
        return false;
    }
 
    @Override
    public IPage<List<CheckDiffAdjDetail>> getCheckDiffAdjDetailPage(Page page, QueryWrapper<CheckDiffAdjDetail> gen, Long id) {
        return checkDiffAdjDetailMapper.getCheckDiffAdjDetailPage(page,gen,id);
    }
}