From a54991d9a7116ab541264816a80520a49cdebdcd Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期三, 25 十二月 2024 14:17:24 +0800 Subject: [PATCH] 最新版本541200007 --- server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java | 138 ++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 126 insertions(+), 12 deletions(-) diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java index 1e84509..e7aa1ca 100644 --- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java +++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java @@ -36,7 +36,6 @@ import org.apache.commons.collections.CollectionUtils; import org.apache.commons.lang3.StringUtils; import org.apache.shiro.SecurityUtils; -import org.checkerframework.checker.units.qual.C; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -104,6 +103,7 @@ } } idPath = parent.getCompanyPath(); + company.setHkParentId(parent.getHkId()); company.setCompanyPath(parent.getCompanyPath()+company.getId()+"/"); company.setCompanyNamePath(parent.getCompanyNamePath()+"/"+company.getName()); } @@ -134,7 +134,7 @@ List<OrgAddRequest> addList = new ArrayList<>(); addList.add(getOrgAddModel(company)); BaseResponse<OrgOrUserAddResponse> result = HKService.addBatchOrg(addList); - if(result !=null && StringUtils.equals(result.getCode(),HKConstants.RESPONSE_SUCCEE)){ + if(result !=null && StringUtils.equals(result.getCode(), HKConstants.RESPONSE_SUCCEE)){ OrgOrUserAddResponse data = result.getData(); if(data.getSuccesses()!=null && data.getSuccesses().size()>0){ //澶勭悊鏂板鎴愬姛鐨勬暟鎹紝淇敼娴峰悍鍚屾鐘舵�� @@ -156,6 +156,7 @@ } private boolean delHkOrg(Company company) { OrgDelRequest request =new OrgDelRequest(); + request.setIndexCodes(new String[]{company.getHkId()}); BaseResponse<List<OrgUpdateFailureResponse>> result = HKService.delBatchOrg(request); if(result !=null && StringUtils.equals(result.getCode(),HKConstants.RESPONSE_SUCCEE)){ @@ -232,6 +233,7 @@ .eq(Member::getIsdeleted,Constants.ZERO)) >0){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(), "瀵逛笉璧凤紝璇ラ儴闂ㄤ笅瀛樺湪浜哄憳淇℃伅锛屼笉鑳借繘琛屽垹闄ゆ搷浣滐紒"); } + Company company = new Company(); company.setId(id); company.setEditDate(new Date()); @@ -241,7 +243,7 @@ company.setHkDate(company.getHkDate()); companyMapper.updateById(company); //涓嬪彂娴峰悍瀹夐槻骞冲彴 - if(StringUtils.isBlank(model.getHkId()) && Constants.equalsInteger(Constants.ONE,model.getHkStatus()) && !delHkOrg(model)){ + if(StringUtils.isNotBlank(model.getHkId()) && Constants.equalsInteger(Constants.ONE,model.getHkStatus()) && !delHkOrg(model)){ throw new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"瀵逛笉璧凤紝缁勭粐鍒犻櫎涓嬪彂澶辫触锛岃纭璇ョ粍缁囨棤涓嬬骇缁勭粐鎴栫粍缁囦汉鍛樹俊鎭瘇"); } } @@ -292,7 +294,8 @@ if(companyJoinMapper.selectCount(new QueryWrapper<Company>().lambda() .eq(Company::getIsdeleted,Constants.ZERO ) .eq(Company::getType,Constants.ONE ) - .likeRight(Company::getCompanyPath,company.getCompanyPath())) >0){ + .ne(Company::getId,model.getId()) + .likeRight(Company::getCompanyPath,model.getCompanyPath())) >0){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(), "瀵逛笉璧凤紝涓嬬骇閮ㄩ棬瀛樺湪鍐呴儴缁勭粐锛岃閮ㄩ棬涓嶆敮鎸佸垏鎹负鐩稿叧鏂圭粍缁囷紒~"); } } @@ -352,8 +355,114 @@ @Override public List<Company> findList(Company company) { - QueryWrapper<Company> wrapper = new QueryWrapper<>(company); - return companyMapper.selectList(wrapper); + MPJLambdaWrapper<Company> queryWrapper = new MPJLambdaWrapper<>(); + if (company.getId() != null) { + queryWrapper.eq(Company::getId, company.getId()); + } + if (company.getCreator() != null) { + queryWrapper.eq(Company::getCreator, company.getCreator()); + } + if (company.getCreateDate() != null) { + queryWrapper.ge(Company::getCreateDate, Utils.Date.getStart(company.getCreateDate())); + queryWrapper.le(Company::getCreateDate, Utils.Date.getEnd(company.getCreateDate())); + } + if (company.getEditor() != null) { + queryWrapper.eq(Company::getEditor, company.getEditor()); + } + if (company.getEditDate() != null) { + queryWrapper.ge(Company::getEditDate, Utils.Date.getStart(company.getEditDate())); + queryWrapper.le(Company::getEditDate, Utils.Date.getEnd(company.getEditDate())); + } + if (company.getIsdeleted() != null) { + queryWrapper.eq(Company::getIsdeleted, company.getIsdeleted()); + } + if (company.getName() != null) { + queryWrapper.like(Company::getName, company.getName()); + } + if (company.getRemark() != null) { + queryWrapper.eq(Company::getRemark, company.getRemark()); + } + if (company.getStatus() != null) { + queryWrapper.eq(Company::getStatus, company.getStatus()); + } + if (company.getSortnum() != null) { + queryWrapper.eq(Company::getSortnum, company.getSortnum()); + } + if (company.getImgurl() != null) { + queryWrapper.eq(Company::getImgurl, company.getImgurl()); + } + if (company.getType() != null) { + queryWrapper.eq(Company::getType, company.getType()); + } + if (company.getCategoryId() != null) { + queryWrapper.eq(Company::getCategoryId, company.getCategoryId()); + } + if (company.getCode() != null) { + queryWrapper.eq(Company::getCode, company.getCode()); + } + if (company.getParentId() != null) { + queryWrapper.eq(Company::getParentId, company.getParentId()); + } + if (company.getLinkName() != null) { + queryWrapper.eq(Company::getLinkName, company.getLinkName()); + } + if (company.getLinkPhone() != null) { + queryWrapper.eq(Company::getLinkPhone, company.getLinkPhone()); + } + if (company.getHkId() != null) { + queryWrapper.eq(Company::getHkId, company.getHkId()); + } + if (company.getHkStatus() != null) { + queryWrapper.eq(Company::getHkStatus, company.getHkStatus()); + } + if (company.getHkDate() != null) { + queryWrapper.ge(Company::getHkDate, Utils.Date.getStart(company.getHkDate())); + queryWrapper.le(Company::getHkDate, Utils.Date.getEnd(company.getHkDate())); + } + if (company.getErpId() != null) { + queryWrapper.eq(Company::getErpId, company.getErpId()); + } + if (company.getErpDate() != null) { + queryWrapper.ge(Company::getErpDate, Utils.Date.getStart(company.getErpDate())); + queryWrapper.le(Company::getErpDate, Utils.Date.getEnd(company.getErpDate())); + } + if (company.getErpStatus() != null) { + queryWrapper.eq(Company::getErpStatus, company.getErpStatus()); + } + if (company.getDdId() != null) { + queryWrapper.eq(Company::getDdId, company.getDdId()); + } + if (company.getDdDate() != null) { + queryWrapper.ge(Company::getDdDate, Utils.Date.getStart(company.getDdDate())); + queryWrapper.le(Company::getDdDate, Utils.Date.getEnd(company.getDdDate())); + } + if (company.getDdStatus() != null) { + queryWrapper.eq(Company::getDdStatus, company.getDdStatus()); + } + if (company.getFsId() != null) { + queryWrapper.eq(Company::getFsId, company.getFsId()); + } + if (company.getFsStatus() != null) { + queryWrapper.eq(Company::getFsStatus, company.getFsStatus()); + } + if (company.getFsDate() != null) { + queryWrapper.ge(Company::getFsDate, Utils.Date.getStart(company.getFsDate())); + queryWrapper.le(Company::getFsDate, Utils.Date.getEnd(company.getFsDate())); + } + if (company.getQueryHiddenDanger() != null && Constants.equalsInteger(company.getQueryHiddenDanger(),Constants.ONE)) { + queryWrapper.apply(" t.id in ( select hdp.COMPANY_ID from hidden_danger_param hdp where hdp.ISDELETED = 0 and hdp.STATUS = 0 and hdp.TYPE = 0 ) "); + } + queryWrapper.orderByDesc(Company::getCreateDate); + queryWrapper.leftJoin(Company.class,Company::getId,Company::getParentId); + queryWrapper.select(" t.* ") + .select("(select count(m.id) from member m where m.COMPANY_ID=t.id and m.ISDELETED=0) as countNum") ; + queryWrapper.select("t1.name",Company::getParentName); + queryWrapper.select("t1.company_path",Company::getParentCompanyPath); + queryWrapper.apply(" t.isdeleted = 0 ") ; + queryWrapper.eq(Objects.nonNull(company.getStatus()),Company::getStatus,Constants.ZERO); + queryWrapper.like(StringUtils.isNotBlank(company.getName()),Company::getName,company.getName()); + queryWrapper.like(StringUtils.isNotBlank(company.getParentName()),"c.name",company.getParentName()); + return companyMapper.selectList(queryWrapper); } @Override @@ -482,13 +591,11 @@ companyMapper.updateById(company); } - @Override public long count(Company company) { QueryWrapper<Company> wrapper = new QueryWrapper<>(company); return companyMapper.selectCount(wrapper); } - @Override public List<CompanyDTO> findCompanyTreePage(Integer type) { @@ -500,7 +607,6 @@ List<Company> companies = companyMapper.selectList(wrapper); return getCompanyTree( companies, null); } - private List<CompanyDTO> getCompanyTree(List<Company> companies, String parentId){ if (CollectionUtils.isEmpty(companies)){ @@ -575,8 +681,15 @@ queryWrapper.leftJoin(Member.class,Member::getId,Company::getHeadId); queryWrapper.leftJoin(SystemUser.class,SystemUser::getId,Company::getEditor); queryWrapper.eq(Company::getIsdeleted,Constants.ZERO); - queryWrapper.eq(type!=null,Company::getType,type); - queryWrapper.orderByAsc(Company::getSortnum ); + if(Objects.nonNull(type) && ( Constants.equalsInteger(type,Constants.ONE) || Constants.equalsInteger(type,Constants.ZERO))){ + queryWrapper.eq(type!=null,Company::getType,type); + }else if(Objects.nonNull(type) && Constants.equalsInteger(type,Constants.TWO)){ + String companySpecialId = systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.SPECIAL_COMPANY_ID).getCode(); + if(StringUtils.isNotBlank(companySpecialId)){ + queryWrapper.apply(" (find_in_set('"+companySpecialId+"',REPLACE(t.company_path,'/',',')) or t.parent_id is null ) "); + } + } + queryWrapper.orderByAsc(true,"t.sortnum"); List<Company> companyList = companyJoinMapper.selectJoinList(Company.class,queryWrapper); //閰嶇疆缁勫憳浜哄憳绫诲瀷鏉ユ簮鏂瑰紡 0鑷缓 1ERP CompanyTree treeBuild = new CompanyTree(companyList, dataSyncConfig.getOrgUserDataOrigin()); @@ -618,7 +731,8 @@ if (currentMenuIndex - 1 < 0) { return; } - Company preMenu = companyPool.remove(currentMenuIndex - 1); + Company preMenu = companyPool.get(currentMenuIndex - 1); + companyPool.remove(currentMenuIndex - 1); companyPool.add(currentMenuIndex, preMenu); } // 涓嬬Щ -- Gitblit v1.9.3