From 2e64c232ab6b51b2cecf1ee96e1e9b709234f326 Mon Sep 17 00:00:00 2001
From: huanghongfa <huanghongfa123456>
Date: 星期六, 21 八月 2021 16:35:14 +0800
Subject: [PATCH] 随手拍改版接口开发

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActServiceImpl.java |  145 +++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 129 insertions(+), 16 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActServiceImpl.java
index 5a8a658..68ddeaf 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComActServiceImpl.java
@@ -4,20 +4,31 @@
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.panzhihua.common.model.dtos.community.PageComActDTO;
+import com.panzhihua.common.model.dtos.community.switchs.SearchCommunityDTO;
 import com.panzhihua.common.model.dtos.user.PageFeedBackDTO;
 import com.panzhihua.common.model.vos.R;
 import com.panzhihua.common.model.vos.community.ComActVO;
 import com.panzhihua.common.model.vos.community.ComMngStructOtherBuildVO;
+import com.panzhihua.common.model.vos.community.switchs.CommunitySwitchAllAppletsVO;
+import com.panzhihua.common.model.vos.community.switchs.StreetAllAppletsVO;
 import com.panzhihua.service_community.dao.ComActDAO;
+import com.panzhihua.service_community.dao.ComActVillageDAO;
+import com.panzhihua.service_community.dao.ComStreetDAO;
 import com.panzhihua.service_community.model.dos.ComActDO;
+import com.panzhihua.service_community.model.dos.ComMngVillageDO;
+import com.panzhihua.service_community.model.dos.ComStreetDO;
 import com.panzhihua.service_community.service.ComActService;
 import org.springframework.beans.BeanUtils;
+import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
 import org.springframework.stereotype.Service;
 import org.springframework.util.ObjectUtils;
 
 import javax.annotation.Resource;
 import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Comparator;
 import java.util.List;
