From 2e9c442b4961dc30423e8b8fa1361c45e63ef620 Mon Sep 17 00:00:00 2001
From: jiangqs <jiangqs>
Date: 星期三, 16 八月 2023 19:52:00 +0800
Subject: [PATCH] bug

---
 ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/staff/SysStaffServiceImpl.java |  258 +++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 257 insertions(+), 1 deletions(-)

diff --git a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/staff/SysStaffServiceImpl.java b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/staff/SysStaffServiceImpl.java
index e972d6b..03acb69 100644
--- a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/staff/SysStaffServiceImpl.java
+++ b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/staff/SysStaffServiceImpl.java
@@ -1,14 +1,35 @@
 package com.ruoyi.system.service.impl.staff;
 
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.core.exception.ServiceException;
+import com.ruoyi.common.core.utils.StringUtils;
+import com.ruoyi.common.core.utils.uuid.IdUtils;
+import com.ruoyi.common.redis.service.RedisService;
+import com.ruoyi.common.security.utils.SecurityUtils;
+import com.ruoyi.system.api.constant.AppErrorConstant;
+import com.ruoyi.system.api.constant.SecurityConstant;
+import com.ruoyi.system.api.domain.dto.MerEditUserDto;
+import com.ruoyi.system.api.domain.dto.MgtBaseGetDto;
+import com.ruoyi.system.api.domain.dto.MgtShopStaffEditDto;
+import com.ruoyi.system.api.domain.poji.sys.SysUser;
+import com.ruoyi.system.api.service.RemoteShopService;
+import com.ruoyi.system.domain.dto.MgtStaffEditDto;
+import com.ruoyi.system.domain.dto.MgtStaffPageDto;
 import com.ruoyi.system.domain.pojo.staff.SysStaff;
 import com.ruoyi.system.domain.vo.MgtDeptStaffListVo;
+import com.ruoyi.system.domain.vo.MgtStaffPageVo;
 import com.ruoyi.system.mapper.staff.SysStaffMapper;
 import com.ruoyi.system.service.staff.SysStaffService;
-import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.system.service.sys.ISysUserService;
+import com.ruoyi.system.util.QiYeUtils;
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
 import java.util.List;
