|
@@ -15,22 +15,30 @@
|
|
|
*/
|
|
*/
|
|
|
package com.java110.store.cmd.purchaseApply;
|
|
package com.java110.store.cmd.purchaseApply;
|
|
|
|
|
|
|
|
|
|
+import com.alibaba.fastjson.JSONArray;
|
|
|
import com.alibaba.fastjson.JSONObject;
|
|
import com.alibaba.fastjson.JSONObject;
|
|
|
import com.java110.core.annotation.Java110Cmd;
|
|
import com.java110.core.annotation.Java110Cmd;
|
|
|
import com.java110.core.annotation.Java110Transactional;
|
|
import com.java110.core.annotation.Java110Transactional;
|
|
|
import com.java110.core.context.ICmdDataFlowContext;
|
|
import com.java110.core.context.ICmdDataFlowContext;
|
|
|
import com.java110.core.event.cmd.Cmd;
|
|
import com.java110.core.event.cmd.Cmd;
|
|
|
import com.java110.core.event.cmd.CmdEvent;
|
|
import com.java110.core.event.cmd.CmdEvent;
|
|
|
|
|
+import com.java110.core.factory.GenerateCodeFactory;
|
|
|
|
|
+import com.java110.intf.store.IPurchaseApplyDetailV1InnerServiceSMO;
|
|
|
import com.java110.intf.store.IPurchaseApplyV1InnerServiceSMO;
|
|
import com.java110.intf.store.IPurchaseApplyV1InnerServiceSMO;
|
|
|
|
|
+import com.java110.po.purchase.PurchaseApplyDetailPo;
|
|
|
import com.java110.po.purchase.PurchaseApplyPo;
|
|
import com.java110.po.purchase.PurchaseApplyPo;
|
|
|
import com.java110.utils.exception.CmdException;
|
|
import com.java110.utils.exception.CmdException;
|
|
|
import com.java110.utils.util.Assert;
|
|
import com.java110.utils.util.Assert;
|
|
|
import com.java110.utils.util.BeanConvertUtil;
|
|
import com.java110.utils.util.BeanConvertUtil;
|
|
|
|
|
+import com.java110.utils.util.StringUtil;
|
|
|
import com.java110.vo.ResultVo;
|
|
import com.java110.vo.ResultVo;
|
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.Logger;
|
|
|
import org.slf4j.LoggerFactory;
|
|
import org.slf4j.LoggerFactory;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
|
|
|
|
|
|
+import java.util.ArrayList;
|
|
|
|
|
+import java.util.List;
|
|
|
|
|
+
|
|
|
|
|
|
|
|
/**
|
|
/**
|
|
|
* 类表述:更新
|
|
* 类表述:更新
|
|
@@ -51,17 +59,30 @@ public class UpdatePurchaseApplyCmd extends Cmd {
|
|
|
@Autowired
|
|
@Autowired
|
|
|
private IPurchaseApplyV1InnerServiceSMO purchaseApplyV1InnerServiceSMOImpl;
|
|
private IPurchaseApplyV1InnerServiceSMO purchaseApplyV1InnerServiceSMOImpl;
|
|
|
|
|
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IPurchaseApplyDetailV1InnerServiceSMO purchaseApplyDetailV1InnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
@Override
|
|
@Override
|
|
|
public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
|
|
public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
|
|
|
Assert.hasKeyAndValue(reqJson, "applyOrderId", "订单号不能为空");
|
|
Assert.hasKeyAndValue(reqJson, "applyOrderId", "订单号不能为空");
|
|
|
- Assert.hasKeyAndValue(reqJson, "state", "必填,请填订单状态");
|
|
|
|
|
|
|
+ Assert.hasKeyAndValue(reqJson, "description", "必填,请填写采购申请说明");
|
|
|
|
|
+ Assert.hasKeyAndValue(reqJson, "endUserName", "必填,请填写采购联系人");
|
|
|
|
|
+ Assert.hasKeyAndValue(reqJson, "endUserTel", "必填,请填写采购联系电话");
|
|
|
|
|
+ Assert.hasKeyAndValue(reqJson, "communityId", "必填,请填写小区信息");
|
|
|
|
|
+ Assert.hasKey(reqJson, "resourceStores", "必填,请填写申请采购的物资");
|
|
|
|
|
|
|
|
|
|
+ JSONArray resourceStores = reqJson.getJSONArray("resourceStores");
|
|
|
|
|
+
|
|
|
|
|
+ if (resourceStores == null || resourceStores.size() < 1) {
|
|
|
|
|
+ throw new CmdException("未包含采购物品");
|
|
|
|
|
+ }
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
@Override
|
|
|
@Java110Transactional
|
|
@Java110Transactional
|
|
|
public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
|
|
public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
|
|
|
-
|
|
|
|
|
|
|
+ JSONArray resourceStores = reqJson.getJSONArray("resourceStores");
|
|
|
|
|
+ reqJson.remove("resourceStores");
|
|
|
PurchaseApplyPo purchaseApplyPo = BeanConvertUtil.covertBean(reqJson, PurchaseApplyPo.class);
|
|
PurchaseApplyPo purchaseApplyPo = BeanConvertUtil.covertBean(reqJson, PurchaseApplyPo.class);
|
|
|
int flag = purchaseApplyV1InnerServiceSMOImpl.updatePurchaseApply(purchaseApplyPo);
|
|
int flag = purchaseApplyV1InnerServiceSMOImpl.updatePurchaseApply(purchaseApplyPo);
|
|
|
|
|
|
|
@@ -69,6 +90,34 @@ public class UpdatePurchaseApplyCmd extends Cmd {
|
|
|
throw new CmdException("更新数据失败");
|
|
throw new CmdException("更新数据失败");
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+ //todo 删除
|
|
|
|
|
+ PurchaseApplyDetailPo purchaseApplyDetailPo = new PurchaseApplyDetailPo();
|
|
|
|
|
+ purchaseApplyDetailPo.setApplyOrderId(purchaseApplyPo.getApplyOrderId());
|
|
|
|
|
+ purchaseApplyDetailV1InnerServiceSMOImpl.deletePurchaseApplyDetail(purchaseApplyDetailPo);
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ for (int resourceStoreIndex = 0; resourceStoreIndex < resourceStores.size(); resourceStoreIndex++) {
|
|
|
|
|
+ JSONObject resourceStore = resourceStores.getJSONObject(resourceStoreIndex);
|
|
|
|
|
+ resourceStore.put("originalStock", resourceStore.getString("stock"));
|
|
|
|
|
+ JSONArray timeList = resourceStore.getJSONArray("times");
|
|
|
|
|
+ purchaseApplyDetailPo = BeanConvertUtil.covertBean(resourceStore, PurchaseApplyDetailPo.class);
|
|
|
|
|
+ purchaseApplyDetailPo.setPurchaseQuantity(resourceStore.getString("quantity"));
|
|
|
|
|
+ purchaseApplyDetailPo.setId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_applyOrderId));
|
|
|
|
|
+ purchaseApplyDetailPo.setApplyOrderId(purchaseApplyPo.getApplyOrderId());
|
|
|
|
|
+ //获取采购参考价格
|
|
|
|
|
+ String consultPrice = null;
|
|
|
|
|
+ if (resourceStore.containsKey("timesId") && !StringUtil.isEmpty(resourceStore.getString("timesId"))) {
|
|
|
|
|
+ for (int timesIndex = 0; timesIndex < timeList.size(); timesIndex++) {
|
|
|
|
|
+ JSONObject times = timeList.getJSONObject(timesIndex);
|
|
|
|
|
+ if (times.getString("timesId").equals(resourceStore.getString("timesId"))) {
|
|
|
|
|
+ consultPrice = times.getString("price");
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ purchaseApplyDetailPo.setConsultPrice(consultPrice);
|
|
|
|
|
+ purchaseApplyDetailV1InnerServiceSMOImpl.savePurchaseApplyDetail(purchaseApplyDetailPo);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
cmdDataFlowContext.setResponseEntity(ResultVo.success());
|
|
cmdDataFlowContext.setResponseEntity(ResultVo.success());
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|