Files
xgy-oa/klp-wms/src/main/java/com/klp/controller/WmsTransferOrderItemController.java
Joshi 62eb5aedfb feat(wms): 添加调拨单明细批量新增功能
- 在 IWmsTransferOrderItemService 中添加 batchInsert 方法
- 在 WmsTransferOrderItemBo 中新增 coilIds 字段用于接收钢卷id列表
- 在 WmsTransferOrderItemController 中添加 /batch 接口支持批量新增
- 在 WmsTransferOrderItemServiceImpl 中实现批量插入业务逻辑
- 新增 WmsMaterialCoil 相关依赖注入和数据查询操作
- 实现根据 itemType 自动设置 materialType 的转换逻辑
2026-03-27 16:43:42 +08:00

120 lines
4.0 KiB
Java

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 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.WmsTransferOrderItemVo;
import com.klp.domain.bo.WmsTransferOrderItemBo;
import com.klp.service.IWmsTransferOrderItemService;
import com.klp.common.core.page.TableDataInfo;
/**
* 调拨单明细
*
* @author klp
* @date 2026-03-27
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/wms/transferOrderItem")
public class WmsTransferOrderItemController extends BaseController {
private final IWmsTransferOrderItemService iWmsTransferOrderItemService;
/**
* 查询调拨单明细列表
*/
@GetMapping("/list")
public TableDataInfo<WmsTransferOrderItemVo> list(WmsTransferOrderItemBo bo, PageQuery pageQuery) {
return iWmsTransferOrderItemService.queryPageList(bo, pageQuery);
}
/**
* 导出调拨单明细列表
*/
@Log(title = "调拨单明细", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(WmsTransferOrderItemBo bo, HttpServletResponse response) {
List<WmsTransferOrderItemVo> list = iWmsTransferOrderItemService.queryList(bo);
ExcelUtil.exportExcel(list, "调拨单明细", WmsTransferOrderItemVo.class, response);
}
/**
* 获取调拨单明细详细信息
*
* @param itemId 主键
*/
@GetMapping("/{itemId}")
public R<WmsTransferOrderItemVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long itemId) {
return R.ok(iWmsTransferOrderItemService.queryById(itemId));
}
/**
* 新增调拨单明细
*/
@Log(title = "调拨单明细", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody WmsTransferOrderItemBo bo) {
return toAjax(iWmsTransferOrderItemService.insertByBo(bo));
}
/**
* 修改调拨单明细
*/
@Log(title = "调拨单明细", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody WmsTransferOrderItemBo bo) {
return toAjax(iWmsTransferOrderItemService.updateByBo(bo));
}
/**
* 删除调拨单明细
*
* @param itemIds 主键串
*/
@Log(title = "调拨单明细", businessType = BusinessType.DELETE)
@DeleteMapping("/{itemIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] itemIds) {
return toAjax(iWmsTransferOrderItemService.deleteWithValidByIds(Arrays.asList(itemIds), true));
}
/**
* 根据itemId和itemType匹配或新增物料
* itemType: raw_material-原料, product-成品
*/
@GetMapping("/matchOrCreate")
public R<Long> matchOrCreateMaterial(@NotNull(message = "itemId不能为空") Long itemId,
@NotNull(message = "itemType不能为空") String itemType) {
return R.ok(iWmsTransferOrderItemService.matchOrCreateMaterial(itemId, itemType));
}
/**
* 批量新增调拨单明细
*/
@Log(title = "调拨单明细", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping("/batch")
public R<Void> batchAdd(@Validated(AddGroup.class) @RequestBody WmsTransferOrderItemBo bo) {
return toAjax(iWmsTransferOrderItemService.batchInsert(bo));
}
}