From 65b30b7cac0a3fdcb8cec19c73411af0e2858766 Mon Sep 17 00:00:00 2001
From: 离歌笑 <137273278@qq.com>
Date: 星期二, 22 十月 2019 16:46:20 +0800
Subject: [PATCH] Merge branch 'tlhhup'

---
 WebService/src/main/java/com/java110/web/smo/impl/CarServiceSMOImpl.java |  145 +++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 119 insertions(+), 26 deletions(-)

diff --git a/WebService/src/main/java/com/java110/web/smo/impl/CarServiceSMOImpl.java b/WebService/src/main/java/com/java110/web/smo/impl/CarServiceSMOImpl.java
index 10b593c..ea17929 100644
--- a/WebService/src/main/java/com/java110/web/smo/impl/CarServiceSMOImpl.java
+++ b/WebService/src/main/java/com/java110/web/smo/impl/CarServiceSMOImpl.java
@@ -1,11 +1,12 @@
 package com.java110.web.smo.impl;
 
+import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
-import com.java110.common.constant.PrivilegeCodeConstant;
-import com.java110.common.constant.ResponseConstant;
-import com.java110.common.constant.ServiceConstant;
-import com.java110.common.exception.SMOException;
-import com.java110.common.util.Assert;
+import com.java110.utils.constant.PrivilegeCodeConstant;
+import com.java110.utils.constant.ResponseConstant;
+import com.java110.utils.constant.ServiceConstant;
+import com.java110.utils.exception.SMOException;
+import com.java110.utils.util.Assert;
 import com.java110.core.context.IPageData;
 import com.java110.web.core.BaseComponentSMO;
 import com.java110.web.smo.ICarServiceSMO;
@@ -90,6 +91,8 @@
         super.checkUserHasPrivilege(pd, restTemplate, PrivilegeCodeConstant.PRIVILEGE_CAR);
 
         JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
