| package doumeemes.api.ext; | 
|   | 
| import doumeemes.api.BaseController; | 
| import doumeemes.core.annotation.excel.ExcelExporter; | 
| import doumeemes.core.annotation.pr.PreventRepeat; | 
| import doumeemes.core.model.ApiResponse; | 
| import doumeemes.core.model.PageData; | 
| import doumeemes.core.model.PageWrap; | 
| import doumeemes.dao.business.model.SalaryParam; | 
| import doumeemes.dao.business.vo.SalaryParamVO; | 
| import doumeemes.dao.ext.dto.SalaryParamDTO; | 
| import doumeemes.service.business.SalaryParamService; | 
| import io.swagger.annotations.Api; | 
| import io.swagger.annotations.ApiImplicitParam; | 
| import io.swagger.annotations.ApiImplicitParams; | 
| 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 org.springframework.web.multipart.MultipartFile; | 
| import org.springframework.web.multipart.MultipartHttpServletRequest; | 
| import org.springframework.web.multipart.commons.CommonsMultipartResolver; | 
|   | 
| import javax.servlet.http.HttpServletRequest; | 
| import javax.servlet.http.HttpServletResponse; | 
| import java.util.ArrayList; | 
| import java.util.Iterator; | 
| import java.util.List; | 
|   | 
| /** | 
|  * @author 江蹄蹄 | 
|  * @date 2023/08/11 15:29 | 
|  */ | 
| @Api(tags = "设置类-绩效工资配置表") | 
| @RestController | 
| @RequestMapping("/ext/salaryParam") | 
| public class SalaryParamExtController extends BaseController { | 
|   | 
|     @Autowired | 
|     private SalaryParamService salaryParamService; | 
|   | 
|     @PreventRepeat | 
|     @ApiOperation("新建") | 
|     @PostMapping("/create") | 
| //    @RequiresPermissions("business:salaryparam:create") | 
|     public ApiResponse create(@RequestBody SalaryParam salaryParam) { | 
|         return ApiResponse.success(salaryParamService.create(salaryParam)); | 
|     } | 
|   | 
|     @ApiOperation("根据ID删除") | 
|     @GetMapping("/delete/{id}") | 
|     @RequiresPermissions("business:salaryparam:delete") | 
|     public ApiResponse deleteById(@PathVariable Integer id) { | 
|         salaryParamService.deleteById(id); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("批量删除") | 
|     @GetMapping("/delete/batch") | 
|     @RequiresPermissions("business:salaryparam:delete") | 
|     public ApiResponse deleteByIdInBatch(@RequestParam String ids) { | 
|         String [] idArray = ids.split(","); | 
|         List<Integer> idList = new ArrayList<>(); | 
|         for (String id : idArray) { | 
|             idList.add(Integer.valueOf(id)); | 
|         } | 
|         salaryParamService.deleteByIdInBatch(idList); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("根据ID修改") | 
|     @PostMapping("/updateById") | 
|     @RequiresPermissions("business:salaryparam:update") | 
|     public ApiResponse updateById(@RequestBody SalaryParam salaryParam) { | 
|         salaryParamService.updateById(salaryParam); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("根据对象信息查询") | 
|     @PostMapping("/queryOne") | 
|     @RequiresPermissions("business:salaryparam:query") | 
|     public ApiResponse<SalaryParam> queryOne(@RequestBody SalaryParam salaryParam) { | 
|         SalaryParam data = salaryParamService.findOne(salaryParam); | 
|         return ApiResponse.success(data); | 
|     } | 
|   | 
|     @ApiOperation("分页查询") | 
|     @PostMapping("/page") | 
|     @RequiresPermissions("business:salaryparam:query") | 
|     public ApiResponse<PageData<SalaryParamVO>> findPage (@RequestBody PageWrap<SalaryParamDTO> pageWrap) { | 
|         return ApiResponse.success(salaryParamService.findPage(pageWrap)); | 
|     } | 
|   | 
|     @ApiOperation("列表查询") | 
|     @PostMapping("/queryList") | 
|     @RequiresPermissions("business:salaryparam:query") | 
|     public ApiResponse<List<SalaryParam>> queryList(@RequestBody SalaryParam salaryParam) { | 
|         List<SalaryParam> data = salaryParamService.findList(salaryParam); | 
|         return ApiResponse.success(data); | 
|     } | 
|   | 
|     @ApiOperation("导出Excel") | 
|     @PostMapping("/exportExcel") | 
|     @RequiresPermissions("business:salaryparam:exportExcel") | 
|     public void exportExcel (@RequestBody PageWrap<SalaryParamDTO> pageWrap, HttpServletResponse response) { | 
|         ExcelExporter.build(SalaryParamVO.class).export(salaryParamService.findPage(pageWrap).getRecords(), "设置类-绩效工资配置表", response); | 
|     } | 
|   | 
|     @ApiOperation("根据ID查询") | 
|     @GetMapping("/{id}") | 
|     @RequiresPermissions("business:salaryparam:query") | 
|     public ApiResponse findById(@PathVariable Integer id) { | 
|         return ApiResponse.success(salaryParamService.findById(id)); | 
|     } | 
|   | 
|     @ApiOperation(value = "批量导入计划", notes = "批量导入计划", httpMethod = "POST", position = 6) | 
|     @ApiImplicitParams({ | 
|             @ApiImplicitParam(name = "folder", value = "文件夹", required = true, paramType = "query", dataType = "String", dataTypeClass = String.class), | 
|     }) | 
|     @PostMapping(value = "/importBatch", headers = "content-type=multipart/form-data") | 
|     @RequiresPermissions("business:salaryparam:create") | 
|     public ApiResponse importBatch(String folder, HttpServletRequest request, HttpServletResponse response) throws Exception { | 
|         CommonsMultipartResolver multipartResovler = new CommonsMultipartResolver(); | 
|         if (multipartResovler.isMultipart(request)) { | 
|             MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request; | 
|             Iterator<String> it = multipartRequest.getFileNames(); | 
|             while (it.hasNext()) { | 
|                 MultipartFile file = multipartRequest.getFile((String) it.next()); | 
|                 salaryParamService.importPlans(file); | 
|                 break; | 
|             } | 
|         } | 
|         return ApiResponse.success( null); | 
|     } | 
| } |