李林
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
/*
 *    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 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.chinaztt.mes.common.numgen.NumberGenerator;
import com.chinaztt.mes.warehouse.dto.PalletTransportsDTO;
import com.chinaztt.mes.warehouse.entity.PalletTransports;
import com.chinaztt.mes.warehouse.entity.PalletTransportsDetail;
import com.chinaztt.mes.warehouse.entity.PalletTransportsMaterial;
import com.chinaztt.mes.warehouse.entity.PalletTransportsOptask;
import com.chinaztt.mes.warehouse.mapper.PalletTransportsDetailMapper;
import com.chinaztt.mes.warehouse.mapper.PalletTransportsMapper;
import com.chinaztt.mes.warehouse.mapper.PalletTransportsMaterialMapper;
import com.chinaztt.mes.warehouse.mapper.PalletTransportsOptaskMapper;
import com.chinaztt.mes.warehouse.service.PalletTransportsService;
import com.chinaztt.mes.warehouse.state.constant.PalletTransportsState;
import com.chinaztt.mes.warehouse.state.pallettransportsdetail.PalletTransportsDetailStateStringValues;
import com.chinaztt.ztt.common.core.util.R;
import lombok.AllArgsConstructor;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
 
import java.math.BigDecimal;
import java.util.List;
 
/**
 * 货盘运输任务主表
 *
 * @author shz
 * @date 2022-05-24 17:17:26
 */
@Transactional(rollbackFor = Exception.class)
@Service
@AllArgsConstructor
public class PalletTransportsServiceImpl extends ServiceImpl<PalletTransportsMapper, PalletTransports> implements PalletTransportsService {
 
    private NumberGenerator<PalletTransports> numberGenerator;
    private PalletTransportsMaterialMapper palletTransportsMaterialMapper;
    private PalletTransportsOptaskMapper palletTransportsOptaskMapper;
    private PalletTransportsDetailMapper palletTransportsDetailMapper;
 
    @Override
    public IPage<PalletTransportsDTO> getPage(Page page, QueryWrapper<PalletTransportsDTO> gen) {
        return this.baseMapper.getPage(page, gen);
    }
 
    @Override
    public boolean fullSave(PalletTransports palletTransports) {
        palletTransports.setTransportsNo(numberGenerator.generateNumberWithPrefix(PalletTransports.DIGIT, PalletTransports.PREFIX, PalletTransports::getTransportsNo));
        return this.save(palletTransports);
    }
 
    @Override
    public PalletTransportsDTO getTransportsById(Long id) {
        return this.baseMapper.getTransportsById(id);
    }
 
    /**
     * 批量添加货盘运输物料需求
     *
     * @param palletTransportsMaterialList 货盘运输物料需求
     * @param ids                          工单id
     * @return
     */
    @Override
    public R batchSave(String ids, List<PalletTransportsMaterial> palletTransportsMaterialList) {
        try {
            PalletTransports palletTransports = new PalletTransports();
            palletTransports.setTransportsNo(numberGenerator.generateNumberWithPrefix(PalletTransports.DIGIT, PalletTransports.PREFIX, PalletTransports::getTransportsNo));
            baseMapper.insert(palletTransports);
            palletTransportsMaterialList.forEach(palletTransportsMaterial -> {
                //移库数量是0
                palletTransportsMaterial.setTransferQuantity(BigDecimal.ZERO);
                palletTransportsMaterial.setSurplusQuantity(palletTransportsMaterial.getDemandQuantity());
                palletTransportsMaterial.setTransportsId(palletTransports.getId());
                palletTransportsMaterialMapper.insert(palletTransportsMaterial);
            });
            String[] idsArray = ids.split("_");
            for (String id : idsArray) {
                PalletTransportsOptask palletTransportsOptask = new PalletTransportsOptask();
                palletTransportsOptask.setOperationTaskId(new Long(id));
                palletTransportsOptask.setTransportsId(palletTransports.getId());
                palletTransportsOptaskMapper.insert(palletTransportsOptask);
            }
            return R.ok();
        } catch (Exception e) {
            return R.failed("新增异常");
        }
    }
 
    @Override
    public boolean delAll(Long id) {
        List<PalletTransportsMaterial> materialList = palletTransportsMaterialMapper.selectList(Wrappers.<PalletTransportsMaterial>lambdaQuery().eq(PalletTransportsMaterial::getTransportsId, id));
        if(CollectionUtil.isNotEmpty(materialList)){
            throw new RuntimeException("有物料需求记录,无法删除");
        }
        baseMapper.deleteById(id);
        palletTransportsMaterialMapper.delete(Wrappers.<PalletTransportsMaterial>lambdaQuery().eq(PalletTransportsMaterial::getTransportsId, id));
        palletTransportsOptaskMapper.delete(Wrappers.<PalletTransportsOptask>lambdaQuery().eq(PalletTransportsOptask::getTransportsId, id));
        return true;
    }
}