Blame view

src/main/java/com/huaheng/pc/receipt/receiptContainerDetail/service/ReceiptContainerDetailServiceImpl.java 20.4 KB
1
2
package com.huaheng.pc.receipt.receiptContainerDetail.service;
3
4
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
5
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
周鸿 authored
6
import com.huaheng.common.utils.Wrappers;
7
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
pengcheng authored
8
import com.huaheng.common.constant.QuantityConstant;
mahuandong authored
9
import com.huaheng.common.exception.service.ServiceException;
游杰 authored
10
import com.huaheng.common.utils.StringUtils;
11
import com.huaheng.common.utils.http.HttpUtils;
12
13
import com.huaheng.common.utils.security.ShiroUtils;
import com.huaheng.framework.web.domain.AjaxResult;
mahuandong authored
14
import com.huaheng.mobile.receipt.ReceiptBill;
15
16
import com.huaheng.pc.config.address.domain.Address;
import com.huaheng.pc.config.address.service.AddressService;
xumiao authored
17
18
import com.huaheng.pc.config.container.domain.Container;
import com.huaheng.pc.config.container.service.ContainerService;
游杰 authored
19
import com.huaheng.pc.config.location.service.LocationService;
mahuandong authored
20
21
import com.huaheng.pc.config.material.domain.Material;
import com.huaheng.pc.config.material.service.MaterialService;
huhai authored
22
23
24
25
import com.huaheng.common.constant.QuantityConstant;
import com.huaheng.common.exception.service.ServiceException;
import com.huaheng.common.utils.security.ShiroUtils;
import com.huaheng.framework.web.domain.AjaxResult;
xumiao authored
26
27
28
29
30
import com.huaheng.pc.inventory.inventoryClear.domain.InventorySearch;
import com.huaheng.pc.inventory.inventoryDetail.domain.InventoryDetail;
import com.huaheng.pc.inventory.inventoryDetail.service.InventoryDetailService;
import com.huaheng.pc.inventory.inventoryTransaction.domain.InventoryTransaction;
import com.huaheng.pc.inventory.inventoryTransaction.service.InventoryTransactionService;
31
32
import com.huaheng.pc.receipt.receiptContainerDetail.domain.ReceiptContainerDetail;
import com.huaheng.pc.receipt.receiptContainerDetail.mapper.ReceiptContainerDetailMapper;
33
import com.huaheng.pc.receipt.receiptContainerHeader.domain.ReceiptContainerHeader;
xumiao authored
34
import com.huaheng.pc.receipt.receiptContainerHeader.domain.ReceiptContainerView;
35
import com.huaheng.pc.receipt.receiptContainerHeader.service.ReceiptContainerHeaderService;
mahuandong authored
36
37
38
39
import com.huaheng.pc.receipt.receiptDetail.domain.ReceiptDetail;
import com.huaheng.pc.receipt.receiptDetail.service.ReceiptDetailService;
import com.huaheng.pc.receipt.receiptHeader.domain.ReceiptHeader;
import com.huaheng.pc.receipt.receiptHeader.service.ReceiptHeaderService;
xumiao authored
40
41
import com.huaheng.pc.system.role.domain.Role;
import com.huaheng.pc.system.user.domain.User;
42
import org.springframework.stereotype.Service;
xumiao authored
43
import org.springframework.ui.ModelMap;
44
import org.springframework.web.bind.annotation.ResponseBody;
45
mahuandong authored
46
import javax.annotation.Resource;
mahuandong authored
47
import java.util.ArrayList;
mahuandong authored
48
49
import java.util.List;
import java.util.Map;
huhai authored
50
51
52
53
54
55
56
57
58
59
import com.huaheng.pc.receipt.receiptContainerHeader.domain.ReceiptContainerHeader;
import com.huaheng.pc.receipt.receiptContainerHeader.service.ReceiptContainerHeaderService;
import com.huaheng.pc.receipt.receiptDetail.domain.ReceiptDetail;
import com.huaheng.pc.receipt.receiptDetail.service.ReceiptDetailService;
import com.huaheng.pc.receipt.receiptHeader.domain.ReceiptHeader;
import com.huaheng.pc.receipt.receiptHeader.service.ReceiptHeaderService;
import org.springframework.stereotype.Service;
import org.springframework.web.bind.annotation.ResponseBody;

