Compare commits

..

19 Commits

Author SHA1 Message Date
Anthony Fu
6189a9225c chore: release v0.31.1 2022-11-29 17:33:07 +08:00
Anthony Fu
46a39e1506 chore: update deps 2022-11-29 17:33:00 +08:00
lainbo
1c37b247c5 feat: support TS 4.9 (#133) 2022-11-29 17:27:36 +08:00
Anthony Fu
2a1e59f43b chore: release v0.31.0 2022-11-17 01:27:39 +08:00
Anthony Fu
94b5fdddad chore: update deps 2022-11-17 01:27:16 +08:00
曾明健
65aec3f101 feat(basic): add max-statements-per-line (#129) 2022-11-17 01:25:16 +08:00
Anthony Fu
b53ffae83e chore: release v0.30.1 2022-11-12 15:06:28 +08:00
Anthony Fu
20c01380c9 fix: move deps 2022-11-12 15:06:25 +08:00
Anthony Fu
6b3f6e620b chore: release v0.30.0 2022-11-12 15:04:52 +08:00
Anthony Fu
693eba91a8 chore: update deps 2022-11-12 15:04:41 +08:00
Anthony Fu
b820b0fd92 feat: auto JS fallback 2022-11-12 15:03:35 +08:00
Anthony Fu
f8014b745e chore: release v0.29.4 2022-11-07 21:04:08 +08:00
Anthony Fu
95e28e4a4a fix(generic-spacing): improve cases 2022-11-07 21:03:56 +08:00
Anthony Fu
54b234f4ef chore: release v0.29.3 2022-11-02 17:21:31 +08:00
Anthony Fu
ff6a1fad6a fix(generic-spacing): improve cases 2022-11-02 17:21:24 +08:00
Anthony Fu
e13613fd5f chore: release v0.29.2 2022-11-01 04:01:12 +08:00
Anthony Fu
e111029e0a feat(generic-spacing): remove space before generic 2022-11-01 04:00:59 +08:00
Anthony Fu
254f8194df chore: release v0.29.1 2022-11-01 03:38:15 +08:00
Anthony Fu
4119f52750 fix(generic-spacing): avoid overriding extends 2022-11-01 03:38:06 +08:00
14 changed files with 851 additions and 668 deletions

View File

@@ -15,48 +15,48 @@
"up": "taze major -I" "up": "taze major -I"
}, },
"dependencies": { "dependencies": {
"@unocss/reset": "^0.45.8", "@unocss/reset": "^0.47.0",
"@vueuse/core": "^9.1.0", "@vueuse/core": "^9.6.0",
"@vueuse/head": "^0.7.9", "@vueuse/head": "^1.0.18",
"nprogress": "^0.2.0", "nprogress": "^0.2.0",
"pinia": "^2.0.17", "pinia": "^2.0.27",
"vue": "^3.2.37", "vue": "^3.2.45",
"vue-demi": "^0.13.6", "vue-demi": "^0.13.11",
"vue-i18n": "^9.2.2", "vue-i18n": "^9.2.2",
"vue-router": "^4.1.3" "vue-router": "^4.1.6"
}, },
"devDependencies": { "devDependencies": {
"@antfu/eslint-config": "^0.25.2", "@antfu/eslint-config": "^0.31.0",
"@iconify-json/carbon": "^1.1.7", "@iconify-json/carbon": "^1.1.11",
"@intlify/vite-plugin-vue-i18n": "^6.0.0", "@intlify/vite-plugin-vue-i18n": "^6.0.3",
"@types/markdown-it-link-attributes": "^3.0.1", "@types/markdown-it-link-attributes": "^3.0.1",
"@types/nprogress": "^0.2.0", "@types/nprogress": "^0.2.0",
"@vitejs/plugin-vue": "^3.0.1", "@vitejs/plugin-vue": "^3.2.0",
"@vue/test-utils": "^2.0.2", "@vue/test-utils": "^2.2.4",
"critters": "^0.0.16", "critters": "^0.0.16",
"cross-env": "^7.0.3", "cross-env": "^7.0.3",
"cypress": "^10.4.0", "cypress": "^11.2.0",
"eslint": "^8.21.0", "eslint": "^8.28.0",
"eslint-plugin-cypress": "^2.12.1", "eslint-plugin-cypress": "^2.12.1",
"https-localhost": "^4.7.1", "https-localhost": "^4.7.1",
"markdown-it-link-attributes": "^4.0.0", "markdown-it-link-attributes": "^4.0.1",
"markdown-it-shiki": "^0.5.1", "markdown-it-shiki": "^0.6.1",
"pnpm": "^7.8.0", "pnpm": "^7.17.1",
"shiki": "^0.10.1", "shiki": "^0.11.1",
"taze": "^0.7.6", "taze": "^0.8.4",
"typescript": "^4.7.4", "typescript": "^4.9.3",
"unocss": "^0.45.5", "unocss": "^0.47.0",
"unplugin-auto-import": "^0.11.0", "unplugin-auto-import": "^0.12.0",
"unplugin-vue-components": "^0.22.0", "unplugin-vue-components": "^0.22.11",
"vite": "^3.0.4", "vite": "^3.2.4",
"vite-plugin-inspect": "^0.6.0", "vite-plugin-inspect": "^0.7.9",
"vite-plugin-pages": "^0.25.0", "vite-plugin-pages": "^0.27.1",
"vite-plugin-pwa": "^0.12.3", "vite-plugin-pwa": "^0.13.3",
"vite-plugin-vue-layouts": "^0.7.0", "vite-plugin-vue-layouts": "^0.7.0",
"vite-plugin-vue-markdown": "^0.21.1", "vite-plugin-vue-markdown": "^0.22.1",
"vite-ssg": "^0.20.2", "vite-ssg": "^0.22.0",
"vite-ssg-sitemap": "^0.3.1", "vite-ssg-sitemap": "^0.4.3",
"vitest": "^0.21.0", "vitest": "^0.25.3",
"vue-tsc": "^0.39.5" "vue-tsc": "^1.0.9"
} }
} }

