package com.klp.cost.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.cost.domain.vo.CostProdMetricResultVo; import com.klp.cost.domain.bo.CostProdMetricResultBo; import com.klp.cost.service.ICostProdMetricResultService; import com.klp.common.core.page.TableDataInfo; /** * 生产指标计算结果 * * @author klp * @date 2026-06-17 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/cost/prodMetricResult") public class CostProdMetricResultController extends BaseController { private final ICostProdMetricResultService iCostProdMetricResultService; /** * 查询生产指标计算结果列表 */ @GetMapping("/list") public TableDataInfo list(CostProdMetricResultBo bo, PageQuery pageQuery) { return iCostProdMetricResultService.queryPageList(bo, pageQuery); } /** * 导出生产指标计算结果列表 */ @Log(title = "生产指标计算结果", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(CostProdMetricResultBo bo, HttpServletResponse response) { List list = iCostProdMetricResultService.queryList(bo); ExcelUtil.exportExcel(list, "生产指标计算结果", CostProdMetricResultVo.class, response); } /** * 获取生产指标计算结果详细信息 * * @param resultId 主键 */ @GetMapping("/{resultId}") public R getInfo(@NotNull(message = "主键不能为空") @PathVariable Long resultId) { return R.ok(iCostProdMetricResultService.queryById(resultId)); } /** * 新增生产指标计算结果 */ @Log(title = "生产指标计算结果", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping() public R add(@Validated(AddGroup.class) @RequestBody CostProdMetricResultBo bo) { return toAjax(iCostProdMetricResultService.insertByBo(bo)); } /** * 批量保存生产指标计算结果(先删除再插入) */ @Log(title = "生产指标计算结果", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping("/batch") public R batchSave(@RequestBody CostProdMetricResultBo bo) { return toAjax(iCostProdMetricResultService.batchSaveWithDelete(bo)); } /** * 修改生产指标计算结果 */ @Log(title = "生产指标计算结果", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R edit(@Validated(EditGroup.class) @RequestBody CostProdMetricResultBo bo) { return toAjax(iCostProdMetricResultService.updateByBo(bo)); } /** * 删除生产指标计算结果 * * @param resultIds 主键串 */ @Log(title = "生产指标计算结果", businessType = BusinessType.DELETE) @DeleteMapping("/{resultIds}") public R remove(@NotEmpty(message = "主键不能为空") @PathVariable Long[] resultIds) { return toAjax(iCostProdMetricResultService.deleteWithValidByIds(Arrays.asList(resultIds), true)); } }