3.0.3 โ€ข Published 7 months ago

@hrcd/eslint-config v3.0.3

Weekly downloads
-
License
-
Repository
github
Last release
7 months ago

social-banner.jpg

@hrcd/eslint-config

license

A comprehensive and opinionated ESLint Flat configuration designed to provide an optimal development experience with Vue, Nuxt and TypeScript projects, while supporting many other technologies.

โœจ Features

  • ๐Ÿ”„ Auto-fix formatting - No need for Prettier, everything is handled by ESLint
  • โšก Vue & Nuxt optimized - First-class support for Vue 3 and the Nuxt ecosystem
  • ๐Ÿ”’ TypeScript ready - Built specifically for TypeScript projects with strict type checking
  • ๐ŸŒ Multi-language support - Handles JavaScript, TypeScript, Vue, JSON, YAML, Markdown and more
  • ๐Ÿ“ฆ PNPM optimized - Special rules for projects using PNPM workspaces
  • ๐Ÿš€ PNPM Catalog support - Integration with the new PNPM Catalog feature for better dependency management
  • ๐Ÿงน Style consistency - Ensures consistent code style with sorted imports and logical formatting
  • ๐Ÿ› ๏ธ Easily customizable - Opinionated defaults but highly configurable
  • ๐Ÿ“ .gitignore integration - Automatically respects your .gitignore files

๐Ÿ“ฅ Installation

# โœจ Auto-detect
npx nypm install @hrcd/eslint-config

# npm
npm install @hrcd/eslint-config

# yarn
yarn add @hrcd/eslint-config

# pnpm
pnpm install @hrcd/eslint-config

# bun
bun install @hrcd/eslint-config

๐Ÿ”ง Configuration

Create an eslint.config.js file at the root of your project:

import { createConfig } from "@hrcd/eslint-config"

export default createConfig()

โš™๏ธ Customization

The configuration is opinionated but flexible. You can customize it to match your project's needs:

import { createConfig } from "@hrcd/eslint-config"

export default createConfig({
  // Enable/disable features
  typescript: true, // TypeScript support
  vue: true,        // Vue support
  nuxt: true,       // Nuxt support

  // Define files to ignore
  ignores: [
    'dist',
    'node_modules',
    // Other patterns to ignore
  ]
})

๐Ÿ“Š PNPM Catalog Support

This ESLint config includes optimized rules for projects using PNPM Catalog, the new feature that helps manage and organize packages in PNPM workspaces. It ensures proper dependency declarations, prevents hoisting issues, and maintains catalog structure consistency.

๐Ÿ’ป IDE Integration

VS Code

  1. Install the ESLint extension
  2. Add to your settings.json:
{
  "eslint.validate": [
    "javascript",
    "typescript",
    "vue",
    "html",
    "markdown",
    "json",
    "yaml"
  ],
  "editor.codeActionsOnSave": {
    "source.fixAll.eslint": true
  }
}

๐Ÿ› ๏ธ Development

  • Clone this repository
  • Install latest LTS version of Node.js
  • Enable Corepack using corepack enable
  • Install dependencies using bun install

๐Ÿค Contributing

To start contributing, follow these steps:

  1. First raise an issue to discuss the changes you would like to make.
  2. Fork the repository.
  3. Create a branch using conventional commits and the issue number as the branch name. For example, feat/123 or fix/456.
  4. Make changes following the local development steps above.
  5. Commit your changes following the Conventional Commits specification.
  6. Run tests using pnpm run test.
  7. Create a pull request following the Pull Request Template.
    • To be merged, the pull request must pass the tests/workflows and have at least one approval.
    • If your changes affect the documentation, make sure to update it.
    • If your changes affect the code, make sure to update the tests.
  8. Wait for the maintainers to review your pull request.
  9. Once approved, the pull request will be merged in the next release!

Sponsors

Contributors

Published under the APACHE license. Made by @HugoRCD and community ๐Ÿ’›


๐Ÿค– auto updated with automd (last updated: Thu Apr 03 2025)