From 3bb39d123ef72b627386301af48a349defda69bd Mon Sep 17 00:00:00 2001
From: fengjin <1435304038@qq.com>
Date: 星期一, 10 十月 2022 16:01:49 +0800
Subject: [PATCH] 小程序获取导半人员及自动分配部分代码

---
 flower_city/src/main/java/com/dg/core/service/impl/GuideRepairOrderServiceImpl.java |   80 +++++++++++++++++++++++++++++++++++----
 1 files changed, 71 insertions(+), 9 deletions(-)

diff --git a/flower_city/src/main/java/com/dg/core/service/impl/GuideRepairOrderServiceImpl.java b/flower_city/src/main/java/com/dg/core/service/impl/GuideRepairOrderServiceImpl.java
index dc96213..8a45c67 100644
--- a/flower_city/src/main/java/com/dg/core/service/impl/GuideRepairOrderServiceImpl.java
+++ b/flower_city/src/main/java/com/dg/core/service/impl/GuideRepairOrderServiceImpl.java
@@ -4,16 +4,14 @@
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.dg.core.db.gen.entity.*;
-import com.dg.core.db.gen.mapper.GuideRepairOrderImageMapper;
-import com.dg.core.db.gen.mapper.GuideRepairOrderMapper;
-import com.dg.core.db.gen.mapper.SysUserMapper;
-import com.dg.core.db.gen.mapper.TransactionEventMapper;
+import com.dg.core.db.gen.mapper.*;
 import com.dg.core.service.IGuideRepairOrderService;
 import com.dg.core.util.Snowflake;
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
 import java.time.LocalDateTime;
+import java.util.ArrayList;
 import java.util.List;
 
 @Service
@@ -27,6 +25,12 @@
 
     @Resource
     private SysUserMapper sysUserMapper;
