Skip to content

Instantly share code, notes, and snippets.

@libetl
Created January 31, 2022 18:03
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save libetl/beab668e10599f67d4dba1c75e825931 to your computer and use it in GitHub Desktop.
Save libetl/beab668e10599f67d4dba1c75e825931 to your computer and use it in GitHub Desktop.
add-mjs-extension-transformer.js
const typescript = require("typescript");
const path = require("path");
module.exports = (_) => (transformationContext) => (sourceFile) => {
function visitNode(node) {
if (shouldMutateModuleSpecifier(node)) {
const factory = transformationContext.factory;
if (typescript.isImportDeclaration(node)) {
const newModuleSpecifier = factory.createStringLiteral(`${node.moduleSpecifier.text}.mjs`);
node = factory.updateImportDeclaration(node, node.decorators, node.modifiers,
node.importClause, newModuleSpecifier, node.assertClause);
}
else if (typescript.isExportDeclaration(node)) {
const newModuleSpecifier = factory.createStringLiteral(`${node.moduleSpecifier.text}.mjs`);
node = factory.updateExportDeclaration(node, node.decorators, node.modifiers, node.isTypeOnly,
node.exportClause, newModuleSpecifier, node.assertClause);
}
}
return typescript.visitEachChild(node, visitNode, transformationContext);
}
function shouldMutateModuleSpecifier(node) {
if (!typescript.isImportDeclaration(node) && !typescript.isExportDeclaration(node))
return false;
if (node.moduleSpecifier === undefined)
return false;
// only when module specifier is valid
if (!typescript.isStringLiteral(node.moduleSpecifier))
return false;
// only when path is relative
if (!node.moduleSpecifier.text.startsWith('./') && !node.moduleSpecifier.text.startsWith('../'))
return false;
// only when module specifier has no extension
if (path.extname(node.moduleSpecifier.text) !== '' &&
!node.moduleSpecifier.text.endsWith('/babel.config'))
return false;
return true;
}
return typescript.visitNode(sourceFile, visitNode);
};
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment