From 5f83dbf4942e7f2e67963ae4ece013c22f091b72 Mon Sep 17 00:00:00 2001
From: Your Name <you@example.com>
Date: 星期五, 25 八月 2023 09:18:26 +0800
Subject: [PATCH] 优化物品

---
 service-community/src/main/java/com/java110/community/cmd/floor/DeleteFloorCmd.java |   78 +++++++++++++++++++++++++++++++++++++++
 1 files changed, 78 insertions(+), 0 deletions(-)

diff --git a/service-community/src/main/java/com/java110/community/cmd/floor/DeleteFloorCmd.java b/service-community/src/main/java/com/java110/community/cmd/floor/DeleteFloorCmd.java
index 42d1877..da5b6d7 100644
--- a/service-community/src/main/java/com/java110/community/cmd/floor/DeleteFloorCmd.java
+++ b/service-community/src/main/java/com/java110/community/cmd/floor/DeleteFloorCmd.java
@@ -6,14 +6,50 @@
 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.room.RoomDto;
+import com.java110.dto.unit.UnitDto;
 import com.java110.intf.community.IFloorInnerServiceSMO;
 import com.java110.intf.community.IFloorV1InnerServiceSMO;
+import com.java110.intf.community.IRoomV1InnerServiceSMO;
+import com.java110.intf.community.IUnitV1InnerServiceSMO;
 import com.java110.po.floor.FloorPo;
+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;
+
+import java.util.List;
+
+
+@Java110CmdDoc(title = "鍒犻櫎妤兼爧",
+        description = "鐢ㄤ簬澶栫郴缁熷垹闄ゆゼ鏍嬩俊鎭姛鑳�",
+        httpMethod = "post",
+        url = "http://{ip}:{port}/app/floor.deleteFloor",
+        resource = "communityDoc",
+        author = "鍚村鏂�",
+        serviceCode = "floor.deleteFloor",
+        seq = 7
+)
+
+@Java110ParamsDoc(params = {
+        @Java110ParamDoc(name = "communityId", length = 30, remark = "灏忓尯ID"),
+        @Java110ParamDoc(name = "floorId", 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 = "{\"floorId\":\"123123\",\"communityId\":\"2022081539020475\"}",
+        resBody = "{'code':0,'msg':'鎴愬姛'}"
+)
 
 @Java110Cmd(serviceCode = "floor.deleteFloor")
 public class DeleteFloorCmd extends Cmd {
@@ -23,10 +59,34 @@
     @Autowired
     private IFloorV1InnerServiceSMO floorV1InnerServiceSMOImpl;
 
+    @Autowired
+    private IUnitV1InnerServiceSMO unitV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IRoomV1InnerServiceSMO roomV1InnerServiceSMOImpl;
+
     @Override
     public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
         Assert.jsonObjectHaveKey(reqJson, "floorId", "璇锋眰鎶ユ枃涓湭鍖呭惈floorId");
         Assert.jsonObjectHaveKey(reqJson, "communityId", "璇锋眰鎶ユ枃涓湭鍖呭惈communityId");
+
+//        UnitDto unitDto = new UnitDto();
+//        unitDto.setFloorId(reqJson.getString("floorId"));
+//        unitDto.setCommunityId(reqJson.getString("communityId"));
+////        unitDto.setRoomUnit(UnitDto.ROOM_UNIT_Y);
+//        int count = unitV1InnerServiceSMOImpl.queryUnitsCount(unitDto);
+//        if (count > 0) {
+//            throw new IllegalArgumentException("璇峰厛鍒犻櫎鍗曞厓 鍐嶅垹闄ゆゼ鏍�");
+//        }
+
+        //todo 鏍¢獙 妤兼爧涓嬫槸鍚︽湁 鎴垮眿鎴栬�呭晢閾�
+        RoomDto roomDto = new RoomDto();
+        roomDto.setFloorId(reqJson.getString("floorId"));
+        roomDto.setCommunityId(reqJson.getString("communityId"));
+        int count = roomV1InnerServiceSMOImpl.queryRoomsCount(roomDto);
+        if (count > 0) {
+            throw new IllegalArgumentException("璇峰厛鍒犻櫎妤兼爧涓嬬殑鎴垮眿鎴栬�呭晢閾�");
+        }
     }
 
     @Override
@@ -39,6 +99,24 @@
             throw new CmdException("鍒犻櫎妤兼爧澶辫触");
         }
 
+        //todo 鍒犻櫎妤兼爧涓嬬殑鍗曞厓
+        UnitDto unitDto = new UnitDto();
+        unitDto.setFloorId(reqJson.getString("floorId"));
+        unitDto.setCommunityId(reqJson.getString("communityId"));
+        List<UnitDto> unitDtos = unitV1InnerServiceSMOImpl.queryUnits(unitDto);
+
+        if (unitDtos == null || unitDtos.size() < 1) {
+            return;
+        }
+
+        UnitPo unitPo = null;
+        for (UnitDto tmpUnitDto : unitDtos) {
+            unitPo = new UnitPo();
+            unitPo.setUnitId(tmpUnitDto.getUnitId());
+            unitV1InnerServiceSMOImpl.deleteUnit(unitPo);
+        }
+
+
         cmdDataFlowContext.setResponseEntity(ResultVo.success());
     }
 }

--
Gitblit v1.8.0