From 66d3cf9a0cbc0eda84b98090bb8d9644b70eea00 Mon Sep 17 00:00:00 2001 From: Simon Holthausen Date: Tue, 21 Nov 2023 16:38:31 +0100 Subject: [PATCH] fix: force module(resolution) transpileModule treats NodeNext as CommonJS because it doesn't read the package.json. Also see https://github.com/microsoft/TypeScript/issues/53022 (the filename workaround doesn't work). Related to https://github.com/sveltejs/kit/issues/11086 --- src/transformers/typescript.ts | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/transformers/typescript.ts b/src/transformers/typescript.ts index a850dfbe..d82b496e 100644 --- a/src/transformers/typescript.ts +++ b/src/transformers/typescript.ts @@ -288,8 +288,13 @@ function getCompilerOptions({ const compilerOptions: CompilerOptions = { target: ts.ScriptTarget.ES2015, - moduleResolution: ts.ModuleResolutionKind.NodeJs, ...(convertedCompilerOptions as CompilerOptions), + // force module(resolution) to esnext and a compatible moduleResolution. Reason: + // transpileModule treats NodeNext as CommonJS because it doesn't read the package.json. + // Also see https://github.com/microsoft/TypeScript/issues/53022 (the filename workaround doesn't work). + module: ts.ModuleKind.ESNext, + moduleResolution: + ts.ModuleResolutionKind.NodeJs ?? ts.ModuleResolutionKind.Node10, // in case the first option every goes away allowNonTsExtensions: true, // Clear outDir since it causes source map issues when the files aren't actually written to disk. outDir: undefined,