Kgshop commited on
Commit
28b130d
·
verified ·
1 Parent(s): 3a3266a

Update service-worker.js

Browse files
Files changed (1) hide show
  1. service-worker.js +21 -10
service-worker.js CHANGED
@@ -40,19 +40,14 @@ self.addEventListener('activate', (event) => {
40
  self.addEventListener('fetch', (event) => {
41
  const requestUrl = new URL(event.request.url);
42
 
43
- // Пропускаем запросы к внешнему iframe
44
  if (requestUrl.origin !== self.location.origin) {
45
- console.log('Пропускаем внешний запрос:', requestUrl.href);
46
- event.respondWith(
47
- fetch(event.request).catch((error) => {
48
- console.error('Ошибка при внешнем запросе:', error);
49
- return new Response('Network error occurred', { status: 503 });
50
- })
51
- );
52
  return;
53
  }
54
 
55
- // Для навигационных запросов
56
  if (event.request.mode === 'navigate') {
57
  event.respondWith(
58
  caches.match('/index.html').then((response) => {
@@ -63,15 +58,31 @@ self.addEventListener('fetch', (event) => {
63
  // Для локальных ресурсов используем Cache First
64
  event.respondWith(
65
  caches.match(event.request).then((response) => {
66
- return response || fetch(event.request).then((networkResponse) => {
 
 
 
 
 
 
 
67
  if (requestUrl.origin === self.location.origin) {
68
  return caches.open(CACHE_NAME).then((cache) => {
69
  cache.put(event.request, networkResponse.clone());
70
  return networkResponse;
71
  });
72
  }
 
73
  return networkResponse;
74
  });
 
 
 
 
 
 
 
 
75
  })
76
  );
77
  }
 
40
  self.addEventListener('fetch', (event) => {
41
  const requestUrl = new URL(event.request.url);
42
 
43
+ // Пропускаем запросы к внешнему iframe. Кэшируем их стандартным образом браузера.
44
  if (requestUrl.origin !== self.location.origin) {
45
+ console.log('Пропускаем внешний запрос (не кэшируем через SW):', requestUrl.href);
46
+ // Используем стандартный fetch, не вмешиваясь. Браузер сам разберется с кэшированием.
 
 
 
 
 
47
  return;
48
  }
49
 
50
+ // Для навигационных запросов (это запросы к index.html)
51
  if (event.request.mode === 'navigate') {
52
  event.respondWith(
53
  caches.match('/index.html').then((response) => {
 
58
  // Для локальных ресурсов используем Cache First
59
  event.respondWith(
60
  caches.match(event.request).then((response) => {
61
+ // Возвращаем кэшированный ресурс, если есть.
62
+ if (response) {
63
+ return response;
64
+ }
65
+
66
+ // Если ресурса нет в кэше, делаем сетевой запрос.
67
+ return fetch(event.request).then((networkResponse) => {
68
+ // Если запрос с нашего origin, кэшируем ответ.
69
  if (requestUrl.origin === self.location.origin) {
70
  return caches.open(CACHE_NAME).then((cache) => {
71
  cache.put(event.request, networkResponse.clone());
72
  return networkResponse;
73
  });
74
  }
75
+ // Если запрос не с нашего origin, просто возвращаем ответ (не кэшируем в SW).
76
  return networkResponse;
77
  });
78
+ }).catch(error => {
79
+ // Обработка ошибок, если и кэш недоступен, и сеть.
80
+ console.error("Fetch failed:", error);
81
+ // Можно вернуть страницу-заглушку об ошибке.
82
+ return new Response('<h1>Offline</h1><p>Sorry, the content is not available offline.</p>', {
83
+ headers: { 'Content-Type': 'text/html' }
84
+ });
85
+
86
  })
87
  );
88
  }