Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

relative-to-alias-resolver

metroxe19MIT1.1.4TypeScript support: included

Transform your TypeScript project with ease using the relative-to-alias-resolver. This powerful tool converts cumbersome relative imports into clean, maintainable alias imports, enhancing code readability and maintainability.

TypeScript, Alias Imports, Relative Imports, Code Readability, Code Maintainability, CLI Tool, tsconfig, TypeScript Project, Build Process, Developer Tools

readme

Relative to Alias Resolver

npm version

Overview

The Relative to Alias Resolver is a tool designed to convert a TypeScript project from using relative imports to alias imports. This can help improve the readability and maintainability of your codebase by using more descriptive import paths.

For example, it can transform your imports from this:

// Before conversion
import { MyComponent } from '../../../components/MyComponent';
import { utilFunction } from '../../utils/utilFunction';

to this:

// After conversion
import { MyComponent } from '@/components/MyComponent';
import { utilFunction } from '@/utils/utilFunction';

This makes your code cleaner and easier to maintain, especially in larger projects.

Why Use This Package?

  • Improved Code Readability: Alias imports make your code cleaner and easier to navigate.
  • Enhanced Maintainability: Simplifies refactoring and reduces the risk of import path errors.
  • Seamless Integration: Easily integrates with existing TypeScript projects and build processes.

Features

  • Converts relative imports to alias imports based on your tsconfig.json configuration.
  • Supports both CommonJS and ES Module formats.
  • Provides a CLI for easy integration into your build process.
  • Includes options for dry runs and concurrency control.

Installation

To install the package cli, use npm:

npm install -g relative-to-alias-resolver

if you intend to use the library in your project, you can install it locally:

npm install relative-to-alias-resolver

Usage

CLI

The package provides a command-line interface to perform the conversion. You can use it as follows:

relative-to-alias-resolver --project <path-to-project> --tsconfig <path-to-tsconfig>

Options

  • -p, --project <path>: The path to the project to generate alias imports for. Defaults to ..
  • -t, --tsconfig <path>: The path to the tsconfig.json file to use for the project. Defaults to ./tsconfig.json.
  • -d, --dry-run: Whether to run the command in dry run mode. Defaults to false.
  • -i, --ignore <patterns>: A comma-separated list of regex patterns for paths to ignore. Defaults to ["node_modules"].
  • -v, --verbose: Enable verbose logging. Defaults to false.

Example

relative-to-alias-resolver --project ./project --tsconfig ./project/tsconfig.json

Library

The library can be used to convert relative imports to alias imports in a TypeScript project.

import { resolveRelativeToAlias } from "relative-to-alias-resolver";

resolveRelativeToAlias({
  projectPath: "./src",
  tsconfigPath: "./tsconfig.json",
  dryRun: true,
  ignore: ["node_modules"],
});

Configuration

The tool relies on the tsconfig.json file to determine the base URL and paths for aliasing. Ensure your tsconfig.json is correctly configured with the baseUrl and paths properties.

Example tsconfig.json:

{
  "compilerOptions": {
    "baseUrl": ".",
    "paths": {
      "@/*": ["src/*"]
    }
  }
}

changelog

1.1.4 (2024-10-24)

Bug Fixes

  • remove unused libraries (72ee86f)

1.1.3 (2024-10-24)

Bug Fixes

  • add the repository URL so its linked back on npm (a7c07c4)

1.1.2 (2024-10-24)

Bug Fixes

  • add additional details for npm to package.json (367885b)

1.1.1 (2024-10-24)

Bug Fixes

1.1.0 (2024-10-24)

Bug Fixes

  • fix bug with abs imports at the base url (2fe47a4)

Features

  • add verbose & fix issues with detecting correct paths (ff90794)

1.0.8 (2024-10-24)

Bug Fixes

  • fix bug with argument names (6c5664e)

1.0.7 (2024-10-24)

Bug Fixes

  • add a bin for running as an executable (bd3db87)
  • run with an import in cjs (5c80778)

1.0.6 (2024-10-24)

Bug Fixes

  • force the js file to run with node (4760b55)

1.0.5 (2024-10-24)

Bug Fixes

  • add example to the README (d81d505)
  • fix bug with the cli not pointing to the correct cjs file (316fb9d)

1.0.4 (2024-10-24)

Bug Fixes

  • add badges to the readme (d154682)
  • remove extra files that were being put in the npm package (ba44b21)

1.0.3 (2024-10-24)

Bug Fixes

  • fix dry run not working (51dc7cf)

1.0.2 (2024-10-24)

Bug Fixes

  • remove concurrency option, and add readme (a167b5c)

1.0.1 (2024-10-24)

Bug Fixes

  • add missing build step (aadcf11)
  • fix broken script with call to different package manager (16ea407)

1.0.0 (2024-10-24)

Bug Fixes

  • fix the package.json syntax error (5927681)
  • move the release workflow to the correct directory (c23117f)