import javax.annotation.Resource;
60
61
import java.util.List;
import java.util.Map;
62
63
64
@Service
public class ReceiptContainerDetailServiceImpl extends ServiceImpl<ReceiptContainerDetailMapper, ReceiptContainerDetail> implements ReceiptContainerDetailService{
mahuandong authored
65
66
67
68
    @Resource
    private ReceiptDetailService receiptDetailService;
    @Resource
    private ReceiptHeaderService receiptHeaderService;
69
70
    @Resource
    private ReceiptContainerHeaderService receiptContainerHeaderService;
mahuandong authored
71
72
    @Resource
    private MaterialService materialService;
游杰 authored
73
74
    @Resource
    private LocationService locationService;
75
76
    @Resource
    private AddressService addressService;
xumiao authored
77
78
    @Resource
    private ReceiptContainerDetailMapper receiptContainerDetailMapper;
xumiao authored
79
80
81
82
83
84
    @Resource
    private ContainerService containerService;
    @Resource
    private InventoryDetailService inventoryDetailService;
    @Resource
    private InventoryTransactionService inventoryTransactionService;
mahuandong authored
85
86
    /**
     * 根据入库单编码查询入库组盘明细
mahuandong authored
87
88
     * @param receiptCode 入库单编码
     * @return AjaxResult
mahuandong authored
89
     */
90
91
92
93
94
95
96
97
98
99
    @Override
    public AjaxResult<List<Map<String, Object>>> getReceiptInfoByBill(String receiptCode) {
        LambdaQueryWrapper<ReceiptContainerDetail> lambdaQueryWrapper = Wrappers.lambdaQuery();
        lambdaQueryWrapper.eq(ReceiptContainerDetail::getReceiptCode, receiptCode)
                .eq(ReceiptContainerDetail::getWarehouseCode, ShiroUtils.getWarehouseCode());

        List<Map<String, Object>> detail = this.listMaps(lambdaQueryWrapper);
        return AjaxResult.success(detail);
    }
mahuandong authored
100
101
102
103
104
105
106
107
108
109
    /**
     * 撤销入库组盘明细
     * @param idList
     * @return
     */
    @Override
    public Boolean detailRemove(List<Integer> idList) {
        for (Integer id : idList){
            ReceiptContainerDetail receiptContainerDetail = this.getById(id);
            //如果已生成任务不允许撤销
pengcheng authored
110
            if (receiptContainerDetail.getStatus() < QuantityConstant.RECEIPT_CONTAINER_TASK){
mahuandong authored
111
112
                //回滚入库单明细收货数量
                ReceiptDetail receiptDetail = receiptDetailService.getById(receiptContainerDetail.getReceiptDetailId());
肖超群 authored
113
                receiptDetail.setTaskQty(receiptDetail.getTaskQty().subtract(receiptContainerDetail.getQty()));
mahuandong authored
114
115
116
117
                //如果为临时容器,则删除
                receiptContainerDetail.getContainerCode();
118
119
120
121
122
123
124
                if (!receiptDetailService.updateById(receiptDetail)){throw new SecurityException("回滚入库单明细失败");}
                //删除组盘明细
                if (!this.removeById(id)){ throw new ServiceException("回滚入库组盘失败");}
                LambdaQueryWrapper<ReceiptContainerDetail> lambdaQueryWrapper = Wrappers.lambdaQuery();
                lambdaQueryWrapper.eq(ReceiptContainerDetail::getReceiptContainerId, receiptContainerDetail.getReceiptContainerId());
                List<ReceiptContainerDetail> list = this.list(lambdaQueryWrapper);
                if (list.size() == 0){
游杰 authored
125
126
                    String locationCode = receiptContainerDetail.getLocationCode();
                    if(StringUtils.isNotEmpty(locationCode)) {
游杰 authored
127
                        locationService.updateStatus(locationCode, QuantityConstant.STATUS_LOCATION_EMPTY);
游杰 authored
128
                    }
129
130
131
132
                    if (!receiptContainerHeaderService.removeById(receiptContainerDetail.getReceiptContainerId())){
                        throw new ServiceException("删除入库组盘头失败");
                    }
                }
133
mahuandong authored
134
135
136
137
                //查询入库头表
                LambdaQueryWrapper<ReceiptContainerDetail> containerDetailLambda = Wrappers.lambdaQuery();
                containerDetailLambda.eq(ReceiptContainerDetail::getReceiptId, receiptContainerDetail.getReceiptId());
                List<ReceiptContainerDetail> containerDetailList = this.list(containerDetailLambda);
138
139
mahuandong authored
140
                //如果入库组盘没有该入库单的组盘信息,回滚入库单状态
141
                if (containerDetailList.size() == 0){
mahuandong authored
142
143
                    ReceiptHeader receiptHeader = new ReceiptHeader();
                    receiptHeader.setId(receiptContainerDetail.getReceiptId());
pengcheng authored
144
145
                    receiptHeader.setFirstStatus(QuantityConstant.RECEIPT_HEADER_RECEIVING);
                    receiptHeader.setLastStatus(QuantityConstant.RECEIPT_HEADER_RECEIVING);
mahuandong authored
146
147
148
149
150
151
152
153
154
155
156
157
                    receiptHeader.setLastUpdatedBy(ShiroUtils.getLoginName());

                    if (!receiptHeaderService.updateById(receiptHeader)){ throw new ServiceException("回滚头表状态失败"); }
                }

            } else {
                throw new SecurityException("已生成任务,不允许取消");
            }
        }
        return true;
    }
158
mahuandong authored
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
//    /**
//     * 移动端收货
//     *
//     * @param code
//     * @return
//     */
//    @Override
//    public AjaxResult scanReceiptCode(String code) {
//        LambdaQueryWrapper<ReceiptDetail> lambdaQueryWrapper = Wrappers.lambdaQuery();
//        lambdaQueryWrapper.eq(ReceiptDetail::getReceiptCode, code);
//        List<ReceiptDetail> receiptContainerDetails = list(lambdaQueryWrapper);
//        return AjaxResult.success(receiptContainerDetails);
//    }

