Browse Source

项目类别时限设置功能优化

feature/dangjian
yujintao 6 years ago
parent
commit
66f2e574ff
  1. 4
      esua-epdc/epdc-admin/epdc-admin-client/src/main/java/com/elink/esua/epdc/dto/epdc/form/UserSysDeptInfoFormDTO.java
  2. 2
      esua-epdc/epdc-module/epdc-events/epdc-events-client/src/main/java/com/elink/esua/epdc/dto/category/result/CategoryInfoResultDTO.java
  3. 1200
      esua-epdc/epdc-module/epdc-events/epdc-events-server/src/main/java/com/elink/esua/epdc/modules/category/service/impl/CategoryServiceImpl.java
  4. 4
      esua-epdc/epdc-module/epdc-kpi/epdc-kpi-client/src/main/java/com/elink/esua/epdc/dto/KpiTimeLimitItemDTO.java
  5. 16
      esua-epdc/epdc-module/epdc-kpi/epdc-kpi-server/src/main/java/com/elink/esua/epdc/dao/KpiTimeLimitItemDao.java
  6. 2
      esua-epdc/epdc-module/epdc-kpi/epdc-kpi-server/src/main/java/com/elink/esua/epdc/entity/KpiTimeLimitItemEntity.java
  7. 20
      esua-epdc/epdc-module/epdc-kpi/epdc-kpi-server/src/main/java/com/elink/esua/epdc/feign/EventFeignClient.java
  8. 114
      esua-epdc/epdc-module/epdc-kpi/epdc-kpi-server/src/main/java/com/elink/esua/epdc/service/impl/KpiTimeLimitItemServiceImpl.java
  9. 20
      esua-epdc/epdc-module/epdc-kpi/epdc-kpi-server/src/main/resources/mapper/KpiTimeLimitItemDao.xml

4
esua-epdc/epdc-admin/epdc-admin-client/src/main/java/com/elink/esua/epdc/dto/epdc/form/UserSysDeptInfoFormDTO.java

@ -16,14 +16,10 @@ public class UserSysDeptInfoFormDTO implements Serializable {
/** /**
* 主键集合 * 主键集合
*/ */
// @NotEmpty(message = "deptIdList不能为空")
// @Valid
private List<Long> deptIdList; private List<Long> deptIdList;
/** /**
* 部门类型键值 * 部门类型键值
*/ */
// @NotEmpty(message = "部门类型不能为空")
// @Valid
private List<String> typeKeyList; private List<String> typeKeyList;
} }

2
esua-epdc/epdc-module/epdc-events/epdc-events-client/src/main/java/com/elink/esua/epdc/dto/category/result/CategoryInfoResultDTO.java

@ -34,5 +34,5 @@ public class CategoryInfoResultDTO implements Serializable {
/** /**
* 所有上级分类名称用逗号分开 * 所有上级分类名称用逗号分开
*/ */
private List<String> parentNames; private String parentNames;
} }

1200
esua-epdc/epdc-module/epdc-events/epdc-events-server/src/main/java/com/elink/esua/epdc/modules/category/service/impl/CategoryServiceImpl.java

File diff suppressed because it is too large

4
esua-epdc/epdc-module/epdc-kpi/epdc-kpi-client/src/main/java/com/elink/esua/epdc/dto/KpiTimeLimitItemDTO.java

@ -53,7 +53,7 @@ public class KpiTimeLimitItemDTO implements Serializable {
/** /**
* 项目类别id * 项目类别id
*/ */
private String categoryId; private Long categoryId;
/** /**
* 所有上级项目类别id * 所有上级项目类别id
@ -108,6 +108,6 @@ public class KpiTimeLimitItemDTO implements Serializable {
/** /**
* 项目类别集合 * 项目类别集合
*/ */
private List<String> categoryIds; private List<Long[]> categoryIds;
} }

16
esua-epdc/epdc-module/epdc-kpi/epdc-kpi-server/src/main/java/com/elink/esua/epdc/dao/KpiTimeLimitItemDao.java

@ -20,6 +20,9 @@ package com.elink.esua.epdc.dao;
import com.elink.esua.epdc.commons.mybatis.dao.BaseDao; import com.elink.esua.epdc.commons.mybatis.dao.BaseDao;
import com.elink.esua.epdc.entity.KpiTimeLimitItemEntity; import com.elink.esua.epdc.entity.KpiTimeLimitItemEntity;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/** /**
* 项目响应时限 * 项目响应时限
@ -29,5 +32,16 @@ import org.apache.ibatis.annotations.Mapper;
*/ */
@Mapper @Mapper
public interface KpiTimeLimitItemDao extends BaseDao<KpiTimeLimitItemEntity> { public interface KpiTimeLimitItemDao extends BaseDao<KpiTimeLimitItemEntity> {
/**
* 按类别id批量删除配置
*
* @param categoryIds
* @return int
* @author work@yujt.net.cn
* @date 2019/12/16 19:19
*/
int deleteBatchByCategoryIds(@Param("categoryIds") List<Long> categoryIds);
} }

