From e94a80ae3d9733eb2d6a5d9bcbd50a624f058caa Mon Sep 17 00:00:00 2001
From: yanghui <2536613402@qq.com>
Date: 星期三, 19 十月 2022 17:39:48 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/huacheng_test' into huacheng_test

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComSanShuoExpertServiceImpl.java |   82 ++++++++++++++++++++++++++++++++++++++---
 1 files changed, 76 insertions(+), 6 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComSanShuoExpertServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComSanShuoExpertServiceImpl.java
index d19192c..6c3e17b 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComSanShuoExpertServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComSanShuoExpertServiceImpl.java
@@ -4,12 +4,15 @@
 import cn.hutool.core.util.NumberUtil;
 import cn.hutool.crypto.SecureUtil;
 import cn.hutool.crypto.digest.MD5;
+import cn.hutool.extra.pinyin.PinyinUtil;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.panzhihua.common.model.dtos.community.sanshuo.ComSanshuoExpertDTO;
 import com.panzhihua.common.model.vos.LoginUserInfoVO;
 import com.panzhihua.common.model.vos.R;
+import com.panzhihua.common.model.vos.sanshuo.ComSanshuoExpertVO;
 import com.panzhihua.common.model.vos.sanshuo.ExpertRangeVO;
 import com.panzhihua.common.model.vos.sanshuo.ExpertShowVO;
 import com.panzhihua.common.model.vos.user.AdministratorsUserVO;
@@ -21,12 +24,14 @@
 import com.panzhihua.service_community.entity.ComEvent;
 import com.panzhihua.service_community.entity.ComSanshuoEvent;
 import com.panzhihua.service_community.entity.ComSanshuoExpert;
+import com.panzhihua.service_community.entity.ComSanshuoIndustryCenter;
 import com.panzhihua.service_community.model.dos.ComActDO;
 import com.panzhihua.service_community.model.dos.ComStreetDO;
 import com.panzhihua.service_community.service.ComActService;
 import com.panzhihua.service_community.service.ComSanShuoExpertService;
 import com.panzhihua.service_community.service.ComStreetService;
 import com.panzhihua.service_community.util.MyAESUtil;
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
@@ -40,6 +45,7 @@
 import static java.util.Objects.nonNull;
 
 @Service
+@Slf4j
 public class ComSanShuoExpertServiceImpl  extends ServiceImpl<ComSanshuoExpertDao, ComSanshuoExpert> implements ComSanShuoExpertService {
 
     @Resource
@@ -106,6 +112,7 @@
                 user.setName(comSanshuoExpertDTO.getName());
                 user.setType(11);
                 user.setImageUrl(comSanshuoExpertDTO.getAvatar());
+                user.setPhone(comSanshuoExpertDTO.getPhone());
                 return R.ok(userService.sanShuoAddUser(user));
             }
         }else {
@@ -133,6 +140,7 @@
         return R.fail("操作失败");
     }
 
+
     /**
      * 后台获取专家列表
      * @param page
@@ -142,7 +150,7 @@
      * @return 处理结果
      * */
     @Override
-    public R expertPage(String keyWord, Integer page, Integer size, LoginUserInfoVO loginUserInfo) {
+    public R expertPage(String keyWord, Integer page, Integer size, LoginUserInfoVO loginUserInfo,Integer level) {
         //range:1.三说会堂下属,2业务中心下属,3街道下属,4社区下属
         //id:社区或街道或业务中心id
         //账号级别
@@ -164,11 +172,23 @@
                 }
             }
         }
