mirror of
https://github.com/sindresorhus/type-fest.git
synced 2025-12-08 19:25:05 +00:00
47 lines
1.0 KiB
TypeScript
47 lines
1.0 KiB
TypeScript
import type {ConditionalKeys} from './conditional-keys.d.ts';
|
|
|
|
/**
|
|
Pick keys from the shape that matches the given `Condition`.
|
|
|
|
This is useful when you want to create a new type from a specific subset of an existing type. For example, you might want to pick all the primitive properties from a class and form a new automatically derived type.
|
|
|
|
@example
|
|
```
|
|
import type {Primitive, ConditionalPick} from 'type-fest';
|
|
|
|
class Awesome {
|
|
constructor(public name: string, public successes: number, public failures: bigint) {}
|
|
|
|
run() {
|
|
// do something
|
|
}
|
|
}
|
|
|
|
type PickPrimitivesFromAwesome = ConditionalPick<Awesome, Primitive>;
|
|
//=> {name: string; successes: number; failures: bigint}
|
|
```
|
|
|
|
@example
|
|
```
|
|
import type {ConditionalPick} from 'type-fest';
|
|
|
|
type Example = {
|
|
a: string;
|
|
b: string | number;
|
|
c: () => void;
|
|
d: {};
|
|
};
|
|
|
|
type StringKeysOnly = ConditionalPick<Example, string>;
|
|
//=> {a: string}
|
|
```
|
|
|
|
@category Object
|
|
*/
|
|
export type ConditionalPick<Base, Condition> = Pick<
|
|
Base,
|
|
ConditionalKeys<Base, Condition>
|
|
>;
|
|
|
|
export {};
|