33 lines
930 B
JavaScript
33 lines
930 B
JavaScript
|
import debounce from 'lodash/debounce'
|
||
|
import { toast } from '../../_utils/toast'
|
||
|
|
||
|
const OFFLINE_DELAY = 1000
|
||
|
|
||
|
const notifyOffline = debounce(() => {
|
||
|
toast.say('You seem to be offline. You can still read toots while offline.')
|
||
|
}, OFFLINE_DELAY)
|
||
|
|
||
|
export function onlineObservers(store) {
|
||
|
if (!process.browser) {
|
||
|
return
|
||
|
}
|
||
|
let meta = document.getElementById('theThemeColor')
|
||
|
let oldTheme = meta.content
|
||
|
|
||
|
store.observe('online', online => {
|
||
|
document.body.classList.toggle('offline', !online)
|
||
|
if (online) {
|
||
|
meta.content = oldTheme
|
||
|
} else {
|
||
|
let offlineThemeColor = window.__themeColors.offline
|
||
|
if (meta.content !== offlineThemeColor) {
|
||
|
oldTheme = meta.content
|
||
|
}
|
||
|
meta.content = offlineThemeColor
|
||
|
notifyOffline()
|
||
|
}
|
||
|
})
|
||
|
|
||
|
window.addEventListener('offline', () => store.set({online: false}))
|
||
|
window.addEventListener('online', () => store.set({online: true}))
|
||
|
}
|