|
|
@@ -0,0 +1,188 @@
|
|
|
+package com.xjrsoft.module.textbook.controller;
|
|
|
+
|
|
|
+import cn.hutool.core.bean.BeanUtil;
|
|
|
+import cn.hutool.core.util.ObjectUtil;
|
|
|
+import cn.hutool.core.util.StrUtil;
|
|
|
+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.toolkit.Wrappers;
|
|
|
+import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
|
|
+import com.xjrsoft.common.constant.GlobalConstant;
|
|
|
+import com.baomidou.mybatisplus.core.toolkit.StringPool;
|
|
|
+import com.xjrsoft.common.enums.DeleteMark;
|
|
|
+import com.xjrsoft.common.page.ConventPage;
|
|
|
+import com.xjrsoft.common.page.PageOutput;
|
|
|
+import com.xjrsoft.common.model.result.RT;
|
|
|
+import com.xjrsoft.common.utils.TreeUtil;
|
|
|
+import com.xjrsoft.common.utils.VoToColumnUtil;
|
|
|
+import com.xjrsoft.module.base.entity.BaseClass;
|
|
|
+import com.xjrsoft.module.base.entity.BaseGrade;
|
|
|
+import com.xjrsoft.module.base.entity.BaseSemester;
|
|
|
+import com.xjrsoft.module.base.mapper.BaseClassMapper;
|
|
|
+import com.xjrsoft.module.oa.vo.NewsGradeClassTreeVo;
|
|
|
+import com.xjrsoft.module.student.vo.BaseClassQfCountVo;
|
|
|
+import com.xjrsoft.module.student.vo.BaseClassTreeVo;
|
|
|
+import com.xjrsoft.module.textbook.dto.AddWfTextbookSubscriptionDto;
|
|
|
+import com.xjrsoft.module.textbook.dto.UpdateWfTextbookSubscriptionDto;
|
|
|
+import cn.dev33.satoken.annotation.SaCheckPermission;
|
|
|
+import com.alibaba.excel.EasyExcel;
|
|
|
+import com.alibaba.excel.support.ExcelTypeEnum;
|
|
|
+import com.xjrsoft.module.textbook.vo.GradeClassListVo;
|
|
|
+import com.xjrsoft.module.textbook.vo.GradeClassTreeVo;
|
|
|
+import org.springframework.http.ResponseEntity;
|
|
|
+import java.io.ByteArrayOutputStream;
|
|
|
+import java.util.ArrayList;
|
|
|
+
|
|
|
+import com.xjrsoft.module.textbook.dto.WfTextbookSubscriptionPageDto;
|
|
|
+import com.xjrsoft.module.textbook.entity.WfTextbookSubscription;
|
|
|
+import com.xjrsoft.module.textbook.service.IWfTextbookSubscriptionService;
|
|
|
+import com.xjrsoft.module.textbook.vo.WfTextbookSubscriptionPageVo;
|
|
|
+
|
|
|
+import com.xjrsoft.module.textbook.vo.WfTextbookSubscriptionVo;
|
|
|
+import io.swagger.annotations.Api;
|
|
|
+import io.swagger.annotations.ApiOperation;
|
|
|
+import lombok.AllArgsConstructor;
|
|
|
+import org.springframework.web.bind.annotation.*;
|
|
|
+
|
|
|
+import javax.validation.Valid;
|
|
|
+import javax.validation.constraints.NotNull;
|
|
|
+import java.util.HashMap;
|
|
|
+import java.util.List;
|
|
|
+import java.util.Map;
|
|
|
+import java.util.stream.Collectors;
|
|
|
+
|
|
|
+/**
|
|
|
+* @title: 教材教辅征订
|
|
|
+* @Author szs
|
|
|
+* @Date: 2024-06-04
|
|
|
+* @Version 1.0
|
|
|
+*/
|
|
|
+@RestController
|
|
|
+@RequestMapping("/textbook" + "/wfTextbookSubscription")
|
|
|
+@Api(value = "/textbook" + "/wfTextbookSubscription",tags = "教材教辅征订代码")
|
|
|
+@AllArgsConstructor
|
|
|
+public class WfTextbookSubscriptionController {
|
|
|
+
|
|
|
+
|
|
|
+ private final IWfTextbookSubscriptionService wfTextbookSubscriptionService;
|
|
|
+
|
|
|
+ private final BaseClassMapper baseClassMapper;
|
|
|
+
|
|
|
+ @GetMapping(value = "/tree")
|
|
|
+ @ApiOperation(value = "学生年级班级树")
|
|
|
+ @SaCheckPermission("studentmanager:detail")
|
|
|
+ public RT<List<GradeClassTreeVo>> tree() {
|
|
|
+ List<GradeClassTreeVo> voList = new ArrayList<>();
|
|
|
+
|
|
|
+ voList.add(new GradeClassTreeVo() {{
|
|
|
+ setId("666666");
|
|
|
+ setName("班级");
|
|
|
+ }});
|
|
|
+
|
|
|
+ //获取班级List(包含年级信息)
|
|
|
+ MPJLambdaWrapper<BaseClass> baseClassMPJLambdaWrapper = new MPJLambdaWrapper<>();
|
|
|
+ baseClassMPJLambdaWrapper
|
|
|
+ .selectAs(BaseClass::getId, GradeClassListVo::getClassId)
|
|
|
+ .selectAs(BaseClass::getName, GradeClassListVo::getClassName)
|
|
|
+ .selectAs(BaseClass::getGradeId, GradeClassListVo::getGradeId)
|
|
|
+ .selectAs(BaseGrade::getName, GradeClassListVo::getGradeName)
|
|
|
+ .leftJoin(BaseGrade.class, BaseGrade::getId, BaseClass::getGradeId)
|
|
|
+ .eq(BaseClass::getDeleteMark, 0)
|
|
|
+ .eq(BaseClass::getIsGraduate, 1)
|
|
|
+ ;
|
|
|
+ List<GradeClassListVo> gradeClassTreeVoList = baseClassMapper.selectJoinList(GradeClassListVo.class, baseClassMPJLambdaWrapper);
|
|
|
+
|
|
|
+ //年级Map
|
|
|
+ Map<String, GradeClassTreeVo> gradeMap = new HashMap<>();
|
|
|
+ for (GradeClassListVo gradeClassListVo : gradeClassTreeVoList){
|
|
|
+ if(gradeClassListVo.getGradeId() != null && gradeMap.get(gradeClassListVo.getGradeId()) == null){
|
|
|
+ gradeMap.put(gradeClassListVo.getGradeId(), new GradeClassTreeVo(){{
|
|
|
+ setId(gradeClassListVo.getGradeId());
|
|
|
+ setName(gradeClassListVo.getGradeName());
|
|
|
+ setParentId("666666");
|
|
|
+ }});
|
|
|
+ }
|
|
|
+ voList.add(new GradeClassTreeVo() {{
|
|
|
+ setId(gradeClassListVo.getClassId());
|
|
|
+ setName(gradeClassListVo.getClassName());
|
|
|
+ setParentId(gradeClassListVo.getGradeId());
|
|
|
+ }});
|
|
|
+ }
|
|
|
+
|
|
|
+ List<GradeClassTreeVo> gradeList = new ArrayList<>(gradeMap.values());
|
|
|
+ voList.addAll(gradeList);
|
|
|
+
|
|
|
+ List<GradeClassTreeVo> treeVoList = TreeUtil.build(voList);
|
|
|
+
|
|
|
+ return RT.ok(treeVoList);
|
|
|
+ }
|
|
|
+
|
|
|
+ @GetMapping(value = "/page")
|
|
|
+ @ApiOperation(value="教材教辅征订列表(分页)")
|
|
|
+ @SaCheckPermission("wftextbooksubscription:detail")
|
|
|
+ public RT<PageOutput<WfTextbookSubscriptionPageVo>> page(@Valid WfTextbookSubscriptionPageDto dto){
|
|
|
+
|
|
|
+ MPJLambdaWrapper<WfTextbookSubscription> queryWrapper = new MPJLambdaWrapper<>();
|
|
|
+ queryWrapper
|
|
|
+ .select(WfTextbookSubscription::getId)
|
|
|
+ .selectAs(BaseSemester::getName, WfTextbookSubscriptionPageVo::getBaseSemesterIdCn)
|
|
|
+ .select("(select sum(student_subscription_number) + sum(teacher_subscription_number) from wf_textbook_subscription_item a where a.wf_textbook_subscription_id = t.id) as sum")
|
|
|
+ .select(WfTextbookSubscription.class,x -> VoToColumnUtil.fieldsToColumns(WfTextbookSubscriptionPageVo.class).contains(x.getProperty()))
|
|
|
+ .leftJoin(BaseSemester.class, BaseSemester::getId, WfTextbookSubscription::getBaseSemesterId)
|
|
|
+ .orderByDesc(WfTextbookSubscription::getCreateDate)
|
|
|
+ ;
|
|
|
+ IPage<WfTextbookSubscription> page = wfTextbookSubscriptionService.selectJoinListPage(ConventPage.getPage(dto),WfTextbookSubscription.class, queryWrapper);
|
|
|
+ PageOutput<WfTextbookSubscriptionPageVo> pageOutput = ConventPage.getPageOutput(page, WfTextbookSubscriptionPageVo.class);
|
|
|
+ return RT.ok(pageOutput);
|
|
|
+ }
|
|
|
+
|
|
|
+ @GetMapping(value = "/info")
|
|
|
+ @ApiOperation(value="根据id查询教材教辅征订信息")
|
|
|
+ @SaCheckPermission("wftextbooksubscription:detail")
|
|
|
+ public RT<WfTextbookSubscriptionVo> info(@RequestParam Long id){
|
|
|
+ WfTextbookSubscription wfTextbookSubscription = wfTextbookSubscriptionService.getByIdDeep(id);
|
|
|
+ if (wfTextbookSubscription == null) {
|
|
|
+ return RT.error("找不到此数据!");
|
|
|
+ }
|
|
|
+ return RT.ok(BeanUtil.toBean(wfTextbookSubscription, WfTextbookSubscriptionVo.class));
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ @PostMapping
|
|
|
+ @ApiOperation(value = "新增教材教辅征订")
|
|
|
+ @SaCheckPermission("wftextbooksubscription:add")
|
|
|
+ public RT<Boolean> add(@Valid @RequestBody AddWfTextbookSubscriptionDto dto){
|
|
|
+ WfTextbookSubscription wfTextbookSubscription = BeanUtil.toBean(dto, WfTextbookSubscription.class);
|
|
|
+ boolean isSuccess = wfTextbookSubscriptionService.add(wfTextbookSubscription);
|
|
|
+ return RT.ok(isSuccess);
|
|
|
+ }
|
|
|
+
|
|
|
+ @PutMapping
|
|
|
+ @ApiOperation(value = "修改教材教辅征订")
|
|
|
+ @SaCheckPermission("wftextbooksubscription:edit")
|
|
|
+ public RT<Boolean> update(@Valid @RequestBody UpdateWfTextbookSubscriptionDto dto){
|
|
|
+
|
|
|
+ WfTextbookSubscription wfTextbookSubscription = BeanUtil.toBean(dto, WfTextbookSubscription.class);
|
|
|
+ return RT.ok(wfTextbookSubscriptionService.update(wfTextbookSubscription));
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ @DeleteMapping
|
|
|
+ @ApiOperation(value = "删除教材教辅征订")
|
|
|
+ @SaCheckPermission("wftextbooksubscription:delete")
|
|
|
+ public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
|
|
|
+ return RT.ok(wfTextbookSubscriptionService.delete(ids));
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ @GetMapping("/export")
|
|
|
+ @ApiOperation(value = "导出")
|
|
|
+ public ResponseEntity<byte[]> exportData(@Valid WfTextbookSubscriptionPageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
|
|
|
+ List<WfTextbookSubscriptionPageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : ((PageOutput<WfTextbookSubscriptionPageVo>) page(dto).getData()).getList();
|
|
|
+ ByteArrayOutputStream bot = new ByteArrayOutputStream();
|
|
|
+ EasyExcel.write(bot, WfTextbookSubscriptionPageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
|
|
|
+
|
|
|
+ return RT.fileStream(bot.toByteArray(), "WfTextbookSubscription" + ExcelTypeEnum.XLSX.getValue());
|
|
|
+ }
|
|
|
+}
|