From 99ac94a7cf412d9f0081c1d84b520eab051bb0fd Mon Sep 17 00:00:00 2001
From: zss <zss@example.com>
Date: 星期五, 24 四月 2026 11:08:21 +0800
Subject: [PATCH] feat(production): 重构生产计划模块,新增和优化生产计划功能

---
 src/main/java/com/ruoyi/basic/service/impl/CustomerFollowUpFileServiceImpl.java |   63 +++++++++++++++++++++++++++++++
 1 files changed, 63 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/ruoyi/basic/service/impl/CustomerFollowUpFileServiceImpl.java b/src/main/java/com/ruoyi/basic/service/impl/CustomerFollowUpFileServiceImpl.java
index 48cbddb..cb915c4 100644
--- a/src/main/java/com/ruoyi/basic/service/impl/CustomerFollowUpFileServiceImpl.java
+++ b/src/main/java/com/ruoyi/basic/service/impl/CustomerFollowUpFileServiceImpl.java
@@ -1,10 +1,21 @@
 package com.ruoyi.basic.service.impl;
 
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.util.StrUtil;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.google.common.collect.Lists;
 import com.ruoyi.basic.mapper.CustomerFollowUpFileMapper;
 import com.ruoyi.basic.pojo.CustomerFollowUpFile;
 import com.ruoyi.basic.service.CustomerFollowUpFileService;
+import com.ruoyi.common.vo.SimpleFileVo;
+import lombok.RequiredArgsConstructor;
 import org.springframework.stereotype.Service;
+
+import java.util.*;
+import java.util.function.BiConsumer;
+import java.util.function.Function;
+import java.util.stream.Collectors;
 
 /**
  * <br>
@@ -16,5 +27,57 @@
  * @since 2026/03/04 14:53
  */
 @Service
+@RequiredArgsConstructor
 public class CustomerFollowUpFileServiceImpl extends ServiceImpl<CustomerFollowUpFileMapper, CustomerFollowUpFile> implements CustomerFollowUpFileService {
+
+    private final CustomerFollowUpFileMapper customerFollowUpFileMapper;
+
+    @Override
+    public <T> void fillAttachment(List<T> list, Function<T, String> getAttachmentIds, BiConsumer<T, List<SimpleFileVo>> setAttachmentList) {
+        if (CollUtil.isEmpty(list)) {
+            return;
+        }
+        // 鏀堕泦鎵�鏈夋枃浠禝D
+        Set<Long> ids = list.stream()
+                .map(getAttachmentIds)
+                .filter(StrUtil::isNotBlank)
+                .flatMap(s -> Arrays.stream(s.split(",")))
+                .map(Long::valueOf)
+                .collect(Collectors.toSet());
+        List<CustomerFollowUpFile> followUpFilesByIds = new ArrayList<>();
+        Lists.partition(Lists.newArrayList(ids), 999).forEach(it -> {
+            followUpFilesByIds.addAll(
+                    getFollowUpFilesByIds(it)
+            );
+        });
+        if (CollUtil.isEmpty(followUpFilesByIds)) {
+            return;
+        }
+        Map<Long, SimpleFileVo> collectMap = followUpFilesByIds.stream().map(SimpleFileVo::convert).collect(Collectors.toMap(
+                SimpleFileVo::getId,
+                Function.identity()
+        ));
+        list.forEach(t -> {
+            String attachmentIds = getAttachmentIds.apply(t);
+            if (StrUtil.isNotBlank(attachmentIds)) {
+                List<SimpleFileVo> fileVos = Arrays.stream(attachmentIds.split(","))
+                        .map(Long::valueOf)
+                        .map(it->collectMap.getOrDefault(it, null))
+                        .filter(Objects::nonNull)
+                        .collect(Collectors.toList());
+                setAttachmentList.accept(t, fileVos);
+            }
+        });
+    }
+
+    private List<CustomerFollowUpFile> getFollowUpFilesByIds(Collection<Long> fileIds) {
+        if (fileIds == null || fileIds.isEmpty()) {
+            return new ArrayList<>(0);
+        }
+
+        LambdaQueryWrapper<CustomerFollowUpFile> queryWrapper = new LambdaQueryWrapper<>();
+        queryWrapper.in(CustomerFollowUpFile::getId, fileIds)
+                .select(CustomerFollowUpFile::getId, CustomerFollowUpFile::getFileUrl, CustomerFollowUpFile::getFileName);
+        return customerFollowUpFileMapper.selectList(queryWrapper);
+    }
 }

--
Gitblit v1.9.3