From 2039385fa4b4ac688907134ee7c7025fb2aea1fb Mon Sep 17 00:00:00 2001
From: whywhyo <1511349576@qq.com>
Date: 星期日, 16 七月 2023 12:59:17 +0800
Subject: [PATCH] 666

---
 zhang-content/src/main/java/com/ruoyi/service/impl/ZfEconomyServiceImpl.java |  506 +++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 323 insertions(+), 183 deletions(-)

diff --git a/zhang-content/src/main/java/com/ruoyi/service/impl/ZfEconomyServiceImpl.java b/zhang-content/src/main/java/com/ruoyi/service/impl/ZfEconomyServiceImpl.java
index 3badb7a..66a01c0 100644
--- a/zhang-content/src/main/java/com/ruoyi/service/impl/ZfEconomyServiceImpl.java
+++ b/zhang-content/src/main/java/com/ruoyi/service/impl/ZfEconomyServiceImpl.java
@@ -14,6 +14,7 @@
 import com.ruoyi.domain.ZfEconomy;
 import com.ruoyi.domain.ZfEconomy;
 import com.ruoyi.mapper.ZfEconomyMapper;
+import com.ruoyi.service.ZAuthorityService;
 import com.ruoyi.service.ZInfoUserService;
 import com.ruoyi.service.ZfEconomyService;
 import com.ruoyi.util.ArraysUtil;
@@ -29,8 +30,7 @@
 import java.util.List;
 import java.util.stream.Collectors;
 
