Sha256: 6ef829366514e4a8f75ce55fa390ebe080810b347e6f4a87bbeecb41e612c079

Contents?: true

Size: 1.99 KB

Versions: 33

Compression:

Stored size: 1.99 KB

Contents

import type {WordSeparators} from '../source/internal';
import type {Split} from './split';

/**
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 readonly 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 readonly 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 type {CamelCase} from 'type-fest';

// Simple

const someVariable: CamelCase<'foo-bar'> = 'fooBar';

// Advanced

type CamelCasedProperties<T> = {
	[K in keyof T as CamelCase<K>]: T[K]
};

interface RawOptions {
	'dry-run': boolean;
	'full_family_name': string;
	foo: number;
	BAR: string;
	QUZ_QUX: number;
	'OTHER-FIELD': boolean;
}

const dbResult: CamelCasedProperties<RawOptions> = {
	dryRun: true,
	fullFamilyName: 'bar.js',
	foo: 123,
	bar: 'foo',
	quzQux: 6,
	otherField: false
};
```

@category Change case
@category Template literal
*/
export type CamelCase<K> = K extends string ? CamelCaseStringArray<Split<K extends Uppercase<K> ? Lowercase<K> : K, WordSeparators>> : K;

Version data entries

33 entries across 33 versions & 1 rubygems

Version Path
immosquare-cleaner-0.1.60 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.59 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.58 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.57 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.56 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.55 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.54 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.53 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.52 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.51 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.50 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.49 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.48 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.47 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.46 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.45 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.44 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.43 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.42 node_modules/type-fest/source/camel-case.d.ts
immosquare-cleaner-0.1.41 node_modules/type-fest/source/camel-case.d.ts