From 91e0a57a7dbbbf0d3ae0c484238fb289fb432252 Mon Sep 17 00:00:00 2001
From: liyong <18434998025@163.com>
Date: 星期二, 14 四月 2026 09:26:10 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev_New' into dev_New

---
 src/main/java/com/ruoyi/approve/service/impl/ApproveProcessServiceImpl.java              |    2 
 src/main/java/com/ruoyi/purchase/mapper/PurchaseReturnOrdersMapper.java                  |    3 
 src/main/java/com/ruoyi/stock/service/impl/StockOutRecordServiceImpl.java                |    2 
 src/main/java/com/ruoyi/common/utils/OrderUtils.java                                     |  102 ++++++++++++++++-----------------
 src/main/java/com/ruoyi/procurementrecord/service/impl/ProcurementRecordServiceImpl.java |    2 
 src/main/java/com/ruoyi/purchase/dto/PurchaseReturnOrderDto.java                         |    2 
 src/main/java/com/ruoyi/stock/service/impl/StockInRecordServiceImpl.java                 |    2 
 src/main/java/com/ruoyi/purchase/controller/PurchaseReturnOrdersController.java          |    2 
 src/main/java/com/ruoyi/procurementrecord/service/impl/ReturnManagementServiceImpl.java  |    2 
 src/main/java/com/ruoyi/projectManagement/controller/RolesController.java                |    2 
 src/main/java/com/ruoyi/sales/controller/PaymentShippingController.java                  |    2 
 src/main/java/com/ruoyi/sales/service/impl/SalesQuotationServiceImpl.java                |    2 
 src/main/java/com/ruoyi/sales/controller/ShippingInfoController.java                     |    2 
 13 files changed, 63 insertions(+), 64 deletions(-)

diff --git a/src/main/java/com/ruoyi/approve/service/impl/ApproveProcessServiceImpl.java b/src/main/java/com/ruoyi/approve/service/impl/ApproveProcessServiceImpl.java
index 4a9317b..48ffd86 100644
--- a/src/main/java/com/ruoyi/approve/service/impl/ApproveProcessServiceImpl.java
+++ b/src/main/java/com/ruoyi/approve/service/impl/ApproveProcessServiceImpl.java
@@ -99,7 +99,7 @@
 //        String approveID = today + formattedCount;
         SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
         ApproveProcess approveProcess = new ApproveProcess();
-        String no = OrderUtils.countTodayByCreateTime(approveProcessMapper, "SP");
+        String no = OrderUtils.countTodayByCreateTime(approveProcessMapper, "","approve_id");
         approveProcess.setApproveId(no);
         approveProcess.setApproveUser(approveProcessVO.getApproveUser());
         approveProcess.setApproveUserName(sysUser.getNickName());
diff --git a/src/main/java/com/ruoyi/common/utils/OrderUtils.java b/src/main/java/com/ruoyi/common/utils/OrderUtils.java
index 7bb9aba..a110ec9 100644
--- a/src/main/java/com/ruoyi/common/utils/OrderUtils.java
+++ b/src/main/java/com/ruoyi/common/utils/OrderUtils.java
@@ -2,9 +2,6 @@
 
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
-import com.ruoyi.common.utils.uuid.UUID;
-import org.apache.poi.ss.formula.functions.T;
-import org.springframework.stereotype.Component;
 
 import java.time.LocalDate;
 import java.time.LocalDateTime;
@@ -12,7 +9,6 @@
 import java.time.ZoneId;
 import java.time.format.DateTimeFormatter;
 import java.util.Date;
-import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
 
