Remove PWA functionality

This commit is contained in:
Benji Grant 2023-06-09 03:29:42 +10:00
parent e426364cfc
commit 028d63992c
5 changed files with 29 additions and 67 deletions

View file

@ -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',
})
)

View file

@ -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 {

View file

@ -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[]

View file

@ -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"