    /**保存到组盘详细*/
mahuandong authored
174
    @Override
mahuandong authored
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
    public List<Integer> insertTodayReceiptcContainerDetail(int headerId, int receiptId, List<Integer> receiptDetailId, List<ReceiptBill> receiptBills) {
        List<Integer> mReceiptContainerIds = new ArrayList<>();

        ReceiptHeader receiptHeader = receiptHeaderService.getById(receiptId);
        if(receiptHeader == null) {
            throw new ServiceException("没有找到入库单表头!");
        }
        for(int i=0; i<receiptBills.size(); i++) {
            ReceiptBill receiptBill = receiptBills.get(i);
            Material condition2 = new Material();
            condition2.setCode(receiptBill.getMaterialCode());
            condition2.setWarehouseCode(ShiroUtils.getWarehouseCode());
            condition2.setDeleted(false);
            condition2.setEnable(true);
            LambdaQueryWrapper<Material> lambdaQueryWrapper = Wrappers.lambdaQuery();
            lambdaQueryWrapper.eq(Material::getCode, receiptBill.getMaterialCode())
                    .eq(Material::getWarehouseCode, ShiroUtils.getWarehouseCode());
            Material material = materialService.getOne(lambdaQueryWrapper);
            ReceiptContainerDetail record = new ReceiptContainerDetail();
            record.setReceiptContainerId(headerId);
            record.setReceiptCode(receiptHeader.getCode());
            record.setReceiptId(receiptId);
            record.setReceiptDetailId(receiptDetailId.get(i));
            record.setMaterialCode(receiptBill.getMaterialCode());
            record.setMaterialName(material.getName());
            record.setMaterialSpec(material.getSpec());
xumiao authored
201
            record.setWarehouseCode(ShiroUtils.getWarehouseCode());
202
            record.setInventorySts("good");
mahuandong authored
203
            record.setQty(receiptBill.getQty());
204
            record.setContainerCode(receiptBills.get(0).getReceiptContainerCode());
mahuandong authored
205
206
207
208
            if(receiptBill.getWeight() != null) {
                record.setWeight(receiptBill.getWeight());
            }
            record.setCreatedBy(ShiroUtils.getLoginName());
209
            record.setLastUpdatedBy(ShiroUtils.getLoginName());
mahuandong authored
210
211
212
213
214
215
216
217
218
219
220
221
222

            LambdaQueryWrapper<ReceiptContainerDetail> detailyWrapper = Wrappers.lambdaQuery();
            detailyWrapper.eq(ReceiptContainerDetail::getReceiptContainerId, headerId)
                    .eq(ReceiptContainerDetail::getReceiptCode, receiptHeader.getCode());
            ReceiptContainerDetail receiptContainerDetail = getOne(detailyWrapper);
            if(receiptContainerDetail == null) {
                save(record);
                mReceiptContainerIds.add(record.getId());
            } else {
                mReceiptContainerIds.add(receiptContainerDetail.getId());
            }
        }
        return mReceiptContainerIds;
mahuandong authored
223
    }
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249

