-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsw-fix.js
More file actions
80 lines (71 loc) · 2.06 KB
/
sw-fix.js
File metadata and controls
80 lines (71 loc) · 2.06 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
const CACHE_NAME = 'pope-game-cache-v1';
// Get base path for GitHub Pages
function getBasePath() {
// Check if we're on GitHub Pages
if (self.location.hostname.includes('github.io')) {
const pathSegments = self.location.pathname.split('/');
if (pathSegments.length > 1) {
return '/' + pathSegments[1]; // Repository name
}
}
return '';
}
const BASE_PATH = getBasePath();
// Dynamic URLs to cache based on environment
const urlsToCache = [
BASE_PATH + '/',
BASE_PATH + '/index.html',
BASE_PATH + '/styles.css',
BASE_PATH + '/game.js',
BASE_PATH + '/sw.js',
BASE_PATH + '/favicon.ico',
BASE_PATH + '/assets/medieval_village.png',
BASE_PATH + '/assets/villager.png',
BASE_PATH + '/assets/lamp_icon.png',
BASE_PATH + '/assets/plant_icon.png',
BASE_PATH + '/assets/question_mark.png'
];
self.addEventListener('install', event => {
event.waitUntil(
caches.open(CACHE_NAME)
.then(cache => cache.addAll(urlsToCache))
.then(() => self.skipWaiting())
);
});
self.addEventListener('fetch', event => {
// Handle GitHub Pages base path
let requestUrl = event.request.url;
event.respondWith(
caches.match(event.request)
.then(response => {
if (response) {
return response;
}
return fetch(event.request)
.then(networkResponse => {
if (!networkResponse || networkResponse.status !== 200 || networkResponse.type !== 'basic') {
return networkResponse;
}
const clonedResponse = networkResponse.clone();
caches.open(CACHE_NAME)
.then(cache => cache.put(event.request, clonedResponse));
return networkResponse;
});
})
);
});
self.addEventListener('activate', event => {
event.waitUntil(
caches.keys()
.then(cacheNames => {
return Promise.all(
cacheNames.map(name => {
if (name !== CACHE_NAME) {
return caches.delete(name);
}
})
);
})
.then(() => self.clients.claim())
);
});