From bf0f96fb05492c89dc9f6865e94c9b44455a6bd9 Mon Sep 17 00:00:00 2001 From: Shahar Dawn Or Date: Tue, 24 Jan 2023 14:53:54 +0700 Subject: [PATCH] feat: @typescript-eslint/consistent-type-{imports/exports} BREAKING CHANGE: @typescript-eslint/consistent-type-{imports/exports} Co-authored-by: Rostislav Simonik --- src/eslint-config-standard.ts | 2 +- src/index.test.ts | 14 ++++++++++---- src/index.ts | 10 +++++++++- 3 files changed, 20 insertions(+), 6 deletions(-) diff --git a/src/eslint-config-standard.ts b/src/eslint-config-standard.ts index c01f9086..42d5ac6d 100644 --- a/src/eslint-config-standard.ts +++ b/src/eslint-config-standard.ts @@ -1,5 +1,5 @@ import config from 'eslint-config-standard/.eslintrc.json' -import { Linter } from 'eslint' +import { type Linter } from 'eslint' const casted = config as unknown as Linter.Config diff --git a/src/index.test.ts b/src/index.test.ts index 4902abbb..3916ba94 100644 --- a/src/index.test.ts +++ b/src/index.test.ts @@ -3,7 +3,7 @@ import exported from '.' import configStandard from './eslint-config-standard' import { rules as typescriptEslintRules } from '@typescript-eslint/eslint-plugin' import standardPkg from 'eslint-config-standard/package.json' -import { NormalizedPackageJson } from 'read-pkg-up' +import type { NormalizedPackageJson, readPackageUp } from 'read-pkg-up' import { Linter } from 'eslint' import { readFile } from 'fs/promises' import { resolve } from 'path' @@ -21,7 +21,7 @@ interface PkgDetails { } const getPkgDetails = async (): Promise => { - const readPkgUp: typeof import('read-pkg-up')['readPackageUp'] = (await inclusion('read-pkg-up')).readPackageUp + const readPkgUp: typeof readPackageUp = (await inclusion('read-pkg-up')).readPackageUp const readResult = await readPkgUp() if (readResult === undefined) { throw new Error() } const ourPkg = readResult.packageJson @@ -162,6 +162,14 @@ test('export', (t): void => { } ], '@typescript-eslint/consistent-type-definitions': ['error', 'interface'], + '@typescript-eslint/consistent-type-exports': ['error', { + fixMixedExportsWithInlineTypeSpecifier: true + }], + '@typescript-eslint/consistent-type-imports': ['error', { + prefer: 'type-imports', + disallowTypeAnnotations: true, + fixStyle: 'inline-type-imports' + }], '@typescript-eslint/dot-notation': ['error', { allowKeywords: true }], '@typescript-eslint/explicit-function-return-type': ['error', { allowExpressions: true, @@ -421,8 +429,6 @@ test('all plugin rules are considered', (t) => { // and then fail upon plugin upgrades where new rules are released. const notYetConsideredRules: string[] = [ 'class-literal-property-style', - 'consistent-type-exports', - 'consistent-type-imports', 'default-param-last', 'explicit-member-accessibility', 'explicit-module-boundary-types', diff --git a/src/index.ts b/src/index.ts index b844d299..436c5452 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,5 +1,5 @@ import configStandard from './eslint-config-standard' -import { Linter } from 'eslint' +import { type Linter } from 'eslint' const equivalents = [ 'comma-spacing', @@ -149,6 +149,14 @@ const config: Linter.Config = { } ], '@typescript-eslint/consistent-type-definitions': ['error', 'interface'], + '@typescript-eslint/consistent-type-exports': ['error', { + fixMixedExportsWithInlineTypeSpecifier: true + }], + '@typescript-eslint/consistent-type-imports': ['error', { + prefer: 'type-imports', + disallowTypeAnnotations: true, + fixStyle: 'inline-type-imports' + }], '@typescript-eslint/explicit-function-return-type': ['error', { allowExpressions: true, allowHigherOrderFunctions: true,