From a1a7c03eae40f4b0344fce652e1a240cf5283624 Mon Sep 17 00:00:00 2001
From: Junjie <540245094@qq.com>
Date: 星期五, 13 九月 2024 16:37:42 +0800
Subject: [PATCH] #合并订单出库,统一转波次出库前最新代码

---
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/controller/LocDetlController.java |  125 ++++++++++++++++++++++++++++++++++++++---
 1 files changed, 115 insertions(+), 10 deletions(-)

diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/controller/LocDetlController.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/controller/LocDetlController.java
index 696873e..3549007 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/controller/LocDetlController.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/controller/LocDetlController.java
@@ -1,14 +1,22 @@
 package com.zy.asrs.wms.asrs.controller;
 
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.parser.Feature;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.zy.asrs.framework.common.Cools;
 import com.zy.asrs.framework.common.R;
+import com.zy.asrs.wms.asrs.entity.*;
+import com.zy.asrs.wms.asrs.entity.enums.LocStsType;
+import com.zy.asrs.wms.asrs.mapper.LocDetlMapper;
+import com.zy.asrs.wms.asrs.service.LocDetlFieldService;
+import com.zy.asrs.wms.asrs.service.LocService;
+import com.zy.asrs.wms.asrs.service.MatFieldService;
 import com.zy.asrs.wms.common.annotation.OperationLog;
 import com.zy.asrs.wms.common.domain.BaseParam;
 import com.zy.asrs.wms.common.domain.KeyValVo;
 import com.zy.asrs.wms.common.domain.PageParam;
-import com.zy.asrs.wms.asrs.entity.LocDetl;
 import com.zy.asrs.wms.asrs.service.LocDetlService;
 import com.zy.asrs.wms.system.controller.BaseController;
 import com.zy.asrs.wms.utils.ExcelUtil;
@@ -17,30 +25,79 @@
 import org.springframework.web.bind.annotation.*;
 
 import javax.servlet.http.HttpServletResponse;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 
 @RestController
 @RequestMapping("/api")
 public class LocDetlController extends BaseController {
 
     @Autowired
+    private LocService locService;
+    @Autowired
     private LocDetlService locDetlService;
+    @Autowired
+    private MatFieldService matFieldService;
+    @Autowired
+    private LocDetlFieldService locDetlFieldService;
 
     @PreAuthorize("hasAuthority('asrs:locDetl:list')")
     @PostMapping("/locDetl/page")
     public R page(@RequestBody Map<String, Object> map) {
         BaseParam baseParam = buildParam(map, BaseParam.class);
-        PageParam<LocDetl, BaseParam> pageParam = new PageParam<>(baseParam, LocDetl.class);
-        return R.ok().add(locDetlService.page(pageParam, pageParam.buildWrapper(true)));
+        PageParam<ViewLocDetl, BaseParam> pageParam = new PageParam<>(baseParam, ViewLocDetl.class);
+        PageParam<ViewLocDetl, BaseParam> data = locDetlService.getPage(pageParam, pageParam.buildWrapper(true));
+        return R.ok().add(data);
+    }
+
+    @PreAuthorize("hasAuthority('asrs:locDetl:list')")
+    @PostMapping("/locDetl/outPage")
+    public R outPage(@RequestBody Map<String, Object> map) {
+        BaseParam baseParam = buildParam(map, BaseParam.class);
+        PageParam<ViewLocDetl, BaseParam> pageParam = new PageParam<>(baseParam, ViewLocDetl.class);
+
+        QueryWrapper<ViewLocDetl> queryWrapper = pageParam.buildWrapper(true);
+        List<Long> locIds = locService.listBySts(LocStsType.F.val());
+        if (locIds.isEmpty()) {
+            locIds.add(-1L);
+        }
+        queryWrapper.in("loc_id", locIds);
+        PageParam<ViewLocDetl, BaseParam> data = locDetlService.getPage(pageParam, queryWrapper);
+        return R.ok().add(data);
     }
 
     @PreAuthorize("hasAuthority('asrs:locDetl:list')")
     @PostMapping("/locDetl/list")
     public R list(@RequestBody Map<String, Object> map) {
-        return R.ok().add(locDetlService.list());
+        List<LocDetl> list = locDetlService.getLocDetlList(map);
+        return R.ok().add(list);
+    }
+
+    @PreAuthorize("hasAuthority('asrs:locDetl:list')")
+    @PostMapping("/locDetl/listByIds")
+    public R listByIds(@RequestBody List<Long> ids) {
+        List<LocDetl> list = locDetlService.listByIds(ids);
+        List<LocDetl> locDetls = locDetlService.parseLocDetl(list);
+        return R.ok().add(locDetls);
+    }
+
+    @PreAuthorize("hasAuthority('asrs:locDetl:list')")
+    @GetMapping("/locDetl/locId/{locId}")
+    public R list(@PathVariable("locId") Long locId) {
+        List<LocDetl> list = locDetlService.list(new LambdaQueryWrapper<LocDetl>().eq(LocDetl::getLocId, locId));
+        List<LocDetl> locDetls = locDetlService.parseLocDetl(list);
+        return R.ok().add(locDetls);
+    }
+
+    @PreAuthorize("hasAuthority('asrs:locDetl:list')")
+    @GetMapping("/locDetl/locNo/{locNo}")
+    public R list(@PathVariable("locNo") String locNo) {
+        Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getLocNo, locNo));
+        if (loc == null) {
+            return R.error("搴撲綅涓嶅瓨鍦�");
+        }
+        List<LocDetl> list = locDetlService.list(new LambdaQueryWrapper<LocDetl>().eq(LocDetl::getLocId, loc.getId()));
+        List<LocDetl> locDetls = locDetlService.parseLocDetl(list);
+        return R.ok().add(locDetls);
     }
 
     @PreAuthorize("hasAuthority('asrs:locDetl:list')")
