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.conditions.query.QueryWrapper; 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.admin.api.entity.SysDeptRelation; 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.entity.Device; import com.by4cloud.platformx.device.entity.DeviceInventory; import com.by4cloud.platformx.device.entity.InvestmentPlan; import com.by4cloud.platformx.device.service.DeviceInventoryService; import com.by4cloud.platformx.device.service.DeviceService; 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.List; import java.util.Objects; /** * 出租设备清单表 * * @author pig * @date 2025-03-05 14:26:14 */ @RestController @RequiredArgsConstructor @RequestMapping("/device" ) @Tag(description = "device" , name = "出租设备清单表管理" ) @SecurityRequirement(name = HttpHeaders.AUTHORIZATION) public class DeviceController { private final DeviceService deviceService; private final DeviceInventoryService inventoryService; private final JcMaxSizeService maxSizeService; /** * 分页查询 * @param page 分页对象 * @param device 出租设备清单表 * @return */ @Operation(summary = "分页查询" , description = "分页查询" ) @GetMapping("/page" ) @PreAuthorize("@pms.hasPermission('platformx_device_view')" ) public R getDevicePage(@ParameterObject Page page, @ParameterObject Device device) { LambdaQueryWrapper wrapper = Wrappers.lambdaQuery(); wrapper.eq(Device::getReqStatus,1); wrapper.like(StrUtil.isNotBlank(device.getNumber()),Device::getNumber,device.getNumber()); wrapper.like(StrUtil.isNotBlank(device.getName()),Device::getName,device.getName()); wrapper.orderByDesc(Device::getCreateTime); Page page1 = deviceService.page(page, wrapper); for (Device device1 : page1.getRecords()) { QueryWrapper wrapper1 = new QueryWrapper<>(); wrapper1.lambda().eq(DeviceInventory::getDeviceId,device1.getId()); long count = inventoryService.count(wrapper1); device1.setNum(Integer.parseInt(count+"")); } return R.ok(page1); } /** * 分页查询 * @param page 分页对象 * @param device 出租设备清单表 * @return */ @Operation(summary = "分页查询" , description = "分页查询" ) @GetMapping("/page2" ) @PreAuthorize("@pms.hasPermission('platformx_device_view')" ) public R getDevicePage2(@ParameterObject Page page, @ParameterObject Device device) { LambdaQueryWrapper wrapper = Wrappers.lambdaQuery(); wrapper.ne(Device::getReqStatus,1); wrapper.like(StrUtil.isNotBlank(device.getNumber()),Device::getNumber,device.getNumber()); wrapper.like(StrUtil.isNotBlank(device.getName()),Device::getName,device.getName()); return R.ok(deviceService.page(page, wrapper)); } @Operation(summary = "根据设备分类获取设备" , description = "根据设备分类获取设备" ) @GetMapping("/getByClassId" ) public R getByClassId(@ParameterObject Device device) { LambdaQueryWrapper wrapper = Wrappers.lambdaQuery(); wrapper.eq(Device::getReqStatus,1); wrapper.eq(Device::getClassId,device.getClassId()); wrapper.like(StrUtil.isNotBlank(device.getName()),Device::getName,device.getName()); return R.ok(deviceService.list(wrapper)); } /** * 通过id查询出租设备清单表 * @param id id * @return R */ @Operation(summary = "通过id查询" , description = "通过id查询" ) @GetMapping("/{id}" ) @PreAuthorize("@pms.hasPermission('platformx_device_view')" ) public R getById(@PathVariable("id" ) Long id) { return R.ok(deviceService.getById(id)); } /** * 审批通过 * @return R */ @Operation(summary = "审批通过" , description = "审批通过" ) @PostMapping("/pass" ) public R passById(@RequestBody Device device) { if(StringUtils.isBlank(device.getNumber())){ return R.failed("请填写设备编号"); } device.setNumber(maxSizeService.nextNo(MaxSizeContant.DEVICE_NUM)); device.setReqStatus(1); deviceService.updateById(device); return R.ok(); } /** * 审批拒绝 * @return R */ @Operation(summary = "审批拒绝" , description = "审批拒绝" ) @GetMapping("/kill" ) public R killById(@ParameterObject Device device) { Device byId = deviceService.getById(device.getId()); byId.setReqStatus(2); if(StringUtils.isNotBlank(device.getRemark())){ byId.setRemark(device.getRemark()); } deviceService.updateById(byId); return R.ok(); } /** * 新增出租设备清单表 * @param device 出租设备清单表 * @return R */ @Operation(summary = "新增出租设备清单表" , description = "新增出租设备清单表" ) @SysLog("新增出租设备清单表" ) @PostMapping public R save(@RequestBody Device device) { if(device.getReqStatus()==0){ return R.ok(deviceService.save(device)); } device.setNumber(maxSizeService.nextNo(MaxSizeContant.DEVICE_NUM)); return R.ok(deviceService.save(device)); } /** * 三级单位新增设备清单 * @param device 三级单位新增设备清单 * @return R */ @Operation(summary = "三级单位新增设备清单" , description = "三级单位新增设备清单" ) @SysLog("新增出租设备清单表" ) @PostMapping("/childAdd") public R childAdd(@RequestBody Device device) { device.setReqStatus(0); return R.ok(deviceService.save(device)); } /** * 修改出租设备清单表 * @param device 出租设备清单表 * @return R */ @Operation(summary = "修改出租设备清单表" , description = "修改出租设备清单表" ) @SysLog("修改出租设备清单表" ) @PutMapping @PreAuthorize("@pms.hasPermission('platformx_device_edit')" ) public R updateById(@RequestBody Device device) { return R.ok(deviceService.updateById(device)); } /** * 通过id删除出租设备清单表 * @param ids id列表 * @return R */ @Operation(summary = "通过id删除出租设备清单表" , description = "通过id删除出租设备清单表" ) @SysLog("通过id删除出租设备清单表" ) @DeleteMapping @PreAuthorize("@pms.hasPermission('platformx_device_del')" ) public R removeById(@RequestBody Long[] ids) { return R.ok(deviceService.removeBatchByIds(CollUtil.toList(ids))); } /** * 导出excel 表格 * @param device 查询条件 * @param ids 导出指定ID * @return excel 文件流 */ @ResponseExcel @GetMapping("/export") @PreAuthorize("@pms.hasPermission('platformx_device_export')" ) public List export(Device device,Long[] ids) { return deviceService.list(Wrappers.lambdaQuery(device).in(ArrayUtil.isNotEmpty(ids), Device::getId, ids)); } /** * 所有设备下拉 * @return */ @GetMapping("/getDropdowmList" ) public R getDeviceList() { return R.ok(deviceService.list()); } }