From 4ee86eb0f4984bf3ede3196ad8c5fe95e8c5a504 Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期三, 15 六月 2022 19:05:02 +0800
Subject: [PATCH] 优化代码

---
 service-api/src/main/java/com/java110/api/smo/assetImport/impl/ImportOwnerRoomSMOImpl.java |   57 +++++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 39 insertions(+), 18 deletions(-)

diff --git a/service-api/src/main/java/com/java110/api/smo/assetImport/impl/ImportOwnerRoomSMOImpl.java b/service-api/src/main/java/com/java110/api/smo/assetImport/impl/ImportOwnerRoomSMOImpl.java
index 7a78124..10af640 100644
--- a/service-api/src/main/java/com/java110/api/smo/assetImport/impl/ImportOwnerRoomSMOImpl.java
+++ b/service-api/src/main/java/com/java110/api/smo/assetImport/impl/ImportOwnerRoomSMOImpl.java
@@ -4,6 +4,7 @@
 import com.java110.api.smo.assetImport.IImportOwnerRoomSMO;
 import com.java110.core.context.IPageData;
 import com.java110.core.log.LoggerFactory;
+import com.java110.dto.RoomDto;
 import com.java110.dto.owner.OwnerDto;
 import com.java110.entity.assetImport.ImportOwnerRoomDto;
 import com.java110.entity.component.ComponentValidateResult;
@@ -12,6 +13,7 @@
 import com.java110.utils.util.CommonUtil;
 import com.java110.utils.util.ImportExcelUtils;
 import com.java110.utils.util.StringUtil;
+import com.java110.vo.ResultVo;
 import org.apache.poi.ss.usermodel.Sheet;
 import org.apache.poi.ss.usermodel.Workbook;
 import org.slf4j.Logger;
@@ -93,9 +95,9 @@
                 throw new IllegalArgumentException((roomIndex + 1) + "琛屽崟鍏冧腑鍖呭惈鐗规畩绗﹀彿  -  #  锛� & 璇峰垹闄わ紒");
             }
 
