Compare commits
	
		
			33 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | b8fe7fe4e7 | ||
|  | 001de3b060 | ||
|  | 761a0ce4ee | ||
|  | a9d330cac3 | ||
|  | 540786d482 | ||
|  | b876b7b1d9 | ||
|  | d463449db4 | ||
|  | 37d30e9e7d | ||
|  | 58b8383d4c | ||
|  | 35a5d3ef9d | ||
|  | f618005402 | ||
|  | a9b6d5f9ee | ||
|  | e6a4d6db8b | ||
|  | ed0f5b1d76 | ||
|  | 65222e2e3a | ||
|  | a1e890844f | ||
|  | a2de527401 | ||
|  | 6080d3f74d | ||
|  | b996c58bac | ||
|  | b8fe1fabea | ||
|  | 0ab9f88603 | ||
|  | 17670e8e38 | ||
|  | 686f285a37 | ||
|  | 2d9efd4df6 | ||
|  | b8e6cdf047 | ||
|  | 50c962197b | ||
|  | bf19dc0adb | ||
|  | 38f64ae9af | ||
|  | 22527f61de | ||
|  | 1ff53f2f04 | ||
|  | 316bbd903b | ||
|  | bce5016b53 | ||
|  | ddd34a9465 | 
| @@ -1,9 +1,10 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config-monorepo", |   "name": "@antfu/eslint-config-monorepo", | ||||||
|   "version": "0.20.2", |   "version": "0.24.2", | ||||||
|   "private": true, |   "private": true, | ||||||
|   "license": "MIT", |   "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/)", | ||||||
|  |   "license": "MIT", | ||||||
|   "scripts": { |   "scripts": { | ||||||
|     "lint": "eslint .", |     "lint": "eslint .", | ||||||
|     "prepare": "pnpm -r run stub", |     "prepare": "pnpm -r run stub", | ||||||
| @@ -12,8 +13,8 @@ | |||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@antfu/eslint-config": "*", |     "@antfu/eslint-config": "*", | ||||||
|     "bumpp": "^7.1.1", |     "bumpp": "^7.1.1", | ||||||
|     "eslint": "^8.12.0", |     "eslint": "^8.16.0", | ||||||
|     "eslint-plugin-antfu": "workspace:*", |     "eslint-plugin-antfu": "workspace:*", | ||||||
|     "typescript": "^4.6.3" |     "typescript": "^4.7.2" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,10 +1,13 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config", |   "name": "@antfu/eslint-config", | ||||||
|   "version": "0.20.2", |   "version": "0.24.2", | ||||||
|   "description": "", |   "description": "Anthony's ESLint config", | ||||||
|   "keywords": [], |  | ||||||
|   "license": "MIT", |  | ||||||
|   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", |   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", | ||||||
|  |   "license": "MIT", | ||||||
|  |   "homepage": "https://github.com/antfu/eslint-config", | ||||||
|  |   "keywords": [ | ||||||
|  |     "eslint-config" | ||||||
|  |   ], | ||||||
|   "main": "index.js", |   "main": "index.js", | ||||||
|   "files": [ |   "files": [ | ||||||
|     "index.js" |     "index.js" | ||||||
| @@ -15,24 +18,21 @@ | |||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@antfu/eslint-config-react": "workspace:*", |     "@antfu/eslint-config-react": "workspace:*", | ||||||
|     "@antfu/eslint-config-vue": "workspace:*", |     "@antfu/eslint-config-vue": "workspace:*", | ||||||
|     "@typescript-eslint/eslint-plugin": "^5.17.0", |     "@typescript-eslint/eslint-plugin": "^5.26.0", | ||||||
|     "@typescript-eslint/parser": "^5.17.0", |     "@typescript-eslint/parser": "^5.26.0", | ||||||
|     "eslint-plugin-eslint-comments": "^3.2.0", |     "eslint-plugin-eslint-comments": "^3.2.0", | ||||||
|     "eslint-plugin-html": "^6.2.0", |     "eslint-plugin-html": "^6.2.0", | ||||||
|     "eslint-plugin-import": "^2.25.4", |     "eslint-plugin-import": "^2.26.0", | ||||||
|     "eslint-plugin-jsonc": "^2.2.1", |     "eslint-plugin-jsonc": "^2.2.1", | ||||||
|     "eslint-plugin-n": "^15.1.0", |     "eslint-plugin-n": "^15.2.0", | ||||||
|     "eslint-plugin-promise": "^6.0.0", |     "eslint-plugin-promise": "^6.0.0", | ||||||
|     "eslint-plugin-unicorn": "^41.0.1", |     "eslint-plugin-unicorn": "^42.0.0", | ||||||
|     "eslint-plugin-vue": "^8.5.0", |     "eslint-plugin-vue": "^9.0.1", | ||||||
|     "eslint-plugin-yml": "^0.14.0", |     "eslint-plugin-yml": "^1.0.0", | ||||||
|     "jsonc-eslint-parser": "^2.1.0", |     "jsonc-eslint-parser": "^2.1.0", | ||||||
|     "yaml-eslint-parser": "^0.5.0" |     "yaml-eslint-parser": "^1.0.1" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "eslint": "^8.12.0" |     "eslint": "^8.16.0" | ||||||
|   }, |  | ||||||
|   "publishConfig": { |  | ||||||
|     "access": "public" |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -44,9 +44,15 @@ module.exports = { | |||||||
|       files: ['*.json', '*.json5'], |       files: ['*.json', '*.json5'], | ||||||
|       parser: 'jsonc-eslint-parser', |       parser: 'jsonc-eslint-parser', | ||||||
|       rules: { |       rules: { | ||||||
|         'quotes': ['error', 'double'], |         'jsonc/array-bracket-spacing': ['error', 'never'], | ||||||
|         'quote-props': ['error', 'always'], |         'jsonc/comma-dangle': ['error', 'never'], | ||||||
|         'comma-dangle': ['error', 'never'], |         'jsonc/comma-style': ['error', 'last'], | ||||||
|  |         'jsonc/indent': ['error', 2], | ||||||
|  |         'jsonc/key-spacing': ['error', { beforeColon: false, afterColon: true }], | ||||||
|  |         'jsonc/no-octal-escape': 'error', | ||||||
|  |         'jsonc/object-curly-newline': ['error', { multiline: true, consistent: true }], | ||||||
|  |         'jsonc/object-curly-spacing': ['error', 'always'], | ||||||
|  |         'jsonc/object-property-newline': ['error', { allowMultiplePropertiesPerLine: true }], | ||||||
|       }, |       }, | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
| @@ -65,33 +71,47 @@ module.exports = { | |||||||
|           { |           { | ||||||
|             pathPattern: '^$', |             pathPattern: '^$', | ||||||
|             order: [ |             order: [ | ||||||
|  |               'publisher', | ||||||
|               'name', |               'name', | ||||||
|  |               'displayName', | ||||||
|               'type', |               'type', | ||||||
|               'version', |               'version', | ||||||
|               'private', |               'private', | ||||||
|               'packageManager', |               'packageManager', | ||||||
|               'description', |               'description', | ||||||
|               'keywords', |  | ||||||
|               'license', |  | ||||||
|               'author', |               'author', | ||||||
|               'repository', |               'license', | ||||||
|               'funding', |               'funding', | ||||||
|  |               'homepage', | ||||||
|  |               'repository', | ||||||
|  |               'bugs', | ||||||
|  |               'keywords', | ||||||
|  |               'categories', | ||||||
|  |               'sideEffects', | ||||||
|  |               'exports', | ||||||
|               'main', |               'main', | ||||||
|               'module', |               'module', | ||||||
|               'types', |  | ||||||
|               'unpkg', |               'unpkg', | ||||||
|               'jsdelivr', |               'jsdelivr', | ||||||
|               'exports', |               'types', | ||||||
|               'files', |               'typesVersions', | ||||||
|               'bin', |               'bin', | ||||||
|               'sideEffects', |               'icon', | ||||||
|  |               'files', | ||||||
|  |               'engines', | ||||||
|  |               'activationEvents', | ||||||
|  |               'contributes', | ||||||
|               'scripts', |               'scripts', | ||||||
|               'peerDependencies', |               'peerDependencies', | ||||||
|               'peerDependenciesMeta', |               'peerDependenciesMeta', | ||||||
|               'dependencies', |               'dependencies', | ||||||
|               'optionalDependencies', |               'optionalDependencies', | ||||||
|               'devDependencies', |               'devDependencies', | ||||||
|  |               'pnpm', | ||||||
|  |               'overrides', | ||||||
|  |               'resolutions', | ||||||
|               'husky', |               'husky', | ||||||
|  |               'simple-git-hooks', | ||||||
|               'lint-staged', |               'lint-staged', | ||||||
|               'eslintConfig', |               'eslintConfig', | ||||||
|             ], |             ], | ||||||
| @@ -100,6 +120,14 @@ module.exports = { | |||||||
|             pathPattern: '^(?:dev|peer|optional|bundled)?[Dd]ependencies$', |             pathPattern: '^(?:dev|peer|optional|bundled)?[Dd]ependencies$', | ||||||
|             order: { type: 'asc' }, |             order: { type: 'asc' }, | ||||||
|           }, |           }, | ||||||
|  |           { | ||||||
|  |             pathPattern: '^exports.*$', | ||||||
|  |             order: [ | ||||||
|  |               'types', | ||||||
|  |               'import', | ||||||
|  |               'require', | ||||||
|  |             ], | ||||||
|  |           }, | ||||||
|         ], |         ], | ||||||
|       }, |       }, | ||||||
|     }, |     }, | ||||||
| @@ -135,6 +163,7 @@ module.exports = { | |||||||
|         '@typescript-eslint/no-unused-vars': 'off', |         '@typescript-eslint/no-unused-vars': 'off', | ||||||
|         '@typescript-eslint/no-use-before-define': 'off', |         '@typescript-eslint/no-use-before-define': 'off', | ||||||
|         '@typescript-eslint/no-var-requires': 'off', |         '@typescript-eslint/no-var-requires': 'off', | ||||||
|  |         '@typescript-eslint/comma-dangle': 'off', | ||||||
|         'import/no-unresolved': 'off', |         'import/no-unresolved': 'off', | ||||||
|         'no-alert': 'off', |         'no-alert': 'off', | ||||||
|         'no-console': 'off', |         'no-console': 'off', | ||||||
| @@ -182,7 +211,15 @@ module.exports = { | |||||||
|     ], |     ], | ||||||
|     'object-curly-spacing': ['error', 'always'], |     'object-curly-spacing': ['error', 'always'], | ||||||
|     'no-return-await': 'off', |     'no-return-await': 'off', | ||||||
|     'space-before-function-paren': ['error', 'never'], |     'space-before-function-paren': [ | ||||||
|  |       'error', | ||||||
|  |       { | ||||||
|  |         anonymous: 'always', | ||||||
|  |         named: 'never', | ||||||
|  |         asyncArrow: 'always', | ||||||
|  |       }, | ||||||
|  |     ], | ||||||
|  |     'no-multiple-empty-lines': ['error', { max: 1, maxBOF: 0, maxEOF: 1 }], | ||||||
|  |  | ||||||
|     // es6 |     // es6 | ||||||
|     'no-var': 'error', |     'no-var': 'error', | ||||||
| @@ -208,6 +245,7 @@ module.exports = { | |||||||
|         avoidQuotes: true, |         avoidQuotes: true, | ||||||
|       }, |       }, | ||||||
|     ], |     ], | ||||||
|  |     'prefer-exponentiation-operator': 'error', | ||||||
|     'prefer-rest-params': 'error', |     'prefer-rest-params': 'error', | ||||||
|     'prefer-spread': 'error', |     'prefer-spread': 'error', | ||||||
|     'prefer-template': 'error', |     'prefer-template': 'error', | ||||||
| @@ -250,15 +288,13 @@ module.exports = { | |||||||
|     // Uppercase regex escapes |     // Uppercase regex escapes | ||||||
|     'unicorn/escape-case': 'error', |     'unicorn/escape-case': 'error', | ||||||
|     // Array.isArray instead of instanceof |     // Array.isArray instead of instanceof | ||||||
|     'unicorn/no-array-instanceof': 'error', |     'unicorn/no-instanceof-array': 'error', | ||||||
|     // Prevent deprecated `new Buffer()` |     // Prevent deprecated `new Buffer()` | ||||||
|     'unicorn/no-new-buffer': 'error', |     'unicorn/no-new-buffer': 'error', | ||||||
|     // Keep regex literals safe! |     // Keep regex literals safe! | ||||||
|     'unicorn/no-unsafe-regex': 'off', |     'unicorn/no-unsafe-regex': 'off', | ||||||
|     // Lowercase number formatting for octal, hex, binary (0x1'error' instead of 0X1'error') |     // Lowercase number formatting for octal, hex, binary (0x1'error' instead of 0X1'error') | ||||||
|     'unicorn/number-literal-case': 'error', |     'unicorn/number-literal-case': 'error', | ||||||
|     // ** instead of Math.pow() |  | ||||||
|     'unicorn/prefer-exponentiation-operator': 'error', |  | ||||||
|     // includes over indexOf when checking for existence |     // includes over indexOf when checking for existence | ||||||
|     'unicorn/prefer-includes': 'error', |     'unicorn/prefer-includes': 'error', | ||||||
|     // String methods startsWith/endsWith instead of more complicated stuff |     // String methods startsWith/endsWith instead of more complicated stuff | ||||||
| @@ -273,6 +309,8 @@ module.exports = { | |||||||
|     'no-use-before-define': ['error', { functions: false, classes: false, variables: true }], |     'no-use-before-define': ['error', { functions: false, classes: false, variables: true }], | ||||||
|     'eslint-comments/disable-enable-pair': 'off', |     'eslint-comments/disable-enable-pair': 'off', | ||||||
|     'import/no-named-as-default-member': 'off', |     'import/no-named-as-default-member': 'off', | ||||||
|  |     'import/no-named-as-default': 'off', | ||||||
|  |     'import/namespace': 'off', | ||||||
|     'n/no-callback-literal': 'off', |     'n/no-callback-literal': 'off', | ||||||
|  |  | ||||||
|     'sort-imports': [ |     'sort-imports': [ | ||||||
| @@ -291,8 +329,8 @@ module.exports = { | |||||||
|     'yml/no-empty-document': 'off', |     'yml/no-empty-document': 'off', | ||||||
|  |  | ||||||
|     // antfu |     // antfu | ||||||
|     'antfu/no-leading-newline': 'error', |  | ||||||
|     'antfu/if-newline': 'error', |     'antfu/if-newline': 'error', | ||||||
|  |     'antfu/import-dedupe': 'error', | ||||||
|     // 'antfu/prefer-inline-type-import': 'error', |     // 'antfu/prefer-inline-type-import': 'error', | ||||||
|   }, |   }, | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,10 +1,13 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config-basic", |   "name": "@antfu/eslint-config-basic", | ||||||
|   "version": "0.20.2", |   "version": "0.24.2", | ||||||
|   "description": "", |   "description": "", | ||||||
|   "keywords": [], |  | ||||||
|   "license": "MIT", |  | ||||||
|   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", |   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", | ||||||
|  |   "license": "MIT", | ||||||
|  |   "homepage": "https://github.com/antfu/eslint-config", | ||||||
|  |   "keywords": [ | ||||||
|  |     "eslint-config" | ||||||
|  |   ], | ||||||
|   "main": "index.js", |   "main": "index.js", | ||||||
|   "files": [ |   "files": [ | ||||||
|     "*.js" |     "*.js" | ||||||
| @@ -19,20 +22,17 @@ | |||||||
|     "eslint-plugin-antfu": "workspace:*", |     "eslint-plugin-antfu": "workspace:*", | ||||||
|     "eslint-plugin-eslint-comments": "^3.2.0", |     "eslint-plugin-eslint-comments": "^3.2.0", | ||||||
|     "eslint-plugin-html": "^6.2.0", |     "eslint-plugin-html": "^6.2.0", | ||||||
|     "eslint-plugin-import": "^2.25.4", |     "eslint-plugin-import": "^2.26.0", | ||||||
|     "eslint-plugin-jsonc": "^2.2.1", |     "eslint-plugin-jsonc": "^2.2.1", | ||||||
|     "eslint-plugin-markdown": "^2.2.1", |     "eslint-plugin-markdown": "^2.2.1", | ||||||
|     "eslint-plugin-n": "^15.1.0", |     "eslint-plugin-n": "^15.2.0", | ||||||
|     "eslint-plugin-promise": "^6.0.0", |     "eslint-plugin-promise": "^6.0.0", | ||||||
|     "eslint-plugin-unicorn": "^41.0.1", |     "eslint-plugin-unicorn": "^42.0.0", | ||||||
|     "eslint-plugin-yml": "^0.14.0", |     "eslint-plugin-yml": "^1.0.0", | ||||||
|     "jsonc-eslint-parser": "^2.1.0", |     "jsonc-eslint-parser": "^2.1.0", | ||||||
|     "yaml-eslint-parser": "^0.5.0" |     "yaml-eslint-parser": "^1.0.1" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "eslint": "^8.12.0" |     "eslint": "^8.16.0" | ||||||
|   }, |  | ||||||
|   "publishConfig": { |  | ||||||
|     "access": "public" |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -202,7 +202,14 @@ module.exports = { | |||||||
|     'semi': ['error', 'never'], |     'semi': ['error', 'never'], | ||||||
|     'semi-spacing': ['error', { before: false, after: true }], |     'semi-spacing': ['error', { before: false, after: true }], | ||||||
|     'space-before-blocks': ['error', 'always'], |     'space-before-blocks': ['error', 'always'], | ||||||
|     'space-before-function-paren': ['error', 'always'], |     'space-before-function-paren': [ | ||||||
|  |       'error', | ||||||
|  |       { | ||||||
|  |         anonymous: 'always', | ||||||
|  |         named: 'never', | ||||||
|  |         asyncArrow: 'always', | ||||||
|  |       }, | ||||||
|  |     ], | ||||||
|     'space-in-parens': ['error', 'never'], |     'space-in-parens': ['error', 'never'], | ||||||
|     'space-infix-ops': 'error', |     'space-infix-ops': 'error', | ||||||
|     'space-unary-ops': ['error', { words: true, nonwords: false }], |     'space-unary-ops': ['error', { words: true, nonwords: false }], | ||||||
|   | |||||||
| @@ -2,8 +2,5 @@ | |||||||
|   "extends": "@antfu", |   "extends": "@antfu", | ||||||
|   "plugins": [ |   "plugins": [ | ||||||
|     "antfu" |     "antfu" | ||||||
|   ], |   ] | ||||||
|   "rules": { |  | ||||||
|     "antfu/no-leading-newline": "error" |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,17 +1,11 @@ | |||||||
| { | { | ||||||
|   "name": "eslint-plugin-antfu", |   "name": "eslint-plugin-antfu", | ||||||
|   "version": "0.20.2", |   "version": "0.24.2", | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|  |   "homepage": "https://github.com/antfu/eslint-config", | ||||||
|   "main": "./dist/index.cjs", |   "main": "./dist/index.cjs", | ||||||
|   "module": "./dist/index.mjs", |   "module": "./dist/index.mjs", | ||||||
|   "types": "./dist/index.d.ts", |   "types": "./dist/index.d.ts", | ||||||
|   "exports": { |  | ||||||
|     ".": { |  | ||||||
|       "require": "./dist/index.cjs", |  | ||||||
|       "import": "./dist/index.mjs", |  | ||||||
|       "types": "./dist/index.d.ts" |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "files": [ |   "files": [ | ||||||
|     "dist" |     "dist" | ||||||
|   ], |   ], | ||||||
| @@ -22,10 +16,10 @@ | |||||||
|     "prepublishOnly": "nr build" |     "prepublishOnly": "nr build" | ||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@typescript-eslint/utils": "^5.17.0" |     "@typescript-eslint/utils": "^5.26.0" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "unbuild": "^0.7.0", |     "unbuild": "^0.7.4", | ||||||
|     "vitest": "^0.8.2" |     "vitest": "^0.12.9" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,11 +1,11 @@ | |||||||
| import ifNewline from './rules/if-newline' | import ifNewline from './rules/if-newline' | ||||||
| import noLeadingNewline from './rules/no-leading-newline' | import importDedupe from './rules/import-dedupe' | ||||||
| import preferInlineTypeImport from './rules/prefer-inline-type-import' | import preferInlineTypeImport from './rules/prefer-inline-type-import' | ||||||
|  |  | ||||||
| export default { | export default { | ||||||
|   rules: { |   rules: { | ||||||
|     'no-leading-newline': noLeadingNewline, |  | ||||||
|     'if-newline': ifNewline, |     'if-newline': ifNewline, | ||||||
|  |     'import-dedupe': importDedupe, | ||||||
|     'prefer-inline-type-import': preferInlineTypeImport, |     'prefer-inline-type-import': preferInlineTypeImport, | ||||||
|   }, |   }, | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,14 +1,15 @@ | |||||||
| import { RuleTester } from '@typescript-eslint/utils/dist/ts-eslint' | import { RuleTester } from '@typescript-eslint/utils/dist/ts-eslint' | ||||||
| import { it } from 'vitest' | import { it } from 'vitest' | ||||||
| import rule, { RULE_NAME } from './no-leading-newline' | import rule, { RULE_NAME } from './import-dedupe' | ||||||
| 
 | 
 | ||||||
| const valids = [ | const valids = [ | ||||||
|   'import {} from \'foo\'', |   'import { a } from \'foo\'', | ||||||
|   `// comment
 |  | ||||||
| import {} from ''`,
 |  | ||||||
| ] | ] | ||||||
| const invalids = [ | const invalids = [ | ||||||
|   '\n\nimport {} from \'fo\'', |   [ | ||||||
|  |     'import { a, b, a, a, c, a } from \'foo\'', | ||||||
|  |     'import { a, b,   c,  } from \'foo\'', | ||||||
|  |   ], | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| it('runs', () => { | it('runs', () => { | ||||||
| @@ -19,9 +20,9 @@ it('runs', () => { | |||||||
|   ruleTester.run(RULE_NAME, rule, { |   ruleTester.run(RULE_NAME, rule, { | ||||||
|     valid: valids, |     valid: valids, | ||||||
|     invalid: invalids.map(i => ({ |     invalid: invalids.map(i => ({ | ||||||
|       code: i, |       code: i[0], | ||||||
|       output: i.trim(), |       output: i[1], | ||||||
|       errors: [{ messageId: 'noLeadingNewline' }], |       errors: [{ messageId: 'importDedupe' }, { messageId: 'importDedupe' }, { messageId: 'importDedupe' }], | ||||||
|     })), |     })), | ||||||
|   }) |   }) | ||||||
| }) | }) | ||||||
							
								
								
									
										55
									
								
								packages/eslint-plugin-antfu/src/rules/import-dedupe.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								packages/eslint-plugin-antfu/src/rules/import-dedupe.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | import { createEslintRule } from '../utils' | ||||||
|  |  | ||||||
|  | export const RULE_NAME = 'import-dedupe' | ||||||
|  | export type MessageIds = 'importDedupe' | ||||||
|  | export type Options = [] | ||||||
|  |  | ||||||
|  | export default createEslintRule<Options, MessageIds>({ | ||||||
|  |   name: RULE_NAME, | ||||||
|  |   meta: { | ||||||
|  |     type: 'problem', | ||||||
|  |     docs: { | ||||||
|  |       description: 'Fix duplication in imports', | ||||||
|  |       recommended: 'error', | ||||||
|  |     }, | ||||||
|  |     fixable: 'code', | ||||||
|  |     schema: [], | ||||||
|  |     messages: { | ||||||
|  |       importDedupe: 'Expect no duplication in imports', | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  |   defaultOptions: [], | ||||||
|  |   create: (context) => { | ||||||
|  |     return { | ||||||
|  |       ImportDeclaration(node) { | ||||||
|  |         if (node.specifiers.length <= 1) | ||||||
|  |           return | ||||||
|  |  | ||||||
|  |         const names = new Set<string>() | ||||||
|  |         node.specifiers.forEach((n) => { | ||||||
|  |           const id = n.local.name | ||||||
|  |           if (names.has(id)) { | ||||||
|  |             context.report({ | ||||||
|  |               node, | ||||||
|  |               loc: { | ||||||
|  |                 start: n.loc.end, | ||||||
|  |                 end: n.loc.start, | ||||||
|  |               }, | ||||||
|  |               messageId: 'importDedupe', | ||||||
|  |               fix(fixer) { | ||||||
|  |                 const s = n.range[0] | ||||||
|  |                 let e = n.range[1] | ||||||
|  |                 if (context.getSourceCode().text[e] === ',') | ||||||
|  |                   e += 1 | ||||||
|  |                 return fixer.removeRange([s, e]) | ||||||
|  |               }, | ||||||
|  |             }) | ||||||
|  |           } | ||||||
|  |           names.add(id) | ||||||
|  |         }) | ||||||
|  |  | ||||||
|  |         // console.log(node) | ||||||
|  |       }, | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  | }) | ||||||
| @@ -1,44 +0,0 @@ | |||||||
| import { createEslintRule } from '../utils' |  | ||||||
|  |  | ||||||
| export const RULE_NAME = 'no-leading-newline' |  | ||||||
| export type MessageIds = 'noLeadingNewline' |  | ||||||
| export type Options = [] |  | ||||||
|  |  | ||||||
| export default createEslintRule<Options, MessageIds>({ |  | ||||||
|   name: RULE_NAME, |  | ||||||
|   meta: { |  | ||||||
|     type: 'problem', |  | ||||||
|     docs: { |  | ||||||
|       description: 'Do not allow leading newline', |  | ||||||
|       recommended: 'error', |  | ||||||
|     }, |  | ||||||
|     fixable: 'whitespace', |  | ||||||
|     schema: [], |  | ||||||
|     messages: { |  | ||||||
|       noLeadingNewline: 'No leading newline allowed', |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
|   defaultOptions: [], |  | ||||||
|   create: (context) => { |  | ||||||
|     return { |  | ||||||
|       Program(node) { |  | ||||||
|         const code = context.getSourceCode() |  | ||||||
|         const match = code.text.match(/^[\s]+/)?.[0] || '' |  | ||||||
|         if (match.includes('\n')) { |  | ||||||
|           const line = match.split('\n') |  | ||||||
|           context.report({ |  | ||||||
|             node, |  | ||||||
|             loc: { |  | ||||||
|               start: { line: 0, column: 0 }, |  | ||||||
|               end: { line: line.length - 1, column: line[line.length - 1].length }, |  | ||||||
|             }, |  | ||||||
|             messageId: 'noLeadingNewline', |  | ||||||
|             fix(fixer) { |  | ||||||
|               return fixer.replaceTextRange([0, match.length], '') |  | ||||||
|             }, |  | ||||||
|           }) |  | ||||||
|         } |  | ||||||
|       }, |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
| }) |  | ||||||
| @@ -1,10 +1,13 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config-react", |   "name": "@antfu/eslint-config-react", | ||||||
|   "version": "0.20.2", |   "version": "0.24.2", | ||||||
|   "description": "", |   "description": "", | ||||||
|   "keywords": [], |  | ||||||
|   "license": "MIT", |  | ||||||
|   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", |   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", | ||||||
|  |   "license": "MIT", | ||||||
|  |   "homepage": "https://github.com/antfu/eslint-config", | ||||||
|  |   "keywords": [ | ||||||
|  |     "eslint-config" | ||||||
|  |   ], | ||||||
|   "main": "index.js", |   "main": "index.js", | ||||||
|   "files": [ |   "files": [ | ||||||
|     "index.js" |     "index.js" | ||||||
| @@ -15,16 +18,13 @@ | |||||||
|   "peerDependencies": { |   "peerDependencies": { | ||||||
|     "eslint": ">=7.4.0" |     "eslint": ">=7.4.0" | ||||||
|   }, |   }, | ||||||
|   "publishConfig": { |  | ||||||
|     "access": "public" |  | ||||||
|   }, |  | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@antfu/eslint-config-ts": "workspace:*", |     "@antfu/eslint-config-ts": "workspace:*", | ||||||
|     "eslint-plugin-react": "^7.29.4" |     "eslint-plugin-react": "^7.30.0" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "eslint": "^8.12.0", |     "eslint": "^8.16.0", | ||||||
|     "react": "^18.0.0", |     "react": "^18.1.0", | ||||||
|     "typescript": "^4.6.3" |     "typescript": "^4.7.2" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -17,7 +17,6 @@ module.exports = { | |||||||
|     'import/named': 'off', |     'import/named': 'off', | ||||||
|  |  | ||||||
|     // TS |     // TS | ||||||
|     '@typescript-eslint/semi': ['error', 'never'], |  | ||||||
|     '@typescript-eslint/ban-ts-comment': ['error', { 'ts-ignore': 'allow-with-description' }], |     '@typescript-eslint/ban-ts-comment': ['error', { 'ts-ignore': 'allow-with-description' }], | ||||||
|     '@typescript-eslint/member-delimiter-style': ['error', { multiline: { delimiter: 'none' } }], |     '@typescript-eslint/member-delimiter-style': ['error', { multiline: { delimiter: 'none' } }], | ||||||
|     '@typescript-eslint/type-annotation-spacing': ['error', {}], |     '@typescript-eslint/type-annotation-spacing': ['error', {}], | ||||||
| @@ -29,7 +28,41 @@ module.exports = { | |||||||
|     // Override JS |     // Override JS | ||||||
|     'no-useless-constructor': 'off', |     'no-useless-constructor': 'off', | ||||||
|     'indent': 'off', |     'indent': 'off', | ||||||
|     '@typescript-eslint/indent': ['error', 2], |     '@typescript-eslint/indent': ['error', 2, { | ||||||
|  |       SwitchCase: 1, | ||||||
|  |       VariableDeclarator: 1, | ||||||
|  |       outerIIFEBody: 1, | ||||||
|  |       MemberExpression: 1, | ||||||
|  |       FunctionDeclaration: { parameters: 1, body: 1 }, | ||||||
|  |       FunctionExpression: { parameters: 1, body: 1 }, | ||||||
|  |       CallExpression: { arguments: 1 }, | ||||||
|  |       ArrayExpression: 1, | ||||||
|  |       ObjectExpression: 1, | ||||||
|  |       ImportDeclaration: 1, | ||||||
|  |       flatTernaryExpressions: false, | ||||||
|  |       ignoreComments: false, | ||||||
|  |       ignoredNodes: [ | ||||||
|  |         'TemplateLiteral *', | ||||||
|  |         'JSXElement', | ||||||
|  |         'JSXElement > *', | ||||||
|  |         'JSXAttribute', | ||||||
|  |         'JSXIdentifier', | ||||||
|  |         'JSXNamespacedName', | ||||||
|  |         'JSXMemberExpression', | ||||||
|  |         'JSXSpreadAttribute', | ||||||
|  |         'JSXExpressionContainer', | ||||||
|  |         'JSXOpeningElement', | ||||||
|  |         'JSXClosingElement', | ||||||
|  |         'JSXFragment', | ||||||
|  |         'JSXOpeningFragment', | ||||||
|  |         'JSXClosingFragment', | ||||||
|  |         'JSXText', | ||||||
|  |         'JSXEmptyExpression', | ||||||
|  |         'JSXSpreadChild', | ||||||
|  |         'TSTypeParameterInstantiation', | ||||||
|  |       ], | ||||||
|  |       offsetTernaryExpressions: true, | ||||||
|  |     }], | ||||||
|     'no-unused-vars': 'off', |     'no-unused-vars': 'off', | ||||||
|     '@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: '^_' }], |     '@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: '^_' }], | ||||||
|     'no-redeclare': 'off', |     'no-redeclare': 'off', | ||||||
| @@ -42,13 +75,50 @@ module.exports = { | |||||||
|     '@typescript-eslint/comma-dangle': ['error', 'always-multiline'], |     '@typescript-eslint/comma-dangle': ['error', 'always-multiline'], | ||||||
|     'object-curly-spacing': 'off', |     'object-curly-spacing': 'off', | ||||||
|     '@typescript-eslint/object-curly-spacing': ['error', 'always'], |     '@typescript-eslint/object-curly-spacing': ['error', 'always'], | ||||||
|  |     'semi': 'off', | ||||||
|  |     '@typescript-eslint/semi': ['error', 'never'], | ||||||
|  |     'quotes': 'off', | ||||||
|  |     '@typescript-eslint/quotes': ['error', 'single'], | ||||||
|  |     'space-before-blocks': 'off', | ||||||
|  |     '@typescript-eslint/space-before-blocks': ['error', 'always'], | ||||||
|  |     'space-before-function-paren': 'off', | ||||||
|  |     '@typescript-eslint/space-before-function-paren': [ | ||||||
|  |       'error', | ||||||
|  |       { | ||||||
|  |         anonymous: 'always', | ||||||
|  |         named: 'never', | ||||||
|  |         asyncArrow: 'always', | ||||||
|  |       }, | ||||||
|  |     ], | ||||||
|  |     'space-infix-ops': 'off', | ||||||
|  |     '@typescript-eslint/space-infix-ops': 'error', | ||||||
|  |     'keyword-spacing': 'off', | ||||||
|  |     '@typescript-eslint/keyword-spacing': ['error', { before: true, after: true }], | ||||||
|  |     'comma-spacing': 'off', | ||||||
|  |     '@typescript-eslint/comma-spacing': ['error', { before: false, after: true }], | ||||||
|  |     'no-extra-parens': 'off', | ||||||
|  |     '@typescript-eslint/no-extra-parens': ['error', 'functions'], | ||||||
|  |     'no-dupe-class-members': 'off', | ||||||
|  |     '@typescript-eslint/no-dupe-class-members': 'error', | ||||||
|  |     'no-loss-of-precision': 'off', | ||||||
|  |     '@typescript-eslint/no-loss-of-precision': 'error', | ||||||
|  |     'lines-between-class-members': 'off', | ||||||
|  |     '@typescript-eslint/lines-between-class-members': ['error', 'always', { exceptAfterSingleLine: true }], | ||||||
|  |     // The following rule overrides require a parser service, aka. require a `typescript.json` path. | ||||||
|  |     // This needs to be done individually for each project, and it slows down linting significantly. | ||||||
|  |     // 'no-throw-literal': 'off', | ||||||
|  |     // '@typescript-eslint/no-throw-literal': 'error', | ||||||
|  |     // 'no-implied-eval': 'off', | ||||||
|  |     // '@typescript-eslint/no-implied-eval': 'error', | ||||||
|  |     // 'dot-notation': 'off', | ||||||
|  |     // '@typescript-eslint/dot-notation': ['error', { allowKeywords: true }], | ||||||
|  |  | ||||||
|     // off |     // off | ||||||
|     '@typescript-eslint/camelcase': 'off', |     '@typescript-eslint/naming-convention': 'off', | ||||||
|     '@typescript-eslint/explicit-function-return-type': 'off', |     '@typescript-eslint/explicit-function-return-type': 'off', | ||||||
|     '@typescript-eslint/explicit-member-accessibility': 'off', |     '@typescript-eslint/explicit-member-accessibility': 'off', | ||||||
|     '@typescript-eslint/no-explicit-any': 'off', |     '@typescript-eslint/no-explicit-any': 'off', | ||||||
|     '@typescript-eslint/no-parameter-properties': 'off', |     '@typescript-eslint/parameter-properties': 'off', | ||||||
|     '@typescript-eslint/no-empty-interface': 'off', |     '@typescript-eslint/no-empty-interface': 'off', | ||||||
|     '@typescript-eslint/ban-ts-ignore': 'off', |     '@typescript-eslint/ban-ts-ignore': 'off', | ||||||
|     '@typescript-eslint/no-empty-function': 'off', |     '@typescript-eslint/no-empty-function': 'off', | ||||||
| @@ -56,5 +126,6 @@ module.exports = { | |||||||
|     '@typescript-eslint/explicit-module-boundary-types': 'off', |     '@typescript-eslint/explicit-module-boundary-types': 'off', | ||||||
|     '@typescript-eslint/ban-types': 'off', |     '@typescript-eslint/ban-types': 'off', | ||||||
|     '@typescript-eslint/no-namespace': 'off', |     '@typescript-eslint/no-namespace': 'off', | ||||||
|  |     '@typescript-eslint/triple-slash-reference': 'off', | ||||||
|   }, |   }, | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,27 +1,27 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config-ts", |   "name": "@antfu/eslint-config-ts", | ||||||
|   "version": "0.20.2", |   "version": "0.24.2", | ||||||
|   "description": "", |   "description": "", | ||||||
|   "keywords": [], |  | ||||||
|   "license": "MIT", |  | ||||||
|   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", |   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", | ||||||
|  |   "license": "MIT", | ||||||
|  |   "homepage": "https://github.com/antfu/eslint-config", | ||||||
|  |   "keywords": [ | ||||||
|  |     "eslint-config" | ||||||
|  |   ], | ||||||
|   "main": "index.js", |   "main": "index.js", | ||||||
|   "files": [ |   "files": [ | ||||||
|     "index.js" |     "index.js" | ||||||
|   ], |   ], | ||||||
|   "publishConfig": { |  | ||||||
|     "access": "public" |  | ||||||
|   }, |  | ||||||
|   "peerDependencies": { |   "peerDependencies": { | ||||||
|     "eslint": ">=7.4.0", |     "eslint": ">=7.4.0", | ||||||
|     "typescript": ">=3.9" |     "typescript": ">=3.9" | ||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@antfu/eslint-config-basic": "workspace:*", |     "@antfu/eslint-config-basic": "workspace:*", | ||||||
|     "@typescript-eslint/eslint-plugin": "^5.17.0", |     "@typescript-eslint/eslint-plugin": "^5.26.0", | ||||||
|     "@typescript-eslint/parser": "^5.17.0" |     "@typescript-eslint/parser": "^5.26.0" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "eslint": "^8.12.0" |     "eslint": "^8.16.0" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -23,6 +23,7 @@ module.exports = { | |||||||
|     'vue/require-prop-types': 'off', |     'vue/require-prop-types': 'off', | ||||||
|     'vue/require-default-prop': 'off', |     'vue/require-default-prop': 'off', | ||||||
|     'vue/multi-word-component-names': 'off', |     'vue/multi-word-component-names': 'off', | ||||||
|  |     'vue/prefer-import-from-vue': 'off', | ||||||
|  |  | ||||||
|     // reactivity transform |     // reactivity transform | ||||||
|     'vue/no-setup-props-destructure': 'off', |     'vue/no-setup-props-destructure': 'off', | ||||||
| @@ -30,5 +31,68 @@ module.exports = { | |||||||
|     'vue/component-tags-order': ['error', { |     'vue/component-tags-order': ['error', { | ||||||
|       order: ['script', 'template', 'style'], |       order: ['script', 'template', 'style'], | ||||||
|     }], |     }], | ||||||
|  |     'vue/block-tag-newline': ['error', { | ||||||
|  |       singleline: 'always', | ||||||
|  |       multiline: 'always', | ||||||
|  |     }], | ||||||
|  |     'vue/component-name-in-template-casing': ['error', 'PascalCase'], | ||||||
|  |     'vue/component-options-name-casing': ['error', 'PascalCase'], | ||||||
|  |     'vue/custom-event-name-casing': ['error', 'camelCase'], | ||||||
|  |     'vue/define-macros-order': ['error', { | ||||||
|  |       order: ['defineProps', 'defineEmits'], | ||||||
|  |     }], | ||||||
|  |     'vue/html-comment-content-spacing': ['error', 'always', { | ||||||
|  |       exceptions: ['-'], | ||||||
|  |     }], | ||||||
|  |     'vue/no-restricted-v-bind': ['error', '/^v-/'], | ||||||
|  |     'vue/no-useless-v-bind': 'error', | ||||||
|  |     'vue/no-v-text-v-html-on-component': 'error', | ||||||
|  |     'vue/padding-line-between-blocks': ['error', 'always'], | ||||||
|  |     'vue/prefer-separate-static-class': 'error', | ||||||
|  |  | ||||||
|  |     // extensions | ||||||
|  |     'vue/array-bracket-spacing': ['error', 'never'], | ||||||
|  |     'vue/arrow-spacing': ['error', { before: true, after: true }], | ||||||
|  |     'vue/block-spacing': ['error', 'always'], | ||||||
|  |     'vue/brace-style': ['error', 'stroustrup', { allowSingleLine: true }], | ||||||
|  |     'vue/comma-dangle': ['error', 'always-multiline'], | ||||||
|  |     'vue/comma-spacing': ['error', { before: false, after: true }], | ||||||
|  |     'vue/comma-style': ['error', 'last'], | ||||||
|  |     'vue/dot-location': ['error', 'property'], | ||||||
|  |     'vue/dot-notation': ['error', { allowKeywords: true }], | ||||||
|  |     'vue/eqeqeq': ['error', 'smart'], | ||||||
|  |     // 'vue/func-call-spacing': ['off', 'never'], | ||||||
|  |     'vue/key-spacing': ['error', { beforeColon: false, afterColon: true }], | ||||||
|  |     'vue/keyword-spacing': ['error', { before: true, after: true }], | ||||||
|  |     'vue/no-constant-condition': 'warn', | ||||||
|  |     'vue/no-empty-pattern': 'error', | ||||||
|  |     'vue/no-extra-parens': ['error', 'functions'], | ||||||
|  |     'vue/no-irregular-whitespace': 'error', | ||||||
|  |     'vue/no-loss-of-precision': 'error', | ||||||
|  |     'vue/no-restricted-syntax': [ | ||||||
|  |       'error', | ||||||
|  |       'DebuggerStatement', | ||||||
|  |       'LabeledStatement', | ||||||
|  |       'WithStatement', | ||||||
|  |     ], | ||||||
|  |     'vue/no-sparse-arrays': 'error', | ||||||
|  |     'vue/object-curly-newline': ['error', { multiline: true, consistent: true }], | ||||||
|  |     'vue/object-curly-spacing': ['error', 'always'], | ||||||
|  |     'vue/object-property-newline': ['error', { allowMultiplePropertiesPerLine: true }], | ||||||
|  |     'vue/object-shorthand': [ | ||||||
|  |       'error', | ||||||
|  |       'always', | ||||||
|  |       { | ||||||
|  |         ignoreConstructors: false, | ||||||
|  |         avoidQuotes: true, | ||||||
|  |       }, | ||||||
|  |     ], | ||||||
|  |     'vue/operator-linebreak': ['error', 'before'], | ||||||
|  |     'vue/prefer-template': 'error', | ||||||
|  |     'vue/quote-props': ['error', 'consistent-as-needed'], | ||||||
|  |     'vue/space-in-parens': ['error', 'never'], | ||||||
|  |     'vue/space-infix-ops': 'error', | ||||||
|  |     'vue/space-unary-ops': ['error', { words: true, nonwords: false }], | ||||||
|  |     'vue/template-curly-spacing': 'error', | ||||||
|   }, |   }, | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,10 +1,12 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config-vue", |   "name": "@antfu/eslint-config-vue", | ||||||
|   "version": "0.20.2", |   "version": "0.24.2", | ||||||
|   "description": "", |   "description": "", | ||||||
|   "keywords": [], |  | ||||||
|   "license": "MIT", |  | ||||||
|   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", |   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", | ||||||
|  |   "license": "MIT", | ||||||
|  |   "keywords": [ | ||||||
|  |     "eslint-config" | ||||||
|  |   ], | ||||||
|   "main": "index.js", |   "main": "index.js", | ||||||
|   "files": [ |   "files": [ | ||||||
|     "index.js" |     "index.js" | ||||||
| @@ -12,14 +14,11 @@ | |||||||
|   "peerDependencies": { |   "peerDependencies": { | ||||||
|     "eslint": ">=7.4.0" |     "eslint": ">=7.4.0" | ||||||
|   }, |   }, | ||||||
|   "publishConfig": { |  | ||||||
|     "access": "public" |  | ||||||
|   }, |  | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@antfu/eslint-config-ts": "workspace:*", |     "@antfu/eslint-config-ts": "workspace:*", | ||||||
|     "eslint-plugin-vue": "^8.5.0" |     "eslint-plugin-vue": "^9.0.1" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "eslint": "^8.12.0" |     "eslint": "^8.16.0" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										1005
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1005
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Reference in New Issue
	
	Block a user