|
@@ -0,0 +1,118 @@
|
|
|
|
|
+package com.xjrsoft.module.classtime.controller;
|
|
|
|
|
+
|
|
|
|
|
+import cn.dev33.satoken.annotation.SaCheckPermission;
|
|
|
|
|
+import cn.hutool.core.bean.BeanUtil;
|
|
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
|
|
+import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
|
|
|
+import com.xjrsoft.common.exception.MyException;
|
|
|
|
|
+import com.xjrsoft.common.model.result.RT;
|
|
|
|
|
+import com.xjrsoft.common.page.ConventPage;
|
|
|
|
|
+import com.xjrsoft.common.page.PageOutput;
|
|
|
|
|
+import com.xjrsoft.common.utils.VoToColumnUtil;
|
|
|
|
|
+import com.xjrsoft.module.activity.dto.ChangeStatusDto;
|
|
|
|
|
+import com.xjrsoft.module.classtime.dto.AddClassTimeStatisticsDto;
|
|
|
|
|
+import com.xjrsoft.module.classtime.dto.ClassTimeStatisticsPageDto;
|
|
|
|
|
+import com.xjrsoft.module.classtime.dto.UpdateClassTimeStatisticsDto;
|
|
|
|
|
+import com.xjrsoft.module.classtime.entity.ClassTimeStatistics;
|
|
|
|
|
+import com.xjrsoft.module.classtime.service.IClassTimeStatisticsService;
|
|
|
|
|
+import com.xjrsoft.module.classtime.vo.ClassTimeStatisticsPageVo;
|
|
|
|
|
+import com.xjrsoft.module.classtime.vo.ClassTimeStatisticsVo;
|
|
|
|
|
+import io.swagger.annotations.Api;
|
|
|
|
|
+import io.swagger.annotations.ApiOperation;
|
|
|
|
|
+import lombok.AllArgsConstructor;
|
|
|
|
|
+import org.springframework.web.bind.annotation.DeleteMapping;
|
|
|
|
|
+import org.springframework.web.bind.annotation.GetMapping;
|
|
|
|
|
+import org.springframework.web.bind.annotation.PostMapping;
|
|
|
|
|
+import org.springframework.web.bind.annotation.PutMapping;
|
|
|
|
|
+import org.springframework.web.bind.annotation.RequestBody;
|
|
|
|
|
+import org.springframework.web.bind.annotation.RequestMapping;
|
|
|
|
|
+import org.springframework.web.bind.annotation.RequestParam;
|
|
|
|
|
+import org.springframework.web.bind.annotation.RestController;
|
|
|
|
|
+
|
|
|
|
|
+import javax.validation.Valid;
|
|
|
|
|
+import java.util.List;
|
|
|
|
|
+
|
|
|
|
|
+/**
|
|
|
|
|
+* @title: 课时统计
|
|
|
|
|
+* @Author dzx
|
|
|
|
|
+* @Date: 2024-09-26
|
|
|
|
|
+* @Version 1.0
|
|
|
|
|
+*/
|
|
|
|
|
+@RestController
|
|
|
|
|
+@RequestMapping("/classtime" + "/classTimeStatistics")
|
|
|
|
|
+@Api(value = "/classtime" + "/classTimeStatistics",tags = "课时统计代码")
|
|
|
|
|
+@AllArgsConstructor
|
|
|
|
|
+public class ClassTimeStatisticsController {
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ private final IClassTimeStatisticsService classTimeStatisticsService;
|
|
|
|
|
+
|
|
|
|
|
+ @GetMapping(value = "/page")
|
|
|
|
|
+ @ApiOperation(value="课时统计列表(分页)")
|
|
|
|
|
+ @SaCheckPermission("classtimestatistics:detail")
|
|
|
|
|
+ public RT<PageOutput<ClassTimeStatisticsPageVo>> page(@Valid ClassTimeStatisticsPageDto dto){
|
|
|
|
|
+
|
|
|
|
|
+ LambdaQueryWrapper<ClassTimeStatistics> queryWrapper = new LambdaQueryWrapper<>();
|
|
|
|
|
+ queryWrapper
|
|
|
|
|
+ .orderByDesc(ClassTimeStatistics::getId)
|
|
|
|
|
+ .eq(dto.getYear() != null, ClassTimeStatistics::getYear, dto.getYear())
|
|
|
|
|
+ .eq(dto.getMonth() != null, ClassTimeStatistics::getMonth, dto.getMonth())
|
|
|
|
|
+ .select(ClassTimeStatistics.class,x -> VoToColumnUtil.fieldsToColumns(ClassTimeStatisticsPageVo.class).contains(x.getProperty()));
|
|
|
|
|
+ IPage<ClassTimeStatistics> page = classTimeStatisticsService.page(ConventPage.getPage(dto), queryWrapper);
|
|
|
|
|
+ PageOutput<ClassTimeStatisticsPageVo> pageOutput = ConventPage.getPageOutput(page, ClassTimeStatisticsPageVo.class);
|
|
|
|
|
+ return RT.ok(pageOutput);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @GetMapping(value = "/info")
|
|
|
|
|
+ @ApiOperation(value="根据id查询课时统计信息")
|
|
|
|
|
+ @SaCheckPermission("classtimestatistics:detail")
|
|
|
|
|
+ public RT<ClassTimeStatisticsVo> info(@RequestParam Long id){
|
|
|
|
|
+ ClassTimeStatistics classTimeStatistics = classTimeStatisticsService.getByIdDeep(id);
|
|
|
|
|
+ if (classTimeStatistics == null) {
|
|
|
|
|
+ return RT.error("找不到此数据!");
|
|
|
|
|
+ }
|
|
|
|
|
+ return RT.ok(BeanUtil.toBean(classTimeStatistics, ClassTimeStatisticsVo.class));
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ @PostMapping
|
|
|
|
|
+ @ApiOperation(value = "新增课时统计")
|
|
|
|
|
+ @SaCheckPermission("classtimestatistics:add")
|
|
|
|
|
+ public RT<Boolean> add(@Valid @RequestBody AddClassTimeStatisticsDto dto){
|
|
|
|
|
+ ClassTimeStatistics classTimeStatistics = BeanUtil.toBean(dto, ClassTimeStatistics.class);
|
|
|
|
|
+ boolean isSuccess = classTimeStatisticsService.add(classTimeStatistics);
|
|
|
|
|
+ return RT.ok(isSuccess);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @PutMapping
|
|
|
|
|
+ @ApiOperation(value = "修改课时统计")
|
|
|
|
|
+ @SaCheckPermission("classtimestatistics:edit")
|
|
|
|
|
+ public RT<Boolean> update(@Valid @RequestBody UpdateClassTimeStatisticsDto dto){
|
|
|
|
|
+
|
|
|
|
|
+ ClassTimeStatistics classTimeStatistics = BeanUtil.toBean(dto, ClassTimeStatistics.class);
|
|
|
|
|
+ return RT.ok(classTimeStatisticsService.update(classTimeStatistics));
|
|
|
|
|
+
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @DeleteMapping
|
|
|
|
|
+ @ApiOperation(value = "删除课时统计")
|
|
|
|
|
+ @SaCheckPermission("classtimestatistics:delete")
|
|
|
|
|
+ public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
|
|
|
|
|
+ return RT.ok(classTimeStatisticsService.delete(ids));
|
|
|
|
|
+
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @PostMapping(value = "/change-status")
|
|
|
|
|
+ @ApiOperation(value="修改状态")
|
|
|
|
|
+ @SaCheckPermission("classtimestatistics:detail")
|
|
|
|
|
+ public RT<Boolean> changeStatus(@Valid @RequestBody ChangeStatusDto dto) throws Exception {
|
|
|
|
|
+ ClassTimeStatistics statistics = classTimeStatisticsService.getById(dto.getId());
|
|
|
|
|
+ if(statistics == null){
|
|
|
|
|
+ throw new MyException("未能查到数据");
|
|
|
|
|
+ }
|
|
|
|
|
+ statistics.setStatus(dto.getStatus());
|
|
|
|
|
+ classTimeStatisticsService.updateById(statistics);
|
|
|
|
|
+ return RT.ok(true);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+}
|