Remove PWA functionality
This commit is contained in:
parent
e426364cfc
commit
028d63992c
|
|
@ -1,67 +1,19 @@
|
||||||
/* eslint-disable no-restricted-globals */
|
// TODO: This is temporary, as I've made the decision to move away
|
||||||
|
// from a PWA, so must remove all existing service workers
|
||||||
|
|
||||||
import { clientsClaim, skipWaiting } from 'workbox-core'
|
self.addEventListener("install", () => {
|
||||||
import { ExpirationPlugin } from 'workbox-expiration'
|
self.skipWaiting()
|
||||||
import { precacheAndRoute, createHandlerBoundToURL, cleanupOutdatedCaches } from 'workbox-precaching'
|
})
|
||||||
import { registerRoute } from 'workbox-routing'
|
|
||||||
import { StaleWhileRevalidate, NetworkFirst } from 'workbox-strategies'
|
|
||||||
|
|
||||||
skipWaiting()
|
self.addEventListener("activate", () => {
|
||||||
clientsClaim()
|
self.registration
|
||||||
|
.unregister()
|
||||||
// Injection point
|
.then(() => self.clients.matchAll())
|
||||||
precacheAndRoute(self.__WB_MANIFEST)
|
.then((clients) => {
|
||||||
|
clients.forEach((client) => {
|
||||||
cleanupOutdatedCaches()
|
if (client.url && "navigate" in client) {
|
||||||
|
client.navigate(client.url)
|
||||||
const fileExtensionRegexp = new RegExp('/[^/?]+\\.[^/]+$')
|
}
|
||||||
registerRoute(
|
})
|
||||||
// Return false to exempt requests from being fulfilled by index.html.
|
})
|
||||||
({ request, url }) => {
|
})
|
||||||
// If this isn't a navigation, skip.
|
|
||||||
if (request.mode !== 'navigate') {
|
|
||||||
return false
|
|
||||||
} // If this is a URL that starts with /_, skip.
|
|
||||||
|
|
||||||
if (url.pathname.startsWith('/_')) {
|
|
||||||
return false
|
|
||||||
} // If this looks like a URL for a resource, because it contains // a file extension, skip.
|
|
||||||
|
|
||||||
if (url.pathname.match(fileExtensionRegexp)) {
|
|
||||||
return false
|
|
||||||
} // Return true to signal that we want to use the handler.
|
|
||||||
|
|
||||||
return true
|
|
||||||
},
|
|
||||||
createHandlerBoundToURL('index.html')
|
|
||||||
)
|
|
||||||
|
|
||||||
registerRoute(
|
|
||||||
// Add in any other file extensions or routing criteria as needed.
|
|
||||||
({ url }) => url.origin === self.location.origin && (
|
|
||||||
url.pathname.endsWith('.png')
|
|
||||||
|| url.pathname.endsWith('.svg')
|
|
||||||
|| url.pathname.endsWith('.jpg')
|
|
||||||
|| url.pathname.endsWith('.jpeg')
|
|
||||||
|| url.pathname.endsWith('.ico')
|
|
||||||
|| url.pathname.endsWith('.ttf')
|
|
||||||
|| url.pathname.endsWith('.woff')
|
|
||||||
|| url.pathname.endsWith('.woff2')
|
|
||||||
), // Customize this strategy as needed, e.g., by changing to CacheFirst.
|
|
||||||
new StaleWhileRevalidate({
|
|
||||||
cacheName: 'res',
|
|
||||||
plugins: [
|
|
||||||
// Ensure that once this runtime cache reaches a maximum size the
|
|
||||||
// least-recently used images are removed.
|
|
||||||
new ExpirationPlugin({ maxEntries: 50 }),
|
|
||||||
],
|
|
||||||
})
|
|
||||||
)
|
|
||||||
|
|
||||||
registerRoute(
|
|
||||||
// Add in any other file extensions or routing criteria as needed.
|
|
||||||
({ url }) => url.origin === self.location.origin && url.pathname.includes('i18n'),
|
|
||||||
new NetworkFirst({
|
|
||||||
cacheName: 'i18n',
|
|
||||||
})
|
|
||||||
)
|
|
||||||
|
|
|
||||||
|
|
@ -1,12 +1,12 @@
|
||||||
import { Fragment, useCallback, useMemo, useRef, useState } from 'react'
|
import { Fragment, useCallback, useMemo, useRef, useState } from 'react'
|
||||||
|
|
||||||
import Content from '/src/components/Content/Content'
|
import Content from '/src/components/Content/Content'
|
||||||
|
import { usePalette } from '/src/hooks/usePalette'
|
||||||
import { useTranslation } from '/src/i18n/client'
|
import { useTranslation } from '/src/i18n/client'
|
||||||
import { useStore } from '/src/stores'
|
import { useStore } from '/src/stores'
|
||||||
import useSettingsStore from '/src/stores/settingsStore'
|
import useSettingsStore from '/src/stores/settingsStore'
|
||||||
import { calculateTable, makeClass } from '/src/utils'
|
import { calculateTable, makeClass } from '/src/utils'
|
||||||
|
|
||||||
import { usePalette } from '/hooks/usePalette'
|
|
||||||
import styles from '../AvailabilityViewer/AvailabilityViewer.module.scss'
|
import styles from '../AvailabilityViewer/AvailabilityViewer.module.scss'
|
||||||
|
|
||||||
interface AvailabilityEditorProps {
|
interface AvailabilityEditorProps {
|
||||||
|
|
|
||||||
|
|
@ -6,13 +6,13 @@ import { Temporal } from '@js-temporal/polyfill'
|
||||||
import Content from '/src/components/Content/Content'
|
import Content from '/src/components/Content/Content'
|
||||||
import Legend from '/src/components/Legend/Legend'
|
import Legend from '/src/components/Legend/Legend'
|
||||||
import { PersonResponse } from '/src/config/api'
|
import { PersonResponse } from '/src/config/api'
|
||||||
|
import { usePalette } from '/src/hooks/usePalette'
|
||||||
import { useTranslation } from '/src/i18n/client'
|
import { useTranslation } from '/src/i18n/client'
|
||||||
import { useStore } from '/src/stores'
|
import { useStore } from '/src/stores'
|
||||||
import useSettingsStore from '/src/stores/settingsStore'
|
import useSettingsStore from '/src/stores/settingsStore'
|
||||||
import { calculateAvailability, calculateTable, makeClass, relativeTimeFormat } from '/src/utils'
|
import { calculateAvailability, calculateTable, makeClass, relativeTimeFormat } from '/src/utils'
|
||||||
|
|
||||||
import styles from './AvailabilityViewer.module.scss'
|
import styles from './AvailabilityViewer.module.scss'
|
||||||
import { usePalette } from '/hooks/usePalette'
|
|
||||||
|
|
||||||
interface AvailabilityViewerProps {
|
interface AvailabilityViewerProps {
|
||||||
times: string[]
|
times: string[]
|
||||||
|
|
|
||||||
|
|
@ -41,6 +41,16 @@ const Settings = () => {
|
||||||
document.body.classList.toggle('dark', store?.theme === 'Dark')
|
document.body.classList.toggle('dark', store?.theme === 'Dark')
|
||||||
}, [store?.theme])
|
}, [store?.theme])
|
||||||
|
|
||||||
|
// TODO: This is temporary, as I've made the decision to move away
|
||||||
|
// from a PWA, so must remove all existing service workers
|
||||||
|
if (process.env.NODE_ENV !== 'development') {
|
||||||
|
useEffect(() => {
|
||||||
|
if ('serviceWorker' in navigator) {
|
||||||
|
navigator.serviceWorker.register('/sw.js')
|
||||||
|
}
|
||||||
|
}, [])
|
||||||
|
}
|
||||||
|
|
||||||
return <>
|
return <>
|
||||||
<button
|
<button
|
||||||
type="button"
|
type="button"
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue