mirror of
https://github.com/kremalicious/portfolio.git
synced 2024-11-14 17:15:15 +01:00
37 lines
1.2 KiB
JavaScript
37 lines
1.2 KiB
JavaScript
import wrapPageElementWithLayout from './src/helpers/wrapPageElement'
|
|
|
|
// Global styles
|
|
import './src/styles/global.css'
|
|
import './src/styles/_toast.css'
|
|
|
|
// IntersectionObserver polyfill for gatsby-image (Safari, IE)
|
|
if (typeof window !== 'undefined' && !window.IntersectionObserver) {
|
|
import('intersection-observer')
|
|
}
|
|
|
|
// Layout with Page Transitions
|
|
export const wrapPageElement = wrapPageElementWithLayout
|
|
|
|
export const shouldUpdateScroll = ({
|
|
routerProps: { location },
|
|
getSavedScrollPosition
|
|
}) => {
|
|
if (location.action === 'PUSH') {
|
|
window.setTimeout(() => window.scrollTo(0, 0), 200)
|
|
} else {
|
|
const savedPosition = getSavedScrollPosition(location)
|
|
window.setTimeout(() => window.scrollTo(...(savedPosition || [0, 0])), 200)
|
|
}
|
|
return false
|
|
}
|
|
|
|
// Display a message when a service worker updates
|
|
// https://www.gatsbyjs.org/docs/add-offline-support-with-a-service-worker/#displaying-a-message-when-a-service-worker-updates
|
|
export const onServiceWorkerUpdateReady = () => {
|
|
const div = document.createElement('div')
|
|
div.id = 'toast'
|
|
div.classList.add('alert', 'alert-info')
|
|
div.innerHTML = `<button onClick="window.location.reload()">Updates are available. <span>Click to Reload</span>.</button>`
|
|
document.body.append(div)
|
|
}
|