Sha256: b0cefbc19466a38f5883079f0845babcb856637f7d4f3f594b746d39b74390f7

Contents?: true

Size: 940 Bytes

Versions: 28

Compression:

Stored size: 940 Bytes

Contents

import type {Except} from './except';
import type {Simplify} from './simplify';

/**
Create a type that makes the given keys optional. The remaining keys are kept as is. The sister of the `SetRequired` type.

Use-case: You want to define a single model where the only thing that changes is whether or not some of the keys are optional.

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

type Foo = {
	a: number;
	b?: string;
	c: boolean;
}

type SomeOptional = SetOptional<Foo, 'b' | 'c'>;
// type SomeOptional = {
// 	a: number;
// 	b?: string; // Was already optional and still is.
// 	c?: boolean; // Is now optional.
// }
```

@category Object
*/
export type SetOptional<BaseType, Keys extends keyof BaseType> =
	Simplify<
	// Pick just the keys that are readonly from the base type.
	Except<BaseType, Keys> &
	// Pick the keys that should be mutable from the base type and make them mutable.
	Partial<Pick<BaseType, Keys>>
	>;

Version data entries

28 entries across 28 versions & 2 rubygems

Version Path
clapton-0.0.26 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.25 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.24 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.23 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.22 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.21 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.20 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.19 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.18 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.17 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.16 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.15 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.14 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.13 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.12 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.11 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.10 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.9 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.8 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts
clapton-0.0.7 lib/clapton/javascripts/node_modules/type-fest/source/set-optional.d.ts