    @Override
    public void autoSendMmsByReceiptContainer(ReceiptContainerDetail receiptContainerDetail){
        //调用mms更改采购状态
        Address address = addressService.getAddressByUrl(QuantityConstant.ADDRESS_MMS,receiptContainerDetail.getWarehouseCode());
        try{
            String url=address.getUrl();
            JSONObject json=new JSONObject();
            json.put("code",receiptContainerDetail.getReceiptCode().trim());
            json.put("materialCode",receiptContainerDetail.getMaterialCode().trim());
            json.put("status","2");
            json.put("inQty",receiptContainerDetail.getQty());
            String workNo=receiptDetailService.getWorkNo(receiptContainerDetail.getReceiptDetailId());
            json.put("workNo",workNo);
            String JsonParam = JSON.toJSONString(json);
            String result2 = HttpUtils.bodypost(url, JsonParam,receiptContainerDetail.getWarehouseCode());
            if(result2!=null){
                receiptContainerDetail.setSyncMms(2);
            }else{
                receiptContainerDetail.setSyncMmsNum(receiptContainerDetail.getSyncMmsNum()+1);
            }
            this.updateById(receiptContainerDetail);
        }catch(Exception e) {
            e.printStackTrace();
        }
    }
250
251
252
253
254
255
256
257
    @Override
    public List<ReceiptContainerDetail> getReceiptContainerDetailByHeaderId(int receiptContainerHeaderId){
        //查询入库组盘明细
        LambdaQueryWrapper<ReceiptContainerDetail> containerDetailLambda = Wrappers.lambdaQuery();
        containerDetailLambda.eq(ReceiptContainerDetail::getReceiptContainerId, receiptContainerHeaderId);
        List<ReceiptContainerDetail> list = this.list(containerDetailLambda);
        return list;
    }
周鸿 authored
258
259
260
261
262
263
264
265
    @Override
    public ReceiptContainerDetail selectFirstEntity(ReceiptContainerDetail domain){
        LambdaQueryWrapper<ReceiptContainerDetail> containerDetailLambda = Wrappers.lambdaQuery();
        containerDetailLambda.eq(StringUtils.isNotNull(domain.getReceiptContainerId()),ReceiptContainerDetail::getReceiptContainerId, domain.getReceiptContainerId());
        containerDetailLambda.eq(StringUtils.isNotNull(domain.getReceiptDetailId()),ReceiptContainerDetail::getReceiptDetailId, domain.getReceiptDetailId());
        containerDetailLambda.last("limit 1");
        return  this.getOne(containerDetailLambda);
    }
xumiao authored
266
267
268
269
270

