package com.by4cloud.platformx.device.controller; import cn.hutool.core.util.ArrayUtil; import cn.hutool.core.collection.CollUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.StringUtils; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.by4cloud.platformx.common.core.util.R; import com.by4cloud.platformx.common.log.annotation.SysLog; import com.by4cloud.platformx.device.constant.MaxSizeContant; import com.by4cloud.platformx.device.entity.Contract; import com.by4cloud.platformx.device.service.JcMaxSizeService; import com.by4cloud.platformx.device.service.PurchaseTendrOrderService; import com.by4cloud.platformx.device.entity.PurchaseTendrOrderEntity; import com.by4cloud.platformx.device.service.PurchaseTendrOrderService; import org.springframework.security.access.prepost.PreAuthorize; import com.by4cloud.platformx.common.excel.annotation.ResponseExcel; import io.swagger.v3.oas.annotations.security.SecurityRequirement; import org.springdoc.api.annotations.ParameterObject; import org.springframework.http.HttpHeaders; import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.Operation; import lombok.RequiredArgsConstructor; import org.springframework.web.bind.annotation.*; import java.util.List; import java.util.Objects; /** * 招标采购单 * * @author pig * @date 2025-03-24 15:45:03 */ @RestController @RequiredArgsConstructor @RequestMapping("/purchaseTendrOrder" ) @Tag(description = "purchaseTendrOrder" , name = "招标采购单管理" ) @SecurityRequirement(name = HttpHeaders.AUTHORIZATION) public class PurchaseTendrOrderController { private final PurchaseTendrOrderService purchaseTendrOrderService; private final JcMaxSizeService jcMaxSizeService; /** * 分页查询 * @param page 分页对象 * @param purchaseTendrOrder 招标采购单 * @return */ @Operation(summary = "分页查询" , description = "分页查询" ) @GetMapping("/page" ) @PreAuthorize("@pms.hasPermission('platformx_purchaseTendrOrder_view')" ) public R getPurchaseTendrOrderPage(@ParameterObject Page page, @ParameterObject PurchaseTendrOrderEntity purchaseTendrOrder) { LambdaQueryWrapper wrapper = Wrappers.lambdaQuery(); wrapper.like(StringUtils.isNotEmpty(purchaseTendrOrder.getOrderName()),PurchaseTendrOrderEntity::getOrderName,purchaseTendrOrder.getOrderName()); wrapper.like(StringUtils.isNotEmpty(purchaseTendrOrder.getPurchasePlanCode()),PurchaseTendrOrderEntity::getPurchasePlanCode,purchaseTendrOrder.getPurchasePlanCode()); wrapper.orderByDesc(PurchaseTendrOrderEntity::getCreateTime); return R.ok(purchaseTendrOrderService.page(page, wrapper)); } /** * 通过id查询招标采购单 * @param id id * @return R */ @Operation(summary = "通过id查询" , description = "通过id查询" ) @GetMapping("/{id}" ) @PreAuthorize("@pms.hasPermission('platformx_purchaseTendrOrder_view')" ) public R getById(@PathVariable("id" ) Long id) { return R.ok(purchaseTendrOrderService.getById(id)); } /** * 新增招标采购单 * @param purchaseTendrOrder 招标采购单 * @return R */ @Operation(summary = "新增招标采购单" , description = "新增招标采购单" ) @SysLog("新增招标采购单" ) @PostMapping @PreAuthorize("@pms.hasPermission('platformx_purchaseTendrOrder_add')" ) public R save(@RequestBody PurchaseTendrOrderEntity purchaseTendrOrder) { purchaseTendrOrder.setPurchasePlanCode(jcMaxSizeService.nextNo(MaxSizeContant.PURCHASE_PLAN_CODE)); return R.ok(purchaseTendrOrderService.save(purchaseTendrOrder)); } /** * 修改招标采购单 * @param purchaseTendrOrder 招标采购单 * @return R */ @Operation(summary = "修改招标采购单" , description = "修改招标采购单" ) @SysLog("修改招标采购单" ) @PutMapping @PreAuthorize("@pms.hasPermission('platformx_purchaseTendrOrder_edit')" ) public R updateById(@RequestBody PurchaseTendrOrderEntity purchaseTendrOrder) { return R.ok(purchaseTendrOrderService.updateById(purchaseTendrOrder)); } /** * 通过id删除招标采购单 * @param ids id列表 * @return R */ @Operation(summary = "通过id删除招标采购单" , description = "通过id删除招标采购单" ) @SysLog("通过id删除招标采购单" ) @DeleteMapping @PreAuthorize("@pms.hasPermission('platformx_purchaseTendrOrder_del')" ) public R removeById(@RequestBody Long[] ids) { return R.ok(purchaseTendrOrderService.removeBatchByIds(CollUtil.toList(ids))); } /** * 导出excel 表格 * @param purchaseTendrOrder 查询条件 * @param ids 导出指定ID * @return excel 文件流 */ @ResponseExcel @GetMapping("/export") @PreAuthorize("@pms.hasPermission('platformx_purchaseTendrOrder_export')" ) public List export(PurchaseTendrOrderEntity purchaseTendrOrder,Long[] ids) { return purchaseTendrOrderService.list(Wrappers.lambdaQuery(purchaseTendrOrder).in(ArrayUtil.isNotEmpty(ids), PurchaseTendrOrderEntity::getId, ids)); } /** * 通过id删除招标采购单 * @param ids id列表 * @return R */ @Operation(summary = "通过id完成招标采购单" , description = "通过id完成招标采购单" ) @SysLog("通过id完成招标采购单" ) @GetMapping("/complete/{id}") @PreAuthorize("@pms.hasPermission('platformx_purchaseTendrOrder_complete')" ) public R complete(@PathVariable("id")Long id) { return R.ok(purchaseTendrOrderService.complete(id)); } /** * 获取招标下拉列表 * @return */ @GetMapping("/getPurchaseRenderList" ) public R getPurchaseRenderList() { return R.ok(purchaseTendrOrderService.getPurchaseRenderList()); } }