From cab3425bb92d01f3494eb25c1f299038dc634c65 Mon Sep 17 00:00:00 2001
From: Your Name <you@example.com>
Date: 星期三, 15 三月 2023 23:43:48 +0800
Subject: [PATCH] 优化保养转单功能

---
 service-user/src/main/java/com/java110/user/cmd/role/ListStaffsNoRoleCmd.java |  160 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 159 insertions(+), 1 deletions(-)

diff --git a/service-user/src/main/java/com/java110/user/cmd/role/ListStaffsNoRoleCmd.java b/service-user/src/main/java/com/java110/user/cmd/role/ListStaffsNoRoleCmd.java
index 3d390ca..a3f121f 100644
--- a/service-user/src/main/java/com/java110/user/cmd/role/ListStaffsNoRoleCmd.java
+++ b/service-user/src/main/java/com/java110/user/cmd/role/ListStaffsNoRoleCmd.java
@@ -1,4 +1,162 @@
 package com.java110.user.cmd.role;
 
-public class ListStaffsNoRoleCmd {
+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.basePrivilege.BasePrivilegeDto;
+import com.java110.dto.org.OrgDto;
+import com.java110.dto.org.OrgStaffRelDto;
+import com.java110.dto.privilegeUser.PrivilegeUserDto;
+import com.java110.dto.user.UserDto;
+import com.java110.intf.community.IMenuInnerServiceSMO;
+import com.java110.intf.user.IOrgStaffRelInnerServiceSMO;
+import com.java110.intf.user.IOrgV1InnerServiceSMO;
+import com.java110.intf.user.IPrivilegeUserV1InnerServiceSMO;
+import com.java110.intf.user.IUserV1InnerServiceSMO;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.util.Assert;
+import com.java110.vo.ResultVo;
+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;
+import java.util.Map;
+
+/**
+ * 鏌ヨ涓嶅湪杩欎釜瑙掕壊 鍐呯殑鍛樺伐
+ */
+@Java110Cmd(serviceCode = "role.listStaffsNoRole")
+public class ListStaffsNoRoleCmd extends Cmd {
+
+    @Autowired
+    private IPrivilegeUserV1InnerServiceSMO privilegeUserV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IUserV1InnerServiceSMO userV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IMenuInnerServiceSMO menuInnerServiceSMOImpl;
+
+    @Autowired
+    private IOrgV1InnerServiceSMO orgV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IOrgStaffRelInnerServiceSMO iOrgStaffRelInnerServiceSMO;
+
+
+    @Override
+    public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
+        Assert.hasKeyAndValue(reqJson, "roleId", "鏈寘鍚鑹�");
+    }
+
+    @Override
+    public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
+        String storeId = context.getReqHeaders().get("store-id");
+        String userId = context.getReqHeaders().get("user-id");
+
+        PrivilegeUserDto privilegeUserDto = new PrivilegeUserDto();
+        privilegeUserDto.setpId(reqJson.getString("roleId"));
+        privilegeUserDto.setStoreId(storeId);
+        privilegeUserDto.setPrivilegeFlag(PrivilegeUserDto.PRIVILEGE_FLAG_GROUP);
+        privilegeUserDto.setUserName(reqJson.getString("userName"));
+        privilegeUserDto.setPage(Integer.parseInt(reqJson.getString("page")));
+        privilegeUserDto.setRow(Integer.parseInt(reqJson.getString("row")));
+
+        // 鍒ゆ柇鏄笉鏄鐞嗗憳锛岀鐞嗗憳鍙嶉 鐗╀笟 鐨勬墍瑙掕壊
+        UserDto userDto = new UserDto();
+        userDto.setUserId(userId);
+        userDto.setPage(1);
+        userDto.setRow(1);
+        List<UserDto> userDtos = userV1InnerServiceSMOImpl.queryUsers(userDto);
+        Assert.listOnlyOne(userDtos, "鐢ㄦ埛涓嶅瓨鍦�");
+        if (!UserDto.LEVEL_CD_ADMIN.equals(userDtos.get(0).getLevelCd())) {
+            //榛樿鍙煡鐪嬪綋鍓嶅綊灞炵粍缁囨灦鏋�
+            BasePrivilegeDto basePrivilegeDto = new BasePrivilegeDto();
+            basePrivilegeDto.setResource("/viewAllOrganization");
+            basePrivilegeDto.setUserId(userId);
+            List<Map> privileges = menuInnerServiceSMOImpl.checkUserHasResource(basePrivilegeDto);
+            if (privileges.size() == 0) {
+                //鏌ヨ鍛樺伐鎵�灞炰簩绾х粍缁囨灦鏋�
+                OrgStaffRelDto orgStaffRelDto = new OrgStaffRelDto();
+                orgStaffRelDto.setStaffId(reqJson.getString("userId"));
+                List<OrgStaffRelDto> orgStaffRelDtos = iOrgStaffRelInnerServiceSMO.queryOrgInfoByStaffIdsNew(orgStaffRelDto);
+                if (orgStaffRelDtos.size() > 0) {
+                    List<String> haveOrgList = new ArrayList<String>();
+                    for (OrgStaffRelDto orgStaffRelDto1 : orgStaffRelDtos) {
+                        OrgDto orgDto1 = new OrgDto();
+                        orgDto1.setOrgId(orgStaffRelDto1.getOrgId());
+                        List<OrgDto> orgDtoList = orgV1InnerServiceSMOImpl.queryOrgs(orgDto1);
+                        findCompany(haveOrgList, orgDtoList);
+                    }
+                    privilegeUserDto.setOrgIds(haveOrgList.toArray(new String[haveOrgList.size()]));//褰撳墠浜鸿櫧褰掑睘鐨勪簩绾х粍缁囦俊鎭�
+                }
+            }
+
+        }
+
+        int count = privilegeUserV1InnerServiceSMOImpl.queryStaffsNoRoleCount(privilegeUserDto);
+
+        List<UserDto> staffsDtos = null;
+
+        if (count > 0) {
+            staffsDtos = privilegeUserV1InnerServiceSMOImpl.queryStaffsNoRoleInfos(privilegeUserDto);
+        } else {
+            staffsDtos = new ArrayList<>();
+        }
+
+        ResultVo resultVo = new ResultVo((int) Math.ceil((double) count / (double) reqJson.getInteger("row")), count, staffsDtos);
+
+        ResponseEntity<String> responseEntity = new ResponseEntity<String>(resultVo.toString(), HttpStatus.OK);
+
+        context.setResponseEntity(responseEntity);
+    }
+
+    private void findCompany(List<String> haveOrgList, List<OrgDto> orgDtoList) {
+
+        for (OrgDto orgDto : orgDtoList) {
+            haveOrgList.add(orgDto.getOrgId());
+            if (!"1".equals(orgDto.getOrgLevel())) {
+                if ("2".equals(orgDto.getOrgLevel())) {
+                    //涓婄骇鍒�
+                    OrgDto orgDto1 = new OrgDto();
+                    orgDto1.setOrgId(orgDto.getParentOrgId());
+                    List<OrgDto> orgDtoList1 = orgV1InnerServiceSMOImpl.queryOrgs(orgDto1);
+                    for (OrgDto orgDto2 : orgDtoList1) {
+                        haveOrgList.add(orgDto2.getOrgId());
+                    }
+                    //鍚岀骇鍒�
+                    OrgDto orgDto2 = new OrgDto();
+                    orgDto2.setParentOrgId(orgDto.getOrgId());
+                    List<OrgDto> orgDtoList2 = orgV1InnerServiceSMOImpl.queryOrgs(orgDto2);
+                    for (OrgDto orgDto3 : orgDtoList2) {
+                        haveOrgList.add(orgDto3.getOrgId());
+                    }
+                } else {
+                    OrgDto orgDto1 = new OrgDto();
+                    orgDto1.setOrgId(orgDto.getParentOrgId());
+                    List<OrgDto> orgDtoList1 = orgV1InnerServiceSMOImpl.queryOrgs(orgDto1);
+                    findCompany(haveOrgList, orgDtoList1);
+
+                    //涓嬩竴涓骇鍒�
+                    if (!"2".equals(orgDto.getOrgLevel())) {
+                        OrgDto orgDto3 = new OrgDto();
+                        orgDto3.setParentOrgId(orgDto.getOrgId());
+                        List<OrgDto> orgDtoList2 = orgV1InnerServiceSMOImpl.queryOrgs(orgDto3);
+                        for (OrgDto orgDto4 : orgDtoList2) {
+                            haveOrgList.add(orgDto4.getOrgId());
+                        }
+                    }
+
+                }
+
+            }
+        }
+
+
+    }
+
 }

--
Gitblit v1.8.0