From 9fa63e316511ca3b116fe86776c04b3b2ac13f97 Mon Sep 17 00:00:00 2001
From: wuxw <928255095@qq.com>
Date: 星期一, 07 十一月 2022 02:27:52 +0800
Subject: [PATCH] 优化 保养计划
---
service-community/src/main/java/com/java110/community/cmd/room/UpdateRoomCmd.java | 186 ++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 186 insertions(+), 0 deletions(-)
diff --git a/service-community/src/main/java/com/java110/community/cmd/room/UpdateRoomCmd.java b/service-community/src/main/java/com/java110/community/cmd/room/UpdateRoomCmd.java
new file mode 100644
index 0000000..1b3495e
--- /dev/null
+++ b/service-community/src/main/java/com/java110/community/cmd/room/UpdateRoomCmd.java
@@ -0,0 +1,186 @@
+package com.java110.community.cmd.room;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.annotation.Java110Transactional;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
+import com.java110.core.factory.GenerateCodeFactory;
+import com.java110.dto.UnitDto;
+import com.java110.dto.owner.OwnerRoomRelDto;
+import com.java110.intf.community.*;
+import com.java110.intf.user.IOwnerRoomRelInnerServiceSMO;
+import com.java110.po.owner.OwnerRoomRelPo;
+import com.java110.po.room.RoomAttrPo;
+import com.java110.po.room.RoomPo;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.BeanConvertUtil;
+import com.java110.utils.util.DateUtil;
+import com.java110.utils.util.StringUtil;
+import org.springframework.beans.factory.annotation.Autowired;
+
+import java.util.Date;
+import java.util.List;
+
+@Java110Cmd(serviceCode = "room.updateRoom")
+public class UpdateRoomCmd extends Cmd {
+
+ @Autowired
+ private IUnitV1InnerServiceSMO unitV1InnerServiceSMOImpl;
+ @Autowired
+ private IUnitInnerServiceSMO unitInnerServiceSMOImpl;
+ @Autowired
+ private IFloorV1InnerServiceSMO floorV1InnerServiceSMOImpl;
+
+
+ @Autowired
+ private IRoomV1InnerServiceSMO roomV1InnerServiceSMOImpl;
+
+ @Autowired
+ private IRoomAttrV1InnerServiceSMO roomAttrV1InnerServiceSMOImpl;
+
+ @Autowired
+ private IOwnerRoomRelInnerServiceSMO ownerRoomRelInnerServiceSMOImpl;
+
+ @Override
+ public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
+ Assert.jsonObjectHaveKey(reqJson, "roomId", "璇锋眰鎶ユ枃涓湭鍖呭惈roomId鑺傜偣");
+ Assert.jsonObjectHaveKey(reqJson, "communityId", "璇锋眰鎶ユ枃涓湭鍖呭惈communityId鑺傜偣");
+ Assert.jsonObjectHaveKey(reqJson, "roomNum", "璇锋眰鎶ユ枃涓湭鍖呭惈roomNum鑺傜偣");
+ Assert.jsonObjectHaveKey(reqJson, "layer", "璇锋眰鎶ユ枃涓湭鍖呭惈layer鑺傜偣");
+ /*Assert.jsonObjectHaveKey(paramIn, "section", "璇锋眰鎶ユ枃涓湭鍖呭惈section鑺傜偣");*/
+ Assert.jsonObjectHaveKey(reqJson, "builtUpArea", "璇锋眰鎶ユ枃涓湭鍖呭惈builtUpArea鑺傜偣");
+
+ if (reqJson.containsKey("builtUpArea")) {
+ Assert.isMoney(reqJson.getString("builtUpArea"), "寤虹瓚闈㈢Н鏁版嵁鏍煎紡閿欒");
+ }
+ if (reqJson.containsKey("feeCoefficient")) {
+ Assert.isMoney(reqJson.getString("feeCoefficient"), "绠楄垂绯绘暟鏁版嵁鏍煎紡閿欒");
+ }
+
+ //鑾峰彇鎴垮眿鐘舵��
+ String state = reqJson.getString("state");
+ if (!StringUtil.isEmpty(state) && state.equals("2006")) { //宸插嚭绉�
+ //鑾峰彇璧风鏃堕棿
+ Date startTime = null;
+ Date endTime = null;
+
+ try {
+ startTime = DateUtil.getDateFromString(reqJson.getString("startTime"), DateUtil.DATE_FORMATE_STRING_B);
+ endTime = DateUtil.getDateFromString(reqJson.getString("endTime"), DateUtil.DATE_FORMATE_STRING_B);
+
+ } catch (Exception e) {
+ throw new CmdException(e.getMessage());
+ }
+ //鑾峰彇鎴鏃堕棿
+
+
+ if (startTime.getTime() > endTime.getTime()) {
+ throw new IllegalArgumentException("璧风鏃堕棿涓嶈兘澶т簬鎴鏃堕棿锛�");
+ }
+ }
+
+ UnitDto unitDto = new UnitDto();
+ unitDto.setCommunityId(reqJson.getString("communityId"));
+ unitDto.setUnitId(reqJson.getString("unitId"));
+ //鏍¢獙灏忓尯妤糏D鍜屽皬鍖烘槸鍚︽湁瀵瑰簲鍏崇郴
+ List<UnitDto> units = unitInnerServiceSMOImpl.queryUnitsByCommunityId(unitDto);
+
+ if (units == null || units.size() < 1) {
+ throw new IllegalArgumentException("浼犲叆鍗曞厓ID涓嶆槸璇ュ皬鍖虹殑鍗曞厓");
+ }
+
+ Assert.judgeAttrValue(reqJson);
+ }
+
+ @Override
+ @Java110Transactional
+ public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
+ updateShellRoom(reqJson, cmdDataFlowContext);
+ String state = reqJson.getString("state");
+ if (!StringUtil.isEmpty(state) && state.equals("2006")) { //宸插嚭绉�
+ OwnerRoomRelDto ownerRoomRelDto = new OwnerRoomRelDto();
+ ownerRoomRelDto.setRoomId(reqJson.getString("roomId"));
+ List<OwnerRoomRelDto> ownerRoomRelDtoList = ownerRoomRelInnerServiceSMOImpl.queryOwnerRoomRels(ownerRoomRelDto);
+ OwnerRoomRelPo ownerRoomRelPo = BeanConvertUtil.covertBean(ownerRoomRelDtoList.get(0), OwnerRoomRelPo.class);
+ ownerRoomRelPo.setStartTime(reqJson.getString("startTime"));
+ ownerRoomRelPo.setEndTime(reqJson.getString("endTime") + " 23:59:59");
+ ownerRoomRelInnerServiceSMOImpl.updateOwnerRoomRels(ownerRoomRelPo);
+ }
+
+ if (!reqJson.containsKey("attrs")) {
+ return;
+ }
+
+ JSONArray attrs = reqJson.getJSONArray("attrs");
+ if (attrs.size() < 1) {
+ return;
+ }
+
+
+ JSONObject attr = null;
+ int flag = 0;
+ for (int attrIndex = 0; attrIndex < attrs.size(); attrIndex++) {
+ attr = attrs.getJSONObject(attrIndex);
+ attr.put("roomId", reqJson.getString("roomId"));
+ if (!attr.containsKey("attrId") || attr.getString("attrId").startsWith("-") || StringUtil.isEmpty(attr.getString("attrId"))) {
+ RoomAttrPo roomAttrPo = new RoomAttrPo();
+ roomAttrPo.setAttrId(GenerateCodeFactory.getAttrId());
+ roomAttrPo.setRoomId(attr.getString("roomId"));
+ roomAttrPo.setSpecCd(attr.getString("specCd"));
+ roomAttrPo.setValue(attr.getString("value"));
+ flag = roomAttrV1InnerServiceSMOImpl.saveRoomAttr(roomAttrPo);
+ if (flag < 1) {
+ throw new CmdException("淇濆瓨鍗曞厓澶辫触");
+ }
+ continue;
+ }
+ RoomAttrPo roomAttrPo = new RoomAttrPo();
+ roomAttrPo.setAttrId(attr.getString("attrId"));
+ roomAttrPo.setRoomId(attr.getString("roomId"));
+ roomAttrPo.setSpecCd(attr.getString("specCd"));
+ roomAttrPo.setValue(attr.getString("value"));
+ flag = roomAttrV1InnerServiceSMOImpl.updateRoomAttr(roomAttrPo);
+ if (flag < 1) {
+ throw new CmdException("淇濆瓨鍗曞厓澶辫触");
+ }
+ }
+ }
+
+ /**
+ * 娣诲姞灏忓尯妤间俊鎭�
+ *
+ * @param paramInJson 鎺ュ彛璋冪敤鏀句紶鍏ュ叆鍙�
+ * @param cmdDataFlowContext 鏁版嵁涓婁笅鏂�
+ * @return 璁㈠崟鏈嶅姟鑳藉鎺ュ彈鐨勬姤鏂�
+ */
+ public void updateShellRoom(JSONObject paramInJson, ICmdDataFlowContext cmdDataFlowContext) {
+ JSONObject businessUnit = new JSONObject();
+ businessUnit.putAll(paramInJson);
+ RoomPo roomPo = BeanConvertUtil.covertBean(businessUnit, RoomPo.class);
+ if (paramInJson.containsKey("apartment1") && paramInJson.getString("apartment1").equals("10")) {
+ roomPo.setSection("1");
+ } else if (paramInJson.containsKey("apartment1") && paramInJson.getString("apartment1").equals("20")) {
+ roomPo.setSection("2");
+ } else if (paramInJson.containsKey("apartment1") && paramInJson.getString("apartment1").equals("30")) {
+ roomPo.setSection("3");
+ } else if (paramInJson.containsKey("apartment1") && paramInJson.getString("apartment1").equals("40")) {
+ roomPo.setSection("4");
+ } else if (paramInJson.containsKey("apartment1") && paramInJson.getString("apartment1").equals("50")) {
+ roomPo.setSection("5");
+ } else if (paramInJson.containsKey("apartment1") && paramInJson.getString("apartment1").equals("60")) {
+ roomPo.setSection("6");
+ } else if (paramInJson.containsKey("apartment1") && paramInJson.getString("apartment1").equals("70")) {
+ roomPo.setSection("7");
+ } else if (paramInJson.containsKey("apartment1") && paramInJson.getString("apartment1").equals("80")) {
+ roomPo.setSection("8");
+ }
+ int flag = roomV1InnerServiceSMOImpl.updateRoom(roomPo);
+ if (flag < 1) {
+ throw new CmdException("淇敼鎴垮眿澶辫触");
+ }
+ }
+}
--
Gitblit v1.8.0