2
esua-epdc/epdc-module/epdc-kpi/epdc-kpi-server/src/main/java/com/elink/esua/epdc/entity/KpiTimeLimitItemEntity.java

@ -51,7 +51,7 @@ public class KpiTimeLimitItemEntity extends BaseEpdcEntity {
/** /**
* 项目类别id * 项目类别id
*/ */
private String categoryId; private Long categoryId;
/** /**
* 所有上级项目类别id * 所有上级项目类别id

20
esua-epdc/epdc-module/epdc-kpi/epdc-kpi-server/src/main/java/com/elink/esua/epdc/feign/EventFeignClient.java

@ -7,7 +7,7 @@ import com.elink.esua.epdc.dto.category.result.CategoryInfoResultDTO;
import com.elink.esua.epdc.feign.fallback.EventFeignClientFallback; import com.elink.esua.epdc.feign.fallback.EventFeignClientFallback;
import org.springframework.cloud.openfeign.FeignClient; import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.http.MediaType; import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.GetMapping;
import java.util.List; import java.util.List;
@ -19,13 +19,13 @@ import java.util.List;
@FeignClient(name = ServiceConstant.EPDC_EVENTS_SERVER, fallback = EventFeignClientFallback.class) @FeignClient(name = ServiceConstant.EPDC_EVENTS_SERVER, fallback = EventFeignClientFallback.class)
public interface EventFeignClient { public interface EventFeignClient {
/** /**
* @param categoryInfoFormDTO * @param categoryInfoFormDTO
* @return com.elink.esua.epdc.commons.tools.utils.Result<java.util.List < com.elink.esua.epdc.dto.category.result.CategoryInfoResultDTO>> * @return com.elink.esua.epdc.commons.tools.utils.Result<java.util.List < com.elink.esua.epdc.dto.category.result.CategoryInfoResultDTO>>
* @Author yinzuomei * @Author yinzuomei
* @Description 根据id查询事件分类基本信息 * @Description 根据id查询事件分类基本信息
* @Date 2019/12/4 10:37 * @Date 2019/12/4 10:37
**/ **/
@PostMapping(value = "events/category/queryCategoryInfo", consumes = MediaType.APPLICATION_JSON_VALUE) @GetMapping(value = "events/category/queryCategoryInfo", consumes = MediaType.APPLICATION_JSON_VALUE)
Result<List<CategoryInfoResultDTO>> queryCategoryInfo(CategoryInfoFormDTO categoryInfoFormDTO); Result<List<CategoryInfoResultDTO>> queryCategoryInfo(CategoryInfoFormDTO categoryInfoFormDTO);
} }

114
esua-epdc/epdc-module/epdc-kpi/epdc-kpi-server/src/main/java/com/elink/esua/epdc/service/impl/KpiTimeLimitItemServiceImpl.java

