From 669fe984048785873c20fbd0ce8abb3cd52c1fce Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期二, 29 四月 2025 15:22:24 +0800
Subject: [PATCH] 新增出库单优化

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderItemController.java |   98 +++++++++++++++++++++++++++++++++++--------------
 1 files changed, 70 insertions(+), 28 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderItemController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderItemController.java
index 0b65aca..014c228 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderItemController.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderItemController.java
@@ -1,39 +1,37 @@
 package com.vincent.rsf.server.manager.controller;
 
-import com.alibaba.fastjson.JSON;
+
+import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.vincent.rsf.framework.common.Cools;
 import com.vincent.rsf.framework.common.R;
 import com.vincent.rsf.framework.exception.CoolException;
-import com.vincent.rsf.server.common.utils.CommonUtil;
 import com.vincent.rsf.server.common.utils.ExcelUtil;
 import com.vincent.rsf.server.common.annotation.OperationLog;
 import com.vincent.rsf.server.common.domain.BaseParam;
 import com.vincent.rsf.server.common.domain.KeyValVo;
 import com.vincent.rsf.server.common.domain.PageParam;
-import com.vincent.rsf.server.manager.controller.params.AsnOrderItemParams;
+import com.vincent.rsf.server.manager.controller.params.BatchUpdateParam;
+import com.vincent.rsf.server.manager.entity.AsnOrder;
 import com.vincent.rsf.server.manager.entity.AsnOrderItem;
+import com.vincent.rsf.server.manager.entity.Companys;
 import com.vincent.rsf.server.manager.entity.excel.AsnOrderTemplate;
+import com.vincent.rsf.server.manager.enums.CompanysType;
 import com.vincent.rsf.server.manager.service.AsnOrderItemService;
+import com.vincent.rsf.server.manager.service.CompanysService;
 import com.vincent.rsf.server.system.controller.BaseController;
-import com.vincent.rsf.server.system.entity.Fields;
-import com.vincent.rsf.server.system.entity.FieldsItem;
-import com.vincent.rsf.server.system.service.FieldsItemService;
-import com.vincent.rsf.server.system.service.FieldsService;
-import com.vincent.rsf.server.system.utils.SerialRuleUtils;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
+import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.web.bind.annotation.*;
 import org.springframework.web.multipart.MultipartFile;
 
-import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 import java.util.*;
-import java.util.stream.Collectors;
 
 @Api(tags = "ASN鍗曟槑缁�")
 @RestController
@@ -42,12 +40,16 @@
     @Autowired
     private AsnOrderItemService asnOrderItemService;
 
+    @Autowired
+    private CompanysService companysService;
+
     @PreAuthorize("hasAuthority('manager:asnOrderItem:list')")
+    @ApiOperation("鍒嗛〉鑾峰彇鍒楄〃")
     @PostMapping("/asnOrderItem/page")
     public R page(@RequestBody Map<String, Object> map) {
         BaseParam baseParam = buildParam(map, BaseParam.class);
         PageParam<AsnOrderItem, BaseParam> pageParam = new PageParam<>(baseParam, AsnOrderItem.class);
-        return R.ok().add(asnOrderItemService.page(pageParam, pageParam.buildWrapper(true)));
+        return R.ok().add(asnOrderItemService.listByAsnId(pageParam, pageParam.buildWrapper(true)));
     }
 
     @PreAuthorize("hasAuthority('manager:asnOrderItem:list')")
@@ -76,17 +78,14 @@
             throw new CoolException("淇℃伅涓嶈兘涓虹┖锛侊紒");
         }
         params.put("createBy", getLoginUserId());
-        params.put("updateBy", getLoginUser());
+        params.put("updateBy", getLoginUserId());
 
         if (!asnOrderItemService.fieldsSave(params)) {
             return R.error("Save Fail");
         }
         return R.ok("Save Success");
-
-
-
-
     }
+
 
     @PreAuthorize("hasAuthority('manager:asnOrderItem:update')")
     @OperationLog("Update ASN鍗曟嵁")
