From f32aea98aa5e6f6922aaa4cb969b202301a3faab Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期四, 05 六月 2025 14:23:33 +0800
Subject: [PATCH] 分页修改

---
 src/layout/components/Navbar.vue |   63 ++++++++++++++++++++++++++++++-
 1 files changed, 60 insertions(+), 3 deletions(-)

diff --git a/src/layout/components/Navbar.vue b/src/layout/components/Navbar.vue
index 41bc17c..3c70204 100644
--- a/src/layout/components/Navbar.vue
+++ b/src/layout/components/Navbar.vue
@@ -6,7 +6,23 @@
     </div>
 <!--    <top-nav v-if="settingsStore.topNav" id="topmenu-container" class="topmenu-container" />-->
     <div class="center-menu">
-      <span class="label">绯荤粺鍚嶇О绯荤粺鍚嶇О</span>
+      <span class="label">{{userStore.currentFactoryName}}</span>
+      <el-dropdown @command="handleFactoryChange" class="right-menu-item hover-effect" trigger="click">
+        <div>
+          <el-icon size="20"><Switch /></el-icon>
+        </div>
+        <template #dropdown>
+          <el-dropdown-menu >
+            <el-dropdown-item
+                v-for="item in factoryList"
+                :key="item.deptId"
+                :command="item"
+            >
+              {{ item.deptName }}
+            </el-dropdown-item>
+          </el-dropdown-menu>
+        </template>
+      </el-dropdown>
     </div>
     <div class="right-menu">
       <div class="avatar-container">
@@ -47,14 +63,21 @@
 import useAppStore from '@/store/modules/app'
 import useUserStore from '@/store/modules/user'
 import useSettingsStore from '@/store/modules/settings'
+import { userLoginFacotryList } from "@/api/system/user.js"
+import Cookies from "js-cookie";
+import { decrypt } from "@/utils/jsencrypt"
 
 const appStore = useAppStore()
 const userStore = useUserStore()
 const settingsStore = useSettingsStore()
-
+const factoryList = ref([])
 function toggleSideBar() {
   appStore.toggleSideBar()
 }
+// const redirect = ref(undefined)
+// watch(route, (newRoute) => {
+//   redirect.value = newRoute.query && newRoute.query.redirect
+// }, { immediate: true })
 
 function handleCommand(command) {
   switch (command) {
@@ -89,6 +112,37 @@
 function toggleTheme() {
   settingsStore.toggleTheme()
 }
+
+function getUserLoginFacotryList() {
+  if(userStore.id){
+    userLoginFacotryList({userId:userStore.id}).then(res => {
+      console.log('res', res)
+      factoryList.value = res.data
+    })
+  }else {
+    factoryList.value = []
+  }
+}
+
+function handleFactoryChange(command) {
+  console.log('command', command)
+  handleLogin(command.deptId);
+}
+
+function handleLogin(currentFatoryId){
+  const loginForm = {
+    username: Cookies.get("username"),
+    password: Cookies.get("password") === undefined ? null : decrypt(Cookies.get("password")),
+    currentFatoryId: currentFatoryId
+  }
+  userStore.loginCheckFactory(loginForm).then(res => {
+    window.location.reload();
+  }).catch((err) => {
+    console.log(err)
+  })
+}
+
+getUserLoginFacotryList();
 </script>
 
 <style lang='scss' scoped>
@@ -103,10 +157,13 @@
     position: absolute;
     left: 50%;
     transform: translateX(-50%);
+    display: flex;
+    align-items: center;
     .label {
       font-weight: bold;
       font-size: 18px;
       color: #333333;
+      margin-right: 10px;
     }
   }
 
@@ -170,7 +227,7 @@
 
         svg {
           transition: transform 0.3s;
-          
+
           &:hover {
             transform: scale(1.15);
           }

--
Gitblit v1.9.3