| package com.by4cloud.platformx.device.controller; | 
|   | 
| import cn.hutool.core.util.StrUtil; | 
| 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.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.common.security.util.SecurityUtils; | 
| import com.by4cloud.platformx.device.constant.MaxSizeContant; | 
| import com.by4cloud.platformx.device.dto.DevicePurchasePlanQueryDTO; | 
| import com.by4cloud.platformx.device.entity.DevicePurchasePlan; | 
| import com.by4cloud.platformx.device.service.DevicePurchasePlanService; | 
| import com.by4cloud.platformx.device.service.JcMaxSizeService; | 
| 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.Date; | 
| import java.util.List; | 
| import java.util.Objects; | 
|   | 
| /** | 
|  * 设备采购计划 | 
|  * | 
|  * @author syt | 
|  * @date 2025-04-21 14:43:13 | 
|  */ | 
| @RestController | 
| @RequiredArgsConstructor | 
| @RequestMapping("/devicePurchasePlan" ) | 
| @Tag(description = "devicePurchasePlan" , name = "设备采购计划管理" ) | 
| @SecurityRequirement(name = HttpHeaders.AUTHORIZATION) | 
| public class DevicePurchasePlanController { | 
|   | 
|     private final  DevicePurchasePlanService devicePurchasePlanService; | 
|   | 
|     /** | 
|      * 分页查询 | 
|      * @param page 分页对象 | 
|      * @param devicePurchasePlan 设备采购计划 | 
|      * @return | 
|      */ | 
|     @Operation(summary = "分页查询" , description = "分页查询" ) | 
|     @GetMapping("/page" ) | 
|     @PreAuthorize("@pms.hasPermission('device_devicePurchasePlan_view')" ) | 
|     public R getDevicePurchasePlanPage(@ParameterObject Page page, @ParameterObject DevicePurchasePlanQueryDTO queryDTO) { | 
|         return R.ok(devicePurchasePlanService.pageNew(page, queryDTO)); | 
|     } | 
|   | 
|   | 
|     /** | 
|      * 通过id查询设备采购计划 | 
|      * @param id id | 
|      * @return R | 
|      */ | 
|     @Operation(summary = "通过id查询" , description = "通过id查询" ) | 
|     @GetMapping("/{id}" ) | 
|     @PreAuthorize("@pms.hasPermission('device_devicePurchasePlan_view')" ) | 
|     public R getById(@PathVariable("id" ) Long id) { | 
|         return R.ok(devicePurchasePlanService.getByIdNew(id)); | 
|     } | 
|   | 
|     /** | 
|      * 新增设备采购计划 | 
|      * @param devicePurchasePlan 设备采购计划 | 
|      * @return R | 
|      */ | 
|     @Operation(summary = "新增设备采购计划" , description = "新增设备采购计划" ) | 
|     @SysLog("新增设备采购计划" ) | 
|     @PostMapping | 
|     @PreAuthorize("@pms.hasPermission('device_devicePurchasePlan_add')" ) | 
|     public R save(@RequestBody DevicePurchasePlan devicePurchasePlan) { | 
|   | 
|         return R.ok(devicePurchasePlanService.saveNew(devicePurchasePlan)); | 
|     } | 
|   | 
|     /** | 
|      * 修改设备采购计划 | 
|      * @param devicePurchasePlan 设备采购计划 | 
|      * @return R | 
|      */ | 
|     @Operation(summary = "修改设备采购计划" , description = "修改设备采购计划" ) | 
|     @SysLog("修改设备采购计划" ) | 
|     @PutMapping | 
|     @PreAuthorize("@pms.hasPermission('device_devicePurchasePlan_edit')" ) | 
|     public R updateById(@RequestBody DevicePurchasePlan devicePurchasePlan) { | 
|         return R.ok(devicePurchasePlanService.updateByIdNew(devicePurchasePlan)); | 
|     } | 
|   | 
|     /** | 
|      * 通过id删除设备采购计划 | 
|      * @param ids id列表 | 
|      * @return R | 
|      */ | 
|     @Operation(summary = "通过id删除设备采购计划" , description = "通过id删除设备采购计划" ) | 
|     @SysLog("通过id删除设备采购计划" ) | 
|     @DeleteMapping | 
|     @PreAuthorize("@pms.hasPermission('device_devicePurchasePlan_del')" ) | 
|     public R removeById(@RequestBody Long[] ids) { | 
|         return R.ok(devicePurchasePlanService.removeBatchByIds(CollUtil.toList(ids))); | 
|     } | 
|   | 
|   | 
|     /** | 
|      * 导出excel 表格 | 
|      * @param devicePurchasePlan 查询条件 | 
|         * @param ids 导出指定ID | 
|      * @return excel 文件流 | 
|      */ | 
|     @ResponseExcel | 
|     @GetMapping("/export") | 
|     @PreAuthorize("@pms.hasPermission('device_devicePurchasePlan_export')" ) | 
|     public List<DevicePurchasePlan> export(DevicePurchasePlan devicePurchasePlan,Long[] ids) { | 
|         return devicePurchasePlanService.list(Wrappers.lambdaQuery(devicePurchasePlan).in(ArrayUtil.isNotEmpty(ids), DevicePurchasePlan::getId, ids)); | 
|     } | 
|   | 
|     /** | 
|      * 通过id通过设备采购计划 | 
|      * @param id id | 
|      * @return R | 
|      */ | 
|     @Operation(summary = "通过id通过设备采购计划" , description = "通过id通过设备采购计划" ) | 
|     @GetMapping("/approved/{id}" ) | 
|     @PreAuthorize("@pms.hasPermission('device_devicePurchasePlan_approved')" ) | 
|     public R approved(@PathVariable("id" ) Long id) { | 
|         return R.ok(devicePurchasePlanService.approved(id)); | 
|     } | 
| } |