Merge pull request #275 from ljt990218/fix-tabbar

fix(tabbar): 优化`tabbar`索引设置
This commit is contained in:
菲鸽
2025-09-19 10:52:24 +08:00
committed by GitHub

View File

@@ -1,7 +1,9 @@
import type { CustomTabBarItem, CustomTabBarItemBadge } from './config'
import { reactive } from 'vue'
import { FG_LOG_ENABLE } from '@/router/interceptor'
import { isNeedLoginMode } from '@/router/config'
import { FG_LOG_ENABLE, judgeIsExcludePath } from '@/router/interceptor'
import { useTokenStore } from '@/store/token'
import { tabbarList as _tabbarList, customTabbarEnable } from './config'
// TODO 1/2: 中间的鼓包tabbarItem的开关
@@ -36,8 +38,12 @@ const tabbarStore = reactive({
curIdx: uni.getStorageSync('app-tabbar-index') || 0,
prevIdx: uni.getStorageSync('app-tabbar-index') || 0,
setCurIdx(idx: number) {
this.curIdx = idx
uni.setStorageSync('app-tabbar-index', idx)
const tokenStore = useTokenStore()
// 已登录 或 (url 需要登录 && 在白名单 || 不需要登录 && 不在黑名单) (关于 白名单|黑名单 逻辑: src/router/interceptor.ts
if (tokenStore.hasLogin || (isNeedLoginMode && judgeIsExcludePath(tabbarList[idx].pagePath)) || (!isNeedLoginMode && !judgeIsExcludePath(tabbarList[idx].pagePath))) {
this.curIdx = idx
uni.setStorageSync('app-tabbar-index', idx)
}
},
setTabbarItemBadge(idx: number, badge: CustomTabBarItemBadge) {
if (tabbarList[idx]) {