Closed4

Astro × TailwindCSS × React な環境に ESLint と Prettier を導入する

r4air4ai

Prettier の導入

インストール
pnpm add -D prettier prettier-plugin-astro prettier-plugin-tailwindcss
.prettierrc.cjs
// @ts-check

/** @type {import('prettier').Options} */
module.exports = {
  printWidth: 80,
  tabWidth: 2,
  plugins: ["prettier-plugin-astro", "prettier-plugin-tailwindcss"],
  overrides: [
    {
      files: "*.astro",
      options: {
        parser: "astro",
      },
    },
  ],
};
package.json
 {
   "scripts": {
+    "format": "prettier --ignore-path .gitignore --write './**/*.{js,cjs,ts,jsx,tsx,astro,json,html,md}'",
   }
 }
r4air4ai

ESLint の導入

インストール
pnpm add -D eslint \
            eslint-config-prettier \
            eslint-plugin-astro \
            eslint-plugin-jsx-a11y \
            @typescript-eslint/eslint-plugin \
            @typescript-eslint/parser
.eslintrc.cjs
// @ts-check

/** @type {import('eslint').ESLint.ConfigData} */
module.exports = {
  root: true,
  extends: [
    "eslint:recommended",
    "plugin:@typescript-eslint/recommended",
    "plugin:astro/recommended",
    "prettier",
  ],
  env: {
    browser: true,
    node: true,
  },
  parser: "@typescript-eslint/parser",
  parserOptions: {
    ecmaVersion: "latest",
    sourceType: "module",
  },
  plugins: ["@typescript-eslint"],
  rules: {
    "no-undef": "off",
  },
  ignorePatterns: ["node_modules", "dist"],
  overrides: [
    {
      files: ["*.astro"],
      parser: "astro-eslint-parser",
      parserOptions: {
        parser: "@typescript-eslint/parser",
        extraFileExtensions: [".astro"],
      },
    },
    {
      files: "*.cjs",
      env: {
        node: true,
      },
      rules: {
        "@typescript-eslint/no-var-requires": "off",
      },
    },
  ],
};
package.json
 {
   "scripts": {
+    "check": "astro check && tsc --noEmit",
+    "lint": "eslint --ext '.js,.cjs,.ts,.jsx,.tsx,.astro' .",
+    "lint:fix": "eslint --ext '.js,.cjs,.ts,.jsx,.tsx,.astro' --fix .",
   }
 }
r4air4ai

lint-staged, husky の導入

1. husky の導入

husky をインストールする。

pnpx husky-init && pnpm install

pre-commit の設定を行う。

pnpm exec husky set .husky/pre-commit "pnpm exec lint-staged"

https://typicode.github.io/husky/getting-started.html#automatic-recommended

2. lint-staged の導入

lint-staged をインストールする。

pnpm add -D lint-staged 

lint-staged の設定を書く。

.lintstagedrc.cjs
// @ts-check

/** @type {import('lint-staged').Config} */
module.exports = {
  "*.{js,cjs,ts,jsx,tsx,astro}": ["eslint --fix", "prettier --write"],
  "*.{md,html,json,yaml,yml}": ["prettier --write"],
}

3. 動作確認

git add -A && git commit -m 'chore: huskyとlint-stagedを導入し、commit時にeslintとprettierを実行させる'

参考文献

https://github.com/okonet/lint-staged#installation-and-setup

https://github.com/typicode/husky

r4air4ai

push 時に pnpm run check を実行させる

pre-push を設定する。

pnpm exec husky set .husky/pre-push "pnpm run check"

動作確認する。

git add -A && \
    git commit -m 'chore: push時に`pnpm run check`を実行させる && \
    git push
このスクラップは2023/08/23にクローズされました