mirror of
https://github.com/elk-zone/elk.git
synced 2024-11-22 01:15:25 +03:00
38 lines
928 B
TypeScript
38 lines
928 B
TypeScript
|
import lifecycle from 'page-lifecycle/dist/lifecycle.mjs'
|
||
|
import { ELK_PAGE_LIFECYCLE_FROZEN } from '~/constants'
|
||
|
import { closeDatabases } from '~/utils/elk-idb'
|
||
|
|
||
|
export default defineNuxtPlugin(() => {
|
||
|
const state = ref(lifecycle.state)
|
||
|
const frozenListeners: (() => void)[] = []
|
||
|
|
||
|
lifecycle.addEventListener('statechange', (evt) => {
|
||
|
if (evt.newState === 'freeze')
|
||
|
frozenListeners.forEach(listener => listener())
|
||
|
else
|
||
|
state.value = evt.newState
|
||
|
})
|
||
|
|
||
|
const addFrozenListener = (listener: () => void) => {
|
||
|
frozenListeners.push(listener)
|
||
|
}
|
||
|
|
||
|
if (useAppConfig().pwaEnabled) {
|
||
|
addFrozenListener(() => {
|
||
|
if (navigator.serviceWorker.controller)
|
||
|
navigator.serviceWorker.controller.postMessage(ELK_PAGE_LIFECYCLE_FROZEN)
|
||
|
|
||
|
closeDatabases()
|
||
|
})
|
||
|
}
|
||
|
|
||
|
return {
|
||
|
provide: {
|
||
|
pageLifecycle: reactive({
|
||
|
state,
|
||
|
addFrozenListener,
|
||
|
}),
|
||
|
},
|
||
|
}
|
||
|
})
|