Sha256: a3cd30ebae3d0217b6b3204245719fc2c2f29d03b626905cac7127e1fb70e79c

Contents?: true

Size: 1.73 KB

Versions: 28

Compression:

Stored size: 1.73 KB

Contents

import type {RequiredKeysOf} from './required-keys-of';
import type {Simplify} from './simplify';

type SpreadObject<FirstType extends object, SecondType extends object> = {
	[Key in keyof FirstType]: Key extends keyof SecondType
		? FirstType[Key] | Required<SecondType>[Key]
		: FirstType[Key];
} & Pick<
SecondType,
RequiredKeysOf<SecondType> | Exclude<keyof SecondType, keyof FirstType>
>;

type TupleOrArray = readonly [...unknown[]];

type SpreadTupleOrArray<
	FirstType extends TupleOrArray,
	SecondType extends TupleOrArray,
> = Array<FirstType[number] | SecondType[number]>;

type Spreadable = object | TupleOrArray;

/**
Mimic the type inferred by TypeScript when merging two objects or two arrays/tuples using the spread syntax.

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

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

type Bar = {
	b?: number;
	c: boolean;
};

const foo = {a: 1, b: '2'};
const bar = {c: false};
const fooBar = {...foo, ...bar};

type FooBar = Spread<Foo, Bar>;
// type FooBar = {
// 	a: number;
// 	b?: string | number | undefined;
// 	c: boolean;
// }

const baz = (argument: FooBar) => {
	// Do something
}

baz(fooBar);
```

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

const foo = [1, 2, 3];
const bar = ['4', '5', '6'];

const fooBar = [...foo, ...bar];
type FooBar = Spread<typeof foo, typeof bar>;
// FooBar = (string | number)[]

const baz = (argument: FooBar) => {
	// Do something
};

baz(fooBar);
```

@category Object
*/
export type Spread<
	FirstType extends Spreadable,
	SecondType extends Spreadable,
> = FirstType extends TupleOrArray
	? SecondType extends TupleOrArray
		? SpreadTupleOrArray<FirstType, SecondType>
		: Simplify<SpreadObject<FirstType, SecondType>>
	: Simplify<SpreadObject<FirstType, SecondType>>;

Version data entries

28 entries across 28 versions & 2 rubygems

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