-        if (loginUserInfo.getAccount().equals("admin") || loginUserInfo.getAccount().equals("xiqu")){
+        if (loginUserInfo.getAccount().equals("admin") && isNull(level)){
             id=null;
-            range=null;
+            range=1;
         }
-        return R.ok(comSanshuoExpertDao.expertPage(new Page(page,size),keyWord,range,id));
+        IPage<ComSanshuoExpertVO> comSanshuoExpertVOIPage = comSanshuoExpertDao.expertPage(new Page(page, size), keyWord, range, id, level);
+        for (ComSanshuoExpertVO record : comSanshuoExpertVOIPage.getRecords()) {
+            //获取调解次数和成功率
+            record.setCount(comEventMapper.selectCount(new QueryWrapper<ComEvent>().lambda().eq(ComEvent::getSpecialistId, record.getId())));
+            record.setSuccessCount(comEventMapper.selectCount(new QueryWrapper<ComEvent>().lambda().eq(ComEvent::getSpecialistId, record.getId()).eq(ComEvent::getEventResult,2 )));
+            if (nonNull(record.getCount()) && nonNull(record.getSuccessCount())){
+                if (!record.getCount().equals(0) && !record.getSuccessCount().equals(0)){
+                    record.setRate(NumberUtil.div(record.getSuccessCount(), record.getCount(),2));
+                }
+
+            }
+        }
+        return R.ok(comSanshuoExpertVOIPage);
     }
 
     /**
@@ -198,6 +218,7 @@
         }
         return R.ok(expertShowVOS);
     }
+
 
     /**
      * 专家级别与单位范围
@@ -244,7 +265,7 @@
                 ExpertRangeVO vo=new ExpertRangeVO();
                 vo.setLevel(2);
                 vo.setName("行业分中心");
-                vo.setId(loginUserInfo.getCommunityId());
+                vo.setId(comSanshuoIndustryCenterDao.selectOne(new QueryWrapper<ComSanshuoIndustryCenter>().lambda().eq(ComSanshuoIndustryCenter::getAccount, loginUserInfo.getAccount())).getId());
                 list.add(vo);
                 return R.ok(list);
             }else if (nonNull(loginUserInfo.getUserType())){
@@ -266,7 +287,7 @@
                     ExpertRangeVO vo=new ExpertRangeVO();
                     vo.setLevel(4);
                     vo.setName(comActDO.getName()+"调解站");
-                    vo.setId(loginUserInfo.getStreetId());
+                    vo.setId(loginUserInfo.getCommunityId());
                     list.add(vo);
                     return R.ok(list);
                 }
@@ -341,5 +362,54 @@
         return R.ok(comSanshuoExperts);
     }
 
+    @Override
+    public void insertExpert(ComSanshuoExpert expert) {
+//            if (nonNull(comSanshuoExpertDTO.getUnit())){
+//                String id = comSanshuoExpertDTO.getUnit();
+//                String[] split = id.split(",");
+//                expert.setUnitId(split[split.length-1]);
+//            }
+            expert.setId(Snowflake.getId());
+            expert.setCreateTime(new Date());
+            if (expert.getLevel()==2){
+                expert.setIndustryCenterId(Long.parseLong(expert.getUnitId()));
+                expert.setUnit(comSanshuoIndustryCenterDao.selectById(expert.getUnitId()).getName()+"调解站");
+            }else if(expert.getLevel()==3){
+                expert.setStreetId(Long.parseLong(expert.getUnitId()));
+                expert.setUnit(comStreetDAO.selectById(expert.getUnitId()).getName()+"调解站");
+            }else if(expert.getLevel()==4){
+                expert.setCommunityId(Long.parseLong(expert.getUnitId()));
+                expert.setUnit(comActDAO.selectById(expert.getUnitId()).getName()+"调解站");
+            }
+            expert.setStatus(1);
+            expert.setDelFlag(1);
+            expert.setCreateBy("admin");
+            expert.setCreateTime(new Date());
+            expert.setAdded(0);
+            expert.setPassword("Huacheng@123");
+            expert.setAccount(PinyinUtil.getPinyin(expert.getName(),""));
+            int insert = comSanshuoExpertDao.insert(expert);
+            if (insert>0){
+                log.info(expert.getName()+"添加完成");
+            }
+//            if (insert>0){
+//                try {
+//                    comSanshuoExpertDTO.setPassword(comSanshuoExpertDTO.getPassword());
+//                } catch (Exception e) {
+//                    e.printStackTrace();
+//                }
+//                //生成后台账号
+//                AdministratorsUserVO user=new AdministratorsUserVO();
+//                user.setUserId(Snowflake.getId());
+//                user.setAccount(comSanshuoExpertDTO.getAccount());
+//                user.setPassword(comSanshuoExpertDTO.getPassword());
+//                user.setName(comSanshuoExpertDTO.getName());
+//                user.setType(11);
+//                user.setImageUrl(comSanshuoExpertDTO.getAvatar());
+//                user.setPhone(comSanshuoExpertDTO.getPhone());
+//                userService.sanShuoAddUser(user);
+//            }
+    }
+
 
 }

--
Gitblit v1.7.1