From c88d1658a2b6b51ed1a81c3be3e9102b661970f3 Mon Sep 17 00:00:00 2001
From: luoxinwu <934743099@qq.com>
Date: 星期二, 05 三月 2024 09:42:37 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/haucheng_panzhihua' into haucheng_panzhihua

---
 springcloud_k8s_panzhihuazhihuishequ/service_partybuilding/src/main/java/com/panzhihua/service_dangjian/service/impl/ComPbCheckUnitServiceImpl.java |  213 +++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 204 insertions(+), 9 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_partybuilding/src/main/java/com/panzhihua/service_dangjian/service/impl/ComPbCheckUnitServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_partybuilding/src/main/java/com/panzhihua/service_dangjian/service/impl/ComPbCheckUnitServiceImpl.java
index c0fa210..b9ed48e 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_partybuilding/src/main/java/com/panzhihua/service_dangjian/service/impl/ComPbCheckUnitServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_partybuilding/src/main/java/com/panzhihua/service_dangjian/service/impl/ComPbCheckUnitServiceImpl.java
@@ -1,32 +1,41 @@
 package com.panzhihua.service_dangjian.service.impl;
 
+import cn.hutool.core.collection.CollUtil;
+import com.baomidou.mybatisplus.core.conditions.Wrapper;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 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.google.common.collect.Lists;
 import com.panzhihua.common.enums.ComPbCheckUnitTypeEnum;
+import com.panzhihua.common.model.dtos.common.AddComPbCheckUnitDto;
+import com.panzhihua.common.model.dtos.common.EditComPbCheckUnitDto;
+import com.panzhihua.common.model.dtos.common.PageComPbCheckUnitDto;
+import com.panzhihua.common.model.dtos.common.PagePbCheckUnitCommonDto;
+import com.panzhihua.common.model.vos.R;
+import com.panzhihua.common.model.vos.TreeListVO;
 import com.panzhihua.common.model.vos.common.ComPbCheckUnitVo;
-import com.panzhihua.common.model.vos.partybuilding.PartyBuildingMemberVO;
 import com.panzhihua.common.model.vos.partybuilding.excel.ComPbCheckUnitErrorExcelVO;
 import com.panzhihua.common.model.vos.partybuilding.excel.ComPbCheckUnitExcelVO;
+import com.panzhihua.common.utlis.StringUtils;
+import com.panzhihua.service_dangjian.dao.ComPbCheckUnitMapper;
 import com.panzhihua.service_dangjian.dao.ComPbMemberDAO;
 import com.panzhihua.service_dangjian.dao.ComPbMemberRoleDAO;
 import com.panzhihua.service_dangjian.entity.ComPbCheckUnit;
-import com.panzhihua.service_dangjian.dao.ComPbCheckUnitMapper;
 import com.panzhihua.service_dangjian.model.dos.ComPbMemberDO;
 import com.panzhihua.service_dangjian.model.dos.ComPbMemberRoleDO;
 import com.panzhihua.service_dangjian.service.ComPbCheckUnitService;
-import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import org.springframework.beans.BeanUtils;
-import com.panzhihua.common.model.dtos.common.*;
-import com.panzhihua.common.model.vos.R;
 import org.springframework.stereotype.Service;
-import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import org.springframework.transaction.annotation.Transactional;
 
 import javax.annotation.Resource;
 import java.util.ArrayList;
 import java.util.Date;
 import java.util.List;
