重构PWA状态管理

This commit is contained in:
jxxghp
2025-07-07 14:05:11 +08:00
parent 73d7eb65b8
commit 0cf3342449
8 changed files with 489 additions and 975 deletions

View File

@@ -1,7 +1,6 @@
import { ref, computed, onMounted, onUnmounted, watch } from 'vue'
import { ref, computed, onMounted } from 'vue'
import { useDisplay } from 'vuetify'
import { checkPWAStatus, isPWADisplayMode } from '@/@core/utils/navigator'
import type { PWAState } from '@/utils/pwaStateManager'
// 全局PWA状态确保只初始化一次
const globalPwaStatus = ref<{
@@ -72,142 +71,6 @@ export function usePWA() {
appMode,
pwaStatus,
loading: globalLoading,
// 保留手动初始化方法以防需要
initializePWA: initializePWAGlobally,
}
}
// PWA状态管理 composable
export function usePWAState() {
const isStateRestored = ref(false)
const stateRestoreCount = ref(0)
const lastRestoredState = ref<PWAState | null>(null)
const isPWAMode = ref(false)
// 检查PWA模式 - 使用统一的检测方式
const checkPWAMode = async () => {
// 确保全局PWA状态已初始化
if (globalPwaStatus.value === null) {
await initializePWAGlobally()
}
// 获取PWA状态
const status = globalPwaStatus.value
if (status) {
isPWAMode.value = status.isPWAEnvironment
} else {
// 如果状态获取失败,使用同步检测作为后备
isPWAMode.value = isPWADisplayMode()
}
}
// 保存当前状态
const saveCurrentState = async () => {
if (window.pwaStateController) {
await window.pwaStateController.saveCurrentState()
}
}
// 手动触发状态恢复检查
const checkStateRestore = async () => {
if (window.pwaStateController) {
// 静默检查
}
}
// 监听状态恢复事件
const handleStateRestored = (event: Event) => {
const customEvent = event as CustomEvent<{ state: PWAState }>
isStateRestored.value = true
stateRestoreCount.value++
lastRestoredState.value = customEvent.detail.state
}
// 重置状态恢复标志
const resetStateRestored = () => {
isStateRestored.value = false
lastRestoredState.value = null
}
// 检查状态管理器是否可用
const isStateManagerAvailable = () => {
return !!window.pwaStateController
}
onMounted(() => {
checkPWAMode()
// 监听状态恢复事件
window.addEventListener('pwaStateRestored', handleStateRestored)
// 监听PWA模式变化
const mediaQuery = window.matchMedia('(display-mode: standalone)')
const handleDisplayModeChange = (e: MediaQueryListEvent) => {
isPWAMode.value = e.matches
// 同步更新全局PWA状态
if (globalPwaStatus.value) {
globalPwaStatus.value.isStandaloneMode = e.matches
globalPwaStatus.value.isPWAEnvironment = globalPwaStatus.value.hasPWAFeatures || e.matches
globalPwaStatus.value.isFullPWA = globalPwaStatus.value.hasPWAFeatures && e.matches
}
}
if (mediaQuery.addEventListener) {
mediaQuery.addEventListener('change', handleDisplayModeChange)
} else {
mediaQuery.addListener(handleDisplayModeChange)
}
onUnmounted(() => {
if (mediaQuery.removeEventListener) {
mediaQuery.removeEventListener('change', handleDisplayModeChange)
} else {
mediaQuery.removeListener(handleDisplayModeChange)
}
})
})
onUnmounted(() => {
window.removeEventListener('pwaStateRestored', handleStateRestored)
})
return {
// 响应式状态
isPWAMode,
isStateRestored,
stateRestoreCount,
lastRestoredState,
// 方法
saveCurrentState,
checkStateRestore,
resetStateRestored,
isStateManagerAvailable,
checkPWAMode,
}
}
// 全局PWA状态管理器
export function useGlobalPWAState() {
// 检查是否在PWA环境中 - 使用统一的检测方式
const isPWAEnvironment = () => {
return globalPwaStatus.value?.isPWAEnvironment ?? isPWADisplayMode()
}
// 获取存储的状态
const getStoredState = () => {
return localStorage.getItem('mp-pwa-app-state')
}
// 清除存储的状态
const clearStoredState = () => {
localStorage.removeItem('mp-pwa-app-state')
sessionStorage.removeItem('mp-pwa-session-state')
}
return {
isPWAEnvironment,
getStoredState,
clearStoredState,
}
}