+import java.util.concurrent.TimeUnit;
 
 /**
  * <p>
@@ -24,6 +45,16 @@
     @Resource
     private SysStaffMapper sysStaffMapper;
 
+    @Resource
+    private ISysUserService sysUserService;
+
+    @Resource
+    private RedisService redisService;
+
+    @Resource
+    private RemoteShopService remoteShopService;
+
+
     /**
      * @description  获取部门员工列表
      * @author  jqs
@@ -35,4 +66,229 @@
     public List<MgtDeptStaffListVo> listMgtDeptStaff(){
         return sysStaffMapper.listMgtDeptStaff();
     }
+
+    /**
+     * @description 通过权限获取部门员工列表
+     * @author  jqs
+     * @date    2023/6/21 10:24
+     * @param userId
+     * @return  List<MgtDeptStaffListVo>
+     */
+    @Override
+    public List<MgtDeptStaffListVo>listMgtDeptStaffByPermission(Long userId){
+        SysUser sysUser = sysUserService.selectUserById(userId);
+        String dataScope = sysUser.getDataScope();
+        List<MgtDeptStaffListVo> deptStaffListVoList;
+        if(dataScope!=null&&dataScope.equals("4")){
+            deptStaffListVoList = sysStaffMapper.listMgtDeptStaffByDept(sysUser.getDeptId(),null);
+        }else if(dataScope!=null&&dataScope.equals("5")){
+            deptStaffListVoList = sysStaffMapper.listMgtDeptStaffByDept(sysUser.getDeptId(),sysUser.getUserId());
+        }else{
+            deptStaffListVoList = sysStaffMapper.listMgtDeptStaff();
+        }
+        return deptStaffListVoList;
+    }
+
+    /**
+     * @description getBYUserId
+     * @param userId
+     * @return SysStaff
+     * @author jqs34
+     * @date 2023/6/18 21:01
+     */
+    @Override
+    public SysStaff getByUserId(Long userId){
+        LambdaQueryWrapper<SysStaff> queryWrapper = new LambdaQueryWrapper();
+        queryWrapper.eq(SysStaff::getDelFlag,0);
+        queryWrapper.eq(SysStaff::getUserId,userId);
+        return this.getOne(queryWrapper, false);
+    }
+
+
+    /**
+     * @description mgtStaffEdit
+     * @param mgtStaffEditDto
+     * @return void
+     * @author jqs34
+     * @date 2023/6/18 20:59
+     */
+    @Override
+    public void mgtStaffEdit(MgtStaffEditDto mgtStaffEditDto){
+        SysStaff sysStaff;
+        SysUser sysUser;
+        LambdaQueryWrapper<SysStaff> queryWrapper = new LambdaQueryWrapper();
+        queryWrapper.eq(SysStaff::getDelFlag,0);
+        queryWrapper.eq(SysStaff::getStaffMobile,mgtStaffEditDto.getStaffMobile());
+        SysStaff sysStaffSame = this.getOne(queryWrapper, false);
+        if(StringUtils.isBlank(mgtStaffEditDto.getStaffAvatar())){
+            mgtStaffEditDto.setStaffAvatar("https://hongruitang.oss-cn-beijing.aliyuncs.com/default.png");
+        }
+        if(mgtStaffEditDto.getSysUserId()!=null){
+            if(sysStaffSame!=null&&!sysStaffSame.getUserId().equals(mgtStaffEditDto.getSysUserId())){
+                throw new ServiceException(AppErrorConstant.STAFF_MOBILE_DOUBLE);
+            }
+            sysStaff = this.getByUserId(mgtStaffEditDto.getSysUserId());
+            sysUser = sysUserService.selectUserById(mgtStaffEditDto.getSysUserId());
+            sysUser.setUserName(mgtStaffEditDto.getStaffMobile());
+            sysUser.setPhonenumber(mgtStaffEditDto.getStaffMobile());
+            sysUser.setNickName(mgtStaffEditDto.getStaffName());
+            sysUser.setAvatar(mgtStaffEditDto.getStaffAvatar());
+            sysUser.setEmail(mgtStaffEditDto.getStaffEmail());
+            sysUserService.updateOnlyUser(sysUser);
+        }else{
+            if(sysStaffSame!=null){
+                throw new ServiceException(AppErrorConstant.STAFF_MOBILE_DOUBLE);
+            }
+            sysStaff = new SysStaff();
+            String staffId = IdUtils.simpleUUID();
+            sysStaff.setStaffId(staffId);
+            sysStaff.setDelFlag(0);
+            sysUser = new SysUser();
+            sysUser.setDelFlag("0");
+            sysUser.setUserType("00");
+            sysUser.setUserName(mgtStaffEditDto.getStaffMobile());
+            sysUser.setPhonenumber(mgtStaffEditDto.getStaffMobile());
+            sysUser.setNickName(mgtStaffEditDto.getStaffName());
+            sysUser.setAvatar(mgtStaffEditDto.getStaffAvatar());
+            sysUser.setEmail(mgtStaffEditDto.getStaffEmail());
+            String password = "123456";
+            sysUser.setPassword(SecurityUtils.encryptPassword(password));
+            sysUser.setDeptId(mgtStaffEditDto.getDeptId());
+            sysUser = sysUserService.registerUser(sysUser);
+            sysStaff.setUserId(sysUser.getUserId());
+        }
+        sysStaff.setStaffName(mgtStaffEditDto.getStaffName());
+        sysStaff.setStaffMobile(mgtStaffEditDto.getStaffMobile());
+        sysStaff.setStaffEmail(mgtStaffEditDto.getStaffEmail());
+        sysStaff.setStaffPost(mgtStaffEditDto.getStaffPost());
+        sysStaff.setStaffAvatar(mgtStaffEditDto.getStaffAvatar());
+        sysStaff.setHeadFlag(mgtStaffEditDto.getHeadFlag());
+        this.saveOrUpdate(sysStaff);
+        MgtShopStaffEditDto mgtShopStaffEditDto = new MgtShopStaffEditDto();
+        mgtShopStaffEditDto.setUserId(sysStaff.getUserId());
+        mgtShopStaffEditDto.setStaffName(sysStaff.getStaffName());
+        mgtShopStaffEditDto.setStaffMobile(sysStaff.getStaffMobile());
+        mgtShopStaffEditDto.setStaffAvatar(sysStaff.getStaffAvatar());
+        remoteShopService.editMgtShopStaff(mgtShopStaffEditDto);
+    }
+
+    /**
+     * @description mgtDeleteStaff
+     * @param mgtBaseGetDto
+     * @return void
+     * @author jqs34
+     * @date 2023/6/18 22:00
+     */
+    @Override
+    public void mgtDeleteStaff(MgtBaseGetDto mgtBaseGetDto){
+        Long userId = Long.valueOf(mgtBaseGetDto.getId());
+        SysStaff sysStaff = this.getByUserId(userId);
+        sysStaff.setDelFlag(1);
+        sysStaff.setStaffMobile(sysStaff.getStaffMobile()+":已删除");
+        this.saveOrUpdate(sysStaff);
+        sysUserService.deleteUserById(userId);
+    }
+
+    /**
+     * @description
+     * @author  jqs
+     * @date    2023/6/25 17:52
+     * @param page
+     * @param mgtStaffPageDto
+     * @return  List<MgtStaffPageVo>
+     */
+    @Override
+    public List<MgtStaffPageVo> pageMgtStaff(Page page, MgtStaffPageDto mgtStaffPageDto){
+        return sysStaffMapper.pageMgtStaff(page, mgtStaffPageDto);
+    }
+
+    /**
+     * @description
+     * @author  jqs
+     * @date    2023/7/14 9:52
+     * @param mobile
+     * @return  SysStaff
+     */
+    @Override
+    public SysStaff getByMobile(String mobile){
+        LambdaQueryWrapper<SysStaff> queryWrapper = new LambdaQueryWrapper();
+        queryWrapper.eq(SysStaff::getDelFlag,0);
+        queryWrapper.eq(SysStaff::getStaffMobile,mobile);
+        return this.getOne(queryWrapper,false);
+    }
+
+
+    /**
+     * @description  同步组织架构
+     * @author  jqs
+     * @date    2023/7/18 19:06
+     * @param
+     * @return  void
+     */
+    @Override
+    public void synchronizeOrganizationalStructure(){
+        String accessToken = getQYToken();
+
+
+    }
+
+
+    /**
+     * @description  获取企业微信token
+     * @author  jqs
+     * @date    2023/7/18 19:35
+     * @param
+     * @return  String
+     */
+    private String getQYToken(){
+        String accessToken = redisService.getCacheObject(SecurityConstant.QY_TOKEN);
+        if(StringUtils.isBlank(accessToken)){
+            try {
+                accessToken = QiYeUtils.getAccessTokenByQY();
+                JSONObject jsonAccessToken = JSONObject.parseObject(accessToken);
+                String errcode = jsonAccessToken.getString("errcode");
+                String errmsg = jsonAccessToken.getString("errmsg");
+                if(errcode.equals("0")){
+                    accessToken = jsonAccessToken.getString("access_token");
+                    Long expiresIn = jsonAccessToken.getLong("expires_in");
+                    expiresIn = expiresIn -100;
+                    redisService.setCacheObject(SecurityConstant.QY_TOKEN,accessToken,expiresIn, TimeUnit.SECONDS);
+                }else{
+                    throw new ServiceException(errmsg);
+                }
+            } catch (Exception e) {
+                throw new RuntimeException(e);
+            }
+        }
+        return accessToken;
+    }
+
+
+    /**
+     * @description  编辑商户员工
+     * @author  jqs
+     * @date    2023/7/19 19:42
+     * @param merEditUserDto
+     * @return  void
+     */
+    @Override
+    public void editSysStaffInfo(MerEditUserDto merEditUserDto){
+        SysStaff sysStaff = this.getByUserId(merEditUserDto.getUserId());
+        Integer editType = merEditUserDto.getEditType();
+        switch (editType){
+            case 1:
+                sysStaff.setStaffName(merEditUserDto.getEditValue());
+                break;
+            case 2:
+                sysStaff.setStaffAvatar(merEditUserDto.getEditValue());
+                break;
+            case 3:
+                break;
+            case 4:
+                break;
+            default:
+                break;
+        }
+        this.saveOrUpdate(sysStaff);
+    }
 }

--
Gitblit v1.7.1