mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-21 20:47:08 -05:00
61 lines
1.3 KiB
JavaScript
61 lines
1.3 KiB
JavaScript
|
import { useEffect, useState } from 'react'
|
||
|
|
||
|
let titleIsFlashing = false
|
||
|
let originalTitle
|
||
|
let flashIntervalHandle
|
||
|
|
||
|
export function flashTitle(message) {
|
||
|
if (document.hasFocus() || titleIsFlashing) {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
function swapTitle() {
|
||
|
if (window.document.title === originalTitle) {
|
||
|
window.document.title = message
|
||
|
} else {
|
||
|
window.document.title = originalTitle
|
||
|
}
|
||
|
}
|
||
|
|
||
|
originalTitle = window.document.title
|
||
|
window.document.title = message
|
||
|
titleIsFlashing = true
|
||
|
flashIntervalHandle = setInterval(swapTitle, 800)
|
||
|
}
|
||
|
|
||
|
export function stopFlashingTitle() {
|
||
|
if (!titleIsFlashing) {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
clearInterval(flashIntervalHandle)
|
||
|
window.document.title = originalTitle
|
||
|
originalTitle = undefined
|
||
|
titleIsFlashing = false
|
||
|
}
|
||
|
|
||
|
function useBrowserWindow() {
|
||
|
const [hasFocus, setHasFocus] = useState(document.hasFocus())
|
||
|
|
||
|
useEffect(() => {
|
||
|
function handleFocusEvent() {
|
||
|
setHasFocus(true)
|
||
|
}
|
||
|
|
||
|
function handleBlurEvent() {
|
||
|
setHasFocus(false)
|
||
|
}
|
||
|
|
||
|
window.addEventListener('focus', handleFocusEvent)
|
||
|
window.addEventListener('blur', handleBlurEvent)
|
||
|
return () => {
|
||
|
window.removeEventListener('focus', handleFocusEvent)
|
||
|
window.removeEventListener('blur', handleBlurEvent)
|
||
|
}
|
||
|
}, [])
|
||
|
|
||
|
return { hasFocus, flashTitle, stopFlashingTitle }
|
||
|
}
|
||
|
|
||
|
export default useBrowserWindow
|