Use this to load modules whose location is specified in the paths section of tsconfig.json.
yarn add ts-transform-paths -D
TypeScript >= 2.4.1
Unfortunately, TypeScript itself does not currently provide any easy way to use custom transformers (See microsoft/TypeScript#14419). The followings are the example usage of the custom transformer.
{
"compilerOptions": {
"paths": {
"@schema": ["./src/schema"],
"@modules/*": ["./src/modules/*"]
}
}
}
// webpack.config.js
const pathsTransformer = require("ts-transform-paths").default;
module.exports = {
// ...
module: {
rules: [
{
test: /\.ts$/,
loader: "ts-loader", // or 'awesome-typescript-loader'
options: {
getCustomTransformers: (program) => ({
before: [pathsTransformer(program)]
})
}
}
]
}
};
// rollup.config.js
import typescript from "rollup-plugin-typescript2";
import pathsTransformer from "ts-transform-paths";
export default {
// ...
plugins: [
typescript({
transformers: [
(service) => ({
before: [pathsTransformer(service.getProgram())],
after: []
})
]
})
]
};
See ttypescript's README for how to use this with module bundlers such as webpack or Rollup.
// tsconfig.json
{
"compilerOptions": {
// ...
"plugins": [{ "transform": "ts-transform-paths" }]
}
// ...
}
// my-ts-script.ts
import { MyClass } from "@schema";
const myClass = new MyClass("Message");
// index.js
const pathsTransformer = require("ts-transform-paths").default;
require("ts-node").register({
transformers: {
before: [pathsTransformer()]
}
});
require("./my-ts-script");
and run
yarn node ./index.js