+
+        JSONArray infos = paramIn.getJSONArray("data");
         String communityId = paramIn.getString("communityId");
         ResponseEntity responseEntity = super.getStoreInfo(pd, restTemplate);
         if (responseEntity.getStatusCode() != HttpStatus.OK) {
@@ -102,9 +105,25 @@
         String storeTypeCd = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeTypeCd");
         //鏁版嵁鏍¢獙鏄惁 鍟嗘埛鏄惁鍏ラ┗璇ュ皬鍖�
         super.checkStoreEnterCommunity(pd, storeId, storeTypeCd, communityId, restTemplate);
-        paramIn.put("userId", pd.getUserId());
-        paramIn.put("storeId", storeId);
-        responseEntity = this.callCenterService(restTemplate, pd, paramIn.toJSONString(),
+
+        JSONObject viewSelectParkingSpace = this.getObj(infos, "viewSelectParkingSpace");
+        JSONObject viewOwnerInfo = this.getObj(infos, "viewOwnerInfo");
+        JSONObject addCar = this.getObj(infos, "addCar");
+        JSONObject parkingSpaceFee = null;
+        if(hasThisFlowComponent(infos, "hireParkingSpaceFee")) {
+            parkingSpaceFee = this.getObj(infos, "hireParkingSpaceFee");
+        }else{
+            parkingSpaceFee = this.getObj(infos, "sellParkingSpaceFee");
+        }
+        JSONObject newParamIn = new JSONObject();
+        newParamIn.putAll(addCar);
+        newParamIn.putAll(parkingSpaceFee);
+        newParamIn.put("communityId", communityId);
+        newParamIn.put("ownerId", viewOwnerInfo.getString("ownerId"));
+        newParamIn.put("psId", viewSelectParkingSpace.getString("psId"));
+        newParamIn.put("userId", pd.getUserId());
+        newParamIn.put("storeId", storeId);
+        responseEntity = this.callCenterService(restTemplate, pd, newParamIn.toJSONString(),
                 ServiceConstant.SERVICE_API_URL + "/api/parkingSpace.sellParkingSpace",
                 HttpMethod.POST);
 
@@ -182,6 +201,16 @@
         return responseEntity;
     }
 
+    @Override
+    public ResponseEntity<String> listCarType(IPageData pd) {
+        //鑾峰彇璇锋眰鍙傛暟
+        JSONObject reqParam = JSONObject.parseObject(pd.getReqData());
+        //鎷夊彇鏁版嵁
+        String url=ServiceConstant.SERVICE_API_URL.concat("/api/dict.type").concat(mapToUrlParam(reqParam));
+        ResponseEntity<String> responseEntity = this.callCenterService(restTemplate, pd, "",url , HttpMethod.GET);
+        return responseEntity;
+    }
+
     /**
      * 鍒犻櫎灏忓尯妤� 鏍¢獙
      *
@@ -221,29 +250,51 @@
     private void validateSaveCar(IPageData pd) {
 
         Assert.jsonObjectHaveKey(pd.getReqData(), "communityId", "鏈寘鍚皬鍖篒D");
-        Assert.jsonObjectHaveKey(pd.getReqData(), "ownerId", "璇锋眰鎶ユ枃涓湭鍖呭惈ownerId");
-        Assert.jsonObjectHaveKey(pd.getReqData(), "carNum", "璇锋眰鎶ユ枃涓湭鍖呭惈carNum");
-        Assert.jsonObjectHaveKey(pd.getReqData(), "carBrand", "璇锋眰鎶ユ枃涓湭鍖呭惈carBrand");
-        Assert.jsonObjectHaveKey(pd.getReqData(), "carType", "璇锋眰鎶ユ枃涓湭鍖呭惈carType");
-        Assert.jsonObjectHaveKey(pd.getReqData(), "carColor", "鏈寘鍚玞arColor");
-        Assert.jsonObjectHaveKey(pd.getReqData(), "psId", "鏈寘鍚玴sId");
-        Assert.jsonObjectHaveKey(pd.getReqData(), "receivedAmount", "鏈寘鍚玶eceivedAmount");
-        Assert.jsonObjectHaveKey(pd.getReqData(), "sellOrHire", "鏈寘鍚玸ellOrHire");
 
-        JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
-        Assert.hasLength(paramIn.getString("communityId"), "灏忓尯ID涓嶈兘涓虹┖");
-        Assert.hasLength(paramIn.getString("ownerId"), "ownerId涓嶈兘涓虹┖");
-        Assert.hasLength(paramIn.getString("psId"), "psId涓嶈兘涓虹┖");
-        Assert.hasLength(paramIn.getString("receivedAmount"), "receivedAmount涓嶈兘涓虹┖");
+        JSONObject info = JSONObject.parseObject(pd.getReqData());
 
-        if(!"H".equals(paramIn.getString("sellOrHire"))
-                && !"S".equals(paramIn.getString("sellOrHire"))){
+        JSONArray infos = info.getJSONArray("data");
+
+        if (infos.size() != 4) {
+            throw new IllegalArgumentException("鏁版嵁琚鏀�");
+        }
+
+        Assert.hasKeyByFlowData(infos, "viewSelectParkingSpace", "psId", "鏈寘鍚玴sId");
+        Assert.hasKeyByFlowData(infos, "viewOwnerInfo", "ownerId", "蹇呭~锛屾湭鍖呭惈涓氫富淇℃伅");
+        Assert.hasKeyByFlowData(infos, "addCar", "carNum", "璇锋眰鎶ユ枃涓湭鍖呭惈carNum");
+        Assert.hasKeyByFlowData(infos, "addCar", "carBrand", "璇锋眰鎶ユ枃涓湭鍖呭惈carBrand");
+        Assert.hasKeyByFlowData(infos, "addCar", "carType", "璇锋眰鎶ユ枃涓湭鍖呭惈carType");
+        Assert.hasKeyByFlowData(infos, "addCar", "carColor", "鏈寘鍚玞arColor");
+
+        JSONObject parkingSpaceFee = null;
+        if (hasThisFlowComponent(infos, "hireParkingSpaceFee")) {
+            Assert.hasKeyByFlowData(infos, "hireParkingSpaceFee", "receivedAmount", "鏈寘鍚玶eceivedAmount");
+            Assert.hasKeyByFlowData(infos, "hireParkingSpaceFee", "sellOrHire", "鏈寘鍚玸ellOrHire");
+             parkingSpaceFee = this.getObj(infos, "hireParkingSpaceFee");
+        }else{
+            Assert.hasKeyByFlowData(infos, "sellParkingSpaceFee", "receivedAmount", "鏈寘鍚玶eceivedAmount");
+            Assert.hasKeyByFlowData(infos, "sellParkingSpaceFee", "sellOrHire", "鏈寘鍚玸ellOrHire");
+            parkingSpaceFee = this.getObj(infos, "sellParkingSpaceFee");
+        }
+
+        JSONObject viewSelectParkingSpace = this.getObj(infos, "viewSelectParkingSpace");
+        JSONObject viewOwnerInfo = this.getObj(infos, "viewOwnerInfo");
+        JSONObject addCar = this.getObj(infos, "addCar");
+
+
+        Assert.hasLength(info.getString("communityId"), "灏忓尯ID涓嶈兘涓虹┖");
+        Assert.hasLength(viewOwnerInfo.getString("ownerId"), "ownerId涓嶈兘涓虹┖");
+        Assert.hasLength(viewSelectParkingSpace.getString("psId"), "psId涓嶈兘涓虹┖");
+        Assert.hasLength(parkingSpaceFee.getString("receivedAmount"), "receivedAmount涓嶈兘涓虹┖");
+
+        if (!"H".equals(parkingSpaceFee.getString("sellOrHire"))
+                && !"S".equals(parkingSpaceFee.getString("sellOrHire"))) {
             throw new IllegalArgumentException("鍏ュ弬閿欒锛屾棤娉曡瘑鍒鎿嶄綔");
         }
 
-        if("H".equals(paramIn.getString("sellOrHire"))){
-            Assert.jsonObjectHaveKey(pd.getReqData(), "cycles", "鏈寘鍚玞ycles");
-            Assert.hasLength(paramIn.getString("cycles"), "cycles涓嶈兘涓虹┖");
+        if ("H".equals(parkingSpaceFee.getString("sellOrHire"))) {
+            Assert.jsonObjectHaveKey(parkingSpaceFee, "cycles", "鏈寘鍚玞ycles");
+            Assert.hasLength(parkingSpaceFee.getString("cycles"), "cycles涓嶈兘涓虹┖");
         }
     }
 
@@ -269,6 +320,7 @@
         }
 
     }
+
     /**
      * 鏍¢獙鏌ヨ灏忓尯妤间俊鎭�
      *
@@ -283,6 +335,47 @@
     }
 
 
+    private JSONObject getObj(JSONArray infos, String flowComponent) {
+
+        JSONObject serviceInfo = null;
+
+        for (int infoIndex = 0; infoIndex < infos.size(); infoIndex++) {
+
+            Assert.hasKeyAndValue(infos.getJSONObject(infoIndex), "flowComponent", "鏈寘鍚湇鍔℃祦绋嬬粍浠跺悕绉�");
+
+            if (flowComponent.equals(infos.getJSONObject(infoIndex).getString("flowComponent"))) {
+                serviceInfo = infos.getJSONObject(infoIndex);
+                Assert.notNull(serviceInfo, "鏈寘鍚湇鍔′俊鎭�");
+                return serviceInfo;
+            }
+        }
+
+        throw new IllegalArgumentException("鏈壘鍒扮粍浠剁紪鐮佷负銆�" + flowComponent + "銆戞暟鎹�");
+    }
+
+    /**
+     * 鏄惁鏈� 杩欎釜缁勪欢
+     *
+     * @param infos                鎵�鏈夌粍浠朵俊鎭�
+     * @param currentFlowComponent 褰撳墠缁勪欢
+     * @return
+     */
+    private boolean hasThisFlowComponent(JSONArray infos, String currentFlowComponent) {
+        JSONObject serviceInfo = null;
+
+        for (int infoIndex = 0; infoIndex < infos.size(); infoIndex++) {
+            serviceInfo = infos.getJSONObject(infoIndex);
+
+            if (currentFlowComponent.equals(serviceInfo.getString("flowComponent"))) {
+                return true;
+            }
+
+        }
+
+        return false;
+    }
+
+
     public RestTemplate getRestTemplate() {
         return restTemplate;
     }

--
Gitblit v1.8.0