@@ -50,19 +107,42 @@
     }
 
     @PreAuthorize("hasAuthority('asrs:locDetl:save')")
+    @OperationLog("鎵归噺鎻掑叆搴撳瓨鏄庣粏")
+    @PostMapping("/locDetl/batchAdd")
+    public R save(@RequestBody List<LocDetl> locDetls) {
+
+        return R.ok().add(locDetls);
+    }
+
+    @PreAuthorize("hasAuthority('asrs:locDetl:save')")
     @OperationLog("娣诲姞搴撳瓨鏄庣粏")
     @PostMapping("/locDetl/save")
     public R save(@RequestBody LocDetl locDetl) {
         if (!locDetlService.save(locDetl)) {
             return R.error("娣诲姞澶辫触");
         }
+
+        //鎻掑叆搴撳瓨鏄庣粏瀛楁
+        List<MatField> matFields = matFieldService.list(new LambdaQueryWrapper<MatField>().eq(MatField::getUnique, 1));
+        for (MatField matField : matFields) {
+            LocDetlField locDetlField = new LocDetlField();
+            locDetlField.setDetlId(locDetl.getId());
+            locDetlField.setFieldId(matField.getId());
+            locDetlField.setName(matField.getName());
+            locDetlFieldService.save(locDetlField);
+        }
+
         return R.ok("娣诲姞鎴愬姛");
     }
 
     @PreAuthorize("hasAuthority('asrs:locDetl:update')")
     @OperationLog("淇敼搴撳瓨鏄庣粏")
     @PostMapping("/locDetl/update")
-    public R update(@RequestBody LocDetl locDetl) {
+    public R update(@RequestBody HashMap<String,Object> param) {
+        LocDetl locDetl = JSON.parseObject(JSON.toJSONString(param), LocDetl.class, Feature.DisableCircularReferenceDetect);
+        //璁剧疆鎵╁睍瀛楁
+        setLocDetlField(param, locDetl);
+
         if (!locDetlService.updateById(locDetl)) {
             return R.error("淇敼澶辫触");
         }
@@ -96,7 +176,32 @@
     @PreAuthorize("hasAuthority('asrs:locDetl:list')")
     @PostMapping("/locDetl/export")
     public void export(@RequestBody Map<String, Object> map, HttpServletResponse response) throws Exception {
-        ExcelUtil.build(ExcelUtil.create(locDetlService.list(), LocDetl.class), response);
+        List<LocDetl> locDetls = locDetlService.parseLocDetl(locDetlService.list());
+        List<MatField> locFields = matFieldService.getLocFields();
+        ExcelUtil.build(ExcelUtil.create(locDetls, LocDetl.class, locFields), response);
+    }
+
+    private void setLocDetlField(HashMap<String, Object> param, LocDetl locDetl) {
+        //鑾峰彇鎵╁睍瀛楁
+        List<MatField> matFields = matFieldService.list(new LambdaQueryWrapper<MatField>().eq(MatField::getFieldType, 1));
+        for (MatField matField : matFields) {
+            if (param.containsKey(matField.getName())) {
+                LocDetlField fieldValue = locDetlFieldService.getOne(new LambdaQueryWrapper<LocDetlField>()
+                        .eq(LocDetlField::getDetlId, locDetl.getId())
+                        .eq(LocDetlField::getFieldId, matField.getId()));
+                if (fieldValue == null) {
+                    fieldValue = new LocDetlField();
+                    fieldValue.setDetlId(locDetl.getId());
+                    fieldValue.setFieldId(matField.getId());
+                    fieldValue.setName(matField.getName());
+                    fieldValue.setValue(param.get(matField.getName()).toString());
+                    locDetlFieldService.save(fieldValue);
+                }else {
+                    fieldValue.setValue(param.get(matField.getName()).toString());
+                    locDetlFieldService.updateById(fieldValue);
+                }
+            }
+        }
     }
 
 }

--
Gitblit v1.9.1