From cb3bc6d91595409e138daf6fe08a661bba9d25ee Mon Sep 17 00:00:00 2001
From: gongchunyi <deslre0381@gmail.com>
Date: 星期二, 28 四月 2026 11:02:53 +0800
Subject: [PATCH] feat: 客户拜访编辑时清除已删除的文件

---
 src/main/java/com/ruoyi/customervisits/service/impl/CustomerVisitsServiceImpl.java |   84 +++++++++++++++++++++++++++++++++++++++---
 1 files changed, 78 insertions(+), 6 deletions(-)

diff --git a/src/main/java/com/ruoyi/customervisits/service/impl/CustomerVisitsServiceImpl.java b/src/main/java/com/ruoyi/customervisits/service/impl/CustomerVisitsServiceImpl.java
index 5023c99..aef8802 100644
--- a/src/main/java/com/ruoyi/customervisits/service/impl/CustomerVisitsServiceImpl.java
+++ b/src/main/java/com/ruoyi/customervisits/service/impl/CustomerVisitsServiceImpl.java
@@ -4,13 +4,27 @@
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.enums.FileNameType;
 import com.ruoyi.common.utils.StringUtils;
+import com.ruoyi.customervisits.dto.CustomerVisitsDto;
 import com.ruoyi.customervisits.mapper.CustomerVisitsMapper;
 import com.ruoyi.customervisits.pojo.CustomerVisits;
 import com.ruoyi.customervisits.service.CustomerVisitsService;
+import com.ruoyi.other.service.impl.TempFileServiceImpl;
+import com.ruoyi.sales.mapper.CommonFileMapper;
+import com.ruoyi.sales.pojo.CommonFile;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.BeanUtils;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.nio.file.Files;
+import java.nio.file.Paths;
+import java.util.Collections;
+import java.util.List;
+import java.util.Set;
+import java.util.stream.Collectors;
 
 /**
  * @author :yys
@@ -23,13 +37,71 @@
     @Autowired
     private CustomerVisitsMapper customerVisitsMapper;
 
+    @Autowired
+    private CommonFileMapper commonFileMapper;
+
+    @Autowired
+    private TempFileServiceImpl tempFileService;
+
     @Override
-    public IPage<CustomerVisits> listPage(Page page, CustomerVisits customerVisits) {
-        LambdaQueryWrapper<CustomerVisits> customerVisitsLambdaQueryWrapper = new LambdaQueryWrapper<>();
-        if(customerVisits != null && !StringUtils.isEmpty(customerVisits.getCustomerName())){
-            customerVisitsLambdaQueryWrapper.like(CustomerVisits::getCustomerName, customerVisits.getCustomerName());
+    public IPage<CustomerVisitsDto> listPage(Page page, CustomerVisits customerVisits) {
+        IPage<CustomerVisitsDto> selectPage = customerVisitsMapper.listPage(page, customerVisits);
+        for (CustomerVisitsDto record : selectPage.getRecords()) {
+            List<CommonFile> allFiles = commonFileMapper.selectList(new LambdaQueryWrapper<CommonFile>()
+                    .eq(CommonFile::getCommonId, record.getId())
+                    .eq(CommonFile::getType, FileNameType.CUSTOMER_VISITS.getValue()));
+            record.setCommonFileList(allFiles);
         }
-        Page page1 = customerVisitsMapper.selectPage(page, customerVisitsLambdaQueryWrapper);
-        return page1;
+        return selectPage;
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean updateCustomerVisit(CustomerVisits customerVisits) {
+        if (customerVisits == null || customerVisits.getId() == null) {
+            return false;
+        }
+
+        if (StringUtils.isEmpty(customerVisits.getCustomerName())
+                || StringUtils.isEmpty(customerVisits.getPurposeVisit())
+                || StringUtils.isEmpty(customerVisits.getVisitAddress())
+                || StringUtils.isEmpty(customerVisits.getPurposeDate())) {
+            return false;
+        }
+
+        return updateById(customerVisits);
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public boolean updateCustomerVisit(CustomerVisitsDto customerVisitsDto) throws Exception {
+        CustomerVisits customerVisits = new CustomerVisits();
+        BeanUtils.copyProperties(customerVisitsDto, customerVisits);
+        boolean updateResult = updateCustomerVisit(customerVisits);
+        if (!updateResult) {
+            return false;
+        }
+
+        Long businessId = customerVisits.getId().longValue();
+        List<CommonFile> existingFiles = commonFileMapper.selectList(new LambdaQueryWrapper<CommonFile>()
+                .eq(CommonFile::getCommonId, businessId)
+                .eq(CommonFile::getType, FileNameType.CUSTOMER_VISITS.getValue()));
+        Set<Long> retainedFileIds = customerVisitsDto.getCommonFileList() == null
+                ? Collections.emptySet()
+                : customerVisitsDto.getCommonFileList().stream()
+                .map(CommonFile::getId)
+                .filter(java.util.Objects::nonNull)
+                .collect(Collectors.toSet());
+        for (CommonFile commonFile : existingFiles) {
+            if (commonFile.getId() == null || retainedFileIds.contains(commonFile.getId())) {
+                continue;
+            }
+            if (commonFile.getUrl() != null && !commonFile.getUrl().isEmpty()) {
+                Files.deleteIfExists(Paths.get(commonFile.getUrl()));
+            }
+            commonFileMapper.deleteById(commonFile.getId());
+        }
+        tempFileService.migrateTempFilesToFormal(businessId, customerVisitsDto.getTempFileIds(), FileNameType.CUSTOMER_VISITS.getValue());
+        return true;
     }
 }

--
Gitblit v1.9.3