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

@meow-double/eslint

v2.1.2

Published

Eslint config for your code

Readme

Eslint config🧹

This npm package include eslind config for your code.

Install

Use this command to set the stylelint configure

npm i -D @meow-double/eslint

ℹ️INFO
Add the npm package as a dev dependency

The library allows you to use TypeScript (TS) at once thanks to @typescript-eslint/parser

How use eslint version 9

  1. Create a file named eslint.config.js in the root of the directory

  2. Import the eslint configuration and export it externally properly

  3. The @meow-double/eslint library provides you with an eslint function that returns the desired config. You can also pass a customized config as an argument, which will change the eslint-config itself from the outside. If you don't need to change anything externally, the default settings will be used.

    import config9 from '@meow-double/eslint/v9';
    
    export default config9()

How use eslint version 8

  1. Create a file named .eslintrc.cjs in the root of the directory

    ℹ️INFO File must contain the .cjs extension, since commonjs is supported

  2. Import the eslint configuration and export it externally properly

  3. The @meow-double/eslint library provides you with an eslint function that returns the desired config. You can also pass a customized config as an argument, which will change the eslint-config itself from the outside. If you don't need to change anything externally, the default settings will be used.

    const { eslint } = require('@meow-double/eslint/v8');
    
    module.exports = eslint({});

Transmitted parameters for version 9

The config was written in typewritten language, so it supports typing of all test parameters

Example parametrs


type eslint = import('typescript-eslint').FlatConfig.Config;

interface FSDRulesType {
  alias: string;
  testFilesPatterns: string[];
  testingPublicFile: string;
  ignoreImportPatterns: string[];
}

export interface DefaultOptionsType {
  plugins: eslint['plugins'];
  globals: {
    tests: 'jest' | 'vitest' | null;
    es: 'es2024';
    other: eslint['languageOptions']['globals'];
  };
  ignore: string[];
  defaultRules: {
    rules: Record<string, string>;
    files: string[];
  };
  config: eslint[];
  fsd: FSDRulesType | null;
  project: eslint['languageOptions']['parserOptions']['project'];
}



//Default value for this config

  const options: DefaultOptionsType = {
    config: [],
    defaultRules: {
      files: [],
      rules: {},
    },
    fsd: null,
    globals: {
      es: 'es2024',
      tests: null,
      other: {},
    },
    ignore: [],
    plugins: {},
    project: ['tsconfig.json', 'tsconfig.node.json'],
  }

How use eslint v9? eslint.config.js

  import config9 from '@meow-double/eslint/v9';

  const options = {
  config: [
    {
      files: ['**/src/**/*.icon.tsx'],
      rules: {
        'max-len': 'off',
      },
    },
  ],
  defaultRules: {
    files: [],
    rules: {
      'custom/one-component': 'off',
      'react/display-name': 'off',
      'react-hooks/rules-of-hooks': 'off',
      'react/no-array-index-key': 'off',
      'no-underscore-dangle': 'off',
      '@typescript-eslint/ban-ts-comment': 'off',
      'no-param-reassign': 'off',
    },
  },
  fsd: {
    alias:"@",
    testFilesPatterns: ["**/*.{test,spec}.{ts,tsx}"];
    testingPublicFile: "testing";
    ignoreImportPatterns: "**/Store";
  },
  globals: {
    es: 'es2024',
    tests: "vitest",
    other: {},
  },
  ignore: ['storybook-static'],
  plugins: {},
  project: ['tsconfig.json', 'tsconfig.app.json'],
  }

  export default config9(options)

Script for version 9

You need to add script on your package.json

    "lint": "eslint . --ext .js,.ts,.tsx",
    "lint:fix": "eslint . --ext .js,.ts,.tsx --fix"

Custom plugin:

fsd-path - Used in projects containing FSD architecture. It checks the relative nature of layers to prevent interdependencies within a single layer (e.g., functions, widgets, etc.). You can pass an alias that identifies you within the project.

 'fsd-path/slice-path' : ['error', {alias:"@"}]

fsd-public-api-imports - Ensures that modules are imported from their root index files. The Shared folder is not used. You can pass an alias that identifies you in the project.

 'fsd-public-api-imports/module-import' : [
    'error',
    {
      alias:"@",
      ignoreImportPatterns: "**/Store";
    }
  ]

fsd-layer-imports - Ensures that the data flow is controlled in a single manner. From shared folders on the corresponding pages.

 'fsd-layer-imports/imports' : [
    'error',
    {
      alias:"@",
      testFilesPatterns:"**/*.test.{ts,tsx}",
      testingPublicFile:"testing"
    }
  ]

#### Transmitted parameters for version 8

All arguments are passed as properties of the object
</br>

| Argument     | Available values  | Description                                                                                                                                                      |
| ------------ | ----------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| test         | `jest` \| `null`  | This parameter registers the jest environment in env. Also thanks to this argument, test files use a modified set of eslint configuration rules.                 |
| storybook    | `true` \| `false` | With this argument, the modified eslint config rules will be applied to files with the <b>.stories</b> extension                                                 |
| defaultRules | `Object`          | By passing an object to this argument you can directly change the rules for eslint configa. Moreover, the rules for different plugins will be taken into account |

