sw.js 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. const CACHE_NAME = 'MeeChat_v1.3.2';
  2. let urlsToCache = ["//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-063fcdb8.7be96541.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-09f52bd0.ca822529.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-13ce04b3.c32784d3.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-1a0d9872.38acc50c.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-3028e170.7b7b6769.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-352466e2.33bf20c7.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-4031c6b3.7da7025b.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-406bac5b.09a98095.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-580cf024.3e00a85d.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-5a6c5be1.5efbb31d.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-5edd596e.b281c6c1.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-60cf0727.8aef334d.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-6361f770.e85683b9.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-6c021ec0.2806d288.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-6f498702.a8887c6a.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-70ed3fb8.1e2497e0.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-81a02e6e.3f6e1708.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-9c4fb57e.64cec1de.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-af4b672c.7675f3ca.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-b17cf818.1737301f.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-common.54d70dac.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-e1f20b62.85f54eab.css","//static.meechat.me/cdn/new.mee.chat/dist/css/chunk-vendors.3c668f4e.css","//static.meechat.me/cdn/new.mee.chat/dist/css/h5.2b5c3223.css","//static.meechat.me/cdn/new.mee.chat/dist/css/mini.0dd5dfbc.css","//static.meechat.me/cdn/new.mee.chat/dist/css/pc.f971b1c8.css","//static.meechat.me/cdn/new.mee.chat/dist/favicon.ico","//static.meechat.me/cdn/new.mee.chat/dist/fonts/element-icons.2fad952a.woff","//static.meechat.me/cdn/new.mee.chat/dist/fonts/element-icons.6f0a7632.ttf","/h5.html","//static.meechat.me/cdn/new.mee.chat/dist/img/bg.261295d3.jpg","//static.meechat.me/cdn/new.mee.chat/dist/img/bg.71de928a.jpg","//static.meechat.me/cdn/new.mee.chat/dist/img/bg.eb029f3a.png","//static.meechat.me/cdn/new.mee.chat/dist/img/bg2.0b28333d.png","//static.meechat.me/cdn/new.mee.chat/dist/img/h5_bg.e9487380.png","//static.meechat.me/cdn/new.mee.chat/dist/img/h5_bg2.21b33271.png","//static.meechat.me/cdn/new.mee.chat/dist/img/h5_bg3.6f597ff4.png","//static.meechat.me/cdn/new.mee.chat/dist/img/icon-meetone.f0168873.png","//static.meechat.me/cdn/new.mee.chat/dist/img/icon-tele.0c036f6a.png","//static.meechat.me/cdn/new.mee.chat/dist/img/icon-tele.88177f4a.png","//static.meechat.me/cdn/new.mee.chat/dist/img/icons/meechat.png","//static.meechat.me/cdn/new.mee.chat/dist/img/icons/meechat_icon.png","//static.meechat.me/cdn/new.mee.chat/dist/img/icons/safari-pinned-tab.svg","//static.meechat.me/cdn/new.mee.chat/dist/img/loading.b4490fa6.gif","//static.meechat.me/cdn/new.mee.chat/dist/img/login-logo.6f40e8ff.png","//static.meechat.me/cdn/new.mee.chat/dist/img/user-ethereum-icon.fdf8b24e.png","//static.meechat.me/cdn/new.mee.chat/dist/img/user-tron-icon.92300839.png","/index.html","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-063fcdb8.bac5db7e.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-09f52bd0.1022935b.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-13ce04b3.3d9aed15.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-1a0d9872.8dd920a5.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-3028e170.a21fdc99.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-352466e2.9344c940.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-4031c6b3.58ec51e9.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-406bac5b.118e6b56.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-437e2b39.45c774a4.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-580cf024.9ca44538.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-5a6c5be1.f6992ba5.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-5edd596e.854a7784.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-60cf0727.cf39f81a.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-6361f770.5b4fc403.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-6c021ec0.0b513db1.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-6f498702.f80fb386.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-70ed3fb8.d66fdf82.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-81a02e6e.a9581797.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-9c4fb57e.1eba2450.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-af4b672c.2142fe06.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-b17cf818.c15f8f84.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-common.f2787976.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-d42f0a14.8b90832e.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-e1f20b62.b5ec5e17.js","//static.meechat.me/cdn/new.mee.chat/dist/js/chunk-vendors.8a48f48a.js","//static.meechat.me/cdn/new.mee.chat/dist/js/h5.67c139d5.js","//static.meechat.me/cdn/new.mee.chat/dist/js/mini.23670eeb.js","//static.meechat.me/cdn/new.mee.chat/dist/js/pc.29cdb715.js","/manifest_h5.json","/manifest_pc.json","/mini.html","/pc.html","//static.meechat.me/cdn/new.mee.chat/dist/robots.txt","//static.meechat.me/cdn/new.mee.chat/dist/sw.js"];
  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. })