Sha256: 1dac9649d09ffda3912dae3d77a2c94211da01c9b6ee203c4acef0bfaff94083
Contents?: true
Size: 1.77 KB
Versions: 31
Compression:
Stored size: 1.77 KB
Contents
import {WordSeparators} from '../source/utilities'; import {Split} from './utilities'; /** Step by step takes the first item in an array literal, formats it and adds it to a string literal, and then recursively appends the remainder. Only to be used by `CamelCaseStringArray<>`. @see CamelCaseStringArray */ type InnerCamelCaseStringArray<Parts extends any[], PreviousPart> = Parts extends [`${infer FirstPart}`, ...infer RemainingParts] ? FirstPart extends undefined ? '' : FirstPart extends '' ? InnerCamelCaseStringArray<RemainingParts, PreviousPart> : `${PreviousPart extends '' ? FirstPart : Capitalize<FirstPart>}${InnerCamelCaseStringArray<RemainingParts, FirstPart>}` : ''; /** Starts fusing the output of `Split<>`, an array literal of strings, into a camel-cased string literal. It's separate from `InnerCamelCaseStringArray<>` to keep a clean API outwards to the rest of the code. @see Split */ type CamelCaseStringArray<Parts extends string[]> = Parts extends [`${infer FirstPart}`, ...infer RemainingParts] ? Uncapitalize<`${FirstPart}${InnerCamelCaseStringArray<RemainingParts, FirstPart>}`> : never; /** Convert a string literal to camel-case. This can be useful when, for example, converting some kebab-cased command-line flags or a snake-cased database result. @example ``` import {CamelCase} from 'type-fest'; // Simple const someVariable: CamelCase<'foo-bar'> = 'fooBar'; // Advanced type CamelCasedProps<T> = { [K in keyof T as CamelCase<K>]: T[K] }; interface RawOptions { 'dry-run': boolean; 'full_family_name': string; foo: number; } const dbResult: CamelCasedProps<ModelProps> = { dryRun: true, fullFamilyName: 'bar.js', foo: 123 }; ``` */ export type CamelCase<K> = K extends string ? CamelCaseStringArray<Split<K, WordSeparators>> : K;
Version data entries
31 entries across 31 versions & 3 rubygems