Skip to main content

prefer-type-fest-value-of

Require TypeFest ValueOf<T> over direct T[keyof T] indexed-access unions when extracting object value unions.

Targeted pattern scopeโ€‹

This rule narrows matching to indexed-access type shapes that are semantically equivalent to ValueOf<T>.

  • Type-level indexed access patterns shaped like T[keyof T].

Indexed accesses with additional constraints or non-equivalent key domains are intentionally excluded.

What this rule reportsโ€‹

This rule reports T[keyof T]-style indexed-access aliases that should use ValueOf<T>.

  • Type-level indexed access patterns shaped like T[keyof T].

Why this rule existsโ€‹

ValueOf<T> is clearer and more intent-revealing than repeating indexed-access unions. It also keeps value-union typing conventions consistent with other TypeFest-based utility types in the codebase.

โŒ Incorrectโ€‹

type Values = User[keyof User];

โœ… Correctโ€‹

type Values = ValueOf<User>;

Behavior and migration notesโ€‹

  • ValueOf<T> replaces raw T[keyof T] value-union extraction patterns.
  • Use keyed form ValueOf<T, K> when you need a subset of value types.
  • Standardize on this alias in shared type utilities to avoid repeated indexed-access spelling.

Additional examplesโ€‹

โŒ Incorrect โ€” Additional exampleโ€‹

type StatusValue = StatusMap[keyof StatusMap];

โœ… Correct โ€” Additional exampleโ€‹

type StatusValue = ValueOf<StatusMap>;

โœ… Correct โ€” Repository-wide usageโ€‹

type Selected = ValueOf<User, "id" | "email">;

ESLint flat config exampleโ€‹

import typefest from "eslint-plugin-typefest";

export default [
{
plugins: { typefest },
rules: {
"typefest/prefer-type-fest-value-of": "error",
},
},
];

When not to use itโ€‹

Disable this rule if explicit indexed-access expressions are required in a published API.

Package documentationโ€‹

TypeFest package documentation:

Source file: source/value-of.d.ts

/**
Create a union of the given object's values, and optionally specify which keys to get the values from.

Please upvote [this issue](https://github.com/microsoft/TypeScript/issues/31438) if you want to have this type as a built-in in TypeScript.

@example
```
import type {ValueOf} from 'type-fest';

type A = ValueOf<{id: number; name: string; active: boolean}>;
//=> string | number | boolean

type B = ValueOf<{id: number; name: string; active: boolean}, 'name'>;
//=> string

type C = ValueOf<{id: number; name: string; active: boolean}, 'id' | 'name'>;
//=> string | number
```

@category Object
*/

Rule catalog ID: R074

Further readingโ€‹

Adoption resourcesโ€‹