View File

@@ -7,6 +7,8 @@ export const install: UserModule = ({ isClient, router }) => {
if (to.path !== from.path) if (to.path !== from.path)
NProgress.start() NProgress.start()
}) })
router.afterEach(() => { NProgress.done() }) router.afterEach(() => {
NProgress.done()
})
} }
} }

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config-monorepo", "name": "@antfu/eslint-config-monorepo",
"version": "0.29.0", "version": "0.31.1",
"private": true, "private": true,
"packageManager": "pnpm@7.1.0", "packageManager": "pnpm@7.1.0",
"author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)",
@@ -14,9 +14,9 @@
"devDependencies": { "devDependencies": {
"@antfu/eslint-config": "*", "@antfu/eslint-config": "*",
"bumpp": "^8.2.1", "bumpp": "^8.2.1",
"eslint": "^8.23.0", "eslint": "^8.28.0",
"eslint-plugin-antfu": "workspace:*", "eslint-plugin-antfu": "workspace:*",
"rimraf": "^3.0.2", "rimraf": "^3.0.2",
"typescript": "^4.8.2" "typescript": "^4.9.3"
} }
} }

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config", "name": "@antfu/eslint-config",
"version": "0.29.0", "version": "0.31.1",
"description": "Anthony's ESLint config", "description": "Anthony's ESLint config",
"author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)",
"license": "MIT", "license": "MIT",
@@ -17,21 +17,21 @@
}, },
"dependencies": { "dependencies": {
"@antfu/eslint-config-vue": "workspace:*", "@antfu/eslint-config-vue": "workspace:*",
"@typescript-eslint/eslint-plugin": "^5.36.1", "@typescript-eslint/eslint-plugin": "^5.45.0",
"@typescript-eslint/parser": "^5.36.1", "@typescript-eslint/parser": "^5.45.0",
"eslint-plugin-eslint-comments": "^3.2.0", "eslint-plugin-eslint-comments": "^3.2.0",
"eslint-plugin-html": "^7.1.0", "eslint-plugin-html": "^7.1.0",
"eslint-plugin-import": "^2.26.0", "eslint-plugin-import": "^2.26.0",
"eslint-plugin-jsonc": "^2.4.0", "eslint-plugin-jsonc": "^2.5.0",
"eslint-plugin-n": "^15.2.5", "eslint-plugin-n": "^15.5.1",
"eslint-plugin-promise": "^6.0.1", "eslint-plugin-promise": "^6.1.1",
"eslint-plugin-unicorn": "^43.0.2", "eslint-plugin-unicorn": "^45.0.1",
"eslint-plugin-vue": "^9.4.0", "eslint-plugin-vue": "^9.8.0",
"eslint-plugin-yml": "^1.1.0", "eslint-plugin-yml": "^1.2.0",
"jsonc-eslint-parser": "^2.1.0", "jsonc-eslint-parser": "^2.1.0",
"yaml-eslint-parser": "^1.1.0" "yaml-eslint-parser": "^1.1.0"
}, },
"devDependencies": { "devDependencies": {
"eslint": "^8.23.0" "eslint": "^8.28.0"
} }
} }

View File

