package cn.shlanbao.qms.controller; import java.util.List; import lombok.RequiredArgsConstructor; import jakarta.servlet.http.HttpServletResponse; import jakarta.validation.constraints.*; import cn.dev33.satoken.annotation.SaCheckPermission; import org.springframework.web.bind.annotation.*; import org.springframework.validation.annotation.Validated; import org.dromara.common.idempotent.annotation.RepeatSubmit; import org.dromara.common.log.annotation.Log; import org.dromara.common.web.core.BaseController; import org.dromara.common.mybatis.core.page.PageQuery; import org.dromara.common.core.domain.R; import org.dromara.common.core.validate.AddGroup; import org.dromara.common.core.validate.EditGroup; import org.dromara.common.log.enums.BusinessType; import org.dromara.common.excel.utils.ExcelUtil; import cn.shlanbao.qms.domain.vo.LbSensorResultVo; import cn.shlanbao.qms.domain.bo.LbSensorResultBo; import cn.shlanbao.qms.service.ILbSensorResultService; import org.dromara.common.mybatis.core.page.TableDataInfo; /** * 批次明细 * * @author bsw * @date 2024-12-27 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/qms/sensorResult") public class LbSensorResultController extends BaseController { private final ILbSensorResultService lbSensorResultService; /** * 查询批次明细列表 */ @SaCheckPermission("qms:sensorResult:list") @GetMapping("/list") public TableDataInfo list(LbSensorResultBo bo, PageQuery pageQuery) { return lbSensorResultService.queryPageList(bo, pageQuery); } /** * 导出批次明细列表 */ @SaCheckPermission("qms:sensorResult:export") @Log(title = "批次明细", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(LbSensorResultBo bo, HttpServletResponse response) { List list = lbSensorResultService.queryList(bo); ExcelUtil.exportExcel(list, "批次明细", LbSensorResultVo.class, response); } /** * 获取批次明细详细信息 * * @param batchCode 主键 */ @SaCheckPermission("qms:sensorResult:query") @GetMapping("/{batchCode}") public R getInfo(@NotNull(message = "主键不能为空") @PathVariable String batchCode) { return R.ok(lbSensorResultService.queryById(batchCode)); } /** * 新增批次明细 */ @SaCheckPermission("qms:sensorResult:add") @Log(title = "批次明细", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping() public R add(@Validated(AddGroup.class) @RequestBody LbSensorResultBo bo) { return toAjax(lbSensorResultService.insertByBo(bo)); } /** * 修改批次明细 */ @SaCheckPermission("qms:sensorResult:edit") @Log(title = "批次明细", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R edit(@Validated(EditGroup.class) @RequestBody LbSensorResultBo bo) { return toAjax(lbSensorResultService.updateByBo(bo)); } /** * 删除批次明细 * * @param batchCodes 主键串 */ @SaCheckPermission("qms:sensorResult:remove") @Log(title = "批次明细", businessType = BusinessType.DELETE) @DeleteMapping("/{batchCodes}") public R remove(@NotEmpty(message = "主键不能为空") @PathVariable String[] batchCodes) { return toAjax(lbSensorResultService.deleteWithValidByIds(List.of(batchCodes), true)); } }