    @Override
    public List<ReceiptContainerView> selectOfView(ReceiptContainerView receiptContainerView) {
        return receiptContainerDetailMapper.selectOfView(receiptContainerView);
    }
xumiao authored
271
272
273
274
275
276

    @Override
    public AjaxResult getReceiptInfoByBillKS(String code,Integer id) {
        //找到主单的账套和u8仓库
        ReceiptHeader receiptHeader=new ReceiptHeader();
        receiptHeader.setCode(code);
277
        receiptHeader.setWarehouseCode(ShiroUtils.getWarehouseCode());
xumiao authored
278
279
280
281
282
283
284
285
286
287
288
289
290
291
        receiptHeader=receiptHeaderService.selectFirstEntity(receiptHeader);
        if(receiptHeader==null){
            throw new ServiceException("找不到主单");
        }
        //找到子单物料
        ReceiptDetail receiptDetail = receiptDetailService.getOne(new LambdaQueryWrapper<ReceiptDetail>().eq(ReceiptDetail::getId, id).eq(ReceiptDetail::getReceiptCode, code));
        if(receiptDetail==null){
            throw new ServiceException("找不到子单");
        }
        LambdaQueryWrapper<InventoryDetail> inventoryDetailLambdaQueryWrapper=Wrappers.lambdaQuery();
        inventoryDetailLambdaQueryWrapper.eq(InventoryDetail::getWarehouseCode,receiptHeader.getWarehouseCode());
        inventoryDetailLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getCompanyCode())),InventoryDetail::getCompanyCode,receiptHeader.getCompanyCode());
        inventoryDetailLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getUWarehouseCode())),InventoryDetail::getUWarehouseCode,receiptHeader.getUWarehouseCode());
        inventoryDetailLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptDetail.getMaterialCode())),InventoryDetail::getMaterialCode,receiptDetail.getMaterialCode());
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
        List<InventoryDetail> list = inventoryDetailService.list(inventoryDetailLambdaQueryWrapper);

        LambdaQueryWrapper<InventoryTransaction> inventoryTransactionLambdaQueryWrapper=Wrappers.lambdaQuery();
        inventoryTransactionLambdaQueryWrapper.eq(InventoryTransaction::getWarehouseCode,receiptHeader.getWarehouseCode());
        inventoryTransactionLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getCompanyCode())),InventoryTransaction::getCompanyCode,receiptHeader.getCompanyCode());
        inventoryTransactionLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getUWarehouseCode())),InventoryTransaction::getUWarehouseCode,receiptHeader.getUWarehouseCode());
        inventoryTransactionLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptDetail.getMaterialCode())),InventoryTransaction::getMaterialCode,receiptDetail.getMaterialCode());
        List<InventoryTransaction> transactionList = inventoryTransactionService.list(inventoryTransactionLambdaQueryWrapper);

        LambdaQueryWrapper<Container> lambdaQueryWrapper=Wrappers.lambdaQuery();
        lambdaQueryWrapper.eq(Container::getWarehouseCode,receiptHeader.getWarehouseCode());
        lambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getCompanyCode())),Container::getCompanyCode,receiptHeader.getCompanyCode());
        lambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getUWarehouseCode())),Container::getUWarehouseCode,receiptHeader.getUWarehouseCode());
