type-fest/source/readonly-keys-of.d.ts
2025-11-30 04:44:57 +07:00

39 lines
888 B
TypeScript

import type {IsReadonlyKeyOf} from './is-readonly-key-of.d.ts';
/**
Extract all readonly keys from the given type.
This is useful when you want to create a new type that contains readonly keys only.
@example
```
import type {ReadonlyKeysOf} from 'type-fest';
type User = {
name: string;
surname: string;
readonly id: number;
};
type UpdateResponse<Entity extends object> = Pick<Entity, ReadonlyKeysOf<Entity>>;
const update1: UpdateResponse<User> = {
id: 123,
};
```
@category Utilities
*/
export type ReadonlyKeysOf<Type extends object> =
Type extends unknown // For distributing `Type`
? (keyof {[Key in keyof Type as
IsReadonlyKeyOf<Type, Key> extends false
? never
: Key
]: never
}) & keyof Type // Intersect with `keyof Type` to ensure result of `ReadonlyKeysOf<Type>` is always assignable to `keyof Type`
: never; // Should never happen
export {};