From 0b04f664887c73e90bf684a4e69c0fdbfe26349d Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期三, 29 三月 2023 13:35:20 +0800
Subject: [PATCH] Merge branch 'master' of http://git.homecommunity.cn/supervip/MicroCommunity

---
 service-community/src/main/java/com/java110/community/cmd/unit/DeleteUnitCmd.java |  116 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 116 insertions(+), 0 deletions(-)

diff --git a/service-community/src/main/java/com/java110/community/cmd/unit/DeleteUnitCmd.java b/service-community/src/main/java/com/java110/community/cmd/unit/DeleteUnitCmd.java
new file mode 100644
index 0000000..2000fc6
--- /dev/null
+++ b/service-community/src/main/java/com/java110/community/cmd/unit/DeleteUnitCmd.java
@@ -0,0 +1,116 @@
+package com.java110.community.cmd.unit;
+
+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.doc.annotation.*;
+import com.java110.dto.FloorDto;
+import com.java110.dto.RoomDto;
+import com.java110.dto.UnitDto;
+import com.java110.intf.community.IFloorInnerServiceSMO;
+import com.java110.intf.community.IRoomV1InnerServiceSMO;
+import com.java110.intf.community.IUnitInnerServiceSMO;
+import com.java110.intf.community.IUnitV1InnerServiceSMO;
+import com.java110.po.unit.UnitPo;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.BeanConvertUtil;
+import com.java110.vo.ResultVo;
+import org.springframework.beans.factory.annotation.Autowired;
+
+
+
+@Java110CmdDoc(title = "鍒犻櫎鍗曞厓",
+        description = "鐢ㄤ簬澶栫郴缁熷垹闄ゅ崟鍏冧俊鎭姛鑳�",
+        httpMethod = "post",
+        url = "http://{ip}:{port}/app/unit.deleteUnit",
+        resource = "communityDoc",
+        author = "鍚村鏂�",
+        serviceCode = "unit.deleteUnit",
+        seq = 11
+)
+
+@Java110ParamsDoc(params = {
+        @Java110ParamDoc(name = "communityId", length = 30, remark = "灏忓尯ID"),
+        @Java110ParamDoc(name = "unitId", length = 30, remark = "鍗曞厓ID"),
+})
+
+@Java110ResponseDoc(
+        params = {
+                @Java110ParamDoc(name = "code", type = "int", length = 11, defaultValue = "0", remark = "杩斿洖缂栧彿锛�0 鎴愬姛 鍏朵粬澶辫触"),
+                @Java110ParamDoc(name = "msg", type = "String", length = 250, defaultValue = "鎴愬姛", remark = "鎻忚堪"),
+        }
+)
+
+@Java110ExampleDoc(
+        reqBody="{\"unitId\":\"123123\",\"communityId\":\"2022081539020475\"}",
+        resBody="{'code':0,'msg':'鎴愬姛'}"
+)
+
+@Java110Cmd(serviceCode = "unit.deleteUnit")
+public class DeleteUnitCmd extends Cmd {
+    @Autowired
+    private IFloorInnerServiceSMO floorInnerServiceSMOImpl;
+
+    @Autowired
+    private IUnitInnerServiceSMO unitInnerServiceSMOImpl;
+
+    @Autowired
+    private IUnitV1InnerServiceSMO unitV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IRoomV1InnerServiceSMO roomV1InnerServiceSMOImpl;
+
+    @Override
+    public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
+        Assert.jsonObjectHaveKey(reqJson, "communityId", "璇锋眰鎶ユ枃涓湭鍖呭惈communityId鑺傜偣");
+        Assert.jsonObjectHaveKey(reqJson, "floorId", "璇锋眰鎶ユ枃涓湭鍖呭惈floorId鑺傜偣");
+        Assert.jsonObjectHaveKey(reqJson, "unitId", "璇锋眰鎶ユ枃涓湭鍖呭惈unitId鑺傜偣");
+
+        FloorDto floorDto = new FloorDto();
+        floorDto.setCommunityId(reqJson.getString("communityId"));
+        floorDto.setFloorId(reqJson.getString("floorId"));
+        //鏍¢獙灏忓尯妤糏D鍜屽皬鍖烘槸鍚︽湁瀵瑰簲鍏崇郴
+        int total = floorInnerServiceSMOImpl.queryFloorsCount(floorDto);
+
+        if (total < 1) {
+            throw new IllegalArgumentException("浼犲叆灏忓尯妤糏D涓嶆槸璇ュ皬鍖虹殑妤�");
+        }
+
+        //鏍¢獙 灏忓尯妤糏D 鍜屽崟鍏僆D鏄惁鏈夊叧绯�
+        UnitDto unitDto = new UnitDto();
+        unitDto.setFloorId(reqJson.getString("floorId"));
+        unitDto.setUnitId(reqJson.getString("unitId"));
+        total = unitInnerServiceSMOImpl.queryUnitsCount(unitDto);
+        if (total < 1) {
+            throw new IllegalArgumentException("浼犲叆鍗曞厓涓嶆槸璇ュ皬鍖虹殑妤肩殑鍗曞厓");
+        }
+
+        RoomDto roomDto = new RoomDto();
+        roomDto.setUnitId(reqJson.getString("unitId"));
+        roomDto.setCommunityId(reqJson.getString("communityId"));
+        int count = roomV1InnerServiceSMOImpl.queryRoomsCount(roomDto);
+        if(count > 0){
+            throw new IllegalArgumentException("鍗曞厓涓嬪瓨鍦ㄦ埧灞� 璇峰厛鍒犻櫎鎴垮眿");
+
+        }
+    }
+
+    @Override
+    @Java110Transactional
+    public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
+        JSONObject businessUnit = new JSONObject();
+        businessUnit.put("unitId", reqJson.getString("unitId"));
+        UnitPo unitPo = BeanConvertUtil.covertBean(businessUnit, UnitPo.class);
+        int flag = unitV1InnerServiceSMOImpl.deleteUnit(unitPo);
+
+        if (flag < 1) {
+            throw new CmdException("鍒犻櫎鍗曞厓澶辫触");
+        }
+
+        cmdDataFlowContext.setResponseEntity(ResultVo.success());
+    }
+}

--
Gitblit v1.8.0