Skip to content

GervinFung/ts-add-js-extension

Repository files navigation

ts-add-js-extension

Originally, I created this solution for personal use due to my preference of not including the .js extension in TypeScript import/export statements when compiling my TypeScript project to ES Module. This decision was motivated by the belief that it is unnecessary to import/export a JavaScript file that does not exist in the source code folder. Importing or exporting a file that does not exist would be illogical. In essence, a source code should not reference its own build artifacts or output file

Additionally, another option would be to compile the TypeScript project to CommonJS Module. However, I prefer not to take that approach. Instead, this package is designed to cater to TypeScript or JavaScript projects that use ES Module (ESM) format and do not rely on a bundler like esbuild or swc.

Feature

Initially designed for TypeScript projects exclusively, this solution also caters to those who prefer a more convenient approach when working with JavaScript. By automatically appending the .js extension to each relative import and export statement in ES Module JavaScript, you can save yourself the effort of doing it manually. This feature is particularly beneficial for TypeScript projects that target ES Module.

Als, this decision was motivated by the belief that it is unnecessary to import/export a JavaScript file that does not exist in the source code folder. Importing or exporting a file that does not exist would be illogical. In essence, a source code should not reference its own build artifacts or output file

It is worth noting that this package intelligently handles import/export statements and adds /index.js where necessary, allowing you to omit the explicit inclusion of index in the statement.

Additionally, it can determine whether a file with the mjs or js extension is being imported or exported

Usage

The compiled folder for TypeScript or JavaScript can be named according to your preference. In this case, I will use the name "dist" as an example.

Note: For command line arguments, refer here

Declarations

Command line:

{
	"scripts": {
		"<command name can be anything>": "ts-add-js-extension --dir=dist"
	}
}

API:

tsAddJsExtension({
	dir: 'dist',
});

Note: If you need to include multiple root folders, such as "common", "dist", "build", or any other names you prefer, you can specify them accordingly, like the following

Command line:

{
	"scripts": {
		"<command name can be anything>": "ts-add-js-extension --dir=dist --include=common build --showchanges=true"
	}
}

API:

tsAddJsExtension({
	dir: 'dist',
	showProgress: true,
	include: ['common', 'build'],
});

Execution Process

Assuming you have a file called main.ts in the "dist" directory, the file structure would look like this:

dist/
  └─ main.ts

And main.ts contains the following imports and exports, where all the files are TypeScript files:

import { add } from './math';
export { add, sub, mul, div } from './math/index';

import div from './math/div';
export * as div from './math/div';

import word from './word';

console.log(add(2, 1));

When ts-add-js-extension is executed, it will generate the following code for main.js:

import { add } from './math/index.js';
export { add, sub, mul, div } from './math/index.js';

import div from './math/div.js';
export * as div from './math/div.js';

import word from './word/index.mjs';

console.log(add(2, 1));

During the process, ts-add-js-extension will traverse the project and analyze the file extensions of JavaScript files being imported or exported. It will then determine whether to add the .js or .mjs file extension based on the file's original extension.

This ensures that all the JavaScript files in your project have the correct file extension, enhancing compatibility and ensuring proper import/export functionality.

Arguments

Argument Usage Required Status Default Value
dir Specifies the folder where JavaScript file extension needs to be added Yes Active None
include Specifies the folder of files that are imported or included in the dir folder, excluding the specified dir No Deprecated []
showchanges Determines whether to display progress feedback in the format of Num. (File Updated) - (SUCCEED or FAILED) No Active True

Please note that the status column indicates whether an argument is active or deprecated, and the default value column specifies the default value if not provided

Contributions

I appreciate your active participation in the development process. If you come across any bugs, have feature requests, or need clarification on any aspect of the project, please don't hesitate to open an issue.

Additionally, your contributions to the project are highly valued. If you have ideas or improvements that you would like to implement, I invite you to suggest a pull request. Simply fork the repository, make the necessary code changes, add relevant tests to ensure quality, and push your changes.

Your feedback and contributions play an essential role in making the project better, and I am grateful for your involvement. Thank you for your support and participation in the development of the project.

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •