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-admin/src/main/java/com/ruoyi/web/controller/api/TAppUserController.java        |   25 +++---
 ruoyi-system/src/main/java/com/ruoyi/system/vo/IndexDataRankVo.java                   |    2 
 ruoyi-system/src/main/java/com/ruoyi/system/vo/IndexDataVo.java                       |    2 
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TDataStatisticsController.java |  153 ++++++++++++++++++++++++++++++++++++--
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java     |   31 +++++++
 ruoyi-framework/src/main/java/com/ruoyi/framework/config/SecurityConfig.java          |    2 
 ruoyi-system/src/main/java/com/ruoyi/system/model/TMissionUser.java                   |    5 +
 7 files changed, 196 insertions(+), 24 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppUserController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppUserController.java
index 76759bf..86cedca 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppUserController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppUserController.java
@@ -2,32 +2,21 @@
 
 
 import com.alibaba.fastjson2.JSON;
-import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.framework.web.service.TokenService;
 import com.ruoyi.system.dto.AuditUserDto;
-import com.ruoyi.system.dto.TAppUserDTO;
 import com.ruoyi.system.dto.UpAndDownDTO;
 import com.ruoyi.system.dto.UserIdDto;
 import com.ruoyi.system.model.TAppUser;
-import com.ruoyi.system.model.TUserMajor;
 import com.ruoyi.system.query.TAppUserQuery;
 import com.ruoyi.system.service.TAppUserService;
-import com.ruoyi.system.service.TUserMajorService;
 import com.ruoyi.system.vo.TAppUserPageVo;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.util.CollectionUtils;
-import org.springframework.util.StringUtils;
-import org.springframework.web.bind.annotation.PostMapping;
-import org.springframework.web.bind.annotation.RequestBody;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
-
-import java.util.List;
+import org.springframework.web.bind.annotation.*;
 
 /**
  * <p>
@@ -211,6 +200,18 @@
     }
 
 
+    /**
+     * 详情
+     */
+    //    @PreAuthorize("@ss.hasPermi('system:user:auditUser')")
+    @ApiOperation(value = "人员详情", response = AuditUserDto.class)
+    @GetMapping(value = "/api/t-app-user/detailUser")
+    public R<TAppUser> detailUser(@RequestBody String param) {
+        UserIdDto dto = JSON.parseObject(param, UserIdDto.class);
+        TAppUser tAppUser = appUserService.getById(dto.getId());
+        return R.ok(tAppUser);
+    }
+
 
 }
 
diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TDataStatisticsController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TDataStatisticsController.java
index 6076a3c..1f6dd6b 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TDataStatisticsController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TDataStatisticsController.java
@@ -1,12 +1,17 @@
 package com.ruoyi.web.controller.api;
 
 
+import com.alibaba.fastjson2.JSONArray;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.framework.web.service.TokenService;
-import com.ruoyi.system.model.TMission;
-import com.ruoyi.system.service.TMissionService;
+import com.ruoyi.system.dto.EquipmentDto;
+import com.ruoyi.system.model.*;
+import com.ruoyi.system.service.*;
 import com.ruoyi.system.vo.IndexDataDetailVo;
+import com.ruoyi.system.vo.IndexDataRankVo;
 import com.ruoyi.system.vo.IndexDataVo;
+import com.tencentcloudapi.iot.v20180123.models.AppUser;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -20,8 +25,12 @@
 import java.time.LocalDate;
 import java.time.LocalDateTime;
 import java.util.ArrayList;
+import java.util.Comparator;
 import java.util.List;
+import java.util.Map;
 import java.util.stream.Collectors;
