瀏覽代碼

优化商城组织架构 bug

wuxw 3 年之前
父節點
當前提交
30a40cb3d4
共有 1 個文件被更改,包括 136 次插入0 次删除
  1. 136 0
      service-store/src/main/java/com/java110/store/cmd/shop/ListMyEnteredShopsCmd.java

+ 136 - 0
service-store/src/main/java/com/java110/store/cmd/shop/ListMyEnteredShopsCmd.java

@@ -0,0 +1,136 @@
+package com.java110.store.cmd.shop;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
+import com.java110.dto.community.CommunityDto;
+import com.java110.dto.roleCommunity.RoleCommunityDto;
+import com.java110.dto.shop.ShopDto;
+import com.java110.dto.store.StoreDto;
+import com.java110.dto.user.UserDto;
+import com.java110.intf.community.ICommunityInnerServiceSMO;
+import com.java110.intf.mall.IShopInnerServiceSMO;
+import com.java110.intf.store.IStoreV1InnerServiceSMO;
+import com.java110.intf.user.IOrgInnerServiceSMO;
+import com.java110.intf.user.IOrgStaffRelInnerServiceSMO;
+import com.java110.intf.user.IRoleCommunityV1InnerServiceSMO;
+import com.java110.intf.user.IUserV1InnerServiceSMO;
+import com.java110.utils.constant.StateConstant;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.BeanConvertUtil;
+import com.java110.utils.util.StringUtil;
+import com.java110.vo.ResultVo;
+import com.java110.vo.api.community.ApiCommunityDataVo;
+import com.java110.vo.api.community.ApiCommunityVo;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.HttpStatus;
+import org.springframework.http.ResponseEntity;
+
+import java.util.ArrayList;
+import java.util.List;
+
+@Java110Cmd(serviceCode = "shop.listMyEnteredShops")
+public class ListMyEnteredShopsCmd extends Cmd {
+
+    @Autowired
+    private IShopInnerServiceSMO shopInnerServiceSMOImpl;
+
+    @Autowired
+    private IOrgStaffRelInnerServiceSMO orgStaffRelInnerServiceSMOImpl;
+
+    @Autowired
+    private IRoleCommunityV1InnerServiceSMO roleCommunityV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IOrgInnerServiceSMO orgInnerServiceSMOImpl;
+
+    @Autowired
+    private IStoreV1InnerServiceSMO storeV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IUserV1InnerServiceSMO userV1InnerServiceSMOImpl;
+
+    @Override
+    public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
+
+        if (!reqJson.containsKey("storeId") || StringUtil.isEmpty(reqJson.getString("storeId"))) {
+            reqJson.put("storeId", cmdDataFlowContext.getReqHeaders().get("store-id"));
+        }
+
+        if (!reqJson.containsKey("userId") || StringUtil.isEmpty(reqJson.getString("userId"))) {
+            reqJson.put("userId", cmdDataFlowContext.getReqHeaders().get("user-id"));
+        }
+
+        Assert.hasKeyAndValue(reqJson, "storeId", "请求报文中未包含商户信息");
+        Assert.hasKeyAndValue(reqJson, "userId", "请求报文中未包含用户信息");
+    }
+
+    @Override
+    public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
+
+
+        // 判断是不是管理员,管理员反馈 物业 的所有小区
+        UserDto userDto = new UserDto();
+        userDto.setUserId(reqJson.getString("userId"));
+        userDto.setPage(1);
+        userDto.setRow(1);
+        List<UserDto> userDtos = userV1InnerServiceSMOImpl.queryUsers(userDto);
+
+        Assert.listOnlyOne(userDtos, "用户不存在");
+
+        //校验商户是否存在;
+        StoreDto storeDto = new StoreDto();
+        storeDto.setStoreId(reqJson.getString("storeId"));
+        List<StoreDto> storeDtos = storeV1InnerServiceSMOImpl.queryStores(storeDto);
+
+        Assert.listOnlyOne(storeDtos, "商户不存在");
+
+        int count = 0;
+        List<ShopDto> shops = null;
+        ShopDto shopDto = null;
+        if(UserDto.LEVEL_CD_ADMIN.equals(userDtos.get(0).getLevelCd())){
+            shopDto = BeanConvertUtil.covertBean(reqJson, ShopDto.class);
+            shopDto.setStoreId(reqJson.getString("storeId"));
+            shopDto.setState(ShopDto.STATE_Y);
+            if (reqJson.containsKey("shopName")) {
+                shopDto.setShopName(reqJson.getString("shopName"));
+            }
+            count = shopInnerServiceSMOImpl.queryShopsCount(shopDto);
+            if (count > 0) {
+                shops = BeanConvertUtil.covertBeanList(shopInnerServiceSMOImpl.queryShops(shopDto), ShopDto.class);
+            } else {
+                shops = new ArrayList<>();
+            }
+        }else{
+            RoleCommunityDto orgCommunityDto = BeanConvertUtil.covertBean(reqJson, RoleCommunityDto.class);
+            orgCommunityDto.setStaffId(userDtos.get(0).getUserId());
+            count = roleCommunityV1InnerServiceSMOImpl.queryRoleCommunitysNameCount(orgCommunityDto);
+            if (count > 0) {
+                List<RoleCommunityDto> roleCommunityDtos = roleCommunityV1InnerServiceSMOImpl.queryRoleCommunitysName(orgCommunityDto);
+                shops = new ArrayList<>();
+                for (RoleCommunityDto tmpOrgCommunityDto : roleCommunityDtos) {
+                    shopDto = new ShopDto();
+                    shopDto.setShopId(tmpOrgCommunityDto.getCommunityId());
+                    shopDto.setShopName(tmpOrgCommunityDto.getCommunityName());
+                }
+            } else {
+                shops = new ArrayList<>();
+            }
+
+        }
+        //兼容 系统刚开始没有小区时
+        if (shops.size() < 1 && (StoreDto.STORE_TYPE_ADMIN.equals(storeDtos.get(0).getStoreTypeCd()) || StoreDto.STORE_TYPE_DEV.equals(storeDtos.get(0).getStoreTypeCd()))) {
+             shopDto = new ShopDto();
+            shopDto.setShopId("-1");
+            shopDto.setShopName("默认小区");
+            shopDto.setStoreTel("18909711234");
+            shopDto.setState("1100");
+            shops.add(shopDto);
+        }
+
+        context.setResponseEntity(ResultVo.createResponseEntity((int) Math.ceil((double) count / (double) reqJson.getInteger("row")),count,shops));
+    }
+}