@lcbase/eslint-config-litts
TypeScript icon, indicating that this package has built-in type declarations

2.0.2 • Public • Published

Eslint Config for LIT Ts Project

This package provides Eslint's Config for LIT Ts Project.

Note 1: Only support the new Eslint flat config.

Note 2: This config is using the Airbnb eslint config.

Usage

1. Install package

pnpm add -D @lcbase/eslint-config-litts eslint

2. Add config to your eslint.config.js. Please read more about Eslint Flat Config

import { baseLitTsConfig } from '@lcbase/eslint-config-litts';

export default baseLitTsConfig;

3. Add script to your package.json.

{
  "scripts": {
    "lint": "eslint \"src/**/*.js\"",
    "lint:fix": "pnpm lint"
  }
}

4. Combine with @lcbase/prettier-config packages

pnpm add -D prettier @lcbase/prettier-config
{
  "prettier": "@lcbase/prettier-config",
  "scripts": {
    "lint": "eslint \"src/**/*.js\"",
    "lint:fix": "pnpm lint",
    "prettify": "prettier src --check",
    "prettify:fix": "prettier src --write",
    "format": "pnpm prettify:fix && pnpm lint:fix"
  }
}

5. Configuration your VScode.

In root your project's folder. Create .vscode folder with structure:

.vscode
  - settings.json
{
  "eslint.experimental.useFlatConfig": true,
  // if mono-repo remove below line comment
  // "eslint.workingDirectories": [{ "pattern": "./apps/*/" }, { "pattern": "./packages/*/" }],
  "eslint.options": {
    "overrideConfigFile": "eslint.config.js"
  },
  "editor.codeActionsOnSave": {
    "source.fixAll.eslint": true
  },
  "editor.defaultFormatter": "esbenp.prettier-vscode",
  "editor.formatOnSave": true
}

6. Setup git hooks

  • Install packages and global setup husky, lint-staged.
pnpm add -D husky lint-staged
npx husky install
npm pkg set scripts.prepare="husky install"
npx husky add .husky/pre-commit "npx lint-staged"
  • Add the following to your package.json:
{
  "scripts": {
    "prepare": "husky install"
  },
  "lint-staged": {
    "*.{js,cjs,mjs,jsx,cjsx,mjsx,ts,mts,cts,tsx,mtsx,ctsx}": ["pnpm format"],
    "*.{json,css,md,html}": ["pnpm prettify:fix"]
  }
}

Extends

You can extends this config by:

import { extendBaseLitTsConfig } from '@lcbase/eslint-config-litts';

const config = extendBaseLitTsConfig({
  files: (Linter.FlatConfigFileSpec | Linter.FlatConfigFileSpec[])[] | undefined, // files that you want to lint
  extendConfig: Linter.FlatConfig | Linter.FlatConfig[] | undefined, // your override extends config here
  litConfig: Linter.FlatConfig,
});

export default config;

Readme

Keywords

none

Package Sidebar

Install

npm i @lcbase/eslint-config-litts

Weekly Downloads

1

Version

2.0.2

License

MIT

Unpacked Size

9.04 kB

Total Files

8

Last publish

Collaborators

  • thienlinh
  • linh2t