mirror of
https://github.com/sindresorhus/type-fest.git
synced 2025-12-08 19:25:05 +00:00
37 lines
1.1 KiB
TypeScript
37 lines
1.1 KiB
TypeScript
import type {LiteralToPrimitive} from './literal-to-primitive';
|
|
import type {OmitIndexSignature} from './omit-index-signature';
|
|
|
|
/**
|
|
Like `LiteralToPrimitive` except it converts literal types inside an object or array deeply.
|
|
|
|
For example, given a constant object, it returns a new object type with the same keys but with all the values converted to primitives.
|
|
|
|
@see LiteralToPrimitive
|
|
|
|
Use-case: Deal with data that is imported from a JSON file.
|
|
|
|
@example
|
|
```
|
|
import type {LiteralToPrimitiveDeep, TsConfigJson} from 'type-fest';
|
|
import tsconfig from 'path/to/tsconfig.json';
|
|
|
|
function doSomethingWithTSConfig(config: LiteralToPrimitiveDeep<TsConfigJson>) { ... }
|
|
|
|
// No casting is needed to pass the type check
|
|
doSomethingWithTSConfig(tsconfig);
|
|
|
|
// If LiteralToPrimitiveDeep is not used, you need to cast the imported data like this:
|
|
doSomethingWithTSConfig(tsconfig as TsConfigJson);
|
|
```
|
|
|
|
@category Type
|
|
@category Object
|
|
*/
|
|
export type LiteralToPrimitiveDeep<T> = T extends object
|
|
? T extends Array<infer U>
|
|
? Array<LiteralToPrimitiveDeep<U>>
|
|
: {
|
|
[K in keyof OmitIndexSignature<T>]: LiteralToPrimitiveDeep<T[K]>;
|
|
}
|
|
: LiteralToPrimitive<T>;
|