persona-community-5/.pnpm-store/v3/files/72/968dabc791339aa16ce0fcf143df07778babbd65b895ed67faf5b1ad03a2898e7b7b464fd069b407f76f79501eac8b1a1c1b067b1e43dec274d9b05b7111b8
rdev-worker a1d0d1bf1c
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
build: /implement-feature community-ui --requirements 'Build the React commu...
2026-02-24 08:22:30 +00:00

42 lines
765 B
Plaintext

/**
Returns a boolean for whether the given number is a float, like `1.5` or `-1.5`.
Use-case:
- If you want to make a conditional branch based on the result of whether a number is a float or not.
@example
```
import type {IsFloat, PositiveInfinity} from "type-fest";
type A = IsFloat<1.5>;
//=> true
type B = IsFloat<-1.5>;
//=> true
type C = IsFloat<1e-7>;
//=> true
type D = IsFloat<1.0>;
//=> false
type E = IsFloat<PositiveInfinity>;
//=> false
type F = IsFloat<1.23e+21>;
//=> false
```
@category Type Guard
@category Numeric
*/
export type IsFloat<T> = T extends number
? `${T}` extends `${number}e${infer E extends '-' | '+'}${number}`
? E extends '-'
? true
: false
: `${T}` extends `${number}.${number}`
? true
: false
: false;