+import java.util.Map;
+import java.util.stream.Collectors;
 
 /**
  * title: 党建-报到单位表服务实现类
@@ -46,6 +55,7 @@
     @Resource
     private ComPbMemberRoleDAO comPbMemberRoleDAO;
 
+
     /**
      * description  queryByPage  分页查询
      *
@@ -56,7 +66,51 @@
      */
     @Override
     public R queryByPage(PageComPbCheckUnitDto comPbCheckUnit) {
-        return R.ok(this.baseMapper.queryAllByLimit(comPbCheckUnit, new Page(comPbCheckUnit.getPageNum(), comPbCheckUnit.getPageSize())));
+
+        Long communityId = comPbCheckUnit.getCommunityId();
+        if (communityId != null){
+            List<Long> communityIds = comPbMemberDAO.selectIds(communityId);
+            if (CollUtil.isEmpty(communityIds)) {
+                communityIds = new ArrayList<>();
+                communityIds.add(communityId);
+            }
+            comPbCheckUnit.setCommunityIds(communityIds);
+        }
+        IPage<ComPbCheckUnitVo> checkUnitVoPage= this.baseMapper.queryAllByLimit(comPbCheckUnit, new Page(comPbCheckUnit.getPageNum(), comPbCheckUnit.getPageSize()));
+        checkUnitVoPage.getRecords().forEach(checkUnit -> {
+            if(StringUtils.isEmpty(checkUnit.getOrgName())){
+                checkUnit.setOrgName("待编辑党支部");
+            }
+        });
+        return R.ok(checkUnitVoPage);
+    }
+
+    @Override
+    public R treeList(TreeListVO treeListVO) {
+        QueryWrapper<ComPbCheckUnit> wrapper = new QueryWrapper<>();
+        if(treeListVO.getName() != null){
+            wrapper.eq("belong_to",treeListVO.getName());
+        } else if(treeListVO.getOrgName() != null){
+            wrapper.eq("org_name",treeListVO.getOrgName());
+        } else {
+            return R.ok();
+        }
+        List<ComPbCheckUnit> comPbCheckUnits = this.baseMapper.selectList(wrapper);
+        return R.ok(comPbCheckUnits);
+    }
+
+    @Override
+    public R orgList() {
+        QueryWrapper<ComPbCheckUnit> wrapper = new QueryWrapper<>();
+        List<ComPbCheckUnitVo> voList = new ArrayList<>();
+        List<ComPbCheckUnit> list = this.baseMapper.selectList(wrapper);
+        Map<String, List<ComPbCheckUnit>> map = list.stream().filter(f -> f.getOrgName() != null).collect(Collectors.groupingBy(ComPbCheckUnit::getOrgName));
+        for (Map.Entry<String, List<ComPbCheckUnit>> entry : map.entrySet()) {
+            ComPbCheckUnitVo pbCheckUnitVo = new ComPbCheckUnitVo();
+            pbCheckUnitVo.setOrgName(entry.getKey());
+            voList.add(pbCheckUnitVo);
+        }
+        return R.ok(voList);
     }
 
     /**
@@ -68,9 +122,14 @@
      * @date 2022-02-16 16:22:26
      */
     @Override