+import java.util.stream.Collectors;
 
 /**
  * @program: springcloud_k8s_panzhihuazhihuishequ
@@ -29,6 +40,9 @@
 public class ComActServiceImpl implements ComActService {
     @Resource
     private ComActDAO comActDAO;
+    @Resource
+    private ComStreetDAO comStreetDAO;
+
     /**
      * 新增社区
      *
@@ -37,11 +51,24 @@
      */
     @Override
     public R addCommunity(ComActVO comActVO) {
-        ComActDO comActDO=new ComActDO();
-        BeanUtils.copyProperties(comActVO,comActDO);
+        String password = comActVO.getPassword();
+        String encode = new BCryptPasswordEncoder().encode(password);
+        comActVO.setPassword(encode);
+        ComStreetDO comStreetDO = comStreetDAO.selectById(comActVO.getStreetId());
+        if (comStreetDO == null) {
+            return R.fail("当前街道不存在!");
+        }
+        ComActDO comActDO = new ComActDO();
+        Integer integer = comActDAO.selectCount(new QueryWrapper<ComActDO>().lambda().eq(ComActDO::getName, comActVO.getName()));
+        if (integer > 0) {
+            return R.fail("社区已经存在");
+        }
+        BeanUtils.copyProperties(comActVO, comActDO);
         int insert = comActDAO.insert(comActDO);
-        if (insert>0) {
-            return R.ok();
+        if (insert > 0) {
+            ComActDO comActDO1 = comActDAO.selectOne(new QueryWrapper<ComActDO>().lambda().eq(ComActDO::getName, comActVO.getName()));
+            BeanUtils.copyProperties(comActDO1, comActVO);
+            return R.ok(comActVO);
         }
         return R.fail();
     }
@@ -54,10 +81,32 @@
      */
     @Override
     public R putCommunity(ComActVO comActVO) {
-        ComActDO comActDO=new ComActDO();
-        BeanUtils.copyProperties(comActVO,comActDO);
+        ComActDO comActDO = new ComActDO();
+        String password = comActVO.getPassword();
+        String account = comActVO.getAccount();
+        Long communityId = comActVO.getCommunityId();
+//        String contacts = comActVO.getContacts();
+        int a = 0;
+        if (!ObjectUtils.isEmpty(password)) {
+            String encode = new BCryptPasswordEncoder().encode(password);
+            comActVO.setPassword(encode);
+            a = 1;
+        }
+        ComStreetDO comStreetDO = comStreetDAO.selectById(comActVO.getStreetId());
+        if (comStreetDO == null) {
+            return R.fail("当前街道不存在!");
+        }
+//        if(!ObjectUtils.isEmpty(account)||!ObjectUtils.isEmpty(contacts)){
+//            a=1;
+//        }
+        BeanUtils.copyProperties(comActVO, comActDO);
+
         int update = comActDAO.updateById(comActDO);
-        if (update>0) {
+        if (update > 0) {
+            if (a == 1) {
+//                修改登录账户的密码
+                comActDAO.updateAccountPassword(comActVO.getPassword(), account, communityId);
+            }
             return R.ok();
         }
         return R.fail();
@@ -71,7 +120,7 @@
      */
     @Override
     public R listCommunity(ComActVO comActVO) {
-        List<ComActVO> comActVOS=comActDAO.listCommunity(comActVO);
+        List<ComActVO> comActVOS = comActDAO.listCommunity(comActVO);
         return R.ok(comActVOS);
     }
 
@@ -87,8 +136,8 @@
         if (ObjectUtils.isEmpty(comActDO)) {
             return R.fail();
         }
-        ComActVO comActVO=new ComActVO();
-        BeanUtils.copyProperties(comActDO,comActVO);
+        ComActVO comActVO = new ComActVO();
+        BeanUtils.copyProperties(comActDO, comActVO);
         comActVO.setAreaName(comActDAO.selectAreaName(comActVO.getAreaCode()));
         return R.ok(comActVO);
     }
@@ -104,10 +153,10 @@
         Page page = new Page<>();
         Long pageNum = pageComActDTO.getPageNum();
         Long pageSize = pageComActDTO.getPageSize();
-        if (null==pageNum||0==pageNum) {
+        if (null == pageNum || 0 == pageNum) {
             pageNum = 1l;
         }
-        if (null==pageSize||0==pageSize) {
+        if (null == pageSize || 0 == pageSize) {
             pageSize = 10l;
         }
         page.setSize(pageSize);
@@ -123,19 +172,83 @@
      */
     @Override
     public R listCommunityAll() {
-        List<ComActDO> comActDOS = comActDAO.selectList(new QueryWrapper<ComActDO>().lambda().eq(ComActDO::getState, 0).orderByDesc(ComActDO::getCreateAt));
-        List<ComActVO> comActVOS=new ArrayList<>();
+        List<ComActDO> comActDOS = comActDAO.selectList(new QueryWrapper<ComActDO>().lambda().eq(ComActDO::getState, 0)
+                .eq(ComActDO::getCityCode, "510400")
+                .orderByDesc(ComActDO::getCreateAt));
+        List<ComActVO> comActVOS = new ArrayList<>();
         if (!ObjectUtils.isEmpty(comActDOS)) {
             comActDOS.forEach(comActDO -> {
-                ComActVO comActVO=new ComActVO();
-                BeanUtils.copyProperties(comActDO,comActVO);
+                ComActVO comActVO = new ComActVO();
+                BeanUtils.copyProperties(comActDO, comActVO);
                 comActVOS.add(comActVO);
             });
         }
         return R.ok(comActVOS);
     }
 
+    /**
+     * 删除社区
+     *
+     * @param communityId 社区id
+     * @return 删除结果
+     */
+    @Override
+    public R delectCommunity(Long communityId) {
+        int delete = comActDAO.deleteById(communityId);
+        if (delete > 0) {
+            return R.ok();
+        }
+        return R.fail();
+    }
 
+    /**
+     * 综治后台-查询社区列表
+     * @return  社区列表
+     */
+    @Override
+    public R getCommunityLists(){
+        return R.ok(this.comActDAO.getCommunityLists());
+    }
+
+    /**
+     * 查询社区所有列表
+     * @return  社区列表
+     */
+    @Override
+    public R getCommunityAllList(){
+        //查询街道列表
+        List<StreetAllAppletsVO> streetList = this.comActDAO.getStreetList();
+        streetList.forEach(street -> {
+            //查询街道下社区列表
+            List<CommunitySwitchAllAppletsVO> communityList = this.comActDAO.getCommunityListByStreetId(street.getStreetId());
+            if(!communityList.isEmpty()){
+                street.setChildList(communityList);
+                street.setCount(communityList.size());
+            }
+        });
+        streetList = streetList.stream().sorted(Comparator.comparing(StreetAllAppletsVO::getCount).reversed()).collect(Collectors.toList());
+        return R.ok(streetList);
+    }
+
+    /**
+     * 根据名字查询所有社区列表
+     * @param name  社区名字
+     * @return  社区列表
+     */
+    @Override
+    public R communitySwitchSearchList(String name){
+        return R.ok(this.comActDAO.getCommunityListByName(name));
+    }
+
+    /**
+     * 根据经纬度以及距离搜索附近社区列表
+     * @param communityDTO  请求参数
+     * @return  社区列表
+     */
+    @Override
+    public R communitySwitchSearchDistanceList(SearchCommunityDTO communityDTO){
+        return R.ok(this.comActDAO.getCommunityListByNearby(communityDTO));
+    }
 
 
 }

--
Gitblit v1.7.1