npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@matsgottenbos/eslint-plugin-import-alias

v1.2.3

Published

ESLint rule for restricting imports to path aliases

Downloads

2,100

Readme

eslint-plugin-import-alias

An ESLint rule for forcing import path aliases.

This is a fork of https://github.com/steelsojka/eslint-import-alias by Steven Sojka. The original project seems to be abandoned.

Installation

yarn add -D @matsgottenbos/eslint-plugin-import-alias

Usage

import { test } from '~/test'; // valid
import { test } from '@src/test'; // valid
import { test } from './test'; // invalid
import { test } from '../test'; // invalid

// Optional relative depth can be specified to allow unaliased paths when they do not go up to parent directories higher than the relative depth
import { test } from './test'; // valid, { relativeDepth: 0 }
import { test } from './test/test'; // valid, { relativeDepth: 0 }
import { test } from '../test'; // valid, { relativeDepth: 1 }
import { test } from '../../test'; // invalid, { relativeDepth: 1 }

Configure

{
  "rules": {
    "import-alias/import-alias": [
      "error",
      {
        "relativeDepth": 0,
        "aliases": [
          // Example: rewrites imports pointing to `src/modules/app/index.js` to `@src/modules/app/index.js`
          { "alias": "@src", "matcher": "^src" },

          // Example: rewrites imports pointing to `test/unit/modules/app` to `@test/modules/app`
          { "alias": "@test", "matcher": "^test\/unit" },

          // Example: rewrites imports pointing to `test/e2e/modules/app` to `@testRoot/e2e/modules/app`
          { "alias": "@testRoot", "matcher": "^(test)\/e2e" },
        ]
      }
    ]
  }
}

Aliases can be configured to fix the path and rewrite to an aliased path. Each alias has the alias text and a regex matcher that will match against the resolved path from the root directory of the eslint process (usually the project root). For example, if the resolved file path is in the 'src' folder (src/modules/app/test) then 'src' will be replaced with '@src'. Optionally, you can define a capture group to replace only the part within the capture group, but still match against the whole regex.

A 'rootDir' can be defined to resolve the file paths from. This defaults to process.cwd(). In a lot of cases, this is already the project root in most cases.

{
  "rules": {
    "import-alias/import-alias": [
      "error",
      {
        "relativeDepth": 0,
        "rootDir": __dirname,
        "aliases": [
          // Example: rewrites imports pointing to `src/modules/app/index.js` to `~/modules/app/index.js`
          { "alias": "~/", "matcher": "^" },

          // Example: rewrites imports pointing to `src/modules/app/index.js` to `@src/modules/app/index.js`
          { "alias": "@src", "matcher": "^src" },
        ]
      }
    ]
  }
};