Skip to content

Commit

Permalink
feat: integrate vite-plugin-pwa plugin
Browse files Browse the repository at this point in the history
  • Loading branch information
flingyp committed Sep 12, 2023
1 parent cf33e1f commit dd74d6b
Show file tree
Hide file tree
Showing 16 changed files with 5,207 additions and 95 deletions.
68 changes: 68 additions & 0 deletions build/plugins.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import Icons from 'unplugin-icons/vite'
import IconsResolver from 'unplugin-icons/resolver'
import { NaiveUiResolver } from 'unplugin-vue-components/resolvers'
import viteCDNPlugin from 'vite-plugin-cdn-import'
import { VitePWA } from 'vite-plugin-pwa'

import { name, version } from '../package.json'

Expand Down Expand Up @@ -116,4 +117,71 @@ export const generatePlugins = (command: string, mode: string): PluginOption[] =
// Vite >= 2.9.0+ automatically splits vendor chunks when using the build command.
// Reference: https://cn.vitejs.dev/guide/build.html#chunking-strategy
// splitVendorChunkPlugin(),
VitePWA({
registerType: 'autoUpdate',
includeAssets: ['favicon.ico', 'logo.svg', '/pwa/180.png'],
devOptions: {
enabled: true,
},
manifest: {
name: 'VAdmire Admin',
short_name: 'VAdmire',
description: 'VAdmire Admin 是一款基于 Vue3 + TypeScript + NaiveUI 等技术栈搭建的后台系统',
theme_color: '#ffffff',
icons: [
{
src: 'pwa/128.png',
sizes: '128x128',
type: 'image/png',
},
{
src: 'pwa/144.png',
sizes: '144x144',
type: 'image/png',
},
{
src: 'pwa/152.png',
sizes: '152x152',
type: 'image/png',
},
{
src: 'pwa/167.png',
sizes: '167x167',
type: 'image/png',
},
{
src: 'pwa/180.png',
sizes: '180x180',
type: 'image/png',
},
{
src: 'pwa/192.png',
sizes: '192x192',
type: 'image/png',
},
{
src: 'pwa/256.png',
sizes: '256x256',
type: 'image/png',
},
{
src: 'pwa/512.png',
sizes: '512x512',
type: 'image/png',
},
{
src: 'pwa/512.png',
sizes: '512x512',
type: 'image/png',
purpose: 'any',
},
{
src: 'pwa/512.png',
sizes: '512x512',
type: 'image/png',
purpose: 'maskable',
},
],
},
}),
]
1 change: 1 addition & 0 deletions dev-dist/registerSW.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

92 changes: 92 additions & 0 deletions dev-dist/sw.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
/**
* Copyright 2018 Google Inc. All Rights Reserved.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

// If the loader is already loaded, just stop.
if (!self.define) {
let registry = {};

// Used for `eval` and `importScripts` where we can't get script URL by other means.
// In both cases, it's safe to use a global var because those functions are synchronous.
let nextDefineUri;

const singleRequire = (uri, parentUri) => {
uri = new URL(uri + ".js", parentUri).href;
return registry[uri] || (

new Promise(resolve => {
if ("document" in self) {
const script = document.createElement("script");
script.src = uri;
script.onload = resolve;
document.head.appendChild(script);
} else {
nextDefineUri = uri;
importScripts(uri);
resolve();
}
})

.then(() => {
let promise = registry[uri];
if (!promise) {
throw new Error(`Module ${uri} didn’t register its module`);
}
return promise;
})
);
};

self.define = (depsNames, factory) => {
const uri = nextDefineUri || ("document" in self ? document.currentScript.src : "") || location.href;
if (registry[uri]) {
// Module is already loading or loaded.
return;
}
let exports = {};
const require = depUri => singleRequire(depUri, uri);
const specialDeps = {
module: { uri },
exports,
require
};
registry[uri] = Promise.all(depsNames.map(
depName => specialDeps[depName] || require(depName)
)).then(deps => {
factory(...deps);
return exports;
});
};
}
define(['./workbox-ab7aa862'], (function (workbox) { 'use strict';

self.skipWaiting();
workbox.clientsClaim();

/**
* The precacheAndRoute() method efficiently caches and responds to
* requests for URLs in the manifest.
* See https://goo.gl/S9QRab
*/
workbox.precacheAndRoute([{
"url": "registerSW.js",
"revision": "3ca0b8505b4bec776b69afdba2768812"
}, {
"url": "index.html",
"revision": "0.kmkb1uarnq"
}], {});
workbox.cleanupOutdatedCaches();
workbox.registerRoute(new workbox.NavigationRoute(workbox.createHandlerBoundToURL("index.html"), {
allowlist: [/^\/$/]
}));

}));

0 comments on commit dd74d6b

Please sign in to comment.