File size: 3,329 Bytes
3e8a166
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
87
88
89
90
91
92
// management/templates/management/service-worker.js
// -*- coding: utf-8 -*-
console.log('Service Worker Loaded and Ready.');

// CACHE_NAME را برای مدیریت نسخه‌ها تغییر دهید
const CACHE_NAME = 'marzban-pwa-cache-v1.0';

// فایل‌هایی که باید در زمان نصب Service Worker کش شوند
const urlsToCache = [
    '/',
    '/dashboard/',
    '/static/js/main.js',
    '/static/css/styles.css',
    '/static/images/icons/icon-192x192.png',
    '/static/images/icons/icon-512x512.png',
    '/manifest.json'
];

self.addEventListener('install', (event) => {
    console.log('Service Worker: Install event.');
    // در زمان نصب، فایل‌های اصلی را در حافظه کش ذخیره می‌کنیم
    event.waitUntil(
        caches.open(CACHE_NAME)
            .then((cache) => {
                console.log('Opened cache');
                return cache.addAll(urlsToCache);
            })
    );
});

self.addEventListener('activate', (event) => {
    console.log('Service Worker: Activate event.');
    // پاک کردن کش‌های قدیمی
    event.waitUntil(
        caches.keys().then((cacheNames) => {
            return Promise.all(
                cacheNames.map((cacheName) => {
                    if (cacheName !== CACHE_NAME) {
                        console.log('Service Worker: Deleting old cache: ', cacheName);
                        return caches.delete(cacheName);
                    }
                })
            );
        })
    );
});

self.addEventListener('fetch', (event) => {
    // برای درخواست‌های شبکه، ابتدا کش را بررسی می‌کنیم و در صورت عدم وجود، درخواست شبکه می‌زنیم
    event.respondWith(
        caches.match(event.request).then((response) => {
            // اگر در کش بود، همان را برمی‌گردانیم
            if (response) {
                return response;
            }
            // اگر در کش نبود، درخواست شبکه می‌زنیم
            return fetch(event.request);
        })
    );
});

self.addEventListener('push', (event) => {
    const data = event.data.json();
    console.log('Push received...', data);

    const title = data.head || 'نوتیفیکیشن جدید';
    const options = {
        body: data.body,
        icon: data.icon || '/static/images/icons/icon-192x192.png',
        // الگوی لرزش: 200ms لرزش، 100ms مکث، 200ms لرزش
        vibrate: data.vibrate || [200, 100, 200],
        // پخش صدای پیش‌فرض سیستم
        // توجه: پخش فایل صوتی سفارشی در مرورگرها به طور کامل پشتیبانی نمی‌شود.
        // مرورگرها از صدای پیش‌فرض سیستم برای نوتیفیکیشن استفاده می‌کنند.
        sound: data.sound || undefined,
        badge: '/static/images/icons/badge-72x72.png'
    };

    event.waitUntil(
        self.registration.showNotification(title, options)
    );
});

self.addEventListener('notificationclick', (event) => {
    console.log('Notification clicked', event);
    event.notification.close();
    event.waitUntil(
        clients.openWindow('https://your-panel-address.com/dashboard/')
    );
});