/* * Copyright (c) 2018-2028, Chill Zhuang All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * Neither the name of the dreamlu.net developer nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * Author: Chill 庄骞 (smallchill@163.com) */ package com.vci.ubcs.code.service.impl; import com.alibaba.nacos.common.utils.StringUtils; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.vci.ubcs.code.entity.CodePhaseAttr; import com.vci.ubcs.code.mapper.CodePhaseAttrMapper; import com.vci.ubcs.code.service.ICodePhaseAttrService; import com.vci.ubcs.code.vo.pagemodel.CodePhaseAttrVO; import com.vci.ubcs.starter.web.util.VciBaseUtil; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; import java.util.*; import java.util.stream.Collectors; /** * 编码库定义-模板阶段-属性 服务实现类 * * @author yuxc * @since 2023-04-20 */ @Service public class CodePhaseAttrServiceImpl extends ServiceImpl implements ICodePhaseAttrService { @Override public IPage selectCodePhaseattrPage(IPage page, CodePhaseAttrVO codePhaseAttr) { return page.setRecords(baseMapper.selectCodePhaseattrPage(page, codePhaseAttr)); } /** * 使用模板主键和阶段编号获取包含的属性 * * @param templateOid 模板的编号 * @param phaseId 阶段的编号 * @return 属性的英文名称 */ @Override public List listAttrByTemplateOidAndPhaseId(String templateOid, String phaseId) { if(StringUtils.isBlank(templateOid)|| StringUtils.isBlank(phaseId)){ return new ArrayList<>(); } QueryWrapper wrapper = new QueryWrapper(); wrapper.inSql("codephaseoid","select oid from pl_code_tempphase where codeClassifyTemplateOid ='" + templateOid + "' and lower(name) ='" + phaseId.trim().toLowerCase(Locale.ROOT) + "'"); // Map conditionMap = new HashMap<>(); // conditionMap.put("codephaseoid", QueryOptionConstant.IN + "(select oid from pl_code_tempphase where codeClassifyTemplateOid ='" + templateOid + "' and lower(name) ='" + phaseId.trim().toLowerCase(Locale.ROOT) + "')"); // PageHelper pageHelper = new PageHelper(-1); List attrDOS = baseMapper.selectList(wrapper); return CollectionUtils.isEmpty(attrDOS)?new ArrayList<>():attrDOS.stream().map(CodePhaseAttr::getId).collect(Collectors.toList()); } }