+    @Transactional
     public R insert(AddComPbCheckUnitDto comPbCheckUnit) {
+        Long communityId=this.baseMapper.selectCommunityId(comPbCheckUnit.getHelpCommunityName().split(",")[0],comPbCheckUnit.getHelpCommunityName().split(",")[1],comPbCheckUnit.getHelpCommunityName().split(",")[2]);
         ComPbCheckUnit entity = new ComPbCheckUnit();
         BeanUtils.copyProperties(comPbCheckUnit, entity);
+        if(communityId!=null){
+            entity.setCommunityId(communityId);
+        }
         if (this.baseMapper.insert(entity) > 0) {
             return R.ok();
         }
@@ -134,7 +193,14 @@
      */
     @Override
     public R detailById(Long id) {
-        return R.ok(this.baseMapper.queryById(id));
+        ComPbCheckUnitVo checkUnitVo = this.baseMapper.queryById(id);
+        if(checkUnitVo != null && StringUtils.isEmpty(checkUnitVo.getContacts())){
+            checkUnitVo.setContacts("待编辑负责人");
+        }
+        if(checkUnitVo != null && StringUtils.isEmpty(checkUnitVo.getOrgName())){
+            checkUnitVo.setOrgName("待编辑党支部");
+        }
+        return R.ok(checkUnitVo);
     }
 
     /**
@@ -147,7 +213,31 @@
      */
     @Override
     public R queryByList(PageComPbCheckUnitDto comPbCheckUnit) {
-        return R.ok(this.baseMapper.queryAllByList(comPbCheckUnit));
+        Long communityId = comPbCheckUnit.getCommunityId();
+        if (communityId != null){
+            List<Long> communityIds = comPbMemberDAO.selectIds(communityId);
+            if (CollUtil.isEmpty(communityIds)) {
+                communityIds = new ArrayList<>();
+                communityIds.add(communityId);
+            }
+            comPbCheckUnit.setCommunityIds(communityIds);
+        }
+        IPage<ComPbCheckUnitVo> checkUnitList = this.baseMapper.queryAllByLimit(comPbCheckUnit,new Page(comPbCheckUnit.getPageNum(),comPbCheckUnit.getPageSize()));
+        checkUnitList.getRecords().forEach(checkUnit -> {
+            if(StringUtils.isEmpty(checkUnit.getOrgName())){
+                checkUnit.setOrgName("待编辑党支部");
+            }
+            if(StringUtils.isNotEmpty(checkUnit.getAreaCode())){
+                switch (checkUnit.getAreaCode()){
+                    case "510423": checkUnit.setAreaName("西区"); break;
+                    case "510402": checkUnit.setAreaName("东区"); break;
+                    case "510411": checkUnit.setAreaName("仁和区"); break;
+                    case "510421": checkUnit.setAreaName("米易县"); break;
+                    case "510422": checkUnit.setAreaName("盐边"); break;
+                }
+            }
+        });
+        return R.ok(checkUnitList);
     }
 
     /**
@@ -191,4 +281,109 @@
         }
         return R.ok();
     }
+
+    @Override
+    public R detailByPhone(String phone) {
+        List<ComPbCheckUnit> comPbCheckUnits=this.baseMapper.selectList(new QueryWrapper<ComPbCheckUnit>().lambda().eq(ComPbCheckUnit::getAdminPhone,phone));
+        if(!comPbCheckUnits.isEmpty()){
+            return R.ok(comPbCheckUnits.get(0));
+        }
+        return R.ok();
+    }
+
+    /**
+     * 报到单位统计-顶部数据
+     * @param communityId
+     * @param belongTo
+     * @param choice
+     * @return
+     */
+    @Override
+    public R unitStatisticsTop(Long communityId, String belongTo, String choice,Long[] unitIds) {
+        List<Long> communityIds = new ArrayList<>();
+        if (null != communityId){
+             communityIds = comPbMemberDAO.selectIds(communityId);
+            if (CollUtil.isEmpty(communityIds)) {
+                communityIds.add(communityId);
+            }
+        }
+
+        return R.ok(this.baseMapper.unitStatisticsTop(communityIds, belongTo, choice,unitIds));
+    }
+
+    /**
+     * 报到单位统计
+     * @param commonDto
+     * @return
+     */
+    @Override
+    public R unitStatistics(PagePbCheckUnitCommonDto commonDto) {
+        Long communityId = commonDto.getCommunityId();
+        if (null != communityId) {
+            List<Long> communityIds = comPbMemberDAO.selectIds(communityId);
+            if (CollUtil.isEmpty(communityIds)) {
+                communityIds = new ArrayList<>();
+                communityIds.add(communityId);
+            }
+            commonDto.setCommunityIds(communityIds);
+        }
+        return R.ok(this.baseMapper.unitStatistics(commonDto, new Page(commonDto.getPageNum(), commonDto.getPageSize())));
+    }
+
+    /**
+     * 报到党员统计-顶部数据
+     * @param communityId
+     * @param belongTo
+     * @param choice
+     * @param checkUnitId
+     * @return
+     */
+    @Override
+    public R pbStatisticsTop(Long communityId, String belongTo, String choice, Long checkUnitId,Long[] unitIds) {
+
+        List<Long> communityIds = new ArrayList<>();
+        if (null != communityId){
+            communityIds = comPbMemberDAO.selectIds(communityId);
+            if (CollUtil.isEmpty(communityIds)) {
+                communityIds.add(communityId);
+            }
+        }
+        return R.ok(this.baseMapper.pbStatisticsTop(communityIds, belongTo, choice, checkUnitId,unitIds));
+    }
+
+    /**
+     * 报到党员统计-按单位归属统计
+     * @param commonDto
+     * @return
+     */
+    @Override
+    public R pbStatisticsBelong(PagePbCheckUnitCommonDto commonDto) {
+        Long communityId = commonDto.getCommunityId();
+        if (null != communityId) {
+            List<Long> communityIds = comPbMemberDAO.selectIds(communityId);
+            if (CollUtil.isEmpty(communityIds)) {
+                communityIds = new ArrayList<>();
+                communityIds.add(communityId);
+            }
+            commonDto.setCommunityIds(communityIds);
+        }
+        return R.ok(this.baseMapper.pbStatisticsBelong(commonDto, new Page(commonDto.getPageNum(), commonDto.getPageSize())));
+    }
+
+    /**
+     * 报到党员统计-按单位统计
+     * @param commonDto
+     * @return
+     */
+    @Override
+    public R pbStatisticsUnit(PagePbCheckUnitCommonDto commonDto) {
+        Long communityId = commonDto.getCommunityId();
+        List<Long> communityIds = comPbMemberDAO.selectIds(communityId);
+        if (CollUtil.isEmpty(communityIds)) {
+            communityIds = new ArrayList<>();
+            communityIds.add(communityId);
+        }
+        commonDto.setCommunityIds(communityIds);
+        return R.ok(this.baseMapper.pbStatisticsUnit(commonDto, new Page(commonDto.getPageNum(), commonDto.getPageSize())));
+    }
 }

--
Gitblit v1.7.1