102 lines
2.3 KiB
TypeScript
102 lines
2.3 KiB
TypeScript
|
import { loadEnvConfig } from '@next/env'
|
||
|
import findUp from 'next/dist/compiled/find-up'
|
||
|
import { init as initWebpack } from 'next/dist/compiled/webpack/webpack'
|
||
|
import { CONFIG_FILE, PHASE_DEVELOPMENT_SERVER } from '../lib/constants'
|
||
|
import { NextConfig, normalizeConfig } from './config-shared'
|
||
|
import * as Log from '../../build/output/log'
|
||
|
|
||
|
let installed: boolean = false
|
||
|
|
||
|
export function install(useWebpack5: boolean) {
|
||
|
if (installed) {
|
||
|
return
|
||
|
}
|
||
|
installed = true
|
||
|
|
||
|
initWebpack(useWebpack5)
|
||
|
|
||
|
// hook the Node.js require so that webpack requires are
|
||
|
// routed to the bundled and now initialized webpack version
|
||
|
require('../../build/webpack/require-hook')
|
||
|
}
|
||
|
|
||
|
export type CheckReasons =
|
||
|
| 'test-mode'
|
||
|
| 'no-config'
|
||
|
| 'future-flag'
|
||
|
| 'no-future-flag'
|
||
|
| 'no-webpack-config'
|
||
|
| 'webpack-config'
|
||
|
|
||
|
export type CheckResult = {
|
||
|
enabled: boolean
|
||
|
reason: CheckReasons
|
||
|
}
|
||
|
|
||
|
export async function shouldLoadWithWebpack5(
|
||
|
phase: string,
|
||
|
dir: string
|
||
|
): Promise<CheckResult> {
|
||
|
await loadEnvConfig(dir, phase === PHASE_DEVELOPMENT_SERVER, Log)
|
||
|
|
||
|
const path = await findUp(CONFIG_FILE, {
|
||
|
cwd: dir,
|
||
|
})
|
||
|
|
||
|
if (Number(process.env.NEXT_PRIVATE_TEST_WEBPACK5_MODE) > 0) {
|
||
|
return {
|
||
|
enabled: true,
|
||
|
reason: 'test-mode',
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// No `next.config.js`:
|
||
|
if (!path?.length) {
|
||
|
// Uncomment to add auto-enable when there is no next.config.js
|
||
|
// Use webpack 5 by default in new apps:
|
||
|
return {
|
||
|
enabled: true,
|
||
|
reason: 'no-config',
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Default to webpack 4 for backwards compatibility on boot:
|
||
|
install(false)
|
||
|
|
||
|
const userConfigModule = require(path)
|
||
|
const userConfig: Partial<NextConfig> = normalizeConfig(
|
||
|
phase,
|
||
|
userConfigModule.default || userConfigModule
|
||
|
)
|
||
|
|
||
|
// Opted-in manually
|
||
|
if (userConfig.future?.webpack5 === true) {
|
||
|
return {
|
||
|
enabled: true,
|
||
|
reason: 'future-flag',
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Opted-out manually
|
||
|
if (userConfig.future?.webpack5 === false) {
|
||
|
return {
|
||
|
enabled: false,
|
||
|
reason: 'no-future-flag',
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Uncomment to add auto-enable when there is no custom webpack config
|
||
|
// The user isn't configuring webpack
|
||
|
if (!userConfig.webpack) {
|
||
|
return {
|
||
|
enabled: true,
|
||
|
reason: 'no-webpack-config',
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return {
|
||
|
enabled: false,
|
||
|
reason: 'webpack-config',
|
||
|
}
|
||
|
}
|