@@ -24,82 +20,88 @@
 
     /**
      * List<Integer> 杞崲涓� Long[] 鏁扮粍
-     * @param ids
-     * @return
+     * @param ids ids
+     * @return Long[]
      */
     public static Long[] listIntegerToLongArray(List<Integer> ids) {
         return ids.stream()
-                // 澶勭悊null鍊硷細濡傛灉鍏冪礌涓簄ull锛岃浆鎹负0L锛堝彲鏍规嵁涓氬姟璋冩暣锛屾瘮濡傛姏寮傚父锛�
                 .map(id -> id != null ? id.longValue() : -1L)
-                // 灏哠tream<Long>杞崲涓篖ong[]鏁扮粍
                 .toArray(Long[]::new);
     }
 
     /**
      * 鍒ゆ柇鐩爣id鏄惁鍦ㄩ�楀彿鍒嗛殧鐨勫瓧绗︿覆涓�
-     * @param targetId
-     * @param str
-     * @return
+     * @param targetId targetId
+     * @param str source
+     * @return boolean
      */
     public boolean isStaffIdExist(Object targetId,String str) {
-        // 绌哄�兼牎楠岋紝閬垮厤绌烘寚閽�
         if (str == null || str.trim().isEmpty() || targetId == null) {
             return false;
         }
-        // 鎸夐�楀彿鍒嗗壊鎴愭暟缁�
         String[] idArray = str.split(",");
-        // 閬嶅巻鏁扮粍鍒ゆ柇鏄惁鍖呭惈鐩爣id
         for (String id : idArray) {
-            // 鍘婚櫎绌烘牸锛堥槻姝㈠瓧绗︿覆涓湁澶氫綑绌烘牸锛屽"1, 121"锛�
             String cleanId = id.trim();
-            // 杞崲涓烘暟瀛楀苟姣旇緝
             try {
                 if (cleanId.equals(String.valueOf(targetId))) {
                     return true;
                 }
             } catch (NumberFormatException e) {
-                // 鑻ュ瓨鍦ㄩ潪鏁板瓧ID锛岀洿鎺ヨ繑鍥瀎alse
                 return false;
             }
         }
         return false;
     }
 
-
-
     /**
-     * 鏌ヨ褰撳ぉ锛堝熀浜巆reateTime瀛楁锛夌殑璁板綍鏁伴噺
-     * @param mapper 瀹炰綋绫诲搴旂殑BaseMapper
-     * @param <T> 瀹炰綋绫绘硾鍨�
-     * @return 褰撳ぉ璁板綍鏁伴噺
+     * 鏌ヨ褰撳ぉ鍩轰簬 create_time 鐨勬渶鏂扮紪鍙凤紝骞剁敓鎴愪笅涓�涓紪鍙�
+     * @param mapper mapper
+     * @param preFix 缂栧彿鍓嶇紑
+     * @param code 缂栧彿瀛楁
+     * @param <T> 瀹炰綋绫诲瀷
+     * @return 璁㈠崟缂栧彿
      */