@@ -285,6 +285,7 @@ module.exports = {
'require-await': 'off', 'require-await': 'off',
'no-return-assign': 'off', 'no-return-assign': 'off',
'operator-linebreak': ['error', 'before'], 'operator-linebreak': ['error', 'before'],
'max-statements-per-line': ['error', { max: 1 }],
// unicorns // unicorns
// Pass error message when throwing errors // Pass error message when throwing errors

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config-basic", "name": "@antfu/eslint-config-basic",
"version": "0.29.0", "version": "0.31.1",
"description": "", "description": "",
"author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)",
"license": "MIT", "license": "MIT",
@@ -23,17 +23,17 @@
"eslint-plugin-eslint-comments": "^3.2.0", "eslint-plugin-eslint-comments": "^3.2.0",
"eslint-plugin-html": "^7.1.0", "eslint-plugin-html": "^7.1.0",
"eslint-plugin-import": "^2.26.0", "eslint-plugin-import": "^2.26.0",
"eslint-plugin-jsonc": "^2.4.0", "eslint-plugin-jsonc": "^2.5.0",
"eslint-plugin-markdown": "^3.0.0", "eslint-plugin-markdown": "^3.0.0",
"eslint-plugin-n": "^15.2.5", "eslint-plugin-n": "^15.5.1",
"eslint-plugin-no-only-tests": "^3.1.0", "eslint-plugin-no-only-tests": "^3.1.0",
"eslint-plugin-promise": "^6.0.1", "eslint-plugin-promise": "^6.1.1",
"eslint-plugin-unicorn": "^43.0.2", "eslint-plugin-unicorn": "^45.0.1",
"eslint-plugin-yml": "^1.1.0", "eslint-plugin-yml": "^1.2.0",
"jsonc-eslint-parser": "^2.1.0", "jsonc-eslint-parser": "^2.1.0",
"yaml-eslint-parser": "^1.1.0" "yaml-eslint-parser": "^1.1.0"
}, },
"devDependencies": { "devDependencies": {
"eslint": "^8.23.0" "eslint": "^8.28.0"
} }
} }

View File

@@ -1,6 +1,6 @@
{ {
"name": "eslint-plugin-antfu", "name": "eslint-plugin-antfu",
"version": "0.29.0", "version": "0.31.1",
"license": "MIT", "license": "MIT",
"homepage": "https://github.com/antfu/eslint-config", "homepage": "https://github.com/antfu/eslint-config",
"main": "./dist/index.cjs", "main": "./dist/index.cjs",
@@ -16,11 +16,11 @@
"prepublishOnly": "nr build" "prepublishOnly": "nr build"
}, },
"dependencies": { "dependencies": {
"@typescript-eslint/utils": "^5.36.1" "@typescript-eslint/utils": "^5.45.0"
}, },
"devDependencies": { "devDependencies": {
"@types/node": "^18.11.8", "@types/node": "^18.11.9",
"unbuild": "^0.8.10", "unbuild": "^1.0.1",
"vitest": "^0.22.1" "vitest": "^0.25.3"
} }
} }

View File

