Files
website-enchun-mgr/apps/backend/next.config.js
pkupuk be7fc902fb feat(backend): update collections, config and migration tools
Update Payload CMS configuration, collections (Audit, Posts), and add migration scripts/reports.
2026-02-11 11:50:23 +08:00

54 lines
1.6 KiB
JavaScript

import { withPayload } from '@payloadcms/next/withPayload'
import { fileURLToPath } from 'node:url'
import { dirname, join } from 'node:path'
import redirects from './redirects.js'
const __dirname = dirname(fileURLToPath(import.meta.url))
const NEXT_PUBLIC_SERVER_URL = process.env.VERCEL_PROJECT_PRODUCTION_URL
? `https://${process.env.VERCEL_PROJECT_PRODUCTION_URL}`
: undefined || process.env.__NEXT_PRIVATE_ORIGIN || 'http://localhost:3000'
/** @type {import('next').NextConfig} */
const nextConfig = {
output: 'standalone',
// Required for monorepo: trace dependencies from the monorepo root
outputFileTracingRoot: join(__dirname, '../../'),
eslint: { ignoreDuringBuilds: true },
typescript: { ignoreBuildErrors: true },
images: {
remotePatterns: [
...[NEXT_PUBLIC_SERVER_URL, process.env.NEXT_PUBLIC_SERVER_URL]
.filter(Boolean)
.map((item) => {
const urlString = item.startsWith('http') ? item : `https://${item}`
try {
const url = new URL(urlString)
return {
hostname: url.hostname,
protocol: url.protocol.replace(':', ''),
}
} catch (_) {
return null
}
})
.filter(Boolean),
],
},
webpack: (webpackConfig) => {
webpackConfig.resolve.extensionAlias = {
'.cjs': ['.cts', '.cjs'],
'.js': ['.ts', '.tsx', '.js', '.jsx'],
'.mjs': ['.mts', '.mjs'],
}
return webpackConfig
},
reactStrictMode: true,
redirects,
}
export default withPayload(nextConfig, { devBundleServerPackages: false })