import { sveltekit } from '@sveltejs/kit/vite'; import { defineConfig } from 'vite'; import { VitePWA } from 'vite-plugin-pwa'; import tailwindcss from '@tailwindcss/vite'; export default defineConfig({ server: { proxy: { '/api': { target: process.env.VITE_API_URL ?? 'http://localhost:8000', changeOrigin: true } } }, plugins: [ tailwindcss(), sveltekit(), VitePWA({ registerType: 'autoUpdate', devOptions: { enabled: true }, manifest: { name: 'Fooder', short_name: 'Fooder', description: 'Simple calorie and macro tracker', theme_color: '#16a34a', background_color: '#09090b', display: 'standalone', orientation: 'portrait', start_url: '/', icons: [ { src: '/icons/icon-192.png', sizes: '192x192', type: 'image/png' }, { src: '/icons/icon-512.png', sizes: '512x512', type: 'image/png' }, { src: '/icons/icon-512.png', sizes: '512x512', type: 'image/png', purpose: 'maskable' } ] }, workbox: { globPatterns: ['**/*.{js,css,html,ico,png,svg,woff2}'], runtimeCaching: [ { urlPattern: /^https?:\/\/.*\/api\//, handler: 'NetworkFirst', options: { cacheName: 'api-cache', networkTimeoutSeconds: 5, cacheableResponse: { statuses: [200] } } } ] } }) ] });