-    public static <T> String countTodayByCreateTime(BaseMapper<T> mapper,String preFix) {
-        // 鑾峰彇褰撳ぉ寮�濮嬫椂闂达紙00:00:00锛�
-        LocalDateTime todayStart = LocalDateTime.of(
-                LocalDateTime.now().toLocalDate(),
-                LocalTime.MIN
-        );
-        // 鑾峰彇褰撳ぉ缁撴潫鏃堕棿锛�23:59:59.999锛�
-        LocalDateTime todayEnd = LocalDateTime.of(
-                LocalDateTime.now().toLocalDate(),
-                LocalTime.MAX
-        );
+    public static <T> String countTodayByCreateTime(BaseMapper<T> mapper,String preFix,String code) {
+        LocalDate today = LocalDate.now();
+        LocalDateTime todayStart = today.atStartOfDay();
+        LocalDateTime tomorrowStart = today.plusDays(1).atStartOfDay();
+        String dateStr = today.format(DateTimeFormatter.BASIC_ISO_DATE);
+        String codePrefix = preFix + dateStr;
 
-        // 杞崲涓篋ate绫诲瀷锛堝鏋滃疄浣撶被涓璫reateTime鏄疞ocalDateTime鍙洿鎺ヤ娇鐢級
-        Date startDate = Date.from(todayStart.atZone(ZoneId.systemDefault()).toInstant());
-        Date endDate = Date.from(todayEnd.atZone(ZoneId.systemDefault()).toInstant());
+        QueryWrapper<T> wrapper = new QueryWrapper<>();
+        wrapper.select(code)
+                .ge("create_time", todayStart)
+                .lt("create_time", tomorrowStart)
+                .likeRight(code, codePrefix)
+                .orderByDesc(code)
+                .last("LIMIT 1");
 
-        // 鏋勫缓鏌ヨ鏉′欢
-        QueryWrapper<T> queryWrapper = new QueryWrapper<>();
-        queryWrapper.ge("create_time", startDate)  // 澶т簬绛変簬褰撳ぉ寮�濮�
-                .lt("create_time", endDate);   // 灏忎簬褰撳ぉ缁撴潫锛堥伩鍏嶆绉掔簿搴﹂棶棰橈級
+        long nextSeq = 1;
+        List<Map<String, Object>> records = mapper.selectMaps(wrapper);
+        if (!records.isEmpty()) {
+            Object lastCode = records.get(0).get(code);
+            if (lastCode != null) {
+                nextSeq = extractSequence(lastCode.toString(), codePrefix) + 1;
+            }
+        }
 
-        // 鎵ц鏌ヨ
-        Long aLong = mapper.selectCount(queryWrapper);
-        // 鎷兼帴璁㈠崟缂栧彿 preFix + 鏃堕棿锛坹yyyMMdd锛� + 璁㈠崟鏁伴噺(001)
-        return preFix + LocalDate.now().format(DateTimeFormatter.ISO_LOCAL_DATE).replaceAll("-", "") + String.format("%03d", (aLong + 1)) + "-" + new Date().getTime();
+        return preFix + dateStr + String.format("%03d", nextSeq);
     }
 
+    private static long extractSequence(String fullCode, String codePrefix) {
+        if (!fullCode.startsWith(codePrefix)) {
+            return 0;
+        }
+        String seqStr = fullCode.substring(codePrefix.length()).trim();
+        if (seqStr.isEmpty()) {
+            return 0;
+        }
+        try {
+            return Long.parseLong(seqStr);
+        } catch (NumberFormatException e) {
+            return 0;
+        }
+    }
 
     /**
      * 鏌ヨ褰撳ぉ锛堝熀浜巆reateTime瀛楁锛夌殑璁板綍鏁伴噺
@@ -108,29 +110,23 @@
      * @return 褰撳ぉ璁板綍鏁伴噺
      */
     public static <T> String countAfterServiceTodayByCreateTime(BaseMapper<T> mapper,String preFix) {
-        // 鑾峰彇褰撳ぉ寮�濮嬫椂闂达紙00:00:00锛�
         LocalDateTime todayStart = LocalDateTime.of(
                 LocalDateTime.now().toLocalDate(),
                 LocalTime.MIN
         );
-        // 鑾峰彇褰撳ぉ缁撴潫鏃堕棿锛�23:59:59.999锛�
         LocalDateTime todayEnd = LocalDateTime.of(
                 LocalDateTime.now().toLocalDate(),
                 LocalTime.MAX
         );
 
-        // 杞崲涓篋ate绫诲瀷锛堝鏋滃疄浣撶被涓璫reateTime鏄疞ocalDateTime鍙洿鎺ヤ娇鐢級
         Date startDate = Date.from(todayStart.atZone(ZoneId.systemDefault()).toInstant());
         Date endDate = Date.from(todayEnd.atZone(ZoneId.systemDefault()).toInstant());
 
-        // 鏋勫缓鏌ヨ鏉′欢
         QueryWrapper<T> queryWrapper = new QueryWrapper<>();
-        queryWrapper.ge("create_time", startDate)  // 澶т簬绛変簬褰撳ぉ寮�濮�
-                .lt("create_time", endDate);   // 灏忎簬褰撳ぉ缁撴潫锛堥伩鍏嶆绉掔簿搴﹂棶棰橈級
+        queryWrapper.ge("create_time", startDate)
+                .lt("create_time", endDate);
 
-        // 鎵ц鏌ヨ
         Long aLong = mapper.selectCount(queryWrapper);
-        // 鎷兼帴璁㈠崟缂栧彿 preFix + 鏃堕棿锛坹yyyMMdd锛� + 璁㈠崟鏁伴噺(001)
         return preFix + LocalDate.now().format(DateTimeFormatter.ISO_LOCAL_DATE).replaceAll("-", "") + String.format("%03d", (aLong + 1));
     }
 }