-import static com.ruoyi.constant.MenuAuthority.COLLECTION_LIST;
-import static com.ruoyi.constant.MenuAuthority.ECONOMY_LIST;
+import static com.ruoyi.constant.MenuAuthority.*;
 
 /**
  * <p>
@@ -49,8 +49,13 @@
     @Resource
     ZInfoUserService zInfoUserService;
 
-    private LambdaQueryWrapper<ZfEconomy> buildCondition(ZfEconomy zfEconomy) {
+    @Resource
+    ZAuthorityService zAuthorityService;
+
+    private LambdaQueryWrapper<ZfEconomy> buildCondition(ZfEconomy zfEconomy,List<Long> familyIdList) {
         LambdaQueryWrapper<ZfEconomy> lqw = new LambdaQueryWrapper<>();
+        lqw.orderByDesc(ZfEconomy::getCreateTime);
+        lqw.in(ZfEconomy::getFamilyId,familyIdList);
         lqw.like(StringUtils.isNotEmpty(zfEconomy.getType()),ZfEconomy::getType,zfEconomy.getType());
         lqw.like(StringUtils.isNotEmpty(zfEconomy.getKind()),ZfEconomy::getKind,zfEconomy.getKind());
         lqw.like(StringUtils.isNotEmpty(zfEconomy.getPrice()),ZfEconomy::getPrice,zfEconomy.getPrice());
@@ -72,139 +77,154 @@
         lqw.eq(StringUtils.isNotEmpty(zfEconomy.getUsePeople()),ZfEconomy::getUsePeople,zfEconomy.getUsePeople());
         lqw.eq(StringUtils.isNotEmpty(zfEconomy.getBalance()),ZfEconomy::getBalance,zfEconomy.getBalance());
         lqw.eq(StringUtils.isNotEmpty(zfEconomy.getRemark()),ZfEconomy::getRemark,zfEconomy.getRemark());
+        lqw.eq(zfEconomy.getFamilyId()!=null,ZfEconomy::getFamilyId,zfEconomy.getFamilyId());
         lqw.eq(zfEconomy.getHappenTime() != null, ZfEconomy::getHappenTime, zfEconomy.getHappenTime());
         return lqw;
     }
 
-    private LambdaQueryWrapper<ZfEconomy> buildCondition(ZfEconomy zfEconomy, String familyIds, String secondFamilyAuthority) {
-        //妯$硦鏌ヨ鐨勬潯浠�
-        LambdaQueryWrapper<ZfEconomy> lqw = buildCondition(zfEconomy);
-
-        //瀹氫箟涓�涓竷灏旀爣璁帮紝鏍囪绗竴瀹跺涵鍙锋槸鍚︽湁閫楀彿
-        boolean flag = false;
-
-        StringBuilder secondFamilyIdsBuffer = new StringBuilder();
-
-        //澶勭悊浼犲叆鐨剆econdFamilyAuthority   3{2007 2018 2015},4{2007 2019}
-
-        if (StringUtils.isNotEmpty(secondFamilyAuthority)) {
-
-            if (secondFamilyAuthority.contains(",")) {
-                //閫楀彿闅斿紑寰楀埌濡備笅涓诧細3{2007 2018 2015}
-                String[] authorityList = secondFamilyAuthority.split(",");
-                for (String authorityAndId : authorityList) {
-                    setSecondFamilyAuthority(secondFamilyIdsBuffer, authorityAndId);
-                }
-
-                //鎶婂悗闈㈢殑閫楀彿鍘绘帀
-                if (secondFamilyIdsBuffer.length() > 1) {
-                    secondFamilyIdsBuffer.deleteCharAt(secondFamilyIdsBuffer.length() - 1);
-                }
-
-            }else{
-                setSecondFamilyAuthority(secondFamilyIdsBuffer, secondFamilyAuthority);
-                //鎶婂悗闈㈢殑閫楀彿鍘绘帀
-                if (secondFamilyIdsBuffer.length() > 1) {
-                    secondFamilyIdsBuffer.deleteCharAt(secondFamilyIdsBuffer.length() - 1);
-                }
-            }
-        }
-        //灏哠tringBuffer杞垚String
-        String secondFamilyIds = secondFamilyIdsBuffer.toString();
-
-        //绗竴瀹跺涵鍙风殑鏉′欢
-        if (familyIds.contains(",")) {
-            flag = true;
-        }
-
-        //绗簩瀹跺涵鍙风殑鏉′欢
-        if (StringUtils.isNotEmpty(secondFamilyIds)) {
-            if (secondFamilyIds.contains(",")) {
-                String[] secondFamilyIdList = secondFamilyIds.split(",");
-                if (flag) {
-                    //濡傛灉绗竴瀹跺涵鍙峰拰绗簩瀹跺涵鍙烽兘鏈夐�楀彿
-                    String[] familyList = familyIds.split(",");
-                    String[] totalFamilyIdList = ArraysUtil.appendToArray(familyList, secondFamilyIdList);
-                    lqw.in(ZfEconomy::getFamilyId, totalFamilyIdList);
-                } else {
-                    //濡傛灉绗竴瀹跺涵鍙锋病鏈夐�楀彿浣嗘槸绗簩瀹跺涵鍙锋湁閫楀彿
-                    String[] totalFamilyIdList = ArraysUtil.appendToArray(secondFamilyIdList, familyIds);
-                    lqw.in(ZfEconomy::getFamilyId, totalFamilyIdList);
-                }
-
-            } else {
-                if (flag) {
-                    //濡傛灉绗竴瀹跺涵鍙锋湁閫楀彿浣嗙浜屽搴彿娌℃湁閫楀彿
-                    String[] familyList = familyIds.split(",");
-                    String[] totalFamilyIdList = ArraysUtil.appendToArray(familyList, secondFamilyIds);
-                    lqw.in(ZfEconomy::getFamilyId, totalFamilyIdList);
-                } else {
-                    //濡傛灉绗竴瀹跺涵鍙峰拰绗簩瀹跺涵鍙烽兘娌℃湁閫楀彿
-                    String[] totalFamilyIdList = ArraysUtil.appendToArray(familyIds, secondFamilyIds);
-                    lqw.in(ZfEconomy::getFamilyId, totalFamilyIdList);
-                }
-            }
-        } else {
-            //濡傛灉娌℃湁绗簩瀹跺涵鍙�
-            if (flag) {
-                String[] familyList = familyIds.split(",");
-                lqw.in(ZfEconomy::getFamilyId, familyList);
-            } else {
-                lqw.eq(ZfEconomy::getFamilyId, familyIds);
-            }
-
-        }
-
-        lqw.orderByDesc(ZfEconomy::getCreateTime);
-        return lqw;
-    }
-
-    private void setSecondFamilyAuthority(StringBuilder secondFamilyIdsBuffer, String authorityAndId) {
-        //寰楀埌鏉冮檺涓�
-        String authorities = authorityAndId.substring(2, authorityAndId.length() - 1);
-
-        if (authorities.contains(" ")) {
-            //绌烘牸闅斿紑寰楀埌鑿滃崟id锛岀湅鏄惁鏈夊搴旂殑鏉冮檺
-            String[] authorityIdList = authorities.split(" ");
-            for (String s : authorityIdList) {
-                if (s.equals(ECONOMY_LIST)) {
-                    secondFamilyIdsBuffer.append(authorityAndId.charAt(0)).append(",");
-                    break;
-                }
-            }
-        } else {
-            if (authorities.equals(ECONOMY_LIST)) {
-                secondFamilyIdsBuffer.append(authorityAndId.charAt(0)).append(",");
-            }
-        }
-    }
-
-    private ZInfoUser getMySelf() {
-        SysUser user = SecurityUtils.getLoginUser().getUser();
-        Long userId = user.getUserId();
-        LambdaQueryWrapper<ZInfoUser> zInfoUserLambdaQueryWrapper = new LambdaQueryWrapper<>();
-        zInfoUserLambdaQueryWrapper.eq(ZInfoUser::getUserId, userId);
-        return zInfoUserService.getOne(zInfoUserLambdaQueryWrapper);
-    }
-
-    private String listFamilyIds() {
-        ZInfoUser mySelf = getMySelf();
-        return mySelf.getFamilyId();
-    }
-
-    private String listSecondFamilyIds() {
-        ZInfoUser mySelf = getMySelf();
-        return mySelf.getSecondFamilyId();
-    }
+//    private LambdaQueryWrapper<ZfEconomy> buildCondition(ZfEconomy zfEconomy, String familyIds, String secondFamilyAuthority) {
+//        //妯$硦鏌ヨ鐨勬潯浠�
+//        LambdaQueryWrapper<ZfEconomy> lqw = buildCondition(zfEconomy);
+//
+//        //瀹氫箟涓�涓竷灏旀爣璁帮紝鏍囪绗竴瀹跺涵鍙锋槸鍚︽湁閫楀彿
+//        boolean flag = false;
+//
+//        StringBuilder secondFamilyIdsBuffer = new StringBuilder();
+//
+//        //澶勭悊浼犲叆鐨剆econdFamilyAuthority   3{2007 2018 2015},4{2007 2019}
+//
+//        if (StringUtils.isNotEmpty(secondFamilyAuthority)) {
+//
+//            if (secondFamilyAuthority.contains(",")) {
+//                //閫楀彿闅斿紑寰楀埌濡備笅涓诧細3{2007 2018 2015}
+//                String[] authorityList = secondFamilyAuthority.split(",");
+//                for (String authorityAndId : authorityList) {
+//                    setSecondFamilyAuthority(secondFamilyIdsBuffer, authorityAndId);
+//                }
+//
+//                //鎶婂悗闈㈢殑閫楀彿鍘绘帀
+//                if (secondFamilyIdsBuffer.length() > 1) {
+//                    secondFamilyIdsBuffer.deleteCharAt(secondFamilyIdsBuffer.length() - 1);
+//                }
+//
+//            }else{
+//                setSecondFamilyAuthority(secondFamilyIdsBuffer, secondFamilyAuthority);
+//                //鎶婂悗闈㈢殑閫楀彿鍘绘帀
+//                if (secondFamilyIdsBuffer.length() > 1) {
+//                    secondFamilyIdsBuffer.deleteCharAt(secondFamilyIdsBuffer.length() - 1);
+//                }
+//            }
+//        }
+//        //灏哠tringBuffer杞垚String
+//        String secondFamilyIds = secondFamilyIdsBuffer.toString();
+//
+//        //绗竴瀹跺涵鍙风殑鏉′欢
+//        if (familyIds.contains(",")) {
+//            flag = true;
+//        }
+//
+//        //绗簩瀹跺涵鍙风殑鏉′欢
+//        if (StringUtils.isNotEmpty(secondFamilyIds)) {
+//            if (secondFamilyIds.contains(",")) {
+//                String[] secondFamilyIdList = secondFamilyIds.split(",");
+//                if (flag) {
+//                    //濡傛灉绗竴瀹跺涵鍙峰拰绗簩瀹跺涵鍙烽兘鏈夐�楀彿
+//                    String[] familyList = familyIds.split(",");
+//                    String[] totalFamilyIdList = ArraysUtil.appendToArray(familyList, secondFamilyIdList);
+//                    lqw.in(ZfEconomy::getFamilyId, totalFamilyIdList);
+//                } else {
+//                    //濡傛灉绗竴瀹跺涵鍙锋病鏈夐�楀彿浣嗘槸绗簩瀹跺涵鍙锋湁閫楀彿
+//                    String[] totalFamilyIdList = ArraysUtil.appendToArray(secondFamilyIdList, familyIds);
+//                    lqw.in(ZfEconomy::getFamilyId, totalFamilyIdList);
+//                }
+//
+//            } else {
+//                if (flag) {
+//                    //濡傛灉绗竴瀹跺涵鍙锋湁閫楀彿浣嗙浜屽搴彿娌℃湁閫楀彿
+//                    String[] familyList = familyIds.split(",");
+//                    String[] totalFamilyIdList = ArraysUtil.appendToArray(familyList, secondFamilyIds);
+//                    lqw.in(ZfEconomy::getFamilyId, totalFamilyIdList);
+//                } else {
+//                    //濡傛灉绗竴瀹跺涵鍙峰拰绗簩瀹跺涵鍙烽兘娌℃湁閫楀彿
+//                    String[] totalFamilyIdList = ArraysUtil.appendToArray(familyIds, secondFamilyIds);
+//                    lqw.in(ZfEconomy::getFamilyId, totalFamilyIdList);
+//                }
+//            }
+//        } else {
+//            //濡傛灉娌℃湁绗簩瀹跺涵鍙�
+//            if (flag) {
+//                String[] familyList = familyIds.split(",");
+//                lqw.in(ZfEconomy::getFamilyId, familyList);
+//            } else {
+//                lqw.eq(ZfEconomy::getFamilyId, familyIds);
+//            }
+//
+//        }
+//
+//        lqw.orderByDesc(ZfEconomy::getCreateTime);
+//        return lqw;
+//    }
+//
+//    private void setSecondFamilyAuthority(StringBuilder secondFamilyIdsBuffer, String authorityAndId) {
+//        //寰楀埌鏉冮檺涓�
+//        String authorities = authorityAndId.substring(2, authorityAndId.length() - 1);
+//
+//        if (authorities.contains(" ")) {
+//            //绌烘牸闅斿紑寰楀埌鑿滃崟id锛岀湅鏄惁鏈夊搴旂殑鏉冮檺
+//            String[] authorityIdList = authorities.split(" ");
+//            for (String s : authorityIdList) {
+//                if (s.equals(ECONOMY_LIST)) {
+//                    secondFamilyIdsBuffer.append(authorityAndId.charAt(0)).append(",");
+//                    break;
+//                }
+//            }
+//        } else {
+//            if (authorities.equals(ECONOMY_LIST)) {
+//                secondFamilyIdsBuffer.append(authorityAndId.charAt(0)).append(",");
+//            }
+//        }
+//    }
+//
+//    private ZInfoUser getMySelf() {
+//        SysUser user = SecurityUtils.getLoginUser().getUser();
+//        Long userId = user.getUserId();
+//        LambdaQueryWrapper<ZInfoUser> zInfoUserLambdaQueryWrapper = new LambdaQueryWrapper<>();
+//        zInfoUserLambdaQueryWrapper.eq(ZInfoUser::getUserId, userId);
+//        return zInfoUserService.getOne(zInfoUserLambdaQueryWrapper);
+//    }
+//
+//    private String listFamilyIds() {
+//        ZInfoUser mySelf = getMySelf();
+//        return mySelf.getFamilyId();
+//    }
+//
+//    private String listSecondFamilyIds() {
+//        ZInfoUser mySelf = getMySelf();
+//        return mySelf.getSecondFamilyId();
+//    }
 
     @Override
     public List<ZfEconomy> selectByCondition(ZfEconomy zfEconomy) {
-        String familyIds = listFamilyIds();
-        String secondFamilyIds = listSecondFamilyIds();
-        LambdaQueryWrapper<ZfEconomy> lambdaQueryWrapper = buildCondition(zfEconomy, familyIds, secondFamilyIds);
+//        String familyIds = listFamilyIds();
+//        String secondFamilyIds = listSecondFamilyIds();
+//        LambdaQueryWrapper<ZfEconomy> lambdaQueryWrapper = buildCondition(zfEconomy, familyIds, secondFamilyIds);
+//        List<ZfEconomy> beanRecords = list(lambdaQueryWrapper);
+//        log.info("浠庢暟鎹簱涓煡鍒扮殑涓�:{}", beanRecords);
+//        return markOwnData(familyIds, beanRecords);
+
+        //瑕佹煡鑷繁瀹跺涵鐨�
+        ZInfoUser myself = zInfoUserService.getMyself();
+        Long familyId = myself.getFamilyId();
+        //涔熻鏌ュ埆浜烘巿鏉冪殑
+        List<ZAuthority> authority = zAuthorityService.getAuthority();
+        List<Long> idList = authority.stream().filter(auth -> auth.getAuthority().toString().equals(ECONOMY_LIST)).map(ZAuthority::getFid).collect(Collectors.toList());
+        //鍔犱笂鑷繁瀹跺涵鐨刬d
+        idList.add(familyId);
+
+        LambdaQueryWrapper<ZfEconomy> lambdaQueryWrapper = buildCondition(zfEconomy, idList);
         List<ZfEconomy> beanRecords = list(lambdaQueryWrapper);
         log.info("浠庢暟鎹簱涓煡鍒扮殑涓�:{}", beanRecords);
-        return markOwnData(familyIds, beanRecords);
+        return markOwnData(familyId, beanRecords);
     }
 
     @Override
@@ -217,76 +237,111 @@
         return list;
     }
 
-    private List<ZfEconomy> markOwnData(String familyIds, List<ZfEconomy> beanRecords) {
-        return beanRecords.stream().peek(record -> {
-            String recordFamilyId = record.getFamilyId();
-            if (familyIds.contains(",")) {
-                String[] familyIdList = familyIds.split(",");
-                for (String familyId : familyIdList) {
-                    if (familyId.equals(recordFamilyId)) {
-                        record.setOwnData(1);
-                    }
-                }
-            } else {
-                if (familyIds.equals(recordFamilyId)) {
-                    record.setOwnData(1);
-                }
-            }
-        }).collect(Collectors.toList());
-    }
+//    private List<ZfEconomy> markOwnData(String familyIds, List<ZfEconomy> beanRecords) {
+//        return beanRecords.stream().peek(record -> {
+//            String recordFamilyId = record.getFamilyId();
+//            if (familyIds.contains(",")) {
+//                String[] familyIdList = familyIds.split(",");
+//                for (String familyId : familyIdList) {
+//                    if (familyId.equals(recordFamilyId)) {
+//                        record.setOwnData(1);
+//                    }
+//                }
+//            } else {
+//                if (familyIds.equals(recordFamilyId)) {
+//                    record.setOwnData(1);
+//                }
+//            }
+//        }).collect(Collectors.toList());
+//    }
 
     @Override
     public AjaxResult selectDataList(ZfEconomy zfEconomy, Integer pageNum, Integer pageSize) {
-        String familyIds = listFamilyIds();
-        String secondFamilyAuthority = listSecondFamilyIds();
-        LambdaQueryWrapper<ZfEconomy> lqw = buildCondition(zfEconomy, familyIds, secondFamilyAuthority);
+//        String familyIds = listFamilyIds();
+//        String secondFamilyAuthority = listSecondFamilyIds();
+//        LambdaQueryWrapper<ZfEconomy> lqw = buildCondition(zfEconomy, familyIds, secondFamilyAuthority);
+//
+//        Page<ZfEconomy> zfEconomyPage = new Page<>(pageNum, pageSize);
+//        Page<ZfEconomy> pageResult = page(zfEconomyPage, lqw);
+//
+//        List<ZfEconomy> beanRecords = pageResult.getRecords();//寰楀埌鏌ヨ鍑烘潵鐨勬暟鎹�
+//
+//        List<ZfEconomy> dtoResult = markOwnData(familyIds, beanRecords);
+//
+//        HashMap<String, Object> data = MapUtils.getResult(pageResult, dtoResult);
+//        return AjaxResult.success(data);
+
+        //瑕佹煡鑷繁瀹跺涵鐨�
+        ZInfoUser myself = zInfoUserService.getMyself();
+        Long familyId = myself.getFamilyId();
+        //涔熻鏌ュ埆浜烘巿鏉冪殑
+        List<ZAuthority> authority = zAuthorityService.getAuthority();
+        List<Long> idList = authority.stream().filter(auth -> auth.getAuthority().toString().equals(ECONOMY_LIST)).map(ZAuthority::getFid).collect(Collectors.toList());
+        //鍔犱笂鑷繁瀹跺涵鐨刬d
+        idList.add(familyId);
+//        String familyIds = listFamilyIds();
+//        String secondFamilyAuthority = listSecondFamilyIds();
+        LambdaQueryWrapper<ZfEconomy> lqw = buildCondition(zfEconomy, idList);
+
 
         Page<ZfEconomy> zfEconomyPage = new Page<>(pageNum, pageSize);
         Page<ZfEconomy> pageResult = page(zfEconomyPage, lqw);
 
         List<ZfEconomy> beanRecords = pageResult.getRecords();//寰楀埌鏌ヨ鍑烘潵鐨勬暟鎹�
 
-        List<ZfEconomy> dtoResult = markOwnData(familyIds, beanRecords);
+        List<ZfEconomy> dtoResult = markOwnData(familyId, beanRecords);
 
         HashMap<String, Object> data = MapUtils.getResult(pageResult, dtoResult);
         return AjaxResult.success(data);
     }
 
-
-    @Override
-    public AjaxResult addData2(ZfEconomy zfEconomy){
-        ZInfoUser mySelf = getMySelf();
-        String myFamilyId = mySelf.getFamilyId();
-
-        if (StringUtils.isNotEmpty(zfEconomy.getFamilyId())){
-            throw new RuntimeException("瀵煎叆鏁版嵁鏃舵偍涓嶈兘鎸囧畾瀹跺涵鍙�");
-        }
-
-        if(StringUtils.isEmpty(myFamilyId)){
-            throw new RuntimeException("鎮ㄨ繕鏈姞鍏ヤ换浣曞搴�");
-        }
-
-        if (myFamilyId.contains(",")){
-            String[] myFamilyIds = myFamilyId.split(",");
-            //榛樿娣诲姞绗竴涓搴殑鏁版嵁
-            zfEconomy.setFamilyId(myFamilyIds[0]);
-        }else {
-            zfEconomy.setFamilyId(myFamilyId);
-        }
-
-        //鍒ゆ柇鏄惁鏈夐噸澶嶆暟鎹�
-        LambdaQueryWrapper<ZfEconomy> lqw = uniqueCondition(zfEconomy);
-        List<ZfEconomy> list = list(lqw);
-        if(list.size()>0){
-            throw new RuntimeException("璇峰嬁鏂板閲嶅鏁版嵁");
-        }
-
-        if (save(zfEconomy)) {
-            return AjaxResult.success();
-        }else {
-            return AjaxResult.error();
-        }
+    public List<ZfEconomy> markOwnData(Long familyId,List<ZfEconomy> beanRecords){
+        return beanRecords.stream().peek(
+                bean -> {
+                    if (bean.getFamilyId() == familyId) {
+                        bean.setOwnData(1);
+                    } else {
+                        bean.setOwnData(0);
+                    }
+                }
+        ).collect(Collectors.toList());
     }
+
+
+//    @Override
+//    public AjaxResult addData2(ZfEconomy zfEconomy){
+//        ZInfoUser mySelf = getMySelf();
+//        String myFamilyId = mySelf.getFamilyId();
+//
+//        if (StringUtils.isNotEmpty(zfEconomy.getFamilyId())){
+//            throw new RuntimeException("瀵煎叆鏁版嵁鏃舵偍涓嶈兘鎸囧畾瀹跺涵鍙�");
+//        }
+//
+//        if(StringUtils.isEmpty(myFamilyId)){
+//            throw new RuntimeException("鎮ㄨ繕鏈姞鍏ヤ换浣曞搴�");
+//        }
+//
+//        if (myFamilyId.contains(",")){
+//            String[] myFamilyIds = myFamilyId.split(",");
+//            //榛樿娣诲姞绗竴涓搴殑鏁版嵁
+//            zfEconomy.setFamilyId(myFamilyIds[0]);
+//        }else {
+//            zfEconomy.setFamilyId(myFamilyId);
+//        }
+//
+//        //鍒ゆ柇鏄惁鏈夐噸澶嶆暟鎹�
+//        LambdaQueryWrapper<ZfEconomy> lqw = uniqueCondition(zfEconomy);
+//        List<ZfEconomy> list = list(lqw);
+//        if(list.size()>0){
+//            throw new RuntimeException("璇峰嬁鏂板閲嶅鏁版嵁");
+//        }
+//
+//        if (save(zfEconomy)) {
+//            return AjaxResult.success();
+//        }else {
+//            return AjaxResult.error();
+//        }
+//    }
 
 
     @Override
@@ -302,12 +357,97 @@
         log.info("鍑嗗瑕佸鍏ョ殑鏁版嵁鍒楄〃涓猴細{}", dataList);
 
         for (ZfEconomy zfEconomy : dataList) {
-            zfEconomyService.addData2(zfEconomy);
+            zfEconomyService.addData(zfEconomy);
         }
 
         return AjaxResult.success("瀵煎叆鏁版嵁鎴愬姛");
 
     }
 
+    @Override
+    public AjaxResult addData(ZfEconomy zfEconomy) {
+        ZInfoUser myself = zInfoUserService.getMyself();
+        Long familyId = myself.getFamilyId();
+
+        if(familyId == null){
+            throw new RuntimeException("鎮ㄨ繕鏈姞鍏ヤ换浣曞搴�");
+        }
+
+        List<ZAuthority> authority = zAuthorityService.getAuthority();
+        List<Long> familyIdList = authority.stream().filter(auth -> auth.getAuthority().toString().equals(ECONOMY_LIST_ADD)).map(ZAuthority::getFid).collect(Collectors.toList());
+        familyIdList.add(familyId);
+
+        if (zfEconomy.getFamilyId()!=null && !familyIdList.contains(zfEconomy.getFamilyId())) {
+            throw new RuntimeException("浣犳病鏈夋潈闄愭搷浣滄瀹跺涵鐨勬暟鎹�");
+        }
+
+
+        if(zfEconomy.getFamilyId() == null){
+            //榛樿娣诲姞鑷繁瀹跺涵鐨勬暟鎹�
+            zfEconomy.setFamilyId(familyId);
+        }
+
+        //鍒ゆ柇鏄惁鏈夐噸澶嶆暟鎹�
+        LambdaQueryWrapper<ZfEconomy> lqw = uniqueCondition(zfEconomy);
+        List<ZfEconomy> list = list(lqw);
+
+        if(list.size()>0){
+            throw new RuntimeException("璇峰嬁鏂板閲嶅鏁版嵁");
+        }
+
+        if (save(zfEconomy)) {
+            return AjaxResult.success();
+        } else {
+            return AjaxResult.error();
+        }
+    }
+
+    @Override
+    public AjaxResult updateData(ZfEconomy zfEconomy) {
+        ZInfoUser myself = zInfoUserService.getMyself();
+        Long familyId = myself.getFamilyId();
+
+        //鍏堟牴鎹甶d鏌ヨ鍑烘暟鎹殑familyId锛岀湅鐪嬫湁娌℃湁鏉冮檺鎿嶄綔
+        Long dataFamilyId = getById(zfEconomy.getId()).getFamilyId();
+
+        List<ZAuthority> authority = zAuthorityService.getAuthority();
+        List<Long> familyIdList = authority.stream().filter(auth -> auth.getAuthority().toString().equals(ECONOMY_LIST_UPDATE)).map(ZAuthority::getFid).collect(Collectors.toList());
+        familyIdList.add(familyId);
+
+        if (dataFamilyId!=null && !familyIdList.contains(dataFamilyId)) {
+            throw new RuntimeException("浣犳病鏈夋潈闄愭搷浣滄瀹跺涵鐨勬暟鎹�");
+        }
+
+        if(updateById(zfEconomy)){
+            return AjaxResult.success();
+        }else {
+            return AjaxResult.error();
+        }
+    }
+
+    @Override
+    public AjaxResult deleteData(Long[] ids) {
+        List<ZfEconomy> dataList = zfEconomyService.listByIds(Arrays.asList(ids));
+
+        ZInfoUser myself = zInfoUserService.getMyself();
+        Long familyId = myself.getFamilyId();
+
+        List<ZAuthority> authority = zAuthorityService.getAuthority();
+        List<Long> familyIdList = authority.stream().filter(auth -> auth.getAuthority().toString().equals(ECONOMY_LIST_REMOVE)).map(ZAuthority::getFid).collect(Collectors.toList());
+        familyIdList.add(familyId);
+
+        for (ZfEconomy data : dataList) {
+            if (!familyIdList.contains(data.getFamilyId())){
+                throw new RuntimeException("浣犳病鏈夋潈闄愭搷浣滄瀹跺涵鐨勬暟鎹�");
+            }
+        }
+
+        if (zfEconomyService.removeByIds(Arrays.asList(ids))) {
+            return AjaxResult.success();
+        }else {
+            return AjaxResult.error();
+        }
+    }
+
 
 }

--
Gitblit v1.9.1