File size: 2,874 Bytes
6c4a603
1da815e
9daf3ee
6c4a603
 
1da815e
 
 
9daf3ee
 
 
 
 
 
 
 
 
 
 
 
1da815e
 
 
 
 
 
 
 
 
 
 
 
6c4a603
 
1da815e
 
 
 
 
 
 
 
6c4a603
 
 
 
1da815e
 
 
 
9daf3ee
1da815e
 
 
 
 
 
 
6c4a603
 
 
 
1da815e
 
 
9daf3ee
1da815e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
81
82
83
84
85
86
const CACHE_NAME = 'my-cache-v1';
let cachedFiles = [
    '/index.html' // index.htmlは常にキャッシュ
];

// メッセージ受信処理
self.addEventListener('message', (event) => {
    if (event.data && event.data.type === 'CACHE_FILES') {
        cachedFiles = ['/index.html', ...event.data.files]; // index.htmlは常に含める
        
        // チェックボックスの状態を保存
        if (event.data.checkboxStates) {
            event.waitUntil(
                caches.open('settings-cache').then(cache => {
                    return cache.put(
                        new Request('checkbox-states'),
                        new Response(JSON.stringify(event.data.checkboxStates))
                })
            );
        }
        
        // 新しいキャッシュリストでキャッシュを更新
        event.waitUntil(
            caches.open(CACHE_NAME).then(cache => {
                return cache.addAll(cachedFiles).catch(error => {
                    console.error('キャッシュ追加エラー:', error);
                });
            })
        );
    }
});

// インストール:キャッシュを保存
self.addEventListener('install', event => {
    event.waitUntil(
        caches.open(CACHE_NAME).then(cache => {
            return cache.addAll(cachedFiles).catch(error => {
                console.error('初期キャッシュエラー:', error);
            });
        })
    );
    self.skipWaiting(); // すぐに有効化
});

// アクティベート:古いキャッシュ削除
self.addEventListener('activate', event => {
    event.waitUntil(
        caches.keys().then(keys =>
            Promise.all(
                keys.map(key => {
                    if (key !== CACHE_NAME && key !== 'settings-cache') {
                        return caches.delete(key);
                    }
                })
            )
        )
    );
    self.clients.claim(); // 即時制御
});

// フェッチ:ネット優先、失敗時にキャッシュ
self.addEventListener('fetch', event => {
    const url = new URL(event.request.url);
    const path = url.pathname;
    
    // キャッシュリストにないファイルはキャッシュしない
    if (!cachedFiles.includes(path)) {
        return fetch(event.request);
    }

    event.respondWith(
        fetch(event.request)
            .then(response => {
                // ネットから取得できたのでキャッシュ更新
                const responseClone = response.clone();
                caches.open(CACHE_NAME).then(cache => {
                    cache.put(event.request, responseClone);
                });
                return response;
            })
            .catch(() => {
                // ネットがだめならキャッシュから
                return caches.match(event.request);
            })
    );
});