type-fest/source/string-slice.d.ts
2025-05-08 15:21:25 +07:00

38 lines
749 B
TypeScript

import type {Join} from './join.d.ts';
import type {ArraySlice} from './array-slice.d.ts';
import type {StringToArray} from './internal/index.d.ts';
/**
Returns a string slice of a given range, just like `String#slice()`.
@see {ArraySlice}
@example
```
import type {StringSlice} from 'type-fest';
StringSlice<'abcde', 0, 2>;
//=> 'ab'
StringSlice<'abcde', 1>;
//=> 'bcde'
StringSlice<'abcde', 0, -1>;
//=> 'abcd'
StringSlice<'abcde', -2, -1>;
//=> 'd'
```
@category String
*/
export type StringSlice<
S extends string,
Start extends number = 0,
End extends number = StringToArray<S>['length'],
> = string extends S
? string
: ArraySlice<StringToArray<S>, Start, End> extends infer R extends readonly string[]
? Join<R, ''>
: never;