From 2f0009c750de4d47a18cce4a5a403fa83ba0c209 Mon Sep 17 00:00:00 2001 From: baoshiwei <baoshiwei@shlanbao.cn> Date: 星期三, 02 七月 2025 08:58:27 +0800 Subject: [PATCH] feat(report): 新增设备稼动率统计功能 --- eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/service/impl/EimsRepairReqServiceImpl.java | 126 +++++++++++++++++++++++++++++++++++------ 1 files changed, 107 insertions(+), 19 deletions(-) diff --git a/eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/service/impl/EimsRepairReqServiceImpl.java b/eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/service/impl/EimsRepairReqServiceImpl.java index 42fa842..7f109ea 100644 --- a/eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/service/impl/EimsRepairReqServiceImpl.java +++ b/eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/service/impl/EimsRepairReqServiceImpl.java @@ -1,7 +1,12 @@ package org.dromara.eims.service.impl; +import cn.hutool.core.convert.Convert; +import cn.hutool.core.util.ObjectUtil; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import org.dromara.common.core.constant.DictConstants; +import org.dromara.common.core.service.RepairReqService; import org.dromara.common.core.utils.MapstructUtils; +import org.dromara.common.core.utils.SpringUtils; import org.dromara.common.core.utils.StringUtils; import org.dromara.common.mybatis.core.page.TableDataInfo; import org.dromara.common.mybatis.core.page.PageQuery; @@ -10,17 +15,24 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers; import lombok.RequiredArgsConstructor; import org.dromara.eims.domain.EimsEqu; +import org.dromara.eims.domain.EimsFixtureBorrow; +import org.dromara.eims.domain.EimsRepairRecord; +import org.dromara.eims.domain.vo.EimsFixtureVo; import org.dromara.eims.domain.vo.EimsInventoryDetailVo; +import org.dromara.eims.mapper.EimsRepairRecordMapper; +import org.dromara.eims.utils.DataFilterUtil; +import org.dromara.system.domain.SysDept; +import org.dromara.system.domain.vo.SysDeptVo; +import org.dromara.system.mapper.SysDeptMapper; import org.springframework.stereotype.Service; import org.dromara.eims.domain.bo.EimsRepairReqBo; import org.dromara.eims.domain.vo.EimsRepairReqVo; import org.dromara.eims.domain.EimsRepairReq; import org.dromara.eims.mapper.EimsRepairReqMapper; import org.dromara.eims.service.IEimsRepairReqService; +import org.springframework.transaction.annotation.Transactional; -import java.util.List; -import java.util.Map; -import java.util.Collection; +import java.util.*; /** * 鏁呴殰鎶ヤ慨Service涓氬姟灞傚鐞� @@ -30,9 +42,11 @@ */ @RequiredArgsConstructor @Service -public class EimsRepairReqServiceImpl implements IEimsRepairReqService { +public class EimsRepairReqServiceImpl implements IEimsRepairReqService, RepairReqService { private final EimsRepairReqMapper baseMapper; + private final EimsRepairRecordMapper recordMapper; + private final SysDeptMapper sysDeptMapper; /** * 鏌ヨ鏁呴殰鎶ヤ慨 @@ -41,7 +55,7 @@ * @return 鏁呴殰鎶ヤ慨 */ @Override - public EimsRepairReqVo queryById(Long id){ + public EimsRepairReqVo queryById(Long id) { return baseMapper.selectVoById(id); } @@ -61,6 +75,8 @@ @Override public TableDataInfo<EimsRepairReqVo> queryPageListCustom(EimsRepairReqBo bo, PageQuery pageQuery) { + //TODO + //DataFilterUtil.getInstance().filterRepairReq(bo); Page<EimsRepairReqVo> page = baseMapper.selectRepairReqList(pageQuery.build(), buildWrapper(bo)); return TableDataInfo.build(page); } @@ -68,22 +84,69 @@ private QueryWrapper<EimsRepairReq> buildWrapper(EimsRepairReqBo bo) { Map<String, Object> params = bo.getParams(); QueryWrapper<EimsRepairReq> qw = Wrappers.query(); - qw.eq(StringUtils.isNotBlank(bo.getCode()),"code", bo.getCode()); - qw.eq(StringUtils.isNotBlank(bo.getStatus()), "status", bo.getStatus()); - qw.eq(bo.getReqTime() != null, "req_time", bo.getReqTime()); - qw.eq(bo.getReqDept() != null, "req_dept", bo.getReqDept()); - qw.eq(bo.getReqUser() != null,"req_user", bo.getReqUser()); - qw.eq(StringUtils.isNotBlank(bo.getUrgencyLevel()), "urgency_level", bo.getUrgencyLevel()); - qw.eq(StringUtils.isNotBlank(bo.getReqType()), "req_type", bo.getReqType()); - qw.eq(bo.getEquId() != null, "equ_id", bo.getEquId()); - qw.eq(bo.getRepairDept() != null,"repair_dept", bo.getRepairDept()); - qw.eq(bo.getRepairUser() != null, "repair_user", bo.getRepairUser()); - qw.eq(StringUtils.isNotBlank(bo.getFaultType()), "fault_type", bo.getFaultType()); + qw.like(StringUtils.isNotBlank(bo.getCode()), "a.code", bo.getCode()); + qw.eq(StringUtils.isNotBlank(bo.getStatus()), "a.status", bo.getStatus()); + qw.eq(bo.getReqTime() != null, "a.req_time", bo.getReqTime()); + qw.eq(bo.getReqUser() != null, "a.req_user", bo.getReqUser()); + qw.eq(StringUtils.isNotBlank(bo.getUrgencyLevel()), "a.urgency_level", bo.getUrgencyLevel()); + qw.eq(StringUtils.isNotBlank(bo.getReqType()), "a.req_type", bo.getReqType()); + qw.eq(bo.getEquId() != null, "a.equ_id", bo.getEquId()); + qw.eq(bo.getRepairDept() != null, "a.repair_dept", bo.getRepairDept()); + qw.eq(bo.getRepairUser() != null, "a.repair_user", bo.getRepairUser()); + qw.eq(StringUtils.isNotBlank(bo.getFaultType()), "a,fault_type", bo.getFaultType()); + qw.in(params.containsKey("createBy"), "a.create_by", (List<Long>) params.get("createBy")); + Object status = params.get("status") == null ? "" : params.get("status"); + if (params.get("searchValue") != null && StringUtils.isNotBlank(params.get("searchValue").toString())) { + qw.and( wq ->wq.like("b.equ_name", params.get("searchValue")) + .or().like("b.asset_no", params.get("searchValue")) + ); + } + String[] split = status.toString().split(","); + qw.in(params.containsKey("status"), "a.status", split); qw.between(params.get("beginReqTime") != null && params.get("endReqTime") != null, - "req_time", params.get("beginReqTime"), params.get("endReqTime")); + "a.req_time", params.get("beginReqTime"), params.get("endReqTime")); + qw.ne(StringUtils.isNotBlank(bo.getStatusLt()), "a.status", bo.getStatusLt()); + qw.eq(bo.getCreateBy()!=null, "a.create_by", bo.getCreateBy()); + qw.eq(StringUtils.isNotEmpty(bo.getStatus()), "a.status", bo.getStatus()); + qw.orderByDesc("a.create_time"); + + /** + * 鏌ヨ閮ㄩ棬涓嬫墍鏈夊瓙閮ㄩ棬 + */ + if (bo.getReqDept() != null) { + List<Long> allDescendantIds = getAllDescendantIds(bo.getReqDept()); + qw.in(bo.getReqDept() != null, "a.req_dept", allDescendantIds); + } + return qw; } + /** + * 鏍规嵁id锛岃幏鍙栨墍鏈夊悗浠d + * + * @param rootId + * @return + */ + public List<Long> getAllDescendantIds(Long rootId) { + List<Long> result = new ArrayList<>(); + result.add(rootId); + collectDescendants(rootId, result); + return result; + } + + private void collectDescendants(Long currentId, List<Long> collector) { + QueryWrapper<SysDept> sysDeptWrapper = new QueryWrapper<>(); + sysDeptWrapper.lambda().eq(SysDept::getParentId, currentId); + + List<SysDeptVo> children = sysDeptMapper.selectVoList(sysDeptWrapper); + if (children != null && !children.isEmpty()) { + for (SysDeptVo child : children) { + Long childId = child.getDeptId(); + collector.add(childId); + collectDescendants(childId, collector); + } + } + } /** * 鏌ヨ绗﹀悎鏉′欢鐨勬晠闅滄姤淇垪琛� @@ -111,6 +174,8 @@ lqw.eq(bo.getRepairDept() != null, EimsRepairReq::getRepairDept, bo.getRepairDept()); lqw.eq(bo.getRepairUser() != null, EimsRepairReq::getRepairUser, bo.getRepairUser()); lqw.eq(StringUtils.isNotBlank(bo.getFaultType()), EimsRepairReq::getFaultType, bo.getFaultType()); + // 鎸夊垱寤烘椂闂村�掑簭 + lqw.orderByDesc(EimsRepairReq::getCreateTime); return lqw; } @@ -120,6 +185,7 @@ * @param bo 鏁呴殰鎶ヤ慨 * @return 鏄惁鏂板鎴愬姛 */ + @Transactional(rollbackFor = Exception.class) @Override public Boolean insertByBo(EimsRepairReqBo bo) { EimsRepairReq add = MapstructUtils.convert(bo, EimsRepairReq.class); @@ -127,6 +193,16 @@ boolean flag = baseMapper.insert(add) > 0; if (flag) { bo.setId(add.getId()); + //鏂板鎶ヤ慨鍗曟椂鐢熸垚缁翠慨璁板綍 + EimsRepairRecord record = new EimsRepairRecord(); + record.setReqId(add.getId()); + record.setHandleTime(new Date()); + //鏂板鐘舵�� + record.setOpera(DictConstants.REPAIR_RECORD_HANDLE_DETAIL.XINZENG); + record.setOperaUser(add.getCreateBy()); + record.setOperaResult("鐢熸垚鎶ヤ慨鍗�"); + //鏂板鏃剁敓鎴愯褰� + recordMapper.insert(record); } return flag; } @@ -147,7 +223,7 @@ /** * 淇濆瓨鍓嶇殑鏁版嵁鏍¢獙 */ - private void validEntityBeforeSave(EimsRepairReq entity){ + private void validEntityBeforeSave(EimsRepairReq entity) { //TODO 鍋氫竴浜涙暟鎹牎楠�,濡傚敮涓�绾︽潫 } @@ -160,11 +236,23 @@ */ @Override public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) { - if(isValid){ + if (isValid) { //TODO 鍋氫竴浜涗笟鍔′笂鐨勬牎楠�,鍒ゆ柇鏄惁闇�瑕佹牎楠� } return baseMapper.deleteByIds(ids) > 0; } + @Override + public String selectRepairReqCodeByIds(String reqIds) { + List<String> list = new ArrayList<>(); + for (Long id : StringUtils.splitTo(reqIds, Convert::toLong)) { + EimsRepairReqVo vo = SpringUtils.getAopProxy(this).queryById(id); + if (ObjectUtil.isNotNull(vo)) { + list.add(vo.getCode()); + } + } + return String.join(StringUtils.SEPARATOR, list); + } + } -- Gitblit v1.9.3