package com.ruoyi.stock.controller;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ruoyi.framework.aspectj.lang.annotation.Log;
import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
import com.ruoyi.framework.web.domain.AjaxResult;
import com.ruoyi.stock.dto.StockOutRecordDto;
import com.ruoyi.stock.service.StockOutRecordService;
import io.swagger.v3.oas.annotations.tags.Tag;
import io.swagger.v3.oas.annotations.Operation;
import lombok.AllArgsConstructor;
import org.springframework.util.CollectionUtils;
import org.springframework.web.bind.annotation.*;
import jakarta.servlet.http.HttpServletResponse;
import java.util.List;
/**
*
* 出库记录表 前端控制器
*
*
* @author 芯导软件(江苏)有限公司
* @since 2026-01-21 05:27:04
*/
@Tag(name = "出库")
@RestController
@RequestMapping("/stockOutRecord")
@AllArgsConstructor
public class StockOutRecordController {
private StockOutRecordService stockOutRecordService;
@GetMapping("/listPage")
@Log(title = "生产出库-出库管理-列表", businessType = BusinessType.OTHER)
@Operation(summary = "出库管理列表")
public AjaxResult listPage(Page page, StockOutRecordDto stockOutRecordDto) {
IPage result = stockOutRecordService.listPage(page, stockOutRecordDto);
return AjaxResult.success(result);
}
@PostMapping("")
@Log(title = "出库管理-新增出库", businessType = BusinessType.INSERT)
public AjaxResult add(@RequestBody StockOutRecordDto stockOutRecordDto) {
return AjaxResult.success(stockOutRecordService.add(stockOutRecordDto));
}
@PutMapping("/{id}")
@Log(title = "出库管理-更新出库", businessType = BusinessType.UPDATE)
public AjaxResult update(@PathVariable("id") Long id, @RequestBody StockOutRecordDto stockOutRecordDto) {
return AjaxResult.success(stockOutRecordService.update(id, stockOutRecordDto));
}
@DeleteMapping("")
@Log(title = "出库管理-删除出库", businessType = BusinessType.DELETE)
public AjaxResult delete(@RequestBody List ids) {
if(CollectionUtils.isEmpty(ids)){
return AjaxResult.error("请选择至少一条数据");
}
return AjaxResult.success(stockOutRecordService.batchDelete(ids));
}
@DeleteMapping("/pending")
@Log(title = "出库管理-删除待审批出库", businessType = BusinessType.DELETE)
@Operation(summary = "删除待审批的出库记录")
public AjaxResult deletePending(@RequestBody List ids) {
if(CollectionUtils.isEmpty(ids)){
return AjaxResult.error("请选择至少一条数据");
}
return AjaxResult.success(stockOutRecordService.batchDeletePending(ids));
}
@PostMapping("/exportStockOutRecord")
@Operation(summary = "导出出库记录")
public void exportStockOutRecord(HttpServletResponse response, StockOutRecordDto stockOutRecordDto) {
stockOutRecordService.exportStockOutRecord(response,stockOutRecordDto);
}
@PostMapping("/approve")
@Log(title = "出库管理-审批出库", businessType = BusinessType.UPDATE)
@Operation(summary = "批量审批出库记录")
public AjaxResult approve(@RequestBody StockOutRecordDto approveDto) {
if(CollectionUtils.isEmpty(approveDto.getIds())){
return AjaxResult.error("请选择至少一条数据");
}
stockOutRecordService.batchApprove(approveDto.getIds(), approveDto.getApprovalStatus());
return AjaxResult.success();
}
}