const CACHE_NAME = 'mindshift-v1'; const urlsToCache = [ '/', '/cbt-therapy-app-mockup.html', '/manifest.json' ]; // Install event - cache resources self.addEventListener('install', function(event) { event.waitUntil( caches.open(CACHE_NAME) .then(function(cache) { console.log('Opened cache'); return cache.addAll(urlsToCache); }) ); }); // Fetch event - serve from cache when offline self.addEventListener('fetch', function(event) { event.respondWith( caches.match(event.request) .then(function(response) { // Cache hit - return response if (response) { return response; } // Clone the request var fetchRequest = event.request.clone(); return fetch(fetchRequest).then( function(response) { // Check if valid response if(!response || response.status !== 200 || response.type !== 'basic') { return response; } // Clone the response var responseToCache = response.clone(); caches.open(CACHE_NAME) .then(function(cache) { cache.put(event.request, responseToCache); }); return response; } ).catch(function() { // Offline fallback for HTML pages if (event.request.destination === 'document') { return caches.match('/cbt-therapy-app-mockup.html'); } }); }) ); }); // Activate event - clean up old caches self.addEventListener('activate', function(event) { event.waitUntil( caches.keys().then(function(cacheNames) { return Promise.all( cacheNames.map(function(cacheName) { if (cacheName !== CACHE_NAME) { console.log('Deleting old cache:', cacheName); return caches.delete(cacheName); } }) ); }) ); }); // Background sync for offline actions self.addEventListener('sync', function(event) { if (event.tag === 'background-sync') { event.waitUntil(doBackgroundSync()); } }); function doBackgroundSync() { // Handle syncing offline data when back online return Promise.resolve(); } // Push notification handler self.addEventListener('push', function(event) { const options = { body: event.data ? event.data.text() : 'Time for your CBT exercise!', icon: '/', badge: '/', vibrate: [100, 50, 100], data: { dateOfArrival: Date.now(), primaryKey: 1 }, actions: [ { action: 'explore', title: 'Open App', icon: '/' }, { action: 'close', title: 'Dismiss', icon: '/' } ] }; event.waitUntil( self.registration.showNotification('MindShift', options) ); }); // Notification click handler self.addEventListener('notificationclick', function(event) { event.notification.close(); if (event.action === 'explore') { // Open the app event.waitUntil( clients.openWindow('/') ); } });