sw.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. const CACHE_NAME = 'MeeChat_v1.3.4';
  2. let urlsToCache = [];
  3. // let networkFirstList = ['', 'h5.html', 'mini.html'];
  4. let networkFirstList = [];
  5. self.addEventListener('install', function (event) {
  6. self.skipWaiting();
  7. console.log('[ServiceWorker] install')
  8. event.waitUntil(
  9. caches.open(CACHE_NAME).then(function(caches){
  10. console.log('open cache:' + CACHE_NAME);
  11. let allList = urlsToCache.concat(networkFirstList)
  12. return caches.addAll(allList);
  13. })
  14. )
  15. })
  16. self.addEventListener('activate', function (event) {
  17. console.log('[ServiceWorker] activate')
  18. // 只保留白名单的版本
  19. const cacheWhitelist = [CACHE_NAME];
  20. event.waitUntil(
  21. caches.keys().then(function(cacheNames) {
  22. return Promise.all(
  23. cacheNames.map(function(cacheName) {
  24. console.log('遍历缓存:' + cacheName)
  25. if (cacheWhitelist.indexOf(cacheName) === -1) {
  26. console.log('删除缓存:' + cacheName)
  27. return caches.delete(cacheName)
  28. }
  29. })
  30. )
  31. })
  32. )
  33. })
  34. self.addEventListener('fetch', function (event) {
  35. // console.log('[ServiceWorker] Fetch', event.request.url)
  36. let url = event.request.url.replace(location.origin, '')
  37. url = url.replace('https:', '')
  38. let pos = url.indexOf('#')
  39. if (pos > 0) {
  40. url = url.substr(0, pos)
  41. }
  42. if (urlsToCache.indexOf(url) !== -1) {
  43. return _cacheFirst(event)
  44. } else {
  45. return _networkFirst(event)
  46. }
  47. })
  48. function _cacheFirst(event) {
  49. event.respondWith(
  50. caches.match(event.request).then(function (response) {
  51. // Cache hit - return response
  52. if (response) {
  53. return response;
  54. }
  55. return fetch(event.request);
  56. })
  57. );
  58. }
  59. function _networkFirst(event) {
  60. event.respondWith(
  61. fetch(event.request).then((response) => {
  62. // console.log('[ServiceWorker] network first, request: ', event.request.url);
  63. return response
  64. }).catch (() => {
  65. caches.match(event.request).then(function (response) {
  66. // Cache hit - return response
  67. if (response) {
  68. // console.log('[ServiceWorker] cache first, From cache:', event.request.url)
  69. return response;
  70. }
  71. // console.log('[ServiceWorker] cache first, From network:', event.request.url)
  72. return fetch(event.request);
  73. })
  74. })
  75. );
  76. }
  77. self.addEventListener('error', function (event) {
  78. console.log('[ServiceWorker] error', event)
  79. })
  80. self.addEventListener('push', function (event) {
  81. console.log('[Service Worker] 收到通知', event);
  82. function decodeUnicode (str) {
  83. str = str.replace(/\\/g, '%')
  84. str = unescape(str)
  85. str = str.replace(/%/g, '\\')
  86. str = str.replace(/\\/g, '')
  87. return str
  88. }
  89. let data = JSON.parse(event.data.text())
  90. const title = decodeUnicode(data.title)
  91. const options = {
  92. body: decodeUnicode(data.content),
  93. icon: 'img/icons/meechat.png',
  94. tag: data.tag,
  95. data: data.data,
  96. }
  97. event.waitUntil(self.registration.showNotification(title, options))
  98. })
  99. // 点击跳转
  100. self.addEventListener('notificationclick', function (event) {
  101. console.log('[Service Worker] 点击通知', event);
  102. let data = event.notification.data
  103. let url = data && data.url || 'https://mee.chat/'
  104. event.notification.close()
  105. event.waitUntil(
  106. clients.openWindow(url)
  107. )
  108. })