|  | @ -33,11 +33,11 @@ import com.epmet.constant.DataSourceConstant; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.dao.evaluationindex.screen.ScreenProjectDataDao; |  |  | import com.epmet.dao.evaluationindex.screen.ScreenProjectDataDao; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.dao.evaluationindex.screen.ScreenProjectImgDataDao; |  |  | import com.epmet.dao.evaluationindex.screen.ScreenProjectImgDataDao; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.dto.screen.ScreenProjectDataDTO; |  |  | import com.epmet.dto.screen.ScreenProjectDataDTO; | 
			
		
	
		
		
			
				
					|  |  |  |  |  | import com.epmet.dto.screen.ScreenProjectImgDataDTO; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.dto.screen.form.ScreenProjectDataInfoFormDTO; |  |  | import com.epmet.dto.screen.form.ScreenProjectDataInfoFormDTO; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.dto.screencoll.ScreenCollFormDTO; |  |  | import com.epmet.dto.screencoll.ScreenCollFormDTO; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.entity.evaluationindex.screen.ScreenProjectCategoryEntity; |  |  | import com.epmet.entity.evaluationindex.screen.ScreenProjectCategoryEntity; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.entity.evaluationindex.screen.ScreenProjectDataEntity; |  |  | import com.epmet.entity.evaluationindex.screen.ScreenProjectDataEntity; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.entity.evaluationindex.screen.ScreenProjectImgDataEntity; |  |  |  | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.entity.stats.CustomerProjectCategoryDictEntity; |  |  | import com.epmet.entity.stats.CustomerProjectCategoryDictEntity; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.feign.EpmetMessageOpenFeignClient; |  |  | import com.epmet.feign.EpmetMessageOpenFeignClient; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.feign.OperCrmOpenFeignClient; |  |  | import com.epmet.feign.OperCrmOpenFeignClient; | 
			
		
	
	
		
		
			
				
					|  | @ -47,6 +47,7 @@ import com.epmet.service.evaluationindex.screen.ScreenProjectCategoryService; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.service.evaluationindex.screen.ScreenProjectDataService; |  |  | import com.epmet.service.evaluationindex.screen.ScreenProjectDataService; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.service.stats.CustomerProjectCategoryDictService; |  |  | import com.epmet.service.stats.CustomerProjectCategoryDictService; | 
			
		
	
		
		
			
				
					|  |  | import com.github.pagehelper.PageHelper; |  |  | import com.github.pagehelper.PageHelper; | 
			
		
	
		
		
			
				
					|  |  |  |  |  | import lombok.extern.slf4j.Slf4j; | 
			
		
	
		
		
			
				
					|  |  | import org.apache.commons.collections4.ListUtils; |  |  | import org.apache.commons.collections4.ListUtils; | 
			
		
	
		
		
			
				
					|  |  | import org.apache.commons.lang3.ArrayUtils; |  |  | import org.apache.commons.lang3.ArrayUtils; | 
			
		
	
		
		
			
				
					|  |  | import org.apache.commons.lang3.StringUtils; |  |  | import org.apache.commons.lang3.StringUtils; | 
			
		
	
	
		
		
			
				
					|  | @ -56,7 +57,6 @@ import org.springframework.util.CollectionUtils; | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | import javax.annotation.Resource; |  |  | import javax.annotation.Resource; | 
			
		
	
		
		
			
				
					|  |  | import java.math.BigDecimal; |  |  | import java.math.BigDecimal; | 
			
		
	
		
		
			
				
					|  |  | import java.text.SimpleDateFormat; |  |  |  | 
			
		
	
		
		
			
				
					|  |  | import java.util.*; |  |  | import java.util.*; | 
			
		
	
		
		
			
				
					|  |  | import java.util.stream.Collectors; |  |  | import java.util.stream.Collectors; | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  | @ -66,6 +66,7 @@ import java.util.stream.Collectors; | 
			
		
	
		
		
			
				
					|  |  |  * @author qu qu@elink-cn.com |  |  |  * @author qu qu@elink-cn.com | 
			
		
	
		
		
			
				
					|  |  |  * @since v1.0.0 2021-02-23 |  |  |  * @since v1.0.0 2021-02-23 | 
			
		
	
		
		
			
				
					|  |  |  */ |  |  |  */ | 
			
		
	
		
		
			
				
					|  |  |  |  |  | @Slf4j | 
			
		
	
		
		
			
				
					|  |  | @Service |  |  | @Service | 
			
		
	
		
		
			
				
					|  |  | @DataSource(value = DataSourceConstant.EVALUATION_INDEX) |  |  | @DataSource(value = DataSourceConstant.EVALUATION_INDEX) | 
			
		
	
		
		
			
				
					|  |  | public class ScreenProjectDataServiceImpl extends BaseServiceImpl<ScreenProjectDataDao, ScreenProjectDataEntity> implements ScreenProjectDataService { |  |  | public class ScreenProjectDataServiceImpl extends BaseServiceImpl<ScreenProjectDataDao, ScreenProjectDataEntity> implements ScreenProjectDataService { | 
			
		
	
	
		
		
			
				
					|  | @ -136,22 +137,50 @@ public class ScreenProjectDataServiceImpl extends BaseServiceImpl<ScreenProjectD | 
			
		
	
		
		
			
				
					|  |  |     } |  |  |     } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |     @Override |  |  |     @Override | 
			
		
	
		
		
			
				
					|  |  |     @Transactional(rollbackFor = Exception.class) |  |  |  | 
			
		
	
		
		
			
				
					|  |  |     @DataSource(value = DataSourceConstant.EVALUATION_INDEX, datasourceNameFromArg = true) |  |  |     @DataSource(value = DataSourceConstant.EVALUATION_INDEX, datasourceNameFromArg = true) | 
			
		
	
		
		
			
				
					|  |  |     public void collect(ScreenCollFormDTO<ScreenProjectDataInfoFormDTO> param) { |  |  |     public void collect(ScreenCollFormDTO<ScreenProjectDataInfoFormDTO> param) { | 
			
		
	
		
		
			
				
					|  |  |         /*if (param.getIsFirst()) { |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             int affectedRows = baseDao.deleteByDateIdAndCustomerId(param.getCustomerId(), param.getDateId()); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             while (affectedRows > 0) { |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                 affectedRows = baseDao.deleteByDateIdAndCustomerId(param.getCustomerId(), param.getDateId()); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             } |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         }*/ |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         Date today = new Date(); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         List<ScreenProjectDataEntity> projectList = new ArrayList<>(); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         param.getDataList().forEach(item -> { |  |  |         param.getDataList().forEach(item -> { | 
			
		
	
		
		
			
				
					|  |  |             String projectStatusCode = item.getProjectStatusCode(); |  |  |             String projectStatusCode = item.getProjectStatusCode(); | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |             //2021.3.8  epmet中,调用方传level,这边不再计算
 |  |  |             //2021.3.8  epmet中,调用方传level,这边不再计算
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             setLevelByCreateTime(item, projectStatusCode); | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             //插入项目表
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             ScreenProjectDataEntity screenProjectDataEntity = ConvertUtils.sourceToTarget(item, ScreenProjectDataEntity.class); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             screenProjectDataEntity.setCustomerId(param.getCustomerId()); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             screenProjectDataEntity.setDataEndTime(param.getDateId()); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             String agencyId = screenCustomerAgencyService.getParentAgencyId(screenProjectDataEntity.getAllParentIds().split(StrConstant.COMMA)[0]); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             if(StringUtils.isNotBlank(agencyId)) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 screenProjectDataEntity.setAllParentIds(agencyId.concat(StrConstant.COMMA).concat(screenProjectDataEntity.getAllParentIds())); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             //删除 并插入新的项目数据
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             delAndInsertProjectData(param, item, screenProjectDataEntity); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         }); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     @Transactional(rollbackFor = Exception.class) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     public void delAndInsertProjectData(ScreenCollFormDTO<ScreenProjectDataInfoFormDTO> param, ScreenProjectDataInfoFormDTO item, ScreenProjectDataEntity screenProjectDataEntity) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         //先删除该projectId对应的旧数据
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         baseDao.deleteByProjectId(param.getCustomerId(), item.getProjectId()); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         screenProjectImgDataDao.deleteByProjectId(param.getCustomerId(), item.getProjectId()); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         baseDao.insert(screenProjectDataEntity); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         saveCategory(param.getCustomerId(), Collections.singletonList(screenProjectDataEntity)) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         //插入该项目图片表
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         String[] projectImgUrl = item.getProjectImgUrl(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         if (ArrayUtils.isNotEmpty(projectImgUrl)) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             List<ScreenProjectImgDataDTO> imgList = new ArrayList<>(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             for (int i = 0; i < projectImgUrl.length; i++) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 ScreenProjectImgDataDTO screenProjectImgDataEntity = new ScreenProjectImgDataDTO(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 screenProjectImgDataEntity.setCustomerId(param.getCustomerId()); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 screenProjectImgDataEntity.setProjectId(item.getProjectId()); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 screenProjectImgDataEntity.setProjectImgUrl(projectImgUrl[i]); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 screenProjectImgDataEntity.setSort(i); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 imgList.add(screenProjectImgDataEntity) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             screenProjectImgDataDao.insertBatch(imgList); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     private void setLevelByCreateTime(ScreenProjectDataInfoFormDTO item, String projectStatusCode) { | 
			
		
	
		
		
			
				
					|  |  |         if(item.getProjectLevel() == null){ |  |  |         if(item.getProjectLevel() == null){ | 
			
		
	
		
		
			
				
					|  |  |             //todo 动态获取超时时间
 |  |  |             //todo 动态获取超时时间
 | 
			
		
	
		
		
			
				
					|  |  |             //如果结案 结案时间立项时间;
 |  |  |             //如果结案 结案时间立项时间;
 | 
			
		
	
	
		
		
			
				
					|  | @ -159,10 +188,10 @@ public class ScreenProjectDataServiceImpl extends BaseServiceImpl<ScreenProjectD | 
			
		
	
		
		
			
				
					|  |  |                 Date createTime = item.getProjectCreateTime(); |  |  |                 Date createTime = item.getProjectCreateTime(); | 
			
		
	
		
		
			
				
					|  |  |                 Date closeCaseTime = item.getCloseCaseTime(); |  |  |                 Date closeCaseTime = item.getCloseCaseTime(); | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |                     if (closeCaseTime.getTime() - createTime.getTime() <= 1000 * 60 * 60 * 24 * 4) { |  |  |                 if (closeCaseTime.getTime() - createTime.getTime() <= 1000 * 60 * 60 * 24 * 4L) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |                     //如果结案时间-立项时间小于等于4天 未超期 level3
 |  |  |                     //如果结案时间-立项时间小于等于4天 未超期 level3
 | 
			
		
	
		
		
			
				
					|  |  |                     item.setProjectLevel(3); |  |  |                     item.setProjectLevel(3); | 
			
		
	
		
		
			
				
					
					|  |  |                     } else if (closeCaseTime.getTime() - createTime.getTime() <= 1000 * 60 * 60 * 24 * 5) { |  |  |                 } else if (closeCaseTime.getTime() - createTime.getTime() <= 1000 * 60 * 60 * 24 * 5L) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |                     //如果结案时间-立项时间大于4天小于5天 即将超期 level2
 |  |  |                     //如果结案时间-立项时间大于4天小于5天 即将超期 level2
 | 
			
		
	
		
		
			
				
					|  |  |                     item.setProjectLevel(2); |  |  |                     item.setProjectLevel(2); | 
			
		
	
		
		
			
				
					|  |  |                 } else { |  |  |                 } else { | 
			
		
	
	
		
		
			
				
					|  | @ -172,11 +201,11 @@ public class ScreenProjectDataServiceImpl extends BaseServiceImpl<ScreenProjectD | 
			
		
	
		
		
			
				
					|  |  |             } else if ("pending".equals(projectStatusCode)) { |  |  |             } else if ("pending".equals(projectStatusCode)) { | 
			
		
	
		
		
			
				
					|  |  |                 //如果处理中 当前时间-立项时间;
 |  |  |                 //如果处理中 当前时间-立项时间;
 | 
			
		
	
		
		
			
				
					|  |  |                 Date createTime = item.getProjectCreateTime(); |  |  |                 Date createTime = item.getProjectCreateTime(); | 
			
		
	
		
		
			
				
					
					|  |  | 
 |  |  |                 Date today = new Date(); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                     if (today.getTime() - createTime.getTime() <= 1000 * 60 * 60 * 24 * 4) { |  |  |                 if (today.getTime() - createTime.getTime() <= 1000 * 60 * 60 * 24 * 4L) { | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |                     //如果当前时间-立项时间小于等于4天 未超期 level3
 |  |  |                     //如果当前时间-立项时间小于等于4天 未超期 level3
 | 
			
		
	
		
		
			
				
					|  |  |                     item.setProjectLevel(3); |  |  |                     item.setProjectLevel(3); | 
			
		
	
		
		
			
				
					
					|  |  |                     } else if (today.getTime() - createTime.getTime() <= 1000 * 60 * 60 * 24 * 5) { |  |  |                 } else if (today.getTime() - createTime.getTime() <= 1000 * 60 * 60 * 24 * 5L) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |                     //如果当前时间-立项时间大于4天小于5天 即将超期 level2
 |  |  |                     //如果当前时间-立项时间大于4天小于5天 即将超期 level2
 | 
			
		
	
		
		
			
				
					|  |  |                     item.setProjectLevel(2); |  |  |                     item.setProjectLevel(2); | 
			
		
	
		
		
			
				
					|  |  |                 } else { |  |  |                 } else { | 
			
		
	
	
		
		
			
				
					|  | @ -185,53 +214,6 @@ public class ScreenProjectDataServiceImpl extends BaseServiceImpl<ScreenProjectD | 
			
		
	
		
		
			
				
					|  |  |                 } |  |  |                 } | 
			
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |         } |  |  |         } | 
			
		
	
		
		
			
				
					|  |  |             //先删除该projectId对应的旧数据
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             baseDao.deleteByProjectId(param.getCustomerId(), item.getProjectId()); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             screenProjectImgDataDao.deleteByProjectId(param.getCustomerId(), item.getProjectId()); |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             //如果orgType未知,获取一下
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //            if ("unknown".equals(item.getOrgType())){
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                ScreenCustomerAgencyEntity screenCustomerAgencyEntity = agencyDao.selectById(item.getOrgId());
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                if (screenCustomerAgencyEntity != null){
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                    item.setOrgType("agency");
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                }else {
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                    ScreenCustomerDeptEntity screenCustomerDeptEntity = deptDao.selectById(item.getOrgId());
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                    if (screenCustomerDeptEntity!=null){
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                        item.setOrgType("department");
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                    }else {
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                        ScreenCustomerGridEntity screenCustomerGridEntity = gridDao.selectById(item.getOrgId());
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                        if (screenCustomerGridEntity != null){
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                           item.setOrgType("grid");
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                        }
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                    }
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //                }
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | //            }
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             //插入项目表
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             ScreenProjectDataEntity screenProjectDataEntity = ConvertUtils.sourceToTarget(item, ScreenProjectDataEntity.class); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             screenProjectDataEntity.setCustomerId(param.getCustomerId()); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             screenProjectDataEntity.setDataEndTime(param.getDateId()); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             String agencyId = screenCustomerAgencyService.getParentAgencyId(screenProjectDataEntity.getAllParentIds().split(StrConstant.COMMA)[0]); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             if(StringUtils.isNotBlank(agencyId)) { |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                 screenProjectDataEntity.setAllParentIds(agencyId.concat(StrConstant.COMMA).concat(screenProjectDataEntity.getAllParentIds())); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             } |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             baseDao.insert(screenProjectDataEntity); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             projectList.add(screenProjectDataEntity); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             //插入图片表
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             String[] projectImgUrl = item.getProjectImgUrl(); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             if (ArrayUtils.isNotEmpty(projectImgUrl)) { |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                 for (int i = 0; i < projectImgUrl.length; i++) { |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                     ScreenProjectImgDataEntity screenProjectImgDataEntity = new ScreenProjectImgDataEntity(); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                     screenProjectImgDataEntity.setCustomerId(param.getCustomerId()); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                     screenProjectImgDataEntity.setProjectId(item.getProjectId()); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                     screenProjectImgDataEntity.setProjectImgUrl(projectImgUrl[i]); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                     screenProjectImgDataEntity.setSort(i); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                     screenProjectImgDataDao.insert(screenProjectImgDataEntity); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                 } |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             } |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         }); |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         saveCategory(param.getCustomerId(), projectList); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |     } |  |  |     } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  | @ -278,7 +260,7 @@ public class ScreenProjectDataServiceImpl extends BaseServiceImpl<ScreenProjectD | 
			
		
	
		
		
			
				
					|  |  |         //复采集时数不会重复
 |  |  |         //复采集时数不会重复
 | 
			
		
	
		
		
			
				
					|  |  |         if(!CollectionUtils.isEmpty(meta)){ |  |  |         if(!CollectionUtils.isEmpty(meta)){ | 
			
		
	
		
		
			
				
					|  |  |             int affectedRows = baseDao.deleteByProjectTimeAndCustomerId(customerId,dateId); |  |  |             int affectedRows = baseDao.deleteByProjectTimeAndCustomerId(customerId,dateId); | 
			
		
	
		
		
			
				
					
					|  |  |             while (affectedRows > 0) { |  |  |             while (affectedRows > NumConstant.ZERO) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |                 affectedRows = baseDao.deleteByProjectTimeAndCustomerId(customerId, dateId); |  |  |                 affectedRows = baseDao.deleteByProjectTimeAndCustomerId(customerId, dateId); | 
			
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |             List<List<ScreenProjectDataDTO>> partition = ListUtils.partition(meta, NumConstant.ONE_HUNDRED); |  |  |             List<List<ScreenProjectDataDTO>> partition = ListUtils.partition(meta, NumConstant.ONE_HUNDRED); | 
			
		
	
	
		
		
			
				
					|  | @ -359,7 +341,10 @@ public class ScreenProjectDataServiceImpl extends BaseServiceImpl<ScreenProjectD | 
			
		
	
		
		
			
				
					|  |  |         List<ScreenProjectCategoryEntity> projectCategoryList = new ArrayList<>(); |  |  |         List<ScreenProjectCategoryEntity> projectCategoryList = new ArrayList<>(); | 
			
		
	
		
		
			
				
					|  |  |         projectList.forEach(project -> { |  |  |         projectList.forEach(project -> { | 
			
		
	
		
		
			
				
					|  |  |             //分类为空不作处理
 |  |  |             //分类为空不作处理
 | 
			
		
	
		
		
			
				
					
					|  |  |             if (StringUtils.isNotBlank(project.getCategoryCode())) { |  |  |             if (StringUtils.isBlank(project.getCategoryCode())) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |                 return; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |             List<String> categoryList = Arrays.asList(project.getCategoryCode().split(StrConstant.COMMA)); |  |  |             List<String> categoryList = Arrays.asList(project.getCategoryCode().split(StrConstant.COMMA)); | 
			
		
	
		
		
			
				
					|  |  |             categoryList.forEach(category -> { |  |  |             categoryList.forEach(category -> { | 
			
		
	
		
		
			
				
					|  |  |                 ScreenProjectCategoryEntity entity = new ScreenProjectCategoryEntity(); |  |  |                 ScreenProjectCategoryEntity entity = new ScreenProjectCategoryEntity(); | 
			
		
	
	
		
		
			
				
					|  | @ -368,7 +353,9 @@ public class ScreenProjectDataServiceImpl extends BaseServiceImpl<ScreenProjectD | 
			
		
	
		
		
			
				
					|  |  |                 entity.setOriginCategoryCode(category); |  |  |                 entity.setOriginCategoryCode(category); | 
			
		
	
		
		
			
				
					|  |  |                 CustomerProjectCategoryDictEntity categoryEntity = customerProjectCategoryDictService.getByCategoryCode(customerId, category); |  |  |                 CustomerProjectCategoryDictEntity categoryEntity = customerProjectCategoryDictService.getByCategoryCode(customerId, category); | 
			
		
	
		
		
			
				
					|  |  |                 if (null != categoryEntity) { |  |  |                 if (null != categoryEntity) { | 
			
		
	
		
		
			
				
					
					|  |  |                         //
 |  |  |                     log.error("customerId:{} categoryCode:{} is not exist in ProjectCategoryDict", customerId, category); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |                     return; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 } | 
			
		
	
		
		
			
				
					|  |  |                 if ("external".equals(categoryEntity.getCustomerType())) { |  |  |                 if ("external".equals(categoryEntity.getCustomerType())) { | 
			
		
	
		
		
			
				
					|  |  |                     entity.setCategoryCode(categoryEntity.getEpmetCategoryCode()); |  |  |                     entity.setCategoryCode(categoryEntity.getEpmetCategoryCode()); | 
			
		
	
		
		
			
				
					|  |  |                     CustomerProjectCategoryDictEntity parent = customerProjectCategoryDictService.getByCategoryCode(parentCustomer.getData(), categoryEntity.getEpmetCategoryCode()); |  |  |                     CustomerProjectCategoryDictEntity parent = customerProjectCategoryDictService.getByCategoryCode(parentCustomer.getData(), categoryEntity.getEpmetCategoryCode()); | 
			
		
	
	
		
		
			
				
					|  | @ -379,12 +366,18 @@ public class ScreenProjectDataServiceImpl extends BaseServiceImpl<ScreenProjectD | 
			
		
	
		
		
			
				
					|  |  |                     entity.setParentCategoryCode(categoryEntity.getParentCategoryCode()); |  |  |                     entity.setParentCategoryCode(categoryEntity.getParentCategoryCode()); | 
			
		
	
		
		
			
				
					|  |  |                     entity.setLevel(categoryEntity.getLevel()); |  |  |                     entity.setLevel(categoryEntity.getLevel()); | 
			
		
	
		
		
			
				
					|  |  |                 } |  |  |                 } | 
			
		
	
		
		
			
				
					|  |  |                     } |  |  |  | 
			
		
	
		
		
			
				
					|  |  |                 projectCategoryList.add(entity); |  |  |                 projectCategoryList.add(entity); | 
			
		
	
		
		
			
				
					
					|  |  |                 }); |  |  |                 //如果分类数据已经超过100了 就插入一批
 | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |                 if (projectCategoryList.size() > NumConstant.ONE_HUNDRED){ | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     screenProjectCategoryService.insertBatch(projectCategoryList); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     projectCategoryList.clear(); | 
			
		
	
		
		
			
				
					|  |  |                 } |  |  |                 } | 
			
		
	
		
		
			
				
					|  |  |             }); |  |  |             }); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         }); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         //如果不为空 则插入剩余的那一部分
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         if (projectCategoryList.size() > NumConstant.ZERO){ | 
			
		
	
		
		
			
				
					|  |  |             screenProjectCategoryService.insertBatch(projectCategoryList); |  |  |             screenProjectCategoryService.insertBatch(projectCategoryList); | 
			
		
	
		
		
			
				
					|  |  |         } |  |  |         } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } | 
			
		
	
	
		
		
			
				
					|  | 
 |