singularity-forge/web/next.config.mjs
2026-05-05 14:31:16 +02:00

44 lines
1.6 KiB
JavaScript

import { resolve } from "node:path";
const webRoot = import.meta.dirname;
const repoRoot = resolve(webRoot, "..");
/** @type {import('next').NextConfig} */
const nextConfig = {
output: "standalone",
outputFileTracingRoot: repoRoot,
typescript: {
ignoreBuildErrors: true,
},
images: {
unoptimized: true,
},
serverExternalPackages: ["@singularity-forge/native", "node-pty"],
// NodeNext-style .js extension imports in src/ must resolve to .ts source.
// Turbopack doesn't support extensionAlias, so builds use --webpack flag.
webpack: (config, { isServer }) => {
config.resolve.extensionAlias = {
".js": [".ts", ".tsx", ".js"],
".mjs": [".mts", ".mjs"],
};
// Webpack swallows `node:module` imports because it treats `module` as an
// internal concept. We need createRequire to survive into the server
// bundle so node-pty (a native addon) can be loaded at runtime.
if (isServer) {
config.externals = config.externals || [];
// Next.js already makes externals an array of functions/regexps — append
// a simple object entry so `require("node:module")` passes through.
config.externals.push({
"node:module": "commonjs node:module",
// @singularity-forge/native is a native addon loaded via runtime require().
// serverExternalPackages handles the top-level import, but webpack
// still tries to resolve the bare specifier inside files traced from
// src/ (outside web/). Explicitly externalize it.
"@singularity-forge/native": "commonjs @singularity-forge/native",
});
}
return config;
},
};
export default nextConfig;