From 140e83402814ffd2e92dfe313f5681feedd39f86 Mon Sep 17 00:00:00 2001
From: 马宇豪 <978517621@qq.com>
Date: 星期二, 06 二月 2024 16:49:12 +0800
Subject: [PATCH] 修复弹窗bug

---
 src/views/Login.vue |   60 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 59 insertions(+), 1 deletions(-)

diff --git a/src/views/Login.vue b/src/views/Login.vue
index 588b32d..9eb9abe 100644
--- a/src/views/Login.vue
+++ b/src/views/Login.vue
@@ -91,11 +91,12 @@
           size="large"
           @click="handleSubmit"
           :loading="isLoading"
+          v-preventReClick="1500"
         >
           登录
         </a-button>
       </a-form-item>
-	  <center><p>技术支持:中国科学院</p></center>
+	  <center><p>技术支持:技术保障部</p></center>
     </a-form-model>
   </div>
   </div>
@@ -106,6 +107,8 @@
 import { login, getMenuAdmin } from "@/api/login";
 import Cookies from 'js-cookie';
 import {Base64} from "js-base64";
+import {getAreaWithUserIfo} from "@/api/user";
+
 
 export default {
   name: "login",
@@ -155,6 +158,7 @@
             Cookies.set('resTk', res.data.data.tk);
             Cookies.set('resUid', res.data.data.uid);
             Cookies.set('userInfo',JSON.stringify(res.data.data),{expires: 7})
+            await this.getAreaUsers(res.data.data.districtId)
             if (this.saveAccount) {
               localStorage.setItem('userName', this.form.name)
               localStorage.setItem('userPassword', Base64.encode(this.form.pwd))
@@ -172,6 +176,60 @@
           return false;
         }
       });
+    },
+
+    async getAreaUsers(districtId) {
+      let t = this
+      let res = await getAreaWithUserIfo()
+      if (res.data.code == 100) {
+        if (res.data.data) {
+          t.userTitTree(res.data.data)
+          const areaUsers = t.findNodeById(res.data.data, districtId).children
+          localStorage.removeItem('areaUsers')
+          localStorage.setItem('areaUsers',JSON.stringify(areaUsers))
+        } else {
+          console.log('暂无数据')
+        }
+      } else {
+        this.$message.warning(res.data.msg);
+      }
+    },
+
+    // 根据id查对象
+    findNodeById(data, value) {
+      for (const node of data) {
+        if (node.id === value) {
+          return node;
+        }
+        if (node.children) {
+          const foundNode = this.findNodeById(node.children, value);
+          if (foundNode) {
+            return foundNode;
+          }
+        }
+      }
+      return null;
+    },
+
+    // 将树状数据name字段放入users的姓名电话
+    userTitTree(treeData) {
+      for (const node of treeData) {
+        if (node.users) {
+          node.users = node.users.filter(i => i.roleId == 3)
+          node.users = node.users.map((i) => {
+            return {
+              ...i,
+              unittype: node.type,
+              districtId: node.id
+            }
+          })
+          node.name = node.name + '(' + node.users.map(i => i.realName + ' ' + i.phone).join(',') + ')'
+        }
+        if (node.children) {
+          this.userTitTree(node.children)
+        }
+      }
+      return treeData
     }
   },
 };

--
Gitblit v1.9.2