From 6f67eee1325143911bd41403a8c8b769a0cdfe2a Mon Sep 17 00:00:00 2001
From: ZQN <364596817@qq.com>
Date: 星期五, 26 七月 2024 15:45:30 +0800
Subject: [PATCH] 方重复

---
 project-admin/src/main/java/com/project/admin/controller/system/SysProfileController.java |   59 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 56 insertions(+), 3 deletions(-)

diff --git a/project-admin/src/main/java/com/project/admin/controller/system/SysProfileController.java b/project-admin/src/main/java/com/project/admin/controller/system/SysProfileController.java
index f36229a..b8220a0 100644
--- a/project-admin/src/main/java/com/project/admin/controller/system/SysProfileController.java
+++ b/project-admin/src/main/java/com/project/admin/controller/system/SysProfileController.java
@@ -48,7 +48,7 @@
     @GetMapping
     public AjaxResult profile()
     {
-        SysUser user = SecurityUtils.getLoginUser().getUser();
+        SysUser user = userService.selectUserById(SecurityUtils.getLoginUser().getUserId());
         if ("02".equals(user.getUserType())){
             SysCompany company = companyService.getById(userService.getById(user.getUserId()).getDeptId());
             SysDept sysDept = new SysDept();
@@ -56,8 +56,10 @@
             user.setDept(sysDept);
         } else {
             SysDept sysDept = deptService.selectDeptById(userService.getById(user.getUserId()).getDeptId());
-            sysDept.setDeptName(deptService.getDeptAllName(sysDept.getDeptId()));
-            user.setDept(sysDept);
+            if (sysDept!=null){
+                sysDept.setDeptName(deptService.getDeptAllName(sysDept.getDeptId()));
+                user.setDept(sysDept);
+            }
         }
 
         // 瑙掕壊闆嗗悎
@@ -101,6 +103,7 @@
         return error("淇敼涓汉淇℃伅寮傚父锛岃鑱旂郴绠$悊鍛�");
     }
 
+
     /**
      * 閲嶇疆瀵嗙爜
      */
@@ -130,6 +133,56 @@
     }
 
     /**
+     * 鏇存崲鎵嬫満鍙�
+     */
+    @Log(title = "鏇存崲鎵嬫満鍙�", businessType = BusinessType.UPDATE)
+    @PostMapping("/updatePhone/{phone}/{companyId}")
+    public AjaxResult updatePhone(@PathVariable String phone, @PathVariable String companyId)
+    {
+        if (StringUtils.isEmpty(phone)){
+            return error("璇峰~鍐欐墜鏈哄彿");
+        }
+        LoginUser loginUser = SecurityUtils.getLoginUser();
+        SysUser user = userService.selectUserById(SecurityUtils.getUserId());
+        if ("02".equals(user.getUserType()) && StringUtils.isNotEmpty(companyId)){//浼佷笟
+            //澶氫紒涓氳处鎴锋洿鎹㈠彿鐮�
+            //鏂板彿鐮佷笉瀛樺湪锛�
+            SysUser one = userService.getOne(userService.lq().eq(SysUser::getPhonenumber, phone));
+            if (one!=null && !"02".equals(one.getUserType())){
+                return error("璇ユ墜鏈哄彿涓嶆槸浼佷笟鍙风爜鑼冨洿锛岃鏇存崲鍙风爜");
+            }
+            if (companyService.count(SysCompany::getCompanyPhone, user.getPhonenumber())==1){
+                userService.deleteUserByCompanyPhone(user.getPhonenumber());
+            }
+            if (one==null){ //涓嶅瓨鍦�,娣诲姞浼佷笟璐︽埛
+                SysCompany company = companyService.getById(Long.parseLong(companyId));
+                company.setCompanyPhone(phone);
+                companyService.addCompanyUser(company, 1);
+            }
+            //淇敼浼佷笟鐢佃瘽
+            companyService.update(companyService.lu().set(SysCompany::getCompanyPhone, phone).eq(SysCompany::getCompanyId, Long.parseLong(companyId)));
+            return success(1);
+        }
+        user.setPhonenumber(phone);
+
+        if (StringUtils.isNotEmpty(user.getPhonenumber())
+                    && UserConstants.NOT_UNIQUE.equals(userService.checkPhoneUnique(user)))
+        {
+            return error("淇敼鐢ㄦ埛'" + user.getUserName() + "'澶辫触锛屾墜鏈哄彿鐮佸凡瀛樺湪");
+        }
+
+        if (userService.resetPhone(user.getUserId(), phone) > 0)
+        {
+            // 鏇存柊缂撳瓨
+            loginUser.getUser().setUserName(phone);
+            loginUser.getUser().setPhonenumber(phone);
+            tokenService.setLoginUser(loginUser);
+            return success(0);
+        }
+        return error("淇敼瀵嗙爜寮傚父锛岃鑱旂郴绠$悊鍛�");
+    }
+
+    /**
      * 澶村儚涓婁紶
      */
     @Log(title = "鐢ㄦ埛澶村儚", businessType = BusinessType.UPDATE)

--
Gitblit v1.9.1