|
@@ -0,0 +1,116 @@
|
|
|
+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.metadata.IPage;
|
|
|
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
|
+import com.xjrsoft.common.constant.GlobalConstant;
|
|
|
+import com.baomidou.mybatisplus.core.toolkit.StringPool;
|
|
|
+import com.xjrsoft.common.page.ConventPage;
|
|
|
+import com.xjrsoft.common.page.PageOutput;
|
|
|
+import com.xjrsoft.common.model.result.RT;
|
|
|
+import com.xjrsoft.common.utils.VoToColumnUtil;
|
|
|
+import com.xjrsoft.module.textbook.dto.AddTextbookClassWarehouseDto;
|
|
|
+import com.xjrsoft.module.textbook.dto.UpdateTextbookClassWarehouseDto;
|
|
|
+import cn.dev33.satoken.annotation.SaCheckPermission;
|
|
|
+import com.alibaba.excel.EasyExcel;
|
|
|
+import com.alibaba.excel.support.ExcelTypeEnum;
|
|
|
+import org.springframework.http.ResponseEntity;
|
|
|
+import java.io.ByteArrayOutputStream;
|
|
|
+import java.util.ArrayList;
|
|
|
+
|
|
|
+import com.xjrsoft.module.textbook.dto.TextbookClassWarehousePageDto;
|
|
|
+import com.xjrsoft.module.textbook.entity.TextbookClassWarehouse;
|
|
|
+import com.xjrsoft.module.textbook.service.ITextbookClassWarehouseService;
|
|
|
+import com.xjrsoft.module.textbook.vo.TextbookClassWarehousePageVo;
|
|
|
+
|
|
|
+import com.xjrsoft.module.textbook.vo.TextbookClassWarehouseVo;
|
|
|
+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.List;
|
|
|
+
|
|
|
+/**
|
|
|
+* @title: 教材入库
|
|
|
+* @Author szs
|
|
|
+* @Date: 2023-12-26
|
|
|
+* @Version 1.0
|
|
|
+*/
|
|
|
+@RestController
|
|
|
+@RequestMapping("/textbook" + "/textbookClassWarehouse")
|
|
|
+@Api(value = "/textbook" + "/textbookClassWarehouse",tags = "教材入库代码")
|
|
|
+@AllArgsConstructor
|
|
|
+public class TextbookClassWarehouseController {
|
|
|
+
|
|
|
+
|
|
|
+ private final ITextbookClassWarehouseService textbookClassWarehouseService;
|
|
|
+
|
|
|
+ @GetMapping(value = "/page")
|
|
|
+ @ApiOperation(value="教材入库列表(分页)")
|
|
|
+ @SaCheckPermission("textbookclasswarehouse:detail")
|
|
|
+ public RT<PageOutput<TextbookClassWarehousePageVo>> page(@Valid TextbookClassWarehousePageDto dto){
|
|
|
+
|
|
|
+ LambdaQueryWrapper<TextbookClassWarehouse> queryWrapper = new LambdaQueryWrapper<>();
|
|
|
+ queryWrapper
|
|
|
+ .orderByDesc(TextbookClassWarehouse::getId)
|
|
|
+ .select(TextbookClassWarehouse.class,x -> VoToColumnUtil.fieldsToColumns(TextbookClassWarehousePageVo.class).contains(x.getProperty()));
|
|
|
+ IPage<TextbookClassWarehouse> page = textbookClassWarehouseService.page(ConventPage.getPage(dto), queryWrapper);
|
|
|
+ PageOutput<TextbookClassWarehousePageVo> pageOutput = ConventPage.getPageOutput(page, TextbookClassWarehousePageVo.class);
|
|
|
+ return RT.ok(pageOutput);
|
|
|
+ }
|
|
|
+
|
|
|
+ @GetMapping(value = "/info")
|
|
|
+ @ApiOperation(value="根据id查询教材入库信息")
|
|
|
+ @SaCheckPermission("textbookclasswarehouse:detail")
|
|
|
+ public RT<TextbookClassWarehouseVo> info(@RequestParam Long id){
|
|
|
+ TextbookClassWarehouse textbookClassWarehouse = textbookClassWarehouseService.getById(id);
|
|
|
+ if (textbookClassWarehouse == null) {
|
|
|
+ return RT.error("找不到此数据!");
|
|
|
+ }
|
|
|
+ return RT.ok(BeanUtil.toBean(textbookClassWarehouse, TextbookClassWarehouseVo.class));
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ @PostMapping
|
|
|
+ @ApiOperation(value = "新增教材入库")
|
|
|
+ @SaCheckPermission("textbookclasswarehouse:add")
|
|
|
+ public RT<Boolean> add(@Valid @RequestBody AddTextbookClassWarehouseDto dto){
|
|
|
+ TextbookClassWarehouse textbookClassWarehouse = BeanUtil.toBean(dto, TextbookClassWarehouse.class);
|
|
|
+ boolean isSuccess = textbookClassWarehouseService.save(textbookClassWarehouse);
|
|
|
+ return RT.ok(isSuccess);
|
|
|
+ }
|
|
|
+
|
|
|
+ @PutMapping
|
|
|
+ @ApiOperation(value = "修改教材入库")
|
|
|
+ @SaCheckPermission("textbookclasswarehouse:edit")
|
|
|
+ public RT<Boolean> update(@Valid @RequestBody UpdateTextbookClassWarehouseDto dto){
|
|
|
+
|
|
|
+ TextbookClassWarehouse textbookClassWarehouse = BeanUtil.toBean(dto, TextbookClassWarehouse.class);
|
|
|
+ return RT.ok(textbookClassWarehouseService.updateById(textbookClassWarehouse));
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ @DeleteMapping
|
|
|
+ @ApiOperation(value = "删除教材入库")
|
|
|
+ @SaCheckPermission("textbookclasswarehouse:delete")
|
|
|
+ public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
|
|
|
+ return RT.ok(textbookClassWarehouseService.removeBatchByIds(ids));
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ @GetMapping("/export")
|
|
|
+ @ApiOperation(value = "导出")
|
|
|
+ public ResponseEntity<byte[]> exportData(@Valid TextbookClassWarehousePageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
|
|
|
+ List<TextbookClassWarehousePageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : ((PageOutput<TextbookClassWarehousePageVo>) page(dto).getData()).getList();
|
|
|
+ ByteArrayOutputStream bot = new ByteArrayOutputStream();
|
|
|
+ EasyExcel.write(bot, TextbookClassWarehousePageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
|
|
|
+
|
|
|
+ return RT.fileStream(bot.toByteArray(), "TextbookClassWarehouse" + ExcelTypeEnum.XLSX.getValue());
|
|
|
+ }
|
|
|
+}
|