diff --git a/src/main/java/com/ruoyi/procurementrecord/service/impl/ProcurementRecordServiceImpl.java b/src/main/java/com/ruoyi/procurementrecord/service/impl/ProcurementRecordServiceImpl.java
index 19509a3..1e31842 100644
--- a/src/main/java/com/ruoyi/procurementrecord/service/impl/ProcurementRecordServiceImpl.java
+++ b/src/main/java/com/ruoyi/procurementrecord/service/impl/ProcurementRecordServiceImpl.java
@@ -535,7 +535,7 @@
             Long aLong = customStorageMapper.selectCount(null);
             item.setInboundBatches(aLong.equals(0L) ? "绗�1鎵规(鑷畾涔夊叆搴�)" : "绗�"+ (aLong + 1) + "鎵规(鑷畾涔夊叆搴�)" );
             item.setCreateBy(loginUser.getNickName());
-            item.setCode(OrderUtils.countTodayByCreateTime(customStorageMapper, ""));
+            item.setCode(OrderUtils.countTodayByCreateTime(customStorageMapper, "", "code"));
             customStorageMapper.insert(item);
         });
         return AjaxResult.success("鑷畾涔夊叆搴撴垚鍔�");
diff --git a/src/main/java/com/ruoyi/procurementrecord/service/impl/ReturnManagementServiceImpl.java b/src/main/java/com/ruoyi/procurementrecord/service/impl/ReturnManagementServiceImpl.java
index d2b6142..edb70f9 100644
--- a/src/main/java/com/ruoyi/procurementrecord/service/impl/ReturnManagementServiceImpl.java
+++ b/src/main/java/com/ruoyi/procurementrecord/service/impl/ReturnManagementServiceImpl.java
@@ -72,7 +72,7 @@
 
     @Override
     public boolean addReturnManagementDto(ReturnManagementDto returnManagementDto) {
-        String rt = OrderUtils.countTodayByCreateTime(returnManagementMapper, "RT");
+        String rt = OrderUtils.countTodayByCreateTime(returnManagementMapper, "RT","return_no");
         returnManagementDto.setReturnNo(rt);
         save(returnManagementDto);
         for (ReturnSaleProduct returnSaleProduct : returnManagementDto.getReturnSaleProducts()) {
diff --git a/src/main/java/com/ruoyi/projectManagement/controller/RolesController.java b/src/main/java/com/ruoyi/projectManagement/controller/RolesController.java
index e3ca4a3..3385128 100644
--- a/src/main/java/com/ruoyi/projectManagement/controller/RolesController.java
+++ b/src/main/java/com/ruoyi/projectManagement/controller/RolesController.java
@@ -35,7 +35,7 @@
     @ApiOperation("鏂板")
     public AjaxResult add(@RequestBody RoleDto roleDto) {
         if (roleDto.getIsDefaultNo()) {
-            roleDto.setNo(OrderUtils.countTodayByCreateTime(rolesMapper, "XMJS"));
+            roleDto.setNo(OrderUtils.countTodayByCreateTime(rolesMapper, "XMJS","no"));
         }
         return AjaxResult.success(rolesservice.save(roleDto));
     }
diff --git a/src/main/java/com/ruoyi/purchase/controller/PurchaseReturnOrdersController.java b/src/main/java/com/ruoyi/purchase/controller/PurchaseReturnOrdersController.java
index 9eebe0a..d23cc11 100644
--- a/src/main/java/com/ruoyi/purchase/controller/PurchaseReturnOrdersController.java
+++ b/src/main/java/com/ruoyi/purchase/controller/PurchaseReturnOrdersController.java
@@ -42,7 +42,7 @@
     @PostMapping("/add")
     public AjaxResult add(@RequestBody PurchaseReturnOrderDto purchaseReturnOrderDto) throws Exception {
         if (purchaseReturnOrderDto.getIsDefaultNo()) {
-            purchaseReturnOrderDto.setNo(OrderUtils.countTodayByCreateTime(purchaseReturnOrdersMapper, "CGTL"));
+            purchaseReturnOrderDto.setNo(OrderUtils.countTodayByCreateTime(purchaseReturnOrdersMapper, "CGTL","no"));
         }
         return AjaxResult.success(purchaseReturnOrdersService.add(purchaseReturnOrderDto));
     }
diff --git a/src/main/java/com/ruoyi/purchase/dto/PurchaseReturnOrderDto.java b/src/main/java/com/ruoyi/purchase/dto/PurchaseReturnOrderDto.java
index c0b98e6..f48f158 100644
--- a/src/main/java/com/ruoyi/purchase/dto/PurchaseReturnOrderDto.java
+++ b/src/main/java/com/ruoyi/purchase/dto/PurchaseReturnOrderDto.java
@@ -14,4 +14,6 @@
     private String supplierName;
 
     private List<PurchaseReturnOrderProductsDto> purchaseReturnOrderProductsDtos;
+
+    private Long[] deptIds;
 }
diff --git a/src/main/java/com/ruoyi/purchase/mapper/PurchaseReturnOrdersMapper.java b/src/main/java/com/ruoyi/purchase/mapper/PurchaseReturnOrdersMapper.java
index f0e0227..a680c12 100644
--- a/src/main/java/com/ruoyi/purchase/mapper/PurchaseReturnOrdersMapper.java
+++ b/src/main/java/com/ruoyi/purchase/mapper/PurchaseReturnOrdersMapper.java
@@ -2,6 +2,7 @@
 
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.purchase.dto.PurchaseReturnOrderDto;
 import com.ruoyi.purchase.pojo.PurchaseReturnOrders;
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
 import com.ruoyi.purchase.vo.PurchaseReturnOrderVo;
@@ -18,5 +19,5 @@
  */
 @Mapper
 public interface PurchaseReturnOrdersMapper extends BaseMapper<PurchaseReturnOrders> {
-    IPage<PurchaseReturnOrderVo> listPage(Page page, @Param("params") PurchaseReturnOrders purchaseReturnOrder);
+    IPage<PurchaseReturnOrderVo> listPage(Page page, @Param("params") PurchaseReturnOrderDto purchaseReturnOrder);
 }
diff --git a/src/main/java/com/ruoyi/sales/controller/PaymentShippingController.java b/src/main/java/com/ruoyi/sales/controller/PaymentShippingController.java
index c67d438..dabd7ac 100644
--- a/src/main/java/com/ruoyi/sales/controller/PaymentShippingController.java
+++ b/src/main/java/com/ruoyi/sales/controller/PaymentShippingController.java
@@ -43,7 +43,7 @@
     @ApiOperation("娣诲姞鏀粯涓庡彂璐т俊鎭�")
     @Transactional(rollbackFor = Exception.class)
     public AjaxResult add(@RequestBody PaymentShipping paymentShipping) {
-        String ord = OrderUtils.countTodayByCreateTime(paymentShippingMapper, "ORD");
+        String ord = OrderUtils.countTodayByCreateTime(paymentShippingMapper, "ORD","order_no");
         paymentShipping.setOrderNo(ord);
         boolean save = paymentShippingService.save(paymentShipping);
         return save ? success() : error();
diff --git a/src/main/java/com/ruoyi/sales/controller/ShippingInfoController.java b/src/main/java/com/ruoyi/sales/controller/ShippingInfoController.java
index db3c5b9..eed5ffa 100644
--- a/src/main/java/com/ruoyi/sales/controller/ShippingInfoController.java
+++ b/src/main/java/com/ruoyi/sales/controller/ShippingInfoController.java
@@ -74,7 +74,7 @@
     @Log(title = "鍙戣揣淇℃伅绠$悊", businessType = BusinessType.INSERT)
     public AjaxResult add(@RequestBody ShippingInfoDto req) throws Exception {
         LoginUser loginUser = SecurityUtils.getLoginUser();
-        String sh = OrderUtils.countTodayByCreateTime(shippingInfoMapper, "SH");
+        String sh = OrderUtils.countTodayByCreateTime(shippingInfoMapper, "SH","shipping_no");
         // 鍙戣揣瀹℃壒
         ApproveProcessVO approveProcessVO = new ApproveProcessVO();
         approveProcessVO.setApproveType(7);
diff --git a/src/main/java/com/ruoyi/sales/service/impl/SalesQuotationServiceImpl.java b/src/main/java/com/ruoyi/sales/service/impl/SalesQuotationServiceImpl.java
index 8e18058..8872e88 100644
--- a/src/main/java/com/ruoyi/sales/service/impl/SalesQuotationServiceImpl.java
+++ b/src/main/java/com/ruoyi/sales/service/impl/SalesQuotationServiceImpl.java
@@ -63,7 +63,7 @@
         LoginUser loginUser = SecurityUtils.getLoginUser();
         SalesQuotation salesQuotation = new SalesQuotation();
         BeanUtils.copyProperties(salesQuotationDto, salesQuotation);
-        String quotationNo = OrderUtils.countTodayByCreateTime(salesQuotationMapper, "QT");
+        String quotationNo = OrderUtils.countTodayByCreateTime(salesQuotationMapper, "QT","quotation_no");
         salesQuotation.setQuotationNo(quotationNo);
         salesQuotation.setStatus("寰呭鎵�");
         salesQuotationMapper.insert(salesQuotation);
diff --git a/src/main/java/com/ruoyi/stock/service/impl/StockInRecordServiceImpl.java b/src/main/java/com/ruoyi/stock/service/impl/StockInRecordServiceImpl.java
index 30e545f..15e3e39 100644
--- a/src/main/java/com/ruoyi/stock/service/impl/StockInRecordServiceImpl.java
+++ b/src/main/java/com/ruoyi/stock/service/impl/StockInRecordServiceImpl.java
@@ -46,7 +46,7 @@
     @Override
     @Transactional(rollbackFor = Exception.class)
     public int add(StockInRecordDto stockInRecordDto) {
-        String no = OrderUtils.countTodayByCreateTime(stockInRecordMapper, "RK");
+        String no = OrderUtils.countTodayByCreateTime(stockInRecordMapper, "RK","inbound_batches");
         stockInRecordDto.setInboundBatches(no);
         StockInRecord stockInRecord = new StockInRecord();
         BeanUtils.copyProperties(stockInRecordDto, stockInRecord);
diff --git a/src/main/java/com/ruoyi/stock/service/impl/StockOutRecordServiceImpl.java b/src/main/java/com/ruoyi/stock/service/impl/StockOutRecordServiceImpl.java
index e01fe5d..f0b3c84 100644
--- a/src/main/java/com/ruoyi/stock/service/impl/StockOutRecordServiceImpl.java
+++ b/src/main/java/com/ruoyi/stock/service/impl/StockOutRecordServiceImpl.java
@@ -51,7 +51,7 @@
 
     @Override
     public int add(StockOutRecordDto stockOutRecordDto) {
-        String no = OrderUtils.countTodayByCreateTime(stockOutRecordMapper, "CK");
+        String no = OrderUtils.countTodayByCreateTime(stockOutRecordMapper, "CK","outbound_batches");
         stockOutRecordDto.setOutboundBatches(no);
         StockInRecord stockInRecord = new StockInRecord();
         BeanUtils.copyProperties(stockOutRecordDto, stockInRecord);

--
Gitblit v1.9.3