eslint-plugin-no-z-index
v1.0.1
Published
ESLint rule to disable the usage of z-index on tailwind classes and style attributes
Downloads
6
Maintainers
Readme
eslint-plugin-no-z-index
Overview
eslint-plugin-no-z-index
is an ESLint plugin that disallows the usage of z-*
classnames and inline styles with zIndex
. This helps to enforce a consistent approach to managing z-index in your projects.
Installation
Option 1: Install from npm
- Install the plugin using npm:
npm install eslint-plugin-no-z-index --save-dev
Option 2: Link Locally
Clone the plugin repository and navigate to the directory:
git clone <repository-url> cd eslint-plugin-no-z-index
Link the plugin locally:
npm link
In your project directory, link the local plugin:
npm link eslint-plugin-no-z-index
Usage
Add
no-z-index
to the plugins section of your ESLint configuration file (.eslintrc.js, eslint.config.js, etc.).Enable the rule provided by the plugin.
Example Configuration
.eslintrc.js:
module.exports = {
root: true,
parserOptions: {
ecmaVersion: 2021,
sourceType: "module",
ecmaFeatures: {
jsx: true,
},
},
plugins: ["no-z-index"],
extends: ["eslint:recommended"],
rules: {
"no-z-index/no-z-index": "error",
},
};
Example Configuration with eslint.config.mjs:
import { FlatCompat } from "@eslint/eslintrc";
import noZIndex from "eslint-plugin-no-z-index";
// Compatibility helper for old-style .eslintrc files
const compat = new FlatCompat({
baseDirectory: import.meta.url,
});
export default [
{
files: ["src/**/*.js", "src/**/*.jsx"],
plugins: {
"no-z-index": noZIndex,
},
rules: {
"no-z-index/no-z-index": "error",
},
languageOptions: {
ecmaVersion: 2021,
sourceType: "module",
ecmaFeatures: { jsx: true },
},
},
...compat.config({}),
];
Rule Details
no-z-index/no-z-index
This rule disallows the usage of z-*
classnames and inline styles with zIndex
.
Examples of incorrect code:
// Using z-* classname
<div className="z-10"></div>;
// Using inline style with zIndex
<div style={{ zIndex: 10 }}></div>;
Examples of correct code:
// Classname without z-*
<div className="foo"></div>;
// Inline style without zIndex
<div style={{ color: "red" }}></div>;
Contributing
- Fork the repository.
- Create a new branch (
git checkout -b feature-branch
). - Make your changes.
- Commit your changes (
git commit -am 'Add new feature'
). - Push to the branch (
git push origin feature-branch
). - Create a new Pull Request.
License
This project is licensed under the MIT License.