package com.doumee.api.business; import com.doumee.api.BaseController; import com.doumee.core.annotation.excel.ExcelExporter; import com.doumee.core.annotation.pr.PreventRepeat; import com.doumee.core.model.ApiResponse; import com.doumee.core.model.PageWrap; import com.doumee.core.model.PageData; import com.doumee.core.utils.Constants; import com.doumee.core.utils.Date; import com.doumee.core.utils.DateUtil; import com.doumee.dao.business.model.DeclareAnswer; import com.doumee.service.business.DeclareAnswerService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.apache.commons.lang3.StringUtils; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; import java.time.LocalDateTime; import java.time.format.DateTimeFormatter; import java.util.ArrayList; import java.util.List; /** * @author 江蹄蹄 * @date 2023/02/15 08:55 */ @Api(tags = "项目申报问卷答题记录") @RestController @RequestMapping("/business/declareAnswer") public class DeclareAnswerController extends BaseController { @Autowired private DeclareAnswerService declareAnswerService; @PreventRepeat @ApiOperation("新建") @PostMapping("/create") @RequiresPermissions("business:declareanswer:create") public ApiResponse create(@RequestBody DeclareAnswer declareAnswer) { declareAnswerService.create(declareAnswer); DeclareAnswer t = new DeclareAnswer(); t.setId(declareAnswer.getId()); t.setScore(declareAnswer.getScore()); return ApiResponse.success(t); } @ApiOperation("根据ID删除") @GetMapping("/delete/{id}") @RequiresPermissions("business:declareanswer:delete") public ApiResponse deleteById(@PathVariable Integer id) { declareAnswerService.deleteById(id); return ApiResponse.success(null); } @ApiOperation("批量删除") @GetMapping("/delete/batch") @RequiresPermissions("business:declareanswer:delete") public ApiResponse deleteByIdInBatch(@RequestParam String ids) { String [] idArray = ids.split(","); List idList = new ArrayList<>(); for (String id : idArray) { idList.add(Integer.valueOf(id)); } declareAnswerService.deleteByIdInBatch(idList); return ApiResponse.success(null); } @ApiOperation("根据ID修改") @PostMapping("/updateById") @RequiresPermissions("business:declareanswer:update") public ApiResponse updateById(@RequestBody DeclareAnswer declareAnswer) { declareAnswerService.updateById(declareAnswer); return ApiResponse.success(null); } @ApiOperation("分页查询") @PostMapping("/page") @RequiresPermissions("business:declareanswer:query") public ApiResponse> findPage (@RequestBody PageWrap pageWrap) { return ApiResponse.success(declareAnswerService.findPage(pageWrap)); } @ApiOperation("导出Excel") @PostMapping("/exportExcel") @RequiresPermissions("business:declareanswer:exportExcel") public void exportExcel (@RequestBody PageWrap pageWrap, HttpServletResponse response) { ExcelExporter.build(DeclareAnswer.class).export(declareAnswerService.findPage(pageWrap).getRecords(), "项目申报问卷答题记录", response); } @ApiOperation("导出答题Excel") @PostMapping("/exportAnswerExcel") @RequiresPermissions("business:declareanswer:exportExcel") public void exportAnswerExcel(@RequestBody DeclareAnswer pageWrap, HttpServletResponse response) { List list = declareAnswerService.findExport(pageWrap) ; // String nowDate = DateUtil.getPlusTime2(DateUtil.getCurrentDate()); String format = LocalDateTime.now().format(Date.formatter); ExcelExporter.build(DeclareAnswer.class).exportWithFirstAndEnd(list, StringUtils.defaultString(pageWrap.getTitle(),"企业问卷答题详情表")+"_"+format, StringUtils.defaultString(pageWrap.getTitle(),"") ,null,"总得分:"+Constants.formatBigdecimal(pageWrap.getScore()).intValue() , response); } // @ApiOperation("根据ID查询") // @GetMapping("/{id}") // @RequiresPermissions("business:declareanswer:query") // public ApiResponse findById(@PathVariable Integer id) { // return ApiResponse.success(declareAnswerService.findById(id)); @ApiOperation("根据ID查询") @GetMapping("/{id}") // @RequiresPermissions("business:declareanswer:query") public ApiResponse findJoinById(@PathVariable Integer id) { return ApiResponse.success(declareAnswerService.findJoinById(id)); } }