+    
+    @Resource
+    private OrganizationChartMapper  organizationChartMapper;
+
+    @Resource
+    private  GuideEvolveMapper guideEvolveMapper;
 
     @Override
     public  int addOrder(GuideRepairOrder guideRepairOrder){
@@ -37,10 +41,55 @@
         guideRepairOrder.setMatterName(transactionEvent.getMatterName());
         guideRepairOrder.setDepartmentId(transactionEvent.getDepartmentId());
         guideRepairOrder.setClassifyId(transactionEvent.getClassifyId());
-        guideRepairOrder.setState("1");
+        List<String> departmentIds=new ArrayList<>();
+        //自动分配业务代码开始
+        List<OrganizationChartEntity> organizationChartEntities = organizationChartMapper.selectByCode(guideRepairOrder.getAreaCode());
+        if (organizationChartEntities!=null){
+            for (OrganizationChartEntity organizationChart:organizationChartEntities) {
+                departmentIds.add(organizationChart.getId().toString());
+            }
+            List<SysUser> sysUsers = sysUserMapper.selectListByDepartmentId(departmentIds, "," + transactionEvent.getClassifyId(), transactionEvent.getClassifyId() + ",");//获取导半人员
+            if (sysUsers==null) {//如果此所属地区部门没有导半人员则看其下级地区有没有相关分类导办人员
+                for (OrganizationChartEntity organizationChart:organizationChartEntities) {
+                    //获取下级部门
+                    List<OrganizationChartEntity> organizationChartEntitiesUser = organizationChartMapper.selectList(new QueryWrapper<OrganizationChartEntity>().lambda()
+                            .eq(OrganizationChartEntity::getParentId, organizationChart.getId().toString()));
+                    if (organizationChartEntitiesUser!=null)
+                        departmentIds=this.getDepartmentIds(organizationChartEntitiesUser,departmentIds);
+                }
+                sysUsers = sysUserMapper.selectListByDepartmentId(departmentIds, "," + transactionEvent.getClassifyId(), transactionEvent.getClassifyId() + ",");//获取导半人员
+                if (sysUsers==null){//如果其下级部门仍没有该分类的导半人员则查询所以该所属地区的导办人员
+                    sysUsers = sysUserMapper.selectListByDepartmentId(departmentIds,null,null);//获取导半人员
+                    if(sysUsers==null)//如果该所属地区没有导办人员则为特殊单据需要手动分配
+                        guideRepairOrder.setState("1");
+                }
+            }
+            if (sysUsers!=null){//系统分配导办人员
+                SysUser sysUser = sysUsers.get(0);//因为sql用了升序排序所以第一条就是待办结最少的人员之一
+                guideRepairOrder.setState("2");
+                guideRepairOrder.setGuideUserId(sysUser.getUserId().toString());
+                guideRepairOrder.setGuideDepartmentId(sysUser.getDepartmentId());
+                //新增分配记录
+                GuideEvolveEntity entity=new GuideEvolveEntity();
+                entity.setCreateTime(LocalDateTime.now());
+                entity.setUpdateTime(LocalDateTime.now());
+                entity.setState("10");
+                entity.setDepartmentalId(sysUser.getDepartmentId());
+                entity.setToUserId(guideRepairOrder.getGuideUserId()+"");
+                entity.setFromUserId(guideRepairOrder.getSubmitUserId());
+                entity.setFromDepartmentalId(guideRepairOrder.getGuideDepartmentId());
+                entity.setGuideId(guideRepairOrder.getId().toString());
+                guideEvolveMapper.insertConfig(entity);
+            }
+        }
+        else{//如果该办事指南用户所选所属地区无导半部门则为特殊单据需要手动分配
+           guideRepairOrder.setState("1");
+        }
+        //自动分配业务代码结束
         guideRepairOrder.setCreateTime(LocalDateTime.now());
         guideRepairOrder.setUpdateTime(LocalDateTime.now());
         transactionEvent.setTransactionNum(transactionEvent.getTransactionNum()+1);
+        //保存图片地址
         if (guideRepairOrder.getImages()!=null){
            String[] images = guideRepairOrder.getImages().split(",");
            for (String image: images) {
@@ -53,6 +102,7 @@
             guideRepairOrderImageMapper.insert(guideRepairOrderImage);
           }
         }
+        //保存视频地址
         if (guideRepairOrder.getVideo()!=null){
           if (guideRepairOrder.getOrderNum()!=null){
             GuideRepairOrderImage guideRepairOrderImage = new GuideRepairOrderImage();
@@ -73,6 +123,18 @@
 
     }
 
+    public  List<String> getDepartmentIds(  List<OrganizationChartEntity> organizationChartEntities,List<String> departmentIds){
+        for (OrganizationChartEntity organizationChart:organizationChartEntities) {
+            departmentIds.add(organizationChart.getId().toString());
+            List<OrganizationChartEntity> organizationChartEntitiesUser = organizationChartMapper.selectList(new QueryWrapper<OrganizationChartEntity>().lambda()
+                    .eq(OrganizationChartEntity::getParentId, organizationChart.getId().toString()));
+            if (organizationChartEntitiesUser!=null)
+                departmentIds=this.getDepartmentIds(organizationChartEntitiesUser,departmentIds);
+
+        }
+        return  departmentIds;
+    }
+
     @Override
     public GuideRepairOrder selectConfigData(String Id, String orderNum) {
         return baseMapper.selectConfigData(Id,orderNum);
@@ -91,13 +153,13 @@
     }
 
     @Override
-    public List<GuideRepairOrder> selectConfigList(IPage<GuideRepairOrder> page, Integer state, String matterName) {
-        return baseMapper.selectConfigList(page,state,matterName);
+    public List<GuideRepairOrder> selectConfigList(IPage<GuideRepairOrder> page, Integer state, String matterName,List<String> ids) {
+        return baseMapper.selectConfigList(page,state,matterName, ids);
     }
 
     @Override
-    public int countConfigList(String matterName) {
-        return baseMapper.countConfigList(matterName);
+    public int countConfigList(String matterName,List<String> ids) {
+        return baseMapper.countConfigList(matterName,ids);
     }
 
 

--
Gitblit v1.7.1