package com.fzzy.igds; import com.bstek.dorado.annotation.DataProvider; import com.bstek.dorado.annotation.DataResolver; import com.bstek.dorado.annotation.Expose; import com.bstek.dorado.data.entity.EntityState; import com.bstek.dorado.data.entity.EntityUtils; import com.bstek.dorado.data.provider.Page; import com.fzzy.igds.domain.DeviceIot; import com.fzzy.igds.service.DeviceIotService; import com.fzzy.igds.utils.ContextUtil; import com.ruoyi.common.utils.StringUtils; import org.springframework.beans.BeanUtils; import org.springframework.data.domain.PageRequest; import org.springframework.data.domain.Pageable; import org.springframework.data.domain.Sort; import org.springframework.data.jpa.domain.Specification; import org.springframework.stereotype.Component; import org.springframework.transaction.annotation.Transactional; import javax.annotation.Resource; import javax.persistence.criteria.CriteriaBuilder; import javax.persistence.criteria.CriteriaQuery; import javax.persistence.criteria.Predicate; import javax.persistence.criteria.Root; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; /** * @Description * @Author CZT * @Date 2025/11/28 14:53 */ @Component public class DeviceIotPR { @Resource private DeviceIotService deviceIotService; /** * 查询设备,将操作信息调整为空 * * deviceIotPR#loadDeviceIotPage * * @param page * @param param * @return */ @DataProvider public void loadDeviceIotPage(Page page, Map param) { if (null == param) { param = new HashMap<>(); } Map finalParam = param; //多参数分页查询 Pageable pageable = PageRequest.of(page.getPageNo() - 1, page.getPageSize(), Sort.Direction.ASC, DeviceIot.SORT_PROP); Specification specification = new Specification() { private static final long serialVersionUID = 1L; public Predicate toPredicate(Root root, CriteriaQuery query, CriteriaBuilder cb) { List predicates = new ArrayList(); //所有的断言 Predicate predicate1 = cb.equal(root.get("companyId"), ContextUtil.getCompanyId()); predicates.add(predicate1); predicate1 = cb.equal(root.get("deptId"), ContextUtil.subDeptId(null)); predicates.add(predicate1); String key = (String) finalParam.get("depotId"); if (StringUtils.isNotEmpty(key)) { predicate1 = cb.equal(root.get("depotId"), key); predicates.add(predicate1); } key = (String) finalParam.get("type"); if (StringUtils.isNotEmpty(key)) { predicate1 = cb.equal(root.get("type"), key); predicates.add(predicate1); } key = (String) finalParam.get("serId"); if (StringUtils.isNotEmpty(key)) { predicate1 = cb.equal(root.get("serId"), key); predicates.add(predicate1); } return cb.and(predicates.toArray(new Predicate[0])); } }; org.springframework.data.domain.Page japPage = deviceIotService.findAll(specification, pageable); page.setEntityCount((int) japPage.getTotalElements()); page.setEntities(japPage.getContent()); } /** * 保存 devicePR#saveAll * * @param depotDeviceIots * @return */ @DataResolver @Transactional public String saveAll(List depotDeviceIots) { String msg = ""; DeviceIot deviceIot; for (DeviceIot depotDeviceIot : depotDeviceIots) { EntityState state = EntityUtils.getState(depotDeviceIot); deviceIot = new DeviceIot(); BeanUtils.copyProperties(depotDeviceIot, deviceIot); if (state == EntityState.NEW) { deviceIotService.updateDeviceIot(deviceIot); msg = "添加成功!"; } if (state == EntityState.DELETED) { deviceIotService.delDepotDeviceIot(deviceIot); msg = "删除成功!"; } if (state == EntityState.MODIFIED) { deviceIotService.updateDeviceIot(deviceIot); msg = "修改成功!"; } } return msg; } /** * devicePR#refreshCache */ @Expose public void refreshCache(){ deviceIotService.refreshCache(null); } }