From 73e8632e1082843e1736d86d3e5fa6a4ee0b4e7d Mon Sep 17 00:00:00 2001
From: liding <756868258@qq.com>
Date: 星期五, 08 五月 2026 13:35:42 +0800
Subject: [PATCH] fix:1.领料,补料,退料,增加库存出入库记录

---
 src/main/java/com/ruoyi/production/service/impl/ProductionOperationTaskServiceImpl.java |   25 +++++++++++++++++++++++++
 1 files changed, 25 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/service/impl/ProductionOperationTaskServiceImpl.java b/src/main/java/com/ruoyi/production/service/impl/ProductionOperationTaskServiceImpl.java
index aad1350..6e9457d 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductionOperationTaskServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductionOperationTaskServiceImpl.java
@@ -58,6 +58,7 @@
 
     @Override
     public IPage<ProductionOperationTaskVo> pageProductionOperationTask(Page<ProductionOperationTaskDto> page, ProductionOperationTaskDto dto) {
+        // 鍒嗛〉鏌ヨ鐢熶骇宸ュ簭浠诲姟
         Page<ProductionOperationTaskVo> voPage = new Page<>(page.getCurrent(), page.getSize(), page.getTotal());
         IPage<ProductionOperationTaskVo> result = baseMapper.pageProductionOperationTask(voPage, dto);
         fillUserNames(result.getRecords());
@@ -66,6 +67,7 @@
 
     @Override
     public List<ProductionOperationTaskVo> listProductionOperationTask(ProductionOperationTaskDto dto) {
+        // 鏌ヨ宸ュ簭浠诲姟鍒楄〃
         List<ProductionOperationTaskVo> result = BeanUtil.copyToList(this.list(buildQueryWrapper(dto)), ProductionOperationTaskVo.class);
         fillUserNames(result);
         return result;
@@ -73,6 +75,7 @@
 
     @Override
     public ProductionOperationTaskVo getProductionOperationTaskInfo(Long id) {
+        // 鑾峰彇鐢熶骇宸ュ簭浠诲姟璇︽儏
         ProductionOperationTask item = this.getById(id);
         if (item == null) {
             return null;
@@ -90,21 +93,25 @@
 
     @Override
     public boolean saveProductionOperationTask(ProductionOperationTask productionOperationTask) {
+        // 淇濆瓨鐢熶骇宸ュ簭浠诲姟
         return this.saveOrUpdate(productionOperationTask);
     }
 
     @Override
     public boolean removeProductionOperationTask(List<Long> ids) {
+        // 鍒犻櫎鐢熶骇宸ュ簭浠诲姟
         return ids != null && !ids.isEmpty() && this.removeByIds(ids);
     }
 
     @Override
     public int updateProductWorkOrder(ProductionOperationTaskDto dto) {
+        // 鏇存柊宸ュ簭浠诲姟瀵瑰簲鐨勫伐鍗曚俊鎭�
         return baseMapper.updateById(dto);
     }
 
     @Override
     public boolean assign(ProductionOperationTaskDto dto) {
+        // 鍒嗛厤宸ュ簭浠诲姟鎵ц浜�
         if (dto == null || dto.getId() == null) {
             throw new ServiceException("宸ュ崟ID涓嶈兘涓虹┖");
         }
@@ -120,6 +127,7 @@
     }
 
     private LambdaQueryWrapper<ProductionOperationTask> buildQueryWrapper(ProductionOperationTaskDto dto) {
+        // 鎸夋潯浠跺姩鎬佹瀯寤烘暟鎹簱鏌ヨ鏉′欢
         ProductionOperationTask query = dto == null ? new ProductionOperationTask() : dto;
         return Wrappers.<ProductionOperationTask>lambdaQuery()
                 .eq(query.getId() != null, ProductionOperationTask::getId, query.getId())
@@ -133,10 +141,12 @@
     }
 
     private void fillUserNames(List<ProductionOperationTaskVo> voList) {
+        // 濉厖鐢ㄦ埛鍚嶇О
         if (voList == null || voList.isEmpty()) {
             return;
         }
         Set<Long> userIdSet = new LinkedHashSet<>();
+        // 閬嶅巻澶勭悊鏁版嵁骞剁粍瑁呯粨鏋�
         for (ProductionOperationTaskVo vo : voList) {
             if (vo == null) {
                 continue;
@@ -172,6 +182,7 @@
     }
 
     private List<Long> parseUserIdList(String userIds, boolean strict) {
+        // 瑙f瀽骞舵牎楠岀敤鎴稩D鏁扮粍瀛楃涓�
         if (StringUtils.isBlank(userIds)) {
             if (strict) {
                 throw new ServiceException("userIds鏍煎紡涓嶆纭紝蹇呴』涓篔SON鏁板瓧鏁扮粍");
@@ -199,6 +210,7 @@
 
     @Override
     public void down(HttpServletResponse response, ProductionOperationTaskDto dto) {
+        // 瀵煎嚭宸ュ簭浠诲姟鏁版嵁
         if (dto == null || dto.getId() == null) {
             throw new ServiceException("宸ュ崟ID涓嶈兘涓虹┖");
         }
@@ -250,15 +262,18 @@
     }
 
     private List<Map<String, Object>> buildTaskAttachmentImages(Long taskId) {
+        // 缁勮浠诲姟闄勪欢鍥剧墖鏁版嵁鐢ㄤ簬瀵煎嚭
         List<Map<String, Object>> images = new ArrayList<>();
         StorageAttachmentDTO storageAttachmentDTO = new StorageAttachmentDTO();
         storageAttachmentDTO.setRecordType(RecordTypeEnum.PRODUCTION_OPERATION_TASK.getType());
         storageAttachmentDTO.setRecordId(taskId);
         List<StorageBlobVO> taskWorkOrderFiles =
                 fileUtil.getStorageBlobVOsByApplicationAndRecordTypeAndRecordId(storageAttachmentDTO);
+        // 鍙傛暟涓庡墠缃潯浠舵牎楠�
         if (CollectionUtils.isEmpty(taskWorkOrderFiles)) {
             return images;
         }
+        // 閬嶅巻澶勭悊鏁版嵁骞剁粍瑁呯粨鏋�
         for (StorageBlobVO blobVO : taskWorkOrderFiles) {
             if (blobVO == null) {
                 continue;
@@ -286,6 +301,7 @@
     }
 
     private File resolveImageFile(StorageBlobVO blobVO) {
+        // 灏嗛檮浠朵俊鎭В鏋愪负鏈湴鍥剧墖鏂囦欢瀵硅薄
         if (blobVO == null || StringUtils.isBlank(blobVO.getUidFilename())) {
             return null;
         }
@@ -296,6 +312,7 @@
     }
 
     private PictureType resolvePictureType(StorageBlobVO blobVO) {
+        // 鎸夋枃浠跺悕鎴栧唴瀹圭被鍨嬭瘑鍒浘鐗囨牸寮�
         if (blobVO == null) {
             return null;
         }
@@ -311,6 +328,7 @@
     }
 
     private PictureType parsePictureTypeByFileName(String fileName) {
+        // 鏍规嵁鏂囦欢鍚庣紑瑙f瀽鍥剧墖鏍煎紡
         if (StringUtils.isBlank(fileName) || !fileName.contains(".")) {
             return null;
         }
@@ -322,6 +340,7 @@
     }
 
     private PictureType parsePictureTypeByContentType(String contentType) {
+        // 鏍规嵁Content-Type瑙f瀽鍥剧墖鏍煎紡
         if (StringUtils.isBlank(contentType)) {
             return null;
         }
@@ -347,4 +366,10 @@
                 return null;
         }
     }
+
+    @Override
+    public List<ProductionOperationTaskVo> getOperation(ProductionOperationTaskDto dto) {
+        // 鏌ヨ宸ュ簭浠诲姟鍒楄〃
+        return baseMapper.getOperation(dto);
+    }
 }

--
Gitblit v1.9.3