Spaces:
Sleeping
Sleeping
| const CACHE_NAME = 'mtextile-v3'; | |
| const ASSETS = [ | |
| '/', | |
| '/index.html', | |
| '/catalog.html', | |
| '/product.html', | |
| '/cart.html', | |
| '/checkout.html', | |
| '/wishlist.html', | |
| '/profile.html', | |
| '/css/global.css', | |
| '/css/components.css', | |
| '/css/pages.css', | |
| '/js/store.js', | |
| '/js/products.js', | |
| '/js/app.js' | |
| ]; | |
| self.addEventListener('install', (event) => { | |
| event.waitUntil( | |
| caches.open(CACHE_NAME) | |
| .then((cache) => cache.addAll(ASSETS)) | |
| ); | |
| self.skipWaiting(); | |
| }); | |
| self.addEventListener('activate', (event) => { | |
| event.waitUntil( | |
| caches.keys().then(keys => | |
| Promise.all(keys.filter(k => k !== CACHE_NAME).map(k => caches.delete(k))) | |
| ) | |
| ); | |
| self.clients.claim(); | |
| }); | |
| self.addEventListener('fetch', (event) => { | |
| // Network First Strategy | |
| event.respondWith( | |
| fetch(event.request) | |
| .then((response) => { | |
| const clone = response.clone(); | |
| // Cache the fresh response | |
| caches.open(CACHE_NAME).then(cache => cache.put(event.request, clone)); | |
| return response; | |
| }) | |
| .catch(() => { | |
| // Return fallback from cache if offline | |
| return caches.match(event.request); | |
| }) | |
| ); | |
| }); | |