From 1cebcbd79fd408e17aa59e434b396476e117fc1c Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期三, 22 十月 2025 18:06:00 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'
---
ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java | 46 +++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 43 insertions(+), 3 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 6d98534..5accc32 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
@@ -163,16 +163,34 @@
TMissionUser user = missionUserMapper.selectById(dto.getId());
user.setSuccessTime(new Date());
BeanUtils.copyProperties(dto, user);
- missionUserMapper.updateById(user);
+
// 判断这个任务还有正在执行的不
Long l = missionUserMapper.selectCount(new LambdaQueryWrapper<TMissionUser>().eq(TMissionUser::getMissionId, user.getMissionId()).eq(TMissionUser::getStatus, 0));
if (l == 0){
- // 全部执行完 任务完成
- this.update(new LambdaUpdateWrapper<TMission>().eq(TMission::getId, user.getMissionId()).set(TMission::getStatus, 4));
+
+ TMission tMission = this.getById(user.getMissionId());
+ tMission.setFinishTime(LocalDateTime.now());
+ // 判断是否全部完成
+ Long unSuccessCount = missionUserMapper.selectCount(new LambdaQueryWrapper<TMissionUser>().eq(TMissionUser::getMissionId, user.getMissionId()).eq(TMissionUser::getStatus, 2));
+ if(unSuccessCount>0){
+ tMission.setStatus(6);
+ }else {
+ tMission.setStatus(4);
+ }
+ LocalDateTime assignTime = tMission.getAssignTime();
+ 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);
@@ -203,6 +221,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);
@@ -226,7 +257,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