+
+import static java.util.stream.Collectors.groupingBy;
 
 /**
  * <p>
@@ -38,14 +47,26 @@
 
     private final TMissionService missionService;
     private final TokenService tokenService;
+    private final TMissionUserService missionUserService;
+    private final TAppUserService appUserService;
+    private final TDivisionTeamService divisionTeamService;
+    private final TMissionAssignRuleService missionReassignService;
+    private final TAppUserEquipmentService appUserEquipmentService;
+    private final TEquipmentService equipmentService;
     @Autowired
-    public TDataStatisticsController( TMissionService missionService, TokenService tokenService) {
+    public TDataStatisticsController(TMissionService missionService, TokenService tokenService, TMissionUserService missionUserService, TAppUserService appUserService, TDivisionTeamService divisionTeamService, TMissionAssignRuleService missionReassignService1, TAppUserEquipmentService appUserEquipmentService, TEquipmentService equipmentService) {
         this.missionService = missionService;
         this.tokenService = tokenService;
+        this.missionUserService = missionUserService;
+        this.appUserService = appUserService;
+        this.divisionTeamService = divisionTeamService;
+        this.missionReassignService = missionReassignService1;
+        this.appUserEquipmentService = appUserEquipmentService;
+        this.equipmentService = equipmentService;
     }
 
-    @ApiOperation(value = "获取数据")
-    @GetMapping(value = "/api/t-data-statistics/getData")
+    @ApiOperation(value = "获取数据-第一部分")
+    @GetMapping(value = "/open/t-data-statistics/getData")
     public R<IndexDataVo> getData() {
         IndexDataVo indexDataVo = new IndexDataVo();
         List<TMission> list = missionService.list();
@@ -87,17 +108,131 @@
 
 
         List<TMission> tMissions1 = list.stream().filter(e -> e.getFinishTime() != null).collect(Collectors.toList());
-        long count = tMissions1.stream().filter(e -> e.getStatus() == 4).count();
-        String finishRate = new BigDecimal(count).divide(new BigDecimal(tMissions1.size()), 4, BigDecimal.ROUND_HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.HALF_UP).toString();
-        indexDataVo.setFinishRate(finishRate);
+        if(!tMissions1.isEmpty()){
+            long count = tMissions1.stream().filter(e -> e.getStatus() == 4).count();
+            String finishRate = new BigDecimal(count).divide(new BigDecimal(tMissions1.size()), 4, BigDecimal.ROUND_HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.HALF_UP).toString();
+            indexDataVo.setFinishRate(finishRate);
+        }
+
 
         double avgFinishTime = tMissions1.stream().mapToDouble(TMission::getSuccessTime).average().orElse(0);
         indexDataVo.setAvgFinishTime(String.valueOf(avgFinishTime));
 
         // 平了分的
         List<TMission> tMissions2 = list.stream().filter(e -> e.getAddressScore() != null ).collect(Collectors.toList());
-        long count1 = tMissions2.stream().filter(e -> e.getTimeScore() + e.getAddressScore() + e.getPersonCountScore() + e.getEquipmentScore() + e.getAttemptScore() > 30).count();
+        if(!tMissions2.isEmpty()){
+            long count1 = tMissions2.stream().filter(e -> e.getTimeScore() + e.getAddressScore() + e.getPersonCountScore() + e.getEquipmentScore() + e.getAttemptScore() > 30).count();
+            String enemyAccuracyRate = new BigDecimal(count1).divide(new BigDecimal(tMissions2.size()), 4, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.HALF_UP).toString();
+            indexDataVo.setEnemyAccuracyRate(enemyAccuracyRate);
+        }
 
+        List<TMissionUser> list1 = missionUserService.list(new LambdaQueryWrapper<TMissionUser>().eq(TMissionUser::getUserType, 1).isNotNull(TMissionUser::getSuccessTime));
+        if(!list1.isEmpty()){
+            double setDamageRate = list1.stream().mapToDouble(TMissionUser::getDamageRate).average().orElse(0);
+            indexDataVo.setDamageRate(String.valueOf(setDamageRate));
+        }
+
+        return R.ok(indexDataVo);
+    }
+
+    @ApiOperation(value = "获取数据-第二部分")
+    @GetMapping(value = "/open/t-data-statistics/getDataTwo")
+    public R<IndexDataVo> getDataTwo() {
+        IndexDataVo indexDataVo = new IndexDataVo();
+        List<TMission> listAll = missionService.list();
+
+        List<TMission> list = listAll.stream().filter(item -> item.getStatus() == 4).collect(Collectors.toList());
+        if(listAll.isEmpty()){
+            return R.ok(indexDataVo);
+        }
+
+        if (!list.isEmpty()) {
+            List<String> missionIds = list.stream().map(TMission::getId).collect(Collectors.toList());
+            List<TMissionUser> missionUsers = missionUserService.list(new LambdaQueryWrapper<TMissionUser>().in(TMissionUser::getMissionId, missionIds));
+            List<String> userIds = missionUsers.stream().map(TMissionUser::getAppUserId).collect(Collectors.toList());
+            List<TAppUser> appUsers = appUserService.list(new LambdaQueryWrapper<TAppUser>().in(TAppUser::getId, userIds));
+            Map<String, List<TAppUser>> collect = appUsers.stream().collect(groupingBy(TAppUser::getTeamId));
+
+            ArrayList<IndexDataRankVo> indexDataRankVos = new ArrayList<>();
+            for (Map.Entry<String, List<TAppUser>> entry : collect.entrySet()) {
+                IndexDataRankVo indexDataRankVo = new IndexDataRankVo();
+                indexDataRankVo.setId(entry.getKey());
+                List<String> userIds1 = entry.getValue().stream().map(TAppUser::getId).collect(Collectors.toList());
+                long count = missionUsers.stream().filter(e -> userIds1.contains(e.getAppUserId())).count();
+                indexDataRankVo.setCount((int) count);
+                indexDataRankVos.add(indexDataRankVo);
+            }
+            List<String> teamIds = indexDataRankVos.stream().map(IndexDataRankVo::getId).collect(Collectors.toList());
+            List<TDivisionTeam> list2 = divisionTeamService.list(new LambdaQueryWrapper<TDivisionTeam>().in(TDivisionTeam::getId, teamIds));
+            indexDataRankVos.forEach(e -> {
+                TDivisionTeam tDivisionTeam = list2.stream().filter(s -> s.getId().equals(e.getId())).findFirst().get();
+                e.setName(tDivisionTeam.getTeamName());
+            });
+
+            // indexDataRankVos取出count排名前5的 若没有5个全取
+            if(indexDataRankVos.size()>5){
+                List<IndexDataRankVo> collect1 = indexDataRankVos.stream().sorted(Comparator.comparingInt(IndexDataRankVo::getCount).reversed()).limit(5).collect(Collectors.toList());
+                indexDataVo.setRank(collect1);
+            }else {
+                List<IndexDataRankVo> collect1 = indexDataRankVos.stream().sorted(Comparator.comparingInt(IndexDataRankVo::getCount).reversed()).collect(Collectors.toList());
+                indexDataVo.setRank(collect1);
+            }
+
+        }
+
+
+        Map<String, List<TMission>> collect = listAll.stream().collect(groupingBy(TMission::getMissionTypeId));
+
+        List<IndexDataRankVo> indexDataDetailVos = new ArrayList<>();
+        for (Map.Entry<String, List<TMission>> entry : collect.entrySet()) {
+            IndexDataRankVo indexDataDetailVo = new IndexDataRankVo();
+            indexDataDetailVo.setId(entry.getKey());
+            indexDataDetailVo.setCount(entry.getValue().size());
+            indexDataDetailVos.add(indexDataDetailVo);
+        }
+        if(!indexDataDetailVos.isEmpty()){
+            List<String> typeIds = indexDataDetailVos.stream().map(IndexDataRankVo::getId).collect(Collectors.toList());
+            List<TMissionAssignRule> tMissionAssignRules = missionReassignService.list(new LambdaQueryWrapper<TMissionAssignRule>().in(TMissionAssignRule::getId, typeIds));
+            indexDataDetailVos.forEach(e -> {
+                TMissionAssignRule tMissionAssignRule = tMissionAssignRules.stream().filter(s -> s.getId().equals(e.getId())).findFirst().get();
+                e.setName(tMissionAssignRule.getTypeName());
+            });
+
+        }
+        indexDataVo.setMissionType(indexDataDetailVos);
+
+
+        // 装备库统计
+        List<TAppUserEquipment> list1 = appUserEquipmentService.list();
+        ArrayList<EquipmentDto> equipmentDtos = new ArrayList<>();
+
+        if (!list1.isEmpty()) {
+            List<String> equipments = list1.stream().map(TAppUserEquipment::getEquipmentCount).collect(Collectors.toList());
+            for (String equipment : equipments) {
+                List<EquipmentDto> dtos = JSONArray.parseArray(equipment, EquipmentDto.class);
+                dtos =  dtos.stream().filter(e->!e.getId().equals("0")).collect(Collectors.toList());
+                equipmentDtos.addAll(dtos);
+            }
+        }
+        Map<String, List<EquipmentDto>> listMap = equipmentDtos.stream().collect(groupingBy(EquipmentDto::getId));
+        List<IndexDataRankVo> indexDataRankVos = new ArrayList<>();
+        for (Map.Entry<String, List<EquipmentDto>> entry : listMap.entrySet()) {
+            IndexDataRankVo indexDataRankVo = new IndexDataRankVo();
+            indexDataRankVo.setId(entry.getKey());
+            indexDataRankVo.setCount(entry.getValue().stream().mapToInt(EquipmentDto::getCount).sum());
+            indexDataRankVos.add(indexDataRankVo);
+        }
+        if(!indexDataRankVos.isEmpty()){
+            List<String> equipIds = indexDataRankVos.stream().map(IndexDataRankVo::getId).collect(Collectors.toList());
+            List<TEquipment> equipmentList = equipmentService.list(new LambdaQueryWrapper<TEquipment>().in(TEquipment::getId, equipIds));
+            indexDataRankVos.forEach(e -> {
+                TEquipment tEquipment = equipmentList.stream().filter(s -> s.getId().equals(e.getId())).findFirst().orElse(null);
+                if(tEquipment!=null){
+                    e.setName(tEquipment.getEquipmentName());
+                }
+            });
+        }
+        indexDataVo.setEquip(indexDataRankVos);
 
 
         return R.ok(indexDataVo);
diff --git a/ruoyi-framework/src/main/java/com/ruoyi/framework/config/SecurityConfig.java b/ruoyi-framework/src/main/java/com/ruoyi/framework/config/SecurityConfig.java
index b9902a4..5bb0e02 100644
--- a/ruoyi-framework/src/main/java/com/ruoyi/framework/config/SecurityConfig.java
+++ b/ruoyi-framework/src/main/java/com/ruoyi/framework/config/SecurityConfig.java
@@ -118,7 +118,7 @@
                         "/applet/changepwd", "/captchaImage","/getCode","/loginCode",
                         "/operations/getBySingleNum/**",
                         "/user/getUserInfoByNumber/**",
-                        "/wxLogin/**","/cos/get/**","/t-mission/**","/api/t-app-user/**","/open/file/**"
+                        "/wxLogin/**","/cos/get/**","/t-mission/**","/api/t-app-user/**","/open/file/**","/open/t-data-statistics/**"
                 ).permitAll()
                 // 静态资源,可匿名访问
                 .antMatchers(HttpMethod.GET, "/", "/*.html", "/**/*.html", "/**/*.css", "/**/*.js", "/profile/**").permitAll()
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/model/TMissionUser.java b/ruoyi-system/src/main/java/com/ruoyi/system/model/TMissionUser.java
index cce64b8..94de192 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/model/TMissionUser.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/model/TMissionUser.java
@@ -88,4 +88,9 @@
     @ApiModelProperty(value = "接受时间")
     @TableField("accept_time")
     private LocalDateTime acceptTime;
+
+
+    @ApiModelProperty(value = "战损率")
+    @TableField("damage_rate")
+    private Double damageRate;
 }
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..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,7 +163,7 @@
         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){
@@ -181,9 +181,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 +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);
@@ -237,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
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/vo/IndexDataRankVo.java b/ruoyi-system/src/main/java/com/ruoyi/system/vo/IndexDataRankVo.java
index a72a9f8..921aef5 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/vo/IndexDataRankVo.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/vo/IndexDataRankVo.java
@@ -9,4 +9,6 @@
     private String name;
 
     private Integer count;
+
+    private String id;
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/vo/IndexDataVo.java b/ruoyi-system/src/main/java/com/ruoyi/system/vo/IndexDataVo.java
index c62d93e..b0da02b 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/vo/IndexDataVo.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/vo/IndexDataVo.java
@@ -46,7 +46,7 @@
     private String damageRate="0";
 
     @ApiModelProperty("敌情准确率")
-    private String enemyAccuracy="0";
+    private String enemyAccuracyRate="0";
 
     @ApiModelProperty("本月分队排名")
     private List<IndexDataRankVo> rank;

--
Gitblit v1.7.1