From 82d6b98f5b6b88e223259547208ab59829ad723e Mon Sep 17 00:00:00 2001
From: wlzboy <66905212@qq.com>
Date: 星期六, 01 十一月 2025 21:30:52 +0800
Subject: [PATCH] fix:增加旧系统状态同步到新系统,新系统状态同步到旧系统

---
 app/App.vue |  104 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 104 insertions(+), 0 deletions(-)

diff --git a/app/App.vue b/app/App.vue
index 797f513..650a7fd 100644
--- a/app/App.vue
+++ b/app/App.vue
@@ -2,10 +2,57 @@
   import config from './config'
   import store from '@/store'
   import { getToken } from '@/utils/auth'
+  import { getUnreadCount } from '@/api/message'
 
   export default {
+    data() {
+      return {
+        messagePollingTimer: null,
+        lastToken: null // 鐢ㄤ簬妫�娴� token 鍙樺寲
+      }
+    },
     onLaunch: function() {
+      this.lastToken = getToken()
       this.initApp()
+      
+      // 鐩戝惉鐢ㄦ埛鐧诲嚭浜嬩欢
+      uni.$on('user-logout', () => {
+        console.log('鎺ユ敹鍒扮敤鎴风櫥鍑轰簨浠讹紝鍋滄娑堟伅杞')
+        this.stopMessagePolling()
+        this.lastToken = null
+        // 娓呴櫎娑堟伅寰芥爣
+        uni.removeTabBarBadge({ index: 3 })
+      })
+    },
+    onShow: function() {
+      const currentToken = getToken()
+      
+      // 妫�娴� token 鍙樺寲锛氫粠鏈夊埌鏃狅紙鐧诲嚭锛�
+      if (this.lastToken && !currentToken) {
+        console.log('妫�娴嬪埌鐢ㄦ埛宸茬櫥鍑猴紝鍋滄娑堟伅杞')
+        this.stopMessagePolling()
+        this.lastToken = currentToken
+        return
+      }
+      
+      // 妫�娴� token 鍙樺寲锛氫粠鏃犲埌鏈夛紙鐧诲綍锛�
+      if (!this.lastToken && currentToken) {
+        console.log('妫�娴嬪埌鐢ㄦ埛宸茬櫥褰曪紝鍚姩娑堟伅杞')
+        this.lastToken = currentToken
+      }
+      
+      // 搴旂敤鏄剧ず鏃跺埛鏂版湭璇绘秷鎭暟閲�
+      if (currentToken) {
+        this.updateUnreadMessageBadge()
+        // 閲嶆柊鍚姩杞锛堝鏋滀箣鍓嶅凡鍋滄锛�
+        if (!this.messagePollingTimer) {
+          this.startMessagePolling()
+        }
+      }
+    },
+    onHide: function() {
+      // 搴旂敤闅愯棌鏃跺仠姝㈣疆璇紝鑺傜渷璧勬簮
+      this.stopMessagePolling()
     },
     methods: {
       // 鍒濆鍖栧簲鐢�
@@ -16,6 +63,13 @@
         //#ifdef H5
         this.checkLogin()
         //#endif
+        
+        // 濡傛灉宸茬櫥褰曪紝鍚姩鏈娑堟伅杞
+        if (getToken()) {
+          this.updateUnreadMessageBadge()
+          // 姣�30绉掕疆璇竴娆�
+          this.startMessagePolling()
+        }
       },
       initConfig() {
         this.globalData.config = config
@@ -24,6 +78,56 @@
         if (!getToken()) {
           this.$tab.reLaunch('/pages/login') 
         }
+      },
+      
+      // 鏇存柊鏈娑堟伅寰芥爣
+      updateUnreadMessageBadge() {
+        // 妫�鏌ユ槸鍚﹀凡鐧诲綍锛屾湭鐧诲綍鍒欎笉璇锋眰
+        if (!getToken()) {
+          console.log('鐢ㄦ埛鏈櫥褰曪紝璺宠繃鑾峰彇鏈娑堟伅鏁伴噺')
+          return
+        }
+        
+        getUnreadCount().then(response => {
+          const count = response.data || 0
+          console.log('鏈娑堟伅鏁伴噺:', count)
+          
+          if (count > 0) {
+            // 璁剧疆寰芥爣
+            uni.setTabBarBadge({
+              index: 3, // 娑堟伅椤甸潰鍦╰abBar涓殑绱㈠紩浣嶇疆锛�0寮�濮嬶級
+              text: count > 99 ? '99+' : count.toString()
+            })
+          } else {
+            // 绉婚櫎寰芥爣
+            uni.removeTabBarBadge({
+              index: 3
+            })
+          }
+        }).catch(error => {
+          console.error('鑾峰彇鏈娑堟伅鏁伴噺澶辫触:', error)
+        })
+      },
+      
+      // 鍚姩娑堟伅杞
+      startMessagePolling() {
+        // 姣�30绉掕疆璇竴娆�
+        this.messagePollingTimer = setInterval(() => {
+          if (getToken()) {
+            this.updateUnreadMessageBadge()
+          } else {
+            // 濡傛灉鐢ㄦ埛宸茬櫥鍑猴紝鍋滄杞
+            this.stopMessagePolling()
+          }
+        }, 30000) // 30绉�
+      },
+      
+      // 鍋滄娑堟伅杞
+      stopMessagePolling() {
+        if (this.messagePollingTimer) {
+          clearInterval(this.messagePollingTimer)
+          this.messagePollingTimer = null
+        }
       }
     }
   }

--
Gitblit v1.9.1