mirror of
https://github.com/sindresorhus/type-fest.git
synced 2025-12-08 19:25:05 +00:00
93 lines
2.3 KiB
TypeScript
93 lines
2.3 KiB
TypeScript
import type {ApplyDefaultOptions} from './internal/index.d.ts';
|
|
import type {Words, WordsOptions} from './words.d.ts';
|
|
|
|
/**
|
|
CamelCase options.
|
|
|
|
@see {@link CamelCase}
|
|
*/
|
|
export type CamelCaseOptions = WordsOptions & {
|
|
/**
|
|
Whether to preserved consecutive uppercase letter.
|
|
|
|
@default false
|
|
*/
|
|
preserveConsecutiveUppercase?: boolean;
|
|
};
|
|
|
|
export type _DefaultCamelCaseOptions = {
|
|
splitOnNumbers: true;
|
|
preserveConsecutiveUppercase: false;
|
|
};
|
|
|
|
/**
|
|
Convert an array of words to camel-case.
|
|
*/
|
|
type CamelCaseFromArray<
|
|
Words extends string[],
|
|
Options extends Required<CamelCaseOptions>,
|
|
OutputString extends string = '',
|
|
> = Words extends [
|
|
infer FirstWord extends string,
|
|
...infer RemainingWords extends string[],
|
|
]
|
|
? Options['preserveConsecutiveUppercase'] extends true
|
|
? `${Capitalize<FirstWord>}${CamelCaseFromArray<RemainingWords, Options>}`
|
|
: `${Capitalize<Lowercase<FirstWord>>}${CamelCaseFromArray<RemainingWords, Options>}`
|
|
: OutputString;
|
|
|
|
/**
|
|
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.
|
|
|
|
By default, consecutive uppercase letter are preserved. See {@link CamelCaseOptions.preserveConsecutiveUppercase preserveConsecutiveUppercase} option to change this behaviour.
|
|
|
|
@example
|
|
```
|
|
import type {CamelCase} from 'type-fest';
|
|
|
|
// Simple
|
|
|
|
const someVariable: CamelCase<'foo-bar'> = 'fooBar';
|
|
const preserveConsecutiveUppercase: CamelCase<'foo-BAR-baz', {preserveConsecutiveUppercase: true}> = 'fooBARBaz';
|
|
|
|
// Advanced
|
|
|
|
type CamelCasedProperties<T> = {
|
|
[K in keyof T as CamelCase<K>]: T[K]
|
|
};
|
|
|
|
type 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<Type, Options extends CamelCaseOptions = {}> = Type extends string
|
|
? string extends Type
|
|
? Type
|
|
: Uncapitalize<CamelCaseFromArray<
|
|
Words<Type extends Uppercase<Type> ? Lowercase<Type> : Type, Options>,
|
|
ApplyDefaultOptions<CamelCaseOptions, _DefaultCamelCaseOptions, Options>
|
|
>>
|
|
: Type;
|
|
|
|
export {};
|