74 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
var dataCacheName = 'PSM-v1';
 | 
						|
var cacheName = 'PSM-PWA-final-1';
 | 
						|
var filesToCache = [
 | 
						|
  '',
 | 
						|
  'index.php',
 | 
						|
  'src/templates/default/static/js/history.js',
 | 
						|
  'src/templates/default/static/js/scripts.js',
 | 
						|
  'src/templates/default/static/js/search.js',
 | 
						|
  'src/templates/default/static/css/bootstrap.min.css',
 | 
						|
  'src/templates/default/static/css/search.min.css',
 | 
						|
  'src/templates/default/static/css/style.min.css',
 | 
						|
  'phpservermon.png'
 | 
						|
];
 | 
						|
 | 
						|
self.addEventListener('install', function(e) {
 | 
						|
  console.log('[ServiceWorker] Install');
 | 
						|
  e.waitUntil(
 | 
						|
    caches.open(cacheName).then(function(cache) {
 | 
						|
      console.log('[ServiceWorker] Caching app shell');
 | 
						|
      return cache.addAll(filesToCache);
 | 
						|
    })
 | 
						|
  );
 | 
						|
});
 | 
						|
 | 
						|
self.addEventListener('activate', function(e) {
 | 
						|
  console.log('[ServiceWorker] Activate');
 | 
						|
  e.waitUntil(
 | 
						|
    caches.keys().then(function(keyList) {
 | 
						|
      return Promise.all(keyList.map(function(key) {
 | 
						|
        if (key !== cacheName && key !== dataCacheName) {
 | 
						|
          console.log('[ServiceWorker] Removing old cache', key);
 | 
						|
          return caches.delete(key);
 | 
						|
        }
 | 
						|
      }));
 | 
						|
    })
 | 
						|
  );
 | 
						|
  return self.clients.claim();
 | 
						|
});
 | 
						|
 | 
						|
/*self.addEventListener('fetch', function(e) {
 | 
						|
  console.log('[Service Worker] Fetch', e.request.url);
 | 
						|
  var dataUrl = 'https://query.yahooapis.com/v1/public/yql';
 | 
						|
  if (e.request.url.indexOf(dataUrl) > -1) {
 | 
						|
    /*
 | 
						|
     * When the request URL contains dataUrl, the app is asking for fresh
 | 
						|
     * weather data. In this case, the service worker always goes to the
 | 
						|
     * network and then caches the response. This is called the "Cache then
 | 
						|
     * network" strategy:
 | 
						|
     * https://jakearchibald.com/2014/offline-cookbook/#cache-then-network
 | 
						|
     */
 | 
						|
    /*
 | 
						|
    e.respondWith(
 | 
						|
      caches.open(dataCacheName).then(function(cache) {
 | 
						|
        return fetch(e.request).then(function(response){
 | 
						|
          cache.put(e.request.url, response.clone());
 | 
						|
          return response;
 | 
						|
        });
 | 
						|
      })
 | 
						|
    );
 | 
						|
  } else {
 | 
						|
    /*
 | 
						|
     * The app is asking for app shell files. In this scenario the app uses the
 | 
						|
     * "Cache, falling back to the network" offline strategy:
 | 
						|
     * https://jakearchibald.com/2014/offline-cookbook/#cache-falling-back-to-network
 | 
						|
     */
 | 
						|
    /*
 | 
						|
    e.respondWith(
 | 
						|
      caches.match(e.request).then(function(response) {
 | 
						|
        return response || fetch(e.request);
 | 
						|
      })
 | 
						|
    );
 | 
						|
  }
 | 
						|
});*/
 |