> ℹ️INFO
> Of course, this package will not be able to give you flexible configuration settings. If you are using this package, you probably don't need flexible configuration. Otherwise, use your own configuration

</br>

<b>Default values that are passed automatically when executing the eslint function</b>

{ test: null, storybook:false, allRules:{} }


#### Flexible customization of the defaultRules argument

The object is passed with all the rules and their values that you would like to change. Rules of used plugins are also supported. The list of used plugins is provided below in the documentation.
</br>

<b>Example</b>

```JavaScript

    const { eslint } = require('@meow-double/eslint/v8');

    module.exports = eslint({
        test:"jest",
        storybook:true,
        allRules:{
            'max-len': ['error', { ignoreComments: true, code: 100 }],
            'no-useless-assignment': 'off',
            'require-await': 'error',
            'no-unused-vars': 'warn',
            'react/jsx-props-no-spreading': 'off',
            'react/no-array-index-key': 'error'
        }
    });

Script for version 8

You need to add script on your package.json
For JS

    "lint:js": "npx eslint --config .eslintrc.cjs \"src/**/*.{js,jsx}\"",
    "lint:js:fix": "npx eslint --config .eslintrc.cjs \"src/**/*.{js,jsx}\" --fix"
    "lint:ts": "npx eslint --config .eslintrc.cjs \"src/**/*.{ts,tsx}\"",
    "lint:ts:fix": "npx eslint --config .eslintrc.cjs \"src/**/*.{ts,tsx}\" --fix",

All the rules used

  • 5 used plugins
  • 1 custom plugin
  • 1 parser

All plugins: 7

ℹ️INFO
By default, ready-made rule sets from the plugins themselves are used

 extends: [
      'eslint:recommended',
      'plugin:@typescript-eslint/recommended',
      'plugin:react-hooks/recommended',
      'plugin:react/recommended',
    ],

Base rules

| Rule Name | Used value | | ------------------------------- | ------------------------------------------- | | consistent-return | 'off' | | no-shadow | 'warn' | | no-duplicate-imports | 'error' | | no-fallthrough | 'warn' | | no-promise-executor-return | 'error' | | no-self-compare | 'error' | | no-template-curly-in-string | 'error' | | no-use-before-define | 'error' | | no-useless-assignment | 'off' | | require-atomic-updates | 'error' | | require-await | 'error' | | no-param-reassign | ['error', { props: false }] | | no-console | ['error', { allow: ['info', 'error'] }] | | no-underscore-dangle | ['error', { allow: ['_id', '_default'] }] | | no-unused-vars | 'warn' |

Eslint-plugin-react

| Rule Name | Used value | | --------------------------------------- | ----------------------------------------------------------------------------------------- | | react/prop-types | 'off' | | react/jsx-indent | [2, 2, { checkAttributes: true }] | | react/no-children-prop | 'off' | | react/react-in-jsx-scope | 'off' | | react/no-unused-prop-types | 'error' | | react/require-default-props | 'off' | | react/jsx-props-no-spreading | 'off' | | react/no-array-index-key | 'error' | | react/button-has-type | 'warn' | | react-hooks/exhaustive-deps | 'warn' | | react/function-component-definition | ['error', { namedComponents: ['arrow-function'], unnamedComponents: 'arrow-function' }] | | react/jsx-no-useless-fragment | ['error', { allowExpressions: true }] |

Eslint-plugin-react-hooks

| Rule Name | Used value | | ------------------------------- | ---------- | | react-hooks/rules-of-hooks | 'error' | | react-hooks/exhaustive-deps | error |

Eslint-plugin-import

| Rule Name | Used type | | ------------------------------------- | --------- | | import/order | 'off' | | import/extensions | 'off' | | import/prefer-default-export | 'off' | | import/no-extraneous-dependencies | 'off' |

Eslint-plugin-simple-import-sort

| Rule Name | Used type | | ------------------------------ | ---------------------------- | | simple-import-sort/exports | 'error' | | simple-import-sort/imports | ['error', (objectOptions)] |

Object options:

 {
      groups: [
        // External packages:
        ['^react', '^@?\\w'],
        // Alias imports:
        ['^@(([\\/.]?\\w)|assets|test-utils)'],
        // Side effect imports:
        ['^\\u0000'],
        // Parent imports:
        ['^\\.\\.(?!/?$)', '^\\.\\./?$'],
        // Other relative imports:
        ['^\\./(?=.*/)(?!/?$)', '^\\.(?!/?$)', '^\\./?$'],
        // Style imports:
        ['^.+\\.s?css$'],
        // Svg icons imports:
        ['^.+\\.svg$'],
      ],
    }

@typescript-eslint/eslint-plugin

| Rule Name | Used type | | -------------------------------------- | --------- | | @typescript-eslint/no-explicit-any | 'warn' |

Custom plugin

| Rule Name | Used type | | ------------------------ | --------- | | custom/one-component | 'error' |

The rule prohibits the use of two react components in one file

❌Example of incorrect code

export const App = () => {
    return <div><SecondaryComponent /></div>
}

const SecondaryComponent = () => <p>This is a secondary component</p>

✅Example of correct code

import { SecondaryComponent } from "@/components";

export const App = () => {
    return <div><SecondaryComponent /></div>
}