|
@@ -3,6 +3,7 @@ package com.xjrsoft.module.classtime.controller;
|
|
|
import cn.dev33.satoken.annotation.SaCheckPermission;
|
|
import cn.dev33.satoken.annotation.SaCheckPermission;
|
|
|
import cn.hutool.core.bean.BeanUtil;
|
|
import cn.hutool.core.bean.BeanUtil;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
|
import com.xjrsoft.common.exception.MyException;
|
|
import com.xjrsoft.common.exception.MyException;
|
|
|
import com.xjrsoft.common.model.result.RT;
|
|
import com.xjrsoft.common.model.result.RT;
|
|
@@ -12,9 +13,12 @@ import com.xjrsoft.common.utils.VoToColumnUtil;
|
|
|
import com.xjrsoft.module.activity.dto.ChangeStatusDto;
|
|
import com.xjrsoft.module.activity.dto.ChangeStatusDto;
|
|
|
import com.xjrsoft.module.classtime.dto.AddClassTimeStatisticsDto;
|
|
import com.xjrsoft.module.classtime.dto.AddClassTimeStatisticsDto;
|
|
|
import com.xjrsoft.module.classtime.dto.ClassTimeStatisticsPageDto;
|
|
import com.xjrsoft.module.classtime.dto.ClassTimeStatisticsPageDto;
|
|
|
|
|
+import com.xjrsoft.module.classtime.dto.RefreshStatisticsDto;
|
|
|
import com.xjrsoft.module.classtime.dto.UpdateClassTimeStatisticsDto;
|
|
import com.xjrsoft.module.classtime.dto.UpdateClassTimeStatisticsDto;
|
|
|
import com.xjrsoft.module.classtime.entity.ClassTimeStatistics;
|
|
import com.xjrsoft.module.classtime.entity.ClassTimeStatistics;
|
|
|
|
|
+import com.xjrsoft.module.classtime.entity.ClassTimeStatisticsSet;
|
|
|
import com.xjrsoft.module.classtime.service.IClassTimeStatisticsService;
|
|
import com.xjrsoft.module.classtime.service.IClassTimeStatisticsService;
|
|
|
|
|
+import com.xjrsoft.module.classtime.service.IClassTimeStatisticsSetService;
|
|
|
import com.xjrsoft.module.classtime.vo.ClassTimeStatisticsPageVo;
|
|
import com.xjrsoft.module.classtime.vo.ClassTimeStatisticsPageVo;
|
|
|
import com.xjrsoft.module.classtime.vo.ClassTimeStatisticsVo;
|
|
import com.xjrsoft.module.classtime.vo.ClassTimeStatisticsVo;
|
|
|
import io.swagger.annotations.Api;
|
|
import io.swagger.annotations.Api;
|
|
@@ -30,7 +34,10 @@ import org.springframework.web.bind.annotation.RequestParam;
|
|
|
import org.springframework.web.bind.annotation.RestController;
|
|
import org.springframework.web.bind.annotation.RestController;
|
|
|
|
|
|
|
|
import javax.validation.Valid;
|
|
import javax.validation.Valid;
|
|
|
|
|
+import java.time.LocalDate;
|
|
|
|
|
+import java.util.Date;
|
|
|
import java.util.List;
|
|
import java.util.List;
|
|
|
|
|
+import java.util.concurrent.CompletableFuture;
|
|
|
|
|
|
|
|
/**
|
|
/**
|
|
|
* @title: 课时统计
|
|
* @title: 课时统计
|
|
@@ -44,7 +51,7 @@ import java.util.List;
|
|
|
@AllArgsConstructor
|
|
@AllArgsConstructor
|
|
|
public class ClassTimeStatisticsController {
|
|
public class ClassTimeStatisticsController {
|
|
|
|
|
|
|
|
-
|
|
|
|
|
|
|
+ private final IClassTimeStatisticsSetService statisticsSetService;
|
|
|
private final IClassTimeStatisticsService classTimeStatisticsService;
|
|
private final IClassTimeStatisticsService classTimeStatisticsService;
|
|
|
|
|
|
|
|
@GetMapping(value = "/page")
|
|
@GetMapping(value = "/page")
|
|
@@ -79,9 +86,8 @@ public class ClassTimeStatisticsController {
|
|
|
@ApiOperation(value = "新增课时统计")
|
|
@ApiOperation(value = "新增课时统计")
|
|
|
@SaCheckPermission("classtimestatistics:add")
|
|
@SaCheckPermission("classtimestatistics:add")
|
|
|
public RT<Boolean> add(@Valid @RequestBody AddClassTimeStatisticsDto dto){
|
|
public RT<Boolean> add(@Valid @RequestBody AddClassTimeStatisticsDto dto){
|
|
|
- ClassTimeStatistics classTimeStatistics = BeanUtil.toBean(dto, ClassTimeStatistics.class);
|
|
|
|
|
- boolean isSuccess = classTimeStatisticsService.add(classTimeStatistics);
|
|
|
|
|
- return RT.ok(isSuccess);
|
|
|
|
|
|
|
+ boolean isSuccess = classTimeStatisticsService.add(dto);
|
|
|
|
|
+ return RT.ok(isSuccess);
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
@PutMapping
|
|
@PutMapping
|
|
@@ -91,7 +97,6 @@ public class ClassTimeStatisticsController {
|
|
|
|
|
|
|
|
ClassTimeStatistics classTimeStatistics = BeanUtil.toBean(dto, ClassTimeStatistics.class);
|
|
ClassTimeStatistics classTimeStatistics = BeanUtil.toBean(dto, ClassTimeStatistics.class);
|
|
|
return RT.ok(classTimeStatisticsService.update(classTimeStatistics));
|
|
return RT.ok(classTimeStatisticsService.update(classTimeStatistics));
|
|
|
-
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
@DeleteMapping
|
|
@DeleteMapping
|
|
@@ -115,4 +120,57 @@ public class ClassTimeStatisticsController {
|
|
|
return RT.ok(true);
|
|
return RT.ok(true);
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+ @GetMapping(value = "/last-date")
|
|
|
|
|
+ @ApiOperation(value="查询最新统计的结束日期")
|
|
|
|
|
+ @SaCheckPermission("classtimestatisticsset:detail")
|
|
|
|
|
+ public RT<LocalDate> lastInfo(){
|
|
|
|
|
+ List<ClassTimeStatistics> list = classTimeStatisticsService.list(
|
|
|
|
|
+ new QueryWrapper<ClassTimeStatistics>().lambda().orderByDesc(ClassTimeStatistics::getEndDate)
|
|
|
|
|
+ );
|
|
|
|
|
+ if (list.isEmpty()) {
|
|
|
|
|
+ return RT.error("未查询到数据");
|
|
|
|
|
+ }
|
|
|
|
|
+ ClassTimeStatistics result = list.get(0);
|
|
|
|
|
+ return RT.ok(result.getEndDate());
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @PostMapping("/refresh-statistics")
|
|
|
|
|
+ @ApiOperation(value = "刷新课时统计")
|
|
|
|
|
+ @SaCheckPermission("classtimestatistics:detail")
|
|
|
|
|
+ public RT<Boolean> refreshStatistics(@Valid @RequestBody RefreshStatisticsDto dto){
|
|
|
|
|
+
|
|
|
|
|
+ ClassTimeStatistics classTimeStatistics = classTimeStatisticsService.getById(dto.getId());
|
|
|
|
|
+ classTimeStatistics.setStatus(0);
|
|
|
|
|
+ classTimeStatistics.setModifyDate(new Date());
|
|
|
|
|
+
|
|
|
|
|
+ //查询最新权重并保存到统计中
|
|
|
|
|
+ Integer category = 1;
|
|
|
|
|
+ List<ClassTimeStatisticsSet> list = statisticsSetService.list(
|
|
|
|
|
+ new QueryWrapper<ClassTimeStatisticsSet>().lambda()
|
|
|
|
|
+ .eq(ClassTimeStatisticsSet::getCategory, category)
|
|
|
|
|
+ .orderByDesc(ClassTimeStatisticsSet::getCreateDate)
|
|
|
|
|
+ );
|
|
|
|
|
+ if(!list.isEmpty()){
|
|
|
|
|
+ classTimeStatistics.setWeightSetJson(list.get(0).getJsonContent());
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ //查询最新费用并保存到统计中
|
|
|
|
|
+ category = 2;
|
|
|
|
|
+ list = statisticsSetService.list(
|
|
|
|
|
+ new QueryWrapper<ClassTimeStatisticsSet>().lambda()
|
|
|
|
|
+ .eq(ClassTimeStatisticsSet::getCategory, category)
|
|
|
|
|
+ .orderByDesc(ClassTimeStatisticsSet::getCreateDate)
|
|
|
|
|
+ );
|
|
|
|
|
+ if(!list.isEmpty()){
|
|
|
|
|
+ classTimeStatistics.setCostSetJson(list.get(0).getJsonContent());
|
|
|
|
|
+ }
|
|
|
|
|
+ Boolean aBoolean = classTimeStatisticsService.save(classTimeStatistics);
|
|
|
|
|
+
|
|
|
|
|
+ CompletableFuture.runAsync(() -> {
|
|
|
|
|
+ classTimeStatisticsService.refreshRecord(classTimeStatistics);
|
|
|
|
|
+ });
|
|
|
|
|
+
|
|
|
|
|
+ return RT.ok(aBoolean);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
}
|
|
}
|