lyhzzz před 3 dny
rodič
revize
3e8aeef9db

+ 3 - 0
src/main/java/com/fdkankan/fusion/entity/CaseFusion.java

@@ -75,4 +75,7 @@ public class CaseFusion implements Serializable {
 
     @TableField("offline_end_time")
     private String offlineEndTime;
+
+    @TableField(exist = false)
+    private String cover;
 }

+ 3 - 0
src/main/java/com/fdkankan/fusion/service/ICaseSettingsService.java

@@ -3,6 +3,7 @@ package com.fdkankan.fusion.service;
 import com.fdkankan.fusion.entity.CaseSettings;
 import com.baomidou.mybatisplus.extension.service.IService;
 
+import java.util.HashMap;
 import java.util.List;
 
 /**
@@ -16,4 +17,6 @@ import java.util.List;
 public interface ICaseSettingsService extends IService<CaseSettings> {
 
     List<CaseSettings> getByFusionId(Integer caseId);
+
+    HashMap<Integer, CaseSettings> getByFusionIds(List<Integer> fusionIds);
 }

+ 10 - 0
src/main/java/com/fdkankan/fusion/service/impl/CaseFusionServiceImpl.java

@@ -53,6 +53,8 @@ public class CaseFusionServiceImpl extends ServiceImpl<ICaseFusionMapper, CaseFu
     LaserClient laserClient;
     @Autowired
     ISceneFileBuildService sceneFileBuildService;
+    @Autowired
+    ICaseSettingsService settingsService;
 
 
     @Override
@@ -70,6 +72,14 @@ public class CaseFusionServiceImpl extends ServiceImpl<ICaseFusionMapper, CaseFu
         }
         wrapper.orderByDesc(CaseFusion::getFusionId);
         Page<CaseFusion> page = this.page(new Page<>(param.getPageNum(), param.getPageSize()), wrapper);
+        List<Integer> fusionIds = page.getRecords().stream().map(CaseFusion::getFusionId).collect(Collectors.toList());
+        HashMap<Integer,CaseSettings> map = settingsService.getByFusionIds(fusionIds);
+        for (CaseFusion record : page.getRecords()) {
+            CaseSettings caseSettings = map.get(record.getFusionId());
+            if(caseSettings !=null){
+                record.setCover(caseSettings.getCover());
+            }
+        }
         return PageInfo.PageInfo(page);
     }
 

+ 12 - 0
src/main/java/com/fdkankan/fusion/service/impl/CaseSettingsServiceImpl.java

@@ -48,4 +48,16 @@ public class CaseSettingsServiceImpl extends ServiceImpl<ICaseSettingsMapper, Ca
 
         return list;
     }
+
+    @Override
+    public HashMap<Integer, CaseSettings> getByFusionIds(List<Integer> fusionIds) {
+        HashMap<Integer, CaseSettings> map = new HashMap<>();
+        if(fusionIds!=null && !fusionIds.isEmpty()){
+            LambdaQueryWrapper<CaseSettings> wrapper = new LambdaQueryWrapper<>();
+            wrapper.in(CaseSettings::getFusionId,fusionIds);
+            List<CaseSettings> list = this.list(wrapper);
+            list.forEach(e -> map.put(e.getFusionId(),e));
+        }
+        return map;
+    }
 }