@ -21,6 +21,8 @@ import cn.hutool.core.collection.CollUtil;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.metadata.IPage;
import com.elink.esua.epdc.commons.mybatis.service.impl.BaseServiceImpl; import com.elink.esua.epdc.commons.mybatis.service.impl.BaseServiceImpl;
import com.elink.esua.epdc.commons.tools.constant.NumConstant;
import com.elink.esua.epdc.commons.tools.constant.StrConstant;
import com.elink.esua.epdc.commons.tools.page.PageData; import com.elink.esua.epdc.commons.tools.page.PageData;
import com.elink.esua.epdc.commons.tools.utils.ConvertUtils; import com.elink.esua.epdc.commons.tools.utils.ConvertUtils;
import com.elink.esua.epdc.commons.tools.constant.FieldConstant; import com.elink.esua.epdc.commons.tools.constant.FieldConstant;
@ -33,6 +35,7 @@ import com.elink.esua.epdc.entity.KpiTimeLimitItemEntity;
import com.elink.esua.epdc.feign.EventFeignClient; import com.elink.esua.epdc.feign.EventFeignClient;
import com.elink.esua.epdc.redis.KpiTimeLimitItemRedis; import com.elink.esua.epdc.redis.KpiTimeLimitItemRedis;
import com.elink.esua.epdc.service.KpiTimeLimitItemService; import com.elink.esua.epdc.service.KpiTimeLimitItemService;
import com.google.common.collect.Lists;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -55,8 +58,6 @@ import java.util.Map;
public class KpiTimeLimitItemServiceImpl extends BaseServiceImpl<KpiTimeLimitItemDao, KpiTimeLimitItemEntity> implements KpiTimeLimitItemService { public class KpiTimeLimitItemServiceImpl extends BaseServiceImpl<KpiTimeLimitItemDao, KpiTimeLimitItemEntity> implements KpiTimeLimitItemService {
private Logger logger = LoggerFactory.getLogger(getClass()); private Logger logger = LoggerFactory.getLogger(getClass());
@Autowired
private KpiTimeLimitItemRedis kpiTimeLimitItemRedis;
@Autowired @Autowired
private EventFeignClient eventFeignClient; private EventFeignClient eventFeignClient;
@ -80,8 +81,8 @@ public class KpiTimeLimitItemServiceImpl extends BaseServiceImpl<KpiTimeLimitIte
return ConvertUtils.sourceToTarget(entityList, KpiTimeLimitItemDTO.class); return ConvertUtils.sourceToTarget(entityList, KpiTimeLimitItemDTO.class);
} }
private QueryWrapper<KpiTimeLimitItemEntity> getWrapper(Map<String, Object> params){ private QueryWrapper<KpiTimeLimitItemEntity> getWrapper(Map<String, Object> params) {
String id = (String)params.get(FieldConstant.ID_HUMP); String id = (String) params.get(FieldConstant.ID_HUMP);
QueryWrapper<KpiTimeLimitItemEntity> wrapper = new QueryWrapper<>(); QueryWrapper<KpiTimeLimitItemEntity> wrapper = new QueryWrapper<>();
wrapper.eq(StringUtils.isNotBlank(id), FieldConstant.ID, id); wrapper.eq(StringUtils.isNotBlank(id), FieldConstant.ID, id);
@ -98,47 +99,82 @@ public class KpiTimeLimitItemServiceImpl extends BaseServiceImpl<KpiTimeLimitIte
@Override @Override
@Transactional(rollbackFor = Exception.class) @Transactional(rollbackFor = Exception.class)
public Result save(KpiTimeLimitItemDTO dto) { public Result save(KpiTimeLimitItemDTO dto) {
for (String categoryIds : dto.getCategoryIds()) { List<Long[]> selectedCategoryIds = dto.getCategoryIds();
categoryIds = categoryIds.replaceAll("\\[", "").replaceAll("\\]", "").replace("\"", ""); // 用户选择的所有部门id(去重之后)
String[] categoryIdArray = categoryIds.split(","); List<Long> distinctCategoryIds = Lists.newArrayList();
String categoryId = categoryIdArray[categoryIdArray.length - 1];
CategoryInfoFormDTO categoryInfoFormDTO = new CategoryInfoFormDTO(); for (Long[] oneOptionCategoryIdArray : selectedCategoryIds) {
Long[] ids = new Long[1]; for (Long categoryId : oneOptionCategoryIdArray) {
ids[0] = Long.valueOf(categoryId); if (!distinctCategoryIds.contains(categoryId)) {
categoryInfoFormDTO.setIds(ids); distinctCategoryIds.add(categoryId);
Result<List<CategoryInfoResultDTO>> res = eventFeignClient.queryCategoryInfo(categoryInfoFormDTO); }
if (res.getCode() != 0 || CollUtil.isEmpty(res.getData()) || res.getData().size() == 0) {
return new Result().error("查询分类详情失败" + res.getMsg());
} }
String allCategoryNames = ""; }
String parentCategoryIds = ""; CategoryInfoFormDTO categoryInfoFormDto = new CategoryInfoFormDTO();
String parentCategoryNames = ""; categoryInfoFormDto.setIds(distinctCategoryIds.toArray(new Long[distinctCategoryIds.size()]));
CategoryInfoResultDTO categoryInfoResultDTO = res.getData().get(0); Result<List<CategoryInfoResultDTO>> eventResult = eventFeignClient.queryCategoryInfo(categoryInfoFormDto);
for (String parentName : categoryInfoResultDTO.getParentNames()) { if (!eventResult.success() || CollUtil.isEmpty(eventResult.getData())) {
parentCategoryNames += (parentName + "-"); return new Result().error();
}
List<CategoryInfoResultDTO> categoryInfoList = eventResult.getData();
KpiTimeLimitItemEntity timeLimit;
List<KpiTimeLimitItemEntity> entityList = Lists.newArrayList();
for (CategoryInfoResultDTO categoryInfo : categoryInfoList) {
delteTimeLimitByCategoryId(categoryInfo.getId());
timeLimit = new KpiTimeLimitItemEntity();
timeLimit.setValidCloseTime(dto.getValidCloseTime());
timeLimit.setValidRespondTime(dto.getValidRespondTime());
timeLimit.setCategoryId(categoryInfo.getId());
// 父id为根节点0,表示一级类别,不拼接根节点
if (categoryInfo.getPids().equals(NumConstant.ZERO_STR)) {
timeLimit.setAllCategoryIds(String.valueOf(categoryInfo.getId()));
timeLimit.setAllCategoryNames(categoryInfo.getCategoryName());
} else {
timeLimit.setAllCategoryIds(categoryInfo.getPids().concat(StrConstant.COMMA).concat(String.valueOf(categoryInfo.getId())));
timeLimit.setAllCategoryNames(categoryInfo.getParentNames().concat(StrConstant.HYPHEN.concat(categoryInfo.getCategoryName())));
} }
//去除最后一个-
parentCategoryNames = parentCategoryNames.substring(0, parentCategoryNames.length() - 1); timeLimit.setParentCategoryIds(categoryInfo.getPids());
allCategoryNames = parentCategoryNames + "-" + categoryInfoResultDTO.getCategoryName(); timeLimit.setParentCategoryNames(categoryInfo.getParentNames());
int index = categoryIds.lastIndexOf(","); entityList.add(timeLimit);
// logger.info("最后一个逗号所在的位置"+index);
parentCategoryIds = categoryIds.substring(0, index);
dto.setCategoryId(categoryId);
dto.setAllCategoryIds(categoryIds);
dto.setAllCategoryNames(allCategoryNames);
dto.setParentCategoryIds(parentCategoryIds);
dto.setParentCategoryNames(parentCategoryNames);
KpiTimeLimitItemEntity entity = ConvertUtils.sourceToTarget(dto, KpiTimeLimitItemEntity.class);
// 删除已存在的记录
QueryWrapper<KpiTimeLimitItemEntity> wrapper = new QueryWrapper<>();
wrapper.eq(StringUtils.isNotBlank(categoryId), "CATEGORY_ID", categoryId);
baseDao.delete(wrapper);
//插入
insert(entity);
} }
baseDao.deleteBatchByCategoryIds(distinctCategoryIds);
this.insertBatch(entityList, NumConstant.THIRTY);
return new Result(); return new Result();
} }
/**
* 根据类别id删除类别设置
*
* @param categoryId
* @return int
* @author work@yujt.net.cn
* @date 2019/12/16 17:49
*/
private int delteTimeLimitByCategoryId(Long categoryId) {
QueryWrapper<KpiTimeLimitItemEntity> wrapper = new QueryWrapper<>();
wrapper.eq("CATEGORY_ID", categoryId);
return baseDao.delete(wrapper);
}
public static void main(String[] args) {
List<Long> aa = Lists.newArrayList();
aa.add(0L);
aa.add(1L);
Long[] bb = aa.toArray(new Long[aa.size()]);
for (Long aLong : bb) {
System.out.println(aLong);
}
}
@Override @Override
@Transactional(rollbackFor = Exception.class) @Transactional(rollbackFor = Exception.class)
public void update(KpiTimeLimitItemDTO dto) { public void update(KpiTimeLimitItemDTO dto) {

20
esua-epdc/epdc-module/epdc-kpi/epdc-kpi-server/src/main/resources/mapper/KpiTimeLimitItemDao.xml

@ -3,22 +3,10 @@
<mapper namespace="com.elink.esua.epdc.dao.KpiTimeLimitItemDao"> <mapper namespace="com.elink.esua.epdc.dao.KpiTimeLimitItemDao">
<resultMap type="com.elink.esua.epdc.entity.KpiTimeLimitItemEntity" id="kpiTimeLimitItemMap"> <delete id="deleteBatchByCategoryIds">
<result property="id" column="ID"/> delete from epdc_kpi_time_limit_item where category_id in
<result property="validRespondTime" column="VALID_RESPOND_TIME"/> <foreach collection="categoryIds" item="item" open="(" separator="," close=")">#{item}</foreach>
<result property="validCloseTime" column="VALID_CLOSE_TIME"/> </delete>
<result property="categoryId" column="CATEGORY_ID"/>
<result property="parentCategoryIds" column="PARENT_CATEGORY_IDS"/>
<result property="parentCategoryNames" column="PARENT_CATEGORY_NAMES"/>
<result property="allCategoryIds" column="ALL_CATEGORY_IDS"/>
<result property="allCategoryNames" column="ALL_CATEGORY_NAMES"/>
<result property="revision" column="REVISION"/>
<result property="createdBy" column="CREATED_BY"/>
<result property="createdTime" column="CREATED_TIME"/>
<result property="updatedBy" column="UPDATED_BY"/>
<result property="updatedTime" column="UPDATED_TIME"/>
<result property="delFlag" column="DEL_FLAG"/>
</resultMap>
</mapper> </mapper>
Loading…
Cancel
Save