2022-12-18 03:15:19 +03:00
|
|
|
import { isCI, isDevelopment } from 'std-env'
|
2022-12-18 02:29:16 +03:00
|
|
|
import type { VitePWANuxtOptions } from '../modules/pwa/types'
|
2023-01-04 16:26:30 +03:00
|
|
|
import { APP_NAME } from '../constants'
|
|
|
|
import { getEnv } from './env'
|
2022-12-18 02:29:16 +03:00
|
|
|
|
2022-12-28 17:08:03 +03:00
|
|
|
export const pwa: VitePWANuxtOptions = {
|
2022-12-18 02:29:16 +03:00
|
|
|
mode: isCI ? 'production' : 'development',
|
2022-12-21 03:06:51 +03:00
|
|
|
// disable PWA only when in preview mode
|
2022-12-22 16:48:20 +03:00
|
|
|
disable: /* temporarily test in CI isPreview || */ (isDevelopment && process.env.VITE_DEV_PWA !== 'true'),
|
2022-12-18 02:29:16 +03:00
|
|
|
scope: '/',
|
|
|
|
srcDir: './service-worker',
|
|
|
|
filename: 'sw.ts',
|
|
|
|
strategies: 'injectManifest',
|
|
|
|
injectRegister: false,
|
|
|
|
includeManifestIcons: false,
|
2023-01-04 16:26:30 +03:00
|
|
|
manifest: async () => {
|
|
|
|
const { env } = await getEnv()
|
|
|
|
const envName = `${env !== 'release' ? '' : ` (${env})`}`
|
|
|
|
return {
|
|
|
|
scope: '/',
|
|
|
|
id: '/',
|
|
|
|
name: `${APP_NAME}${envName}`,
|
|
|
|
short_name: `${APP_NAME}${envName}`,
|
|
|
|
description: `A nimble Mastodon Web Client${envName}`,
|
|
|
|
theme_color: '#ffffff',
|
|
|
|
icons: [
|
|
|
|
{
|
|
|
|
src: 'pwa-192x192.png',
|
|
|
|
sizes: '192x192',
|
|
|
|
type: 'image/png',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
src: 'pwa-512x512.png',
|
|
|
|
sizes: '512x512',
|
|
|
|
type: 'image/png',
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
{
|
|
|
|
src: 'logo.svg',
|
|
|
|
sizes: '250x250',
|
|
|
|
type: 'image/png',
|
|
|
|
purpose: 'any maskable',
|
|
|
|
},
|
|
|
|
*/
|
|
|
|
],
|
|
|
|
}
|
2022-12-18 02:29:16 +03:00
|
|
|
},
|
|
|
|
injectManifest: {
|
|
|
|
globPatterns: ['**/*.{js,json,css,html,txt,svg,png,ico,webp,woff,woff2,ttf,eot,otf,wasm}'],
|
2023-01-03 12:57:41 +03:00
|
|
|
globIgnores: ['emojis/**'],
|
2022-12-18 02:29:16 +03:00
|
|
|
},
|
|
|
|
devOptions: {
|
|
|
|
enabled: process.env.VITE_DEV_PWA === 'true',
|
|
|
|
type: 'module',
|
|
|
|
},
|
|
|
|
}
|