From e70053d772947e6e50cfa42f5a544a009699c4ac Mon Sep 17 00:00:00 2001
From: huanghongfa <huanghongfa123456>
Date: 星期三, 04 八月 2021 17:31:38 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/test' into test

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComSwRotaServiceImpl.java |   34 ++++++++++++++++++++++++++++------
 1 files changed, 28 insertions(+), 6 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComSwRotaServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComSwRotaServiceImpl.java
index 9c1afe2..7ca46d7 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComSwRotaServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComSwRotaServiceImpl.java
@@ -36,6 +36,8 @@
 import java.util.Date;
 import java.util.List;
 import java.util.Map;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
 
 /**
  * @auther txb
@@ -123,7 +125,9 @@
             return R.fail("该值班表不存在");
         }
         BeanUtils.copyProperties(comSwRotaDO,comSwRotaVO);
-        comSwRotaVO.setRotaDate(new SimpleDateFormat("yyyy-MM-dd").format(comSwRotaDO.getRotaDate()));
+        if (null != comSwRotaDO.getRotaDate()) {
+            comSwRotaVO.setRotaDate(new SimpleDateFormat("yyyy-MM-dd").format(comSwRotaDO.getRotaDate()));
+        }
         comSwRotaVO.setWeekDay(DateUtils.dateToWeek(comSwRotaVO.getRotaDate()));
         StringBuilder leaderNameString = new StringBuilder();
         StringBuilder leaderPhoneString = new StringBuilder();
@@ -282,23 +286,41 @@
                 }
                 ComSwRotaDO comSwRotaDO = new ComSwRotaDO();
                 String[] leaderPhones = comSwRotaExcelVO.getLeaderPhone().split("、");
+                String[] leaderNames = comSwRotaExcelVO.getLeaderName().split("、");
                 List<String> leaderIds = new ArrayList<>();
-                for (String leaderPhone : leaderPhones) {
-                    String id = comSwRotaDAO.getTeamIdsByTeamPhone(leaderPhone);
+                for (int i = 0; i < leaderPhones.length; i++) {
+                    String id = comSwRotaDAO.getTeamIdsByTeamPhone(leaderPhones[i]);
+                    if (StringUtils.isEmpty(id)) {
+                        return R.fail(leaderNames[i] + "为非社区团队人员或该人员电话未维护!");
+                    }
                     leaderIds.add(id);
                 }
 
                 String[] personPhones = comSwRotaExcelVO.getPersonPhone().split("、");
+                String[] personNames = comSwRotaExcelVO.getPersonName().split("、");
                 List<String> personIds = new ArrayList<>();
-                for (String personPhone : personPhones) {
-                    String id = comSwRotaDAO.getTeamIdsByTeamPhone(personPhone);
+                for (int i = 0; i < leaderPhones.length; i++) {
+                    String id = comSwRotaDAO.getTeamIdsByTeamPhone(personPhones[i]);
+                    if (StringUtils.isEmpty(id)) {
+                        return R.fail(personNames[i] + "为非社区团队人员或该人员电话未维护!");
+                    }
                     personIds.add(id);
                 }
                 BeanUtils.copyProperties(comSwRotaExcelVO, comSwRotaDO);
                 comSwRotaDO.setId(Snowflake.getId());
                 comSwRotaDO.setCommunityId(communityId);
+                if (StringUtils.isNotEmpty(comSwRotaExcelVO.getRotaDate())) {
+                    String el = "(([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29)   \n" +
+                            "(([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29) ";
+                    Pattern p = Pattern.compile(el);
+                    Matcher m = p.matcher(comSwRotaExcelVO.getRotaDate());
+                    if (!m.matches()) {
+                        return R.fail(comSwRotaExcelVO.getRotaDate() + "日期格式不正确");
+                    }
+                }
                 try {
-                comSwRotaDO.setRotaDate(new SimpleDateFormat("yyyy-MM-dd").parse(comSwRotaExcelVO.getRotaDate()));
+                    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
+                    comSwRotaDO.setRotaDate(sdf.parse(comSwRotaExcelVO.getRotaDate()));
                 } catch (ParseException e) {
                     e.printStackTrace();
                 }

--
Gitblit v1.7.1