//        lambdaQueryWrapper.eq(Container::getStatus,QuantityConstant.STATUS_CONTAINER_EMPTY);
        lambdaQueryWrapper.last("and containerType in ('X','D')");
        List<Container> containers = containerService.list(lambdaQueryWrapper);

        Map map=new ModelMap();
        map.put("list",list);
        map.put("transactionList",transactionList);
        map.put("containers",containers);

        return AjaxResult.success(map);
    }

    @Override
    public AjaxResult getReceiptInfoByReferBillKS(String code, Integer id) {
        //找到主单的账套和u8仓库
        ReceiptHeader receiptHeader=new ReceiptHeader();
        receiptHeader.setReferCode(code);
        receiptHeader.setWarehouseCode(ShiroUtils.getWarehouseCode());
        receiptHeader=receiptHeaderService.selectFirstEntity(receiptHeader);
        if(receiptHeader==null){
            throw new ServiceException("找不到主单");
        }
        //找到子单物料
        ReceiptDetail receiptDetail = receiptDetailService.getOne(new LambdaQueryWrapper<ReceiptDetail>().eq(ReceiptDetail::getId, id).eq(ReceiptDetail::getReferCode, code));
        if(receiptDetail==null){
            throw new ServiceException("找不到子单");
        }
        LambdaQueryWrapper<InventoryDetail> inventoryDetailLambdaQueryWrapper=Wrappers.lambdaQuery();
        inventoryDetailLambdaQueryWrapper.eq(InventoryDetail::getWarehouseCode,receiptHeader.getWarehouseCode());
        inventoryDetailLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getCompanyCode())),InventoryDetail::getCompanyCode,receiptHeader.getCompanyCode());
        inventoryDetailLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getUWarehouseCode())),InventoryDetail::getUWarehouseCode,receiptHeader.getUWarehouseCode());
        inventoryDetailLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptDetail.getMaterialCode())),InventoryDetail::getMaterialCode,receiptDetail.getMaterialCode());
xumiao authored
337
338
339
340
341
342
343
344
345
346
347
348
349
        List<InventoryDetail> list = inventoryDetailService.list(inventoryDetailLambdaQueryWrapper);

        LambdaQueryWrapper<InventoryTransaction> inventoryTransactionLambdaQueryWrapper=Wrappers.lambdaQuery();
        inventoryTransactionLambdaQueryWrapper.eq(InventoryTransaction::getWarehouseCode,receiptHeader.getWarehouseCode());
        inventoryTransactionLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getCompanyCode())),InventoryTransaction::getCompanyCode,receiptHeader.getCompanyCode());
        inventoryTransactionLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getUWarehouseCode())),InventoryTransaction::getUWarehouseCode,receiptHeader.getUWarehouseCode());
        inventoryTransactionLambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptDetail.getMaterialCode())),InventoryTransaction::getMaterialCode,receiptDetail.getMaterialCode());
        List<InventoryTransaction> transactionList = inventoryTransactionService.list(inventoryTransactionLambdaQueryWrapper);

        LambdaQueryWrapper<Container> lambdaQueryWrapper=Wrappers.lambdaQuery();
        lambdaQueryWrapper.eq(Container::getWarehouseCode,receiptHeader.getWarehouseCode());
        lambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getCompanyCode())),Container::getCompanyCode,receiptHeader.getCompanyCode());
        lambdaQueryWrapper.eq((StringUtils.isNotEmpty(receiptHeader.getUWarehouseCode())),Container::getUWarehouseCode,receiptHeader.getUWarehouseCode());
350
//        lambdaQueryWrapper.eq(Container::getStatus,QuantityConstant.STATUS_CONTAINER_EMPTY);
xumiao authored
351
352
353
354
355
356
357
358
359
360
        lambdaQueryWrapper.last("and containerType in ('X','D')");
        List<Container> containers = containerService.list(lambdaQueryWrapper);

        Map map=new ModelMap();
        map.put("list",list);
        map.put("transactionList",transactionList);
        map.put("containers",containers);

        return AjaxResult.success(map);
    }
361
}