@@ -94,6 +93,14 @@
     public R update(@RequestBody AsnOrderItem asnOrderItem) {
         asnOrderItem.setUpdateBy(getLoginUserId());
         asnOrderItem.setUpdateTime(new Date());
+        if (!Objects.isNull(asnOrderItem.getSplrName()) && StringUtils.isNotBlank(asnOrderItem.getSplrName())) {
+            Companys companys = companysService.getOne(new LambdaQueryWrapper<Companys>()
+                            .eq(Companys::getType, CompanysType.COMPANYS_TYPE_SUPPLIER.val)
+                    .eq(Companys::getId, asnOrderItem.getSplrName()));
+            if (!Objects.isNull(companys)) {
+                asnOrderItem.setSplrCode(companys.getCode()).setSplrName(companys.getName());
+            }
+        }
         if (!asnOrderItemService.updateById(asnOrderItem)) {
             return R.error("Update Fail");
         }
@@ -126,12 +133,34 @@
 
     @PreAuthorize("hasAuthority('manager:asnOrderItem:list')")
     @PostMapping("/asnOrderItem/export")
-    @ApiOperation("鏀惰揣閫氱煡鍗曟槑缁�")
+    @ApiOperation("瀵煎嚭鏀惰揣閫氱煡鍗曟槑缁�")
     public void export(@RequestBody Map<String, Object> map, HttpServletResponse response) throws Exception {
-        AsnOrderTemplate template = ExcelUtil.mockData(AsnOrderTemplate.class);
-        List<AsnOrderTemplate> list = new ArrayList<>();
-        list.add(template);
-        ExcelUtil.build(ExcelUtil.create(list, AsnOrderTemplate.class, true), response);
+        List<AsnOrderItem> orderItems = new ArrayList<>();
+        if (!Objects.isNull(map.get("ids"))) {
+            List<Long> ids = JSONArray.parseArray(JSONObject.toJSONString(map.get("ids")), Long.class);
+            if (!ids.isEmpty()) {
+                orderItems = asnOrderItemService.list(new LambdaQueryWrapper<AsnOrderItem>()
+                        .in(AsnOrderItem::getId, ids)
+                        .eq(AsnOrderItem::getStatus, 1));
+            } else {
+                orderItems = asnOrderItemService.list(new LambdaQueryWrapper<>());
+            }
+        } else {
+            orderItems = asnOrderItemService.list(new LambdaQueryWrapper<>());
+        }
+
+        ExcelUtil.build(ExcelUtil.create(orderItems, AsnOrderItem.class, true), response);
+    }
+
+
+    @PostMapping("/asnOrderItem/generate/barcode")
+    @ApiOperation("鐢熸垚ASN鏍囩")
+    @PreAuthorize("hasAuthority('manager:asnOrder:list')")
+    public R generateBarcode(@RequestBody List<Long> orders) {
+        if (orders.isEmpty()) {
+            return R.error("鍗曟嵁涓嶈兘涓虹┖!!");
+        }
+        return asnOrderItemService.generateBarcode(orders);
     }
 
     /**
@@ -139,18 +168,31 @@
      * @param file
      * @return
      */
-    @PostMapping("/asnOrder/import")
+    @PostMapping("/asnOrderItem/import")
     @ApiOperation("ASN瀵煎叆鎺ュ彛")
-    @PreAuthorize("hasAuthority('manager:asnOrder:update')")
+    @PreAuthorize("hasAuthority('manager:asnOrderItem:update')")
     public R importExcel(@RequestParam(value = "file") MultipartFile file, @RequestParam String asnId) throws Exception {
         if (Objects.isNull(file)) {
-            throw new CoolException("鏂囦欢涓嶈兘涓虹┖锛侊紒");
+            R.error("鏂囦欢涓嶈兘涓虹┖锛侊紒");
         }
         HashMap<String, Object> hashMap = new HashMap<>();
-        if (!Objects.isNull(asnId)) {
-            hashMap.put("asnId", asnId);
-        }
-        return asnOrderItemService.excelImport(file, hashMap);
+        return asnOrderItemService.excelImport(file, hashMap, getLoginUserId());
+    }
+
+    /**
+     * @author Ryan
+     * @description 涓嬭浇妯℃澘
+     * @param
+     * @return
+     * @time 2025/4/18 08:17
+     */
+    @PostMapping("/asnOrderItem/template/download")
+    @ApiOperation("涓嬭浇鏀惰揣鍗曟ā鏉�")
+    @PreAuthorize("hasAuthority('manager:asnOrderItem:update')")
+    public void downloadTemplate(@RequestBody Map<String, Object> map, HttpServletResponse response) throws Exception {
+        AsnOrderTemplate template = ExcelUtil.mockData(AsnOrderTemplate.class);
+        List<AsnOrderTemplate> list = Arrays.asList(template);
+        ExcelUtil.build(ExcelUtil.create(list, AsnOrderTemplate.class, true), response);
     }
 
 }

--
Gitblit v1.9.1