mirror of
https://github.com/plebbit/seedit.git
synced 2026-01-15 01:08:01 -05:00
237 lines
6.5 KiB
JavaScript
237 lines
6.5 KiB
JavaScript
import { defineConfig } from 'vite';
|
|
import react from '@vitejs/plugin-react';
|
|
import { resolve } from 'path';
|
|
import { nodePolyfills } from 'vite-plugin-node-polyfills';
|
|
import eslint from 'vite-plugin-eslint';
|
|
import { VitePWA } from 'vite-plugin-pwa';
|
|
import reactScan from '@react-scan/vite-plugin-react-scan';
|
|
import { reactGrab } from 'react-grab/plugins/vite';
|
|
|
|
const isProduction = process.env.NODE_ENV === 'production';
|
|
const isDevelopment = process.env.NODE_ENV === 'development';
|
|
|
|
export default defineConfig({
|
|
plugins: [
|
|
react({
|
|
babel: {
|
|
plugins: [
|
|
['babel-plugin-react-compiler', {
|
|
verbose: true
|
|
}]
|
|
]
|
|
}
|
|
}),
|
|
// Only include React Scan in development mode - never in production builds
|
|
(isDevelopment || (!isProduction && process.env.NODE_ENV !== 'production')) && reactScan({
|
|
showToolbar: true,
|
|
playSound: true,
|
|
}),
|
|
// Only include React Grab in development mode - never in production builds
|
|
(isDevelopment || (!isProduction && process.env.NODE_ENV !== 'production')) && reactGrab(),
|
|
!isProduction && eslint({
|
|
lintOnStart: true,
|
|
overrideConfigFile: './.eslintrc.cjs',
|
|
failOnError: false,
|
|
failOnWarning: false,
|
|
cache: true,
|
|
}),
|
|
nodePolyfills({
|
|
globals: {
|
|
Buffer: true,
|
|
global: true,
|
|
process: true,
|
|
},
|
|
protocolImports: true,
|
|
include: ['crypto', 'stream', 'util', 'buffer', 'events'],
|
|
}),
|
|
VitePWA({
|
|
registerType: 'autoUpdate',
|
|
strategies: 'injectManifest',
|
|
injectManifest: {
|
|
maximumFileSizeToCacheInBytes: 20000000,
|
|
},
|
|
srcDir: 'src',
|
|
filename: 'sw.ts',
|
|
devOptions: {
|
|
enabled: true,
|
|
type: 'module',
|
|
},
|
|
includeAssets: ['favicon.ico', 'robots.txt', 'apple-touch-icon.png'],
|
|
manifest: {
|
|
name: 'Seedit',
|
|
short_name: 'Seedit',
|
|
description: 'A GUI for plebbit similar to old.reddit',
|
|
theme_color: '#ffffff',
|
|
background_color: '#ffffee',
|
|
display: 'standalone',
|
|
icons: [
|
|
{
|
|
src: '/android-chrome-192x192.png',
|
|
sizes: '192x192',
|
|
type: 'image/png'
|
|
},
|
|
{
|
|
src: '/android-chrome-512x512.png',
|
|
sizes: '512x512',
|
|
type: 'image/png'
|
|
},
|
|
{
|
|
src: '/android-chrome-512x512.png',
|
|
sizes: '512x512',
|
|
type: 'image/png',
|
|
purpose: 'any maskable'
|
|
}
|
|
]
|
|
},
|
|
workbox: {
|
|
clientsClaim: true,
|
|
skipWaiting: true,
|
|
cleanupOutdatedCaches: true,
|
|
navigateFallback: 'index.html',
|
|
navigateFallbackDenylist: [/^\/api/, /^\/_(.*)/],
|
|
|
|
runtimeCaching: [
|
|
// Always get fresh HTML from network first
|
|
{
|
|
urlPattern: ({ url }) => url.pathname === '/' || url.pathname === '/index.html',
|
|
handler: 'NetworkFirst',
|
|
options: {
|
|
cacheName: 'html-cache',
|
|
networkTimeoutSeconds: 3
|
|
}
|
|
},
|
|
// PNG caching
|
|
{
|
|
urlPattern: ({ url }) => url.pathname.endsWith('.png'),
|
|
handler: 'StaleWhileRevalidate',
|
|
options: {
|
|
cacheName: 'images',
|
|
expiration: {
|
|
maxEntries: 50
|
|
}
|
|
}
|
|
},
|
|
// Add additional asset caching
|
|
{
|
|
urlPattern: /\.(?:js|css|woff2?|svg|gif|jpg|jpeg)$/,
|
|
handler: 'StaleWhileRevalidate',
|
|
options: {
|
|
cacheName: 'assets-cache',
|
|
expiration: {
|
|
maxEntries: 100,
|
|
maxAgeSeconds: 60 * 60 * 24 * 30 // 30 days
|
|
}
|
|
}
|
|
},
|
|
// Google Fonts caching
|
|
{
|
|
urlPattern: /^https:\/\/fonts\.googleapis\.com\/.*/i,
|
|
handler: 'CacheFirst',
|
|
options: {
|
|
cacheName: 'google-fonts-cache',
|
|
expiration: {
|
|
maxEntries: 10,
|
|
maxAgeSeconds: 60 * 60 * 24 * 365 // 365 days
|
|
},
|
|
cacheableResponse: {
|
|
statuses: [0, 200]
|
|
}
|
|
}
|
|
},
|
|
{
|
|
urlPattern: /^https:\/\/fonts\.gstatic\.com\/.*/i,
|
|
handler: 'CacheFirst',
|
|
options: {
|
|
cacheName: 'google-fonts-webfonts',
|
|
expiration: {
|
|
maxEntries: 30,
|
|
maxAgeSeconds: 60 * 60 * 24 * 365 // 365 days
|
|
},
|
|
cacheableResponse: {
|
|
statuses: [0, 200]
|
|
}
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}),
|
|
],
|
|
resolve: {
|
|
alias: {
|
|
'@': resolve(__dirname, 'src'),
|
|
'node-fetch': 'isomorphic-fetch',
|
|
'assert': 'assert',
|
|
'stream': 'stream-browserify',
|
|
'crypto': 'crypto-browserify',
|
|
'buffer': 'buffer',
|
|
}
|
|
},
|
|
server: {
|
|
port: 3000,
|
|
open: true,
|
|
watch: {
|
|
usePolling: true,
|
|
},
|
|
hmr: {
|
|
overlay: false
|
|
}
|
|
},
|
|
build: {
|
|
outDir: 'build',
|
|
emptyOutDir: true,
|
|
sourcemap: process.env.GENERATE_SOURCEMAP === 'true',
|
|
target: process.env.ELECTRON ? 'electron-renderer' : 'modules',
|
|
chunkSizeWarningLimit: 1000,
|
|
rollupOptions: {
|
|
output: {
|
|
manualChunks: {
|
|
vendor: ['react', 'react-dom', 'react-router-dom', 'react-i18next', 'i18next', 'i18next-browser-languagedetector', 'i18next-http-backend']
|
|
}
|
|
}
|
|
}
|
|
},
|
|
base: process.env.PUBLIC_URL || '/',
|
|
optimizeDeps: {
|
|
esbuildOptions: {
|
|
target: 'es2020',
|
|
define: {
|
|
global: 'globalThis',
|
|
},
|
|
},
|
|
include: [
|
|
'ethers',
|
|
'assert',
|
|
'buffer',
|
|
'process',
|
|
'stream-browserify',
|
|
'isomorphic-fetch',
|
|
'workbox-core',
|
|
'workbox-precaching'
|
|
],
|
|
// Exclude packages that use TypeScript decorators for ASN.1 schema registration
|
|
// esbuild strips decorator metadata, breaking schema registration at runtime
|
|
exclude: [
|
|
'@peculiar/asn1-schema',
|
|
'@peculiar/asn1-x509',
|
|
'@peculiar/asn1-rsa',
|
|
'@peculiar/asn1-ecc',
|
|
'@peculiar/asn1-pkcs8',
|
|
'@peculiar/asn1-pkcs9',
|
|
'@peculiar/asn1-cms',
|
|
'@peculiar/asn1-csr',
|
|
'@peculiar/asn1-pfx',
|
|
'@peculiar/asn1-x509-attr',
|
|
'@peculiar/webcrypto',
|
|
'@peculiar/x509',
|
|
],
|
|
},
|
|
esbuild: {
|
|
target: 'es2020'
|
|
},
|
|
define: {
|
|
'process.env.VITE_COMMIT_REF': JSON.stringify(process.env.COMMIT_REF),
|
|
'global': 'globalThis',
|
|
'__dirname': '""',
|
|
}
|
|
});
|