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.device.entity.DeviceStocktakingPlan; import com.by4cloud.platformx.device.service.DeviceStocktakingPlanService; 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 syt * @date 2025-04-24 15:19:13 */ @RestController @RequiredArgsConstructor @RequestMapping("/deviceStocktakingPlan" ) @Tag(description = "deviceStocktakingPlan" , name = "设备盘点计划管理" ) @SecurityRequirement(name = HttpHeaders.AUTHORIZATION) public class DeviceStocktakingPlanController { private final DeviceStocktakingPlanService deviceStocktakingPlanService; /** * 分页查询 * @param page 分页对象 * @param deviceStocktakingPlan 设备盘点计划 * @return */ @Operation(summary = "分页查询" , description = "分页查询" ) @GetMapping("/page" ) @PreAuthorize("@pms.hasPermission('device_deviceStocktakingPlan_view')" ) public R getDeviceStocktakingPlanPage(@ParameterObject Page page, @ParameterObject DeviceStocktakingPlan deviceStocktakingPlan) { LambdaQueryWrapper wrapper = Wrappers.lambdaQuery(); wrapper.eq(StrUtil.isNotBlank(deviceStocktakingPlan.getPlanName()), DeviceStocktakingPlan::getPlanName,deviceStocktakingPlan.getPlanName()); wrapper.eq(Objects.nonNull(deviceStocktakingPlan.getPlanStatus()),DeviceStocktakingPlan::getPlanStatus,deviceStocktakingPlan.getPlanStatus()); wrapper.eq(StrUtil.isNotBlank(deviceStocktakingPlan.getResultFlag())&&"1".equals(deviceStocktakingPlan.getResultFlag()),DeviceStocktakingPlan::getPlanStatus,2) .or().eq(StrUtil.isNotBlank(deviceStocktakingPlan.getResultFlag())&&"1".equals(deviceStocktakingPlan.getResultFlag()),DeviceStocktakingPlan::getPlanStatus,3); wrapper.orderByDesc(DeviceStocktakingPlan::getCreateTime); return R.ok(deviceStocktakingPlanService.page(page, wrapper)); } /** * 通过id查询设备盘点计划 * @param id id * @return R */ @Operation(summary = "通过id查询" , description = "通过id查询" ) @GetMapping("/{id}" ) @PreAuthorize("@pms.hasPermission('device_deviceStocktakingPlan_view')" ) public R getById(@PathVariable("id" ) Long id) { return deviceStocktakingPlanService.getByIdNew(id); } /** * 新增设备盘点计划 * @param deviceStocktakingPlan 设备盘点计划 * @return R */ @Operation(summary = "新增设备盘点计划" , description = "新增设备盘点计划" ) @SysLog("新增设备盘点计划" ) @PostMapping @PreAuthorize("@pms.hasPermission('device_deviceStocktakingPlan_add')" ) public R save(@RequestBody DeviceStocktakingPlan deviceStocktakingPlan) { return deviceStocktakingPlanService.saveNew(deviceStocktakingPlan); } /** * 修改设备盘点计划 * @param deviceStocktakingPlan 设备盘点计划 * @return R */ @Operation(summary = "修改设备盘点计划" , description = "修改设备盘点计划" ) @SysLog("修改设备盘点计划" ) @PutMapping @PreAuthorize("@pms.hasPermission('device_deviceStocktakingPlan_edit')" ) public R updateById(@RequestBody DeviceStocktakingPlan deviceStocktakingPlan) { return deviceStocktakingPlanService.updateByIdNew(deviceStocktakingPlan); } /** * 通过id删除设备盘点计划 * @param ids id列表 * @return R */ @Operation(summary = "通过id删除设备盘点计划" , description = "通过id删除设备盘点计划" ) @SysLog("通过id删除设备盘点计划" ) @DeleteMapping @PreAuthorize("@pms.hasPermission('device_deviceStocktakingPlan_del')" ) public R removeById(@RequestBody Long[] ids) { return R.ok(deviceStocktakingPlanService.removeBatchByIds(CollUtil.toList(ids))); } /** * 导出excel 表格 * @param deviceStocktakingPlan 查询条件 * @param ids 导出指定ID * @return excel 文件流 */ @ResponseExcel @GetMapping("/export") @PreAuthorize("@pms.hasPermission('device_deviceStocktakingPlan_export')" ) public List export(DeviceStocktakingPlan deviceStocktakingPlan,Long[] ids) { return deviceStocktakingPlanService.list(Wrappers.lambdaQuery(deviceStocktakingPlan).in(ArrayUtil.isNotEmpty(ids), DeviceStocktakingPlan::getId, ids)); } /** * 通过id审核通过设备盘点计划 * @param id id * @return R */ @Operation(summary = "通过id审核通过设备盘点计划" , description = "通过id审核通过设备盘点计划" ) @GetMapping("/approved/{id}" ) @PreAuthorize("@pms.hasPermission('device_deviceStocktakingPlan_approved')" ) public R approved(@PathVariable("id" ) Long id) { return deviceStocktakingPlanService.approved(id); } /** * 通过盘点计划id生成盘点单 * @param id id * @return R */ @Operation(summary = "通过盘点计划id生成盘点单" , description = "通过盘点计划id生成盘点单" ) @GetMapping("/genRecord/{id}" ) @PreAuthorize("@pms.hasPermission('device_deviceStocktakingPlan_genrecord')" ) public R genRecord(@PathVariable("id" ) Long id) { return deviceStocktakingPlanService.genRecord(id); } /** * 通过盘点计划id获取盘点结果 * @param id id * @return R */ @Operation(summary = "通过盘点计划id获取盘点结果" , description = "通过盘点计划id获取盘点结果" ) @GetMapping("/getResult/{id}" ) public R getResult(@PathVariable("id" ) Long id) { return deviceStocktakingPlanService.getResult(id); } /** * 通过盘点计划id完成盘点结果 * @param id id * @return R */ @Operation(summary = "通过盘点计划id完成盘点结果" , description = "通过盘点计划id完成盘点结果" ) @GetMapping("/complete/{id}" ) public R complete(@PathVariable("id" ) Long id) { return deviceStocktakingPlanService.complete(id); } }