-            if (!StringUtil.isNumber(importOwnerRoomDto.getLayer())) {
-                throw new IllegalArgumentException((roomIndex + 1) + "琛屾ゼ灞備笉鏄湁鏁堟暟瀛�");
-            }
+//            if (!StringUtil.isNumber(importOwnerRoomDto.getLayer())) {
+//                throw new IllegalArgumentException((roomIndex + 1) + "琛屾ゼ灞備笉鏄湁鏁堟暟瀛�");
+//            }
 
             if (!StringUtil.isNumber(importOwnerRoomDto.getLayerCount())) {
                 throw new IllegalArgumentException((roomIndex + 1) + "琛屾�绘ゼ灞備笉鏄湁鏁堟暟瀛�");
@@ -146,6 +148,15 @@
             if (!StringUtil.isNumber(importOwnerRoomDto.getOwnerTypeCd())) {
                 throw new IllegalArgumentException((roomIndex + 1) + "琛屼笟涓荤被鍨嬩笉鑳戒负绌�");
             }
+
+            if(RoomDto.STATE_FREE.equals(importOwnerRoomDto.getRoomState()) && !StringUtil.isEmpty(importOwnerRoomDto.getOwnerName())){
+                throw new IllegalArgumentException((roomIndex + 1) + "琛屾埧灞嬬姸鎬佷负鏈攢鍞姸鎬侊紝涓嶈兘鍖呭惈涓氫富淇℃伅");
+            }
+
+            if(!RoomDto.STATE_FREE.equals(importOwnerRoomDto.getRoomState()) && StringUtil.isEmpty(importOwnerRoomDto.getOwnerName())){
+                throw new IllegalArgumentException((roomIndex + 1) + "琛屾埧灞嬬姸鎬佷笉鏄湭閿�鍞姸鎬侊紝蹇呴』鍖呭惈涓氫富淇℃伅");
+            }
+
             // 濡傛灉鏄笟涓� 璺宠繃
             if (OwnerDto.OWNER_TYPE_CD_OWNER.equals(importOwnerRoomDto.getOwnerTypeCd())) {
                 continue;
@@ -201,17 +212,19 @@
             Assert.hasValue(os[8], (osIndex + 1) + "琛屽缓绛戦潰绉笉鑳戒负绌�");
             Assert.hasValue(os[9], (osIndex + 1) + "琛屽鍐呴潰绉笉鑳戒负绌�");
             Assert.hasValue(os[10], (osIndex + 1) + "琛岀閲戜笉鑳戒负绌�");
-            if (os.length > 11) {
-                Assert.hasValue(os[11], (osIndex + 1) + "琛屼笟涓诲悕绉颁笉鑳戒负绌�");
-                Assert.hasValue(os[12], (osIndex + 1) + "琛屾�у埆涓嶈兘涓虹┖");
-                Assert.hasValue(os[13], (osIndex + 1) + "琛屽勾榫勪笉鑳戒负绌�");
-                Assert.hasValue(os[14], (osIndex + 1) + "琛屾墜鏈哄彿涓嶈兘涓虹┖");
-                Assert.hasValue(os[15], (osIndex + 1) + "琛岃韩浠借瘉涓嶈兘涓虹┖");
-                Assert.hasValue(os[16], (osIndex + 1) + "琛屼笟涓荤被鍨嬩笉鑳戒负绌�");
+            Assert.hasValue(os[11], (osIndex + 1) + "琛屾埧灞嬬姸鎬佷笉鑳戒负绌�");
+            if (os.length > 12 && !StringUtil.isNullOrNone(os[12])) {
+                Assert.hasValue(os[12], (osIndex + 1) + "琛屼笟涓诲悕绉颁笉鑳戒负绌�");
+                Assert.hasValue(os[13], (osIndex + 1) + "琛屾�у埆涓嶈兘涓虹┖");
+                Assert.hasValue(os[14], (osIndex + 1) + "琛屽勾榫勪笉鑳戒负绌�");
+                Assert.hasValue(os[15], (osIndex + 1) + "琛屾墜鏈哄彿涓嶈兘涓虹┖");
+                Assert.hasValue(os[16], (osIndex + 1) + "琛岃韩浠借瘉涓嶈兘涓虹┖");
+                Assert.hasValue(os[17], (osIndex + 1) + "琛屼笟涓荤被鍨嬩笉鑳戒负绌�");
             }
 
             importOwnerRoomDto = new ImportOwnerRoomDto();
             importOwnerRoomDto.setCommunityId(result.getCommunityId());
+            importOwnerRoomDto.setUserId(result.getUserId());
             importOwnerRoomDto.setFloorNum(os[0].toString().trim());
             importOwnerRoomDto.setUnitNum(os[1].toString().trim());
             importOwnerRoomDto.setRoomNum(os[2].toString().trim());
@@ -224,15 +237,18 @@
             importOwnerRoomDto.setBuiltUpArea(os[8].toString().trim());
             importOwnerRoomDto.setRoomArea(os[9].toString().trim());
             importOwnerRoomDto.setRoomRent(os[10].toString().trim());
-            if (os.length > 11) {
-                importOwnerRoomDto.setOwnerName(os[11].toString().trim());
-                importOwnerRoomDto.setSex("鐢�".equals(os[12].toString().trim()) ? "0" : "1");
-                String age = StringUtil.isNullOrNone(os[13]) ? CommonUtil.getAgeByCertId(os[15].toString().trim()) : os[13].toString().trim();
+            importOwnerRoomDto.setRoomState(os[11].toString().trim());
+            if (os.length > 12 && !StringUtil.isNullOrNone(os[12])) {
+                importOwnerRoomDto.setOwnerName(os[12].toString().trim());
+                importOwnerRoomDto.setSex("鐢�".equals(os[13].toString().trim()) ? "0" : "1");
+                String age = StringUtil.isNullOrNone(os[14]) ? CommonUtil.getAgeByCertId(os[16].toString().trim()) : os[14].toString().trim();
                 importOwnerRoomDto.setAge(age);
-                importOwnerRoomDto.setTel(os[14].toString().trim());
-                importOwnerRoomDto.setIdCard(os[15].toString().trim());
-                importOwnerRoomDto.setOwnerTypeCd(os[16].toString().trim());
+                importOwnerRoomDto.setTel(os[15].toString().trim());
+                importOwnerRoomDto.setIdCard(os[16].toString().trim());
+                importOwnerRoomDto.setOwnerTypeCd(os[17].toString().trim());
             }
+
+
 
             ownerRoomDtos.add(importOwnerRoomDto);
 
@@ -248,6 +264,8 @@
 
         List<ImportOwnerRoomDto> tmpImportOwnerRoomDtos = new ArrayList<>();
         int flag = 0;
+
+        int successCount = 0;
         try {
             for (int roomIndex = 0; roomIndex < ownerRoomDtos.size(); roomIndex++) {
                 tmpImportOwnerRoomDtos.add(ownerRoomDtos.get(roomIndex));
@@ -257,6 +275,8 @@
                         throw new IllegalArgumentException("淇濆瓨澶辫触");
                     }
                     tmpImportOwnerRoomDtos = new ArrayList<>();
+
+                    successCount += flag;
                 }
             }
 
@@ -265,6 +285,7 @@
                 if (flag < 1) {
                     throw new IllegalArgumentException("淇濆瓨澶辫触");
                 }
+                successCount += flag;
             }
         } catch (Exception e) {
             logger.error("瀵煎叆澶辫触", e);
@@ -272,7 +293,7 @@
             throw e;
         }
 
-        return responseEntity;
+        return ResultVo.createResponseEntity("鎬诲叡瀵煎叆:" + ownerRoomDtos.size() + ";鎴愬姛瀵煎叆锛�" + successCount + ";瀵煎叆澶辫触锛�" + (ownerRoomDtos.size() - successCount));
     }
 
     //瑙f瀽Excel鏃ユ湡鏍煎紡

--
Gitblit v1.8.0