| | |
| | | import com.baomidou.mybatisplus.core.conditions.Wrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; |
| | | import com.baomidou.mybatisplus.core.metadata.IPage; |
| | | import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import com.baomidou.mybatisplus.extension.toolkit.SqlHelper; |
| | | import com.sun.org.apache.bcel.internal.generic.NEW; |
| | | import com.vci.ubcs.code.bo.CodeClassifyFullInfoBO; |
| | | import com.vci.ubcs.code.entity.CodeClassify; |
| | | import com.vci.ubcs.code.entity.CodeClassifyTemplate; |
| | | import com.vci.ubcs.code.entity.*; |
| | | import com.vci.ubcs.code.enumpack.FrameworkDataLCStatus; |
| | | import com.vci.ubcs.code.mapper.CodeClassifyMapper; |
| | | import com.vci.ubcs.code.mapper.CodeClassifyTemplateMapper; |
| | | import com.vci.ubcs.code.mapper.CommonsMapper; |
| | | import com.vci.ubcs.code.mapper.*; |
| | | import com.vci.ubcs.code.po.CodeClassifyPO; |
| | | import com.vci.ubcs.code.service.ICodeClassifyService; |
| | | import com.vci.ubcs.code.service.ICodeKeyAttrRepeatService; |
| | | import com.vci.ubcs.code.service.ICodeRuleService; |
| | | import com.vci.ubcs.code.vo.pagemodel.CodeAllCodeVO; |
| | | import com.vci.ubcs.code.vo.pagemodel.CodeClassifyVO; |
| | | import com.vci.ubcs.code.vo.pagemodel.CodeKeyAttrRepeatRuleVO; |
| | | import com.vci.ubcs.code.vo.pagemodel.CodeRuleVO; |
| | |
| | | import com.vci.ubcs.starter.web.util.LangBaseUtil; |
| | | import com.vci.ubcs.starter.web.util.VciBaseUtil; |
| | | import com.vci.ubcs.system.cache.NacosConfigCache; |
| | | import com.vci.ubcs.system.feign.ISysClient; |
| | | import org.apache.poi.hssf.util.HSSFColor; |
| | | import org.slf4j.Logger; |
| | | import org.slf4j.LoggerFactory; |
| | |
| | | import org.springblade.core.tool.utils.Func; |
| | | import org.springframework.beans.BeanUtils; |
| | | import org.springframework.beans.factory.annotation.Value; |
| | | import org.springframework.context.annotation.Bean; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import org.springframework.util.CollectionUtils; |
| | | |
| | | import javax.annotation.Resource; |
| | |
| | | private IBtmTypeClient btmTypeClient; |
| | | |
| | | @Resource |
| | | private CommonsMapper commonsMapper; |
| | | private ISysClient sysClient; |
| | | |
| | | /** |
| | | * 日志 |
| | |
| | | |
| | | @Resource |
| | | private ICodeKeyAttrRepeatService iCodeKeyattrrepeatService; |
| | | |
| | | @Resource |
| | | private CodeAllCodeMapper codeAllCodeMapper; |
| | | |
| | | @Resource |
| | | private CodeSerialValueMapper codeSerialValueMapper; |
| | | |
| | | @Resource |
| | | private CodeBasicSecMapper codeBasicSecMapper; |
| | | /** |
| | | * 上级节点的属性名称 |
| | | */ |
| | |
| | | * @return 执行结果 |
| | | */ |
| | | @Override |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public R editSave(CodeClassify codeClassifyEntity) { |
| | | if(codeClassifyEntity == null || codeClassifyEntity.getOid() == null){ |
| | | return R.fail("传入数据不能为空!"); |
| | |
| | | codeClassifyEntity.setLastModifier(String.valueOf(AuthUtil.getUser().getAccount())); |
| | | codeClassifyEntity.setLastModifyTime(new Date()); |
| | | codeClassifyEntity.setTs(new Date()); |
| | | int insertNumber = codeClassifyMapper.updateById(codeClassifyEntity); |
| | | int updateEntity = codeClassifyMapper.updateById(codeClassifyEntity); |
| | | // 如果不是叶子结点,则需要修改其下所有的子分类,是否参与关键属性校验的值 |
| | | String oid = codeClassifyEntity.getOid(); |
| | | List<CodeClassify> codeClassifies = codeClassifyMapper.selectStartWithCurrentOid(oid); |
| | | int updateAttr = 0; |
| | | // 不为空就需要该当前分类下所有子分类的isParticipateCheck |
| | | if(!codeClassifies.isEmpty()){ |
| | | List<String> oids = codeClassifies.stream().map(CodeClassify::getOid).collect(Collectors.toList()); |
| | | LambdaUpdateWrapper<CodeClassify> updateWrapper = Wrappers.<CodeClassify>update() |
| | | .lambda().in(CodeClassify::getOid, oids) |
| | | .set(CodeClassify::getIsParticipateCheck, codeClassifyEntity.getIsParticipateCheck()); |
| | | // 父分类的业务类型做了更改,所有子分类的都得进行更改 |
| | | if(!codeClassifyEntity.getBtmTypeId().equals(detail.getBtmTypeId())){ |
| | | updateWrapper.set(CodeClassify::getBtmTypeId,codeClassifyEntity.getBtmTypeId()) |
| | | .set(CodeClassify::getBtmTypeName,codeClassifyEntity.getBtmTypeName()); |
| | | } |
| | | updateAttr = codeClassifyMapper.update(null,updateWrapper); |
| | | |
| | | } |
| | | |
| | | // //处理数据集成逻辑,成功后执行集成第一步,分类数据特殊处理。只有启用状态的分类才推送 |
| | | // if(FRAMEWORK_DATA_ENABLED.equals(codeClassifyDO.getLcStatus())); |
| | | // { |
| | | // codeDuckingServiceI.insertCache1(CACHE_TYPE_CLASSIFY_EDIT,FRAMEWORK_DATA_ENABLED,DOCKING_DEFAULT_CLASSIFY, DOCKING_DEFAULT_CLASSIFYOID, codeClassifyDO.getOid(), codeClassifyDTO.getTs()); |
| | | // } |
| | | return R.status(SqlHelper.retBool(insertNumber)); |
| | | // return BaseResult.success(codeClassifyDO2VO(codeClassifyDO)); |
| | | return R.status(SqlHelper.retBool(updateAttr) & SqlHelper.retBool(updateEntity)); |
| | | } |
| | | |
| | | /** |
| | |
| | | lcStatus = treeQueryObject.getConditionMap().getOrDefault("lcStatus",null); |
| | | } |
| | | if(StringUtils.isNotBlank(id) || StringUtils.isNotBlank(lcStatus) ){ |
| | | String tableName = this.getTableName(treeQueryObject.getConditionMap().get("btmTypeId"),treeQueryObject.getConditionMap().get("id"), treeQueryObject.getConditionMap().get("lcStatus")); |
| | | //String tableName = this.getTableName(treeQueryObject.getConditionMap().get("btmTypeId"),treeQueryObject.getConditionMap().get("id"), treeQueryObject.getConditionMap().get("lcStatus")); |
| | | doList = codeClassifyMapper |
| | | .selectCodeClassifyDOByTree( |
| | | treeQueryObject.getConditionMap().get("id"), |
| | | treeQueryObject.getConditionMap().get("lcStatus"), |
| | | treeQueryObject.getParentOid(), |
| | | VciBaseUtil.checkAdminTenant() ? null:AuthUtil.getTenantId(), |
| | | tableName |
| | | VciBaseUtil.checkAdminTenant() ? null:AuthUtil.getTenantId() |
| | | /*tableName*/ |
| | | ); |
| | | }else{ |
| | | // 只要前端会传参数过来就不会出现走这句的情况,所以查询总数没在这儿添加 |
| | |
| | | return s.getId() + " " + s.getName() + (FrameworkDataLCStatus.DISABLED.getValue().equalsIgnoreCase(s |
| | | .getLcStatus()) ? (" 【停用】 ") : ""); |
| | | }); |
| | | |
| | | Iterator var6 = tree.listIterator(); |
| | | while(var6.hasNext()){ |
| | | Tree trees = (Tree) var6.next(); |
| | | boolean checkHasChild=codeClassifyMapper.checkHasChild(trees.getOid()); |
| | | if(checkHasChild){ |
| | | trees.setLeaf(false); |
| | | }else{ |
| | | trees.setLeaf(true); |
| | | //超管显示所有分类 |
| | | if(VciBaseUtil.checkAdminTenant()){ |
| | | Iterator var6 = tree.listIterator(); |
| | | while(var6.hasNext()){ |
| | | Tree trees = (Tree) var6.next(); |
| | | boolean checkHasChild=codeClassifyMapper.checkHasChild(trees.getOid()); |
| | | if(checkHasChild){ |
| | | trees.setLeaf(false); |
| | | }else{ |
| | | trees.setLeaf(true); |
| | | } |
| | | } |
| | | }else { |
| | | // 那些分类具备查看权限 |
| | | R<List<String>> viewClassByRoleIds = sysClient.getViewClassByRoleIds(Arrays.asList(AuthUtil.getUser().getRoleId().split(","))); |
| | | // 请求失败或者请求得到的具备查看权限的分类id集合为空 |
| | | if(!viewClassByRoleIds.isSuccess() && !viewClassByRoleIds.getData().isEmpty()){ |
| | | return new ArrayList<>(); |
| | | } |
| | | // 过滤 |
| | | filterTreeNodes(tree,viewClassByRoleIds.getData()); |
| | | } |
| | | return tree; |
| | | } |
| | | |
| | | /** |
| | | * 分类授权过滤掉没有权限的分类 |
| | | * @param trees |
| | | * @param classifyIds |
| | | */ |
| | | private void filterTreeNodes(List<Tree> trees, List<String> classifyIds) { |
| | | Iterator<Tree> iterator = trees.iterator(); |
| | | while (iterator.hasNext()) { |
| | | Tree tree = iterator.next(); |
| | | Boolean checkHasChild = codeClassifyMapper.checkHasChild(tree.getOid()); |
| | | tree.setLeaf(!checkHasChild); |
| | | if (classifyIds.contains(tree.getOid())) { |
| | | // 如果顶层节点存在于 classifyIds 中,直接保留其子节点集合 |
| | | continue; |
| | | } |
| | | if (tree.getChildren() != null && !tree.getChildren().isEmpty()) { |
| | | filterTreeNodes(tree.getChildren(), classifyIds); |
| | | } |
| | | if (!hasMatchingChild(tree, classifyIds)) { |
| | | iterator.remove(); |
| | | } |
| | | } |
| | | } |
| | | |
| | | private boolean hasMatchingChild(Tree tree, List<String> classifyIds) { |
| | | if (classifyIds.contains(tree.getOid())) { |
| | | return true; |
| | | } |
| | | if (tree.getChildren() != null) { |
| | | for (Tree child : tree.getChildren()) { |
| | | if (hasMatchingChild(child, classifyIds)) { |
| | | return true; |
| | | } |
| | | } |
| | | } |
| | | return false; |
| | | } |
| | | |
| | | /** |
| | |
| | | * @param oid |
| | | * @return |
| | | */ |
| | | public List<CodeClassifyVO> selectAllClassifyByOid(String oid){ |
| | | List<CodeClassify> codeClassifyList=codeClassifyMapper.selectAllClassifyByOid(oid,AuthUtil.getTenantId()); |
| | | public List<CodeClassifyVO> selectAllClassifyByOid(String oid, String fieldInPath){ |
| | | List<CodeClassify> codeClassifyList=codeClassifyMapper.selectAllClassifyByOid(oid,fieldInPath,AuthUtil.getTenantId()); |
| | | List<CodeClassifyVO> voList = codeClassifyDO2VOs(codeClassifyList); |
| | | return voList; |
| | | |
| | | } |
| | | |
| | | /** |
| | | * 根据顶层节点oid查询所有除当前节点以外所有不参与校验的分类oid |
| | | * @param topOid |
| | | * @param currentOid |
| | | * @return |
| | | */ |
| | | @Override |
| | | public String selectLeafByParentClassifyOid(String topOid, String currentOid) { |
| | | List<CodeClassify> codeClassifies = codeClassifyMapper.selectLeafByParentClassifyOid(topOid, currentOid); |
| | | if(codeClassifies.isEmpty()){ |
| | | return ""; |
| | | } |
| | | String oids = codeClassifies.stream() |
| | | .map(CodeClassify::getOid) |
| | | .map(s -> "'" + s + "'") |
| | | .collect(Collectors.joining(","));; |
| | | return oids; |
| | | } |
| | | |
| | | /** |
| | | * 流水依赖生成 |
| | | */ |
| | | @Override |
| | | public R flowingDependencyGen(String classifyOid) { |
| | | //查询此分类下面的所有分类 |
| | | List<CodeClassify> codeClassifyList=codeClassifyMapper.selectAllClassifyByOid(classifyOid,AuthUtil.getTenantId(),null); |
| | | //查询码值表,获取最大流水 |
| | | List<CodeAllCode> codeAllCodeVOS = codeAllCodeMapper.selectGroupByClassify("'" + codeClassifyList.stream() |
| | | .map(classfiy -> classfiy.getOid()).collect(Collectors.joining("','")) + "'","'${sav}'"); |
| | | //往流水表里面加数据,有则更新,无则添加数据。 |
| | | for (CodeAllCode codeAllCodeVO : codeAllCodeVOS) { |
| | | if(Func.isEmpty(codeAllCodeVO.getSerialUnit())){ |
| | | throw new ServiceException("编码为:" + codeAllCodeVO.getId() + "的码值数据流水依赖不能为空!"); |
| | | } |
| | | try { |
| | | CodeRuleVO codeRuleVO = codeRuleService.getObjectByOid(codeAllCodeVO.getCodeRuleOid()); |
| | | if(Func.isEmpty(codeRuleVO)){ |
| | | continue; |
| | | } |
| | | }catch (Exception e){ |
| | | continue; |
| | | } |
| | | QueryWrapper<CodeBasicSec> secWrapper = new QueryWrapper<>(); |
| | | secWrapper.eq("PKCODERULE",codeAllCodeVO.getCodeRuleOid()); |
| | | secWrapper.eq("SECTYPE","codeserialsec"); |
| | | List<CodeBasicSec> codeBasicSecs = codeBasicSecMapper.selectList(secWrapper); |
| | | if(codeBasicSecs.size() == 0 ){ |
| | | throw new ServiceException("根据码值ID:" + codeAllCodeVO.getCodeRuleOid() + ",码段类型为流水码段(codeserialsec),在基础码段中未找到相关数据!"); |
| | | } |
| | | QueryWrapper<CodeSerialValue> wrapper = new QueryWrapper<>(); |
| | | wrapper.eq("codeRuleOid",codeAllCodeVO.getCodeRuleOid()); |
| | | wrapper.eq("serialUnit",codeAllCodeVO.getSerialUnit()); |
| | | wrapper.eq("codeSecOid",codeBasicSecs.get(0).getOid()); |
| | | List<CodeSerialValue> codeSerialValues = codeSerialValueMapper.selectList(wrapper); |
| | | if(codeSerialValues.size() == 0){ |
| | | CodeSerialValue newSerialValue = new CodeSerialValue(); |
| | | DefaultAttrAssimtUtil.addDefaultAttrAssimt(newSerialValue,"codeserialvalue"); |
| | | newSerialValue.setCodeRuleOid(codeAllCodeVO.getCodeRuleOid()); |
| | | newSerialValue.setCodeSecOid(codeBasicSecs.get(0).getOid()); |
| | | newSerialValue.setSerialUnit(codeAllCodeVO.getSerialUnit()); |
| | | newSerialValue.setMaxSerial(codeAllCodeVO.getUnFillSerial()); |
| | | newSerialValue.setLctid("defaultLC"); |
| | | newSerialValue.setLcStatus("Exist"); |
| | | codeSerialValueMapper.insert(newSerialValue); |
| | | }else{ |
| | | codeSerialValues.get(0).setMaxSerial(codeAllCodeVO.getUnFillSerial()); |
| | | codeSerialValues.get(0).setLastModifyTime(new Date()); |
| | | codeSerialValues.get(0).setLastModifier(String.valueOf(AuthUtil.getUser().getUserId())); |
| | | codeSerialValues.get(0).setTs(new Date()); |
| | | codeSerialValueMapper.updateById(codeSerialValues.get(0)); |
| | | } |
| | | } |
| | | return R.success("操作成功!"); |
| | | } |
| | | |
| | | /*** |
| | | * 根据分类描述备注和库节点查询分类信息 |
| | | * @param desc |
| | |
| | | @Override |
| | | public List<CodeClassifyVO> listChildrenClassify(String codeClassifyOid, boolean allLevel, String fieldInPath, boolean enable) { |
| | | if(allLevel){ |
| | | List<CodeClassify> classifyDOS = codeClassifyMapper.selectAllLevelChildHasPath(codeClassifyOid,fieldInPath); |
| | | List<CodeClassify> classifyDOS = codeClassifyMapper.selectAllLevelChildHasPath(codeClassifyOid,fieldInPath,AuthUtil.getTenantId()); |
| | | if(!CollectionUtils.isEmpty(classifyDOS)){ |
| | | // 这儿用stream有点慢 |
| | | classifyDOS = classifyDOS.parallelStream().filter(s->FRAMEWORK_DATA_ENABLED.equalsIgnoreCase(s.getLcStatus())).collect(Collectors.toList()); |
| | | } |
| | | return codeClassifyDO2VOs(classifyDOS); |
| | |
| | | Map<String/**路径**/,String/**主键**/> oidPathMap = new HashMap<>(); |
| | | |
| | | //我们需要查询所有已经存在的分类,主要是路径,用来判断分类的数据 |
| | | List<CodeClassify> existClassifyDOs = codeClassifyMapper.selectAllLevelChildHasPath("",null); |
| | | List<CodeClassify> existClassifyDOs = codeClassifyMapper.selectAllLevelChildHasPath("",null,AuthUtil.getTenantId()); |
| | | Map<String/**路径**/, CodeClassify/**已经存在的数据**/> pathDOMap = Optional.ofNullable(existClassifyDOs).orElse(new ArrayList<>()).stream().collect(Collectors.toMap(s -> { |
| | | String path = s.getPath(); |
| | | if(StringUtils.isNotBlank(path) && path.startsWith("#")){ |
| | |
| | | } |
| | | |
| | | /** |
| | | * 查询所有上层父节点的oid |
| | | * @param oid |
| | | * @return |
| | | */ |
| | | @Override |
| | | public List<String> selectAllParentOid(String oid){ |
| | | if(Func.isBlank(oid)){ |
| | | return new ArrayList<>(); |
| | | } |
| | | return this.codeClassifyMapper.selectAllParentOid(oid); |
| | | } |
| | | |
| | | /** |
| | | * 使用分类主键获取分类相关的所有信息 |
| | | * |
| | | * @param codeClassifyOid 分类的主键 |
| | |
| | | return codeClassifyMapper.selectCount(wrapper).intValue(); |
| | | } |
| | | |
| | | |
| | | |
| | | } |