@@ -4,16 +4,36 @@ import rule, { RULE_NAME } from './generic-spacing'
const valids = [ const valids = [
'type Foo<T = true> = T', 'type Foo<T = true> = T',
'type Foo<T extends true = true> = T',
` `
type Foo< type Foo<
T = true, T = true,
K = false K = false
> = T`, > = T`,
`function foo<
T
>() {}`,
'const foo = <T>(name: T) => name',
`interface Log {
foo<T>(name: T): void
}`,
`interface Log {
<T>(name: T): void
}`,
`interface Foo {
foo?: <T>(name: T) => void
}`,
] ]
const invalids = [ const invalids = [
['type Foo<T=true> = T', 'type Foo<T = true> = T'], ['type Foo<T=true> = T', 'type Foo<T = true> = T'],
['type Foo<T,K> = T', 'type Foo<T, K> = T'], ['type Foo<T,K> = T', 'type Foo<T, K> = T'],
['type Foo<T=false,K=1|2> = T', 'type Foo<T = false, K = 1|2> = T', 3], ['type Foo<T=false,K=1|2> = T', 'type Foo<T = false, K = 1|2> = T', 3],
['function foo <T>() {}', 'function foo<T>() {}'],
[`interface Log {
foo <T>(name: T): void
}`, `interface Log {
foo<T>(name: T): void
}`],
] as const ] as const
it('runs', () => { it('runs', () => {

View File

@@ -23,6 +23,22 @@ export default createEslintRule<Options, MessageIds>({
const sourceCode = context.getSourceCode() const sourceCode = context.getSourceCode()
return { return {
TSTypeParameterDeclaration: (node) => { TSTypeParameterDeclaration: (node) => {
if (!['TSCallSignatureDeclaration', 'ArrowFunctionExpression', 'TSFunctionType'].includes(node.parent.type)) {
const pre = sourceCode.text.slice(0, node.range[0])
const preSpace = pre.match(/(\s+)$/)?.[0]
// strip space before <T>
if (preSpace && preSpace.length) {
context.report({
node,
messageId: 'genericSpacingMismatch',
*fix(fixer) {
yield fixer.replaceTextRange([node.range[0] - preSpace.length, node.range[0]], '')
},
})
}
}
// add space between <T,K>
const params = node.params const params = node.params
for (let i = 1; i < params.length; i++) { for (let i = 1; i < params.length; i++) {
const prev = params[i - 1] const prev = params[i - 1]
@@ -45,10 +61,12 @@ export default createEslintRule<Options, MessageIds>({
} }
} }
}, },
// add space around = in type Foo<T = true>
TSTypeParameter: (node) => { TSTypeParameter: (node) => {
if (!node.default) if (!node.default)
return return
const from = node.name.range[1] const endNode = node.constraint || node.name
const from = endNode.range[1]
const to = node.default.range[0] const to = node.default.range[0]
if (sourceCode.text.slice(from, to) !== ' = ') { if (sourceCode.text.slice(from, to) !== ' = ') {
context.report({ context.report({
@@ -56,7 +74,7 @@ export default createEslintRule<Options, MessageIds>({
yield fixer.replaceTextRange([from, to], ' = ') yield fixer.replaceTextRange([from, to], ' = ')
}, },
loc: { loc: {
start: node.name.loc.end, start: endNode.loc.end,
end: node.default.loc.start, end: node.default.loc.start,
}, },
messageId: 'genericSpacingMismatch', messageId: 'genericSpacingMismatch',

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config-react", "name": "@antfu/eslint-config-react",
"version": "0.29.0", "version": "0.31.1",
"description": "", "description": "",
"author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)",
"license": "MIT", "license": "MIT",
@@ -20,12 +20,12 @@
}, },
"dependencies": { "dependencies": {
"@antfu/eslint-config-ts": "workspace:*", "@antfu/eslint-config-ts": "workspace:*",
"eslint-plugin-react": "^7.31.1", "eslint-plugin-react": "^7.31.11",
"eslint-plugin-react-hooks": "^4.6.0" "eslint-plugin-react-hooks": "^4.6.0"
}, },
"devDependencies": { "devDependencies": {
"eslint": "^8.23.0", "eslint": "^8.28.0",
"react": "^18.2.0", "react": "^18.2.0",
"typescript": "^4.8.2" "typescript": "^4.9.3"
} }
} }

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config-ts", "name": "@antfu/eslint-config-ts",
"version": "0.29.0", "version": "0.31.1",
"description": "", "description": "",
"author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)",
"license": "MIT", "license": "MIT",
@@ -18,10 +18,10 @@
}, },
"dependencies": { "dependencies": {
"@antfu/eslint-config-basic": "workspace:*", "@antfu/eslint-config-basic": "workspace:*",
"@typescript-eslint/eslint-plugin": "^5.36.1", "@typescript-eslint/eslint-plugin": "^5.45.0",
"@typescript-eslint/parser": "^5.36.1" "@typescript-eslint/parser": "^5.45.0"
}, },
"devDependencies": { "devDependencies": {
"eslint": "^8.23.0" "eslint": "^8.28.0"
} }
} }

View File

@@ -1,3 +1,10 @@
const { isPackageExists } = require('local-pkg')
const TS = isPackageExists('typescript')
if (!TS)
console.warn('[@antfu/eslint-config] TypeScript is not installed, fallback to JS only.')
module.exports = { module.exports = {
overrides: [ overrides: [
{ {
@@ -9,13 +16,17 @@ module.exports = {
rules: { rules: {
'no-unused-vars': 'off', 'no-unused-vars': 'off',
'no-undef': 'off', 'no-undef': 'off',
'@typescript-eslint/no-unused-vars': 'off', ...(TS
? { '@typescript-eslint/no-unused-vars': 'off' }
: null),
}, },
}, },
], ],
extends: [ extends: [
'plugin:vue/vue3-recommended', 'plugin:vue/vue3-recommended',
'@antfu/eslint-config-ts', TS
? '@antfu/eslint-config-ts'
: '@antfu/eslint-config-basic',
], ],
rules: { rules: {
'vue/max-attributes-per-line': 'off', 'vue/max-attributes-per-line': 'off',

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config-vue", "name": "@antfu/eslint-config-vue",
"version": "0.29.0", "version": "0.31.1",
"description": "", "description": "",
"author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)",
"license": "MIT", "license": "MIT",
@@ -15,10 +15,12 @@
"eslint": ">=7.4.0" "eslint": ">=7.4.0"
}, },
"dependencies": { "dependencies": {
"@antfu/eslint-config-basic": "workspace:*",
"@antfu/eslint-config-ts": "workspace:*", "@antfu/eslint-config-ts": "workspace:*",
"eslint-plugin-vue": "^9.4.0" "eslint-plugin-vue": "^9.8.0",
"local-pkg": "^0.4.2"
}, },
"devDependencies": { "devDependencies": {
"eslint": "^8.23.0" "eslint": "^8.28.0"
} }
} }

1319
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff