|
@@ -1,8 +1,7 @@
|
|
|
package cn.iocoder.yudao.module.crm.service.statistics;
|
|
|
|
|
|
import cn.hutool.core.collection.CollUtil;
|
|
|
-import cn.hutool.core.collection.ListUtil;
|
|
|
-import cn.hutool.core.date.DateUtil;
|
|
|
+import cn.hutool.core.date.LocalDateTimeUtil;
|
|
|
import cn.hutool.core.util.ObjUtil;
|
|
|
import cn.iocoder.yudao.module.crm.controller.admin.statistics.vo.performance.CrmStatisticsPerformanceReqVO;
|
|
|
import cn.iocoder.yudao.module.crm.controller.admin.statistics.vo.performance.CrmStatisticsPerformanceRespVO;
|
|
@@ -11,15 +10,14 @@ import cn.iocoder.yudao.module.system.api.dept.DeptApi;
|
|
|
import cn.iocoder.yudao.module.system.api.dept.dto.DeptRespDTO;
|
|
|
import cn.iocoder.yudao.module.system.api.user.AdminUserApi;
|
|
|
import cn.iocoder.yudao.module.system.api.user.dto.AdminUserRespDTO;
|
|
|
-import jakarta.annotation.Resource;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
import org.springframework.validation.annotation.Validated;
|
|
|
|
|
|
+import jakarta.annotation.Resource;
|
|
|
+
|
|
|
import java.math.BigDecimal;
|
|
|
-import java.util.ArrayList;
|
|
|
-import java.util.Collections;
|
|
|
-import java.util.List;
|
|
|
-import java.util.Map;
|
|
|
+import java.time.LocalDateTime;
|
|
|
+import java.util.*;
|
|
|
import java.util.function.Function;
|
|
|
|
|
|
import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertList;
|
|
@@ -69,7 +67,7 @@ public class CrmStatisticsPerformanceServiceImpl implements CrmStatisticsPerform
|
|
|
* @return 员工业绩数据
|
|
|
*/
|
|
|
private List<CrmStatisticsPerformanceRespVO> getPerformance(CrmStatisticsPerformanceReqVO performanceReqVO,
|
|
|
- Function<CrmStatisticsPerformanceReqVO, List<CrmStatisticsPerformanceRespVO>> performanceFunction) {
|
|
|
+ Function<CrmStatisticsPerformanceReqVO, List<CrmStatisticsPerformanceRespVO>> performanceFunction) {
|
|
|
|
|
|
|
|
|
List<Long> userIds = getUserIds(performanceReqVO);
|
|
@@ -79,13 +77,17 @@ public class CrmStatisticsPerformanceServiceImpl implements CrmStatisticsPerform
|
|
|
performanceReqVO.setUserIds(userIds);
|
|
|
|
|
|
|
|
|
+ int year = Integer.parseInt(LocalDateTimeUtil.format(performanceReqVO.getTimes()[0],"yyyy"));
|
|
|
+ LocalDateTime[] timesRange = performanceReqVO.getTimes();
|
|
|
+ timesRange[0] = performanceReqVO.getTimes()[0].minusYears(1);
|
|
|
+ timesRange[1] = performanceReqVO.getTimes()[1];
|
|
|
+ performanceReqVO.setTimes(timesRange);
|
|
|
List<CrmStatisticsPerformanceRespVO> performanceList = performanceFunction.apply(performanceReqVO);
|
|
|
Map<String, BigDecimal> performanceMap = convertMap(performanceList, CrmStatisticsPerformanceRespVO::getTime,
|
|
|
CrmStatisticsPerformanceRespVO::getCurrentMonthCount);
|
|
|
|
|
|
|
|
|
List<CrmStatisticsPerformanceRespVO> result = new ArrayList<>();
|
|
|
- int year = DateUtil.thisYear();
|
|
|
for (int month = 1; month <= 12; month++) {
|
|
|
String currentMonth = String.format("%d%02d", year, month);
|
|
|
String lastMonth = month == 1 ? String.format("%d%02d", year - 1, 12) : String.format("%d%02d", year, month - 1);
|
|
@@ -107,7 +109,7 @@ public class CrmStatisticsPerformanceServiceImpl implements CrmStatisticsPerform
|
|
|
private List<Long> getUserIds(CrmStatisticsPerformanceReqVO reqVO) {
|
|
|
|
|
|
if (ObjUtil.isNotNull(reqVO.getUserId())) {
|
|
|
- return ListUtil.of(reqVO.getUserId());
|
|
|
+ return List.of(reqVO.getUserId());
|
|
|
}
|
|
|
|
|
|
|