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.entity.Device;
|
import com.by4cloud.platformx.device.entity.DeviceInventory;
|
import com.by4cloud.platformx.device.service.DeviceInventoryService;
|
import com.by4cloud.platformx.device.service.DeviceService;
|
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;
|
|
/**
|
* 分页查询
|
* @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<Device> 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());
|
Page<Device> page1 = deviceService.page(page, wrapper);
|
for (Device device1 : page1.getRecords()) {
|
QueryWrapper<DeviceInventory> 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<Device> 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<Device> 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("请填写设备编号");
|
}
|
QueryWrapper<Device> wrapper = new QueryWrapper<>();
|
wrapper.lambda().eq(Device::getNumber,device.getNumber());
|
List<Device> list = deviceService.list(wrapper);
|
if(list !=null && list.size()>0){
|
Device device1 = list.get(0);
|
if(!device1.getId().equals(device.getId())){
|
return R.failed("已存在该编号");
|
}
|
}
|
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));
|
}
|
if(StringUtils.isBlank(device.getNumber())){
|
return R.failed("请填写设备编号");
|
}
|
QueryWrapper<Device> wrapper = new QueryWrapper<>();
|
wrapper.lambda().eq(Device::getNumber,device.getNumber());
|
List<Device> list = deviceService.list(wrapper);
|
if(list !=null && list.size()>0){
|
return R.failed("已存在该编号");
|
}
|
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) {
|
QueryWrapper<Device> wrapper = new QueryWrapper<>();
|
wrapper.lambda().eq(Device::getNumber,device.getNumber());
|
List<Device> list = deviceService.list(wrapper);
|
if(list !=null && list.size()>0){
|
Device device1 = list.get(0);
|
if(!device1.getId().equals(device.getId())){
|
return R.failed("已存在该编号");
|
}
|
}
|
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<Device> export(Device device,Long[] ids) {
|
return deviceService.list(Wrappers.lambdaQuery(device).in(ArrayUtil.isNotEmpty(ids), Device::getId, ids));
|
}
|
}
|