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.PageWrap; import doumeemes.core.model.PageData; import doumeemes.core.utils.DateUtil; import doumeemes.dao.business.model.WOutboundRecord; import doumeemes.dao.ext.beanDto.QueryWOutBoundRecordCodeDto; import doumeemes.dao.ext.beanDto.QueryWSOutBoundDto; import doumeemes.dao.ext.dto.QueryWOutboundRecordExtDTO; import doumeemes.dao.ext.vo.WOutboundRecordCodeListVO; import doumeemes.dao.ext.vo.WOutboundRecordExtListVO; import doumeemes.dao.ext.vo.WorkOrderOutboundExtListVO; import doumeemes.service.business.WOutboundRecordService; import doumeemes.service.ext.WOutboundRecordExtService; 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 2022/04/20 10:56 */ @RestController @RequestMapping("/ext/wOutboundRecordExt") @Api(tags = "出入库单处理明细接口") public class WOutboundRecordExtController extends BaseController { @Autowired private WOutboundRecordExtService wOutboundRecordExtService; @Autowired private WOutboundRecordService wOutboundRecordService; @PreventRepeat @ApiOperation("新建") @PostMapping("/create") @RequiresPermissions("ext:woutboundrecordext:create") public ApiResponse create(@RequestBody WOutboundRecord wOutboundRecord) { return ApiResponse.success(wOutboundRecordService.create(wOutboundRecord)); } @ApiOperation("根据ID删除") @GetMapping("/delete/{id}") @RequiresPermissions("ext:woutboundrecordext:delete") public ApiResponse deleteById(@PathVariable Integer id) { wOutboundRecordService.deleteById(id); return ApiResponse.success(null); } @ApiOperation("批量删除") @GetMapping("/delete/batch") @RequiresPermissions("ext:woutboundrecordext:delete") public ApiResponse deleteByIds(@RequestParam String ids) { String [] idArray = ids.split(","); List idList = new ArrayList<>(); for (String id : idArray) { idList.add(Integer.valueOf(id)); } wOutboundRecordService.deleteByIdInBatch(idList); return ApiResponse.success(null); } @ApiOperation("根据ID修改") @PostMapping("/updateById") @RequiresPermissions("ext:woutboundrecordext:update") public ApiResponse updateById(@RequestBody WOutboundRecord wOutboundRecord) { wOutboundRecordService.updateById(wOutboundRecord); return ApiResponse.success(null); } @ApiOperation("分页查询") @PostMapping("/page") @RequiresPermissions("ext:woutboundrecordext:query") public ApiResponse> findPage (@RequestBody PageWrap pageWrap) { return ApiResponse.success(wOutboundRecordExtService.findPage(pageWrap)); } @ApiOperation("导出Excel") @PostMapping("/exportExcel") @RequiresPermissions("ext:woutboundrecordext:exportExcel") public void exportExcel (@RequestBody PageWrap pageWrap, HttpServletResponse response) { ExcelExporter.build(WOutboundRecordExtListVO.class).export(wOutboundRecordExtService.findPage(pageWrap).getRecords(), "出入库单处理明细", response); } @ApiOperation("根据ID查询") @GetMapping("/{id}") @RequiresPermissions("ext:woutboundrecordext:query") public ApiResponse findById(@PathVariable Integer id) { return ApiResponse.success(wOutboundRecordService.findById(id)); } @ApiOperation("出入库篮筐明细 ") @PostMapping("/recordCodeListPage") // @RequiresPermissions("ext:woutboundrecordext:query") public ApiResponse> recordCodeListPage (@RequestBody PageWrap pageWrap) { return ApiResponse.success(wOutboundRecordExtService.recordCodeList(pageWrap)); } @ApiOperation("出入库篮筐明细 - 导出Excel") @PostMapping("/recordCodeListExcel") // @RequiresPermissions("ext:woutboundrecordext:query") public void recordCodeListExcel (@RequestBody PageWrap pageWrap, HttpServletResponse response) throws Exception{ ExcelExporter.build(WOutboundRecordCodeListVO.class).export(wOutboundRecordExtService.recordCodeList(pageWrap).getRecords(), "出入库篮筐明细"+ DateUtil.getNowLongTime(), response); } }