package com.klp.controller; import java.util.List; import java.util.Arrays; import lombok.RequiredArgsConstructor; import javax.servlet.http.HttpServletResponse; import javax.validation.constraints.*; import cn.dev33.satoken.annotation.SaCheckPermission; import org.springframework.web.bind.annotation.*; import org.springframework.validation.annotation.Validated; import com.klp.common.annotation.RepeatSubmit; import com.klp.common.annotation.Log; import com.klp.common.core.controller.BaseController; import com.klp.common.core.domain.PageQuery; import com.klp.common.core.domain.R; import com.klp.common.core.validate.AddGroup; import com.klp.common.core.validate.EditGroup; import com.klp.common.enums.BusinessType; import com.klp.common.utils.poi.ExcelUtil; import com.klp.domain.vo.WmsStockVo; import com.klp.domain.bo.WmsStockBo; import com.klp.service.IWmsStockService; import com.klp.common.core.page.TableDataInfo; /** * 库存:原材料/产品与库区/库位的存放关系 * * @author Joshi * @date 2025-07-18 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/wms/stock") public class WmsStockController extends BaseController { private final IWmsStockService iWmsStockService; /** * 查询库存:原材料/产品与库区/库位的存放关系列表 */ @GetMapping("/list") public TableDataInfo list(WmsStockBo bo, PageQuery pageQuery) { return iWmsStockService.queryPageList(bo, pageQuery); } /** * 导出库存:原材料/产品与库区/库位的存放关系列表 */ @Log(title = "库存:原材料/产品与库区/库位的存放关系", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(WmsStockBo bo, HttpServletResponse response) { List list = iWmsStockService.queryList(bo); ExcelUtil.exportExcel(list, "库存:原材料-产品与库区-库位的存放关系", WmsStockVo.class, response); } /** * 获取库存:原材料/产品与库区/库位的存放关系详细信息 * * @param stockId 主键 */ @GetMapping("/{stockId}") public R getInfo(@NotNull(message = "主键不能为空") @PathVariable Long stockId) { return R.ok(iWmsStockService.queryById(stockId)); } /** * 新增库存:原材料/产品与库区/库位的存放关系 */ @Log(title = "库存:原材料/产品与库区/库位的存放关系", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping() public R add(@Validated(AddGroup.class) @RequestBody WmsStockBo bo) { return toAjax(iWmsStockService.insertByBo(bo)); } /** * 修改库存:原材料/产品与库区/库位的存放关系 */ @Log(title = "库存:原材料/产品与库区/库位的存放关系", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R edit(@Validated(EditGroup.class) @RequestBody WmsStockBo bo) { return toAjax(iWmsStockService.updateByBo(bo)); } /** * 删除库存:原材料/产品与库区/库位的存放关系 * * @param stockIds 主键串 */ @Log(title = "库存:原材料/产品与库区/库位的存放关系", businessType = BusinessType.DELETE) @DeleteMapping("/{stockIds}") public R remove(@NotEmpty(message = "主键不能为空") @PathVariable Long[] stockIds) { return toAjax(iWmsStockService.deleteWithValidByIds(Arrays.asList(stockIds), true)); } /** * 测试递归查询功能 */ @GetMapping("/test/warehouse/{warehouseId}") public R testWarehouseQuery(@PathVariable Long warehouseId) { WmsStockBo bo = new WmsStockBo(); bo.setWarehouseId(warehouseId); List list = iWmsStockService.queryList(bo); return R.ok("查询到 " + list.size() + " 条库存记录,仓库ID: " + warehouseId); } }