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.LoginUserInfo; import com.doumee.core.model.PageWrap; import com.doumee.core.model.PageData; import com.doumee.core.utils.Constants; import com.doumee.dao.business.model.DeclareScore; import com.doumee.service.business.DeclareScoreService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; 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.util.ArrayList; import java.util.List; /** * @author 江蹄蹄 * @date 2023/05/29 10:50 */ @Api(tags = "项目申报评分记录表") @RestController @RequestMapping("/business/declareScore") public class DeclareScoreController extends BaseController { @Autowired private DeclareScoreService declareScoreService; @PreventRepeat @ApiOperation("新建") @PostMapping("/create") @RequiresPermissions("business:declarescore:create") public ApiResponse create(@RequestBody DeclareScore declareScore) { return ApiResponse.success(declareScoreService.create(declareScore)); } @PreventRepeat @ApiOperation("批量新建") @PostMapping("/createBatch") @RequiresPermissions("business:declarescore:create") public ApiResponse createBatch(@RequestBody List declareScore) { return ApiResponse.success(declareScoreService.createBatch(declareScore)); } @ApiOperation("根据ID删除") @GetMapping("/delete/{id}") @RequiresPermissions("business:declarescore:delete") public ApiResponse deleteById(@PathVariable Integer id) { declareScoreService.deleteById(id); return ApiResponse.success(null); } @ApiOperation("批量删除") @GetMapping("/delete/batch") @RequiresPermissions("business:declarescore:delete") public ApiResponse deleteByIdInBatch(@RequestParam String ids) { String [] idArray = ids.split(","); List idList = new ArrayList<>(); for (String id : idArray) { idList.add(Integer.valueOf(id)); } declareScoreService.deleteByIdInBatch(idList); return ApiResponse.success(null); } @ApiOperation("根据ID修改") @PostMapping("/updateById") @RequiresPermissions("business:declarescore:update") public ApiResponse updateById(@RequestBody DeclareScore declareScore) { declareScoreService.updateById(declareScore); return ApiResponse.success(null); } /** * 批量主键更新 * * @param declareScores 实体集 */ @ApiOperation("批量修改") @PostMapping("/updateByIdInBatch") @RequiresPermissions("business:declarescore:update") public ApiResponse updateByIdInBatch(@RequestBody List declareScores){ declareScoreService.updateByIdInBatch(declareScores); return ApiResponse.success(null); } @ApiOperation("分页查询") @PostMapping("/page") @RequiresPermissions("business:declarescore:query") public ApiResponse> findPage (@RequestBody PageWrap pageWrap) { return ApiResponse.success(declareScoreService.findPage(pageWrap)); } @ApiOperation("导出Excel") @PostMapping("/exportExcel") @RequiresPermissions("business:declarescore:exportExcel") public void exportExcel (@RequestBody PageWrap pageWrap, HttpServletResponse response) { ExcelExporter.build(DeclareScore.class).export(declareScoreService.findPage(pageWrap).getRecords(), "项目申报评分记录表", response); } @ApiOperation("根据ID查询") @GetMapping("/{id}") @RequiresPermissions("business:declarescore:query") public ApiResponse findById(@PathVariable Integer id) { return ApiResponse.success(declareScoreService.findById(id)); } /** * 条件查询单条记录 * * @return DeclareScore */ @ApiOperation("根据ID查询") @GetMapping("/findByDeclareId") @RequiresPermissions("business:declarescore:query") public ApiResponse> findByDeclareId(@RequestParam Integer declareId){ LoginUserInfo loginUser = getLoginUser(); DeclareScore declareScore = new DeclareScore(); declareScore.setDeclareId(declareId); // declareScore.setRoleType(Constants.ProjectScoreType.getProjectScoreRoleType(loginUser.getType())); return ApiResponse.success(declareScoreService.findList(declareScore)); } }