https://github.com/dolmios/eslint-config-dolmios
  
  
    A simple ESLint setup using @typescript-eslint. 
    https://github.com/dolmios/eslint-config-dolmios
  
core-web-vitals eslint nextjs prettier react typescript
        Last synced: 4 months ago 
        JSON representation
    
A simple ESLint setup using @typescript-eslint.
- Host: GitHub
- URL: https://github.com/dolmios/eslint-config-dolmios
- Owner: dolmios
- Created: 2022-04-14T06:29:01.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2025-06-06T18:38:04.000Z (5 months ago)
- Last Synced: 2025-06-10T09:04:36.768Z (5 months ago)
- Topics: core-web-vitals, eslint, nextjs, prettier, react, typescript
- Language: JavaScript
- Homepage: https://www.npmjs.com/package/eslint-config-dolmios
- Size: 613 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
- 
            Metadata Files:
            - Readme: README.md
 
Awesome Lists containing this project
README
          # eslint-config-dolmios
> A comprehensive ESLint (9) setup using [@typescript-eslint](https://typescript-eslint.io), integrated with Prettier and tailored TSConfig setups for modern JavaScript and TypeScript projects. This config is designed for my projects, but feel free to use it as a starting point for your own projects.
## Install
```sh
pnpm  add  eslint-config-dolmios
```
## Usage
This ESLint configuration is designed for use with ESLint v9, which uses a flat config format. Follow the steps below to integrate it into your project.
### Setting Up ESLint
1.  **Create an ESLint Configuration File**: In the root of your project, create a file named  `eslint.config.js`.
2.  **Import and Extend the Configuration**: Add the following content to  `eslint.config.js`  to use the  `eslint-config-dolmios`  configuration:
```js
import dolmios from "eslint-config-dolmios";
export default [
  ...dolmios,
  // Add any project-specific overrides here
];
```
### Features
- **TypeScript Support**: Comprehensive TypeScript linting with strict type checking
- **React Best Practices**: Rules for React and React Hooks
- **Accessibility**: A11y rules to ensure your app is accessible
- **Next.js Optimization**: Includes Next.js Core Web Vitals rules for performance optimization
- **Code Organization**: Perfectionist plugin for consistent code organization
- **Modern JavaScript**: Enforces modern JavaScript practices
### Next.js Compatibility
This configuration automatically detects your Next.js project structure and adjusts accordingly:
- **App Router Support**: Works with Next.js App Router projects
- **Pages Router Support**: Works with Next.js Pages Router projects
- **Non-Next.js Projects**: Works with regular React projects without Next.js
The configuration automatically detects:
- If you're using Next.js (by checking for `next.config.js`)
- If you're using App Router (by checking for an `app` directory)
- If you're using Pages Router (by checking for `pages` or `src/pages` directories)
Rules like `no-html-link-for-pages` are only enabled when a Pages Router is detected.
---
### Usage with Prettier
Prettier is configured to work seamlessly with this ESLint setup. To include Prettier, add the configuration to your  `package.json`:
```js
"prettier": "eslint-config-dolmios/configs/prettier"
```
#### Extending Prettier
If you need to extend the Prettier configuration, you can do so by creating a  `.prettierrc.js`  file and exporting your modifications:
For more details, refer to the [Prettier documentation](https://prettier.io/docs/en/configuration.html#sharing-configurations).
```js
module.exports = {
  ...require("eslint-config-dolmios/configs/prettier"),
  parser: "babel",
};
```
---
### Usage with TSConfig
This config also exports two TSConfig setups, `base` and `lib` respectively. The _base_ config is generally suitable. To include either, extend your `tsconfig.json`.
```
"extends": "eslint-config-dolmios/configs/tsconfig"
```
  
## Configurations
You can view the ESLint configuration in the reference notes: [reference.txt](./reference.txt). 
## Acknowledgments
This configuration leverages several third-party libraries to enhance linting and formatting capabilities:
-   **[@typescript-eslint/eslint-plugin](https://github.com/typescript-eslint/typescript-eslint)**: Provides TypeScript-specific linting rules.
-   **[eslint-plugin-react-hooks](https://www.npmjs.com/package/eslint-plugin-react-hooks)**: Enforces the rules of React Hooks.
-   **[eslint-plugin-jsx-a11y](https://github.com/jsx-eslint/eslint-plugin-jsx-a11y)**: Static AST checker for accessibility rules on JSX elements.
-   **[eslint-plugin-next](https://github.com/vercel/next.js/tree/canary/packages/eslint-plugin-next)**: Provides Next.js specific linting rules.
-   **[eslint-plugin-perfectionist](https://github.com/azat-io/eslint-plugin-perfectionist)**: Handles sorting of imports, objects, and other elements for a consistent codebase.
-   **[eslint-config-prettier](https://github.com/prettier/eslint-config-prettier)**: Disables ESLint rules that might conflict with Prettier.
## License
This project is licensed under the MIT License.