From 9c348b05a774adf47453780cf3b7a8f9823661f5 Mon Sep 17 00:00:00 2001
From: ZQN <364596817@qq.com>
Date: 星期三, 26 六月 2024 18:30:19 +0800
Subject: [PATCH] 企业多手机号

---
 project-admin/src/main/java/com/project/admin/controller/system/SysProfileController.java |   32 +++++++++++++++++++++++++-------
 1 files changed, 25 insertions(+), 7 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 8b96f96..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
@@ -136,30 +136,48 @@
      * 鏇存崲鎵嬫満鍙�
      */
     @Log(title = "鏇存崲鎵嬫満鍙�", businessType = BusinessType.UPDATE)
-    @PostMapping("/updatePhone/{phone}")
-    public AjaxResult updatePhone(@PathVariable String phone)
+    @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)))
+                    && 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);
-            if ("02".equals(user.getUserType())){
-                companyService.update(companyService.lu().set(SysCompany::getCompanyPhone, phone).eq(SysCompany::getCompanyId, user.getDeptId()));
-            }
-            return success();
+            return success(0);
         }
         return error("淇敼瀵嗙爜寮傚父锛岃鑱旂郴绠$悊鍛�");
     }

--
Gitblit v1.9.1