package com.gear.oa.controller; import java.util.List; import java.util.Arrays; import java.util.concurrent.TimeUnit; 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.gear.common.annotation.RepeatSubmit; import com.gear.common.annotation.Log; import com.gear.common.core.controller.BaseController; import com.gear.common.core.domain.PageQuery; import com.gear.common.core.domain.R; import com.gear.common.core.validate.AddGroup; import com.gear.common.core.validate.EditGroup; import com.gear.common.core.validate.QueryGroup; import com.gear.common.enums.BusinessType; import com.gear.common.utils.poi.ExcelUtil; import com.gear.oa.domain.vo.GearPurchasePlanDetailVo; import com.gear.oa.domain.bo.GearPurchasePlanDetailBo; import com.gear.oa.service.IGearPurchasePlanDetailService; import com.gear.common.core.page.TableDataInfo; /** * 采购计划明细 * * @author Joshi * @date 2025-08-30 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/oa/purchasePlanDetail") public class GearPurchasePlanDetailController extends BaseController { private final IGearPurchasePlanDetailService iGearPurchasePlanDetailService; /** * 查询采购计划明细列表 */ @GetMapping("/list") public TableDataInfo list(GearPurchasePlanDetailBo bo, PageQuery pageQuery) { return iGearPurchasePlanDetailService.queryPageList(bo, pageQuery); } /** * 导出采购计划明细列表 */ @Log(title = "采购计划明细", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(GearPurchasePlanDetailBo bo, HttpServletResponse response) { List list = iGearPurchasePlanDetailService.queryList(bo); ExcelUtil.exportExcel(list, "采购计划明细", GearPurchasePlanDetailVo.class, response); } /** * 获取采购计划明细详细信息 * * @param detailId 主键 */ @GetMapping("/{detailId}") public R getInfo(@NotNull(message = "主键不能为空") @PathVariable Long detailId) { return R.ok(iGearPurchasePlanDetailService.queryById(detailId)); } /** * 新增采购计划明细 */ @Log(title = "采购计划明细", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping() public R add(@Validated(AddGroup.class) @RequestBody GearPurchasePlanDetailBo bo) { return toAjax(iGearPurchasePlanDetailService.insertByBo(bo)); } /** * 修改采购计划明细 */ @Log(title = "采购计划明细", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R edit(@Validated(EditGroup.class) @RequestBody GearPurchasePlanDetailBo bo) { return toAjax(iGearPurchasePlanDetailService.updateByBo(bo)); } /** * 删除采购计划明细 * * @param detailIds 主键串 */ @Log(title = "采购计划明细", businessType = BusinessType.DELETE) @DeleteMapping("/{detailIds}") public R remove(@NotEmpty(message = "主键不能为空") @PathVariable Long[] detailIds) { return toAjax(iGearPurchasePlanDetailService.deleteWithValidByIds(Arrays.asList(detailIds), true)); } }