Skip to content

Commit

Permalink
feat(vite): add tsconfig paths resolution plugin
Browse files Browse the repository at this point in the history
  • Loading branch information
barbados-clemens committed Jun 29, 2023
1 parent 7d15e0c commit f9a319a
Show file tree
Hide file tree
Showing 6 changed files with 74 additions and 10 deletions.
6 changes: 4 additions & 2 deletions packages/vite/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,8 @@
"dotenv": "~10.0.0",
"enquirer": "~2.3.6",
"@nx/devkit": "file:../devkit",
"@nx/js": "file:../js"
"@nx/js": "file:../js",
"tsconfig-paths": "^4.1.2"
},
"peerDependencies": {
"vite": "^4.3.4",
Expand All @@ -53,6 +54,7 @@
"./executors": "./executors.js",
"./src/executors/*/schema.json": "./src/executors/*/schema.json",
"./src/executors/*.impl": "./src/executors/*.impl.js",
"./src/executors/*/compat": "./src/executors/*/compat.js"
"./src/executors/*/compat": "./src/executors/*/compat.js",
"./plugins/nx-tsconfig-paths.plugin": "./plugins/nx-tsconfig-paths.plugin.js"
}
}
60 changes: 60 additions & 0 deletions packages/vite/plugins/nx-tsconfig-paths.plugin.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
import { stripIndents, workspaceRoot } from '@nx/devkit';
import { existsSync } from 'node:fs';
import { relative, join, resolve, posix } from 'node:path';
import { loadConfig, createMatchPath, MatchPath } from 'tsconfig-paths';

// TODO(caleb): should we provide a way to override anything for the plugin?

export function nxViteTsPaths() {
let matchTsPath: MatchPath;

return {
name: 'nx-vite-ts-paths',
configResolved(config: any) {
const projectRoot = config.root;
// TODO(caleb): verify on windows to see what type of paths vite returns posix vs win32
const projectRootFromWorkspaceRoot = relative(workspaceRoot, projectRoot);

const foundTsConfigPath = getTsConfig(projectRootFromWorkspaceRoot);
if (!foundTsConfigPath) {
throw new Error(stripIndents`Unable to find a tsconfig in the workspace!
There should at least be a tsconfig.base.json or tsconfig.json in the root of the workspace ${workspaceRoot}`);
}
const parsed = loadConfig(foundTsConfigPath);

if (parsed.resultType === 'failed') {
throw new Error(`Failed loading tsonfig at ${foundTsConfigPath}`);
}

matchTsPath = createMatchPath(parsed.absoluteBaseUrl, parsed.paths, [
['exports', '.', 'import'],
]);
},
resolveId(source: string) {
const resolvedFile = matchTsPath(source);

if (!resolvedFile && process.env.NX_VERBOSE_LOGGING === 'true') {
console.warn(
`[Nx Vite TsPaths] Unable to resolve ${source} with tsconfig paths`
);
}

return resolvedFile;
},
};
}

function getTsConfig(
projectRoot: string,
tmpTsConfigName = 'tsconfig.generated.json'
): string {
return [
resolve(join(workspaceRoot, 'tmp', projectRoot, tmpTsConfigName)),
resolve(join(workspaceRoot, 'tsconfig.base.json')),
resolve(join(workspaceRoot, 'tsconfig.json')),
].find((tsPath) => {
if (existsSync(tsPath)) {
return tsPath;
}
});
}
1 change: 1 addition & 0 deletions packages/vite/src/executors/build/build.impl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ export async function* viteBuildExecutor(
const projectRoot =
context.projectsConfigurations.projects[context.projectName].root;

// TODO(caleb): do we need to register the paths anymore or just make tsconfig?
registerPaths(projectRoot, options, context);

const normalizedOptions = normalizeOptions(options);
Expand Down
1 change: 1 addition & 0 deletions packages/vite/src/executors/dev-server/dev-server.impl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ export async function* viteDevServerExecutor(
const projectRoot =
context.projectsConfigurations.projects[context.projectName].root;

// TODO(caleb): do we need to register the paths anymore or just make tsconfig?
registerPaths(projectRoot, options, context);

// Retrieve the option for the configured buildTarget.
Expand Down
7 changes: 3 additions & 4 deletions packages/vite/src/utils/executor-utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,9 @@ export function registerPaths(
const tsConfig = resolve(projectRoot, 'tsconfig.json');
options.buildLibsFromSource ??= true;

if (!options.buildLibsFromSource) {
if (options.buildLibsFromSource) {
registerTsConfigPaths(tsConfig);
} else {
const { dependencies } = calculateProjectDependencies(
context.projectGraph,
context.root,
Expand All @@ -49,9 +51,6 @@ export function registerPaths(
projectRoot,
dependencies
);

registerTsConfigPaths(tmpTsConfig);
} else {
registerTsConfigPaths(tsConfig);
}
}
9 changes: 5 additions & 4 deletions packages/vite/src/utils/generator-utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -583,13 +583,14 @@ export function createOrEditViteConfig(
host: 'localhost',
},`;

// viteTsConfigPaths({
// root: '${offsetFromRoot(projectConfig.root)}',
// }),
const pluginOption = `
plugins: [
${dtsPlugin}
${reactPlugin}
viteTsConfigPaths({
root: '${offsetFromRoot(projectConfig.root)}',
}),
nxViteTsPaths(),
],
`;

Expand Down Expand Up @@ -628,7 +629,7 @@ export function createOrEditViteConfig(
/// <reference types="vitest" />
import { defineConfig } from 'vite';
${reactPluginImportLine}
import viteTsConfigPaths from 'vite-tsconfig-paths';
import { nxViteTsPaths } from '@nx/vite/plugins/nx-tsconfig-paths.plugin';
${dtsImportLine}
export default defineConfig({
Expand Down

0 comments on commit f9a319a

Please sign in to comment.