Files
btpxpress-frontend/next.config.js
dahoud a8825a058b Fix: Corriger toutes les erreurs de build du frontend
- Correction des erreurs TypeScript dans userService.ts et workflowTester.ts
- Ajout des propriétés manquantes aux objets User mockés
- Conversion des dates de string vers objets Date
- Correction des appels asynchrones et des types incompatibles
- Ajout de dynamic rendering pour résoudre les erreurs useSearchParams
- Enveloppement de useSearchParams dans Suspense boundary
- Configuration de force-dynamic au niveau du layout principal

Build réussi: 126 pages générées avec succès

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-18 13:23:08 +00:00

98 lines
2.8 KiB
JavaScript

/** @type {import('next').NextConfig} */
const nextConfig = {
reactStrictMode: true,
output: 'standalone',
// Optimisations pour la production
compress: true,
poweredByHeader: false,
generateEtags: false,
// Désactiver la génération statique pour éviter les erreurs useSearchParams
skipTrailingSlashRedirect: true,
// Configuration des images optimisées
images: {
domains: ['btpxpress.lions.dev', 'api.lions.dev', 'security.lions.dev'],
formats: ['image/webp', 'image/avif'],
minimumCacheTTL: 60,
dangerouslyAllowSVG: true,
contentSecurityPolicy: "default-src 'self'; script-src 'none'; sandbox;",
},
// Optimisations de performance
experimental: {
optimizeCss: true,
optimizePackageImports: ['primereact', 'primeicons'],
},
// Configuration Turbopack (stable)
turbopack: {
rules: {
'*.svg': {
loaders: ['@svgr/webpack'],
as: '*.js',
},
},
},
// Configuration du bundler simplifiée
webpack: (config, { dev }) => {
// Alias pour optimiser les imports
config.resolve.alias = {
...config.resolve.alias,
'@': require('path').resolve(__dirname),
'@components': require('path').resolve(__dirname, 'components'),
'@services': require('path').resolve(__dirname, 'services'),
'@types': require('path').resolve(__dirname, 'types'),
'@utils': require('path').resolve(__dirname, 'utils'),
};
return config;
},
// Headers de sécurité
async headers() {
return [
{
source: '/(.*)',
headers: [
{
key: 'X-Frame-Options',
value: 'DENY'
},
{
key: 'X-Content-Type-Options',
value: 'nosniff'
},
{
key: 'Referrer-Policy',
value: 'strict-origin-when-cross-origin'
}
]
}
];
},
async redirects() {
return [
{
source: '/apps/mail',
destination: '/apps/mail/inbox',
permanent: true
}
];
},
// Configuration des variables d'environnement
env: {
NEXT_PUBLIC_API_URL: process.env.NEXT_PUBLIC_API_URL,
NEXT_PUBLIC_KEYCLOAK_URL: process.env.NEXT_PUBLIC_KEYCLOAK_URL,
NEXT_PUBLIC_KEYCLOAK_REALM: process.env.NEXT_PUBLIC_KEYCLOAK_REALM,
NEXT_PUBLIC_KEYCLOAK_CLIENT_ID: process.env.NEXT_PUBLIC_KEYCLOAK_CLIENT_ID,
NEXT_PUBLIC_APP_ENV: process.env.NEXT_PUBLIC_APP_ENV,
}
};
module.exports = nextConfig;