Files
xgy-oa/klp-wms/src/main/java/com/klp/controller/WmsCoilWarehouseOperationLogController.java
Joshi ad100083ed feat(wms): 添加钢卷库区操作记录导出功能以及优化查询速率
- 在服务接口中新增 exportBySecondWarehouseIdAndTimeRange 方法用于导出功能
- 在控制器中新增 exportByWarehouseAndTime 接口支持报表导出
- 在映射器中新增 selectVoListWithJoin 查询方法优化关联查询
- 在 XML 映射文件中新增完整的关联查询 SQL 和结果映射配置
- 在服务实现类中重构查询逻辑使用新的关联查询方法
- 新增 WmsCoilWarehouseOperationLogExportVo 导出数据对象
- 实现导出逻辑将操作记录转换为 Excel 格式并支持多表关联
- 添加状态描述转换方法支持中文显示
- 更新 VO 类继承 BaseEntity 基础实体类
2026-03-24 10:35:57 +08:00

178 lines
7.2 KiB
Java

package com.klp.controller;
import java.util.List;
import java.util.Arrays;
import java.util.Date;
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.WmsCoilWarehouseOperationLogVo;
import com.klp.domain.vo.WmsCoilWarehouseOperationLogExportVo;
import com.klp.domain.bo.WmsCoilWarehouseOperationLogBo;
import com.klp.service.IWmsCoilWarehouseOperationLogService;
import com.klp.common.core.page.TableDataInfo;
/**
* 钢卷库区操作记录
*
* @author klp
* @date 2026-03-05
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/wms/coilWarehouseOperationLog")
public class WmsCoilWarehouseOperationLogController extends BaseController {
private final IWmsCoilWarehouseOperationLogService iWmsCoilWarehouseOperationLogService;
/**
* 查询钢卷库区操作记录列表
*/
@GetMapping("/list")
public TableDataInfo<WmsCoilWarehouseOperationLogVo> list(WmsCoilWarehouseOperationLogBo bo, PageQuery pageQuery) {
return iWmsCoilWarehouseOperationLogService.queryPageList(bo, pageQuery);
}
/**
* 导出钢卷库区操作记录列表
*/
@Log(title = "钢卷库区操作记录", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(WmsCoilWarehouseOperationLogBo bo, HttpServletResponse response) {
List<WmsCoilWarehouseOperationLogVo> list = iWmsCoilWarehouseOperationLogService.queryList(bo);
ExcelUtil.exportExcel(list, "钢卷库区操作记录", WmsCoilWarehouseOperationLogVo.class, response);
}
/**
* 获取钢卷库区操作记录详细信息
*
* @param logId 主键
*/
@GetMapping("/{logId}")
public R<WmsCoilWarehouseOperationLogVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long logId) {
return R.ok(iWmsCoilWarehouseOperationLogService.queryById(logId));
}
/**
* 新增钢卷库区操作记录
*/
@Log(title = "钢卷库区操作记录", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody WmsCoilWarehouseOperationLogBo bo) {
return toAjax(iWmsCoilWarehouseOperationLogService.insertByBo(bo));
}
/**
* 修改钢卷库区操作记录
*/
@Log(title = "钢卷库区操作记录", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody WmsCoilWarehouseOperationLogBo bo) {
return toAjax(iWmsCoilWarehouseOperationLogService.updateByBo(bo));
}
/**
* 删除钢卷库区操作记录
*
* @param logIds 主键串
*/
@Log(title = "钢卷库区操作记录", businessType = BusinessType.DELETE)
@DeleteMapping("/{logIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] logIds) {
return toAjax(iWmsCoilWarehouseOperationLogService.deleteWithValidByIds(Arrays.asList(logIds), true));
}
/**
* 根据钢卷 ID、操作类型及出入库类型删除钢卷库区操作记录
*
* @param coilId 钢卷 ID
* @param operationType 操作类型
* @param inOutType 出入库类型
*/
@Log(title = "钢卷库区操作记录", businessType = BusinessType.DELETE)
@DeleteMapping("/byCoilId")
public R<Void> removeByCoilId(@NotNull(message = "钢卷 ID 不能为空")
@RequestParam Long coilId,
@NotNull(message = "操作类型不能为空")
@RequestParam String operationType,
@NotNull(message = "出入库类型不能为空")
@RequestParam String inOutType) {
return toAjax(iWmsCoilWarehouseOperationLogService.deleteByCoilIdAndTypes(coilId, operationType, inOutType));
}
/**
* 根据二级库区ID和时间范围查询操作记录及钢卷信息
*
* @param secondWarehouseId 二级库区ID
* @param startTime 开始时间
* @param endTime 结束时间
*/
@GetMapping("/byWarehouseAndTime")
public R<List<WmsCoilWarehouseOperationLogVo>> getByWarehouseAndTime(
@RequestParam Long secondWarehouseId,
@RequestParam(required = false) Integer operationType,
@RequestParam(required = false) Integer inOutType,
@RequestParam(required = false) Date startTime,
@RequestParam(required = false) Date endTime) {
return R.ok(iWmsCoilWarehouseOperationLogService.queryBySecondWarehouseIdAndTimeRange(secondWarehouseId, operationType, inOutType, startTime, endTime));
}
/**
* 根据钢卷ID查询操作记录及钢卷信息、库区信息
*
* @param coilId 钢卷ID
* @param operationType 操作类型
* @param inOutType 出入库类型
* @param startTime 开始时间
* @param endTime 结束时间
*/
@GetMapping("/byCoilId")
public R<List<WmsCoilWarehouseOperationLogVo>> getByCoilId(
@RequestParam @NotNull(message = "钢卷ID不能为空") Long coilId,
@RequestParam(required = false) Integer operationType,
@RequestParam(required = false) Integer inOutType,
@RequestParam(required = false) Date startTime,
@RequestParam(required = false) Date endTime) {
return R.ok(iWmsCoilWarehouseOperationLogService.queryByCoilId(coilId, operationType, inOutType, startTime, endTime));
}
/**
* 导出钢卷库区操作记录(报表导出)
*
* @param secondWarehouseId 二级库区ID
* @param operationType 操作类型
* @param inOutType 出入库类型
* @param startTime 开始时间
* @param endTime 结束时间
*/
@Log(title = "钢卷库区操作记录导出", businessType = BusinessType.EXPORT)
@PostMapping("/exportByWarehouseAndTime")
public void exportByWarehouseAndTime(
@RequestParam Long secondWarehouseId,
@RequestParam(required = false) Integer operationType,
@RequestParam(required = false) Integer inOutType,
@RequestParam(required = false) Date startTime,
@RequestParam(required = false) Date endTime,
HttpServletResponse response) {
List<WmsCoilWarehouseOperationLogExportVo> list = iWmsCoilWarehouseOperationLogService.exportBySecondWarehouseIdAndTimeRange(secondWarehouseId, operationType, inOutType, startTime, endTime);
ExcelUtil.exportExcel(list, "钢卷库区操作记录导出", WmsCoilWarehouseOperationLogExportVo.class, response);
}
}