package com.doumee.api.business; 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.PageData; import com.doumee.core.model.PageWrap; import com.doumee.dao.business.model.ImportRecord; import com.doumee.core.utils.Utils; import com.doumee.service.business.ImportRecordService; import io.swagger.annotations.*; 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 com.doumee.api.BaseController; import org.springframework.web.multipart.MultipartFile; import java.io.File; /** * 分类信息表Controller定义 * @author doumee * @date 2026-01-27 16:02:37 */ @Api(tags = "分类信息表接口") @RestController @RequestMapping("/business/importRecord") public class ImportRecordController extends BaseController { @Autowired private ImportRecordService importRecordService; @PreventRepeat @ApiOperation("新建") @PostMapping("/create") @RequiresPermissions("business:importrecord:create") public ApiResponse create(@RequestBody ImportRecord importRecord) { return ApiResponse.success(importRecordService.create(importRecord)); } @ApiOperation("根据ID删除") @GetMapping("/delete/{id}") @RequiresPermissions("business:importrecord:delete") public ApiResponse deleteById(@PathVariable Integer id) { importRecordService.deleteById(id); return ApiResponse.success(null); } @ApiOperation("批量删除") @GetMapping("/delete/batch") @RequiresPermissions("business:importrecord:delete") public ApiResponse deleteByIdInBatch(@RequestParam String ids) { importRecordService.deleteByIdInBatch(this.getIdList(ids)); return ApiResponse.success(null); } @ApiOperation("根据ID修改") @PostMapping("/updateById") @RequiresPermissions("business:importrecord:update") public ApiResponse updateById(@RequestBody ImportRecord importRecord) { importRecordService.updateById(importRecord); return ApiResponse.success(null); } @ApiOperation("分页查询") @PostMapping("/page") @RequiresPermissions("business:importrecord:query") public ApiResponse> findPage (@RequestBody PageWrap pageWrap) { return ApiResponse.success(importRecordService.findPage(pageWrap)); } @ApiOperation("导出Excel") @PostMapping("/exportExcel") @RequiresPermissions("business:importrecord:exportExcel") public void exportExcel (@RequestBody PageWrap pageWrap, HttpServletResponse response) { ExcelExporter.build(ImportRecord.class).export(importRecordService.findPage(pageWrap).getRecords(), "分类信息表", response); } @ApiOperation("根据ID查询") @GetMapping("/{id}") @RequiresPermissions("business:importrecord:query") public ApiResponse findById(@PathVariable Integer id) { return ApiResponse.success(importRecordService.findById(id)); } @ApiOperation(value = "信息导入" ,notes = "保单申请") @PostMapping("/importExcel") @ApiImplicitParams({ @ApiImplicitParam(name = "file", value = "file", required = true, paramType = "query", dataType = "file", dataTypeClass = File.class), @ApiImplicitParam(name = "导入类型 0人员 1案例", value = "type", required = true, paramType = "query", dataType = "Integer",example = "0",dataTypeClass = Integer.class), }) public ApiResponse importExcel (@ApiParam(value = "file") MultipartFile file, @ApiParam(value = "type") Integer type) { ImportRecord importRecord = importRecordService.importBatch(file,type); importRecordService.dealImporTask(importRecord); return ApiResponse.success("文件上传成功"); } }