test VitePWA new config

This commit is contained in:
Romulus21
2024-02-25 14:54:46 +01:00
parent ffc4bb0678
commit 05644918cc
5 changed files with 96 additions and 47 deletions

View File

@@ -4,47 +4,92 @@ import react from '@vitejs/plugin-react';
import copy from "rollup-plugin-copy";
import { VitePWA } from 'vite-plugin-pwa'
export default () => {
const manifestIcons = [
{
src: '/pwa-64x64.png',
sizes: '64x64',
type: 'image/png'
},
{
src: '/pwa-192x192.png',
sizes: '192x192',
type: 'image/png'
},
{
src: '/pwa-512x512.png',
sizes: '512x512',
type: 'image/png',
purpose: 'any'
},
{
src: '/maskable-icon-512x512.png',
sizes: '512x512',
type: 'image/png',
purpose: 'maskable'
},
]
const publicIcons = [
{ src: '/favicon.ico' },
{ src: '/favicon.svg' },
{ src: '/apple-touch-icon-180x180.png' }
]
const additionalImages = []
export default defineConfig({
plugins: [
laravel({
input: 'resources/js/app.tsx',
refresh: true,
}),
react(),
copy({
targets: [
{ src: 'resources/images/*', dest: 'public/images' },
]
}),
VitePWA({
registerType: 'autoUpdate',
includeAssets: ['favicon.ico', 'apple-touch-icon.png', 'mask-icon.svg'],
manifest: {
name: 'Bermite',
short_name: 'Bermite',
lang: "fr",
description: 'Application de suivi météo',
theme_color: '#ffffff',
display: "standalone",
icons: [
{
src: '/pwa-64x64.png',
sizes: '64x64',
type: 'image/png'
},
{
src: '/pwa-192x192.png',
sizes: '192x192',
type: 'image/png'
},
{
src: '/pwa-512x512.png',
sizes: '512x512',
type: 'image/png'
}
return defineConfig({
plugins: [
laravel({
input: 'resources/js/app.tsx',
refresh: true,
}),
react(),
copy({
targets: [
{ src: 'resources/images/*', dest: 'public/images' },
]
}
})
],
});
}),
VitePWA({
buildBase: '/build/',
scope: '/',
base: '/',
registerType: 'prompt',
devOptions: {
enabled: false
},
includeAssets: [],
workbox: {
globPatterns: ['**/*.{js,css,html,ico,jpg,png,svg,woff,woff2,ttf,eot}'],
navigateFallback: '/',
navigateFallbackDenylist: [/^\/horizon/],
additionalManifestEntries: [
{ url: '/', revision: `${Date.now()}` },
...manifestIcons.map((i) => {
return { url: i.src, revision: `${Date.now()}` }
}),
...publicIcons.map((i) => {
return { url: i.src, revision: `${Date.now()}` }
}),
...additionalImages.map((i) => {
return { url: i.src, revision: `${Date.now()}` }
})
],
maximumFileSizeToCacheInBytes: 3000000
},
manifest: {
name: 'Bermite',
short_name: 'Bermite',
lang: "fr",
description: 'Application de suivi météo',
theme_color: '#ffffff',
display: "standalone",
scope: '/',
start_url: '/',
id: '/',
// These icons are used when installing the PWA onto a home screen
icons: [...manifestIcons],
}
})
],
})
}