From 983101b33da69e1f2372b4fa0af34cacd9423b15 Mon Sep 17 00:00:00 2001
From: liujie <1793218484@qq.com>
Date: 星期四, 23 十月 2025 13:50:47 +0800
Subject: [PATCH] 指派

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java |   53 ++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 44 insertions(+), 9 deletions(-)

diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java
index db92bbd..a981fbf 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java
@@ -12,14 +12,8 @@
 import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.system.dto.EquipmentDto;
 import com.ruoyi.system.dto.TMissionUserDto;
-import com.ruoyi.system.mapper.TAppUserEquipmentMapper;
-import com.ruoyi.system.mapper.TMissionAssignRuleMapper;
-import com.ruoyi.system.mapper.TMissionMapper;
-import com.ruoyi.system.mapper.TMissionUserMapper;
-import com.ruoyi.system.model.TAppUserEquipment;
-import com.ruoyi.system.model.TMission;
-import com.ruoyi.system.model.TMissionAssignRule;
-import com.ruoyi.system.model.TMissionUser;
+import com.ruoyi.system.mapper.*;
+import com.ruoyi.system.model.*;
 import com.ruoyi.system.query.TMissionQuery;
 import com.ruoyi.system.service.TMissionService;
 import com.ruoyi.system.vo.MissionTotalVo;
@@ -28,6 +22,7 @@
 import com.ruoyi.system.vo.TotalHistoryVo;
 import org.springframework.beans.BeanUtils;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.CollectionUtils;
 
 import java.text.SimpleDateFormat;
@@ -64,6 +59,11 @@
 
     @Resource
     private TMissionAssignRuleMapper missionAssignRuleMapper;
+
+
+    @Resource
+    private TAppUserMapper appUserMapper;
+
 
     @Override
     public PageInfo<TMissionVO> pageListAssigned(TMissionQuery query) {
@@ -159,11 +159,17 @@
     }
 
     @Override
+    @Transactional(rollbackFor = Exception.class)
     public void successMission(TMissionUserDto dto, String userId) {
         TMissionUser user = missionUserMapper.selectById(dto.getId());
         user.setSuccessTime(new Date());
         BeanUtils.copyProperties(dto, user);
-        missionUserMapper.updateById(user);
+        String appUserId = user.getAppUserId();
+
+        TAppUser tAppUser = appUserMapper.selectById(appUserId);
+        tAppUser.setMissionState(1);
+        appUserMapper.updateById(tAppUser);
+
         // 判断这个任务还有正在执行的不
         Long l = missionUserMapper.selectCount(new LambdaQueryWrapper<TMissionUser>().eq(TMissionUser::getMissionId, user.getMissionId()).eq(TMissionUser::getStatus, 0));
         if (l == 0){
@@ -181,9 +187,16 @@
             tMission.setSuccessTime((double) Duration.between(assignTime, tMission.getFinishTime()).toHours());
             this.updateById(tMission);
         }
+
+
+
         // 更新装备
         TAppUserEquipment tAppUserEquipment = appUserEquipmentMapper.selectOne(new LambdaQueryWrapper<TAppUserEquipment>().eq(TAppUserEquipment::getAppUserId, userId).eq(TAppUserEquipment::getAppUserId, userId));
+
         if (Objects.nonNull(tAppUserEquipment)) {
+
+            String equipmentCount1 = tAppUserEquipment.getEquipmentCount();
+            List<EquipmentDto> dtos = JSONArray.parseArray(equipmentCount1, EquipmentDto.class);
             String lossText = dto.getLossText();
             String victoryText = dto.getVictoryText();
             List<EquipmentDto> victoryTextDtos = JSONArray.parseArray(victoryText, EquipmentDto.class);
@@ -214,6 +227,19 @@
             EquipmentDtoList.addAll(notHaveEquipment);
             tAppUserEquipment.setEquipmentCount(JSON.toJSONString(EquipmentDtoList));
             appUserEquipmentMapper.updateById(tAppUserEquipment);
+
+
+            int winSum = victoryTextDtos.stream().filter(e -> !e.getId().equals("0")).mapToInt(EquipmentDto::getCount).sum();
+            int oldSum = dtos.stream().mapToInt(EquipmentDto::getCount).sum();
+            winSum = winSum + oldSum;
+            int lossSum = lossTextDtos.stream().filter(e -> !e.getId().equals("0")).mapToInt(EquipmentDto::getCount).sum();
+            if(winSum!=0){
+                user.setDamageRate(new BigDecimal(lossSum).divide(BigDecimal.valueOf(winSum), 4, BigDecimal.ROUND_HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.HALF_UP).doubleValue());
+            }
+
+
+
+
         } else {
             tAppUserEquipment = new TAppUserEquipment();
             tAppUserEquipment.setAppUserId(userId);
@@ -237,7 +263,16 @@
             }
             tAppUserEquipment.setEquipmentCount(JSON.toJSONString(victoryTextDtos));
             appUserEquipmentMapper.insert(tAppUserEquipment);
+
+            int winSum = victoryTextDtos.stream().filter(e -> !e.getId().equals("0")).mapToInt(EquipmentDto::getCount).sum();
+            int lossSum = lossTextDtos.stream().filter(e -> !e.getId().equals("0")).mapToInt(EquipmentDto::getCount).sum();
+            if(winSum!=0){
+                user.setDamageRate(new BigDecimal(lossSum).divide(BigDecimal.valueOf(winSum), 4, BigDecimal.ROUND_HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.HALF_UP).doubleValue());
+            }
+
         }
+
+        missionUserMapper.updateById(user);
     }
 
     @Override

--
Gitblit v1.7.1