forked from nasa-gcn/web-dev-bootcamp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
lint-staged.config.mjs
38 lines (35 loc) · 1.29 KB
/
lint-staged.config.mjs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import { ESLint } from 'eslint'
import prettier from 'prettier'
// Adapted from https://github.com/okonet/lint-staged#how-can-i-ignore-files-from-eslintignore
async function eslintRemoveIgnoredFiles(files) {
const eslint = new ESLint()
const isIgnored = await Promise.all(
files.map((file) => {
return eslint.isPathIgnored(file)
})
)
const filteredFiles = files.filter((_, i) => !isIgnored[i])
return filteredFiles.join(' ')
}
// Adapted from https://github.com/okonet/lint-staged#how-can-i-ignore-files-from-eslintignore
function prettierRemoveIgnoredFiles(files) {
const filteredFiles = files.filter(
(file) => !prettier.getFileInfo(file).isIgnored
)
return filteredFiles.join(' ')
}
export default {
// Note, this rule should include *.mdx, but mdx linting is broken.
// See https://github.com/mdx-js/eslint-mdx/issues/367.
'*.{cjs,mjs,js,jsx,ts,tsx}': async (files) => {
const filteredFiles = await eslintRemoveIgnoredFiles(files)
if (!files) return []
return `eslint --cache --fix --max-warnings 0 ${filteredFiles}`
},
'*.{ts,tsx}': () => 'tsc',
'*.{css,scss,cjs,mjs,js,json,jsx,md,mdx,ts,tsx}': async (files) => {
const filteredFiles = prettierRemoveIgnoredFiles(files)
if (!files) return []
return `prettier --write ${filteredFiles}`
},
}