const withLess = require('next-with-less'); const withBundleAnalyzer = require('@next/bundle-analyzer')({ enabled: process.env.ANALYZE === 'true', }); const runtimeCaching = require('next-pwa/cache'); const withPWA = require('next-pwa')({ dest: 'public', runtimeCaching: [ ...runtimeCaching, { urlPattern: /\.(?:ts|m3u8)$/i, handler: 'NetworkOnly', }, { urlPattern: /^\/admin\/.*$/, handler: 'NetworkOnly', }, { urlPattern: /^\/api\/.*$/, handler: 'NetworkOnly', }, ], register: true, skipWaiting: true, disableDevLogs: true, publicExcludes: ['!img/platformlogos/**/*', '!styles/admin/**/*'], buildExcludes: [/chunks\/pages\/admin.*/, '!**/admin/**/*'], sourcemap: process.env.NODE_ENV === 'development', disable: process.env.NODE_ENV === 'development', }); module.exports = withPWA( withBundleAnalyzer( withLess({ productionBrowserSourceMaps: process.env.SOURCE_MAPS === 'true', trailingSlash: true, reactStrictMode: true, images: { unoptimized: true, }, swcMinify: true, output: 'export', webpack(config) { config.module.rules.push({ test: /\.svg$/i, issuer: /\.[jt]sx?$/, use: ['@svgr/webpack'], }); return config; }, async rewrites() { return [ { source: '/api/:path*', destination: 'http://localhost:8080/api/:path*', // Proxy to Backend to work around CORS. }, { source: '/hls/:path*', destination: 'http://localhost:8080/hls/:path*', // Proxy to Backend to work around CORS. }, { source: '/img/:path*', destination: 'http://localhost:8080/img/:path*', // Proxy to Backend to work around CORS. }, { source: '/logo', destination: 'http://localhost:8080/logo', // Proxy to Backend to work around CORS. }, { source: '/thumbnail.jpg', destination: 'http://localhost:8080/thumbnail.jpg', // Proxy to Backend to work around CORS. }, { source: '/customjavascript', destination: 'http://localhost:8080/customjavascript', // Proxy to Backend to work around CORS. }, ]; }, pageExtensions: ['tsx'], }), ), );