From 0db231806e34e8580c450276ea3e194e9f78ac13 Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期三, 07 四月 2021 22:52:21 +0800
Subject: [PATCH] 优化代码
---
service-store/src/main/java/com/java110/store/api/PurchaseApi.java | 93 ++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 92 insertions(+), 1 deletions(-)
diff --git a/service-store/src/main/java/com/java110/store/api/PurchaseApi.java b/service-store/src/main/java/com/java110/store/api/PurchaseApi.java
index 41de2c4..8279136 100644
--- a/service-store/src/main/java/com/java110/store/api/PurchaseApi.java
+++ b/service-store/src/main/java/com/java110/store/api/PurchaseApi.java
@@ -1,8 +1,99 @@
package com.java110.store.api;
-import org.springframework.web.bind.annotation.RestController;
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.factory.GenerateCodeFactory;
+import com.java110.dto.purchaseApply.PurchaseApplyDto;
+import com.java110.po.purchase.PurchaseApplyDetailPo;
+import com.java110.po.purchase.PurchaseApplyPo;
+import com.java110.store.bmo.purchase.IPurchaseApplyBMO;
+import com.java110.store.bmo.purchase.IResourceEnterBMO;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.BeanConvertUtil;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.ResponseEntity;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.ArrayList;
+import java.util.List;
@RestController
+@RequestMapping(value = "/purchase")
public class PurchaseApi {
+
+ @Autowired
+ private IPurchaseApplyBMO purchaseApplyBMOImpl;
+
+ @Autowired
+ private IResourceEnterBMO resourceEnterBMOImpl;
+
+ /**
+ * 閲囪喘鐢宠
+ * <p>
+ * {"resourceStores":[{"resId":"852020061636590016","resName":"姗$毊鎿�","resCode":"003","price":"100.00","stock":"0","description":"ada","quantity":"1"},
+ * {"resId":"852020061729120031","resName":"鏂囨。鏌�","resCode":"002","price":"33.00","stock":"0","description":"钃濊壊","quantity":"1"}],
+ * "description":"123123","endUserName":"1","endUserTel":"17797173942","file":"","resOrderType":"10000","staffId":"","staffName":""}
+ *
+ * @param reqJson
+ * @return
+ */
+ @RequestMapping(value = "/purchaseApply", method = RequestMethod.POST)
+ public ResponseEntity<String> purchaseApply(@RequestBody JSONObject reqJson,
+ @RequestHeader(value = "user-id") String userId,
+ @RequestHeader(value = "user-name") String userName,
+ @RequestHeader(value = "store-id") String storeId) {
+
+ Assert.hasKeyAndValue(reqJson, "resourceStores", "蹇呭~锛岃濉啓鐢宠閲囪喘鐨勭墿璧�");
+ Assert.hasKeyAndValue(reqJson, "description", "蹇呭~锛岃濉啓閲囪喘鐢宠璇存槑");
+ Assert.hasKeyAndValue(reqJson, "resOrderType", "蹇呭~锛岃濉啓鐢宠绫诲瀷");
+
+ PurchaseApplyPo purchaseApplyPo = new PurchaseApplyPo();
+ purchaseApplyPo.setApplyOrderId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_applyOrderId));
+ purchaseApplyPo.setDescription(reqJson.getString("description"));
+ purchaseApplyPo.setUserId(userId);
+ purchaseApplyPo.setUserName(userName);
+ purchaseApplyPo.setEndUserName(reqJson.getString("endUserName"));
+ purchaseApplyPo.setEndUserTel(reqJson.getString("endUserTel"));
+ purchaseApplyPo.setStoreId(storeId);
+ purchaseApplyPo.setResOrderType(PurchaseApplyDto.RES_ORDER_TYPE_ENTER);
+ purchaseApplyPo.setState(PurchaseApplyDto.STATE_DEALING);
+
+ JSONArray resourceStores = reqJson.getJSONArray("resourceStores");
+
+ List<PurchaseApplyDetailPo> purchaseApplyDetailPos = new ArrayList<>();
+
+ for (int resourceStoreIndex = 0; resourceStoreIndex < resourceStores.size(); resourceStoreIndex++) {
+ JSONObject resourceStore = resourceStores.getJSONObject(resourceStoreIndex);
+ PurchaseApplyDetailPo purchaseApplyDetailPo = BeanConvertUtil.covertBean(resourceStore, PurchaseApplyDetailPo.class);
+ purchaseApplyDetailPo.setId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_applyOrderId));
+ purchaseApplyDetailPos.add(purchaseApplyDetailPo);
+ }
+ purchaseApplyPo.setPurchaseApplyDetailPos(purchaseApplyDetailPos);
+
+ return purchaseApplyBMOImpl.apply(purchaseApplyPo);
+ }
+
+ @RequestMapping(value = "/resourceEnter", method = RequestMethod.POST)
+ public ResponseEntity<String> resourceEnter(@RequestBody JSONObject reqJson) {
+ Assert.hasKeyAndValue(reqJson, "applyOrderId", "璁㈠崟ID涓虹┖");
+
+ JSONArray purchaseApplyDetails = reqJson.getJSONArray("purchaseApplyDetailVo");
+
+ List<PurchaseApplyDetailPo> purchaseApplyDetailPos = new ArrayList<>();
+ for (int detailIndex = 0; detailIndex < purchaseApplyDetails.size(); detailIndex++) {
+ JSONObject purchaseApplyDetail = purchaseApplyDetails.getJSONObject(detailIndex);
+ Assert.hasKeyAndValue(purchaseApplyDetail, "purchaseQuantity", "閲囪喘鏁伴噺鏈~鍐�");
+ Assert.hasKeyAndValue(purchaseApplyDetail, "price", "閲囪喘鍗曚环鏈~鍐�");
+ Assert.hasKeyAndValue(purchaseApplyDetail, "id", "鏄庣粏ID涓虹┖");
+ PurchaseApplyDetailPo purchaseApplyDetailPo = BeanConvertUtil.covertBean(purchaseApplyDetail, PurchaseApplyDetailPo.class);
+ purchaseApplyDetailPos.add(purchaseApplyDetailPo);
+
+ }
+
+ PurchaseApplyPo purchaseApplyPo = new PurchaseApplyPo();
+ purchaseApplyPo.setApplyOrderId(reqJson.getString("applyOrderId"));
+ purchaseApplyPo.setPurchaseApplyDetailPos(purchaseApplyDetailPos);
+ return resourceEnterBMOImpl.enter(purchaseApplyPo);
+ }
}
--
Gitblit v1.8.0