diff --git a/src/tabbar/store.ts b/src/tabbar/store.ts index 839bc61..01c713a 100644 --- a/src/tabbar/store.ts +++ b/src/tabbar/store.ts @@ -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]) {